/* ====== Catálogo Express ====== */
.cx-cat{
  --accent:#2563eb; --ok:#16a34a; --muted:#6b7280; --border:#e5e7eb; --bg:#fff;
  --panel:#0ea5e9; --panel2:#38bdf8;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:#111827;
}
.cx-layout{display:grid;gap:22px}
@media(min-width:1100px){.cx-layout{grid-template-columns:340px 1fr}}

.cx-panel{
  border:1px solid var(--border); border-radius:16px; background:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,.06); padding:16px;
}
.cx-panel.is-highlight{
  background:linear-gradient(180deg,rgba(14,165,233,.08),rgba(56,189,248,.08));
  border-color:#bae6fd;
}
.cx-block{margin-bottom:18px}
.cx-label{font-weight:800;margin-bottom:8px}
.cx-inline label{margin-right:14px}
.cx-help{color:var(--muted)}
.cx-tier{font-size:13px;color:#374151;margin:6px 0}

/* Cantidad */
/* Quantity input only */
.cx-quantity .cx-num{
  display:block;
  width:100%;
  border:1px solid var(--border);
  border-radius:10px;
  padding:10px 12px;
  font-weight:700;
  text-align:center;
}

.cx-progress{
  height:8px;
  background:#f3f4f6;
  border-radius:999px;
  margin-top:8px;
  overflow:hidden;
}
.cx-progress .cx-progress-fill{
  display:block;
  height:100%;
  background:linear-gradient(90deg,#22c55e,#16a34a);
  width:0%;
}
/* Texto bajo la barra de progreso */
.cx-hint{
  font-size:13px;
  color:var(--muted);
  margin-top:6px;
}

/* Print options */
.cx-print-options{display:flex;gap:12px;margin-top:6px}
.cx-print-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:2px solid var(--border);
  border-radius:12px;
  padding:10px 16px;
  cursor:pointer;
  font-weight:800;
  transition:background .2s, border-color .2s, color .2s;
}
.cx-print-btn span{display:block; position:relative; padding-left:0;}
/* selected / not selected classes added via JS */
.cx-print-btn.selected{
  background:#ecfdf5;
  border-color:#16a34a;
  color:#16a34a;
}
.cx-print-btn.unselected{
  background:#fef2f2;
  border-color:#dc2626;
  color:#dc2626;
}

/* Summary box */
.cx-summary{
  background:#f1f5f9;
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px;
  font-size:14px;
}
.cx-summary-list{list-style:none;padding:0;margin:0;line-height:1.5}

/* Grid cards 1→2→3 */
.cx-grid{display:grid;gap:18px}
@media(min-width:820px){.cx-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1280px){.cx-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}


.cx-body{padding:14px}
.cx-quality{display:none} /* la clase original ya no se usa como etiqueta visible */

/* Badge de calidad sobre la imagen */
.cx-card{
  border:1px solid var(--border);
  border-radius:18px;
  background:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,.05);
  display:flex;
  flex-direction:column;
  position:relative;
}
.cx-card.is-featured{
  outline:2px solid #93c5fd;
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(37,99,235,.15);
}
.cx-fig{
  margin:0;
  border-bottom:1px solid var(--border);
  background:#f8fafc;
  position:relative;
}
.cx-fig img{
  width:100%;
  height:auto;
  aspect-ratio:4/5;
  object-fit:cover;
}
/* Badge superpuesto */
.cx-quality-badge{
  position:absolute;
  top:10px;
  left:10px;
  display:inline-block;
  background:#eef2ff;
  color:#1e40af;
  font-weight:800;
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  box-shadow:0 4px 10px rgba(0,0,0,.12);
}
.cx-title{
  font-size:18px;
  font-weight:900;
  margin:0 0 2px 0;
}
.cx-rating{
  margin:0 0 14px 0;
  font-size:14px;
}
.cx-stars{
  color:#f59e0b;
  letter-spacing:2px;
}
.cx-price{
  margin:12px 0 4px 0;
  font-weight:600;
}
.cx-total{
  margin:0 0 8px 0;
}
.cx-total strong{
  font-size:1.15rem;
  font-weight:800;
}
.cx-print-note{
  margin-top:4px;
  font-size:13px;
  color:var(--muted);
}

/* Pricing box: agrupa precio unitario y total con fondo suave */
.cx-pricing{
  background:#f8fafc;
  border:1px solid var(--border);
  border-radius:10px;
  padding:8px 12px;
  margin:10px 0;
}

.cx-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.cx-btn{display:inline-block;border-radius:12px;padding:10px 14px;font-weight:800;text-align:center}
.cx-btn.primary{background:var(--accent);color:#fff}
.cx-btn.secondary{background:#fff;border:1px solid var(--border);color:#111827}

.cx-foot{padding:12px 14px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.cx-foot .cx-badge{font-size:12px;color:var(--muted)}
.cx-link{color:var(--accent);text-decoration:underline}

/* Feedback cambio de precios */
@keyframes cxFlash{0%{background:#fff}50%{background:#fef3c7}100%{background:#fff}}
@keyframes cxBump{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}
.flash{animation:cxFlash .7s ease}
.bump{display:inline-block;animation:cxBump .35s ease}

/* === Color swatches === */
.cx-color-swatches{
  display:flex;
  gap:16px;
  margin-top:6px;
}
.cx-color-swatch{
  display:flex;
  flex-direction:column;
  align-items:center;
  cursor:pointer;
  font-size:13px;
  color:#111827;
  position:relative;
}
.cx-color-swatch input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.cx-color-dot{
  width:26px;
  height:26px;
  border-radius:999px;
  border:2px solid transparent;
  box-shadow:0 0 0 1px rgba(0,0,0,.08);
  margin-bottom:4px;
}
.cx-color-dot--white{background:#ffffff;}
.cx-color-dot--black{background:#000000;}
.cx-color-swatch input:checked + .cx-color-dot{
  border-color:#16a34a;
  box-shadow:0 0 0 2px rgba(22,163,74,.35);
}
.cx-color-name{user-select:none;}
