/* Footer de versión */
.footer-version {
    text-align: center;
    margin-top: 40px;
    color: #888;
    font-size: 0.95em;
}
/* Botón especial para el tablón */
.btn-tablon {
    padding: 10px 24px;
    background: #ffd700;
    color: #3b2f2f;
    font-weight: bold;
    border-radius: 8px;
    border: 2px solid #a67c52;
    font-size: 1.1rem;
    cursor: pointer;
    margin-bottom: 10px;
}
.btn-tablon:hover {
    background: #ffcc00;
    color: #222;
}

.enlace-volver {
    color: #007bff;
    text-decoration: underline;
    font-size: 1rem;
    margin-bottom: 20px;
    display: inline-block;
}

/* --- THEME VARIABLES --- */
:root {
    --color-background: linear-gradient(135deg, #e0f7fa 0%, #fffde4 100%);
    --color-surface: #fff;
    --color-text-primary: #333;
    --color-text-secondary: #555;
    --color-text-muted: #7f8c8d;
    --color-primary: #3498db;
    --color-primary-hover: #2980b9;
    --color-border: #e0e0e0;
    --color-shadow: rgba(0, 0, 0, 0.1);
    --color-card-bg: #fafafa;
    --color-card-border: #ddd;
    --color-header-bg: #fff;
    --color-header-border: #eee;
    --color-header-shadow: rgba(0,0,0,0.05);
    --color-header-link: #3498db;
    --color-header-link-hover-bg: #f0f0f0;
    --color-header-link-hover-text: #2980b9;
    --color-footer-bg: rgba(255, 255, 255, 0.6);
    --color-footer-text: #555;
    --color-h1-h2: #34495e;
    --color-input-border: #ccc;
    --color-success-bg: #eaf7ed;
    --color-success-text: #27ae60;
    --color-error-bg: #fdecea;
    --color-error-text: #c0392b;
}

body.dark-mode {
    --color-background: #121212;
    --color-surface: #1e1e1e;
    --color-text-primary: #e0e0e0;
    --color-text-secondary: #b0b0b0;
    --color-text-muted: #888;
    --color-primary: #63b3ed; /* Azul más brillante para mejor contraste en modo oscuro */
    --color-primary-hover: #5dade2;
    --color-border: #333;
    --color-shadow: rgba(0, 0, 0, 0.2);
    --color-card-bg: #2a2a2a;
    --color-card-border: #444;
    --color-header-bg: #1e1e1e;
    --color-header-border: #333;
    --color-header-shadow: rgba(0,0,0,0.2);
    --color-header-link: #87CEFA; /* CORRECCIÓN: Azul cielo claro para máxima visibilidad en el header */
    --color-header-link-hover-bg: #333;
    --color-header-link-hover-text: #fff;
    --color-footer-bg: #1e1e1e;
    --color-footer-text: #b0b0b0;
    --color-h1-h2: #ecf0f1;
    --color-input-border: #555;
    --color-success-bg: rgba(39, 174, 96, 0.2);
    --color-success-text: #2ecc71;
    --color-error-bg: rgba(192, 57, 43, 0.2);
    --color-error-text: #e74c3c;
}

/* Mejora de visibilidad para el menú móvil en modo oscuro */
body.dark-mode .mobile-nav a {
    color: #FFFFFF; /* Blanco para máxima legibilidad */
}

/* --- ESTILOS PARA EL LAYOUT DE TIENDA/CATÁLOGO/TABLÓN --- */
.tienda-layout {
    display: flex;
    gap: 30px;
    align-items: flex-start;
}
.tienda-sidebar {
    flex: 0 0 250px; /* No crece, no se encoge, base de 250px */
    position: sticky; /* Para que se quede fija al hacer scroll */
    top: 20px;
}
.tienda-sidebar .tienda-controles {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: stretch; /* Los elementos se estiran */
    text-align: left;
}
.tienda-productos-main {
    flex: 1; /* Ocupa el resto del espacio */
}

/* --- Media Query para el layout en móvil --- */
@media (max-width: 850px) {
    .tienda-layout {
        flex-direction: column; /* Apila la barra lateral y los productos */
    }
    .tienda-sidebar {
        position: static; /* Quita el 'sticky' en móvil */
        width: 100%;
    }
}

/* --- ESTILOS PARA EL MENÚ HAMBURGUESA (MÓVIL) --- */
.menu-toggle {
    display: none; /* Oculto en escritorio */
    background: none;
    border: none;
    font-size: 2em;
    cursor: pointer;
    color: var(--color-text-primary);
}

/* Estilos generales para todas las páginas */
body {
    font-family: 'Arial', sans-serif;
    background: var(--color-background);
    color: var(--color-text-primary);
    margin: 0;
    padding: 20px;
    line-height: 1.6;
    transition: background-color 0.3s, color 0.3s;
}

.container {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
    background-color: var(--color-surface);
    border-radius: 10px;
    box-shadow: 0 4px 8px var(--color-shadow);
}

h1, h2 {
    color: var(--color-h1-h2);
    text-align: center;
}

/* Ocultar el menú móvil por defecto en todas las vistas */
.mobile-nav {
    display: none;
    width: 100%; /* Asegura que ocupe todo el ancho cuando sea visible */
}

.logo {
    font-size: 1.5em;
    font-weight: bold;
    color: var(--color-text-primary);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-logo {
    height: 40px; /* Altura del logo en la cabecera */
    width: auto;
}

.header-logo {
    height: 45px; /* Altura fija para el logo */
    width: auto;
}

/* Estilos del Header y Navegación */
header {
    padding: 0; /* Quitamos el padding para que las barras ocupen todo el ancho */
    background-color: var(--color-header-bg);
    box-shadow: 0 2px 4px var(--color-header-shadow);
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    width: 100%;
}

/* Barra principal (logo, búsqueda, acciones) */
.header-main-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 15px 2%;
    width: 96%;
    border-bottom: 1px solid var(--color-border);
}

/* --- ESTILOS PARA EL NUEVO FILTRO DE JUEGO GLOBAL --- */
.game-filter-container {
    display: flex;
    align-items: center;
}
.game-filter {
    display: flex;
    gap: 10px;
    background-color: var(--color-surface);
    padding: 5px;
    border-radius: 25px;
    border: 1px solid var(--color-border);
}
.game-filter label {
    cursor: pointer;
    position: relative;
}
.game-filter input[type="radio"] {
    display: none; /* Ocultamos el radio button real */
}
.tcg-logo-filter {
    width: 40px;
    height: 40px;
    object-fit: contain;
    border-radius: 50%;
    transition: transform 0.2s, box-shadow 0.2s;
}
.game-filter input[type="radio"]:checked + .tcg-logo-filter {
    transform: scale(1.1);
    box-shadow: 0 0 10px var(--color-primary);
}

/* Contenedor de la búsqueda */
.header-search-form {
    flex-grow: 1; /* Permite que la barra de búsqueda crezca */
    display: flex;
    max-width: 600px; /* Ancho máximo para la búsqueda */
    margin: 0 20px; /* Espacio a los lados */
}

.header-search-form input {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid var(--color-input-border);
    border-radius: 25px 0 0 25px; /* Bordes redondeados a la izquierda */
    font-size: 1em;
    background-color: var(--color-surface);
    color: var(--color-text-primary);
    border-right: none; /* Quitar el borde derecho para unir con el botón */
}

.header-search-form button {
    padding: 0 15px;
    border: 1px solid var(--color-input-border);
    border-left: none;
    background-color: var(--color-surface);
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: 0 25px 25px 0; /* Bordes redondeados a la derecha */
    font-size: 1.2em;
}

/* Contenedor para botones de la derecha */
.header-right {
    display: flex;
    align-items: center;
    gap: 15px;
}

.nav-bar {
    width: 100%;
    background-color: #212F42; /* Azul oscuro para la barra de navegación */
    padding: 5px 0;
}

header nav.desktop-nav {
    display: flex;
    align-items: center;
    justify-content: center; /* Centra los enlaces */
    gap: 25px; /* Aumenta el espacio entre enlaces */
}

header .nav-bar a {
    text-decoration: none;
    color: #d0d3d4; /* Un gris claro para el estado normal en modo claro */
    font-weight: bold;
    padding: 8px 15px;
    border-radius: 5px;
    transition: color 0.2s, background-color 0.2s;
}

header .nav-bar a:hover {
    background-color: var(--color-primary-hover); /* Un azul un poco más oscuro para el fondo */
    color: #FFD700 !important; /* Color dorado/amarillo para resaltar, como sugeriste */
}

/* --- THEME TOGGLE BUTTON --- */
.theme-toggle {
    background: none;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    width: 38px;
    height: 38px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2em;
    transition: background-color 0.2s, color 0.2s, border-color 0.2s;
    color: var(--color-text-secondary);
    padding: 0;
}

.theme-toggle:hover {
    background-color: var(--color-header-link-hover-bg);
}

/* Botón de Vender en el header */
.btn-vender {
    background-color: #2ecc71;
    color: white;
    padding: 10px 20px;
    border-radius: 5px;
    text-decoration: none;
    font-weight: bold;
    transition: background-color 0.2s;    
}

.btn-vender:hover {
    background-color: #27ae60;
}

/* --- FIN NUEVOS ESTILOS HEADER --- */
/* Estilos para los enlaces de login/registro en el header */
.auth-links-desktop a {
    margin: 0 8px;
    font-weight: bold;
    color: var(--color-primary);
    text-decoration: none;
}

/* Mejora de visibilidad para enlaces de login/registro en modo oscuro */
body.dark-mode .auth-links-desktop a {
    color: #ecf0f1; /* Un gris muy claro, casi blanco */
}
body.dark-mode .auth-links-desktop a:hover {
    color: var(--color-primary); /* Se vuelve azul al pasar el mouse */
}

/* Estilo para el fondo de la página de login */
 
/* --- NUEVOS ESTILOS PARA INDEX.HTML --- */
.hero-search {
    background: #2c3e50; /* This is a specific design element, might not need a variable */
    color: white;
    padding: 80px 20px; /* Aumentamos el padding vertical para centrar más la sección */
    text-align: center;
}

.hero-search-title {
    font-size: 2.8em; /* Un poco más grande */
    margin-bottom: 10px;
    color: white;
}

.hero-search-subtitle {
    font-size: 1.2em;
    color: #bdc3c7; /* Also specific to this dark hero section */
    margin-bottom: 30px;
}

.hero-search-title .sub-headline {
    display: block;
    font-size: 0.6em;
    font-weight: normal;
    margin-top: 10px;
    letter-spacing: 0.5px; /* Sutil espaciado de letras */
}

.hero-search-form {
    display: flex;
    justify-content: center;
    align-items: center; /* Para alinear verticalmente los botones y el input */
    gap: 10px;
    max-width: 750px; /* Aumentamos el ancho para que los elementos más grandes encajen bien */
    margin: 0 auto;
}

.hero-search-form .search-logo {
    height: 80px; /* Hacemos el logo más grande */
    width: auto;
}

.hero-search-form input {
    width: 100%;
    padding: 18px; /* Hacemos el input más alto */
    border: 1px solid rgba(255, 255, 255, 0.2); /* Specific */
    border-radius: 5px;
    font-size: 1.1em; /* Aumentamos el tamaño del texto */
    background-color: rgba(255, 255, 255, 0.1);
    color: white;
}

.hero-search-form input::placeholder {
    color: rgba(255, 255, 255, 0.6); /* Placeholder más claro */
}

.hero-search-form button {
    padding: 15px 25px; /* Un poco menos de padding para que quepa mejor */
    border: none;
    border-radius: 5px;
    background-color: var(--color-primary);
    color: white;
    font-size: 1em;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.2s;
}

.hero-search-form button:hover {
    background-color: var(--color-primary-hover);
}

.btn-vender-hero {
    display: inline-block;
    padding: 15px 25px;
    background-color: #2ecc71;
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.2s;
    white-space: nowrap; /* Evita que el texto se parta en dos líneas */
}

.btn-vender-hero:hover {
    background-color: #27ae60;
}

.features-section {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 50px 20px;
}

.features-section h2 {
    color: var(--color-h1-h2);
}

.btn-mision {
    background-color: #e67e22;
    color: white;
    padding: 12px 25px;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    margin-top: 15px;
    display: inline-block;
    transition: background-color 0.2s;
}

.btn-mision:hover {
    background-color: #d35400;
}

/* --- FIN NUEVOS ESTILOS INDEX.HTML --- */

/* Estilos para botones generales */
.btn {
    display: inline-block;
    padding: 12px 24px;
    font-size: 16px;
    font-weight: bold;
    text-decoration: none;
    color: #fff;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.btn-azul {
    background-color: var(--color-primary);
}

.btn-azul:hover {
    background-color: var(--color-primary-hover);
}

.btn-verde {
    background-color: #ae275f; /* Color rosa */
}
.btn-verde:hover {
    background-color: #7b1e41; /* Un rosa un poco más oscuro para el hover */
}

.publicar-main {
    max-width: 600px;
    margin: 20px auto;
    background-color: var(--color-surface);
    padding: 20px 30px;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}


/* Estilos para el formulario de publicación */
.formulario-publicar {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.formulario-publicar label {
    font-weight: bold;
    color: var(--color-text-secondary);
}

.formulario-publicar input[type="text"],
.formulario-publicar input[type="number"],
.formulario-publicar input[type="tel"],
.formulario-publicar textarea,
.formulario-publicar input[type="file"],
.formulario-publicar select {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--color-input-border);
    border-radius: 5px;
    box-sizing: border-box;
    background-color: var(--color-surface);
    color: var(--color-text-primary);
}

/* Estilos para el botón de regresar */
.boton-regresar {
    display: inline-block;
    padding: 10px 15px;
    margin-bottom: 20px;
    background-color: var(--color-primary);
    color: white;
    text-decoration: none;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.boton-regresar:hover {
    background-color: var(--color-primary-hover);
}

/* Estilos de la lista de cartas (tienda.html) */
#contenedor-cartas-publicadas {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

/* Estilos para el contenedor de lotes y accesorios, para que usen la misma cuadrícula */
.contenedor-cartas {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

.tienda-controles {
    margin-bottom: 20px;
    text-align: center;
}

/* Corrección para el fondo de autocompletado del navegador en modo oscuro */
body.dark-mode input:-webkit-autofill,
body.dark-mode input:-webkit-autofill:hover, 
body.dark-mode input:-webkit-autofill:focus, 
body.dark-mode input:-webkit-autofill:active,
body.dark-mode textarea:-webkit-autofill {
    /* Forzamos los colores para el modo oscuro para evitar el fondo blanco del navegador */
    -webkit-box-shadow: 0 0 0 30px #1e1e1e inset !important; /* Color de fondo oscuro (#1e1e1e es --color-surface) */
    -webkit-text-fill-color: #e0e0e0 !important; /* Color de texto claro (#e0e0e0 es --color-text-primary) */
}

#buscador,
#buscador-misiones {
    width: 50%;
    padding: 12px;
    border: 1px solid var(--color-input-border);
    border-radius: 8px;
    font-size: 1em;
    background-color: var(--color-surface);
    color: var(--color-text-primary);
}

/* Añadir margen inferior al buscador de misiones para separarlo de los filtros */
#buscador-misiones {
    margin-bottom: 15px;
}

.card {
    border: 1px solid var(--color-card-border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 5px var(--color-shadow);
    transition: transform 0.2s;
    background-color: var(--color-card-bg);
    display: flex;
    flex-direction: column;
}

.card:hover {
    transform: translateY(-5px);
}

.card img {
    width: 100%;
    border-radius: 8px;
    margin-bottom: 10px;
}

.card-content {
    padding: 15px;
    flex-grow: 1; /* Hace que este div crezca para ocupar el espacio */
    display: flex;
    flex-direction: column;
}

.card-content h3 {
    margin-top: 0;
    margin-bottom: 5px;
    font-size: 1.1em;
    color: #3b4cca; /* Azul de Pokémon */
}

.card-content p {
    margin: 4px 0;
    font-size: 0.9em;
    color: var(--color-text-muted);
}

.card-content .card-game {
    font-weight: bold;
    color: #ffde00; /* Amarillo de Pokémon */
    background-color: #3b4cca; /* Azul de Pokémon */
    padding: 2px 6px;
    border-radius: 4px;
    align-self: flex-start; /* Para que no ocupe todo el ancho */
    margin-bottom: 10px;
}

.card-content small {
    margin-top: auto; /* Empuja la fecha al final de la tarjeta */
    color: var(--color-text-muted);
}

/* Mejora de visibilidad para la barra de navegación en modo oscuro */
/* Se aplica a ambas estructuras de header para asegurar consistencia */
body.dark-mode header .nav-bar a,
body.dark-mode header .desktop-nav a {
    color: #FFFFFF; /* Blanco puro para máxima visibilidad */
    font-weight: 500; /* Un poco más grueso para que resalte */
}

/* Estilo para el botón de borrar en la tarjeta de perfil */
.card-content .btn-borrar-venta {
    background-color: #e74c3c;
    color: white;
    border: none;
    padding: 8px 12px;
    border-radius: 5px;
    cursor: pointer;
    margin-top: 10px;
    align-self: flex-end;
    font-weight: bold;
    font-size: 0.9em;
    transition: background-color 0.2s;
}

/* Estilos para los mensajes de estado */
.mensaje-estado {
    text-align: center;
    padding: 10px;
    margin-top: 20px;
    border-radius: 5px;
    font-weight: bold;
}

.mensaje-info {
    background-color: rgba(52, 152, 219, 0.1);
    color: var(--color-primary-hover);
}

.mensaje-success {
    background-color: var(--color-success-bg);
    color: var(--color-success-text);
}

.mensaje-error {
    background-color: var(--color-error-bg);
    color: var(--color-error-text);
}

.btn-recargar {
    display: block;
    width: 150px;
    margin: 10px auto;
}
.navegacion-botones {
    margin-bottom: 20px;
    display: flex;
    gap: 10px; /* Para separar los botones */
}

.boton-tienda {
    padding: 10px 15px;
    background-color: var(--color-primary);
    color: white;
    text-decoration: none;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.boton-tienda:hover {
    background-color: var(--color-primary-hover);
}

/* Estilos para el botón flotante de Quejas y Sugerencias */
.feedback-whatsapp {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1000;
}

.feedback-whatsapp a {
    display: block;
    padding: 10px 15px;
    background-color: #25D366; /* Color de WhatsApp */
    color: white;
    text-decoration: none;
    border-radius: 25px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
    font-weight: bold;
    transition: transform 0.2s;
}

.feedback-whatsapp a:hover {
    transform: scale(1.05);
}

/* === Media Queries para Responsividad (Móviles) === */
@media (max-width: 768px) {
    body {
        padding: 10px; /* Reducir padding en pantallas pequeñas */
    }

    header nav {
        gap: 10px; /* Reducir el espacio entre los enlaces de navegación */
    }

    footer {
        font-size: 0.9em; /* Reducir fuente en el footer para que quepa mejor */
        padding-left: 5%;
        padding-right: 5%;
    }

    #buscador,
    #buscador-misiones {
        width: 85%; /* Hacer el buscador más ancho en móviles */
    }

    .hero-search {
        padding: 30px 15px;
    }

    .hero-search-title {
        font-size: 1.5em;
    }

    .hero-search-form {
        flex-direction: column;
        box-shadow: none;
    }

    .hero-search-form input,
    .hero-search-form button,
    .hero-search-form .btn-vender-hero {
        border-radius: 8px;
        width: 100%;
        box-sizing: border-box;
        margin-bottom: 10px;
        border: 2px solid #3498db;
        text-align: center; /* Para centrar el texto en el enlace 'Vender' */
    }

    .ventas-tabla, .vendedores-table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
}

/* Estilos para la página de perfil */
.perfil-container {
    background-color: var(--color-surface);
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 4px 15px var(--color-shadow);
    max-width: 900px;
    margin: 20px auto;
}

#perfil-info {
    border-bottom: 2px solid var(--color-header-border);
    padding-bottom: 20px;
    margin-bottom: 20px;
}

.perfil-detalle {
    font-size: 1.1em;
    margin-bottom: 10px;
    color: var(--color-text-secondary);
}

.perfil-detalle strong {
    color: var(--color-text-primary);
    min-width: 150px;
    display: inline-block;
}

.perfil-seccion h2 {
    color: var(--color-h1-h2);
    border-bottom: 1px solid var(--color-card-border);
    padding-bottom: 10px;
    margin-bottom: 20px;
}
/* Mejora de visibilidad para el perfil en modo oscuro */
body.dark-mode .perfil-detalle {
    color: var(--color-text-secondary); /* Un gris más claro */
}
body.dark-mode .perfil-detalle strong {
    color: var(--color-text-primary); /* Texto principal (blanco) */
}
body.dark-mode .perfil-seccion h2 {
    color: var(--color-h1-h2); /* Títulos claros */
}

/* Para que toda la tarjeta de producto sea un enlace clickeable */
.card-producto a.producto-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Nuevo contenedor para mostrar múltiples imágenes en la tarjeta de producto */
.card-multi-imagen-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* Una cuadrícula de 2x2 */
    grid-template-rows: repeat(2, 1fr);
    height: 200px; /* Altura fija para el contenedor de imágenes */
    background-color: var(--color-header-link-hover-bg);
    overflow: hidden; /* Esconde cualquier parte de la imagen que se desborde */
}

.card-multi-imagen-container img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 'cover' para rellenar el espacio, puede cortar un poco la imagen */
}

/* Si solo hay una imagen, hacemos que ocupe todo el espacio */
.card-multi-imagen-container img:first-child:nth-last-child(1) {
    grid-column: 1 / span 2;
    grid-row: 1 / span 2;
}

/* Estilos para la página de detalle del producto */
.producto-detalle-container {
    display: flex;
    flex-wrap: wrap; /* Para que sea responsive en móviles */
    gap: 30px;
    max-width: 1200px;
    margin: 20px auto;
    background: var(--color-surface);
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 4px 15px var(--color-shadow);
}

.producto-imagen {
    flex: 1 1 300px; /* Flex-grow, flex-shrink, flex-basis */
    max-width: 350px;
}

.producto-imagen img {
    width: 100%;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.producto-info {
    flex: 2 1 500px; /* Que ocupe más espacio que la imagen */
}

.producto-info h1 {
    text-align: left;
    margin-top: 0;
}

.producto-info h2 {
    text-align: left;
    color: var(--color-text-muted);
    font-weight: normal;
    margin-top: -10px;
    margin-bottom: 30px;
}

.ventas-tabla {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    font-size: 0.95em;
    overflow-x: auto; /* Para que la tabla sea responsive en móvil */
    display: block;
}

.ventas-tabla th, .ventas-tabla td {
    border: 1px solid var(--color-border);
    padding: 12px 15px;
    text-align: left;
    vertical-align: middle;
}

.ventas-tabla th {
    background-color: var(--color-card-bg);
    font-weight: 600;
    color: var(--color-text-secondary);
}

.ventas-tabla tr:hover {
    background-color: var(--color-header-link-hover-bg);
}

/* Estilos para la tabla de vendedores en producto.html */
.vendedores-table {
    width: 100%;
}

/* Corrección para fondo de tablas en modo oscuro */
body.dark-mode .ventas-tabla td {
    background-color: transparent; /* Asegura que las celdas no tengan fondo blanco */
}

/* === Estilos del Footer === */
footer {
    text-align: center;
    padding: 25px 15%; /* Padding lateral para que no se pegue a los bordes */
    margin-top: 50px;
    background-color: var(--color-footer-bg);
    border-top: 1px solid var(--color-border);
    font-size: 0.95em;
    color: var(--color-footer-text);
    line-height: 1.7;
}

footer p {
    margin: 8px 0;
}

footer a {
    color: var(--color-primary);
    font-weight: bold;
    text-decoration: none;
}

footer a:hover {
    text-decoration: underline;
}

/* --- ESTILOS PARA LA PÁGINA PRE-PUBLICAR --- */
.pre-publicar-container {
    max-width: 900px;
    margin: 40px auto;
    text-align: center;
    padding: 0 20px;
}

.subtitulo-pre-publicar {
    font-size: 1.2em;
    color: var(--color-text-muted);
    margin-bottom: 40px;
}

.opciones-venta {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 30px;
    margin-bottom: 50px;
}

.opcion-venta {
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 30px 20px;
    text-decoration: none;
    color: var(--color-text-primary);
    box-shadow: 0 4px 10px var(--color-shadow);
    transition: transform 0.2s, box-shadow 0.2s;
}

.opcion-venta:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.opcion-icono {
    font-size: 3em;
    margin-bottom: 15px;
}

.opcion-venta h2 {
    margin-top: 0;
    color: var(--color-primary);
}

.opcion-venta p {
    color: var(--color-text-secondary);
    font-size: 0.95em;
}

.opcion-venta.disabled {
    background-color: var(--color-card-bg);
    cursor: not-allowed;
    opacity: 0.6;
}

.opcion-venta.disabled:hover {
    transform: none;
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}

.guia-venta-container {
    margin-top: 40px;
    padding: 20px;
}

.btn-transparente {
    background-color: transparent;
    border: 1px solid var(--color-primary);
    color: var(--color-primary);
    padding: 15px 30px;
    text-decoration: none;
    border-radius: 8px;
    display: inline-block;
    transition: background-color 0.2s, color 0.2s;
    font-weight: 500;
}

.btn-transparente:hover {
    background-color: var(--color-primary);
    color: #fff;
}

.btn-transparente strong {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
}

/* Ocultar/mostrar iconos de tema */
.sun-icon, .dark-mode .moon-icon {
    display: none;
}

.moon-icon, .dark-mode .sun-icon {
    display: block;
}

/* --- ESTILOS PARA MISIONES (TABLÓN E INDEX) --- */
.misiones-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); /* Un poco más ancho */
    gap: 25px;
    padding: 20px 0;
}

.mision {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 20px;
    box-shadow: 0 2px 8px var(--color-shadow);
    display: flex;
    flex-direction: column;
    transition: transform 0.2s, box-shadow 0.2s;
}

.mision:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 12px var(--color-shadow);
}

.mision h2 {
    font-size: 1.2em;
    color: #c0392b; /* Rojo oscuro para misiones */
    margin-top: 0;
    margin-bottom: 15px;
}

.mision p {
    margin: 5px 0;
    font-size: 0.95em;
}

.mision em {
    margin-top: auto; /* Empuja la fecha al final */
    padding-top: 10px;
    font-size: 0.85em;
    color: var(--color-text-muted);
}

body.dark-mode .mision h2 {
    color: #e57373; /* Rojo más brillante para el modo oscuro */
}

.mision-link {
    font-weight: bold;
    color: var(--color-primary);
    text-decoration: none;
}

/* --- MEDIA QUERIES ADICIONALES PARA MÓVIL --- */
@media (max-width: 768px) {
    .menu-toggle {
        display: block; /* Mostrar el botón de hamburguesa */
        order: 3; /* Moverlo al final */
        margin-left: auto; /* Empujarlo a la derecha */
    }

    header nav {
        display: none; /* Ocultar la navegación por defecto */
        flex-direction: column;
        width: 100%;
        background-color: var(--color-surface);
        position: static; /* Ya no es absoluto, se muestra debajo */
        top: 75px; /* Ajustar según la altura del header */
        left: 0;
        padding: 20px 0;
        box-shadow: 0 4px 8px var(--color-shadow);
        z-index: 100;
    }

    header nav.active {
        display: flex; /* Mostrar la navegación cuando está activa */
    }

    header nav a {
        width: 100%;
        text-align: center;
        padding: 15px 0;
        border-bottom: 1px solid var(--color-border);
    }

    .header-right .btn-vender,
    .header-right .theme-toggle,
    .auth-links-desktop {
        display: none; /* Ocultar estos elementos en la barra principal móvil */
    }    

    /* Filtros en tienda y tablón */
    .filtros-container {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }

    .filtros-container label {
        margin-left: 0 !important;
    }

    /* --- RESPONSIVIDAD PARA EL NUEVO LAYOUT DE TIENDA --- */
    .tienda-layout {
        flex-direction: column; /* Apila la sidebar y el contenido */
    }
    .tienda-sidebar {
        position: static; /* Quita el 'sticky' en móvil */
        width: 100%;
    }

    /* --- RESPONSIVIDAD PARA NUEVO HEADER --- */
    .header-main-bar { /* La barra principal se adapta a móvil */
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .header-search-form { /* El buscador ocupa todo el ancho */
        order: 3; /* Mueve el buscador a la última posición en el flujo flex */
        width: 100%;
        margin-top: 10px;
    }
    .nav-bar { display: none; } /* La barra de navegación azul se oculta en móvil */

}

body.dark-mode .mision-link {
    color: #63b3ed; /* Azul más brillante para mejor contraste en modo oscuro */
}

/* Mejora de visibilidad para TODOS los enlaces dentro de una misión en modo oscuro */
body.dark-mode .mision a {
    color: #63b3ed; /* Azul brillante para que resalte sobre el fondo oscuro */
    text-decoration: underline; /* Subrayado para que sea más obvio que es un enlace */
}

/* --- ESTILOS PARA SECCIÓN DE COMENTARIOS --- */
.comments-section {
    border-top: 1px solid var(--color-border);
    margin-top: 15px;
    padding-top: 15px;
}

.comments-section h4 {
    margin: 0 0 10px 0;
    font-size: 1em;
    color: var(--color-text-secondary);
}

.comments-list {
    max-height: 200px;
    overflow-y: auto;
    margin-bottom: 10px;
    padding-right: 5px; /* Espacio para la barra de scroll */
}

.comment {
    background-color: var(--color-background);
    padding: 8px 12px;
    border-radius: 8px;
    margin-bottom: 8px;
    font-size: 0.9em;
}

.comment-author {
    font-weight: bold;
    color: var(--color-primary);
    margin-right: 5px;
}

.comment-date {
    font-size: 0.8em;
    color: var(--color-text-muted);
    margin-left: 5px;
}

.comment-form {
    display: grid; /* Cambiado a grid para mejor control */
    gap: 8px;
}

.comment-form textarea {
    width: 100%;
    padding: 8px;
    border: 1px solid var(--color-input-border);
    border-radius: 5px;
    background-color: var(--color-surface);
    color: var(--color-text-primary);
    resize: vertical;
    min-height: 40px;
    box-sizing: border-box;
}

.comment-form-actions {
    display: flex;
    justify-content: flex-end; /* Alinea los botones a la derecha */
    gap: 8px;
}

.comment-form button {
    padding: 6px 12px;
    font-size: 0.9em;
    background-color: var(--color-primary);
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}

.comment-form button:hover {
    background-color: var(--color-primary-hover);
}

/* Estilo para el nuevo botón de compartir */
.btn-share {
    background-color: #7f8c8d; /* Un color neutro */
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    padding: 6px 12px;
    font-size: 0.9em;
    transition: background-color 0.2s;
}

.btn-share:hover {
    background-color: #95a5a6;
}

/* --- PRELOADER CON ANIMACIÓN DE GATITO --- */
#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-surface);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: opacity 0.75s ease, visibility 0.75s ease;
    opacity: 1;
    visibility: visible;
}

#preloader.hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none; /* Evita que intercepte clics cuando está oculto */
}

#preloader p {
    margin-top: 20px;
    font-size: 1.2em;
    color: var(--color-text-secondary);
    font-weight: bold;
}

/* --- Animación del Sol --- */
.sun-loader {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #f1c40f;
    box-shadow: 0 0 20px rgba(241, 196, 15, 0.7);
    animation: sun-pulse 1.5s ease-in-out infinite alternate, sun-spin 4s linear infinite;
}

body.dark-mode .sun-loader {
    background-color: #f39c12;
    box-shadow: 0 0 25px rgba(243, 156, 18, 0.8);
}

@keyframes sun-pulse {
    from { transform: scale(0.9); }
    to { transform: scale(1.1); }
}

@keyframes sun-spin {
    from { transform: rotate(0deg) scale(1); }
    to { transform: rotate(360deg) scale(1); }
}

/* --- ESTILOS PARA EL PRELOADER (PANTALLA DE CARGA) --- */
@keyframes pulse {
    0% { transform: scale(1); opacity: 0.8; }
    50% { transform: scale(1.1); opacity: 1; }
    100% { transform: scale(1); opacity: 0.8; }
}
.preloader-logo {
    animation: pulse 2s infinite ease-in-out;
    max-width: 150px;
}

/* --- ESTILOS PARA LA SECCIÓN DE SELECCIÓN DE TCG (INDEX.HTML) --- */
.tcg-selection-section {
    text-align: center;
    padding: 50px 20px;
    background-color: var(--color-surface-variant, #f9f9f9);
    transition: background-color 0.3s;
}
.tcg-selection-section h2 {
    margin-bottom: 30px;
    font-size: 2em;
    color: var(--color-h1-h2);
}
body.dark-mode .tcg-selection-section {
    background-color: var(--color-surface, #2d3748); /* Fondo oscuro para la sección en modo oscuro */
}
.tcg-options {
    display: flex;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
}
.tcg-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    transition: transform 0.2s ease-in-out;
}
.tcg-option:hover {
    transform: scale(1.05);
}
.tcg-option img {
    width: 200px; /* Controla el ancho del logo */
    height: 120px; /* Controla la altura del logo */
    object-fit: contain; /* Asegura que el logo no se deforme */
    filter: drop-shadow(0 4px 6px rgba(0,0,0,0.1));
}

/* --- ESTILO PARA IMAGEN DE GENGAR EN MODO NOCHE (INDEX) --- */
.gengar-noche-img {
    display: none; /* Oculta por defecto */
    position: fixed; /* Se queda fija en la esquina de la ventana */
    left: 20px; /* A la izquierda */
    bottom: 90px; /* Un poco más arriba para no chocar con el botón de feedback */
    width: 120px; /* Más pequeño */
    height: auto;
    z-index: 998; /* Por debajo de los pop-ups pero por encima del contenido */
    opacity: 0.6; /* Un poco más sutil */
    pointer-events: none; /* Para que no se pueda hacer clic en la imagen */
    transition: opacity 0.5s ease-in-out; /* Animación suave */
    opacity: 0; /* Empieza invisible para la animación */
}

/* Mostrar la imagen solo si el body tiene la clase 'show-gengar' (controlado por JS) */
body.show-gengar .gengar-noche-img {
    display: block;
    opacity: 0.6; /* Se hace visible con la animación de transición */
}
}