/* ============================================================
   BAZAR — sistema de diseño propio (marketplace moderno).
   Distinto a Lost Lines: violeta, redondeado, botones grandes pill,
   sombras suaves. Carga DESPUÉS de theme.css/components.css.
   ============================================================ */

:root {
  /* Estilo SITEMA_EDUCATIVO: slate + esmeralda, blanco, bordes claros, limpio */
  --bz-primary: #059669;       /* emerald-600 */
  --bz-primary-dark: #047857;  /* emerald-700 */
  --bz-primary-soft: #ecfdf5;  /* emerald-50 */
  --bz-accent: #2563eb;        /* blue-600 (enlaces) */
  --bz-ink: #0f172a;           /* slate-900 */
  --bz-muted: #64748b;         /* slate-500 */
  --bz-line: #e2e8f0;          /* slate-200 */
  --bz-surface: #ffffff;
  --bz-bg: #f8fafc;            /* slate-50 */
  --bz-radius: 14px;
  --bz-radius-sm: 10px;
  --bz-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);
  --bz-shadow-hover: 0 10px 28px rgba(15, 23, 42, .10);
}

body { background: var(--bz-bg); color: var(--bz-ink); }

/* ---------- Botones (grandes, pill) ---------- */
.bz-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 0; border-radius: 10px; cursor: pointer; font-weight: 600;
  padding: 11px 20px; font-size: .94rem; line-height: 1; transition: .16s ease;
  font-family: inherit; text-decoration: none;
}
.bz-btn--primary { background: var(--bz-primary); color: #fff; box-shadow: 0 1px 2px rgba(5,150,105,.2); }
.bz-btn--primary:hover { background: var(--bz-primary-dark); transform: translateY(-1px); box-shadow: 0 6px 18px rgba(5,150,105,.25); }
.bz-btn--ghost { background: #fff; color: var(--bz-ink); border: 1.5px solid var(--bz-line); }
.bz-btn--ghost:hover { border-color: var(--bz-primary); color: var(--bz-primary); }
.bz-btn--lg { padding: 15px 30px; font-size: 1.05rem; }
.bz-btn--sm { padding: 9px 16px; font-size: .85rem; }
.bz-btn--block { width: 100%; }

/* ---------- Tarjeta de producto ---------- */
.bz-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; }
.bz-card {
  background: var(--bz-surface); border: 1px solid var(--bz-line); border-radius: var(--bz-radius);
  overflow: hidden; box-shadow: var(--bz-shadow); display: flex; flex-direction: column;
  cursor: pointer; transition: transform .22s ease, box-shadow .22s ease;
}
.bz-card:hover { transform: translateY(-4px); box-shadow: var(--bz-shadow-hover); }
.bz-card__media { position: relative; aspect-ratio: 1/1; background: #eef0f4; overflow: hidden; }
.bz-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.bz-card:hover .bz-card__img { transform: scale(1.06); }
.bz-card__body { padding: 14px 15px 16px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.bz-card__title { font-weight: 700; font-size: .98rem; line-height: 1.3; letter-spacing: -.01em; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bz-card__price { display: flex; align-items: baseline; gap: 7px; margin-top: auto; }
.bz-price { font-weight: 800; font-size: 1.18rem; color: var(--bz-primary); font-variant-numeric: tabular-nums; }
.bz-price-old { font-size: .85rem; color: var(--bz-muted); text-decoration: line-through; }
.bz-cur { font-size: .72rem; color: var(--bz-muted); font-weight: 600; }
.bz-card__add { margin-top: 4px; }

/* ---------- Badges ---------- */
.bz-badges { position: absolute; top: 10px; left: 10px; z-index: 2; display: flex; flex-direction: column; gap: 6px; }
.bz-badge { background: var(--bz-ink); color: #fff; font-size: .7rem; font-weight: 700; padding: 4px 10px; border-radius: 999px; align-self: flex-start; }
.bz-badge--sale { background: #ef4444; }
.bz-badge--ship { position: absolute; top: 10px; right: 10px; left: auto; z-index: 2; background: var(--bz-accent); }

/* ---------- Layout / secciones ---------- */
.bz-wrap { width: min(1200px, calc(100% - 40px)); margin: 0 auto; }
.bz-section { padding: 44px 0; }
.bz-section__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 22px; }
.bz-h2 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800; letter-spacing: -.02em; margin: 0; }
.bz-link { color: var(--bz-primary); font-weight: 700; }

/* ---------- Hero (limpio, estilo SITEMA: panel claro, acento esmeralda) ---------- */
.bz-hero {
  background:
    radial-gradient(600px 240px at 90% -10%, rgba(5,150,105,.10), transparent 60%),
    var(--bz-surface);
  color: var(--bz-ink); border: 1px solid var(--bz-line); border-radius: 16px;
  padding: 52px 40px; position: relative; overflow: hidden;
}
.bz-hero h1 { font-size: clamp(1.9rem, 4.5vw, 3rem); font-weight: 800; letter-spacing: -.025em; margin: 0 0 12px; line-height: 1.08; }
.bz-hero p { font-size: 1.08rem; color: var(--bz-muted); max-width: 560px; margin: 0 0 26px; }
.bz-hero__eyebrow { display: inline-block; background: var(--bz-primary-soft); color: var(--bz-primary-dark); font-weight: 700; font-size: .78rem; padding: 5px 12px; border-radius: 999px; margin-bottom: 16px; }

/* ---------- Categorías (pills) ---------- */
.bz-cats { display: flex; flex-wrap: wrap; gap: 10px; }
.bz-cat { background: #fff; border: 1px solid var(--bz-line); border-radius: 999px; padding: 9px 18px; font-weight: 600; font-size: .92rem; color: var(--bz-ink); transition: .15s; }
.bz-cat:hover, .bz-cat.is-active { background: var(--bz-primary); color: #fff; border-color: var(--bz-primary); }

/* ---------- Tira de ventajas (cards limpias estilo SITEMA) ---------- */
.bz-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 16px; }
.bz-feature { background: var(--bz-surface); border: 1px solid var(--bz-line); border-left: 3px solid var(--bz-primary); border-radius: var(--bz-radius); padding: 20px 22px; display: grid; gap: 6px; }
.bz-feature strong { font-size: 1rem; font-weight: 700; color: var(--bz-ink); }
.bz-feature__txt { color: var(--bz-muted); font-size: .9rem; line-height: 1.45; }

@media (max-width: 600px) {
  .bz-hero { padding: 40px 24px; border-radius: 20px; }
  .bz-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
}

/* ============================================================
   Compat: re-skin de clases heredadas (Lost Lines) al look BAZAR.
   Así el carrito, checkout, cuenta y modales adoptan el estilo nuevo
   sin editar cada plantilla.
   ============================================================ */
.btn-ink, .btn-wine, .btn-light, .btn-ghost {
  border-radius: 10px !important; padding: 11px 20px; font-weight: 600;
  text-transform: none !important; letter-spacing: 0 !important;
}
.btn-ink { background: var(--bz-primary) !important; color: #fff !important; border: 0 !important; }
.btn-ink:hover { background: var(--bz-primary-dark) !important; }
.btn-wine { background: var(--bz-accent) !important; color: #fff !important; border: 0 !important; }
.btn-ghost { background: #fff !important; border: 1.5px solid var(--bz-line) !important; color: var(--bz-ink) !important; }
.btn-ghost:hover { border-color: var(--bz-primary) !important; color: var(--bz-primary) !important; }

/* Búsqueda heredada -> blanca redondeada */
.ll-search__input { background: #fff !important; border-radius: 10px !important; border: 1px solid var(--bz-line) !important; }
.ll-search__icon { color: var(--bz-muted) !important; }
.ll-search__results { background: #fff !important; border: 1px solid var(--bz-line) !important; border-radius: 16px !important; box-shadow: var(--bz-shadow) !important; }
.ll-search .sr-price { color: var(--bz-primary) !important; }
.ll-search .sr-item:hover, .ll-search .sr-item.is-active { background: var(--bz-primary-soft) !important; }

/* Tabs de categoría heredadas -> violeta */
.filter-btn:hover, .filter-btn.is-active { color: var(--bz-primary) !important; }
.filter-btn.is-active::after { background: var(--bz-primary) !important; }

/* Paneles/sketch heredados -> tarjeta limpia */
.sketch-border::before { display: none !important; }
.sketch-border { border: 1px solid var(--bz-line) !important; border-radius: var(--bz-radius) !important; }
.wine-accent { color: var(--bz-primary) !important; }
.wine-underline::after { background: var(--bz-primary) !important; }
.grain-texture { background-image: none !important; }

/* De-brutalizar utilidades heredadas en TODO el sitio (contacto, cuenta,
   direcciones, faq, etc. quedan estilo SITEMA limpio). */
.uppercase { text-transform: none !important; letter-spacing: 0 !important; }
.font-black { font-weight: 700 !important; }
.paper-shadow { box-shadow: var(--bz-shadow) !important; }
.border-neutral-800, .border-neutral-700 { border-color: var(--bz-line) !important; }
/* Inputs/areas heredados -> limpios */
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]),
select, textarea {
  border-radius: 10px;
}
/* Tarjetas/paneles que usaban borde grueso oscuro -> slate suave */
.border-2 { border-width: 1px !important; }
/* Enderezar todo lo inclinado (look limpio, no brutalista) */
.-rotate-1, .-rotate-2, .-rotate-3, .rotate-1, .rotate-2, .rotate-3 { transform: none !important; }
.hover\:rotate-0:hover { transform: none !important; }
