/* =============================================
   OLPA THEME — COMPONENT STYLES
   Cards, Badges, Buttons, Forms, Benefits
   ============================================= */

/* =============================================
   BADGES
   ============================================= */
.badge { font-family: var(--font-display); font-size: var(--fs-badge); font-weight: var(--fw-badge); letter-spacing: var(--ls-nav); text-transform: uppercase; padding: 3px 8px; border-radius: var(--radius-badge); display: inline-flex; align-items: center; gap: 3px; }
.badge-discount { background: var(--red); color: #fff; }
.badge-stock-ok { background: rgba(34,197,94,0.15); color: #4ade80; border: 1px solid rgba(34,197,94,0.3); }
.badge-stock-low { background: rgba(245,166,35,0.15); color: var(--gold); border: 1px solid rgba(245,166,35,0.3); }
.badge-new { background: rgba(99,179,237,0.15); color: #63b3ed; border: 1px solid rgba(99,179,237,0.3); }
.badge-hot { background: rgba(245,101,31,0.2); color: #f97316; border: 1px solid rgba(245,101,31,0.3); }

/* =============================================
   PRODUCT CARD
   ============================================= */
.product-card { background: var(--dark2); border: 1px solid var(--border); border-radius: var(--radius-card); overflow: hidden; display: flex; flex-direction: column; transition: transform .25s, border-color .25s, box-shadow .25s; position: relative; }
.product-card:hover { transform: translateY(-4px); border-color: var(--red-glow); box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(227,27,35,0.1); }

.card-badges { position: absolute; top: 12px; left: 12px; display: flex; flex-direction: column; gap: 5px; z-index: 2; }

.card-image { height: var(--card-image-height); background: var(--card-bg); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.card-image a { display: flex; width: 100%; height: 100%; align-items: center; justify-content: center; }
.card-product-img { width: 100%; height: 100%; object-fit: cover; object-position: center bottom; transition: transform .35s ease, filter .35s ease; filter: drop-shadow(0 6px 18px rgba(0,0,0,0.7)) drop-shadow(0 0 12px rgba(227,27,35,0.15)); position: relative; z-index: 1; }
.product-card:hover .card-product-img { transform: scale(1.07) translateY(-4px); filter: drop-shadow(0 10px 24px rgba(0,0,0,0.8)) drop-shadow(0 0 20px var(--red-glow)); }

.card-brand-stripe { position: absolute; bottom: 0; left: 0; right: 0; height: var(--brand-stripe-height); background: var(--dark4); border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: center; z-index: 2; }
.card-brand-name { font-family: var(--font-display); font-weight: var(--fw-hero); font-size: var(--fs-nav); letter-spacing: 0.12em; text-transform: uppercase; color: var(--grey1); }

.card-body { padding: 13px 14px 0; flex: 1; display: flex; flex-direction: column; }
.card-model { font-family: var(--font-display); font-weight: var(--fw-heading); font-size: var(--fs-body); line-height: var(--lh-heading); color: var(--white); margin-bottom: 4px; }
.card-size { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-nav); color: var(--red); letter-spacing: 0.04em; margin-bottom: 6px; }

.card-price-block { margin-bottom: 10px; }
.card-price-old { font-size: var(--fs-price-old); color: var(--grey3); text-decoration: line-through; margin-bottom: 2px; }
.card-price-current { font-family: var(--font-display); font-weight: var(--fw-hero); font-size: var(--fs-price); color: var(--white); line-height: 1; margin-bottom: 4px; }
.card-price-cuotas { font-family: var(--font-display); font-size: var(--fs-cuotas); font-weight: 700; color: var(--gold); letter-spacing: 0.02em; display: flex; align-items: center; gap: 4px; }

.card-footer { padding: 10px 14px 14px; display: flex; flex-direction: column; gap: 0; }

/* =============================================
   BUTTONS
   ============================================= */
.btn-cart { background: var(--red); color: #fff; font-family: var(--font-button); font-weight: var(--fw-button); font-size: var(--fs-button); letter-spacing: 0.08em; text-transform: uppercase; height: var(--btn-height); border-radius: var(--radius-button); border: none; display: flex; align-items: center; justify-content: center; gap: 6px; transition: background .2s, transform .15s; width: 100%; cursor: pointer; }
.btn-cart:hover { background: var(--red-dark); transform: translateY(-1px); }

.btn-primary { background: var(--red); color: #fff; font-family: var(--font-button); font-weight: var(--fw-button); font-size: var(--fs-button-lg); letter-spacing: 0.08em; text-transform: uppercase; height: var(--btn-height-lg); padding: 0 var(--container-padding); border-radius: var(--radius-button); border: none; display: inline-flex; align-items: center; gap: 8px; transition: background .2s, transform .15s; cursor: pointer; white-space: nowrap; }
.btn-primary:hover { background: var(--red-dark); transform: translateY(-1px); }

.btn-secondary { background: var(--dark3); color: var(--white); font-family: var(--font-button); font-weight: 700; font-size: var(--fs-button); letter-spacing: var(--ls-nav); text-transform: uppercase; height: var(--btn-height); padding: 0 20px; border-radius: var(--radius-button); border: 1px solid var(--border); display: inline-flex; align-items: center; gap: 6px; transition: all .2s; cursor: pointer; }
.btn-secondary:hover { background: var(--dark5); border-color: var(--grey3); }

/* =============================================
   FORM ELEMENTS
   ============================================= */
.filter-group { margin-bottom: 20px; }
.filter-group-title { font-family: var(--font-display); font-size: var(--fs-eyebrow); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--grey2); margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }

.filter-select,
.form-select {
  width: 100%;
  background: var(--dark4);
  border: 1px solid var(--dark5);
  border-radius: var(--radius-button);
  color: var(--white);
  font-size: var(--fs-small);
  padding: 0 14px;
  height: var(--btn-height-lg);
  outline: none;
  transition: border-color .2s;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 34px;
  cursor: pointer;
}
.filter-select:focus,
.form-select:focus { border-color: var(--red); }
.filter-select option,
.form-select option { background: var(--dark3); }

.filter-field { display: flex; flex-direction: column; gap: 4px; }
.filter-field-label { font-family: var(--font-display); font-size: var(--fs-badge); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--grey3); }

/* Chips */
.chip { font-family: var(--font-display); font-size: var(--fs-eyebrow); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; background: var(--dark4); border: 1px solid var(--dark5); color: var(--grey2); padding: 6px 12px; border-radius: 6px; cursor: pointer; transition: all .2s; }
.chip:hover { border-color: var(--grey3); color: var(--grey1); }
.chip.active { background: rgba(227,27,35,.15); border-color: var(--red); color: var(--red); }
.filter-chips { display: flex; flex-wrap: wrap; gap: 6px; }

/* Checkbox custom */
.filter-check { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: var(--fs-small); color: var(--grey1); margin-bottom: 8px; }
.filter-check input[type="checkbox"] { display: none; }
.custom-check { width: 18px; height: 18px; border-radius: var(--radius-small); background: var(--dark4); border: 1px solid var(--dark5); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .2s; }
.filter-check input:checked + .custom-check { background: var(--red); border-color: var(--red); }

/* =============================================
   BENEFITS BAR
   ============================================= */
.benefits-bar { max-width: var(--container-max-width); margin: 0 auto; padding: var(--section-padding) var(--container-padding) 40px; display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.benefit-item { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; padding: 20px 12px; background: var(--dark2); border: 1px solid var(--border); border-radius: 12px; transition: border-color .2s, transform .2s; min-width: 140px; flex: 1; }
.benefit-item:hover { border-color: var(--red-glow); transform: translateY(-2px); }
.benefit-icon { width: var(--benefit-icon-size); height: var(--benefit-icon-size); border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.bi-green { background: rgba(34,197,94,.1); color: var(--green); }
.bi-gold { background: rgba(245,166,35,.1); color: var(--gold); }
.bi-red { background: rgba(227,27,35,.1); color: var(--red); }
.bi-blue { background: rgba(99,179,237,.1); color: #63b3ed; }
.benefit-title { font-family: var(--font-display); font-weight: var(--fw-heading); font-size: var(--fs-nav); text-transform: uppercase; letter-spacing: .04em; }
.benefit-desc { font-size: var(--fs-cuotas); color: var(--grey2); margin: 0; }

/* =============================================
   MID BANNERS
   ============================================= */
.mid-banners { max-width: var(--container-max-width); margin: 0 auto; padding: 0 var(--container-padding) 32px; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--card-gap); }
.mid-banner { border-radius: 12px; padding: var(--container-padding); display: flex; align-items: center; gap: var(--card-gap); border: 1px solid var(--border); }
.mid-banner-1 { background: linear-gradient(135deg, #1a0808, var(--dark3)); border-color: rgba(227,27,35,0.2); }
.mid-banner-2 { background: linear-gradient(135deg, #1a1200, var(--dark3)); border-color: rgba(245,166,35,0.2); }
.mid-banner-3 { background: linear-gradient(135deg, #060d1a, var(--dark3)); border-color: rgba(99,179,237,0.2); }
.mid-banner-icon { display: flex; align-items: center; justify-content: center; flex-shrink: 0; width: 52px; height: 52px; }
.mid-banner-title { font-family: var(--font-display); font-weight: var(--fw-hero); font-size: var(--fs-h3); text-transform: uppercase; letter-spacing: 0.02em; margin-bottom: 4px; }
.mid-banner-text { font-size: var(--fs-small); color: var(--grey2); line-height: 1.4; margin: 0; }
.mid-banner-1 .mid-banner-icon, .mid-banner-1 .mid-banner-title { color: var(--red); }
.mid-banner-2 .mid-banner-icon, .mid-banner-2 .mid-banner-title { color: var(--gold); }
.mid-banner-3 .mid-banner-icon, .mid-banner-3 .mid-banner-title { color: #63b3ed; }

@media (max-width: 768px) {
  .mid-banners { grid-template-columns: 1fr; }
  .benefits-bar { gap: 20px; }
}
