/* PixelGen Custom Styles - Purple Blue Theme */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* Variables de Tema - Colores Principales */
:root {
    /* Colores Primarios */
    --color-primary-pink: #ec4899;
    --color-primary-blue: #3c8ff5;

    /* Variaciones de Rosado */
    --color-pink-light: #f9a8d4;
    /* equivalente a pink-300 */
    --color-pink-medium: #f472b6;
    /* equivalente a pink-400 */
    --color-pink-base: #ec4899;
    /* equivalente a pink-500 */
    --color-pink-dark: #db2777;
    /* equivalente a pink-600 */

    /* Variaciones de Azul */
    --color-blue-light: #93c5fd;
    /* equivalente a blue-300 */
    --color-blue-medium: #60a5fa;
    /* equivalente a blue-400 */
    --color-blue-base: #3b82f6;
    /* equivalente a blue-500 */
    --color-blue-dark: #2563eb;
    /* equivalente a blue-600 */
    --color-blue-darker: #1d4ed8;
    /* equivalente a blue-700 */

    /* Gradientes Predefinidos */
    --gradient-primary: linear-gradient(135deg, var(--color-primary-pink) 0%, var(--color-primary-blue) 100%);
    --gradient-primary-to-r: linear-gradient(to right, var(--color-pink-dark), var(--color-blue-medium));
    --gradient-primary-to-br: linear-gradient(to bottom right, var(--color-pink-dark), var(--color-blue-medium));
}

* {
    font-family: 'Inter', sans-serif;
}

body {
    background: #0a0a0f;
}

/* Gradient Text */
.gradient-text {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Glass Card Effect */
.glass-card {
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Hover Glow Effect */
.hover-glow {
    transition: all 0.3s ease;
}

.hover-glow:hover {
    box-shadow: 0 0 30px color-mix(in srgb, var(--color-primary-pink) 40%, transparent);
    transform: translateY(-4px);
}

/* Grid Pattern Background */
.grid-pattern {
    background-image:
        linear-gradient(color-mix(in srgb, var(--color-primary-pink) 5%, transparent) 1px, transparent 1px),
        linear-gradient(90deg, color-mix(in srgb, var(--color-primary-pink) 5%, transparent) 1px, transparent 1px);
    background-size: 50px 50px;
}

/* Float Animation */
.animate-float {
    animation: float 6s ease-in-out infinite;
}

@keyframes float {

    0%,
    100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-20px);
    }
}

/* Fade In Animation */
@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* Upload Zone */
.upload-zone {
    border: 2px dashed color-mix(in srgb, var(--color-primary-pink) 30%, transparent);
    transition: all 0.3s ease;
}

.upload-zone:hover {
    border-color: color-mix(in srgb, var(--color-primary-pink) 60%, transparent);
    background: color-mix(in srgb, var(--color-primary-pink) 5%, transparent);
}

/* Coin Badge */
.coin-badge {
    background: linear-gradient(135deg, #ffd700, #ffed4e);
    color: #000;
    font-weight: 700;
}

/* Button Gradients */
.btn-primary {
    background: var(--gradient-primary);
}

.btn-pink-blue {
    background: var(--gradient-primary-to-r);
}

/* Card Hover Effects */
.card-hover {
    transition: all 0.3s ease;
}

.card-hover:hover {
    transform: translateY(-4px);
    box-shadow: 0 0 30px color-mix(in srgb, var(--color-primary-pink) 40%, transparent);
}

/* Blur Backgrounds for Floating Elements */
.blur-pink {
    background: color-mix(in srgb, var(--color-primary-pink) 20%, transparent);
    filter: blur(80px);
}

.blur-blue {
    background: color-mix(in srgb, var(--color-primary-blue) 20%, transparent);
    filter: blur(80px);
}

/* Progress Bar */
.progress-bar {
    background: var(--gradient-primary-to-r);
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-track {
    background: #1a1a2e;
}

::-webkit-scrollbar-thumb {
    background: var(--gradient-primary);
    border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, #ff006e 0%, var(--color-blue-base) 100%);
}

/* ========================================
   Clases Auxiliares (Utility Classes)
   ======================================== */

/* Clases de color de texto */
.text-primary-pink {
    color: var(--color-pink-medium);
}

.text-primary-blue {
    color: var(--color-blue-medium);
}

/* Clases de fondo */
.bg-primary-pink {
    background-color: var(--color-pink-dark);
}

.bg-primary-blue {
    background-color: var(--color-blue-dark);
}

/* Clases de borde */
.border-primary-pink {
    border-color: var(--color-pink-base);
}

.border-primary-blue {
    border-color: var(--color-blue-base);
}

/* Clases de gradiente */
.bg-gradient-primary {
    background: var(--gradient-primary);
}

.bg-gradient-primary-to-r {
    background: var(--gradient-primary-to-r);
}

.bg-gradient-primary-to-br {
    background: var(--gradient-primary-to-br);
}

/* ========================================
   Size Selector & Privacy Controls
   ======================================== */

/* Toggle switch hidden visually but accessible */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}