/* =========================================
   1. IMPORTACIONES
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0');

/* =========================================
   2. VARIABLES GLOBALES
   ========================================= */
:root {
    --bg-base: #0D0D0D;          
    --bg-surface: #1A1A1A;       
    --text-primary: #FFFFFF;     
    --text-secondary: #A1A1AA;   

    --brand-red: #E63946;        
    --neon-red: #FF1744;         

    --glow-red: 0 0 15px rgba(255, 23, 68, 0.4);
    
    --font-main: 'Roboto', sans-serif;
    --transition: all 0.3s ease;
}

/* =========================================
   3. RESETEO Y TIPOGRAFÍA
   ========================================= */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background-color: var(--bg-base);
    color: var(--text-primary);
    font-family: var(--font-main);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    background-image: 
        radial-gradient(circle at center, rgba(230, 57, 70, 0.065) 0%, transparent 75%),
        radial-gradient(1.5px 1.5px at 20px 30px, rgba(255, 255, 255, 0.95), transparent),
        radial-gradient(1px 1px at 80px 70px, rgba(255, 255, 255, 0.6), transparent),
        radial-gradient(1.5px 1.5px at 150px 40px, rgba(230, 57, 70, 0.4), transparent),
        radial-gradient(2px 2px at 250px 120px, rgba(255, 255, 255, 0.4), transparent),
        radial-gradient(1px 1px at 320px 180px, rgba(255, 255, 255, 0.7), transparent),
        radial-gradient(1.5px 1.5px at 60px 220px, rgba(255, 255, 255, 0.5), transparent);
    background-size: 100% 100vh, 320px 320px, 320px 320px, 320px 320px, 320px 320px, 320px 320px, 320px 320px;
    background-attachment: fixed; 
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main { flex-grow: 1; }
a { text-decoration: none; color: inherit; }
.text-red { color: var(--neon-red); }

/* =========================================
   4. SCROLLBAR (BARRA DE NAVEGACIÓN)
   ========================================= */
/* Scoped a html/body: solo afecta al scroll principal de la página, no a widgets de terceros */
html { scrollbar-width: thin; scrollbar-color: rgba(255, 255, 255, 0.1) var(--bg-base); scrollbar-gutter: stable; }
html::-webkit-scrollbar { width: 8px; }
html::-webkit-scrollbar-track { background-color: var(--bg-base); }
html::-webkit-scrollbar-thumb { background-color: rgba(255, 255, 255, 0.08); border-radius: 10px; }
html::-webkit-scrollbar-thumb:hover { background-color: rgba(255, 255, 255, 0.2); }
html::-webkit-scrollbar-thumb:active { background-color: var(--brand-red); }

/* =========================================
   5. UTILIDADES Y BOTONES
   ========================================= */
.btn-neon-red {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background-color: var(--brand-red);
    color: var(--text-primary);
    padding: 12px 28px;
    border-radius: 14px;
    font-size: 1rem;
    font-weight: 700;
    transition: var(--transition);
    cursor: pointer;
    border: 1px solid transparent; 
}

.btn-neon-red:hover {
    background-color: #ffffff;
    color: var(--brand-red);
    box-shadow: var(--glow-red);
    transform: translateY(-2px);
}

/* =========================================
   6. NAVBAR (HEADER)
   ========================================= */
.navbar {
    position: fixed;
    top: 0; left: 0; width: 100%;
    background-color: rgba(39, 39, 39, 0.20);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5);
    z-index: 1000;
}

.nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 12px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.nav-left { display: flex; align-items: center; gap: 20px; }
.logo img { height: 45px; width: auto; display: block; }

.hamburger-btn {
    display: none;
    background: none; border: none;
    color: var(--text-primary); cursor: pointer;
    padding: 5px;
}

.nav-links { display: flex; gap: 10px; }
.nav-link {
    font-size: 0.8rem; font-weight: 500;
    color: var(--text-secondary);
    padding: 8px 14px; border-radius: 50px;
    transition: var(--transition);
}

.nav-link:hover, .nav-link.active {
    color: var(--text-primary);
    background-color: rgba(255, 255, 255, 0.08);
}

.nav-actions { display: flex; align-items: center; gap: 15px; }

/* Iconos limpios (Lupa y Perfil) */
.icon-btn {
    display: flex; align-items: center; justify-content: center;
    background: transparent; color: var(--text-primary);
    border: none; padding: 5px; cursor: pointer;
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), color 0.3s ease;
}

.icon-btn:hover {
    color: var(--neon-red);
    transform: translateY(-3px) scale(1.1);
}

.lang-currency-btn {
    display: inline-flex; /* Agregado */
    align-items: center;  /* Agregado */
    gap: 6px;             /* Agregado */
    background-color: rgba(255, 255, 255, 0.05);
    color: var(--text-primary);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px; 
    padding: 6px 14px;
    font-size: 0.85rem; 
    font-weight: 700;
    cursor: pointer; 
    transition: var(--transition);
}

.lang-currency-btn:hover {
    border-color: var(--neon-red);
    color: var(--neon-red);
}

/* =========================================
   7. MODAL DE MONEDA
   ========================================= */
.modal-overlay {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(8px);
    z-index: 2000;
    display: flex; justify-content: center; align-items: center;
    opacity: 0; visibility: hidden; transition: all 0.3s ease;
}

.modal-overlay.active { opacity: 1; visibility: visible; }

.modal-box {
    background-color: var(--bg-surface);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    width: 90%; max-width: 320px; padding: 20px;
    transform: translateY(30px); transition: all 0.3s ease;
}

.modal-overlay.active .modal-box { transform: translateY(0); }

.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }

.close-btn {
    background: rgba(255, 255, 255, 0.05); border: none;
    color: var(--text-secondary); width: 28px; height: 28px;
    border-radius: 6px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
}

.btn-confirmar {
    width: 100%; background-color: var(--brand-red);
    color: #fff; border: none; padding: 10px;
    border-radius: 8px; font-weight: 700; cursor: pointer;
}

/* =========================================
   8. MODAL DE LOGIN / REGISTRO
   ========================================= */
.auth-box { position: relative; max-width: 400px; padding: 40px 30px 30px 30px; }

.auth-close {
    position: absolute; top: 15px; right: 15px;
    background: transparent !important;
}

.auth-tabs { display: flex; border-bottom: 1px solid rgba(255, 255, 255, 0.1); margin-bottom: 25px; }

.auth-tab {
    flex: 1; background: none; border: none;
    color: var(--text-secondary); font-size: 1rem;
    font-weight: 600; padding: 10px 0; cursor: pointer;
    position: relative; font-family: var(--font-main);
}

.auth-tab.active { color: var(--neon-red); }

.auth-tab::after {
    content: ''; position: absolute; bottom: -1px; left: 0; width: 100%; height: 2px;
    background-color: var(--neon-red); transform: scaleX(0); transition: transform 0.3s ease;
}

.auth-tab.active::after { transform: scaleX(1); }

.auth-form { display: none; animation: fadeIn 0.4s ease; }
.auth-form.active { display: block; }

.auth-form label { display: block; font-size: 0.95rem; color: var(--text-secondary); margin-bottom: 8px; }

.input-with-icon { position: relative; display: flex; align-items: center; margin-bottom: 15px; }
.input-with-icon .material-symbols-outlined { position: absolute; left: 15px; color: var(--text-secondary); }

.input-with-icon input {
    width: 100%; padding: 12px 15px 12px 45px;
    background-color: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px; color: var(--text-primary);
}

.auth-btn-center { display: flex; justify-content: center; margin-top: 25px; }
.auth-btn-center .btn-neon-red { min-width: 160px; }

.btn-google-oauth:hover {
    background: #f1f3f4 !important;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.35) !important;
    transform: translateY(-2px);
}

@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* =========================================
   9. BUSCADOR FLOTANTE
   ========================================= */
.search-overlay { position: absolute; top: calc(100% + 15px); right: -10px; width: 350px; display: none; z-index: 1000; }
.search-overlay.active { display: block; animation: slideInSearch 0.3s ease-out; }

.search-container {
    width: 100%; background-color: var(--bg-surface);
    padding: 18px 15px; border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.7);
}

/* NUEVO: Contenedor relativo para posicionar la lupa */
.search-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
}

/* NUEVO: Posicionamiento absoluto de la lupa */
.search-inner-icon {
    position: absolute;
    left: 15px; /* Separación desde la izquierda */
    color: var(--text-secondary);
    font-size: 1.4rem;
    pointer-events: none; /* Evita que la lupa bloquee los clics en el campo de texto */
}

#mainSearchInput {
    width: 100%; background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 50px; padding: 10px 15px 10px 45px; /* Aquí ya tienes los 45px listos para la lupa */
    color: #fff; outline: none;
}

.suggestion-item {
    display: flex; align-items: center; gap: 15px;
    padding: 10px 15px; color: var(--text-primary);
    transition: var(--transition); border-radius: 10px;
}

.suggestion-item:hover { background-color: rgba(255, 255, 255, 0.1); }

/* =========================================
   AJUSTES PARA LOS RESULTADOS DE BÚSQUEDA
   ========================================= */
.search-suggestions {
    margin-top: 15px;
    max-height: 300px; /* Límite de altura para no salir de la pantalla */
    overflow-y: auto;  /* Scroll automático si hay muchos resultados */
    display: flex;
    flex-direction: column;
    gap: 5px;
}

/* Scrollbar estética para las sugerencias */
.search-suggestions::-webkit-scrollbar {
    width: 6px;
}
.search-suggestions::-webkit-scrollbar-thumb {
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
}

/* Ajuste para que las imágenes no exploten el diseño */
.suggestion-item img {
    width: 45px;          /* Tamaño de miniatura */
    height: 45px;
    object-fit: cover;    /* Recorta la imagen sin deformarla */
    border-radius: 8px;   /* Bordes redondeados suaves */
    flex-shrink: 0;       /* Evita que el contenedor aplaste la imagen */
}

/* Evitar que los textos muy largos rompan la caja */
.suggestion-item span {
    font-size: 0.9rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis; /* Puntos suspensivos al final */
    width: 100%;
}

/* Contenedor para apilar el texto y la etiqueta en el buscador */
.suggestion-text-box {
    display: flex;
    flex-direction: column;
    gap: 4px; /* Separación entre el título y la etiqueta */
    overflow: hidden;
    width: 100%;
}

/* Evitar que el título se rompa */
.suggestion-title {
    font-size: 0.9rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-primary);
}

/* Ajustar la etiqueta específicamente para el buscador */
.suggestion-text-box .category-tag {
    font-size: 0.65rem;
    padding: 2px 6px;
    width: fit-content; /* Para que la etiqueta no ocupe todo el ancho */
    margin-top: 0;
}

@keyframes slideInSearch { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }

/* =========================================
   10. MENÚ DESPLEGABLE (PERFIL)
   ========================================= */
.user-menu-container { position: relative; display: flex; align-items: center; }

/* Sincronización de Hover Nombre + Icono */
.user-menu-container:hover .icon-btn {
    color: var(--neon-red);
    transform: translateY(-3px) scale(1.1);
}

.user-dropdown {
    position: absolute; top: 130%; right: 0;
    background-color: var(--bg-surface); min-width: 220px;
    border-radius: 12px; border: 1px solid rgba(255, 255, 255, 0.05);
    opacity: 0; visibility: hidden; transform: translateY(15px);
    transition: all 0.3s ease; z-index: 1000;
}

.user-menu-container:hover .user-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }

.dropdown-header { display: flex; flex-direction: column; align-items: center; padding: 20px 15px; border-bottom: 1px solid rgba(255, 255, 255, 0.05); }
.dropdown-header .username { color: var(--text-primary); font-weight: 700; margin-top: 8px; }

.dropdown-menu { list-style: none; padding: 10px 0; }
.dropdown-menu li a { display: flex; align-items: center; gap: 12px; padding: 12px 20px; color: var(--text-secondary); transition: var(--transition); }
.dropdown-menu li a:hover { background-color: rgba(255, 255, 255, 0.03); color: var(--text-primary); }

.logout-item { border-top: 1px solid rgba(255, 255, 255, 0.05); margin-top: 5px; }
.logout-item a { color: var(--neon-red) !important; }

/* =========================================
   11. FOOTER (PIE DE PÁGINA)
   ========================================= */
.footer {
    background-color: rgba(39, 39, 39, 0.20); 
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    padding: 20px;
    /* Fuerza composición GPU para evitar que el blur cause
       renders en blanco en mobile hasta el primer tap */
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

.footer-container { max-width: 1200px; margin: 0 auto; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; }
.footer-bottom p { color: var(--text-secondary); font-size: 0.85rem; }
.footer-eslogan { height: 36px; width: auto; display: block; opacity: 0.85; transition: opacity 0.3s ease; }
.footer-eslogan:hover { opacity: 1; }

/* =========================================
   ESTILOS DE REDES SOCIALES EN FOOTER
   ========================================= */
.footer-socials {
    display: flex;
    gap: 15px;
    align-items: center;
}

.footer-social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary); /* Gris por defecto, igual que el texto del footer */
    background-color: transparent;
    padding: 8px;
    border-radius: 12px;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Transición suave y rebotona */
}

.footer-social-btn svg {
    width: 22px;
    height: 22px;
    fill: currentColor; /* Esto permite que el color lo dicte el CSS */
}

/* Efecto Hover: Se ilumina en rojo y sube un poco */
.footer-social-btn:hover,
.footer-social-btn:active {
    color: var(--neon-red);
    background-color: rgba(255, 23, 68, 0.08); /* Un fondo rojizo muy sutil */
    transform: translateY(-3px) scale(1.1);
}

/* =========================================
   12. TARJETAS DE JUEGOS (GLOBAL)
   ========================================= */
.catalog-section { padding: 20px 20px 80px 20px; }
.catalog-container { max-width: 1200px; margin: 0 auto; }
.section-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 25px; }
.section-title { font-size: 1.4rem; font-weight: 700; color: var(--text-primary); }
.section-subtitle { font-size: 0.88rem; color: rgba(255, 255, 255, 0.35); margin-top: 4px; }

.games-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 12px; }
.game-card { background-color: var(--bg-surface); border: 1px solid rgba(255, 255, 255, 0.04); border-radius: 16px; display: flex; flex-direction: column; padding: 8px; transition: var(--transition); }
.game-card:hover { transform: translateY(-4px); border-color: var(--neon-red); background-color: #222226; }

.game-img-box { position: relative; width: 100%; padding-top: 100%; border-radius: 14px; overflow: hidden; }
.game-img-box img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.game-card:hover .game-img-box img { transform: scale(1.06); }

.game-badge { position: absolute; top: 0; right: 0; background: linear-gradient(135deg, #ff416c, var(--neon-red)); color: #fff; font-size: 0.75rem; font-weight: 900; padding: 4px 8px; border-bottom-left-radius: 12px; border-top-right-radius: 14px; }

.game-title { font-size: 0.95rem; font-weight: 600; color: var(--text-primary); margin-top: 12px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.4em; }
.category-tag { 
    display: inline-block; /* Mantiene la caja unida si baja de línea */
    font-size: 0.75rem; 
    color: var(--text-secondary); 
    background-color: rgba(255, 255, 255, 0.05); 
    padding: 4px 8px; 
    border-radius: 6px; 
    line-height: 1.3; /* Da un buen espacio si el texto ocupa dos líneas */
    white-space: normal; /* Permite que baje a la segunda línea si lo necesita */
    word-wrap: break-word; 
    margin-top: 4px; /* Una pequeña separación del título */
}

/* =========================================
   ESTILOS PERSONALIZADOS PARA CHOICES.JS
   ========================================= */
/* La caja principal del selector */
.choices[data-type*="select-one"] .choices__inner {
    background-color: rgba(0, 0, 0, 0.3) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    color: var(--text-primary) !important;
    min-height: auto !important;
    padding: 10px 15px !important;
}

/* El menú desplegable con las opciones */
.choices__list--dropdown, .choices__list[aria-expanded] {
    background-color: var(--bg-surface) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.8) !important;
    margin-top: 5px !important;
    z-index: 3000 !important; /* Asegura que pase por encima del modal */
}

/* Texto y fondo de cada opción por defecto */
.choices__list--dropdown .choices__item, 
.choices__list[aria-expanded] .choices__item {
    background-color: transparent !important; /* Quitamos el fondo blanco */
    color: var(--text-primary) !important;
    font-size: 0.95rem !important;
}

/* Opción que está actualmente seleccionada en la lista */
.choices__list--dropdown .choices__item.is-selected,
.choices__list[aria-expanded] .choices__item.is-selected {
    background-color: rgba(0, 0, 0, 0.3) !important; /* Un fondo un poco más oscuro */
    color: var(--text-secondary) !important; /* Letra un poco más gris para diferenciarla */
}

/* Efecto al pasar el mouse por encima de una opción (hover) */
.choices__list--dropdown .choices__item--selectable.is-highlighted, 
.choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
    background-color: rgba(255, 255, 255, 0.08) !important; /* Resaltado sutil */
    color: var(--neon-red) !important; /* El texto se pone rojo */
}

/* Flecha del selector (apuntando abajo) */
.choices[data-type*="select-one"]::after {
    border-color: var(--text-secondary) transparent transparent transparent !important;
}

/* Flecha del selector al abrirse (apuntando arriba) */
.choices.is-open[data-type*="select-one"]::after {
    border-color: transparent transparent var(--text-secondary) transparent !important;
    margin-top: -7.5px !important;
}

/* =========================================
   13. ADAPTACIÓN MÓVIL GLOBAL
   ========================================= */
@media (max-width: 1100px) { .games-grid { grid-template-columns: repeat(5, 1fr); } }

@media (max-width: 768px) {
    .nav-container { padding: 10px 15px; }
    .logo img { height: 24px; }
    .hamburger-btn { display: flex; }

    .nav-links {
        position: absolute; top: calc(100% + 15px); left: 20px; width: calc(100% - 40px);
        background-color: rgba(30, 30, 36, 0.98); backdrop-filter: blur(25px);
        flex-direction: column; padding: 15px; border-radius: 24px;
        opacity: 0; visibility: hidden; transform: translateY(-15px); transition: var(--transition);
    }
    .nav-links.active { opacity: 1; visibility: visible; transform: translateY(0); }
    .nav-links a { width: 100%; text-align: center; padding: 12px; }

    .games-grid { grid-template-columns: repeat(4, 1fr); }
    .footer-bottom { flex-direction: column; text-align: center; gap: 10px; }
}

@media (max-width: 480px) { 
    .games-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 8px; }
    .game-title { font-size: 0.7rem; min-height: 2.3em; }
    
    /* NUEVO: Diseño de la etiqueta exclusivo para móviles */
    .category-tag {
        display: block; /* Se convierte en un bloque completo */
        width: 100%; /* Toma todo el ancho de la tarjeta */
        text-align: center; /* Centramos el texto */
        font-size: 0.65rem; /* Letra un poco más pequeña */
        padding: 4px 2px;
        box-sizing: border-box;
        border-radius: 4px; /* Bordes un poco más rectos para ahorrar espacio */
    }
}

/* =========================================
   BARRA INFERIOR MÓVIL (BOTTOM NAV APP STYLE)
   ========================================= */
/* 1. Por defecto en PC, los elementos móviles no existen */
@media (min-width: 769px) {
    .mobile-bottom-nav,
    .mobile-menu-overlay,
    .mobile-profile-drawer {
        display: none !important;
    }
}

/* 2. Activamos la magia solo en dispositivos móviles */
@media (max-width: 768px) {
    /* Ocultamos el perfil de la parte superior que marcamos en el paso 2 */
    .hide-on-mobile { 
        display: none !important; 
    }

    /* Mostramos y fijamos la nueva barra abajo con los colores del header */
    .mobile-bottom-nav {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        background-color: rgba(39, 39, 39, 0.20); /* Mismo color que el header/footer */
        backdrop-filter: blur(16px);              /* Mismo blur que el header/footer */
        -webkit-backdrop-filter: blur(16px);
        border-top: 1px solid rgba(255, 255, 255, 0.05);
        justify-content: center; /* Centramos el único botón */
        padding: 12px 0; /* Reducimos el alto */
        z-index: 9999;
        box-shadow: 0 -4px 30px rgba(0, 0, 0, 0.5); /* Misma sombra que el header */
        padding-bottom: max(12px, env(safe-area-inset-bottom)); 
    }

    /* Estilo del botón horizontal (Icono + Nombre) */
    .mobile-bottom-nav .nav-item {
        display: flex;
        flex-direction: row; /* Coloca el icono y el texto uno al lado del otro */
        align-items: center;
        justify-content: center;
        color: var(--text-primary); 
        text-decoration: none;
        font-size: 1rem;
        font-weight: 600;
        gap: 8px; /* Espacio entre el icono y el nombre */
        transition: var(--transition);
    }

    .mobile-bottom-nav .nav-item .material-symbols-outlined {
        font-size: 1.6rem;
        color: var(--text-primary);
    }

    /* Flecha indicadora del menú */
    .mobile-bottom-nav .mobile-nav-arrow {
        font-size: 1.3rem;
        color: var(--text-secondary);
        margin-left: 2px;
        transition: transform 0.3s ease, color 0.2s ease;
    }

    .mobile-bottom-nav .mobile-nav-arrow.rotated {
        transform: rotate(180deg);
        color: var(--neon-red);
    }

    /* Efectos al tocar/hover */
    .mobile-bottom-nav .nav-item:hover,
    .mobile-bottom-nav .nav-item:active {
        color: var(--neon-red);
        transform: translateY(-2px);
    }

    .mobile-bottom-nav .nav-item.exit:hover {
        color: var(--brand-red);
    }

    /* IMPORTANTE: Anclamos el footer al fondo en móviles */
    body {
        padding-bottom: 0; 
    }
    
    .footer {
        /* Alargamos el fondo del footer para que la barra móvil quede por encima de él */
        padding-bottom: 90px; 
    }

    /* Fondo oscuro tras el menú */
    .mobile-menu-overlay {
        position: fixed;
        top: 0; left: 0; width: 100%; height: 100%;
        background-color: rgba(0, 0, 0, 0.7);
        backdrop-filter: blur(4px);
        z-index: 9997; /* Por debajo del menú y la barra */
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
    }
    .mobile-menu-overlay.active { opacity: 1; visibility: visible; }

    /* El cajón del menú (Drawer Flotante) */
    .mobile-profile-drawer {
        position: fixed;
        bottom: 75px; /* Fijamos la altura ideal desde el principio */
        left: 15px;  
        right: 15px; 
        width: auto; 
        background-color: rgba(26, 26, 26, 0.98); 
        backdrop-filter: blur(20px);
        border-radius: 24px; 
        z-index: 9998;
        padding: 24px; 
        border: 1px solid rgba(255, 255, 255, 0.08); 
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.8);
        
        /* AQUÍ ESTÁ LA MAGIA: Lo ocultamos empujándolo hacia abajo y haciéndolo invisible */
        transform: translateY(150%);
        opacity: 0;
        visibility: hidden;
        transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    }
    
    .mobile-profile-drawer.active {
        /* Al activarse, regresa a su posición original suavemente */
        transform: translateY(0); 
        opacity: 1;
        visibility: visible;
    }

    /* Cabecera del menú interno */
    .drawer-header {
        display: flex;
        align-items: center;
        gap: 15px;
        margin-bottom: 25px;
        padding-bottom: 15px;
        border-bottom: 1px solid rgba(255,255,255,0.05);
    }
    .drawer-header .material-symbols-outlined { font-size: 40px; color: var(--neon-red); }
    .drawer-username { display: block; font-size: 1.1rem; font-weight: 700; color: #fff; }
    .drawer-status { font-size: 0.8rem; color: var(--text-secondary); }

    /* Lista de enlaces */
    .drawer-links { list-style: none; padding: 0; }
    .drawer-links li a {
        display: flex;
        align-items: center;
        gap: 15px;
        padding: 15px 0;
        color: var(--text-secondary);
        text-decoration: none;
        font-size: 1rem;
        transition: 0.3s;
    }
    .drawer-links li a:active { color: #fff; }
    .drawer-links li a .material-symbols-outlined { color: var(--text-secondary); font-size: 1.4rem; }

    /* Item de Salir en Rojo */
    .logout-item { border-top: 1px solid rgba(255,255,255,0.05); margin-top: 10px; }
    .logout-item a, .logout-item a .material-symbols-outlined { color: var(--neon-red) !important; }

    /* NUEVO: Buscador centrado y adaptable en pantallas de teléfonos */
    .search-overlay {
        position: fixed;
        top: 60px; /* Lo bajamos para que quede justo debajo del header */
        left: 15px; /* Margen izquierdo seguro */
        right: 15px; /* Margen derecho seguro */
        width: auto; /* Le quitamos los 350px fijos para que fluya */
    }
}

/* =========================================
   9. BARRAS DE MENSAJES DE ESTADO
   ========================================= */
.pedido-mensaje-bar {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 15px 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.05); /* Borde gris sutil universal */
    font-size: 0.85rem;
    line-height: 1.5;
    background: rgba(0, 0, 0, 0.2); /* Fondo oscuro/gris neutro universal */
}

/* Solo le damos color al ícono, el fondo se queda quieto y elegante */
.msg-success .material-symbols-outlined { color: #2ecc71; font-size: 1.3rem; }
.msg-error .material-symbols-outlined { color: #e74c3c; font-size: 1.3rem; }
.msg-warning .material-symbols-outlined { color: #f39c12; font-size: 1.3rem; }

.pedido-mensaje-text { color: var(--text-secondary); flex: 1; }
.pedido-mensaje-text strong { color: var(--text-primary); font-weight: 600; display: block; margin-bottom: 2px; }
/* El chevron colapsable solo aparece en mobile (perfil.css lo activa) */
.msg-chevron { display: none; color: #fff !important; }
/* Separación entre título y descripción dentro del bar */
.msg-titulo { display: block; margin-bottom: 2px; }
.msg-descripcion { color: var(--text-secondary); }