/* =============================================================
   alertas2.css — sistema unificado de alertas/notificações.
   Estilos escopados em .glass-note-stack / .notification.
   Posicionado no topo centralizado, fonte Michroma.
   ============================================================= */

.glass-note-stack {
    --note-hue: 223;
    --note-fg: hsl(var(--note-hue), 10%, 10%);
    --note-bg: hsl(0, 0%, 100%);
    --note-divider: hsla(var(--note-hue), 10%, 10%, 0.15);
    --note-shadow: 0 2em 4em hsla(var(--note-hue), 30%, 10%, 0.28);
    --note-trans: 0.15s;

    --note-success: #22c55e;
    --note-error: #ef4444;
    --note-warning: #f59e0b;
    --note-info: #3b82f6;
    --note-confirm: #7c3aed;

    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 1.5em;
    padding: 2.5em 1.5em 1.5em;
    pointer-events: none;
    font-family: 'Michroma', "Helvetica Neue", Helvetica, Arial, sans-serif;
	text-transform: uppercase;
}

.glass-note-stack .notification {
    pointer-events: auto;
    width: min(60em, calc(100% - 3em));
    -webkit-user-select: none;
    user-select: none;
}

.glass-note-stack .notification__box {
    animation: glassNoteIn 0.32s cubic-bezier(0.22, 1, 0.36, 1);
    background-color: var(--note-bg);
    color: var(--note-fg);
    border-radius: 1.5em;
    box-shadow: var(--note-shadow);
    min-height: 12em;
    display: flex;
    align-items: stretch;
    overflow: hidden;
    transition: background-color var(--note-trans), color var(--note-trans);
}

.glass-note-stack .notification--out .notification__box {
    animation: glassNoteOut 0.28s ease-in forwards;
}

.glass-note-stack .notification__content {
    display: flex;
    align-items: center;
    padding: 2em 3em;
    width: 100%;
    min-width: 0;
}

.glass-note-stack .notification__icon {
    flex-shrink: 0;
    margin-right: 2.25em;
    width: 5em;
    height: 5em;
    display: grid;
    place-items: center;
    font-size: 1.6em;
    color: var(--level-color, var(--note-info));
}

.glass-note-stack .notification__icon i {
    font-size: 3em;
    line-height: 1;
}

.glass-note-stack .notification--success .notification__icon { --level-color: var(--note-success); }
.glass-note-stack .notification--error   .notification__icon { --level-color: var(--note-error); }
.glass-note-stack .notification--warning .notification__icon { --level-color: var(--note-warning); }
.glass-note-stack .notification--info    .notification__icon { --level-color: var(--note-info); }
.glass-note-stack .notification--confirm .notification__icon { --level-color: var(--note-confirm); }
.glass-note-stack .notification--error .btn_warning { --level-color: var(--note-error); }

.glass-note-stack .notification__text {
    line-height: 1.4;
    min-width: 0;
}

.glass-note-stack .notification__text-title {
    font-family: 'Michroma', sans-serif;
    font-size: 1.5em;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--note-fg);
    word-break: break-word;
}

.glass-note-stack .notification__text-subtitle {
    font-family: 'Michroma', sans-serif;
    font-size: 1.1em;
    font-weight: 400;
    opacity: 0.78;
    word-break: break-word;
    margin-top: 0.5em;
}

.glass-note-stack .notification__btns {
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    min-width: 12em;
    box-shadow: -1px 0 0 var(--note-divider);
    transition: box-shadow var(--note-trans);
}

.glass-note-stack .notification__btn {
    background-color: transparent;
    border: 0;
    color: inherit;
    font-family: 'Michroma', sans-serif;
    font-size: 1.1em;
    font-weight: 500;
    letter-spacing: 0.02em;
    line-height: 1;
    flex: 1;
    padding: 1.25em 1.5em;
    cursor: pointer;
    transition: background-color var(--note-trans), color var(--note-trans);
    -webkit-appearance: none;
    appearance: none;
    -webkit-tap-highlight-color: transparent;
}

.glass-note-stack .notification__btn-text {
    display: inline-block;
    pointer-events: none;
}

.glass-note-stack .notification__btn:hover {
    background-color: hsl(var(--note-hue), 10%, 95%);
}


.glass-note-stack .notification__btn:first-of-type { border-radius: 0 1.5em 0 0; }
.glass-note-stack .notification__btn:last-of-type  { border-radius: 0 0 1.5em 0; }
.glass-note-stack .notification__btn:only-child    { border-radius: 0 1.5em 1.5em 0; }

.glass-note-stack .notification__btn + .notification__btn {
    box-shadow: 0 -1px 0 var(--note-divider);
    font-weight: 400;
}

.glass-note-stack .notification__btn:active,
.glass-note-stack .notification__btn:focus {
    background-color: hsl(var(--note-hue), 10%, 95%);
    outline: transparent;
}

@supports selector(:focus-visible) {
    .glass-note-stack .notification__btn:focus { background-color: transparent; }
    .glass-note-stack .notification__btn:focus-visible,
    .glass-note-stack .notification__btn:active {
        background-color: hsl(var(--note-hue), 10%, 95%);
    }
}

@media (prefers-color-scheme: dark) {
    .glass-note-stack {
        --note-fg: hsl(var(--note-hue), 10%, 90%);
        --note-bg: hsl(var(--note-hue), 10%, 22%);
        --note-divider: hsla(var(--note-hue), 10%, 90%, 0.15);
        --note-shadow: 0 2em 4em hsla(0, 0%, 0%, 0.6);
    }
    .glass-note-stack .notification__btn:active,
    .glass-note-stack .notification__btn:focus {
        background-color: hsl(var(--note-hue), 10%, 32%);
    }
    @supports selector(:focus-visible) {
        .glass-note-stack .notification__btn:focus { background-color: transparent; }
        .glass-note-stack .notification__btn:focus-visible,
        .glass-note-stack .notification__btn:active {
            background-color: hsl(var(--note-hue), 10%, 32%);
        }
    }
}

@keyframes glassNoteIn {
    from { transform: translateY(-2em) scale(0.96); opacity: 0; }
    to   { transform: translateY(0) scale(1);        opacity: 1; }
}

@keyframes glassNoteOut {
    from { transform: translateY(0) scale(1);        opacity: 1; }
    to   { transform: translateY(-2em) scale(0.96); opacity: 0; }
}
