/* ========================================
   CORREÇÃO DE EMERGÊNCIA PARA CATEGORIAS MOBILE
   Garantir que texto seja visível e botões não fiquem pretos
   ======================================== */

/* Forçar fundo branco em todos os estados */
.category-item-mobile,
.category-item-mobile:hover,
.category-item-mobile:active,
.category-item-mobile:focus,
.category-item-mobile:visited {
    background: #ffffff !important;
    background-color: #ffffff !important;
    background-image: none !important;
    background-gradient: none !important;
}

/* Forçar texto visível */
.category-text-mobile,
.category-item-mobile .category-text-mobile,
.category-item-mobile:hover .category-text-mobile,
.category-item-mobile:active .category-text-mobile,
.category-item-mobile:focus .category-text-mobile {
    color: #374151 !important;
    text-shadow: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
}

/* Garantir que o container não tenha overflow hidden */
.categories-grid-mobile {
    overflow: visible !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
}

.category-item-mobile {
    overflow: visible !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
}

/* Garantir altura mínima para o texto */
.category-item-mobile {
    min-height: 90px !important;
    padding: 0.5rem 0.25rem !important;
}

/* Garantir que o texto tenha espaço suficiente */
.category-text-mobile {
    min-height: 1.5rem !important;
    max-height: 3rem !important;
    padding: 0.25rem 0.125rem !important;
    line-height: 1.2 !important;
    overflow: visible !important;
    white-space: normal !important;
    word-wrap: break-word !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
}

/* Correção para telas muito pequenas */
@media (max-width: 360px) {
    .category-item-mobile {
        min-height: 80px !important;
        padding: 0.375rem 0.125rem !important;
    }
    
    .category-text-mobile {
        font-size: 0.55rem !important;
        min-height: 1.2rem !important;
        max-height: 2.4rem !important;
        padding: 0.125rem 0.0625rem !important;
    }
}

/* Correção para telas pequenas */
@media (max-width: 480px) {
    .category-item-mobile {
        min-height: 85px !important;
        padding: 0.5rem 0.25rem !important;
    }
    
    .category-text-mobile {
        font-size: 0.6rem !important;
        min-height: 1.3rem !important;
        max-height: 2.6rem !important;
        padding: 0.125rem 0.125rem !important;
    }
}

/* Override de qualquer estilo conflitante do Tailwind */
.categories-grid-mobile .category-item-mobile {
    background: #ffffff !important;
    color: #374151 !important;
}

.categories-grid-mobile .category-item-mobile * {
    color: inherit !important;
}

.categories-grid-mobile .category-text-mobile {
    color: #374151 !important;
}

/* Garantir que ícones não quebrem o layout */
.category-icon-mobile {
    max-width: 32px !important;
    max-height: 32px !important;
    flex-shrink: 0 !important;
}

/* Correção para problemas de flexbox */
.category-item-mobile {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex: 1 1 auto !important;
}

/* Garantir que não haja problemas de z-index */
.category-item-mobile {
    position: relative !important;
    z-index: 1 !important;
}

.category-text-mobile {
    position: relative !important;
    z-index: 2 !important;
}

/* CORREÇÃO ESPECÍFICA: Evitar quebra de palavras únicas */
.category-text-mobile {
    /* Permitir quebra apenas entre palavras, nunca dentro de uma palavra */
    word-break: normal !important;
    overflow-wrap: break-word !important;
    word-wrap: break-word !important;
    
    /* Usar hifenização inteligente apenas para palavras muito longas */
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -moz-hyphens: auto !important;
    -ms-hyphens: auto !important;
    
    /* Garantir que o texto se ajuste sem quebrar palavras individuais */
    white-space: normal !important;
    
    /* Permitir que o texto use o espaço disponível */
    max-width: 100% !important;
    width: 100% !important;
}

/* Regra especial para palavras muito longas (mais de 15 caracteres) */
.category-text-mobile.text-long {
    /* Para palavras extremamente longas, permitir quebra apenas se necessário */
    word-break: break-word !important;
    font-size: 0.6rem !important;
    line-height: 1.1 !important;
}

/* Regra para palavras médias (8-15 caracteres) */
.category-text-mobile.text-medium {
    font-size: 0.62rem !important;
    line-height: 1.15 !important;
}

/* Regra para palavras curtas (até 8 caracteres) */
.category-text-mobile.text-short {
    font-size: 0.65rem !important;
    line-height: 1.2 !important;
}
