/* ==========================================
   MOBILE RESPONSIVE STYLES - BRACHLINE
   Estilos exclusivos para dispositivos móviles
   ========================================== */

/* ==========================================
   MEDIA QUERIES PARA MÓVILES Y TABLETS
   ========================================== */

@media (max-width: 1200px) {
    /* ==========================================
       NAVBAR MÓVIL - Reducir altura
       ========================================== */
    .navbar {
        padding: 0 !important;
        height: auto !important;
        min-height: 50px !important;
        backdrop-filter: blur(10px) !important;
    }

    .navbar .container {
        padding: 0.5rem 1rem !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        min-height: 50px !important;
    }

    .logo img {
        height: 32px !important;
        width: auto !important;
    }

    /* ==========================================
       HAMBURGER MENU - Cambiar a negro al hacer scroll
       ========================================== */
    .navbar.scrolled .menu-toggle span,
    .menu-toggle.scrolled span {
        background: #000000 !important;
    }

    .menu-toggle span {
        background: white;
        transition: background 0.3s ease;
    }

    /* ==========================================
       HERO SECTION - Mejorar espaciado
       ========================================== */
    section:first-of-type,
    .hero-section,
    .hero {
        padding-top: 180px !important;
        padding-bottom: 4rem !important;
        margin-top: 0 !important;
        min-height: auto !important;
    }

    /* Agregar margen superior al primer elemento del hero */
    .hero-section .container > *:first-child,
    .hero .container > *:first-child {
        margin-top: 8rem !important;
    }

    .hero-section .container,
    .hero .container {
        padding: 0 1.5rem !important;
    }

    .hero-section h1,
    .hero h1 {
        font-size: 2.25rem !important;
        line-height: 1.15 !important;
        margin-bottom: 1.25rem !important;
        margin-top: 0 !important;
        font-weight: 800 !important;
        letter-spacing: -0.02em !important;
    }

    .hero-section p,
    .hero p {
        font-size: 1.05rem !important;
        line-height: 1.65 !important;
        margin-bottom: 2rem !important;
        opacity: 0.9 !important;
    }

    /* Botones del hero */
    .hero-section .btn,
    .hero .btn {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0.5rem 0 !important;
        justify-content: center !important;
        padding: 1rem 2rem !important;
        font-size: 1rem !important;
        font-weight: 600 !important;
    }

    /* Contenedor de botones en hero */
    .hero-section > div > div,
    .hero > div > div {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.75rem !important;
    }

    /* Ajustar contenedor de botones si existe */
    .flex.gap-4,
    .flex.gap-6 {
        flex-direction: column !important;
        gap: 0.75rem !important;
        width: 100% !important;
    }

    /* ==========================================
       FONDO MÓVIL - Degradado mejorado (animación lenta)
       ========================================== */
    .fluid-bg {
        background: linear-gradient(135deg, 
            #667eea 0%, 
            #764ba2 25%, 
            #f093fb 50%, 
            #4facfe 75%, 
            #00f2fe 100%) !important;
        background-size: 400% 400% !important;
        /* En responsive el fondo no debe moverse */
        animation: none !important;
    }

    /* Hero waves - fondo estático en responsive */
    .hero-wave {
        animation: none !important;
    }

    @keyframes gradientShift {
        0% { background-position: 0% 50%; }
        25% { background-position: 50% 75%; }
        50% { background-position: 100% 50%; }
        75% { background-position: 50% 25%; }
        100% { background-position: 0% 50%; }
    }

    .fluid-bg::before,
    .fluid-bg::after {
        display: none !important;
    }

    /* ==========================================
       ESTADÍSTICAS - Mejor distribución (2 columnas)
       ========================================== */
    #hero-stats {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 1rem !important;
        padding: 2rem 0 !important;
        margin: 2rem 0 !important;
    }

    #hero-stats > div {
        padding: 1.75rem 1rem !important;
        background: rgba(255, 255, 255, 0.1) !important;
        backdrop-filter: blur(10px) !important;
        border-radius: 20px !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1) !important;
        text-align: center !important;
    }

    .stat-number {
        font-size: 2.5rem !important;
        font-weight: 800 !important;
        margin-bottom: 0.5rem !important;
        background: linear-gradient(135deg, #fff 0%, rgba(255,255,255,0.8) 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
    }

    #hero-stats > div > div:last-child {
        font-size: 0.85rem !important;
        opacity: 0.9 !important;
        font-weight: 500 !important;
        line-height: 1.3 !important;
    }

    /* ==========================================
       SECCIONES - Eliminar separaciones
       ========================================== */
    section {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    section .container {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    /* Títulos de secciones */
    section h2,
    .section-header h2 {
        font-size: 2rem !important;
        line-height: 1.2 !important;
        margin-bottom: 1rem !important;
        font-weight: 800 !important;
        text-align: center !important;
    }

    section h3 {
        font-size: 1.5rem !important;
        line-height: 1.3 !important;
        margin-bottom: 0.875rem !important;
        font-weight: 700 !important;
    }

    .section-header {
        margin-bottom: 2.5rem !important;
        text-align: center !important;
    }

    .section-header p {
        font-size: 1rem !important;
        line-height: 1.6 !important;
        color: var(--text-secondary) !important;
        margin-top: 0.75rem !important;
    }

    /* ==========================================
       LOGOS CAROUSEL - Mejorar scroll
       ========================================== */
    #logos-carousel {
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        scroll-behavior: smooth !important;
        padding: 1rem 0 !important;
        margin: 0 !important;
    }

    /* Eliminar degradados laterales en móvil */
    #logos-carousel::before,
    #logos-carousel::after {
        display: none !important;
    }

    /* Asegurar que el scroll llegue al final */
    #logos-carousel > div {
        display: flex !important;
        gap: 2rem !important;
        padding: 0 1.5rem !important;
        min-width: max-content !important;
        animation: scroll-logos 120s linear infinite !important;
    }

    /* Pausar animación al hacer hover */
    #logos-carousel:hover > div {
        animation-play-state: paused !important;
    }

    @keyframes scroll-logos {
        0% {
            transform: translateX(0);
        }
        100% {
            transform: translateX(-50%);
        }
    }

    #logos-carousel img {
        max-height: 60px !important;
        width: auto !important;
        min-width: 120px !important;
    }

    /* Quitar padding extra de la sección de logos */
    section:has(#logos-carousel) {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    /* ==========================================
       MENÚ HAMBURGUESA - Diseño mejorado
       ========================================== */
    .mobile-menu {
        background: #ffffff !important;
        backdrop-filter: none !important;
        display: flex !important;
        flex-direction: column !important;
    }

    /* Ocultar el botón hamburguesa cuando el menú está abierto, dejando solo el botón de cierre negro */
    .menu-toggle.active {
        opacity: 0 !important;
        pointer-events: none !important;
    }

    /* Header del menú móvil */
    .mobile-menu-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 0.75rem 1.25rem !important;
        border-bottom: 1px solid #f0f0f0 !important;
    }

    .mobile-menu-logo-top {
        height: 40px !important;
        width: auto !important;
        filter: brightness(0) !important;
    }

    .mobile-menu-close {
        background: none !important;
        border: none !important;
        font-size: 1.5rem !important;
        color: #000000 !important;
        cursor: pointer !important;
        padding: 0.5rem !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: all 0.3s ease !important;
    }

    .mobile-menu-close:hover {
        color: #666666 !important;
    }

    .mobile-menu-close i {
        font-size: 1.5rem !important;
    }

    /* Contenido del menú */
    .mobile-menu-content {
        flex: 1 !important;
        padding: 0 !important;
        overflow-y: auto !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 0 !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        min-height: auto !important;
        text-align: left !important;
    }

    /* Ocultar cualquier logo/imágenes sueltas dentro del contenido del menú móvil */
    .mobile-menu-content img {
        display: none !important;
    }

    /* Footer del menú móvil */
    .mobile-menu-footer {
        padding: 1.5rem !important;
        border-top: 1px solid #f0f0f0 !important;
        background: #fafafa !important;
    }

    .mobile-user-info-footer {
        display: flex !important;
        align-items: center !important;
        gap: 0.875rem !important;
        margin-bottom: 1rem !important;
        padding: 0.75rem !important;
        background: #ffffff !important;
        border-radius: 12px !important;
    }

    .mobile-user-avatar-small {
        width: 40px !important;
        height: 40px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: white !important;
        flex-shrink: 0 !important;
    }

    .mobile-user-avatar-small i {
        font-size: 1.25rem !important;
    }

    .mobile-user-details {
        flex: 1 !important;
        min-width: 0 !important;
    }

    .mobile-user-name-small {
        font-size: 0.95rem !important;
        font-weight: 600 !important;
        color: #000000 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .mobile-user-email-small {
        font-size: 0.8rem !important;
        color: #666666 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .mobile-logout-btn {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.5rem !important;
    }

    /* Items del menú móvil */
    .mobile-nav-item {
        display: flex !important;
        align-items: center !important;
        gap: 0.875rem !important;
        padding: 0.6rem 1.5rem !important;
        font-size: 1rem !important;
        font-weight: 400 !important;
        color: #000000 !important;
        width: 100% !important;
        text-align: left !important;
        border-radius: 0 !important;
        margin: 0 !important;
        background: transparent !important;
        transition: all 0.3s ease !important;
        text-decoration: none !important;
        border-bottom: 1px solid #f5f5f5 !important;
    }

    /* Aún menos espacio encima del primer ítem (Inicio) */
    .mobile-menu-content .mobile-nav-item:first-child {
        padding-top: 0.4rem !important;
    }

    .mobile-nav-item i {
        font-size: 1.1rem !important;
        color: #000000 !important;
        flex-shrink: 0 !important;
    }

    .mobile-nav-item span {
        flex: 1 !important;
    }

    .mobile-nav-item:hover,
    .mobile-nav-item:active {
        background: rgba(0, 0, 0, 0.02) !important;
    }

    /* Dropdown en móvil - Mejorado */
    .mobile-dropdown {
        cursor: default !important;
        flex-direction: column !important;
        padding: 0 !important;
        background: transparent !important;
        margin: 0 !important;
        border-bottom: 1px solid #f5f5f5 !important;
    }

    .mobile-dropdown-header {
        display: flex !important;
        align-items: center !important;
        gap: 0.875rem !important;
        padding: 1rem 1.5rem !important;
        font-size: 1rem !important;
        font-weight: 400 !important;
        color: #000000 !important;
        background: transparent !important;
        border-radius: 0 !important;
        margin: 0 !important;
        cursor: pointer !important;
        width: 100% !important;
    }

    .mobile-dropdown-header i:first-child {
        font-size: 1.1rem !important;
        color: #000000 !important;
        order: 1 !important;
    }

    .mobile-dropdown-title {
        padding: 0 !important;
        font-size: 1rem !important;
        font-weight: 400 !important;
        flex: 1 !important;
        order: 2 !important;
    }

    .dropdown-arrow {
        font-size: 1rem !important;
        color: #666666 !important;
        margin-left: auto !important;
        order: 3 !important;
    }

    .mobile-dropdown-content {
        background: #ffffff !important;
        padding: 0 !important;
        border-radius: 0 !important;
        margin: 0 !important;
        border-left: none !important;
        display: none !important;
        width: 100% !important;
    }

    .mobile-dropdown.active .mobile-dropdown-content {
        display: block !important;
    }

    .mobile-submenu-item {
        display: flex !important;
        align-items: flex-start !important;
        gap: 1rem !important;
        padding: 1rem 1.5rem !important;
        border-radius: 0 !important;
        margin: 0 !important;
        background: #ffffff !important;
        color: #000000 !important;
        text-decoration: none !important;
        transition: all 0.3s ease !important;
        font-size: 0.95rem !important;
        border-bottom: 1px solid #f5f5f5 !important;
        width: 100% !important;
    }

    .mobile-submenu-item:hover,
    .mobile-submenu-item:active {
        background: #fafafa !important;
    }

    .mobile-submenu-item i {
        font-size: 1.1rem !important;
        color: #000000 !important;
        flex-shrink: 0 !important;
        margin-top: 2px !important;
    }

    .mobile-submenu-item > div {
        flex: 1 !important;
        text-align: left !important;
    }

    .mobile-submenu-item > div > div:first-child {
        font-weight: 500 !important;
        color: #000000 !important;
        margin-bottom: 4px !important;
        font-size: 0.95rem !important;
    }

    .mobile-submenu-item small {
        display: block !important;
        font-size: 0.8rem !important;
        color: #666666 !important;
        font-weight: 400 !important;
        line-height: 1.4 !important;
    }

    .mobile-submenu-item:active {
        background: rgba(0, 0, 0, 0.05) !important;
        transform: translateX(4px) !important;
    }

    /* Auth buttons cuando no está logueado */
    .mobile-auth {
        margin-top: 1.5rem !important;
        padding-top: 1.5rem !important;
        border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
    }

    /* ==========================================
       BOTONES - Mejor tamaño en móvil
       ========================================== */
    .btn {
        padding: 0.875rem 1.75rem !important;
        font-size: 0.95rem !important;
        min-height: 48px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* ==========================================
       CARDS - Mejor espaciado
       ========================================== */
    .card {
        padding: 1.75rem !important;
        margin-bottom: 1.5rem !important;
        border-radius: 20px !important;
        background: var(--bg-primary) !important;
        border: 1px solid var(--border-color) !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
        transition: all 0.3s ease !important;
    }

    .card:hover {
        transform: translateY(-4px) !important;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12) !important;
    }

    .card-grid {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }

    /* Cards de precios */
    .card h3 {
        font-size: 1.5rem !important;
        margin-bottom: 0.75rem !important;
    }

    .card .text-5xl,
    .card [class*="text-5xl"] {
        font-size: 2.5rem !important;
        font-weight: 800 !important;
    }

    .card ul {
        margin: 1.5rem 0 !important;
    }

    .card li {
        padding: 0.625rem 0 !important;
        font-size: 0.95rem !important;
    }

    /* ==========================================
       FEATURES GRID - Una columna
       ========================================== */
    #features-grid {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }

    /* ==========================================
       HOSTING PLANS - Una columna
       ========================================== */
    #hosting-plans {
        grid-template-columns: 1fr !important;
        gap: 2rem !important;
    }

    /* ==========================================
       TESTIMONIALS - Una columna
       ========================================== */
    #testimonials-grid {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }

    /* ==========================================
       FOOTER - Mejor distribución
       ========================================== */
    footer {
        padding: 3rem 0 2rem !important;
        background: var(--bg-primary) !important;
    }

    footer .container {
        padding: 0 1.5rem !important;
    }

    footer .container > div {
        display: flex !important;
        flex-direction: column !important;
        gap: 2.5rem !important;
        text-align: left !important;
    }

    /* Logo del footer */
    footer .logo img {
        height: 40px !important;
        margin-bottom: 1rem !important;
    }

    /* Secciones del footer */
    footer > div > div > div {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.75rem !important;
    }

    /* Títulos del footer */
    footer h3,
    footer h4 {
        font-size: 1.1rem !important;
        font-weight: 700 !important;
        margin-bottom: 1rem !important;
        color: var(--text-primary) !important;
    }

    /* Links del footer */
    footer a {
        font-size: 0.95rem !important;
        color: var(--text-secondary) !important;
        text-decoration: none !important;
        transition: color 0.3s ease !important;
        display: block !important;
        padding: 0.5rem 0 !important;
    }

    footer a:hover {
        color: var(--text-primary) !important;
    }

    /* Información de contacto */
    footer p {
        font-size: 0.95rem !important;
        line-height: 1.6 !important;
        color: var(--text-secondary) !important;
        margin: 0.5rem 0 !important;
    }

    /* Redes sociales en footer */
    footer .social-links {
        display: flex !important;
        gap: 1rem !important;
        margin-top: 1rem !important;
        flex-wrap: wrap !important;
    }

    footer .social-links a {
        width: 40px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: rgba(0, 0, 0, 0.05) !important;
        border-radius: 50% !important;
        padding: 0 !important;
    }

    footer .social-links a:hover {
        background: rgba(0, 0, 0, 0.1) !important;
    }

    /* Copyright */
    footer .copyright,
    footer [style*="border-top"] {
        margin-top: 2rem !important;
        padding-top: 2rem !important;
        border-top: 1px solid var(--border-color) !important;
        text-align: center !important;
        font-size: 0.875rem !important;
        color: var(--text-secondary) !important;
    }

    /* Grid del footer */
    footer .grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 2rem !important;
    }

    footer .grid > div {
        width: 100% !important;
    }

    /* ==========================================
       FLOATING BUTTONS - Mejor posición
       ========================================== */
    .floating-buttons {
        bottom: 20px !important;
        right: 20px !important;
        gap: 12px !important;
    }

    .floating-btn {
        width: 50px !important;
        height: 50px !important;
        font-size: 1.25rem !important;
    }

    /* ==========================================
       SCROLL TO TOP - Ajustar posición
       ========================================== */
    #scrollToTop {
        bottom: 90px !important;
        right: 20px !important;
        width: 45px !important;
        height: 45px !important;
    }

    /* ==========================================
       TEXTOS - Mejorar legibilidad
       ========================================== */
    h1 {
        font-size: 2rem !important;
        line-height: 1.2 !important;
    }

    h2 {
        font-size: 1.75rem !important;
        line-height: 1.3 !important;
    }

    h3 {
        font-size: 1.35rem !important;
        line-height: 1.4 !important;
    }

    p {
        font-size: 1rem !important;
        line-height: 1.6 !important;
    }

    /* ==========================================
       FORMS - Mejor UX en móvil
       ========================================== */
    input,
    textarea,
    select {
        font-size: 16px !important; /* Evita zoom en iOS */
        padding: 0.875rem !important;
        min-height: 48px !important;
    }

    /* ==========================================
       ANIMACIONES - Optimizar en móvil
       ========================================== */
    /* Desactivar completamente la animación del fondo en responsive */
    .fluid-bg,
    .fluid-bg::before,
    .fluid-bg::after {
        animation: none !important;
    }

    #logos-carousel > div {
        animation-duration: 120s !important;
    }

    /* Reducir animaciones de entrada */
    .fade-in-up,
    .fade-in-left,
    .fade-in-right {
        animation-duration: 0.5s !important;
        transform: translateY(20px) !important;
    }
}

/* ==========================================
   TABLETS (768px - 1024px)
   ========================================== */
@media (min-width: 769px) and (max-width: 1024px) {
    .container {
        padding: 0 2rem !important;
    }

    #hero-stats {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 1.5rem !important;
    }

    #features-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    #hosting-plans {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    #testimonials-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ==========================================
   MÓVILES PEQUEÑOS (< 375px)
   ========================================== */
@media (max-width: 374px) {
    .container {
        padding: 0 1rem !important;
    }

    .hero-section h1 {
        font-size: 1.75rem !important;
    }

    .btn {
        padding: 0.75rem 1.5rem !important;
        font-size: 0.9rem !important;
    }

    .stat-number {
        font-size: 2rem !important;
    }
}

/* ==========================================
   LANDSCAPE MODE - Móviles horizontales
   ========================================== */
@media (max-height: 500px) and (orientation: landscape) {
    .hero-section {
        padding-top: 80px !important;
        padding-bottom: 2rem !important;
    }

    .mobile-menu-content {
        padding: 60px 20px 30px !important;
        justify-content: flex-start !important;
    }

    .mobile-nav-item {
        padding: 12px 24px !important;
        font-size: 1rem !important;
        margin: 4px 0 !important;
    }
}
