/* =============================================================================
   ERROR / FEEDBACK MESSAGE
   Two layout tiers: inline (field-level) and banner (form/page-level).
   ============================================================================= */

/* ── Base wrapper ────────────────────────────────────────── */
.message { 
    display: flex; 
    align-items: flex-start; 
    gap: 8px; 
}

/* ── Motion: Calm Entry ──────────────────────────────────── */
/* Replaces shaking/bouncing with a professional fade-in */
.error-enter {
    animation: messageFadeIn var(--motion-fast) forwards;
}

@keyframes messageFadeIn {
    0% {
        opacity: 0;
        transform: translateY(-2px); /* Very subtle drop down */
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.message__icon { 
    flex-shrink: 0; 
    line-height: 1.5; 
}

.message__body { 
    flex: 1; 
    min-width: 0; 
}

/* ── Inline Layout (below form fields) ───────────────────── */
.message--inline {
    margin-top: 6px;
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.5;
    align-items: center;
}

.message--inline .message__icon { 
    font-size: 11px; 
}

/* Inline color variants */
.message--inline.message--error { color: var(--color-error); }
.message--inline.message--warning { color: var(--color-warning); }
.message--inline.message--success { color: var(--color-success); }
.message--inline.message--info { color: var(--color-calm-teal); }

/* ── Banner Layout (Form-level feedback) ─────────────────── */
.message--banner {
    position: relative;
    padding: 14px 16px;
    border-radius: 8px;
    border-width: 1px;
    border-style: solid;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.6;
    width: 100%;
    box-sizing: border-box;
    margin-top: 16px;
}

.message--banner .message__icon { 
    font-size: 16px; 
    margin-top: 2px; 
}

/* Banner color variants (Background + Border + Text) */
.message--banner.message--error {
    background-color: rgba(196, 62, 62, 0.08);
    border-color: rgba(196, 62, 62, 0.3);
    color: var(--color-error);
}

.message--banner.message--warning {
    background-color: rgba(242, 163, 60, 0.08);
    border-color: rgba(242, 163, 60, 0.3);
    color: var(--color-warning);
}

.message--banner.message--success {
    background-color: rgba(46, 133, 64, 0.08);
    border-color: rgba(46, 133, 64, 0.3);
    color: var(--color-success);
}

.message--banner.message--info {
    background-color: rgba(31, 138, 112, 0.08);
    border-color: rgba(31, 138, 112, 0.3);
    color: var(--color-calm-teal);
}

/* Ensure body text doesn't overflow into dismiss button space */
.message--banner .message__body { 
    padding-right: 28px; 
}

/* ── Dismiss Button (Banner only) ────────────────────────── */
.message__dismiss {
    position: absolute;
    top: 10px;
    right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    opacity: 0.6;
    transition: opacity var(--motion-fast), background-color var(--motion-fast), outline var(--motion-fast);
}

.message__dismiss:hover { 
    opacity: 1; 
    background-color: rgba(0, 0, 0, 0.06); 
}

.message__dismiss:focus-visible { 
    outline: var(--focus-outline);
    outline-offset: var(--focus-offset); 
}

/* Match dismiss button cross color to the variant */
.message--error .message__dismiss { color: var(--color-error); }
.message--warning .message__dismiss { color: var(--color-warning); }
.message--success .message__dismiss { color: var(--color-success); }
.message--info .message__dismiss { color: var(--color-calm-teal); }