/* Variables CSS para facilitar el mantenimiento y la personalización */
:root {
    --primary-blue: #007bff;
    --dark-blue: #0056b3;
    --light-blue: #e0f2ff; /* Para efectos sutiles */
    --text-dark: #333;
    --text-medium: #555;
    --text-light: #666;
    --bg-light: #f0f2f5;
    --card-bg: #ffffff;
    --border-light: #e0e0e0;
    --shadow-light: rgba(0, 0, 0, 0.08);
    --shadow-medium: rgba(0, 0, 0, 0.15);
    --shadow-strong: rgba(0, 0, 0, 0.25);
    --border-radius-base: 10px;
    --transition-speed: 0.3s;
}

/* Estilos básicos y reseteo */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Poppins', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; /* Usando Poppins si está disponible */
    background: linear-gradient(135deg, #e0f2ff 0%, #d1e8ff 100%); /* Gradiente suave */
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 20px;
    color: var(--text-dark);
    overflow-y: auto; /* Asegura scroll si el contenido es muy largo */
}

.container {
    background-color: var(--card-bg);
    padding: 40px;
    border-radius: var(--border-radius-base);
    box-shadow: 0 10px 30px var(--shadow-medium); /* Sombra más pronunciada */
    max-width: 600px;
    width: 100%;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 25px; /* Espacio entre secciones */
    transition: box-shadow var(--transition-speed) ease; /* Transición para sombra */
}

/* Efecto sutil en hover del contenedor, puede quitarse si se prefiere un look más estático */
.container:hover {
    box-shadow: 0 15px 40px var(--shadow-strong);
}

h1 {
    color: var(--primary-blue);
    margin-bottom: 25px;
    font-size: 2.5em;
    font-weight: 700; /* Más grueso */
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.05); /* Sombra sutil para el título */
}

h2 {
    color: var(--text-medium);
    margin-bottom: 15px;
    font-size: 1.6em;
    font-weight: 600;
    border-bottom: 1px solid var(--border-light);
    padding-bottom: 10px;
}

label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    text-align: left;
    color: var(--text-light);
}

input[type="text"],
input[type="number"] {
    width: 100%;
    padding: 12px 15px; /* Más padding horizontal */
    border: 1px solid var(--border-light);
    border-radius: var(--border-radius-base);
    font-size: 1.05em;
    margin-bottom: 15px;
    background-color: var(--bg-light); /* Fondo sutil para inputs */
    color: var(--text-dark);
    transition: all var(--transition-speed) ease; /* Transición para todo */
}

input[type="text"]::placeholder,
input[type="number"]::placeholder {
    color: #999;
}

input[type="text"]:focus,
input[type="number"]:focus {
    outline: none;
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 4px var(--light-blue); /* Sombra de enfoque más grande */
    background-color: var(--card-bg); /* Fondo blanco al enfocar */
}

.option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 15px;
    padding: 10px 0; /* Más padding */
    border-bottom: 1px dashed var(--border-light); /* Borde sutil */
}

.option:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.option label {
    margin-bottom: 0;
    flex-grow: 1;
    text-align: left;
    color: var(--text-dark); /* Color más oscuro para labels */
}

input[type="color"] {
    width: 60px;
    height: 35px;
    border: 2px solid var(--border-light); /* Borde para el selector de color */
    border-radius: 8px; /* Bordes más redondeados */
    cursor: pointer;
    background: var(--card-bg); /* Fondo blanco */
    padding: 0;
    transition: border-color var(--transition-speed) ease;
}

input[type="color"]:hover {
    border-color: var(--primary-blue);
}
input[type="color"]:focus {
    outline: none;
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px var(--light-blue);
}

input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}
input[type="color"]::-webkit-color-swatch {
    border: none; /* Eliminar borde interno */
    border-radius: 6px; /* Ajustar radios */
}

#qrcode-container {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 250px; /* Un poco más de altura */
    margin: 25px auto; /* Más margen */
    border: 2px solid var(--border-light); /* Borde más sólido */
    border-radius: var(--border-radius-base);
    padding: 15px; /* Más padding */
    background-color: var(--bg-light); /* Fondo sutil */
    box-shadow: inset 0 2px 5px rgba(0, 0, 0, 0.05); /* Sombra interna sutil */
    overflow: hidden; /* Asegura que el QR no se salga */
}

/* Estilos para el canvas generado por qrcode.js dentro de #qrcode-container */
#qrcode-container canvas {
    max-width: 100%;
    height: auto;
    display: block;
    border-radius: var(--border-radius-base);
    box-shadow: 0 5px 15px var(--shadow-light); /* Sombra para el QR */
    transform: scale(1); /* Estado inicial */
    transition: transform var(--transition-speed) ease-out, box-shadow var(--transition-speed) ease-out;
}

/* Efecto al generar el QR o al hacer hover (si quieres) */
#qrcode-container:not(:empty) canvas {
    transform: scale(1); /* Asegura que no se achique si hubo una animación */
    animation: qrFadeInScale 0.5s ease-out forwards; /* Animación de aparición */
}

@keyframes qrFadeInScale {
    from {
        opacity: 0;
        transform: scale(0.8);
        filter: blur(5px);
    }
    to {
        opacity: 1;
        transform: scale(1);
        filter: blur(0);
    }
}


button {
    background-color: var(--primary-blue);
    color: white;
    padding: 14px 30px; /* Más padding */
    border: none;
    border-radius: var(--border-radius-base);
    font-size: 1.15em; /* Más grande */
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0, 123, 255, 0.2); /* Sombra de botón */
    transition: all var(--transition-speed) ease; /* Transición para todo */
    margin: 0 10px;
    letter-spacing: 0.5px; /* Espaciado de letras */
}

button:hover {
    background-color: var(--dark-blue);
    transform: translateY(-3px); /* Levanta el botón */
    box-shadow: 0 7px 15px rgba(0, 123, 255, 0.3); /* Sombra más grande al levantar */
}

button:active {
    transform: translateY(0); /* Vuelve a la posición original */
    box-shadow: 0 2px 5px rgba(0, 123, 255, 0.2); /* Sombra pequeña al presionar */
}

button:disabled {
    background-color: #cccccc;
    cursor: not-allowed;
    opacity: 0.6; /* Un poco más opaco */
    transform: none;
    box-shadow: none;
}

/* Estilos para el área de mensajes (con animaciones) */
.message {
    padding: 12px 20px;
    margin-bottom: 25px; /* Más margen */
    border-radius: var(--border-radius-base);
    font-weight: 500;
    text-align: center;
    display: none; /* Ocultar por defecto */
    word-break: break-word;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); /* Sombra para mensajes */
    font-size: 0.95em;
    /* Animación inicial, luego se gestiona con JS */
    animation-duration: 0.4s;
    animation-timing-function: ease-out;
    animation-fill-mode: forwards;
}

.message.error {
    background-color: #ffe0e0;
    color: #cc0000;
    border: 1px solid #ff9999;
}

.message.warning {
    background-color: #fffacd;
    color: #e08000;
    border: 1px solid #ffcc66;
}

.message.success {
    background-color: #e6ffe6;
    color: #008000;
    border: 1px solid #99ff99;
}

/* Keyframes para animaciones de mensajes */
@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeOutUp {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-20px);
    }
}


/* Media Queries para responsividad */
@media (max-width: 600px) {
    .container {
        padding: 25px;
        gap: 15px;
    }

    h1 {
        font-size: 2em;
    }

    h2 {
        font-size: 1.4em;
    }

    .option {
        flex-direction: column;
        align-items: flex-start;
    }

    .option label {
        margin-bottom: 5px;
    }

    input[type="color"] {
        width: 100%;
        height: 40px;
    }

    button {
        display: block;
        width: 100%;
        margin: 10px 0;
        padding: 12px 20px;
        font-size: 1em;
    }

    .download-area {
        flex-direction: column;
    }
}

@media (max-width: 400px) {
    .container {
        padding: 15px;
    }
    h1 {
        font-size: 1.8em;
    }
    h2 {
        font-size: 1.2em;
    }
}