/* CumpleMarket Platform — Main CSS */
:root {
  --cmp-orange: #F97316;
  --cmp-orange-dark: #EA580C;
  --cmp-green: #16A34A;
  --cmp-red: #DC2626;
  --cmp-yellow: #CA8A04;
  --cmp-gray-50: #F9FAFB;
  --cmp-gray-100: #F3F4F6;
  --cmp-gray-200: #E5E7EB;
  --cmp-gray-400: #9CA3AF;
  --cmp-gray-600: #4B5563;
  --cmp-gray-900: #111827;
  --cmp-radius: 10px;
  --cmp-shadow: 0 2px 8px rgba(0,0,0,.08);
  --cmp-shadow-md: 0 4px 16px rgba(0,0,0,.12);
}

/* ── BOTONES ── */
.cmp-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 10px 20px; border-radius: 8px; font-size: 15px; font-weight: 500;
  cursor: pointer; border: none; transition: background .15s, transform .1s;
  text-decoration: none;
}
.cmp-btn:active { transform: scale(.98); }
.cmp-btn--primary { background: var(--cmp-orange); color: #fff; }
.cmp-btn--primary:hover { background: var(--cmp-orange-dark); color: #fff; }
.cmp-btn--success { background: var(--cmp-green); color: #fff; }
.cmp-btn--ghost { background: transparent; color: var(--cmp-gray-600); border: 1.5px solid var(--cmp-gray-200); }
.cmp-btn--ghost:hover { border-color: var(--cmp-gray-400); }
.cmp-btn--block { width: 100%; }
.cmp-btn--sm { padding: 6px 12px; font-size: 13px; }
.cmp-btn:disabled { opacity: .45; cursor: not-allowed; }

/* ── NOTICES ── */
.cmp-notice { padding: 14px 18px; border-radius: var(--cmp-radius); font-size: 15px; margin-bottom: 16px; }
.cmp-notice--error { background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; }
.cmp-notice--success { background: #F0FDF4; color: #166534; border: 1px solid #BBF7D0; }
.cmp-notice--warning { background: #FFFBEB; color: #92400E; border: 1px solid #FDE68A; }

/* ── WIZARD ── */
.cmp-wizard { max-width: 700px; margin: 0 auto; font-family: inherit; }

/* Tour overlay */
.cmp-tour-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.6);
  z-index: 9999; display: flex; align-items: center; justify-content: center;
}
.cmp-tour-modal {
  background: #fff; border-radius: 16px; padding: 40px;
  max-width: 440px; text-align: center; box-shadow: var(--cmp-shadow-md);
}
.cmp-tour-icon { font-size: 48px; margin-bottom: 12px; display: block; }
.cmp-tour-title { font-size: 22px; font-weight: 600; margin-bottom: 12px; color: var(--cmp-gray-900); }
.cmp-tour-body { font-size: 15px; color: var(--cmp-gray-600); line-height: 1.6; margin-bottom: 24px; }
.cmp-tour-actions { display: flex; flex-direction: column; gap: 10px; }

/* Rubros grid */
.cmp-rubros-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin: 24px 0;
}
.cmp-rubro-card {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 28px 20px; background: var(--cmp-gray-50); border: 2px solid var(--cmp-gray-200);
  border-radius: 12px; cursor: pointer; transition: all .15s; gap: 10px;
}
.cmp-rubro-card:hover { border-color: var(--cmp-orange); background: #FFF7ED; }
.cmp-rubro-card.is-selected { border-color: var(--cmp-orange); background: #FFF7ED; box-shadow: 0 0 0 3px rgba(249,115,22,.15); }
.cmp-rubro-icon { font-size: 36px; }
.cmp-rubro-label { font-size: 16px; font-weight: 500; color: var(--cmp-gray-900); }

/* Progress */
.cmp-progress { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.cmp-progress-bar {
  flex: 1; height: 6px; background: var(--cmp-gray-200); border-radius: 3px; overflow: hidden;
  position: relative;
}
.cmp-progress-bar::after {
  content: ''; position: absolute; left: 0; top: 0; height: 100%;
  background: var(--cmp-orange); border-radius: 3px;
  width: var(--progress, 0%); transition: width .3s;
}
.cmp-progress-label { font-size: 13px; color: var(--cmp-gray-600); white-space: nowrap; }

/* Pasos de campos */
.cmp-step { display: none; }
.cmp-step.is-active { display: block; animation: cmpFadeIn .2s ease; }
@keyframes cmpFadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.cmp-field { margin-bottom: 22px; }
.cmp-field-label { display: block; font-size: 15px; font-weight: 500; color: var(--cmp-gray-900); margin-bottom: 6px; }
.cmp-field-hint { font-size: 13px; color: var(--cmp-gray-400); margin-top: 4px; }
.cmp-field-error { font-size: 13px; color: var(--cmp-red); margin-top: 4px; display: none; }
.cmp-field.has-error .cmp-field-error { display: block; }
.cmp-field.has-error input, .cmp-field.has-error textarea, .cmp-field.has-error select { border-color: var(--cmp-red); }

.cmp-input, .cmp-textarea, .cmp-select {
  width: 100%; padding: 10px 14px; border: 1.5px solid var(--cmp-gray-200);
  border-radius: 8px; font-size: 15px; color: var(--cmp-gray-900);
  background: #fff; transition: border .15s;
}
.cmp-input:focus, .cmp-textarea:focus, .cmp-select:focus {
  outline: none; border-color: var(--cmp-orange);
}
.cmp-textarea { min-height: 120px; resize: vertical; }

/* Opciones radio/check tipo tarjetas */
.cmp-options-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.cmp-option-card {
  display: flex; align-items: center; gap: 8px; padding: 10px 18px;
  border: 2px solid #C9CDD4; border-radius: 8px; cursor: pointer;
  font-size: 14px; font-weight: 500; color: var(--cmp-gray-900);
  transition: all .12s; user-select: none;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.07);
}
.cmp-option-card:hover {
  border-color: var(--cmp-orange); background: #FFF7ED;
  box-shadow: 0 2px 8px rgba(249,115,22,.12);
}
.cmp-option-card.is-selected {
  border-color: var(--cmp-orange); background: #FFF7ED;
  font-weight: 700; color: #C2410C;
  box-shadow: 0 0 0 3px rgba(249,115,22,.18), 0 2px 6px rgba(249,115,22,.1);
}
.cmp-option-card input { display: none; }

/* Imágenes */
.cmp-images-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 12px; }
.cmp-image-thumb {
  aspect-ratio: 1; border-radius: 8px; overflow: hidden; position: relative;
  background: var(--cmp-gray-100); border: 1.5px solid var(--cmp-gray-200);
}
.cmp-image-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cmp-image-remove {
  position: absolute; top: 4px; right: 4px; background: rgba(0,0,0,.5);
  color: #fff; border: none; border-radius: 50%; width: 22px; height: 22px;
  cursor: pointer; font-size: 12px; line-height: 22px; text-align: center;
}
.cmp-image-add {
  aspect-ratio: 1; border: 2px dashed var(--cmp-gray-200); border-radius: 8px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  cursor: pointer; color: var(--cmp-gray-400); gap: 6px; font-size: 13px;
  transition: all .15s;
}
.cmp-image-add:hover { border-color: var(--cmp-orange); color: var(--cmp-orange); background: #FFF7ED; }
.cmp-image-add-icon { font-size: 24px; }

/* Nav wizard */
.cmp-wizard-nav { display: flex; gap: 12px; margin-top: 28px; justify-content: flex-end; }
.cmp-wizard-header { margin-bottom: 24px; }
.cmp-wizard-title { font-size: 22px; font-weight: 600; color: var(--cmp-gray-900); margin-bottom: 6px; }
.cmp-wizard-subtitle { font-size: 15px; color: var(--cmp-gray-600); }

/* Feedback */
.cmp-wizard-feedback { padding: 20px; border-radius: var(--cmp-radius); margin-top: 20px; text-align: center; }
.cmp-wizard-feedback.is-success { background: #F0FDF4; color: #166534; border: 1px solid #BBF7D0; }
.cmp-wizard-feedback.is-error { background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; }

/* ── DASHBOARD ── */
.cmp-dashboard { display: grid; grid-template-columns: 240px 1fr; min-height: 600px; gap: 0; border-radius: 12px; overflow: hidden; box-shadow: var(--cmp-shadow-md); }
.cmp-dashboard-nav { background: var(--cmp-gray-900); padding: 24px 0; display: flex; flex-direction: column; }
.cmp-dashboard-brand { padding: 0 20px 20px; border-bottom: 1px solid rgba(255,255,255,.1); margin-bottom: 16px; }
.cmp-dashboard-vendor-name { display: block; color: #fff; font-weight: 500; font-size: 15px; }
.cmp-dashboard-role { display: block; color: var(--cmp-gray-400); font-size: 12px; margin-top: 2px; }
.cmp-nav-list { list-style: none; padding: 0; margin: 0; flex: 1; }
.cmp-nav-item { margin: 2px 8px; }
.cmp-nav-link { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 8px; color: var(--cmp-gray-400); text-decoration: none; font-size: 14px; transition: all .12s; }
.cmp-nav-link:hover { background: rgba(255,255,255,.08); color: #fff; }
.cmp-nav-item.is-active .cmp-nav-link { background: var(--cmp-orange); color: #fff; }
.cmp-nav-icon { font-size: 16px; width: 20px; text-align: center; }
.cmp-nav-footer { padding: 16px; border-top: 1px solid rgba(255,255,255,.1); }

.cmp-dashboard-content { background: var(--cmp-gray-50); padding: 32px; overflow-y: auto; }
.cmp-section-title { font-size: 20px; font-weight: 600; color: var(--cmp-gray-900); margin-bottom: 24px; }
.cmp-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }
.cmp-section-header .cmp-section-title { margin-bottom: 0; }

/* Stats */
.cmp-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
.cmp-stat-card { background: #fff; border-radius: var(--cmp-radius); padding: 20px; display: flex; flex-direction: column; align-items: center; gap: 6px; box-shadow: var(--cmp-shadow); }
.cmp-stat-card--warning { border-top: 3px solid var(--cmp-yellow); }
.cmp-stat-card--success { border-top: 3px solid var(--cmp-green); }
.cmp-stat-icon { font-size: 24px; }
.cmp-stat-value { font-size: 22px; font-weight: 600; color: var(--cmp-gray-900); }
.cmp-stat-label { font-size: 12px; color: var(--cmp-gray-400); text-align: center; }

/* Quick actions */
.cmp-quick-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.cmp-quick-card { background: #fff; border-radius: var(--cmp-radius); padding: 20px; display: flex; flex-direction: column; align-items: center; gap: 8px; text-decoration: none; box-shadow: var(--cmp-shadow); transition: box-shadow .15s; }
.cmp-quick-card:hover { box-shadow: var(--cmp-shadow-md); }
.cmp-quick-icon { font-size: 28px; }
.cmp-quick-label { font-size: 14px; font-weight: 500; color: var(--cmp-gray-900); }

/* Tabla */
.cmp-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--cmp-radius); overflow: hidden; box-shadow: var(--cmp-shadow); }
.cmp-table th { background: var(--cmp-gray-100); padding: 12px 16px; text-align: left; font-size: 13px; font-weight: 500; color: var(--cmp-gray-600); border-bottom: 1px solid var(--cmp-gray-200); }
.cmp-table td { padding: 14px 16px; font-size: 14px; color: var(--cmp-gray-900); border-bottom: 1px solid var(--cmp-gray-100); }
.cmp-table tr:last-child td { border-bottom: none; }
.cmp-td-product { display: flex; align-items: center; gap: 10px; }
.cmp-product-thumb { width: 44px; height: 44px; object-fit: cover; border-radius: 6px; }
.cmp-td-commission { color: var(--cmp-red); }
.cmp-td-net { color: var(--cmp-green); }

/* Badges */
.cmp-badge { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: 12px; font-weight: 500; }
.cmp-badge--publish { background: #D1FAE5; color: #065F46; }
.cmp-badge--pending { background: #FEF3C7; color: #92400E; }
.cmp-badge--draft   { background: var(--cmp-gray-100); color: var(--cmp-gray-600); }
.cmp-badge--retained  { background: #FEF3C7; color: #92400E; }
.cmp-badge--available { background: #D1FAE5; color: #065F46; }
.cmp-badge--paid      { background: #DBEAFE; color: #1E40AF; }

/* Balance */
.cmp-balance-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px; }
.cmp-balance-item { background: #fff; border-radius: var(--cmp-radius); padding: 20px; box-shadow: var(--cmp-shadow); display: flex; flex-direction: column; gap: 4px; }
.cmp-balance-item span { font-size: 13px; color: var(--cmp-gray-400); }
.cmp-balance-item strong { font-size: 22px; font-weight: 600; color: var(--cmp-gray-900); }
.cmp-balance--available strong { color: var(--cmp-green); }
.cmp-balance--retained strong { color: var(--cmp-yellow); }

/* Messages */
.cmp-message-card { background: #fff; border-radius: var(--cmp-radius); padding: 16px 20px; margin-bottom: 12px; box-shadow: var(--cmp-shadow); }
.cmp-message-meta { display: flex; gap: 12px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.cmp-message-product { font-size: 13px; color: var(--cmp-gray-400); }
.cmp-message-date { font-size: 12px; color: var(--cmp-gray-400); margin-left: auto; }
.cmp-message-body { font-size: 14px; color: var(--cmp-gray-600); line-height: 1.6; margin: 0; }

/* Empty state */
.cmp-empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 48px; gap: 16px; text-align: center; }
.cmp-empty-icon { font-size: 48px; }
.cmp-empty-state p { font-size: 16px; color: var(--cmp-gray-600); margin: 0; }

/* Cards resultados (comprador) */
.cmp-results-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.cmp-result-card { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: var(--cmp-shadow); transition: box-shadow .15s, transform .1s; position: relative; }
.cmp-result-card:hover { box-shadow: var(--cmp-shadow-md); transform: translateY(-2px); }
.cmp-result-card.is-selected { box-shadow: 0 0 0 2px var(--cmp-orange), var(--cmp-shadow); }
.cmp-card-image { aspect-ratio: 4/3; overflow: hidden; background: var(--cmp-gray-100); }
.cmp-card-image img { width: 100%; height: 100%; object-fit: cover; }
.cmp-card-fav { position: absolute; top: 10px; right: 10px; background: rgba(255,255,255,.9); border: none; border-radius: 50%; width: 34px; height: 34px; cursor: pointer; font-size: 18px; display: flex; align-items: center; justify-content: center; }
.cmp-card-body { padding: 14px 16px; }
.cmp-card-title { font-size: 15px; font-weight: 500; color: var(--cmp-gray-900); margin-bottom: 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cmp-card-subtitle { font-size: 13px; color: var(--cmp-gray-400); margin-bottom: 8px; }
.cmp-card-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.cmp-card-badge { font-size: 11px; padding: 2px 8px; border-radius: 99px; background: var(--cmp-gray-100); color: var(--cmp-gray-600); }
.cmp-card-price { font-size: 16px; font-weight: 600; color: var(--cmp-orange); margin-bottom: 12px; }
.cmp-card-reasons { font-size: 12px; color: var(--cmp-gray-400); margin-bottom: 10px; }
.cmp-card-reason { display: inline-block; margin-right: 6px; }
.cmp-card-reason::before { content: '✓ '; color: var(--cmp-green); }
.cmp-card-actions { display: flex; align-items: center; gap: 8px; }
.cmp-card-select { display: flex; align-items: center; gap: 6px; cursor: pointer; font-size: 13px; color: var(--cmp-gray-600); }
.cmp-card-select input { accent-color: var(--cmp-orange); width: 16px; height: 16px; }

/* Calculadora sticky */
.cmp-calculator { position: sticky; bottom: 0; background: var(--cmp-gray-900); color: #fff; padding: 14px 20px; display: flex; align-items: center; gap: 20px; border-radius: 12px 12px 0 0; box-shadow: 0 -4px 12px rgba(0,0,0,.15); z-index: 100; }
.cmp-calculator-total { font-size: 18px; font-weight: 600; }
.cmp-calculator-label { font-size: 12px; color: var(--cmp-gray-400); }
.cmp-calculator-actions { margin-left: auto; display: flex; gap: 10px; }
.cmp-calculator-disclaimer { font-size: 11px; color: var(--cmp-gray-400); text-align: center; margin-top: 6px; }

/* Responsive */
@media (max-width: 768px) {
  .cmp-dashboard { grid-template-columns: 1fr; }
  .cmp-dashboard-nav { flex-direction: row; padding: 12px; overflow-x: auto; }
  .cmp-nav-list { display: flex; flex-direction: row; gap: 4px; }
  .cmp-nav-item { margin: 0; flex-shrink: 0; }
  .cmp-nav-link { white-space: nowrap; padding: 8px 12px; font-size: 13px; gap: 6px; }
  .cmp-nav-label { display: inline; }
  .cmp-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .cmp-rubros-grid { grid-template-columns: repeat(2, 1fr); }
  .cmp-images-grid { grid-template-columns: repeat(3, 1fr); }
  .cmp-quick-actions { grid-template-columns: repeat(2, 1fr); }
}

/* ── COTIZADOR (BUYER WIZARD) ── */
.cmp-cotizador { max-width: 680px; margin: 0 auto; padding: 24px 0; }
.cmp-cotizador-progress { height: 6px; background: var(--cmp-gray-200); border-radius: 3px; overflow: hidden; margin-bottom: 6px; }
.cmp-cotizador-progress-bar { height: 100%; background: var(--cmp-orange); border-radius: 3px; transition: width .4s; width: 0%; }
.cmp-cotizador-progress-text { font-size: 12px; color: var(--cmp-gray-400); text-align: right; margin-bottom: 28px; }

.cmp-cot-step { display: none; animation: cmpFadeIn .2s ease; }
.cmp-cot-step.is-active { display: block; }
.cmp-cot-title { font-size: 24px; font-weight: 600; color: var(--cmp-gray-900); margin-bottom: 8px; }
.cmp-cot-subtitle { font-size: 15px; color: var(--cmp-gray-400); margin-bottom: 20px; }

.cmp-cot-options { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 28px; }
.cmp-cot-options--grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.cmp-cot-options--multi { display: flex; flex-wrap: wrap; gap: 10px; }

.cmp-cot-opt {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 20px; background: #fff;
  border: 2px solid var(--cmp-gray-200); border-radius: 12px;
  cursor: pointer; font-size: 15px; color: var(--cmp-gray-900);
  transition: all .15s; min-width: 140px;
}
.cmp-cot-opt:hover { border-color: var(--cmp-orange); background: #FFF7ED; }
.cmp-cot-opt.is-selected { border-color: var(--cmp-orange); background: #FFF7ED; font-weight: 500; box-shadow: 0 0 0 3px rgba(249,115,22,.15); }
.cmp-cot-opt--skip { border-style: dashed; color: var(--cmp-gray-400); font-size: 14px; }
.cmp-cot-opt--skip.is-selected { border-style: solid; }
.cmp-cot-opt--multi .cmp-cot-opt-check { margin-left: auto; opacity: 0; color: var(--cmp-orange); font-weight: 700; }
.cmp-cot-opt--multi.is-selected .cmp-cot-opt-check { opacity: 1; }
.cmp-cot-opt-icon { font-size: 22px; }
.cmp-cot-skip { margin-top: 4px; font-size: 14px; }

.cmp-cot-nav { display: flex; gap: 12px; justify-content: flex-end; margin-top: 8px; }

/* ── RESULTADOS (BUYER) ── */
.cmp-resultados { position: relative; }
.cmp-resultados-loading { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 60px 20px; }
.cmp-spinner { width: 40px; height: 40px; border: 3px solid var(--cmp-gray-200); border-top-color: var(--cmp-orange); border-radius: 50%; animation: cmpSpin .8s linear infinite; }
@keyframes cmpSpin { to { transform: rotate(360deg); } }

.cmp-resultados-empty { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 60px 20px; text-align: center; }
.cmp-resultados-partial { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: #FFFBEB; border: 1px solid #FDE68A; border-radius: 8px; margin-bottom: 20px; font-size: 14px; color: #92400E; }
.cmp-partial-icon { font-size: 18px; }

.cmp-resultados-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.cmp-resultados-header span { font-size: 14px; color: var(--cmp-gray-600); font-weight: 500; }

.cmp-card-no-img { display: flex; align-items: center; justify-content: center; aspect-ratio: 4/3; font-size: 48px; background: var(--cmp-gray-100); }

/* Modal */
.cmp-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 20px; }
.cmp-modal { background: #fff; border-radius: 16px; padding: 32px; max-width: 480px; width: 100%; position: relative; max-height: 90vh; overflow-y: auto; }
.cmp-modal-close { position: absolute; top: 16px; right: 16px; background: none; border: none; font-size: 18px; cursor: pointer; color: var(--cmp-gray-400); }
.cmp-modal-title { font-size: 20px; font-weight: 600; margin-bottom: 6px; color: var(--cmp-gray-900); }
.cmp-modal-subtitle { font-size: 14px; color: var(--cmp-gray-400); margin-bottom: 20px; }
.cmp-modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 20px; }

/* Toast */
.cmp-toast { position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--cmp-gray-900); color: #fff; padding: 12px 24px; border-radius: 99px; font-size: 14px; opacity: 0; transition: all .3s; z-index: 10000; white-space: nowrap; }
.cmp-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.cmp-toast--success { background: var(--cmp-green); }
.cmp-toast--info { background: var(--cmp-gray-900); }

/* Calculadora */
.cmp-calc-left { flex: 1; }

@media(max-width:600px){
  /* Cotizador: 2 columnas, texto siempre horizontal */
  .cmp-cot-options { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .cmp-cot-options--grid { grid-template-columns: repeat(2, 1fr); }
  .cmp-cot-options--multi { display: grid; grid-template-columns: repeat(2, 1fr); }
  .cmp-cot-opt {
    min-width: 0; width: 100%;
    padding: 12px 10px;
    font-size: 14px;
    white-space: normal;
    word-break: normal;
    overflow-wrap: break-word;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .cmp-cot-opt-icon { font-size: 20px; }
  .cmp-results-grid { grid-template-columns: 1fr; }
  .cmp-calculator { flex-direction: column; gap: 12px; }
}

/* ── REGISTRO PROVEEDOR ── */
.cmp-registro { max-width: 600px; margin: 0 auto; }

.cmp-registro-tabs { display: flex; gap: 0; margin-bottom: 32px; border-bottom: 2px solid var(--cmp-gray-200); }
.cmp-registro-tab { flex: 1; padding: 14px; background: none; border: none; font-size: 15px; font-weight: 500; color: var(--cmp-gray-400); cursor: pointer; transition: all .15s; border-bottom: 2px solid transparent; margin-bottom: -2px; }
.cmp-registro-tab:hover { color: var(--cmp-orange); }
.cmp-registro-tab.is-active { color: var(--cmp-orange); border-bottom-color: var(--cmp-orange); }

.cmp-registro-panel { display: none; }
.cmp-registro-panel.is-active { display: block; }
.cmp-registro-header { margin-bottom: 28px; }
.cmp-registro-title { font-size: 24px; font-weight: 600; color: var(--cmp-gray-900); margin-bottom: 8px; }
.cmp-registro-subtitle { font-size: 15px; color: var(--cmp-gray-400); line-height: 1.5; }

.cmp-form-section { background: var(--cmp-gray-50); border-radius: 12px; padding: 24px; margin-bottom: 20px; }
.cmp-form-section-title { font-size: 15px; font-weight: 600; color: var(--cmp-gray-900); margin-bottom: 18px; padding-bottom: 10px; border-bottom: 1px solid var(--cmp-gray-200); }

.cmp-form-row { display: flex; gap: 14px; }
.cmp-form-row--2 > .cmp-field { flex: 1; }

.cmp-input-password { position: relative; display: flex; }
.cmp-input-password .cmp-input { flex: 1; padding-right: 44px; }
.cmp-toggle-password { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; font-size: 16px; color: var(--cmp-gray-400); }

.cmp-field--check { display: flex; flex-direction: column; gap: 4px; }
.cmp-check-label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-size: 14px; color: var(--cmp-gray-600); }
.cmp-check-label input { margin-top: 2px; accent-color: var(--cmp-orange); width: 16px; height: 16px; flex-shrink: 0; }
.cmp-check-label a { color: var(--cmp-orange); }

.cmp-form-error { padding: 12px 16px; background: #FEF2F2; border: 1px solid #FECACA; border-radius: 8px; color: #991B1B; font-size: 14px; margin-bottom: 16px; }
.cmp-form-links { text-align: right; margin-bottom: 16px; font-size: 14px; }
.cmp-form-links a { color: var(--cmp-orange); }
.cmp-form-note { font-size: 13px; color: var(--cmp-gray-400); text-align: center; margin-top: 14px; line-height: 1.5; }

.cmp-btn--lg { padding: 14px 28px; font-size: 16px; }

/* Éxito */
.cmp-registro-success { text-align: center; padding: 48px 24px; }
.cmp-success-icon { font-size: 64px; margin-bottom: 16px; }
.cmp-registro-success h2 { font-size: 24px; font-weight: 600; margin-bottom: 10px; color: var(--cmp-gray-900); }
.cmp-registro-success p { font-size: 16px; color: var(--cmp-gray-600); margin-bottom: 24px; }

/* Textarea pequeño */
.cmp-textarea--sm { min-height: 80px; }

.cmp-required { color: var(--cmp-orange); }

@media(max-width:600px){
  .cmp-form-row { flex-direction: column; }
  .cmp-form-row--2 > .cmp-field { flex: none; }
}

/* ── RUBROS CON DESCRIPCIÓN (registro) ── */
.cmp-rubros-registro { display: flex; flex-direction: column; gap: 10px; margin-bottom: 4px; }
.cmp-rubro-registro-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px; background: #fff;
  border: 2px solid var(--cmp-gray-200); border-radius: 12px;
  cursor: pointer; text-align: left; width: 100%;
  transition: all .15s;
}
.cmp-rubro-registro-card:hover { border-color: var(--cmp-orange); background: #FFF7ED; }
.cmp-rubro-registro-card.is-selected { border-color: var(--cmp-orange); background: #FFF7ED; box-shadow: 0 0 0 3px rgba(249,115,22,.15); }
.cmp-rubro-registro-icon { font-size: 28px; flex-shrink: 0; }
.cmp-rubro-registro-info { display: flex; flex-direction: column; gap: 2px; }
.cmp-rubro-registro-name { font-size: 15px; font-weight: 500; color: var(--cmp-gray-900); }
.cmp-rubro-registro-desc { font-size: 13px; color: var(--cmp-gray-400); }
.cmp-rubro-registro-card.is-selected .cmp-rubro-registro-desc { color: var(--cmp-orange); opacity: .8; }

/* ── DRAG & DROP IMÁGENES ── */
.cmp-image-thumb { cursor: grab; transition: opacity .15s, transform .15s; }
.cmp-image-thumb.is-dragging { opacity: .4; transform: scale(.95); cursor: grabbing; }
.cmp-image-thumb.drag-over { box-shadow: 0 0 0 3px var(--cmp-orange); transform: scale(1.03); }
.cmp-img-badge {
  position: absolute; top: 4px; left: 4px;
  background: var(--cmp-orange); color: #fff;
  font-size: 10px; font-weight: 600; padding: 2px 6px;
  border-radius: 4px; pointer-events: none;
}

/* ── BOTÓN TODO EL PAÍS ── */
.cmp-btn-all-country {
  margin-bottom: 12px; font-size: 13px;
  border-color: var(--cmp-orange); color: var(--cmp-orange);
}
.cmp-btn-all-country:hover { background: #FFF7ED; }

/* ── PRECIO PREVIEW ── */
.cmp-price-preview {
  display: block; margin-top: 6px;
  font-size: 22px; font-weight: 700;
  color: var(--cmp-orange); letter-spacing: -.5px;
  min-height: 28px;
}

/* ── FOTOS MÁS COMPACTAS ── */
.cmp-images-uploader { border: 2px dashed var(--cmp-gray-200); border-radius: 12px; padding: 16px; background: #FFFBF7; }
.cmp-images-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 12px; }
.cmp-image-thumb { width: 90px; height: 90px; border-radius: 8px; overflow: hidden; position: relative; border: 1.5px solid var(--cmp-gray-200); flex-shrink: 0; }
.cmp-image-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cmp-image-add { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border: 1.5px dashed var(--cmp-orange); border-radius: 8px; cursor: pointer; color: var(--cmp-orange); font-size: 14px; background: #FFF7ED; transition: all .15s; }
.cmp-image-add:hover { background: #FFEDD5; }
.cmp-image-add-icon { font-size: 18px; }

/* ── OPCIONES COTIZADOR COMPRADOR — mejor contraste ── */
.cmp-cot-opt {
  border-width: 2px !important;
  border-color: #C9CDD4 !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.07);
  font-weight: 500;
}
.cmp-cot-opt:hover {
  border-color: var(--cmp-orange) !important;
  box-shadow: 0 2px 8px rgba(249,115,22,.12);
}
.cmp-cot-opt.is-selected {
  border-color: var(--cmp-orange) !important;
  font-weight: 700 !important;
  color: #C2410C !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,.18) !important;
}

/* ── HINT ARRIBA DEL INPUT (wizard proveedor) ── */
.cmp-field-hint--top {
  display: block;
  font-size: 13px;
  color: #6B7280;
  margin-bottom: 8px;
  margin-top: 2px;
  line-height: 1.4;
}

/* ── BANNER SOS ── */
.cmp-sos-banner {
  border: 2px solid #FCA5A5;
  border-radius: 14px;
  background: linear-gradient(135deg, #FFF7ED 0%, #FEF2F2 100%);
  padding: 20px 22px 16px;
  transition: border-color .2s, box-shadow .2s;
}
.cmp-sos-banner--active {
  border-color: #EF4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.12);
}
.cmp-sos-banner__header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}
.cmp-sos-banner__icon {
  font-size: 36px;
  line-height: 1;
}
.cmp-sos-banner__titles {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cmp-sos-banner__title {
  font-size: 18px;
  font-weight: 700;
  color: #B91C1C;
  letter-spacing: -.3px;
}
.cmp-sos-banner__subtitle {
  font-size: 12px;
  font-weight: 600;
  color: #EF4444;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.cmp-sos-banner__desc {
  font-size: 14px;
  color: #374151;
  line-height: 1.55;
  margin: 0 0 12px;
}
.cmp-sos-banner__checks {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.cmp-sos-banner__checks li {
  font-size: 13px;
  color: #374151;
}
.cmp-sos-banner__options {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.cmp-sos-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 10px;
  border: 2px solid #E5E7EB;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  transition: all .15s;
  background: #fff;
}
.cmp-sos-option input { display: none; }
.cmp-sos-option--si { border-color: #FCA5A5; color: #B91C1C; }
.cmp-sos-option--si:has(input:checked),
.cmp-sos-banner--active .cmp-sos-option--si {
  background: #EF4444;
  border-color: #EF4444;
  color: #fff;
  box-shadow: 0 2px 8px rgba(239,68,68,.25);
}
.cmp-sos-option--no:has(input:checked) {
  background: #F3F4F6;
  border-color: #9CA3AF;
}
.cmp-sos-option__icon { font-size: 16px; }
.cmp-sos-banner__condiciones {
  display: inline-block;
  font-size: 12px;
  color: #6B7280;
  text-decoration: underline;
}
.cmp-field[data-field-id="sos_disponible"] { margin-top: 28px; }

.cmp-sos-banner__condiciones:hover { color: #B91C1C; }

/* ── BLOQUE DE PRECIO ── */
#cmp-precio-inputs-block { margin-top: 8px; max-width: 560px; }
.cmp-precio-fila-principal { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 10px; }
.cmp-precio-campo-wrap { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.cmp-descuento-campo-wrap { width: 130px; flex-shrink: 0; display: flex; flex-direction: column; gap: 3px; }
.cmp-precio-lbl { font-size: 13px; font-weight: 600; color: var(--cmp-gray-700); }
.cmp-precio-sublbl { font-size: 11px; color: var(--cmp-gray-400); }
.cmp-descuento-input-wrap { display: flex; align-items: center; gap: 0; }
.cmp-descuento-input-wrap .cmp-input--desc { border-radius: 8px 0 0 8px; width: 80px; text-align: center; }
.cmp-descuento-pct { background: var(--cmp-gray-100); border: 1px solid var(--cmp-gray-200); border-left: none; border-radius: 0 8px 8px 0; padding: 0 10px; font-size: 14px; font-weight: 600; color: var(--cmp-gray-500); display: flex; align-items: center; height: 44px; }
.cmp-precio-extra-toggle { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--cmp-gray-600); cursor: pointer; padding: 10px 12px; border: 1.5px dashed var(--cmp-gray-200); border-radius: 8px; margin-bottom: 8px; transition: border-color .15s; }
.cmp-precio-extra-toggle:hover { border-color: var(--cmp-orange); color: var(--cmp-gray-800); }
.cmp-precio-extra-toggle input { cursor: pointer; accent-color: var(--cmp-orange); width: 16px; height: 16px; }
#cmp-precio-por-persona-wrap { padding: 12px; background: #FFF7ED; border: 1.5px solid #FED7AA; border-radius: 8px; margin-bottom: 8px; max-width: 560px; }
#cmp-precio-por-persona-wrap .cmp-precio-lbl { color: var(--cmp-orange); }
.cmp-precio-persona-lbl { color: var(--cmp-orange); font-weight: 700; }
.cmp-precio-preview { margin-top: 10px; padding: 11px 14px; background: var(--cmp-gray-50); border-radius: 10px; border: 1px solid var(--cmp-gray-200); max-width: 560px; }
.cmp-precio-preview:empty { display: none; }
.cmp-precio-preview-row { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; font-size: 14px; }
.cmp-precio-preview-row + .cmp-precio-preview-row { border-top: 1px dashed var(--cmp-gray-200); }
.cmp-precio-preview-row span { color: var(--cmp-gray-600); }
.cmp-precio-preview-row strong { font-size: 16px; color: var(--cmp-gray-900); }
.cmp-precio-preview-row--contado strong { color: var(--cmp-green); }
.cmp-precio-warn { margin-top: 8px; padding: 7px 10px; background: #FEF3C7; border-radius: 6px; font-size: 12px; color: #92400E; }
/* Placeholder tenue — no confunde con valor real */
#cmp-precio-inputs-block input::placeholder,
#cmp-precio-por-persona-wrap input::placeholder { color: #C9CDD4; font-style: italic; }
@media (max-width: 600px) {
  .cmp-precio-fila-principal { flex-direction: column; }
  .cmp-descuento-campo-wrap { width: 100%; }
}

/* ══════════════════════════════════════════
   RESULTADOS — layout por rubros
══════════════════════════════════════════ */

/* Header */
.cmp-results-top { display: flex; justify-content: space-between; align-items: center; padding: 12px 0 8px; flex-wrap: wrap; gap: 8px; }
.cmp-badges-wrap { display: flex; flex-wrap: wrap; gap: 6px; padding: 8px 0; }
.cmp-badge-filtro { background: #F3F4F6; border-radius: 20px; padding: 4px 12px; font-size: 13px; color: #374151; }
.cmp-badge-filtro strong { color: #111827; }

/* Sección por rubro */
.cmp-rubro-section { margin-bottom: 32px; }
.cmp-rubro-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 0 10px; border-bottom: 2px solid var(--cmp-orange); margin-bottom: 14px; }
.cmp-rubro-header-left { display: flex; align-items: center; gap: 8px; }
.cmp-rubro-emoji { font-size: 22px; }
.cmp-rubro-nombre { font-size: 18px; font-weight: 700; color: #111827; }
.cmp-rubro-count { font-size: 13px; color: #6B7280; background: #F3F4F6; border-radius: 20px; padding: 2px 10px; }
.cmp-rubro-header-right { font-size: 13px; color: #6B7280; }
.cmp-rubro-total { font-weight: 700; color: #111827; margin-left: 4px; }

/* Grid de cards */
.cmp-rubro-cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.cmp-card-hidden { display: none; }
.cmp-btn-ver-mas { display: block; margin: 12px auto 0; }

/* Cards */
.cmp-result-card { background: #fff; border-radius: 14px; border: 2px solid #E5E7EB; overflow: hidden; transition: border-color .15s, box-shadow .15s; position: relative; }
.cmp-result-card:hover { border-color: #D1D5DB; box-shadow: 0 4px 16px rgba(0,0,0,.08); }
.cmp-result-card.is-selected { border-color: var(--cmp-orange); box-shadow: 0 0 0 3px rgba(249,115,22,.15); }
.cmp-card-img { aspect-ratio: 4/3; overflow: hidden; background: #F3F4F6; }
.cmp-card-img img { width: 100%; height: 100%; object-fit: cover; }
.cmp-card-no-img { display: flex; align-items: center; justify-content: center; height: 100%; font-size: 32px; color: #D1D5DB; }
.cmp-card-fav { position: absolute; top: 8px; right: 8px; background: rgba(255,255,255,.9); border: none; border-radius: 50%; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 14px; opacity: .7; transition: opacity .15s; }
.cmp-card-fav:hover, .cmp-card-fav.is-active { opacity: 1; }
.cmp-card-sos { position: absolute; top: 8px; left: 8px; background: #EF4444; color: #fff; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 6px; }
.cmp-card-body { padding: 12px; }
.cmp-card-title { font-size: 14px; font-weight: 600; color: #111827; margin-bottom: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cmp-card-razones { margin-bottom: 6px; }
.cmp-card-razon { display: block; font-size: 11px; color: #6B7280; }
.cmp-card-precios { margin-bottom: 10px; }
.cmp-card-precio-tarjeta { font-size: 15px; font-weight: 700; color: #111827; }
.cmp-card-precio-contado { font-size: 13px; color: #16A34A; }
.cmp-card-descuento { font-size: 11px; background: #DCFCE7; color: #16A34A; border-radius: 4px; padding: 1px 6px; margin-left: 4px; }
.cmp-card-actions { display: flex; justify-content: space-between; align-items: center; gap: 6px; }
.cmp-card-select-label { display: flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--cmp-orange); cursor: pointer; }
.cmp-card-select-label input { accent-color: var(--cmp-orange); width: 15px; height: 15px; }

/* Calculadora sticky */
.cmp-calculator { position: sticky; bottom: 0; background: #fff; border-top: 2px solid var(--cmp-orange); box-shadow: 0 -4px 20px rgba(0,0,0,.1); z-index: 100; padding: 16px 24px; }
.cmp-calc-body { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1px 340px; gap: 0; align-items: start; }
.cmp-calc-izquierda { min-width: 0; padding-right: 28px; }
.cmp-calc-totales { display: flex; gap: 24px; align-items: flex-start; flex-wrap: wrap; margin-bottom: 8px; }
.cmp-calc-item { display: flex; flex-direction: column; gap: 2px; }
.cmp-calc-label { font-size: 11px; color: #6B7280; text-transform: uppercase; letter-spacing: .3px; }
.cmp-calc-valor { font-size: 22px; font-weight: 700; color: #111827; }
.cmp-calc-valor--contado { color: #16A34A; }
.cmp-calc-personas { margin-left: auto; }
.cmp-calc-personas-controls { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.cmp-input--xs { width: 60px; text-align: center; padding: 4px 6px; font-size: 14px; }
#cmp-calc-personas-slider { width: 100px; accent-color: var(--cmp-orange); }
.cmp-calc-por-persona { display: flex; align-items: center; gap: 12px; font-size: 13px; color: #6B7280; margin-bottom: 8px; flex-wrap: wrap; }
.cmp-calc-ppp-label { font-weight: 700; color: #374151; font-size: 13px; }
.cmp-calc-ppp-item strong { color: #111827; font-size: 16px; font-weight: 700; }
.cmp-calc-ppp-item strong.verde { color: #16A34A; font-size: 16px; }
.cmp-calc-ppp-sep { color: #D1D5DB; font-size: 16px; }
.cmp-calc-disclaimer { font-size: 11px; color: #9CA3AF; margin-bottom: 10px; }
.cmp-calc-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.cmp-calc-divisor { background: #E5E7EB; align-self: stretch; width: 1px; margin: 0 4px; }
.cmp-calc-detalle { padding-left: 28px; max-height: 160px; overflow-y: auto; }
.cmp-calc-detalle-titulo { font-size: 11px; font-weight: 700; color: #9CA3AF; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.cmp-calc-detalle-count { background: var(--cmp-orange); color: #fff; font-size: 11px; border-radius: 10px; padding: 1px 7px; font-weight: 700; }
.cmp-calc-detalle-item { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; border-bottom: 1px dashed #F3F4F6; font-size: 12px; }
.cmp-calc-detalle-item:last-child { border-bottom: none; }
.cmp-calc-detalle-nombre { color: #374151; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 180px; }
.cmp-calc-detalle-precio { color: #111827; font-weight: 600; white-space: nowrap; }
.cmp-calc-detalle-vacio { font-size: 12px; color: #9CA3AF; font-style: italic; }

/* Responsive */
@media (max-width: 1100px) {
  .cmp-rubro-cards { grid-template-columns: repeat(4, 1fr); }
  .cmp-calc-body { grid-template-columns: 1fr; }
  .cmp-calc-divisor { display: none; }
  .cmp-calc-detalle { border-top: 1px solid #F3F4F6; padding-left: 0; padding-top: 10px; }
}
@media (max-width: 768px) {
  .cmp-rubro-cards { grid-template-columns: repeat(2, 1fr); }
  .cmp-calc-totales { gap: 12px; }
  .cmp-calc-personas { margin-left: 0; }
}
@media (max-width: 480px) {
  .cmp-rubro-cards { grid-template-columns: repeat(2, 1fr); }
  .cmp-calc-valor { font-size: 16px; }
}

/* ── FILTROS INLINE POR RUBRO ── */
.cmp-rubro-filtros { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-left: 12px; }
.cmp-filtro-group { position: relative; }
.cmp-filtro-btn { background: #F9FAFB; border: 1px solid #E5E7EB; border-radius: 20px; padding: 3px 10px; font-size: 12px; font-weight: 500; color: #374151; cursor: pointer; transition: all .15s; white-space: nowrap; }
.cmp-filtro-btn:hover, .cmp-filtro-btn.is-active { background: var(--cmp-orange); border-color: var(--cmp-orange); color: #fff; }
.cmp-filtro-dropdown { position: absolute; top: calc(100% + 6px); left: 0; background: #fff; border: 1px solid #E5E7EB; border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,.12); padding: 12px; z-index: 200; min-width: 180px; }
.cmp-filtro-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; font-size: 13px; }
.cmp-filtro-row label { width: 40px; color: #6B7280; }
.cmp-btn--xs { padding: 4px 12px; font-size: 12px; }
.cmp-stars-opts { display: flex; flex-direction: column; gap: 4px; }
.cmp-stars-opt { background: none; border: 1px solid #E5E7EB; border-radius: 6px; padding: 5px 10px; font-size: 13px; cursor: pointer; text-align: left; transition: all .15s; }
.cmp-stars-opt:hover { background: #FFF7ED; border-color: var(--cmp-orange); }
.cmp-stars-opt--clear { color: #6B7280; border-style: dashed; }
/* Layout calculadora izquierda/derecha */
.cmp-calc-izquierda { min-width: 0; }

/* ── FILTRO UBICACIÓN ── */
.cmp-ubic-opts { display: flex; flex-direction: column; gap: 4px; min-width: 150px; }
.cmp-ubic-opt { background: none; border: 1px solid #E5E7EB; border-radius: 6px; padding: 5px 10px; font-size: 13px; cursor: pointer; text-align: left; transition: all .15s; }
.cmp-ubic-opt:hover, .cmp-ubic-opt.is-active { background: #FFF7ED; border-color: var(--cmp-orange); color: var(--cmp-orange); font-weight: 600; }
.cmp-ubic-opt--clear { color: #6B7280; border-style: dashed; }

/* ── UPLOAD PROGRESS ── */
.cmp-upload-progress { margin-top: 8px; background: #F3F4F6; border-radius: 8px; overflow: hidden; padding: 8px 12px; }
.cmp-upload-progress-bar { height: 4px; background: var(--cmp-orange); border-radius: 4px; transition: width .3s ease; width: 0%; margin-bottom: 6px; }
.cmp-upload-progress-text { font-size: 12px; color: #6B7280; }
.cmp-image-thumb--uploading { opacity: .7; }
.cmp-img-uploading-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.6); font-size: 20px; border-radius: 8px; }
.cmp-upload-error { margin-top: 8px; padding: 8px 12px; background: #FEE2E2; border-radius: 6px; font-size: 13px; color: #B91C1C; }

/* ── FILTRO — mensajes de resultado ── */
.cmp-filtro-msg { font-size: 13px; padding: 8px 12px; border-radius: 8px; margin-top: 8px; }
.cmp-filtro-msg--ok { background: #ECFDF5; color: #16A34A; font-weight: 600; }
.cmp-filtro-msg--empty { background: #FEF3C7; color: #92400E; font-weight: 600; }
