/* ============================================================
   DedicaQR — Sprint 28 — Event Bus
   CSS namespace: .evb-*
   ============================================================ */

/* === LAYOUT === */
.evb-page { padding: 24px; max-width: 1500px; margin: 0 auto; color: #1a1a1a; }
.evb-page-head { display: flex; justify-content: space-between; align-items: flex-start;
                 gap: 24px; margin-bottom: 22px; flex-wrap: wrap; }
.evb-title { margin: 0 0 4px; font-family: 'Playfair Display', Georgia, serif;
             color: #C9184A; font-size: 28px; font-weight: 700; }
.evb-subtitle { margin: 0; color: #6b6b6b; font-size: 14px; max-width: 800px; }
.evb-breadcrumb { font-size: 12px; color: #999; margin-bottom: 8px; }
.evb-breadcrumb a { color: #6b6b6b; text-decoration: none; }
.evb-breadcrumb a:hover { color: #C9184A; }
.evb-head-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.evb-counter { color: #999; font-size: 14px; font-weight: 400; }
.evb-section-title { margin: 26px 0 14px; font-size: 16px; font-weight: 600;
                     display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.evb-help-inline { color: #6b6b6b; font-size: 12px; font-weight: 400; }
.evb-dim { color: #999; }
.evb-tiny { font-size: 10px; }

/* === BADGE COUNT === */
.evb-badge-count { background: #C9184A; color: #fff; padding: 1px 7px;
    border-radius: 10px; font-size: 11px; margin-left: 4px; }

/* === DEPS WARNING === */
.evb-deps-warning { background: #FEF3C7; border-left: 4px solid #D4A24C;
    padding: 12px 16px; border-radius: 6px; margin-bottom: 18px; font-size: 13px; }
.evb-deps-warning div { margin: 2px 0; }
.evb-soft-warning { color: #6b6b6b; font-size: 12px; }

/* === STATS ROW === */
.evb-stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
                 margin-bottom: 26px; }
.evb-stat-card { background: #fff; padding: 16px 18px; border-radius: 12px;
                 box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.evb-stat-num { font-size: 28px; font-weight: 700; color: #C9184A; line-height: 1.1; }
.evb-stat-lbl { font-size: 11px; color: #6b6b6b; text-transform: uppercase;
                letter-spacing: 0.4px; margin-top: 4px; }
.evb-stat-breakdown { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.evb-stat-mini { padding: 2px 7px; border-radius: 10px; font-size: 10px; font-weight: 600; }
.evb-st-success { background: #DCFCE7; color: #166534; }
.evb-st-failure { background: #FEE2E2; color: #991B1B; }
.evb-st-active  { background: #DCFCE7; color: #166534; }
.evb-st-paused  { background: #FEF3C7; color: #92400E; }
.evb-st-archived{ background: #E5E7EB; color: #4B5563; }
.evb-st-skipped { background: #FEF3C7; color: #92400E; }
.evb-stat-clickable a { color: inherit; text-decoration: none; display: block; }
.evb-stat-clickable:hover { background: #FFFAFA; transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.08); transition: all 0.15s ease; }

/* === MATRIX === */
.evb-matrix-group { background: #fff; border-radius: 10px; margin-bottom: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05); overflow: hidden; }
.evb-matrix-group-summary { cursor: pointer; padding: 12px 18px; user-select: none;
    display: flex; align-items: center; gap: 10px; background: #FFFAFA; }
.evb-matrix-group-summary::marker { content: ''; }
.evb-matrix-group-summary::-webkit-details-marker { display: none; }
.evb-matrix { width: 100%; border-collapse: collapse; font-size: 12px; }
.evb-matrix th { background: #FFF1EE; padding: 9px 12px; text-align: left;
    font-size: 10px; color: #6b6b6b; text-transform: uppercase; letter-spacing: 0.4px;
    border-bottom: 2px solid #FFD6DD; }
.evb-matrix-event-col { min-width: 250px; }
.evb-matrix-listener-col { width: 140px; }
.evb-matrix td { padding: 8px 12px; border-bottom: 1px solid #FFF1EE; vertical-align: top; }
.evb-event-name { color: #C9184A; background: #FFF1EE; padding: 2px 6px;
    border-radius: 4px; font-size: 11px; font-family: monospace; }
.evb-event-desc { font-size: 10px; color: #6b6b6b; margin-top: 2px; }
.evb-since-tag { display: inline-block; background: #FFB3C1; color: #831843;
    padding: 1px 6px; border-radius: 4px; font-size: 9px; font-weight: 600;
    margin-top: 3px; }

/* Matrix cells */
.evb-cell { text-align: center; }
.evb-cell-bound { background: #F0FDF4; }
.evb-cell-empty { color: #ccc; font-size: 16px; }
.evb-binding-link { text-decoration: none; color: inherit; display: inline-flex;
    align-items: center; gap: 4px; }
.evb-binding-link:hover { color: #C9184A; }
.evb-binding-status { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.evb-binding-status.evb-st-active   { background: #22A052; }
.evb-binding-status.evb-st-paused   { background: #D4A24C; }
.evb-binding-status.evb-st-archived { background: #9CA3AF; }
.evb-binding-mode { font-size: 9px; padding: 1px 4px; border-radius: 3px;
    font-weight: 600; text-transform: uppercase; }
.evb-binding-mode.evb-mode-sync  { background: #DBEAFE; color: #1E40AF; }
.evb-binding-mode.evb-mode-async { background: #F3E8FF; color: #6B21A8; }
.evb-binding-priority { font-size: 10px; color: #6b6b6b; font-family: monospace; }
.evb-binding-pattern { font-size: 9px; color: #6b6b6b; font-style: italic; }

/* === CATEGORY PILLS === */
.evb-cat-pill { display: inline-block; padding: 3px 10px; border-radius: 12px;
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; }
.evb-cat-security     { background: #FCE7F3; color: #831843; }
.evb-cat-billing      { background: #FEF3C7; color: #92400E; }
.evb-cat-content      { background: #DCFCE7; color: #166534; }
.evb-cat-integrations { background: #F3E8FF; color: #6B21A8; }
.evb-cat-system       { background: #E5E7EB; color: #4B5563; }
.evb-cat-data         { background: #DBEAFE; color: #1E40AF; }

/* === TABLE === */
.evb-table-wrap { background: #fff; border-radius: 10px; overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.evb-table { width: 100%; border-collapse: collapse; }
.evb-table th { background: #FFF1EE; padding: 11px 12px; text-align: left;
    font-size: 11px; font-weight: 600; color: #6b6b6b; text-transform: uppercase;
    letter-spacing: 0.4px; border-bottom: 2px solid #FFD6DD; }
.evb-table td { padding: 10px 12px; border-bottom: 1px solid #FFF1EE;
    vertical-align: top; font-size: 13px; }
.evb-table tbody tr:hover { background: #FFFAFA; }
.evb-id { font-family: monospace; font-size: 11px; color: #999; }
.evb-class-hint { font-size: 11px; color: #6b6b6b; margin-top: 2px; font-family: monospace; }
.evb-priority-pill { background: #E5E7EB; color: #4B5563; padding: 2px 8px;
    border-radius: 4px; font-family: monospace; font-size: 11px; }
.evb-mode-pill { padding: 2px 8px; border-radius: 4px; font-size: 11px;
    font-weight: 600; text-transform: uppercase; }
.evb-mode-pill.evb-mode-sync  { background: #DBEAFE; color: #1E40AF; }
.evb-mode-pill.evb-mode-async { background: #F3E8FF; color: #6B21A8; }
.evb-status-pill { padding: 3px 10px; border-radius: 6px; font-size: 11px;
    font-weight: 600; }
.evb-status-pill.evb-st-active   { background: #DCFCE7; color: #166534; }
.evb-status-pill.evb-st-paused   { background: #FEF3C7; color: #92400E; }
.evb-status-pill.evb-st-archived { background: #E5E7EB; color: #4B5563; }
.evb-last-status { font-size: 11px; font-weight: 600; padding: 2px 6px; border-radius: 4px; }
.evb-last-status.evb-last-success { background: #DCFCE7; color: #166534; }
.evb-last-status.evb-last-failure { background: #FEE2E2; color: #991B1B; }
.evb-last-status.evb-last-skipped { background: #FEF3C7; color: #92400E; }
.evb-failure-hint { font-size: 10px; color: #991B1B; margin-top: 2px; }
.evb-row-status-paused   { background: #FFFBEB !important; }
.evb-row-status-archived { background: #F9FAFB !important; opacity: 0.7; }

/* === DETAIL SECTIONS === */
.evb-section { background: #fff; padding: 20px; border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05); margin-bottom: 16px; }
.evb-dl dt { font-weight: 600; color: #6b6b6b; font-size: 11px; margin-top: 10px;
    text-transform: uppercase; letter-spacing: 0.4px; }
.evb-dl dd { margin: 3px 0 0; font-size: 13px; }
.evb-show-grid { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; }
.evb-section-wide { grid-column: span 2; }
.evb-mono { font-family: monospace; font-size: 12px; background: #FFF1EE;
    padding: 2px 6px; border-radius: 4px; }

/* === FORM === */
.evb-form { background: #fff; padding: 24px; border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.evb-form-row { margin-bottom: 16px; }
.evb-form-row label { display: block; font-size: 12px; color: #4b4b4b;
    font-weight: 600; margin-bottom: 4px; }
.evb-form-help { font-size: 11px; color: #6b6b6b; margin-top: 4px; }
.evb-form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.evb-form-actions { display: flex; gap: 8px; justify-content: flex-end;
    margin-top: 18px; border-top: 1px solid #FFE4EC; padding-top: 14px; }
.evb-textarea-mono { font-family: monospace; font-size: 12px; min-height: 100px; }

/* === DISPATCH TEST === */
.evb-dispatch-warn { background: #FEF3C7; border-left: 4px solid #D4A24C;
    padding: 12px 16px; border-radius: 6px; margin-bottom: 16px; font-size: 13px;
    color: #92400E; }
.evb-dispatch-result { background: #fff; padding: 18px; border-radius: 10px;
    margin-top: 18px; box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.evb-result-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
    margin: 12px 0; }
.evb-result-stat { padding: 10px; background: #FFFAFA; border-radius: 6px;
    text-align: center; }
.evb-result-num { font-size: 22px; font-weight: 700; color: #C9184A; }
.evb-result-lbl { font-size: 10px; color: #6b6b6b; text-transform: uppercase; }
.evb-listener-results { margin-top: 14px; }
.evb-lr-item { padding: 8px 12px; background: #FFFAFA; border-radius: 6px;
    margin-bottom: 4px; font-size: 12px; display: flex; align-items: center; gap: 10px; }
.evb-lr-status-success { border-left: 3px solid #22A052; }
.evb-lr-status-failure { border-left: 3px solid #C9184A; }
.evb-lr-status-skipped { border-left: 3px solid #D4A24C; }
.evb-lr-status-queued  { border-left: 3px solid #6B21A8; }
.evb-error-banner { background: #FEE2E2; border-left: 4px solid #C9184A;
    padding: 12px 16px; border-radius: 6px; margin-bottom: 16px; }

/* === QUEUE === */
.evb-queue-status-pending    { background: #DBEAFE; color: #1E40AF; }
.evb-queue-status-processing { background: #FEF3C7; color: #92400E; }
.evb-queue-status-done       { background: #DCFCE7; color: #166534; }
.evb-queue-status-failed     { background: #FEE2E2; color: #991B1B; }
.evb-queue-status-cancelled  { background: #E5E7EB; color: #4B5563; }
.evb-queue-pill { padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; }
.evb-attempts-cell { font-family: monospace; font-size: 11px; }
.evb-error-cell { font-size: 11px; color: #991B1B; max-width: 300px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* === LISTENER REGISTRY === */
.evb-listener-card { background: #fff; padding: 16px 20px; border-radius: 10px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05); margin-bottom: 10px;
    border-left: 4px solid #C9184A; }
.evb-listener-card.evb-listener-unavail { border-left-color: #9CA3AF;
    background: #FAFAFA; opacity: 0.85; }
.evb-listener-card h3 { margin: 0 0 4px; font-size: 16px; }
.evb-listener-class { font-family: monospace; font-size: 11px; color: #6b6b6b; }
.evb-listener-desc { font-size: 13px; color: #4b4b4b; margin-top: 6px; }
.evb-listener-badge { float: right; padding: 3px 10px; border-radius: 6px;
    font-size: 11px; font-weight: 600; }
.evb-listener-badge.evb-avail-yes { background: #DCFCE7; color: #166534; }
.evb-listener-badge.evb-avail-no  { background: #E5E7EB; color: #4B5563; }

/* === PRE / CODE === */
.evb-pre { background: #FFFAFA; padding: 14px; border-radius: 8px;
    font-size: 11px; line-height: 1.5; max-height: 400px; overflow: auto;
    border: 1px solid #FFE4EC; margin: 0; font-family: monospace; }

/* === RESPONSIVE === */
@media (max-width: 1100px) {
    .evb-stats-row { grid-template-columns: repeat(2, 1fr); }
    .evb-show-grid { grid-template-columns: 1fr; }
    .evb-section-wide { grid-column: span 1; }
    .evb-form-grid-2 { grid-template-columns: 1fr; }
    .evb-result-stats { grid-template-columns: repeat(2, 1fr); }
    .evb-matrix { font-size: 11px; }
    .evb-matrix th, .evb-matrix td { padding: 7px 8px; }
}
@media (max-width: 700px) {
    .evb-page-head { flex-direction: column; }
    .evb-stats-row { grid-template-columns: 1fr; }
    .evb-table th, .evb-table td { padding: 8px 6px; font-size: 11px; }
    .evb-matrix-listener-col { width: auto; }
}

/* ============================================================
 * ADITIONS - clases faltantes detectadas por diff vista vs CSS
 * Agregadas por fixcsseb.php para completar el design del modulo event-bus
 * ============================================================ */

/* === STATS GRID (alternative to evb-stats-row, 6 cards) === */
.evb-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 14px;
    margin-bottom: 26px;
}

/* Stat card variants */
.evb-stat-primary {
    border-left: 4px solid #C9184A;
}
.evb-stat-primary .evb-stat-num { color: #C9184A; }

.evb-stat-success {
    border-left: 4px solid #10b981;
}
.evb-stat-success .evb-stat-num { color: #10b981; }

.evb-stat-fail {
    border-left: 4px solid #ef4444;
}
.evb-stat-fail .evb-stat-num { color: #ef4444; }

/* === MINI STATS (inline, in tables) === */
.evb-stats-mini {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
    font-size: 11px;
}
.evb-stat-mini-success {
    background: #DCFCE7;
    color: #166534;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 600;
}
.evb-stat-mini-fail {
    background: #FEE2E2;
    color: #991B1B;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 600;
}

/* === TABLE EXTRAS === */
.evb-empty {
    text-align: center;
    color: #999;
    padding: 24px;
    font-style: italic;
    font-size: 13px;
}

.evb-row.evb-status-paused   td { background: #FFFBEB; }
.evb-row.evb-status-archived td { background: #F9FAFB; opacity: 0.7; }

.evb-pattern {
    background: #FFF1EE;
    color: #C9184A;
    padding: 2px 7px;
    border-radius: 4px;
    font-family: monospace;
    font-size: 11px;
    font-weight: 600;
}

.evb-listener-cell {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.evb-listener-cell strong {
    font-size: 13px;
    color: #1a1a1a;
}

.evb-priority {
    background: #E5E7EB;
    color: #4B5563;
    padding: 2px 8px;
    border-radius: 4px;
    font-family: monospace;
    font-size: 11px;
    font-weight: 600;
}

/* Mode pill (alias para vista) */
.evb-mode {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.evb-mode.evb-mode-sync   { background: #DBEAFE; color: #1E40AF; }
.evb-mode.evb-mode-async  { background: #F3E8FF; color: #6B21A8; }

/* Status pill (alias para vista) */
.evb-status {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
}
.evb-status.evb-st-active   { background: #DCFCE7; color: #166534; }
.evb-status.evb-st-paused   { background: #FEF3C7; color: #92400E; }
.evb-status.evb-st-archived { background: #E5E7EB; color: #4B5563; }

.evb-when {
    font-size: 11px;
    color: #6b6b6b;
    font-family: monospace;
}

.evb-help {
    font-size: 12px;
    color: #6b6b6b;
    margin: 0 0 14px;
    font-style: italic;
}

.evb-soft-warn {
    color: #6b6b6b;
    font-size: 12px;
    font-style: italic;
}

/* === CATEGORY GROUPS (for matrix view) === */
.evb-cat-group {
    background: #fff;
    border-radius: 10px;
    margin-bottom: 14px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    overflow: hidden;
}
.evb-cat-header {
    margin: 0;
    padding: 12px 18px;
    background: #FFFAFA;
    border-left: 4px solid #C9184A;
    font-size: 14px;
    font-weight: 600;
    color: #4b4b4b;
    display: flex;
    align-items: center;
    gap: 8px;
    text-transform: capitalize;
}
.evb-cat-header .evb-counter {
    color: #999;
    font-size: 12px;
    font-weight: 400;
}

/* === MATRIX EXTRAS === */
.evb-matrix-wrap {
    overflow-x: auto;
}

.evb-matrix-event {
    min-width: 240px;
    font-size: 12px;
    vertical-align: top;
}
.evb-matrix-event code {
    background: #FFF1EE;
    color: #C9184A;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
}

.evb-matrix-cell {
    text-align: center;
    width: 110px;
    vertical-align: middle;
}

.evb-cell-none {
    color: #ccc;
    font-size: 16px;
}

.evb-cell-active {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    text-decoration: none;
    color: inherit;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 0.15s, transform 0.15s;
    font-weight: 600;
    font-size: 13px;
}
.evb-cell-active:hover {
    background: #FFF1EE;
    transform: translateY(-1px);
}
.evb-cell-active.evb-cell-st-active   { color: #166534; }
.evb-cell-active.evb-cell-st-paused   { color: #92400E; }
.evb-cell-active.evb-cell-st-archived { color: #4B5563; opacity: 0.7; }

.evb-cell-icon { font-size: 14px; }

.evb-cell-async {
    background: #F3E8FF;
    color: #6B21A8;
    padding: 0 4px;
    border-radius: 3px;
    font-size: 9px;
    margin-left: 2px;
    font-weight: 700;
}

/* === RESPONSIVE for stats grid === */
@media (max-width: 1100px) {
    .evb-stats-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 700px) {
    .evb-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .evb-matrix-cell {
        width: auto;
    }
}
@media (max-width: 480px) {
    .evb-stats-grid {
        grid-template-columns: 1fr;
    }
}
