/* ===== COMPONENT-SPECIFIC STYLES ===== */

/* Notification Component Enhancements */
.notification--success {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    border-left: 4px solid #047857;
}

.notification--error {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    border-left: 4px solid #b91c1c;
}

.notification--warning {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    border-left: 4px solid #b45309;
}

.notification--info {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    border-left: 4px solid #1d4ed8;
}

/* Image Loading States */
.image--loading {
    opacity: 0.6;
    filter: blur(2px);
    transition: all var(--transition-normal);
}

.image--loaded {
    opacity: 1;
    filter: none;
}

.image--error {
    opacity: 0.5;
    filter: grayscale(100%);
}

/* Skip Link Component */
.skip-link {
    position: absolute;
    top: -40px;
    left: 6px;
    background: var(--color-primary);
    color: white;
    padding: 8px 16px;
    text-decoration: none;
    border-radius: var(--radius-sm);
    z-index: 10000;
    transition: top var(--transition-fast);
    font-weight: 600;
    font-size: var(--font-size-sm);
    /* Ocultar el skip link para interfaz más limpia */
    display: none;
}

.skip-link:focus {
    top: 6px;
    outline: 2px solid white;
    outline-offset: 2px;
}

/* Focus Visible States */
.focus-visible *:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

.focus-visible *:focus:not(:focus-visible) {
    outline: none;
}

.focus-visible *:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* Loading Animation */
@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.5;
    }
}

.loading-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* Smooth Transitions for Interactive Elements */
button,
a,
[role="button"] {
    transition: all var(--transition-fast);
}

button:active,
[role="button"]:active {
    transform: translateY(1px);
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    :root {
        --border-primary: rgba(255, 255, 255, 0.3);
        --border-secondary: rgba(255, 255, 255, 0.4);
        --text-secondary: #e0e0e0;
    }
    
    .content__section,
    .winner-section,
    .promo-section,
    .contact-section {
        border-width: 2px;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    
    .screenshot-container__image:hover {
        transform: none;
    }
    
    .promo-section__code:hover {
        transform: none;
    }
    
    .contact-section__discord-tag:hover {
        transform: none;
    }
}
