/* ===================== Avisos — polished card styles =====================
 * Migrated from css/styles.css (aviso block ~1873-1894).
 * All colors are token-based for full dark-mode compatibility.
 * Local hue vars at the top allow future theme overrides.
 * Class names are identical to those emitted by js/views/avisos.js.
 * ======================================================================= */

/* --- Local type-color vars (fallback hex used only as last resort) --- */
:root {
    --aviso-info:    var(--blue,    #0984E3);
    --aviso-alerta:  var(--orange,  #FDCB6E);
    --aviso-urgente: var(--red,     #E17055);
}

/* --- List container --- */
.avisos-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 24px 28px;
}

/* --- Base card --- */
.aviso-card {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border);
    border-radius: var(--radius-md);
    padding: 20px 22px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition);
}

.aviso-card:hover {
    box-shadow: var(--shadow-md);
}

/* --- Type accent borders --- */
.aviso-info    { border-left-color: var(--aviso-info); }
.aviso-alerta  { border-left-color: var(--aviso-alerta); }
.aviso-urgente { border-left-color: var(--aviso-urgente); }

/* --- Card header row --- */
.aviso-header {
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
}

/* --- Type badge (tinted per type) --- */
.aviso-tipo-badge {
    font-size: 0.73rem;
    font-weight: 600;
    padding: 2px 9px;
    border-radius: 10px;
    white-space: nowrap;
    /* default (info) tint */
    background: color-mix(in srgb, var(--aviso-info) 14%, transparent);
    color: var(--aviso-info);
}

.aviso-info .aviso-tipo-badge {
    background: color-mix(in srgb, var(--aviso-info) 14%, transparent);
    color: var(--aviso-info);
}

.aviso-alerta .aviso-tipo-badge {
    background: color-mix(in srgb, var(--aviso-alerta) 18%, transparent);
    color: color-mix(in srgb, var(--aviso-alerta) 80%, var(--text-primary));
}

.aviso-urgente .aviso-tipo-badge {
    background: color-mix(in srgb, var(--aviso-urgente) 14%, transparent);
    color: var(--aviso-urgente);
}

/* --- Title --- */
.aviso-titulo {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
    flex: 1;
    color: var(--text-primary);
    letter-spacing: var(--tracking-tight);
}

/* --- Author · date meta --- */
.aviso-meta {
    font-size: 0.78rem;
    color: var(--text-muted);
    margin-left: auto;
    white-space: nowrap;
}

/* --- Body text --- */
.aviso-corpo {
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--text-secondary);
    margin: 0;
    white-space: pre-wrap;
}

/* --- Footer (action buttons) --- */
.aviso-footer {
    display: flex;
    gap: 8px;
}
