/* ============================================================
   alerts.css
   ============================================================ */

.alert {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    margin-bottom: var(--space-4);
    border-left: 4px solid transparent;
}

.alert--success { background: rgba(46,125,50,.08);  border-color: var(--color-success); color: #1b5e20; }
.alert--warning { background: rgba(237,185,73,.12); border-color: var(--color-warning); color: #5d4200; }
.alert--error,
.alert--danger  { background: rgba(198,40,40,.08);  border-color: var(--color-danger);  color: #7f0000; }
.alert--info    { background: rgba(21,101,192,.08); border-color: var(--color-info);    color: #0d3a6b; }

.alert__close {
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    color: inherit;
    opacity: .6;
    flex-shrink: 0;
    padding: 0;
    transition: opacity var(--transition);
}
.alert__close:hover { opacity: 1; }
