/* 
   ========================================================
   CIRCUITO GOVAUR - PROFESSIONAL MOBILE UI REFIMENENT
   Focus: Cleanliness, Alignment, Readability, Fluidity
   ======================================================== 
*/

@media (max-width: 768px) {
    :root {
        --app-bg: #0F172A;
        --app-card: #1E293B;
        --app-accent: #3B82F6;
        --app-text: #F8FAFC;
        --app-text-muted: #94A3B8;
        --app-radius: 16px;
        --app-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
        --safe-bottom: env(safe-area-inset-bottom, 16px);
        --mobile-margin: 16px;
        --mobile-title-size: 18px;
    }


    /* Reset & Base */
    html, body {
        background-color: var(--app-bg) !important;
        color: var(--app-text);
        font-family: 'Inter', sans-serif;
        overflow-x: hidden;
        -webkit-tap-highlight-color: transparent;
        line-height: 1.5;
        width: 100%;
    }

    img {
        max-width: 100%;
        height: auto;
    }

    /* Hide Desktop Elements */
    .sidebar, .topbar { display: none !important; }

    /* Layout Structure */
    .main-wrapper {
        margin-left: 0 !important;
        width: 100% !important;
        padding-top: 64px; /* Matches mobile-header height */
        padding-bottom: calc(90px + var(--safe-bottom));
        box-sizing: border-box;
        display: block !important;
    }

    .desktop-only { display: none !important; }
    .mobile-only { display: block !important; }
    
    .bottom-nav.mobile-only {
        display: flex !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 64px !important;
        background: #111827 !important;
        border-top: 1px solid rgba(255,255,255,0.05) !important;
        justify-content: space-around !important;
        align-items: center !important;
        z-index: 1000 !important;
        padding-bottom: env(safe-area-inset-bottom, 0) !important;
        box-sizing: border-box !important;
    }
    .mobile-home-cards.mobile-only { display: flex !important; flex-direction: column; gap: 16px; }

    /* === HOME MOBILE: Esconder card inscrição e arrecadação, mostrar caixa atual === */
    #card-inscricao-mobile { display: none !important; }

    #card-caixa-atual-mobile {
        display: flex !important;
        flex-direction: column !important;
        grid-column: 1 / -1 !important;
        background: linear-gradient(145deg, rgba(22, 163, 74, 0.12), rgba(15, 23, 42, 0.9)) !important;
        border: 1px solid rgba(34, 197, 94, 0.2) !important;
    }

    .content-area {
        padding: 16px 16px !important; /* Correct lateral padding */
        margin-left: 0 !important;
        margin-right: 0 !important;
        display: flex;
        flex-direction: column;
        gap: 20px;
        width: 100% !important;
        box-sizing: border-box;
    }

    /* Clean Mobile Header - FIXED to ensure content starts below */
    .mobile-header {
        display: flex !important;
        position: fixed !important;
        top: 0;
        left: 0;
        width: 100% !important;
        z-index: 1000 !important;
        background: #0F172A !important; /* Solid background */
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
        padding: 0 16px;
        height: 64px !important;
        align-items: center;
        gap: 12px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.2);
        box-sizing: border-box;
    }

    .mobile-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 0 16px !important;
        height: 60px !important;
        background: var(--app-card) !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 1000 !important;
    }

    .mobile-header .logo-container {
        display: flex;
        align-items: center;
        gap: 12px;
    }

    .mobile-header img {
        width: 32px;
        height: 32px;
        border-radius: 8px;
        object-fit: contain;
    }

    .mobile-header span {
        font-weight: 700;
        font-size: 16px;
        letter-spacing: -0.3px;
        color: var(--app-text);
    }

    .hamburger-btn {
        display: flex !important;
        color: var(--app-text);
        padding: 8px;
        border-radius: 8px;
        background: rgba(255, 255, 255, 0.03);
    }

    /* Side Drawer Mobile */
    .side-drawer {
        position: fixed !important;
        top: 0 !important;
        right: -280px !important;
        width: 280px !important;
        height: 100% !important;
        background: #0F172A !important;
        z-index: 2000 !important;
        transition: right 0.3s ease !important;
        box-shadow: -4px 0 20px rgba(0,0,0,0.5) !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .side-drawer.active {
        right: 0 !important;
    }

    .drawer-header {
        padding: 20px !important;
        background: var(--app-card) !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        border-bottom: 1px solid rgba(255,255,255,0.05) !important;
    }

    .drawer-items {
        display: flex !important;
        flex-direction: column !important;
        padding: 10px 0 !important;
    }

    .drawer-items a {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        padding: 14px 20px !important;
        color: #F8FAFC !important;
        text-decoration: none !important;
        font-weight: 600 !important;
        font-size: 15px !important;
        transition: background 0.2s !important;
    }

    .drawer-items a:active {
        background: rgba(255,255,255,0.05) !important;
    }

    .drawer-overlay {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background: rgba(0,0,0,0.7) !important;
        z-index: 1999 !important;
        display: none !important;
        backdrop-filter: blur(4px) !important;
    }

    .drawer-overlay.active {
        display: block !important;
    }

    /* Dashboard Layout Fix */
    #view-dashboard {
        display: none; /* JS will change to flex */
        flex-direction: column;
        gap: 20px;
        width: 100%;
    }

    /* Only show when JS sets style.display to block/flex */
    #view-dashboard[style*="display: block"],
    #view-dashboard[style*="display: flex"] {
        display: flex !important;
    }

    /* Stat Cards - All same size in 2 columns */
    .dashboard-stats-container .stats-grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
        width: 100%;
    }

    #view-dashboard #card-arrecadacao {
        background: linear-gradient(145deg, rgba(30, 41, 59, 0.7), rgba(15, 23, 42, 0.8)) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        padding: 14px !important;
        border-radius: 12px !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 6px !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
        margin-top: 0 !important;
        box-sizing: border-box !important;
    }

    #view-dashboard #card-arrecadacao .stat-icon {
        display: block !important;
    }

    /* Professional Card Layout (General) */
    .stat-card {
        background: linear-gradient(145deg, rgba(30, 41, 59, 0.7), rgba(15, 23, 42, 0.8)) !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
        padding: 12px !important; /* Mais fino */
        border-radius: 10px !important;
        display: flex;
        flex-direction: column;
        gap: 4px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
        width: 100% !important;
        box-sizing: border-box;
    }

    .stat-title {
        font-size: 11px !important;
        font-weight: 600 !important;
        color: var(--app-text-muted) !important;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    .stat-value {
        font-size: 20px !important;
        font-weight: 800 !important;
        color: var(--app-text);
        margin: 0;
    }

    .stat-icon {
        background: rgba(255, 255, 255, 0.03);
        padding: 8px;
        border-radius: 10px;
        width: 32px !important;
        height: 32px !important;
        color: var(--app-accent);
        display: flex !important;
        align-items: center;
        justify-content: center;
    }

    /* Ajuste fino nos cards de estatística do financeiro */
    #view-financeiro .stat-card {
        padding: 14px !important;
        height: 100% !important;
        justify-content: space-between !important;
        background: linear-gradient(145deg, rgba(30, 41, 59, 0.7), rgba(15, 23, 42, 0.8)) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
    }

    #view-financeiro .stat-value {
        font-size: 18px !important;
        letter-spacing: -0.5px;
    }

    /* Ranking Dashboard Section */
    .ranking-dashboard-header {
        display: flex !important;
        gap: 8px !important;
        margin: 16px 0 !important;
    }

    .btn-ranking-filter {
        flex: 1 !important;
        height: 40px !important;
        border-radius: 10px !important;
        font-weight: 700 !important;
        font-size: 12px !important;
        border: none !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
    }

    .btn-ranking-masc { background: #3b82f6 !important; color: white !important; }
    .btn-ranking-fem { background: #ec4899 !important; color: white !important; }
    .btn-ranking-filter.inactive { opacity: 0.3 !important; filter: grayscale(1) !important; }

    /* =============================================
       VAQUEIROS - HEADER E BOTÃO (Padrão Etapas)
       ============================================= */

    /* Cabeçalho da aba Vaqueiros - mesmo padrão do Etapas */
    #view-vaqueiros .card-header {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px !important;
        padding-bottom: 16px !important;
        margin-bottom: 0 !important;
        width: 100% !important;
    }

    #view-vaqueiros .card-header h3 {
        font-size: 14px !important;
        margin: 0 !important;
        white-space: nowrap !important;
        color: var(--app-text) !important;
        text-align: left !important;
        width: 100% !important;
    }

    /* Botão "Novo Vaqueiro" - Padrão igual ao "Nova Etapa" */
    #view-vaqueiros #btn-novo-vaqueiro {
        display: flex !important;
        width: 100% !important;
        height: 48px !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        justify-content: center !important;
        align-items: center !important;
        border-radius: 10px !important;
        background: var(--color-blue) !important;
        color: white !important;
        box-sizing: border-box;
        margin: 0 !important;
    }

    /* =============================================
       VAQUEIROS - CARDS MOBILE COMPLETOS
       (Padrão Etapas: Título + Subtitle + Detalhes)
       ============================================= */

    #table-vaqueiros thead { display: none !important; }
    
    #table-vaqueiros tbody {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
    }

    /* Cada vaqueiro = um card */
    #table-vaqueiros tr {
        display: flex !important;
        flex-direction: column !important;
        background: #1E293B !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        border-radius: 12px !important;
        padding: 14px !important;
        margin: 0 !important;
        width: 100% !important;
        box-sizing: border-box !important;
        gap: 0 !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
    }

    /* Título: Avatar + Nome + Subtitle (padrão Etapas) */
    #table-vaqueiros td:first-child {
        display: flex !important;
        align-items: center !important;
        padding: 0 0 10px 0 !important;
        border: none !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
        margin-bottom: 6px !important;
        width: 100% !important;
    }

    #table-vaqueiros .avatar, .avatar-img, .avatar-img-dash, .etapa-logo-mobile {
        width: 40px !important;
        height: 40px !important;
        border-radius: 10px !important;
        margin-right: 12px !important;
        flex-shrink: 0 !important;
        object-fit: cover !important;
    }

    /* Subtitle mobile (código · cidade) - visível apenas no mobile */
    .vaq-mobile-subtitle {
        display: block !important;
    }

    .ranking-pos-mobile {
        display: inline-block !important;
        font-size: 12px !important;
        min-width: 24px !important;
    }

    .substituto-label {
        display: block !important;
        font-size: 10px !important;
        margin-left: 0 !important;
        margin-top: 2px !important;
    }

    /* Código e Cidade - ESCONDIDOS (já estão no subtitle do título) */
    #table-vaqueiros td:nth-child(2),
    #table-vaqueiros td:nth-child(3) {
        display: none !important;
    }

    /* Telefone */
    #table-vaqueiros td:nth-child(4) {
        display: flex !important;
        justify-content: space-between !important;
        padding: 4px 0 !important;
        border: none !important;
        font-size: 12px !important;
        color: var(--app-text) !important;
    }
    #table-vaqueiros td:nth-child(4)::before {
        content: 'Telefone' !important;
        color: var(--app-text-muted) !important;
        font-weight: 500 !important;
        font-size: 12px !important;
    }

    /* Pontuação */
    #table-vaqueiros td:nth-child(5) {
        display: flex !important;
        justify-content: space-between !important;
        padding: 4px 0 !important;
        border: none !important;
        font-size: 13px !important;
        color: var(--color-blue) !important;
        font-weight: 700 !important;
    }
    #table-vaqueiros td:nth-child(5)::before {
        content: 'Pontuação' !important;
        color: var(--app-text-muted) !important;
        font-weight: 500 !important;
        font-size: 12px !important;
    }

    /* Status */
    #table-vaqueiros td:nth-child(6) {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 4px 0 8px 0 !important;
        border: none !important;
        font-size: 12px !important;
    }
    #table-vaqueiros td:nth-child(6)::before {
        content: 'Status' !important;
        color: var(--app-text-muted) !important;
        font-weight: 500 !important;
        font-size: 12px !important;
    }

    /* Ações - Todos os botões alinhados na mesma linha */
    #table-vaqueiros td:last-child {
        display: flex !important;
        flex-direction: row !important;
        gap: 8px !important;
        margin-top: 4px !important;
        padding-top: 10px !important;
        border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
        width: 100% !important;
    }

    #table-vaqueiros td:last-child > div {
        display: flex !important;
        flex-direction: row !important;
        gap: 8px !important;
        width: 100% !important;
    }

    /* Todos os botões: mesma altura, mesmo flex, alinhados */
    #table-vaqueiros .btn,
    #table-vaqueiros .btn-perf,
    #table-vaqueiros .btn-whatsapp-table {
        flex: 1 !important;
        height: 38px !important;
        min-height: 38px !important;
        max-height: 38px !important;
        font-size: 12px !important;
        padding: 0 !important;
        border-radius: 8px !important;
        justify-content: center !important;
        display: flex !important;
        align-items: center !important;
        border: none !important;
        cursor: pointer !important;
        box-sizing: border-box !important;
    }

    /* === RANKING ITEMS (Dashboard) === */

    .ranking-pos-mobile { display: inline-block; }

    .ranking-item {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 10px 8px !important;
        width: 100% !important;
        background: transparent !important;
        border: none !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    }

    .ranking-item .left {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        min-width: 0 !important;
        flex: 1 !important;
    }

    .ranking-item .posicao {
        font-size: 13px !important;
        width: 24px !important;
        color: var(--text-muted) !important;
    }

    .ranking-item .avatar {
        width: 28px !important;
        height: 28px !important;
        border-radius: 50% !important;
        object-fit: cover !important;
    }

    .ranking-item .nome {
        font-size: 13px !important;
        font-weight: 600 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .ranking-item .right {
        margin-left: auto !important;
        text-align: right !important;
    }

    .ranking-item .pontos {
        font-weight: bold !important;
        font-size: 13px !important;
        white-space: nowrap !important;
        color: var(--color-blue) !important;
    }



    /* Financeiro Refined */
    #view-financeiro .stats-grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
        margin-bottom: 20px !important;
    }

    #view-financeiro .stats-grid .stat-card:last-child {
        grid-column: 1 / span 2 !important; /* Saldo ocupa a linha toda */
    }

    /* Novo Lançamento - Padrão Standalone (Igual Etapas/Vaqueiros) */
    #btn-novo-lancamento {
        display: flex !important;
        width: 100% !important;
        height: 48px !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        justify-content: center !important;
        align-items: center !important;
        border-radius: 10px !important;
        background: var(--color-blue) !important;
        color: white !important;
        box-sizing: border-box !important;
        margin: 0 !important;
        border: none !important;
        box-shadow: 0 4px 12px rgba(30, 94, 214, 0.2) !important;
    }
    
    .header-actions-mobile {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        width: 100% !important;
    }

    #btn-novo-lancamento:active {
        transform: scale(0.98) !important;
        box-shadow: 0 2px 8px rgba(37, 99, 235, 0.2) !important;
    }

    #table-financeiro-geral thead { display: none !important; }
    #table-financeiro-geral tbody { display: flex !important; flex-direction: column !important; gap: 10px !important; }

    #table-financeiro-geral tr {
        display: grid !important;
        grid-template-columns: 1fr auto !important; /* Descrição/Data, Valor */
        background: var(--app-card) !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
        border-radius: 12px !important;
        padding: 12px 14px !important;
        gap: 4px !important;
        align-items: center !important;
    }

    #table-financeiro-geral td {
        padding: 0 !important;
        border: none !important;
    }

    #table-financeiro-geral td:first-child {
        display: flex !important;
        flex-direction: column !important;
        gap: 2px !important;
        font-size: 11px !important;
        color: var(--app-text-muted) !important;
    }

    #table-financeiro-geral td:nth-child(3) {
        grid-column: 1 !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        color: var(--app-text) !important;
        margin-top: -2px;
    }

    #table-financeiro-geral td:nth-child(5) {
        font-size: 15px !important;
        font-weight: 800 !important;
        text-align: right !important;
    }

    #table-financeiro-geral td:nth-child(2),
    #table-financeiro-geral td:nth-child(4) {
        display: none !important;
    }

    #table-financeiro-geral td:last-child {
        grid-column: 1 / span 2 !important;
        padding-top: 10px !important;
        margin-top: 8px !important;
        border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
        display: flex !important;
        justify-content: flex-end !important;
    }

    #table-financeiro-geral .btn {
        width: 100% !important;
        justify-content: center !important;
    }

    .fin-header-ref {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px !important;
        padding: 16px !important;
    }

    .fin-select-ref {
        width: 100% !important;
        min-width: 100% !important;
        padding: 10px !important;
        font-size: 14px !important;
        height: 44px !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 8px !important;
        color: white !important;
        margin: 0 !important;
    }



    /* Dashboard Etapas - Lista Compacta */
    #table-dashboard-etapas thead { display: none !important; }
    #table-dashboard-etapas tbody { display: flex !important; flex-direction: column !important; gap: 0 !important; }
    
    #table-dashboard-etapas tr {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 12px 14px !important;
        background: transparent !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        margin: 0 !important;
    }

    #table-dashboard-etapas tr:last-child { border-bottom: none !important; }

    #table-dashboard-etapas td { 
        padding: 0 !important; 
        border: none !important; 
        background: none !important; 
    }

    #table-dashboard-etapas td:first-child {
        flex: 1 !important;
        display: block !important;
    }

    #table-dashboard-etapas td:nth-child(2) { display: none !important; }

    #table-dashboard-etapas td:nth-child(3) {
        text-align: right !important;
        min-width: 100px !important;
    }

    #table-dashboard-etapas td:nth-child(4),
    #table-dashboard-etapas td:nth-child(5) {
        display: none !important;
    }

    .stat-value {
        font-size: 24px !important;
        font-weight: 700 !important;
        color: var(--app-text);
        margin: 0;
    }

    .stat-icon {
        background: rgba(59, 130, 246, 0.1);
        padding: 10px;
        border-radius: 12px;
        width: 40px !important;
        height: 40px !important;
        color: var(--app-accent);
    }

    /* =============================================
       ETAPAS - LISTA COMPACTA E PROFISSIONAL
       ============================================= */

    #view-etapas {
        padding: 0;
        width: 100%;
        box-sizing: border-box;
    }

    #view-etapas .card-container {
        display: flex;
        flex-direction: column;
        width: 100%;
        box-sizing: border-box;
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
    }

    #table-etapas thead {
        display: none !important;
    }

    /* tbody = lista de cards */
    #table-etapas tbody {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        width: 100%;
        padding: 0 !important;
        box-sizing: border-box;
    }

    /* cada tr = 1 card simplificado */
    #table-etapas tr {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
        padding: 12px !important;
        border-radius: 12px !important;
        background: #1E293B !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        box-sizing: border-box;
        gap: 12px !important;
        margin-bottom: 4px !important;
    }

    /* Título */
    #table-etapas td:first-child {
        font-size: 14px !important;
        font-weight: 700 !important;
        color: #F8FAFC !important;
        padding: 0 !important;
        border: none !important;
        width: 100% !important;
        text-align: left !important;
    }

    /* REMOVER: Data, Valor, Senhas conforme solicitado */
    #table-etapas td:nth-child(2),
    #table-etapas td:nth-child(3),
    #table-etapas td:nth-child(4) {
        display: none !important;
    }

    /* Ações (Em linha na parte de baixo) */
    #table-etapas td:last-child {
        display: flex !important;
        flex-direction: row !important;
        gap: 8px !important;
        padding: 8px 0 0 0 !important;
        margin: 0 !important;
        border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
        width: 100% !important;
    }

    #table-etapas td:last-child > div {
        display: flex !important;
        flex-direction: row !important;
        gap: 8px !important;
        width: 100% !important;
    }

    #table-etapas .btn {
        flex: 1 !important;
        height: 38px !important;
        padding: 0 8px !important;
        font-size: 12px !important;
        font-weight: 600 !important;
        justify-content: center !important;
        border-radius: 8px !important;
    }

    #table-etapas .btn-mapa {
        flex: 2 !important; /* Mapa maior para o nome ficar visível */
        background: var(--color-blue) !important;
        color: white !important;
    }

    /* REMOVER: Cabeçalhos de Grupo (Masculinas/Femininas) conforme solicitado */
    #table-etapas tr td[colspan="5"] {
        display: none !important;
    }
    
    /* Ajuste de margem dos botões de categoria para não parecer card extra */
    #view-etapas .ranking-dashboard-header,
    #view-vaqueiros .ranking-dashboard-header {
        margin: 0 0 16px 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }

    /* Cabeçalho da Seção (Título, Filtro e Botão Nova Etapa) */
    #view-etapas .card-header {
        display: flex !important;
        flex-direction: column !important; /* Coluna para empilhar */
        align-items: flex-start !important;
        gap: 12px !important;
        padding-bottom: 20px !important;
        margin-bottom: 0 !important;
        width: 100% !important;
    }

    /* Linha superior: Título e Filtro */
    #view-etapas .card-header > div:first-child {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        width: 100% !important;
        gap: 10px !important;
    }

    #view-etapas .card-header h3 {
        font-size: 14px !important;
        margin: 0 !important;
        white-space: nowrap !important;
        color: var(--app-text) !important;
        text-align: left !important;
        width: 100% !important;
    }

    #view-etapas #filtro-etapas-categoria {
        width: auto !important;
        min-width: 120px !important;
        height: 30px !important;
        font-size: 12px !important;
        margin: 0 !important;
    }

    /* Botões "Nova Etapa" e "Novo Parque" - Padrão Standalone */
    #view-etapas #btn-nova-etapa,
    #view-parques #btn-novo-parque {
        display: flex !important;
        width: 100% !important;
        height: 48px !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        justify-content: center !important;
        align-items: center !important;
        border-radius: 10px !important;
        background: var(--color-blue) !important;
        color: white !important;
        box-sizing: border-box;
        margin: 0 !important; /* Reset margens para não sobrar */
    }

    #view-etapas .table-wrapper {
        width: 100%;
    }

    /* Anti-overflow geral */
    #view-etapas * {
        box-sizing: border-box;
        max-width: 100%;
    }

    /* =============================================
       MAPA DE SENHAS - MOBILE REFINADO
       ============================================= */

    #view-mapa-senhas {
        display: flex;
        flex-direction: column;
        gap: 16px;
        width: 100%;
        box-sizing: border-box;
    }

    /* --- CABEÇALHO COMPACTO --- */
    #view-mapa-senhas > .card-container:first-child {
        background: linear-gradient(135deg, #1E293B, #0F172A) !important;
        border: 1px solid rgba(59, 130, 246, 0.2) !important;
        border-radius: 14px !important;
        padding: 0 !important;
        margin-bottom: 0 !important;
        overflow: hidden;
    }

    #view-mapa-senhas > .card-container:first-child > div {
        padding: 16px !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px !important;
        display: flex !important;
    }

    /* Perfil / Administrador Refined */
    #view-configuracoes .card-container {
        max-width: 100% !important;
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
    }

    .perfil-financeiro-card {
        background: var(--app-card) !important;
        border-radius: 12px !important;
        padding: 16px !important;
        margin-bottom: 20px !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
        box-shadow: var(--app-shadow) !important;
    }

    #view-configuracoes .config-row {
        display: flex !important;
        flex-direction: column !important;
         /* Dashboard Etapas Compact Cards */
    #table-dashboard-etapas thead { display: none !important; }
    #table-dashboard-etapas tbody { display: flex !important; flex-direction: column !important; gap: 0 !important; }

    #table-dashboard-etapas tr {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 12px 14px !important;
        background: transparent !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        margin: 0 !important;
    }

    #table-dashboard-etapas tr:last-child { border-bottom: none !important; }

    #table-dashboard-etapas td { 
        padding: 0 !important; 
        border: none !important; 
        background: none !important; 
    }

    #table-dashboard-etapas td:first-child {
        flex: 1 !important;
        display: block !important;
    }

    #table-dashboard-etapas td:nth-child(2) { display: none !important; } /* Ocultar data para compactar */

    #table-dashboard-etapas td:nth-child(3) {
        text-align: right !important;
        min-width: 100px !important;
    }

    #table-dashboard-etapas td:nth-child(4),
    #table-dashboard-etapas td:nth-child(5) {
        display: none !important;
    }

    #view-configuracoes .config-row {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        padding: 20px 16px !important;
        background: var(--app-card) !important;
        border-radius: 12px !important;
        margin-bottom: 12px !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
    }

    #view-configuracoes .config-row div:first-child {
        width: 100% !important;
    }

    #view-configuracoes .config-row div:last-child {
        width: 100% !important;
        margin: 0 !important;
        display: flex !important;
        gap: 8px !important;
    }

    #view-configuracoes input {
        flex: 1 !important;
        height: 42px !important;
        width: auto !important;
    }

    #view-configuracoes .btn-primary {
        height: 42px !important;
    }

    /* Ocultar cabeçalhos desktop e usar o mobile header */
    #view-configuracoes .card-header {
        display: none !important;
    }

    #view-mapa-senhas .logo-info-container {
        display: flex;
        align-items: center;
        gap: 12px;
        flex: 1;
    }

    #view-mapa-senhas .info-text {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

    /* Linha superior: logo + botão voltar + nome da etapa */
    #view-mapa-senhas > .card-container:first-child > div > div:first-child {
        width: 100% !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 10px !important;
    }

    /* Logo do parque */
    #mapa-parque-logo {
        width: 48px !important;
        height: 48px !important;
        border-radius: 10px !important;
    }

    /* Nome da etapa */
    #mapa-etapa-nome {
        font-size: 17px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
    }

    /* Info do parque */
    .bloco-etapa-info {
        font-size: 12px !important;
        gap: 1px !important;
        color: #94A3B8 !important;
    }

    /* --- CABEÇALHO MAPA REFINADO E COMPACTO --- */
    .mapa-header-container {
        margin-bottom: 32px !important; /* Mais espaço para não colar nos cards abaixo */
    }

    .mapa-header-content {
        padding: 16px !important;
        gap: 16px !important;
    }

    #mapa-parque-logo {
        width: 50px !important;
        height: 50px !important;
        border-radius: 8px !important;
        margin: 0 !important;
    }

    .mapa-header-info {
        width: 100% !important;
    }

    #mapa-etapa-nome {
        font-size: 15px !important; /* Mais compacto para não quebrar */
        font-weight: 800 !important;
    }

    .bloco-etapa-info {
        font-size: 10px !important;
        line-height: 1.2 !important;
        color: var(--text-muted) !important;
    }

    .mapa-header-actions {
        display: flex !important;
        flex-direction: row !important;
        gap: 6px !important;
        width: 100% !important;
        margin-top: 4px !important;
        padding-bottom: 2px !important;
    }

    .mapa-header-actions .btn {
        flex: 1 !important;
        height: 36px !important;
        font-size: 9px !important; /* Ajustado para caber texto longo */
        font-weight: 700 !important;
        padding: 0 4px !important;
        white-space: nowrap !important;
        border-radius: 8px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 3px !important;
    }

    #btn-finalizar-etapa {
        min-width: 0 !important;
    }

    .mapa-header-actions .btn i {
        width: 12px !important;
        height: 12px !important;
    }

    /* --- CARDS DE ESTATÍSTICAS (Espaçamento unificado) --- */
    #view-mapa-senhas .stats-grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        margin-top: 20px !important; /* Aproximado conforme solicitado */
        gap: 16px !important;
        margin-bottom: 16px !important;
    }

    /* Espaçamento entre os blocos de cards (Sincronizado) */
    .stats-grid + .stats-grid {
        margin-top: 16px !important;
    }

    /* Card de Arrecadação (Clone Perfeito da Home - Caixa Atual) */
    #view-mapa-senhas #card-arrecadacao-mapa {
        grid-column: 1 / -1 !important;
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        padding: 16px !important; /* Igual ao da Home */
        background: linear-gradient(145deg, rgba(22, 163, 74, 0.12), rgba(15, 23, 42, 0.9)) !important;
        border: 1px solid rgba(34, 197, 94, 0.2) !important;
        height: auto !important;
        gap: 8px !important;
        box-sizing: border-box !important;
    }

    #view-mapa-senhas #card-arrecadacao-mapa .stat-value {
        font-size: 24px !important; /* Igual ao da Home */
        font-weight: 800 !important;
        color: #22c55e !important;
        width: 100% !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        margin: 0 !important;
    }

    #view-mapa-senhas #card-arrecadacao-mapa .stat-title {
        color: rgba(255, 255, 255, 0.7) !important;
        font-weight: 700 !important;
        margin-bottom: 4px !important;
    }

    #view-mapa-senhas .stats-grid:last-of-type .stat-card .stat-title {
        color: rgba(255, 255, 255, 0.7) !important;
        font-weight: 700 !important;
    }

    #view-mapa-senhas .stat-card {
        padding: 12px 14px !important;
        border-radius: 10px !important;
        background: #1E293B !important;
        border: 1px solid rgba(255, 255, 255, 0.06) !important;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15) !important;
    }

    #view-mapa-senhas .stat-title {
        font-size: 11px !important;
        font-weight: 600 !important;
        color: #64748B !important;
        text-transform: uppercase !important;
        letter-spacing: 0.3px !important;
        margin-bottom: 4px !important;
    }

    #view-mapa-senhas .stat-value {
        font-size: 22px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
    }

    #view-mapa-senhas .stat-icon {
        width: 28px !important;
        height: 28px !important;
        padding: 6px !important;
    }

    /* --- GRID DE SENHAS (5 colunas, margens corretas, min 6 linhas) --- */
    .grid-numeros-container {
        padding: 0 4px !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .grid-senhas,
    .grid-numeros {
        display: grid !important;
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 8px !important;
        width: 100% !important;
        padding: 0 2px !important;
        box-sizing: border-box !important;
    }

    /* Não limitar altura - mostrar pelo menos 6 linhas */
    .grid-senhas:not(.expandido) {
        max-height: none !important;
        overflow: visible !important;
    }

    /* Mostrar 25 números por vez */
    .grid-senhas:not(.expandido) .senha-item:nth-child(n+26) {
        display: none !important;
    }

    .senha-item {
        aspect-ratio: 1;
        border-radius: 8px !important;
        font-size: 14px !important;
        font-weight: 800 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        margin: 0 !important;
    }

    .senha-status {
        font-size: 8px !important;
        text-transform: uppercase;
        font-weight: 600;
        margin-top: 2px;
        opacity: 0.8;
    }

    /* Status disponível menor na legenda */
    .legenda-item {
        display: flex !important;
        align-items: center !important;
        gap: 5px !important;
        font-size: 11px !important;
        font-weight: 500 !important;
    }

    /* --- LISTA DE INSCRIÇÃO (table-reservas-etapa) REFINADA --- */
    #table-reservas-etapa {
        width: 100% !important;
        box-sizing: border-box !important;
    }

    #table-reservas-etapa thead {
        display: none !important;
    }

    #table-reservas-etapa tbody {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        width: 100% !important;
    }

    /* Cada inscrição = card compacto com grid */
    #table-reservas-etapa tr {
        display: grid !important;
        grid-template-columns: 45px 1fr auto !important;
        grid-template-rows: auto auto !important;
        align-items: center !important;
        background: var(--app-card) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        border-radius: 12px !important;
        padding: 10px !important;
        gap: 4px 10px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2) !important;
        margin-bottom: 10px !important;
    }

    /* Senha (número) - coluna 1, linha 1 */
    #table-reservas-etapa td:first-child {
        grid-row: 1 / 2 !important;
        grid-column: 1 / 2 !important;
        font-size: 20px !important;
        font-weight: 900 !important;
        color: var(--color-blue) !important;
        padding: 0 !important;
        border: none !important;
        text-align: center !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: auto !important;
    }

    /* Vaqueiro (nome) - coluna 2, linha 1 */
    #table-reservas-etapa td:nth-child(2) {
        grid-row: 1 / 2 !important;
        grid-column: 2 / 3 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 2px !important;
        padding: 0 !important;
        border: none !important;
        overflow: hidden !important;
        width: auto !important;
    }

    #table-reservas-etapa td:nth-child(2) b {
        font-size: 14px !important;
        font-weight: 700 !important;
        color: white !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #table-reservas-etapa td:nth-child(2) span,
    #table-reservas-etapa td:nth-child(2) small {
        font-size: 11px !important;
        color: var(--app-text-muted) !important;
    }

    /* Status - coluna 3, linha 1 */
    #table-reservas-etapa td:nth-child(3) {
        grid-row: 1 / 2 !important;
        grid-column: 3 / 4 !important;
        display: flex !important;
        justify-content: flex-end !important;
        padding: 0 !important;
        border: none !important;
        width: auto !important;
    }

    /* Estilo para o badge de status dentro da lista */
    #table-reservas-etapa td:nth-child(3) .badge,
    #table-reservas-etapa td:nth-child(3) span {
        font-size: 9px !important;
        padding: 2px 6px !important;
        border-radius: 4px !important;
        text-transform: uppercase !important;
        font-weight: 700 !important;
    }

    /* Ocultar colunas Bois e Pontos no mobile list */
    #table-reservas-etapa td:nth-child(4),
    #table-reservas-etapa td:nth-child(5) {
        display: none !important;
    }

    /* Ações - linha 2, colunas completas */
    #table-reservas-etapa td:last-child {
        grid-row: 2 / 3 !important;
        grid-column: 1 / -1 !important;
        display: flex !important;
        flex-direction: row !important;
        gap: 8px !important;
        margin-top: 8px !important;
        padding-top: 10px !important;
        border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
        width: 100% !important;
    }

    #table-reservas-etapa td:last-child > div {
        display: flex !important;
        flex-direction: row !important;
        gap: 8px !important;
        width: 100% !important;
    }

    #table-reservas-etapa .btn {
        flex: 1 !important;
        height: 38px !important;
        font-size: 12px !important;
        padding: 0 !important;
        border-radius: 10px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
        border: none !important;
    }

    /* Ajuste para o botão Ver Mais */
    .btn-ver-mais {
        width: 100% !important;
        height: 44px !important;
        background: rgba(59, 130, 246, 0.1) !important;
        color: var(--color-blue) !important;
        border: 1px solid rgba(59, 130, 246, 0.2) !important;
        border-radius: 12px !important;
        font-weight: 700 !important;
        font-size: 13px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        margin-top: 10px !important;
        cursor: pointer !important;
    }

    /* Legenda compacta e refinada */
    .legenda {
        display: flex !important;
        gap: 10px !important;
        flex-wrap: wrap !important;
        font-size: 10px !important;
        color: #94A3B8 !important;
        margin-bottom: 14px !important;
        padding: 0 4px !important;
    }

    .legenda-item {
        display: flex !important;
        align-items: center !important;
        gap: 4px !important;
        background: rgba(255, 255, 255, 0.03) !important;
        padding: 4px 8px !important;
        border-radius: 6px !important;
    }

    .legenda-cor {
        width: 8px !important;
        height: 8px !important;
        border-radius: 2px !important;
    }

    /* Anti-overflow */
    #view-mapa-senhas * {
        box-sizing: border-box;
        max-width: 100%;
    }

    /* --- PESQUISA DE VAQUEIROS REFINADA --- */
    .search-container.mobile-only {
        margin-bottom: 16px !important;
    }

    #input-busca-vaqueiros-lista {
        height: 48px !important;
        background: var(--app-card) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 14px !important;
        font-weight: 500 !important;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    }

    /* --- AJUSTES FINAIS DOS BOTÕES DO MAPA --- */
    .mapa-header-actions .btn i {
        width: 12px !important;
        height: 12px !important;
    }

    #btn-finalizar-etapa {
        letter-spacing: -0.2px !important;
    }

    /* --- PADRONIZAÇÃO GERAL SISTEMA (MOBILE) --- */
    :root {
        --mobile-margin: 16px;
        --mobile-title-size: 16px;
        --mobile-radius: 12px;
    }

    .card-container {
        margin-bottom: var(--mobile-margin) !important;
        border-radius: var(--mobile-radius) !important;
        padding: 0 !important; /* Deixa o padding para o conteúdo interno */
        overflow: hidden !important;
    }

    .card-header {
        padding: 12px var(--mobile-margin) !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important; /* Título esquerda, Botão direita */
        gap: 12px !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        min-height: 50px !important;
        margin-bottom: 16px !important; /* Espaço global após cabeçalho */
    }

    /* Títulos Padronizados (Sincronização Absoluta) */
    #view-etapas .card-header h3,
    #view-parques .card-header h3,
    #view-vaqueiros .card-header h3,
    #mapa-etapa-nome {
        font-size: 18px !important;
        font-weight: 800 !important;
        text-align: left !important;
        margin: 0 !important;
        color: white !important;
        letter-spacing: -0.3px !important;
    }

    /* Cabeçalhos em Coluna (Título acima, Botão abaixo) */
    .header-column-mobile {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px !important;
        padding: 16px var(--mobile-margin) !important;
    }

    .header-column-mobile h3 {
        width: 100% !important;
    }

    .btn-full-mobile {
        width: 100% !important;
        height: 44px !important;
        justify-content: center !important;
        font-size: 13px !important;
        font-weight: 800 !important;
        text-transform: uppercase !important;
        border-radius: 10px !important;
        margin: 0 !important;
    }

    /* Imagens Padronizadas (Avatares / Logos em Listas) */
    .avatar-img {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        max-width: 32px !important;
        border-radius: 50% !important;
        object-fit: cover !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        background: var(--bg-main) !important;
        flex-shrink: 0 !important;
        margin-right: 12px !important;
    }

    /* Logos de Parques (Quadradas com borda arredondada) */
    #mapa-parque-logo, .parque-logo-lista {
        width: 50px !important;
        height: 50px !important;
        border-radius: 8px !important;
        margin: 0 !important;
    }

    /* Espaçamento Consistente */
    .stats-grid {
        gap: 12px !important;
        margin-bottom: var(--mobile-margin) !important;
    }

    .content-area {
        padding: var(--mobile-margin) !important;
    }

    /* Alinhamento de Textos nas Listas */
    .vaqueiro-info, .parque-info {
        display: flex !important;
        flex-direction: column !important;
        gap: 2px !important;
        text-align: left !important;
    }

    .etapa-info-cell {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 12px !important;
        text-align: left !important;
    }

    .etapa-info {
        display: flex !important;
        flex-direction: column !important;
        gap: 2px !important;
    }

    .vaqueiro-name, .etapa-name, .parque-name {
        font-size: 14px !important;
        font-weight: 700 !important;
    }

    .vaqueiro-details, .etapa-details, .parque-details {
        font-size: 11px !important;
        color: var(--text-muted) !important;
    }

    /* List Transformation (Other tables remain 1 column) */
    .table-wrapper {
        overflow: visible;
        width: 100%;
        padding: var(--mobile-margin) !important;
        box-sizing: border-box !important;
    }

    #table-dashboard-etapas, #table-vaqueiros, #table-parques, #table-etapas {
        display: flex;
        flex-direction: column;
        gap: 12px;
        width: 100%;
    }

    thead { display: none !important; }
    tbody { display: flex; flex-direction: column; gap: 12px; width: 100%; padding-bottom: 8px; }

    tr {
        display: flex !important;
        flex-direction: column;
        background: var(--app-card) !important;
        padding: 16px !important;
        border-radius: var(--app-radius) !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
        box-shadow: var(--app-shadow);
        width: 100%;
        box-sizing: border-box;
    }

    /* ── Ranking: RESET forçado (sobrepõe regra genérica de tr) ── */
    #table-dashboard-ranking tr,
    #table-dashboard-ranking tbody tr {
        background: transparent !important;
        border: none !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
        gap: 0 !important;
    }

    #table-dashboard-ranking tbody {
        gap: 0 !important;
    }

    td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 6px 0 !important;
        font-size: 14px !important;
        color: var(--app-text-muted) !important;
        border: none !important;
        width: 100%;
    }

    td:first-child {
        font-size: 16px !important;
        font-weight: 700 !important;
        color: var(--app-text) !important;
        padding: 0 0 10px 0 !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        margin-bottom: 8px !important;
    }

    /* Actions Alignment - Horizontal Row */
    td:last-child {
        margin-top: 10px !important;
        padding-top: 12px !important;
        border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
        display: flex !important;
        flex-direction: row !important; /* Obrigatoriamente em linha */
        gap: 8px !important;
        justify-content: flex-start !important;
        width: 100% !important;
    }

    #table-vaqueiros td:last-child .btn {
        flex: 1 !important; /* Mesma largura */
        height: 38px !important;
        margin-top: 0 !important;
        font-size: 11px !important;
    }

    .btn-whatsapp-table {
        background: rgba(37, 211, 102, 0.1) !important;
        color: #25D366 !important;
    }

    /* Professional Buttons */
    .btn, .btn-primary {
        height: 46px !important;
        border-radius: 12px !important;
        font-weight: 600 !important;
        padding: 0 16px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 14px !important;
        width: auto !important;
    }

    .stat-card .btn, tr .btn { width: 100% !important; margin-top: 8px; }

    .btn-primary {
        background: var(--app-accent) !important;
        color: #fff !important;
    }

    /* --- FILTROS DE CATEGORIA EM BOTÕES --- */
    .category-buttons-row {
        width: 100% !important;
        overflow-x: auto !important;
        padding-bottom: 4px !important;
        -webkit-overflow-scrolling: touch;
    }

    .btn-category {
        flex: 1 !important;
        height: 40px !important;
        background: rgba(255, 255, 255, 0.03) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        color: var(--text-muted) !important;
        font-size: 12px !important;
        font-weight: 600 !important;
        border-radius: 10px !important;
        white-space: nowrap !important;
        transition: all 0.2s ease !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .btn-category.active {
        background: var(--color-blue) !important;
        border-color: var(--color-blue) !important;
        color: white !important;
        box-shadow: 0 4px 12px rgba(30, 94, 214, 0.3) !important;
    }

    /* Balanced Bottom Navigation */
    .bottom-nav {
        display: flex !important;
        background: #111827 !important;
        border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
        height: 80px !important; /* Safe fallback */
        padding-top: 4px !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
        padding-bottom: 16px !important; /* Safe fallback */
        padding-bottom: env(safe-area-inset-bottom, 16px) !important; /* Modern support */
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 2000 !important;
        justify-content: space-around !important;
        align-items: center !important;
        box-shadow: 0 -4px 12px rgba(0,0,0,0.3) !important;
    }

    .bottom-nav-item {
        display: flex !important;
        flex-direction: column;
        align-items: center;
        gap: 2px;
        color: var(--app-text-muted);
        text-decoration: none;
        font-size: 11px;
        font-weight: 500;
        flex: 1;
        padding: 8px 0;
    }

    .bottom-nav-item i {
        width: 22px !important;
        height: 22px !important;
    }

    .bottom-nav-item.active {
        color: var(--app-accent) !important;
    }

    /* Optimized Modals */
    .modal {
        display: none;
        align-items: center !important; /* Back to center for professional feel */
        justify-content: center !important;
        padding: 16px !important;
    }

    .modal-content, .modal-conteudo {
        width: 100% !important;
        max-width: 400px !important;
        border-radius: 16px !important;
        background: var(--app-card) !important;
        padding: 24px !important;
        max-height: 90vh !important;
        overflow-y: auto !important;
        position: relative;
        animation: fadeIn 0.2s ease-out;
    }

    /* Clear Typography & Spacing */
    h2, h3 { line-height: 1.3; margin-bottom: 8px; }
    p { font-size: 14px; color: var(--app-text-muted); }

    /* Forms */
    .form-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
    
    input, select, textarea {
        height: 48px !important;
        background: var(--app-bg) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 10px !important;
        padding: 0 14px !important;
        font-size: 15px !important;
    }

    /* Numeric Map Grid (Keep functional) */
    .grid-senhas, .grid-numeros {
        display: grid !important;
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 8px !important;
    }

    .senha-item {
        aspect-ratio: 1;
        border-radius: 8px !important;
        font-size: 15px !important;
    }

    .ranking-pos-mobile, .substituto-label { display: inline-block !important; }

    /* Botões de Ação do Vaqueiro (Compactos) */
    .vaqueiro-actions-row {
        gap: 4px !important;
    }
    .vaqueiro-actions-row .btn {
        padding: 5px !important;
        min-width: 30px !important;
        height: 30px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 8px !important;
    }
    .vaqueiro-actions-row .btn i, 
    .vaqueiro-actions-row .btn svg {
        width: 14px !important;
        height: 14px !important;
    }

    /* Barra de Pesquisa Refinada (Mobile) */
    .search-container {
        margin-bottom: 20px !important;
        padding: 0 4px !important;
    }
    
    .search-wrapper {
        position: relative !important;
        width: 100% !important;
    }
    
    .search-icon {
        position: absolute !important;
        left: 14px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        width: 16px !important;
        height: 16px !important;
        color: var(--app-text-muted) !important;
        opacity: 0.7;
        pointer-events: none;
    }
    
    .search-input {
        width: 100% !important;
        padding: 12px 14px 12px 42px !important;
        background: rgba(255, 255, 255, 0.04) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        border-radius: 12px !important;
        color: white !important;
        font-size: 14px !important;
        height: 44px !important;
        transition: all 0.2s ease;
    }
    
    ::-webkit-scrollbar { width: 0; }
}

@keyframes fadeIn {
    from { opacity: 0; transform: scale(0.98); }
    to { opacity: 1; transform: scale(1); }
}

/* Ranking Dashboard (Sincronização Absoluta) */
.ranking-container {
    margin-top: 30px !important;
}

.ranking-item {
    background: var(--app-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.05) !important;
    border-radius: 12px !important;
    padding: 8px 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 8px !important;
    transition: transform 0.2s ease;
}

.avatar-img, .avatar-img-dash {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    border: 2px solid rgba(255, 255, 255, 0.1) !important;
}

.rank-number {
    font-size: 16px !important;
    font-weight: 800 !important;
    width: 24px !important;
    text-align: center !important;
    color: var(--app-text-muted) !important;
}

.rank-1 { color: #FACC15 !important; font-size: 20px !important; }
.rank-2 { color: #E2E8F0 !important; }
.rank-3 { color: #CD7F32 !important; }

.vaqueiro-info { flex: 1 !important; }
.vaqueiro-name { font-size: 14px !important; font-weight: 700 !important; color: var(--app-text) !important; }
.vaqueiro-details { font-size: 11px !important; color: var(--app-text-muted) !important; }

.vaqueiro-points { text-align: right !important; }
.points-value { font-size: 18px !important; font-weight: 800 !important; color: var(--color-blue) !important; }
.points-label { font-size: 9px !important; text-transform: uppercase !important; font-weight: 600 !important; color: var(--app-text-muted) !important; }
