/* =========================================================
   BOOTCAMP MANAGER PRO — Mobile Responsive FINAL
   /static/css/mobile_responsive.css
   ========================================================= */

/* ─── Hamburger Button ─── */
.mobile-menu-toggle {
    display: none;
    position: fixed;
    top: 14px;
    left: 14px;
    z-index: 1100;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: var(--bg-card, #1a1a2e);
    border: 1px solid var(--border-purple, rgba(124,58,237,0.3));
    cursor: pointer;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 0;
    transition: all 0.2s;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}
.mobile-menu-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    background: var(--purple-light, #a78bfa);
    border-radius: 2px;
    transition: all 0.25s;
}
.mobile-menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-menu-toggle.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.mobile-menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ─── Sidebar overlay ─── */
.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.65);
    z-index: 1050;
    backdrop-filter: blur(3px);
}
.sidebar-overlay.active { display: block; }

/* ═══════════════════════════════════════════════════════
   FIX GLOBAL: Flip card webkit (iOS Safari)
   ═══════════════════════════════════════════════════════ */
.ath-flip-wrapper {
    -webkit-perspective: 1200px;
    perspective: 1200px;
}
.ath-flip-inner {
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-transition: -webkit-transform 0.55s cubic-bezier(0.4,0.2,0.2,1);
    transition: transform 0.55s cubic-bezier(0.4,0.2,0.2,1);
}
.ath-flip-wrapper.flipped .ath-flip-inner {
    -webkit-transform: rotateY(180deg);
    transform: rotateY(180deg);
}
.ath-flip-front {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
}
.ath-card-back {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-transform: rotateY(180deg) translateZ(1px);
    transform: rotateY(180deg) translateZ(1px);
}

/* ═══════════════════════════════════════════════════════
   TABLET (≤ 1024px)
   ═══════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .sidebar { width: 220px; }
    .main-content { margin-left: 220px; }
    .scout-hero-section { flex-direction: column !important; align-items: center !important; }
    .scout-hero-panel { width: 100% !important; }
    #page-partidas .content-card > div[style*="grid-template-columns: 1.3fr"] {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* ═══════════════════════════════════════════════════════
   MOBILE (≤ 768px)
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {

    .mobile-menu-toggle { display: flex; }

    .sidebar {
        position: fixed;
        left: -260px;
        top: 0; bottom: 0;
        width: 260px !important;
        z-index: 1060;
        transition: left 0.3s cubic-bezier(0.4,0,0.2,1);
        overflow-y: auto;
    }
    .sidebar.open { left: 0; box-shadow: 8px 0 40px rgba(0,0,0,0.6); }

    .main-content {
        margin-left: 0 !important;
        padding: 64px 12px calc(62px + env(safe-area-inset-bottom, 0px) + 8px) !important;
    }

    /* ── Header ── */
    .header { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important; margin-bottom: 16px !important; }
    .header h2 { font-size: 18px !important; }
    .header-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 7px !important;
        width: 100% !important;
    }
    .header-actions select { grid-column: 1 / -1 !important; width: 100% !important; font-size: 12px !important; padding: 9px 10px !important; }
    .header-actions .btn-primary { grid-column: 1 / -1 !important; }
    .header-actions .btn, .header-actions button { width: 100% !important; font-size: 12px !important; padding: 9px 8px !important; }
    #page-scout .header-actions #select-atleta { grid-column: 1 / -1 !important; }
    #page-ranking .header-actions #filter-periodo,
    #page-ranking .header-actions #filter-equipe { grid-column: 1 / -1 !important; }
    #historico-actions-normal, #historico-actions-select {
        display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 7px !important; width: 100% !important;
    }

    /* ── Grids gerais ── */
    .content-grid { grid-template-columns: 1fr !important; }
    .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .eq-grid { grid-template-columns: 1fr !important; }

    /* ═══════════════════════════════════════════
       ATLETAS: grade 2 colunas, altura fixa 360px
       ═══════════════════════════════════════════ */
    #atletas-list {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        grid-auto-rows: 360px !important;
        gap: 10px !important;
        align-items: start !important;
    }

    /* Flip wrapper = célula inteira */
    #atletas-list > .ath-flip-wrapper {
        width: 100% !important;
        height: 360px !important;
        min-height: 360px !important;
        max-height: 360px !important;
        overflow: hidden !important;
    }
    #atletas-list .ath-flip-inner,
    #atletas-list .ath-flip-front,
    #atletas-list .ath-card-back {
        height: 360px !important;
        max-height: 360px !important;
        overflow: hidden !important;
    }

    /* Borda: sem hover transform no mobile (iOS sticky hover) */
    #atletas-list .ath-card:hover,
    #atletas-list .ath-flip-front:hover { transform: none !important; }
    #atletas-list > .ath-flip-wrapper { overflow: visible !important; }
    #atletas-list .ath-card.active,
    #atletas-list .ath-flip-front.active {
        transform: none !important;
        box-shadow: inset 0 0 40px rgba(0,0,0,0.5),
                    0 0 0 2px var(--ath-color-exact, rgba(124,58,237,0.8)),
                    0 0 20px var(--ath-color-exact, rgba(124,58,237,0.4)) !important;
    }

    /* Card "Novo Atleta" inicial (+) */
    #ath-card-new-container {
        height: 360px !important;
        min-height: 360px !important;
        max-height: 360px !important;
        overflow: hidden !important;
    }

    /* ═══════════════════════════════════════════
       SCOUT HERO — z-index e nome sem transbordar
       ═══════════════════════════════════════════ */
    .scout-hero-section { flex-direction: column !important; padding: 16px !important; overflow: hidden !important; position: relative !important; }
    #scout-hero-bg { z-index: 0 !important; }
    .scout-hero-card-slot { position: relative !important; z-index: 2 !important; width: 140px !important; height: 190px !important; margin: 0 auto 12px !important; }
    .scout-hero-panel { position: relative !important; z-index: 1 !important; width: 100% !important; overflow: hidden !important; }
    .scout-hero-identity { overflow: hidden !important; margin-bottom: 12px !important; }
    .scout-hero-name { font-size: 22px !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; max-width: 100% !important; }
    .scout-hero-kpis { flex-wrap: wrap !important; gap: 10px !important; }
    .scout-hero-kpi { min-width: 70px !important; }
    .scout-hero-kpi-val { font-size: 22px !important; }
    .scout-hero-stats-grid { grid-template-columns: repeat(2, 1fr) !important; }

    /* Scout picker scroll horizontal */
    #scout-card-picker-wrap { overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; }
    #scout-card-picker { flex-wrap: nowrap !important; padding-bottom: 8px !important; }
    #scout-card-picker .ath-flip-wrapper,
    #scout-card-picker .ath-flip-front,
    #scout-card-picker .ath-card-back,
    #scout-card-picker .ath-flip-inner { width: 130px !important; min-width: 130px !important; max-width: 130px !important; }

    /* ── Partidas ── */
    #page-partidas .content-card > div[style*="grid-template-columns"] { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
    .grid-header { display: none !important; }
    #jogadores-container > div, #edit-jogadores-container > div, #auto-jogadores-grid > div {
        grid-template-columns: 1fr 1fr 1fr !important; gap: 8px !important; padding: 10px !important;
    }
    #auto-upload-box > div[style*="grid-template-columns: 1fr 1fr 1fr"] { grid-template-columns: 1fr !important; }
    #auto-preview-box > div[style*="grid-template-columns: 1fr 1fr 1fr 1fr"] { grid-template-columns: 1fr 1fr !important; }

    /* ── Scout equipe ── */
    #scout-equipe-content > div[style*="grid-template-columns:repeat(3,1fr)"] { grid-template-columns: 1fr !important; }
    #scout-equipe-content > div[style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }

    /* ── Ranking ── */
    #ranking-table { overflow-x: auto !important; }
    .ranking-row {
        grid-template-columns: 38px 1fr 52px 52px 52px !important;
        gap: 6px !important; padding: 10px !important; font-size: 12px !important;
    }
    #ranking-table > div:first-child {
        grid-template-columns: 38px 1fr 52px 52px 52px !important;
        gap: 6px !important; padding: 8px 10px !important; font-size: 10px !important;
    }
    .ranking-row > div:nth-child(6), .ranking-row > div:nth-child(7),
    #ranking-table > div:first-child > div:nth-child(6),
    #ranking-table > div:first-child > div:nth-child(7) { display: none !important; }
    .rank-avatar { width: 34px !important; height: 34px !important; }
    .rank-position { font-size: 15px !important; }
    .rank-stat { font-size: 13px !important; font-weight: 700 !important; }
    .rank-player { gap: 7px !important; }
    .rank-player > div > div:first-child { font-size: 13px !important; }
    .rank-player > div > div:last-child { font-size: 10px !important; }

    /* ── Histórico ── */
    #historico-lista .content-card { padding: 12px !important; }
    #painel-periodos > div[style*="grid-template-columns: repeat(3"] { grid-template-columns: 1fr !important; gap: 10px !important; }

    /* ── Modais ── */
    .modal-box { max-width: 96vw !important; margin: 0 8px !important; padding: 20px 16px !important; max-height: 90vh !important; overflow-y: auto !important; }
    #modal-edit-partida div[style*="grid-template-columns: 1fr 1fr 1fr 1fr 1fr"] { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
    #resultado-comparacao > div[style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }

    .scout-atmo-clip { height: 80px !important; }
    .content-card { padding: 14px !important; }
    .plans-grid { grid-template-columns: 1fr !important; max-width: 100% !important; }

    .mobile-bottom-nav { display: flex !important; }
}

/* ═══════════════════════════════════════════════════════
   PHONE (≤ 480px)
   ═══════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    .main-content { padding: 58px 8px calc(62px + env(safe-area-inset-bottom, 0px) + 8px) !important; }
    #atletas-list { grid-auto-rows: 330px !important; gap: 8px !important; }
    #atletas-list > .ath-flip-wrapper,
    #atletas-list .ath-flip-inner,
    #atletas-list .ath-flip-front,
    #atletas-list .ath-card-back { height: 330px !important; max-height: 330px !important; }
    #ath-card-new-container { height: 330px !important; min-height: 330px !important; max-height: 330px !important; }
    .stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }
    .header h2 { font-size: 16px !important; }
    .header-actions { grid-template-columns: 1fr !important; }
    .header-actions .btn, .header-actions button, .header-actions select { grid-column: 1 / -1 !important; }
    .scout-hero-name { font-size: 20px !important; }
    #scout-card-picker .ath-flip-wrapper,
    #scout-card-picker .ath-flip-front,
    #scout-card-picker .ath-card-back,
    #scout-card-picker .ath-flip-inner { width: 120px !important; min-width: 120px !important; }
    .ranking-row { grid-template-columns: 32px 1fr 46px 46px 46px !important; padding: 8px !important; }
    #ranking-table > div:first-child { grid-template-columns: 32px 1fr 46px 46px 46px !important; }
}

/* ═══════════════════════════════════════════════════════
   BOTTOM NAV BAR — estável no iPhone Pro Max
   ═══════════════════════════════════════════════════════ */
.mobile-bottom-nav {
    display: none;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    background: rgba(15, 17, 26, 0.97);
    border-top: 1px solid var(--border-purple, rgba(124,58,237,0.25));
    z-index: 900;
    align-items: stretch;
    justify-content: space-around;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
}
.mobile-bottom-nav button {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 3px; background: none; border: none; cursor: pointer;
    padding: 10px 4px 8px; flex: 1; border-radius: 0; position: relative;
    -webkit-tap-highlight-color: transparent; transition: background 0.15s;
}
.mobile-bottom-nav button:active { background: rgba(124,58,237,0.15); }
.mobile-bottom-nav button.active { background: rgba(124,58,237,0.08); }
.mobile-bottom-nav button.active::after {
    content: ''; position: absolute; top: 0; left: 25%; right: 25%;
    height: 2px; background: var(--purple, #7c3aed); border-radius: 0 0 3px 3px;
}
.mobile-bottom-nav button .bnav-icon { font-size: 22px; line-height: 1; transition: transform 0.15s; }
.mobile-bottom-nav button.active .bnav-icon { transform: translateY(-1px); }
.mobile-bottom-nav button .bnav-label {
    font-size: 9px; font-weight: 700; color: var(--text-muted, #64748b);
    text-transform: uppercase; letter-spacing: 0.5px; line-height: 1; white-space: nowrap;
}
.mobile-bottom-nav button.active .bnav-label { color: var(--purple-light, #a78bfa); }