/* ============================================================
   Alert banner — system notice band below the primary nav.
   Renderizzato sitewide, gated da: enabled + (titolo o testo) +
   finestra date. Layout centrato, sfondo brand-tint per dare
   evidenza senza scendere a marketing-strip.
   ============================================================ */

.mz-alert-banner {
    background-color: var(--brand-tint);
    border-top: 1px solid var(--brand);
    border-bottom: 1px solid var(--brand);
    color: var(--ink-1);
    font-family: var(--ff-ui);
}

.mz-alert-banner__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--s-1);
    padding: var(--s-4) var(--s-3);
    text-align: center;
}

.mz-alert-banner__head {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    max-width: 100%;
}

.mz-alert-banner__icon {
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
    color: var(--brand);
}

.mz-alert-banner__icon--inline {
    width: 18px;
    height: 18px;
    flex-basis: 18px;
    vertical-align: -3px;
    margin-right: var(--s-2);
}

.mz-alert-banner__title {
    margin: 0;
    font-family: var(--ff-ui);
    font-size: var(--t-md);
    line-height: var(--lh-md);
    font-weight: 700;
    letter-spacing: var(--tr-tight);
    color: var(--ink-1);
}

.mz-alert-banner__text {
    max-width: 65ch;
    margin: 0 auto;
    font-size: var(--t-base);
    line-height: var(--lh-base);
    color: var(--ink-1);
}

.mz-alert-banner__text > :first-child { margin-top: 0; }
.mz-alert-banner__text > :last-child { margin-bottom: 0; }

.mz-alert-banner__text a {
    color: var(--brand);
    font-weight: 600;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    transition: color var(--d-1) var(--ease);
}

.mz-alert-banner__text a:hover,
.mz-alert-banner__text a:focus-visible {
    color: var(--brand-ink);
}

.mz-alert-banner__text strong { font-weight: 700; }
.mz-alert-banner__text em { font-style: italic; }

/* Pulsante CTA opzionale, sotto titolo/testo. */
.mz-alert-banner__actions {
    display: flex;
    justify-content: center;
    margin-top: var(--s-1);
}

.mz-alert-banner__button {
    display: inline-flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-2) var(--s-4);
    border-radius: var(--radius-pill, 999px);
    background-color: var(--brand);
    color: var(--paper);
    font-family: var(--ff-ui);
    font-size: var(--t-sm);
    font-weight: 700;
    letter-spacing: var(--tr-tight);
    line-height: 1;
    text-decoration: none;
    border: 1px solid var(--brand);
    transition: background-color var(--d-1) var(--ease), border-color var(--d-1) var(--ease), transform var(--d-1) var(--ease);
}

.mz-alert-banner__button:hover,
.mz-alert-banner__button:focus-visible {
    background-color: var(--brand-ink);
    border-color: var(--brand-ink);
    color: var(--paper);
    transform: translateY(-1px);
}

.mz-alert-banner__button-icon {
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
    color: currentColor;
    transition: transform var(--d-1) var(--ease);
}

.mz-alert-banner__button:hover .mz-alert-banner__button-icon,
.mz-alert-banner__button:focus-visible .mz-alert-banner__button-icon {
    transform: translateX(2px);
}

@media (max-width: 640px) {
    .mz-alert-banner__inner {
        padding: var(--s-3) var(--s-3);
        gap: var(--s-1);
    }
    .mz-alert-banner__title {
        font-size: var(--t-base);
        line-height: var(--lh-base);
    }
    .mz-alert-banner__text {
        font-size: var(--t-sm);
        line-height: var(--lh-sm);
    }
    .mz-alert-banner__icon {
        width: 18px;
        height: 18px;
        flex-basis: 18px;
    }
    .mz-alert-banner__icon--inline {
        width: 16px;
        height: 16px;
        flex-basis: 16px;
    }
}
