/* ============================================================
   FFACILITES - Polish Mobile
   Refinamentos finais para uso confortavel em celular.
   Carregado por ultimo para sobrescrever onde precisar.
   ============================================================ */

/* ===== Variaveis e regras base ===== */
@media (max-width: 900px) {
    /* Larguras controladas - nada estoura horizontalmente */
    html, body { max-width: 100%; overflow-x: hidden; }
    img, canvas, video, table { max-width: 100%; }
    button { font-family: inherit; }
}

/* ============================================================
   Mobile geral (<=768px)
   ============================================================ */
@media (max-width: 768px) {
    /* Header mais limpo e fixo */
    .top-header {
        padding: 0;
        border-bottom: 1px solid rgba(212,160,23,0.15);
    }
    .header-container {
        gap: 6px !important;
        padding: 8px 12px !important;
        align-items: center;
    }
    .header-logo { gap: 8px; min-width: 0; }
    .header-logo-img { height: 26px !important; }
    .header-container > div:last-child {
        flex-shrink: 0;
        gap: 4px !important;
    }
    .header-container > div:last-child button {
        padding: 6px 10px !important;
        font-size: 10px !important;
    }

    /* Hamburger ganha leve indicador de "tem conteudo" */
    .btn-mobile-menu {
        position: relative;
    }

    /* ===== Drawer da sidebar mais polido ===== */
    .sidebar {
        padding-top: 64px !important;
    }
    .sidebar::before {
        content: 'FFACILITES';
        position: absolute;
        top: 18px;
        left: 20px;
        right: 56px;
        font-size: 14px;
        font-weight: 900;
        letter-spacing: 2px;
        color: var(--primary, #d4a017);
        background: linear-gradient(135deg, var(--primary, #d4a017), var(--primary-light, #f5c518));
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        z-index: 4;
        pointer-events: none;
    }
    .menu-section-title {
        font-size: 9.5px !important;
        opacity: 0.65;
    }
    .btn-nav {
        font-size: 13.5px !important;
        padding: 12px 16px 12px 22px !important;
        margin: 0 !important;
        border-bottom: 1px solid rgba(255,255,255,0.02);
        position: relative;
    }
    .btn-nav::after {
        content: '';
        position: absolute;
        right: 16px; top: 50%;
        width: 6px; height: 6px;
        border-right: 2px solid currentColor;
        border-top: 2px solid currentColor;
        transform: translateY(-50%) rotate(45deg);
        opacity: 0.3;
    }
    .btn-nav.active {
        background: linear-gradient(90deg, rgba(212,160,23,0.18), transparent 90%) !important;
        color: var(--primary-light, #f5c518) !important;
        border-left: 3px solid var(--primary, #d4a017);
        padding-left: 19px !important;
    }
    .btn-nav.active::after { opacity: 1; }

    /* ===== Tipografia geral mais legivel ===== */
    .bloco-titulo { font-size: 14px !important; letter-spacing: 1px !important; }
    .titulo-icon { width: 16px !important; height: 16px !important; }

    /* Inputs/selects altura confortavel */
    input[type="text"], input[type="number"], input[type="email"],
    input[type="password"], input[type="search"], select, textarea {
        font-size: 16px !important;  /* evita zoom no iOS */
        padding: 11px 12px !important;
    }

    /* ===== Botoes - alvo de toque generoso ===== */
    button, .btn-nav, .btn-add, .btn-acao-form,
    .btn-processar-imagens, .btn-config-salvar, .btn-banner {
        min-height: 42px;
    }

    /* ===== Tabelas com scroll horizontal suave =====
       Embrulha tabelas em scroll com indicacao visual de overflow */
    .tabela-ranking-torneio,
    .historico-table,
    table.ffws-tabela {
        font-size: 11px !important;
        min-width: 540px;
    }
    .tabela-ranking-torneio td,
    .tabela-ranking-torneio th,
    .historico-table td, .historico-table th,
    table.ffws-tabela td, table.ffws-tabela th {
        padding: 8px 6px !important;
        white-space: nowrap;
    }
    /* Wrapper de scroll com sombra lateral indicando que ha mais conteudo */
    .ffws-bloco {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        position: relative;
    }
    .ffws-bloco::before {
        content: '';
        position: sticky;
        top: 0; left: 100%;
        display: block;
        width: 1px; height: 1px;
        box-shadow: -10px 0 16px rgba(212,160,23,0.08);
        pointer-events: none;
    }

    /* ===== Cards de equipe - 2 colunas, miniaturas balanceadas ===== */
    .grid-equipes {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
        padding: 10px !important;
    }
    .equipe-card-quadrado {
        padding: 12px 10px 10px !important;
        gap: 8px !important;
    }
    .equipe-logo-area {
        width: 100% !important;
        height: auto !important;
        max-width: 100%;
        aspect-ratio: 1/1;
    }
    .equipe-logo-placeholder-grande { font-size: 36px !important; }
    .equipe-card-nome { font-size: 11.5px !important; }

    /* ===== Jogadores - card de elenco compacto ===== */
    .grid-jogadores-cards {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        padding: 10px !important;
    }

    /* ===== Cards de estatisticas / live ===== */
    .live-stat-card { padding: 12px !important; }
    .live-stat-titulo { font-size: 9px !important; }
    .live-stat-valor { font-size: 22px !important; }
    .live-actions-grid { gap: 8px !important; }
    .live-action-card { padding: 14px !important; }

    /* ===== Booyah - cards em coluna ===== */
    .booyah-grid { grid-template-columns: 1fr !important; }
    .booyah-item { padding: 10px !important; gap: 10px !important; }
    .booyah-item-num { width: 28px !important; height: 28px !important; font-size: 12px !important; }
    .booyah-item-equipe { font-size: 13px !important; }
    .booyah-item-data { font-size: 10px !important; }

    /* ===== Backup - botoes empilhados ===== */
    .backup-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
    .backup-card { padding: 16px !important; }

    /* ===== OBS - lista de cards confortavel ===== */
    .obs-grid { grid-template-columns: 1fr !important; }
    .obs-card-modern { padding: 14px !important; }
    .obs-card-actions { flex-direction: column !important; gap: 6px !important; }
    .obs-card-actions button { width: 100% !important; }

    /* ===== Configuracoes - tudo em coluna unica ===== */
    .config-page { padding: 12px !important; }
    .config-hero { gap: 10px !important; padding: 18px 16px !important; }
    .config-hero-icon { width: 56px !important; height: 56px !important; }
    .config-hero-icon img { width: 28px !important; height: 28px !important; }
    .config-hero-titulo { font-size: 17px !important; }
    .config-hero-desc { font-size: 11.5px !important; }
    .grid-posicoes-config {
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 6px !important;
    }
    .grid-posicoes-config > div { padding: 8px 6px !important; }
    .grid-posicoes-config input { font-size: 16px !important; padding: 4px !important; }
    .grid-posicoes-config label { font-size: 9px !important; margin-bottom: 4px !important; }

    /* ===== Subir log / converter / drop zone ===== */
    .subir-log-drop, .drop-zone {
        margin: 12px !important;
        padding: 24px 14px !important;
        min-height: 140px !important;
    }
    .subir-log-icon { width: 44px !important; height: 44px !important; }
    .subir-log-icon img { width: 22px !important; height: 22px !important; }
    .subir-log-texto { font-size: 14px !important; }
    .subir-log-sub { font-size: 11px !important; }
    .drop-content img { width: 32px !important; height: 32px !important; }

    /* Manual - 2 inputs por linha */
    .manual-page { padding: 12px !important; }
    .manual-hero { padding: 16px 14px !important; }
    .manual-hero-icon { width: 44px !important; height: 44px !important; }
    .manual-hero-icon img { width: 22px !important; height: 22px !important; }
    .manual-hero-titulo { font-size: 16px !important; }
    .manual-hero-desc { font-size: 11.5px !important; }
    .manual-form-card { padding: 14px !important; }
    .manual-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
    .manual-campo label { font-size: 10px !important; }
    .manual-campo input, .manual-campo select { font-size: 16px !important; padding: 9px !important; }

    /* Resultado de log com scroll horizontal so na tabela */
    .resultado-tabela-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .resultado-tabela-wrap table { min-width: 540px; }
    .resultado-jogadores-grid { grid-template-columns: 1fr 1fr !important; gap: 6px !important; }
    .res-jog-chip { padding: 8px 10px !important; font-size: 11px !important; }
    .res-jog-nick { max-width: 100px; overflow: hidden; text-overflow: ellipsis; }

    /* ===== Banners - usados pelos shells novos ===== */
    .banner-shell .bnr-titulo {
        flex-direction: column;
        gap: 6px !important;
    }
    .banner-shell .bnr-titulo .bnr-tema-chip {
        font-size: 9px !important;
        padding: 3px 10px !important;
    }
    .banner-shell .bnr-actions {
        grid-template-columns: 1fr 1fr 1fr !important;
    }
    .banner-shell .bnr-btn { padding: 10px 4px !important; font-size: 10.5px !important; }

    /* ===== Toasts e modais ===== */
    .toast {
        left: 10px !important;
        right: 10px !important;
        bottom: 14px !important;
        max-width: none !important;
        font-size: 12.5px !important;
        padding: 12px 14px !important;
    }
    .modal-conteudo, .admin-confirm-box {
        max-width: 92vw !important;
        width: 92vw !important;
        padding: 18px !important;
    }

    /* ===== Champion notification stack ja eh mobile-ready,
       so afasta um pouco do header ===== */
    .champion-stack {
        top: 56px !important;
        right: 8px !important;
        left: 8px !important;
        max-width: none !important;
    }

    /* ===== Ranking blocos com titulo melhor ===== */
    .ffws-titulo {
        font-size: 11px !important;
        padding: 10px 14px !important;
    }

    /* ===== Foto de jogadores cards menores ===== */
    .foto-jog-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; padding: 10px !important; }

    /* ===== Aba "registro rapido" / spec ===== */
    .reg-rapido-grid { grid-template-columns: 1fr !important; gap: 12px !important; }
}

/* ============================================================
   Telas pequenas (<=480px) - smartphone vertical
   ============================================================ */
@media (max-width: 480px) {
    .header-container { padding: 6px 10px !important; }
    .header-logo-img { height: 22px !important; }
    .top-header .header-container > div:last-child #userEmailDisplay { display: none !important; }

    /* Logo da equipe ainda menor mas grid de 2 mantem */
    .grid-equipes { grid-template-columns: repeat(2, 1fr) !important; }
    .equipe-logo-placeholder-grande { font-size: 32px !important; }

    /* Stats em 2 colunas, action grid em 2 */
    .live-stats { grid-template-columns: repeat(2, 1fr) !important; }
    .live-actions-grid { grid-template-columns: 1fr 1fr !important; }
    .manual-grid { grid-template-columns: 1fr !important; }
    .resultado-jogadores-grid { grid-template-columns: 1fr !important; }

    /* Banner actions empilham */
    .banner-shell .bnr-actions { grid-template-columns: 1fr !important; }

    /* Posicoes - mantem 5 mas com fonte menor */
    .grid-posicoes-config {
        grid-template-columns: repeat(5, 1fr) !important;
    }
    .grid-posicoes-config input { font-size: 14px !important; }

    /* Notificacao champion compacta */
    .champion-notif { padding: 10px 12px !important; }
    .champion-notif-icon { font-size: 24px !important; }
    .champion-notif-equipe { font-size: 13px !important; }
}

/* ============================================================
   Telas muito pequenas (<=360px) - tipo iPhone SE
   ============================================================ */
@media (max-width: 360px) {
    .grid-equipes { grid-template-columns: 1fr !important; }
    .grid-posicoes-config { grid-template-columns: repeat(3, 1fr) !important; }
    .live-stats { grid-template-columns: 1fr !important; }
    .live-actions-grid { grid-template-columns: 1fr !important; }
    .header-logo-img { height: 20px !important; }
    .header-container > div:last-child button {
        padding: 4px 8px !important;
        font-size: 9px !important;
    }
}

/* ============================================================
   Touch / dispositivos sem hover
   ============================================================ */
@media (hover: none) and (pointer: coarse) {
    /* Remove transformacoes de hover que ficam "presas" no mobile */
    .equipe-card-quadrado:hover,
    .config-card:hover,
    .live-stat-card:hover,
    .live-action-card:hover,
    .obs-card-modern:hover,
    .backup-card:hover,
    .res-jog-chip:hover {
        transform: none !important;
    }
    /* Indicacao tatil em vez de hover */
    .btn-add:active, .btn-acao-form:active,
    .btn-processar-imagens:active, .btn-config-salvar:active,
    .btn-banner:active, .bnr-btn:active {
        transform: scale(0.97);
        transition: transform 0.08s ease;
    }
    .btn-nav:active {
        background: rgba(212,160,23,0.18) !important;
    }
    .equipe-card-quadrado:active {
        background: rgba(255,255,255,0.02);
    }
}

/* ============================================================
   Suporte a notch / safe area do iPhone
   ============================================================ */
@supports (padding: env(safe-area-inset-top)) {
    @media (max-width: 768px) {
        .top-header {
            padding-top: env(safe-area-inset-top);
        }
        .sidebar {
            padding-top: calc(64px + env(safe-area-inset-top)) !important;
            padding-bottom: env(safe-area-inset-bottom);
        }
        .toast {
            bottom: calc(14px + env(safe-area-inset-bottom)) !important;
        }
        .champion-stack {
            top: calc(56px + env(safe-area-inset-top)) !important;
        }
    }
}

/* ============================================================
   Orientacao paisagem em celular - tabelas mais legiveis
   ============================================================ */
@media (max-width: 900px) and (orientation: landscape) {
    .ranking-triple { grid-template-columns: 1fr 1fr 1fr !important; gap: 8px !important; }
    .live-stats { grid-template-columns: repeat(5, 1fr) !important; }
    .live-actions-grid { grid-template-columns: repeat(3, 1fr) !important; }
    .manual-grid { grid-template-columns: repeat(3, 1fr) !important; }
    .grid-equipes { grid-template-columns: repeat(3, 1fr) !important; }
}

/* ============================================================
   Scrollbars discretas em mobile
   ============================================================ */
@media (max-width: 768px) {
    *::-webkit-scrollbar { width: 4px; height: 4px; }
    *::-webkit-scrollbar-thumb { background: rgba(212,160,23,0.35); border-radius: 4px; }
    *::-webkit-scrollbar-track { background: transparent; }
}

/* ============================================================
   Reduce motion respect
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
