/**
 * MOBILE APP EXPERIENCE - Dark Cinema Premium
 * Experiência nativa de aplicativo para mobile e tablet
 */

/* =============================================
   BASE - APP-LIKE FOUNDATION
   ============================================= */
@media (max-width: 1024px) {
    html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
    body { overflow-x: hidden; -webkit-tap-highlight-color: transparent; }
    img { max-width: 100%; height: auto; }
}

/* =============================================
   HEADER MOBILE - COMPACT APP BAR
   ============================================= */
@media (max-width: 768px) {
    .bs-header {
        position: sticky;
        top: 0;
        z-index: 999;
    }
    
    /* Header principal: Logo + Busca + User em UMA linha */
    .bs-header-main .container {
        display: flex !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        padding: 8px 12px !important;
        gap: 8px !important;
    }
    
    /* Logo compacto */
    .bs-logo { flex-shrink: 0; }
    .bs-logo img { max-height: 32px !important; }
    .bs-logo-text { font-size: 0 !important; } /* Esconde texto, mostra só imagem */
    .bs-logo-text .highlight,
    .bs-logo-text .domain { display: none !important; }
    
    /* Busca SEMPRE visível e expandida */
    .bs-search {
        flex: 1 !important;
        max-width: none !important;
        order: unset !important;
        display: block !important;
    }
    .bs-search-form {
        border-radius: 10px !important;
        border-width: 1.5px !important;
        background: #0e0e1a !important;
    }
    .bs-search-input {
        padding: 10px 12px !important;
        font-size: 13px !important;
    }
    .bs-search-btn { padding: 0 12px !important; }
    
    /* User menu desktop (login/register pills + pill online + sininho desktop)
       DEVE FICAR OCULTO no mobile — a versao mobile usa .bs-header-actions-mobile */
    .bs-user-menu {
        display: none !important;
    }
    .pfh-online-pill { display: none !important; }
    
    /* Esconder toggle antigo */
}

/* =============================================
   NAV DRAWER MOBILE - estilo completo em dark-theme.css
   (Bottom-nav foi removido; o navbar é um drawer lateral direito)
   ============================================= */
@media (max-width: 768px) {
    /* Mantém apenas ajustes NÃO-CONFLITANTES com o drawer */

    /* =============================================
       MEGA MENU GÊNEROS - FULLSCREEN OVERLAY
       ============================================= */
    .bs-dropdown {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100% !important;
        max-height: 100vh !important;
        height: 100vh !important;
        border-radius: 0 !important;
        z-index: 10000 !important;
        background: #0e0e1a !important;
        animation: genreSlideIn 0.25s ease !important;
        overflow-y: auto !important;
        display: none;
        padding-bottom: 20px !important;
    }
    .bs-nav-item:hover .bs-dropdown,
    .bs-nav-item.active .bs-dropdown {
        display: block;
    }
    
    @keyframes genreSlideIn {
        from { opacity: 0; transform: translateX(-100%); }
        to { opacity: 1; transform: translateX(0); }
    }
    
    .bs-dropdown-header {
        position: sticky !important;
        top: 0 !important;
        z-index: 2 !important;
        padding: 16px 18px !important;
        background: #0e0e1a !important;
        border-bottom: 1px solid rgba(255,255,255,0.08) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
    }
    .bs-dropdown-header span { font-size: 13px !important; }
    .bs-dropdown-header a { font-size: 12px !important; }
    
    .bs-dropdown-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        max-height: none !important;
        padding: 10px 12px !important;
        gap: 0 !important;
    }
    .bs-dropdown-grid a {
        padding: 14px 12px !important;
        font-size: 13px !important;
        border-radius: 10px !important;
    }
    .bs-dropdown-grid a .genre-icon {
        width: 36px !important;
        height: 36px !important;
        font-size: 14px !important;
        border-radius: 10px !important;
    }
    .bs-dropdown-grid a .genre-name { font-size: 13px !important; }
    .bs-dropdown-grid a .genre-count { font-size: 11px !important; }
    
    .bs-dropdown-footer {
        position: sticky !important;
        bottom: 0 !important;
        background: #0e0e1a !important;
        border-top: 1px solid rgba(255,255,255,0.08) !important;
        padding: 12px !important;
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px !important;
    }
    .bs-dropdown-footer a {
        justify-content: center !important;
        padding: 12px 8px !important;
        font-size: 11px !important;
        border-radius: 8px !important;
    }
}


/* =============================================
   QUICK BAR MOBILE
   ============================================= */
@media (max-width: 768px) {
    .quick-bar { padding: 8px 0 !important; }
    .quick-bar .container {
        gap: 12px !important;
        padding: 0 12px !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
        justify-content: flex-start !important;
    }
    .quick-bar .container::-webkit-scrollbar { display: none; }
    .quick-stat {
        font-size: 11px !important;
        gap: 5px !important;
        white-space: nowrap !important;
        flex-shrink: 0 !important;
        padding: 0 !important;
        border: none !important;
    }
    .quick-stat i { font-size: 10px !important; }
    .random-btn {
        padding: 7px 14px !important;
        font-size: 11px !important;
        gap: 5px !important;
        border-radius: 6px !important;
        flex-shrink: 0 !important;
    }
}


/* =============================================
   CARROSSEL - COVERS GROSSAS
   ============================================= */
@media (max-width: 768px) {
    .bs-featured-carousel { padding: 16px 0 24px !important; }
    .bs-carousel-header { padding: 0 12px !important; margin-bottom: 12px !important; }
    .bs-carousel-title .icon { width: 36px !important; height: 36px !important; font-size: 14px !important; }
    .bs-carousel-title .text { font-size: 15px !important; }
    .bs-carousel-nav { display: none !important; }
    .bs-carousel-track {
        padding: 0 12px !important;
        gap: 10px !important;
        scroll-snap-type: x mandatory;
    }
    .bs-carousel-item {
        flex: 0 0 145px !important;
        scroll-snap-align: start;
    }
    .bs-carousel-item-cover {
        width: 145px !important;
        height: 210px !important;
        border-radius: 8px !important;
    }
    .bs-carousel-item-title {
        font-size: 11px !important;
        padding: 8px !important;
    }
}

@media (max-width: 380px) {
    .bs-carousel-item { flex: 0 0 130px !important; }
    .bs-carousel-item-cover { width: 130px !important; height: 188px !important; }
}


/* =============================================
   FILTROS MOBILE
   ============================================= */
@media (max-width: 768px) {
    .filter-menu.filter-desktop { display: none !important; }
    .filter-mobile-container { display: block !important; }
    
    .filter-menu:not(.filter-desktop) {
        gap: 6px !important;
        padding: 10px 0 !important;
        margin-bottom: 12px !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
        flex-wrap: nowrap !important;
    }
    .filter-menu:not(.filter-desktop)::-webkit-scrollbar { display: none; }
    .filter-btn {
        padding: 9px 14px !important;
        font-size: 11px !important;
        flex-shrink: 0 !important;
        border-radius: 8px !important;
    }
    .view-toggle { margin-left: auto !important; flex-shrink: 0 !important; }
    .view-btn { width: 34px !important; height: 34px !important; }
    
    .section-header { margin-bottom: 14px !important; }
    .section-title { font-size: 17px !important; gap: 10px !important; }
    .section-title .icon { width: 34px !important; height: 34px !important; font-size: 14px !important; }
    .section-title .count { font-size: 10px !important; padding: 4px 10px !important; margin-left: 0 !important; }
    
    .portal-section,
    .category-container { padding: 0 12px !important; }
    .category-header { padding: 16px !important; margin-bottom: 14px !important; border-radius: 10px !important; }
    .category-header h1 { font-size: 17px !important; }
    .results-toolbar { padding: 10px 12px !important; border-radius: 8px !important; }
}


/* =============================================
   GAME CARDS - GRID APP
   ============================================= */
@media (max-width: 768px) {
    .bs-games-grid,
    .games-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px !important;
    }
    .bs-game-card,
    .game-card:not(.bs-premium-grid *) { border-radius: 6px !important; }
    .bs-game-card:hover,
    .game-card:not(.bs-premium-grid *):hover { transform: none !important; box-shadow: none !important; }
    
    .bs-game-card-title-wrap,
    .game-card-title-wrap { padding: 8px !important; }
    .bs-game-card-title,
    .game-card-title { font-size: 10px !important; margin-bottom: 3px !important; -webkit-line-clamp: 1 !important; }
    .bs-game-card-details,
    .game-card-details { gap: 3px !important; }
    .bs-game-card-details span,
    .game-card-detail { font-size: 8px !important; }
    .bs-game-card-details span i,
    .game-card-detail i { font-size: 7px !important; }
    
    .bs-dl-btn, .card-dl-btn { width: 36px !important; height: 36px !important; font-size: 13px !important; }
    .card-hover-meta, .bs-card-hover-meta { display: none !important; }
    .bs-cover-badge { font-size: 7px !important; padding: 1px 4px !important; }
    
    /* List view */
    .bs-games-grid.list-view .bs-game-card,
    .games-grid.list-view .game-card {
        grid-template-columns: 55px 1fr !important;
        padding: 10px !important;
        gap: 10px !important;
    }
    .bs-games-grid.list-view .bs-game-card-cover,
    .games-grid.list-view .game-card-cover { width: 55px !important; min-width: 55px !important; height: 92px !important; aspect-ratio: 3/5 !important; }
    .bs-games-grid.list-view .bs-game-card-cover img,
    .games-grid.list-view .game-card-cover img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
    .bs-games-grid.list-view .list-dl-btn,
    .games-grid.list-view .list-dl-btn { display: none !important; }
    .bs-games-grid.list-view .bs-game-card-title,
    .games-grid.list-view .game-card-title { font-size: 12px !important; }
}

@media (max-width: 420px) {
    .bs-games-grid:not(.bs-premium-grid),
    .games-grid:not(.bs-premium-grid) { grid-template-columns: repeat(3, 1fr) !important; gap: 6px !important; }
    .bs-game-card-title, .game-card-title { font-size: 9px !important; }
}

/* Tablet */
@media (min-width: 769px) and (max-width: 1024px) {
    .bs-games-grid:not(.bs-premium-grid), .games-grid:not(.bs-premium-grid) { grid-template-columns: repeat(5, 1fr) !important; gap: 12px !important; }
}


/* =============================================
   PAGINATION MOBILE
   ============================================= */
@media (max-width: 768px) {
    .bs-pagination, .pagination {
        gap: 4px !important;
        margin-top: 20px !important;
        padding-bottom: 10px !important;
    }
    .bs-pagination a, .bs-pagination span,
    .pagination a, .pagination span {
        min-width: 36px !important;
        height: 36px !important;
        font-size: 12px !important;
        border-radius: 8px !important;
    }
}


/* =============================================
   SINGLE GAME PAGE MOBILE
   ============================================= */
@media (max-width: 768px) {
    .single-esq { width: 100% !important; float: none !important; padding: 0 !important; }
    .single-dir { width: 100% !important; float: none !important; clear: both !important; margin-top: 16px !important; padding: 0 !important; }
    
    .bs-box { margin-bottom: 12px !important; border-radius: 10px !important; overflow: hidden; }
    .bs-box-header { padding: 12px 14px !important; }
    .bs-box-content { padding: 14px !important; }
    
    .info-grid { grid-template-columns: 1fr 1fr !important; }
    .info-item { padding: 8px 0 !important; }
    .info-item .icon { width: 28px !important; height: 28px !important; font-size: 11px !important; }
    .info-item .label { font-size: 10px !important; }
    .info-item .value { font-size: 12px !important; }
    
    .gallery-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 6px !important; }
    
    .dl-item { padding: 10px !important; gap: 10px !important; }
    .dl-item-icon { width: 32px !important; height: 32px !important; font-size: 13px !important; border-radius: 6px !important; }
    .dl-item-name { font-size: 11px !important; }
    .dl-item-meta { font-size: 9px !important; }
    
    .bs-action-bar { flex-wrap: wrap !important; gap: 6px !important; }
    .bs-action-btn { flex: 1 !important; min-width: 0 !important; font-size: 10px !important; padding: 9px 10px !important; justify-content: center !important; }
    
    .bs-comment-form-body textarea { min-height: 70px !important; }
    .bs-tutorials-grid { grid-template-columns: 1fr !important; gap: 8px !important; }
    
    .sidebar-box { margin-bottom: 12px !important; border-radius: 10px !important; }
}


/* =============================================
   BANNER "NÃO ACHOU" MOBILE
   ============================================= */
@media (max-width: 768px) {
    .bs-request-banner { padding: 0 12px !important; margin: 16px auto !important; }
    .bs-request-banner-inner {
        flex-direction: column !important;
        text-align: center !important;
        padding: 18px 14px !important;
        gap: 12px !important;
        border-radius: 12px !important;
    }
    .bs-request-banner-inner::before { display: none; }
    .bs-request-banner-text h3 { font-size: 14px !important; }
    .bs-request-banner-text p { font-size: 11px !important; }
    .bs-request-banner-btn {
        width: 100% !important;
        justify-content: center !important;
        padding: 12px 20px !important;
        font-size: 12px !important;
        border-radius: 8px !important;
    }
}


/* =============================================
   PEDIDOS PAGE MOBILE
   ============================================= */
@media (max-width: 768px) {
    .rq-container { padding: 14px !important; }
    .rq-header h1 { font-size: 22px !important; }
    .rq-header p { font-size: 12px !important; }
    .rq-stats { flex-wrap: wrap !important; gap: 6px !important; }
    .rq-stat { flex: 1 !important; min-width: 80px !important; padding: 10px !important; border-radius: 8px !important; }
    .rq-stat-num { font-size: 18px !important; }
    .rq-stat-label { font-size: 9px !important; }
    .rq-search-card { padding: 14px !important; border-radius: 10px !important; }
    .rq-search-input { padding: 11px 12px 11px 36px !important; font-size: 13px !important; }
    .rq-result {
        flex-direction: row !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 10px !important;
    }
    .rq-result-cover { width: 42px !important; height: 58px !important; flex-shrink: 0 !important; }
    .rq-result-info { min-width: 0 !important; }
    .rq-result-name { font-size: 12px !important; }
    .rq-result-meta { font-size: 10px !important; }
    .rq-result-btn { padding: 8px 12px !important; font-size: 10px !important; flex-shrink: 0 !important; }
    .rq-top-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
    .rq-top-card { padding: 12px !important; }
    .rq-top-cover { width: 40px !important; height: 56px !important; }
    .rq-community-grid { grid-template-columns: repeat(3, 1fr) !important; }
    .rq-my-item { padding: 10px !important; }
}


/* =============================================
   DONATION BANNER MOBILE ("Quer acesso instantâneo")
   ============================================= */
@media (max-width: 768px) {
    .bs-donation-banner {
        margin: 14px 0 !important;
        border-radius: 12px !important;
    }
    .bs-donation-banner > div:first-of-type + div {
        flex-direction: column !important;
    }
    /* Ícone lateral - esconder no mobile */
    .bs-donation-banner > div:nth-child(2) > div:first-child {
        display: none !important;
    }
    /* Conteúdo central - empilhar */
    .bs-donation-banner > div:nth-child(2) > div:last-child {
        padding: 18px 16px !important;
        flex-direction: column !important;
        text-align: center !important;
        gap: 14px !important;
    }
    .bs-donation-banner h3 { font-size: 17px !important; }
    .bs-donation-banner p { font-size: 12px !important; }
    .bs-donation-banner p br { display: none; }
    /* Botão doar - full width */
    .bs-donation-banner a[href*="doar"] {
        width: 100% !important;
        justify-content: center !important;
        padding: 12px 20px !important;
        font-size: 14px !important;
        border-radius: 8px !important;
    }
    /* Barra de benefícios */
    .bs-donation-banner > div:last-child {
        flex-direction: column !important;
        gap: 8px !important;
        padding: 12px 16px !important;
        align-items: flex-start !important;
    }
}


/* =============================================
   TELEGRAM BANNER MOBILE
   ============================================= */
@media (max-width: 768px) {
    .bs-telegram-banner,
    .tg-banner-portal {
        flex-direction: column !important;
        text-align: center !important;
        padding: 12px !important;
        gap: 8px !important;
        border-radius: 8px !important;
        margin: 0 0 12px !important;
    }
    .bs-telegram-banner .tg-info h4,
    .tg-banner-portal .tg-info h4 { font-size: 12px !important; }
    .bs-telegram-banner .tg-info p,
    .tg-banner-portal .tg-info p { font-size: 10px !important; }
    .bs-telegram-banner .tg-btn,
    .tg-banner-portal .tg-btn { padding: 8px 16px !important; font-size: 11px !important; }
}


/* =============================================
   FOOTER MOBILE
   ============================================= */
@media (max-width: 768px) {
    .pro-footer { padding: 24px 0 12px !important; }
    .footer-inner { padding: 0 12px !important; }
    .footer-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
    .footer-block h4 { font-size: 12px !important; margin-bottom: 10px !important; }
    .footer-links li a { font-size: 11px !important; padding: 3px 0 !important; }
    .footer-bottom { flex-direction: column !important; gap: 8px !important; text-align: center !important; padding-top: 14px !important; }
}

@media (max-width: 420px) {
    .footer-grid { grid-template-columns: 1fr !important; }
}


/* =============================================
   AUTH PAGES MOBILE
   ============================================= */
@media (max-width: 768px) {
    .auth-container, .auth-box { padding: 20px 16px !important; margin: 12px !important; border-radius: 12px !important; }
    .auth-title { font-size: 20px !important; }
}


/* =============================================
   DASHBOARD MOBILE
   ============================================= */
@media (max-width: 768px) {
    .dashboard-container { padding: 12px !important; }
    .dashboard-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
    .dash-stat { padding: 12px !important; border-radius: 8px !important; }
}


/* =============================================
   DOWNLOAD RESTRICTED MOBILE
   ============================================= */
@media (max-width: 768px) {
    .bs-download-restricted {
        margin: 16px !important;
        padding: 24px 16px !important;
        border-radius: 12px !important;
    }
    .bs-download-restricted h3 { font-size: 16px !important; }
    .bs-download-restricted p { font-size: 12px !important; }
    .bs-restricted-actions { flex-direction: column !important; gap: 8px !important; }
    .bs-restricted-actions a { width: 100% !important; text-align: center !important; justify-content: center !important; display: flex !important; }
}


/* =============================================
   GLOBAL: PREVENT OVERFLOW & SMOOTH
   ============================================= */
@media (max-width: 768px) {
    #wrapper, #meio, main, section, .container, .portal-section, .category-container {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    iframe { max-width: 100% !important; }
    h1, h2, h3, h4 { word-wrap: break-word; overflow-wrap: break-word; }
    
    /* Smooth transitions globais */
    * { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
    
    /* Safe area (notch) */
    body { padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); }
}


/* =============================================
   TABLET (769px - 1024px)
   ============================================= */
@media (min-width: 769px) and (max-width: 1024px) {
    .bs-header-main .container { padding: 12px 16px !important; gap: 12px !important; }
    .bs-logo img { max-height: 44px; }
    .bs-search { max-width: 400px !important; }
    .bs-nav-link { padding: 12px 14px !important; font-size: 11px !important; }
    
    .quick-bar .container { gap: 20px !important; }
    .bs-carousel-item { flex: 0 0 155px !important; }
    .bs-carousel-item-cover { width: 155px !important; height: 224px !important; }
    
    .footer-grid { grid-template-columns: repeat(4, 1fr) !important; }
}
