/* ============================================================================
 * Cursos Rateio — Search Premium CSS
 * ============================================================================
 * Página de busca moderna, mobile-first, alinhada ao design system do porto-child
 *
 * Cores (alinhadas ao Color Plan de Abril 2026):
 *   CTA/Price: #1D4ED8  |  Info: #475569  |  Success: #059669  |  Urgency: #DC2626
 * ============================================================================ */

/* Reset local */
.cr-busca-page, .cr-busca-page * { box-sizing: border-box; }
.cr-busca-page a { text-decoration: none; color: inherit; }
.cr-busca-page ul { list-style: none; margin: 0; padding: 0; }
.cr-busca-page h1, .cr-busca-page h2, .cr-busca-page h3, .cr-busca-page p { margin: 0; padding: 0; }

/* Container principal */
.cr-busca-page {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    max-width: 1280px;
    margin: 0 auto;
    padding: 24px 16px 80px;
    color: #0f172a;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}
@media (min-width: 768px) {
    .cr-busca-page { padding: 40px 24px 80px; }
}

/* ============================================
   HERO
   ============================================ */
.cr-hero {
    margin-bottom: 24px;
    animation: crFadeUp 0.4s ease both;
}
.cr-hero__title {
    font-family: 'DM Serif Display', Georgia, serif;
    font-size: 1.75rem;
    font-weight: 400;
    color: #0f172a;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-bottom: 8px !important;
}
.cr-hero__title strong {
    color: #1D4ED8;
    font-weight: 400;
}
.cr-hero__subtitle {
    font-size: 0.95rem;
    color: #64748b;
}
.cr-hero__subtitle strong { color: #0f172a; font-weight: 700; }
.cr-hero__time { color: #94a3b8; font-size: 0.85rem; margin-left: 6px; }

@media (min-width: 768px) {
    .cr-hero__title { font-size: 2.5rem; }
    .cr-hero__subtitle { font-size: 1.05rem; }
}

/* ============================================
   FILTROS
   ============================================ */
.cr-filtros {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 24px;
    animation: crFadeUp 0.4s 0.05s ease both;
}
.cr-filtros__main {
    display: flex;
    gap: 8px;
    align-items: stretch;
}
.cr-filtros__search {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}
.cr-filtros__search-icon {
    position: absolute;
    left: 14px;
    color: #94a3b8;
    pointer-events: none;
}
.cr-filtros__input {
    width: 100%;
    padding: 12px 40px 12px 44px;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    background: #fff !important;
    font-size: 1rem !important;
    color: #0f172a !important;
    font-weight: 500 !important;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    -webkit-text-fill-color: #0f172a;
}
.cr-filtros__input::placeholder { color: #94a3b8 !important; font-weight: 400 !important; }
.cr-filtros__input:focus {
    border-color: #1D4ED8;
    box-shadow: 0 0 0 3px rgba(29, 78, 216, 0.1);
}
.cr-filtros__clear {
    position: absolute;
    right: 12px;
    background: #e2e8f0;
    border: none;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    color: #475569;
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cr-filtros__clear:hover { background: #cbd5e1; }

.cr-filtros__toggle {
    padding: 0 16px;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    background: #fff;
    color: #475569;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
    position: relative;
    transition: border-color 0.2s;
}
.cr-filtros__toggle:hover { border-color: #1D4ED8; color: #1D4ED8; }
.cr-filtros__toggle span:not(.cr-filtros__badge) { display: none; }
@media (min-width: 640px) {
    .cr-filtros__toggle span { display: inline; }
}
.cr-filtros__badge {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 8px;
    height: 8px;
    background: #DC2626;
    border-radius: 50%;
}

.cr-filtros__submit {
    padding: 0 20px;
    border: none;
    border-radius: 12px;
    background: #1D4ED8;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s, transform 0.1s;
}
.cr-filtros__submit:hover { background: #1E40AF; }
.cr-filtros__submit:active { transform: scale(0.98); }

/* Painel de filtros */
.cr-filtros__panel {
    display: none;
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #e2e8f0;
}
.cr-filtros__panel--open { display: grid; }
@media (min-width: 768px) {
    .cr-filtros__panel { grid-template-columns: repeat(4, 1fr) auto; align-items: end; }
}

.cr-filtro label {
    display: block;
    font-size: 0.78rem;
    font-weight: 700;
    color: #475569;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 6px;
}
.cr-filtro select,
.cr-filtro input[type="number"] {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #cbd5e1;
    border-radius: 10px;
    background: #fff;
    font-size: 0.9rem;
    color: #0f172a;
    outline: none;
    transition: border-color 0.2s;
    font-family: inherit;
}
.cr-filtro select:focus,
.cr-filtro input:focus { border-color: #1D4ED8; }

.cr-filtro__preco-row {
    display: flex;
    align-items: center;
    gap: 6px;
}
.cr-filtro__preco-row span { color: #94a3b8; }

.cr-filtros__actions {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
}
.cr-filtros__reset {
    color: #DC2626;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 8px 12px;
    border-radius: 8px;
    transition: background 0.2s;
}
.cr-filtros__reset:hover { background: rgba(220, 38, 38, 0.08); }
.cr-filtros__apply {
    padding: 10px 20px;
    border: none;
    border-radius: 10px;
    background: #059669;
    color: #fff;
    font-weight: 700;
    cursor: pointer;
    font-size: 0.9rem;
}
.cr-filtros__apply:hover { background: #047857; }

/* ============================================
   LAYOUT (grid + sidebar)
   ============================================ */
.cr-busca-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 1024px) {
    .cr-busca-layout { grid-template-columns: 1fr 320px; }
}

/* ============================================
   PAGINAÇÃO
   ============================================ */
.cr-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 40px;
    padding: 24px 0;
}
.cr-pagination__btn, .cr-pagination__num {
    min-width: 40px;
    height: 40px;
    padding: 0 14px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #fff;
    color: #475569;
    font-size: 0.9rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}
.cr-pagination__btn:hover, .cr-pagination__num:hover {
    border-color: #1D4ED8;
    color: #1D4ED8;
}
.cr-pagination__num--active {
    background: #1D4ED8;
    border-color: #1D4ED8;
    color: #fff;
    pointer-events: none;
}
.cr-pagination__ellipsis {
    color: #94a3b8;
    padding: 0 4px;
}
.cr-pagination__numbers {
    display: flex;
    gap: 4px;
}

/* ============================================
   SIDEBAR WIDGETS
   ============================================ */
.cr-busca-sidebar {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.cr-widget {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 20px;
}
.cr-widget__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 4px !important;
    display: flex;
    align-items: center;
    gap: 6px;
}
.cr-widget__subtitle {
    font-size: 0.82rem;
    color: #64748b;
    margin-bottom: 16px !important;
}

/* Widget: Bestsellers */
.cr-widget--hot { background: linear-gradient(135deg, #fff7ed, #fff); border-color: #fed7aa; }
.cr-widget__list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.cr-widget__item {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 8px;
    border-radius: 10px;
    transition: background 0.2s;
}
.cr-widget__item:hover { background: rgba(29, 78, 216, 0.05); }
.cr-widget__rank {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #1D4ED8;
    color: #fff;
    font-weight: 800;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cr-widget__item:nth-child(1) .cr-widget__rank { background: #f59e0b; }
.cr-widget__item:nth-child(2) .cr-widget__rank { background: #94a3b8; }
.cr-widget__item:nth-child(3) .cr-widget__rank { background: #b45309; }
.cr-widget__link { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cr-widget__name {
    font-size: 0.82rem;
    font-weight: 600;
    color: #0f172a;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.cr-widget__meta {
    font-size: 0.72rem;
    color: #64748b;
}

/* Widget: Categorias */
.cr-widget__cats { display: flex; flex-direction: column; gap: 2px; }
.cr-widget__cat a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border-radius: 8px;
    transition: background 0.2s;
}
.cr-widget__cat a:hover { background: #f1f5f9; color: #1D4ED8; }
.cr-widget__cat-name { font-size: 0.9rem; font-weight: 500; }
.cr-widget__cat-count {
    background: #f1f5f9;
    color: #64748b;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
}

/* Widget: WhatsApp */
.cr-widget--whatsapp {
    background: linear-gradient(135deg, #059669, #047857);
    color: #fff;
    border: none;
    text-align: center;
}
.cr-widget--whatsapp .cr-widget__title { color: #fff; justify-content: center; }
.cr-widget--whatsapp .cr-widget__subtitle { color: rgba(255,255,255,0.85); }
.cr-widget__wa-icon { font-size: 2rem; margin-bottom: 8px; }
.cr-widget__wa-btn {
    display: inline-block;
    background: #fff;
    color: #059669;
    padding: 10px 20px;
    border-radius: 10px;
    font-weight: 700;
    font-size: 0.9rem;
    margin-top: 12px;
    transition: transform 0.1s;
}
.cr-widget__wa-btn:hover { transform: scale(1.03); }

/* ============================================
   EMPTY STATE
   ============================================ */
.cr-empty {
    text-align: center;
    padding: 40px 20px;
    animation: crFadeUp 0.4s ease both;
}
.cr-empty__icon { font-size: 3rem; margin-bottom: 16px; }
.cr-empty__title {
    font-family: 'DM Serif Display', Georgia, serif;
    font-size: 1.75rem;
    font-weight: 400;
    color: #0f172a;
    margin-bottom: 8px !important;
}
.cr-empty__message {
    color: #64748b;
    font-size: 1rem;
    max-width: 500px;
    margin: 0 auto 32px !important;
}
.cr-empty__subtitle {
    font-size: 1.1rem;
    font-weight: 700;
    color: #0f172a;
    margin: 32px 0 16px !important;
}
.cr-empty__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    margin-bottom: 24px;
}
.cr-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 600;
    color: #475569;
    transition: all 0.2s;
}
.cr-chip:hover { border-color: #1D4ED8; color: #1D4ED8; }
.cr-chip__count {
    background: #f1f5f9;
    color: #64748b;
    font-size: 0.72rem;
    padding: 1px 6px;
    border-radius: 999px;
    font-weight: 700;
}
.cr-empty__products { margin: 32px 0; text-align: left; }
.cr-empty__whatsapp {
    margin-top: 40px;
    padding: 24px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 14px;
}
.cr-empty__whatsapp p { color: #065f46; margin-bottom: 12px !important; }
.cr-btn-whatsapp {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #059669;
    color: #fff;
    padding: 12px 24px;
    border-radius: 10px;
    font-weight: 700;
    font-size: 0.95rem;
}
.cr-btn-whatsapp:hover { background: #047857; color: #fff; }

/* ============================================
   ANIMAÇÕES
   ============================================ */
@keyframes crFadeUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ============================================
   MOBILE ESPECÍFICO
   ============================================ */
@media (max-width: 767px) {
    .cr-filtros__panel {
        position: fixed;
        inset: auto 0 0 0;
        background: #fff;
        padding: 20px;
        border-radius: 20px 20px 0 0;
        box-shadow: 0 -20px 60px -20px rgba(0,0,0,0.2);
        z-index: 99;
        max-height: 80vh;
        overflow-y: auto;
        grid-template-columns: 1fr !important;
        transform: translateY(100%);
        transition: transform 0.3s ease;
        display: grid;
    }
    .cr-filtros__panel--open {
        transform: translateY(0);
    }
    .cr-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .cr-card__title { font-size: 0.78rem; min-height: 3em; }
    .cr-card__price { font-size: 0.95rem; }
    .cr-pagination__btn, .cr-pagination__num {
        min-width: 36px; height: 36px; padding: 0 10px; font-size: 0.85rem;
    }
}
/* ============================================================================
 * CARD V2 — substitui seção antiga. Inspirado no card "Você pode gostar".
 * Header escuro + preço destacado + CTA azul sólido.
 * ============================================================================ */

/* Grid: 1 col mobile, 2 cols tablet+, 3 cols desktop */
.cr-cards-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    animation: crFadeUp 0.5s 0.1s ease both;
}
@media (min-width: 500px) {
    .cr-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (min-width: 1024px) {
    .cr-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
@media (min-width: 1280px) {
    .cr-cards-grid { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}

/* Card principal */
.cr-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    transition: all 0.2s ease;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.cr-card:hover {
    border-color: #1D4ED8;
    box-shadow: 0 4px 12px -4px rgba(29, 78, 216, 0.15);
}
/* Isolation garante que cada card tem seu proprio stacking context */
.cr-cards-grid { position: relative; isolation: isolate; }
.cr-card { position: relative; isolation: isolate; }

/* HEADER ESCURO */
.cr-card__header {
    background: #0f172a;
    color: #fff;
    padding: 10px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    line-height: 1.2;
}
.cr-card__editora {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #fff;
}
.cr-card__ano {
    background: rgba(255, 255, 255, 0.12);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.7rem;
    color: #fff;
    flex-shrink: 0;
}

/* CORPO */
.cr-card__body {
    padding: 14px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    color: inherit;
    text-decoration: none;
}
.cr-card__body:hover { text-decoration: none; }

/* Badge (PRÉ-EDITAL / PÓS-EDITAL) */
.cr-card__badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    align-self: flex-start;
    background: #1f2937;
    color: #fff;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    line-height: 1;
}
.cr-card__badge-icon {
    flex-shrink: 0;
}
.cr-card__badge--pos-edital {
    background: #DC2626;
}
.cr-card__badge--trending {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
}

/* Título */
.cr-card__title {
    font-size: 0.9rem;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 3.8em;
    margin: 0;
}

/* FOOTER (preço + CTA) */
.cr-card__footer {
    padding: 12px 14px;
    border-top: 1px solid #f1f5f9;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: #fafbfc;
}
.cr-card__price-block {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1px;
    min-width: 0;
}
.cr-card__price {
    font-size: 1.25rem;
    font-weight: 800;
    color: #1D4ED8;
    letter-spacing: -0.02em;
    line-height: 1.1;
}
.cr-card__price--free { color: #059669; }
.cr-card__price-old {
    font-size: 0.72rem;
    color: #94a3b8;
    text-decoration: line-through;
    line-height: 1;
}
.cr-card__discount {
    font-size: 0.68rem;
    background: #059669;
    color: #fff;
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: 700;
    margin-top: 2px;
}

/* CTA (botão "Ver curso" azul) */
.cr-card__cta {
    background: #1D4ED8;
    color: #fff !important;
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 700;
    white-space: nowrap;
    text-decoration: none;
    transition: background 0.2s;
    flex-shrink: 0;
}
.cr-card__cta:hover {
    background: #1E40AF;
    color: #fff !important;
    text-decoration: none;
}

/* ============================================
   OVERRIDES de cards antigos (remove imagem se houver)
   ============================================ */
.cr-card__image-wrap { display: none !important; }

/* Ajusta cards menores em mobile */
@media (max-width: 499px) {
    .cr-card__header {
        padding: 8px 12px;
        font-size: 0.68rem;
    }
    .cr-card__ano { font-size: 0.65rem; padding: 2px 6px; }
    .cr-card__body { padding: 12px; gap: 8px; }
    .cr-card__title {
        font-size: 0.85rem;
        -webkit-line-clamp: 2;
        min-height: 2.6em;
    }
    .cr-card__footer { padding: 10px 12px; }
    .cr-card__price { font-size: 1.1rem; }
    .cr-card__cta {
        padding: 7px 12px;
        font-size: 0.75rem;
    }
}

/* ============================================================================
 * FIXES — problemas descobertos no teste visual 18/04/2026
 * ============================================================================ */

/* FIX 1: Cards com fundo opaco garantido (sem transparência) */
.cr-card {
    position: relative;
    z-index: 1;
    background: #fff !important;
    isolation: isolate;
}

/* FIX 2: :hover só em dispositivos com mouse (não grudar no mobile) */
@media (hover: none) {
    .cr-card:hover {
        border-color: #e5e7eb !important;
        transform: none !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
    }
}
@media (hover: hover) {
    .cr-card:active {
        transform: translateY(0);
    }
}

/* FIX 3: Input de busca com cor de texto forte */
.cr-filtros__input {
    color: #0f172a !important;
    -webkit-text-fill-color: #0f172a !important;
    font-weight: 500 !important;
    opacity: 1 !important;
}
.cr-filtros__input::placeholder {
    color: #94a3b8 !important;
    -webkit-text-fill-color: #94a3b8 !important;
    font-weight: 400 !important;
    opacity: 1 !important;
}

/* FIX 4: Garantir espaço vertical entre cards (sem overlap) */
.cr-cards-grid {
    position: relative;
    z-index: 1;
}


/* ============================================================================
 * CARD V3 — VERSAO FINAL LIMPA (sem clip-path, sem overflow hidden, sem trick)
 * Cada parte se desenha sozinha com suas proprias bordas e radius.
 * O container article eh 100% transparente.
 * ============================================================================ */

/* Container article: INVISIVEL, so serve como flex parent */
.cr-busca-page article.cr-card {
    all: unset !important;
    display: flex !important;
    flex-direction: column !important;
    box-sizing: border-box !important;
}

/* Header escuro - com cantos arredondados SUPERIORES */
.cr-busca-page .cr-card__header {
    background-color: #0f172a !important;
    color: #ffffff !important;
    padding: 10px 14px !important;
    border-radius: 12px 12px 0 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    border: 1px solid #0f172a !important;
    border-bottom: none !important;
}

/* Body branco - centro */
.cr-busca-page .cr-card__body {
    background-color: #ffffff !important;
    padding: 14px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin: 0 !important;
    border-left: 1px solid #e5e7eb !important;
    border-right: 1px solid #e5e7eb !important;
    border-top: none !important;
    border-bottom: none !important;
    border-radius: 0 !important;
    color: inherit !important;
    text-decoration: none !important;
    flex: 1 !important;
}

/* Footer com cantos arredondados INFERIORES */
.cr-busca-page .cr-card__footer {
    background-color: #fafbfc !important;
    padding: 12px 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin: 0 !important;
    border: 1px solid #e5e7eb !important;
    border-top: 1px solid #f1f5f9 !important;
    border-radius: 0 0 12px 12px !important;
}

/* Box shadow SUAVE aplicada ao conjunto (via filter no article) */
.cr-busca-page article.cr-card {
    filter: drop-shadow(0 1px 3px rgba(0,0,0,0.04)) !important;
}

/* Reset do wrapper Porto que envolve a pagina */
article.hentry.page,
article.post-94675 {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
article.hentry.page > .entry-title,
article.post-94675 > .entry-title,
article.hentry.page > .vcard,
article.post-94675 > .vcard {
    display: none !important;
}

/* Input de busca com texto preto forte */
.cr-filtros__input {
    color: #0f172a !important;
    -webkit-text-fill-color: #0f172a !important;
    font-weight: 500 !important;
}

/* Cards hover só em desktop */
@media (hover: none) {
    .cr-busca-page article.cr-card:hover { filter: drop-shadow(0 1px 3px rgba(0,0,0,0.04)) !important; }
}

/* ============================================================================
 * FIX DEFINITIVO — Esconde completamente o painel de filtros quando fechado
 * (o transform sozinho deixava os selects brancos vazando por trás dos cards)
 * ============================================================================ */
@media (max-width: 767px) {
    .cr-filtros__panel:not(.cr-filtros__panel--open) {
        visibility: hidden !important;
        pointer-events: none !important;
        display: none !important;
    }
    .cr-filtros__panel.cr-filtros__panel--open {
        visibility: visible !important;
        pointer-events: auto !important;
        display: grid !important;
        position: fixed !important;
        inset: auto 0 0 0 !important;
        transform: translateY(0) !important;
        z-index: 9999 !important;
    }
}

/* ============================================================================
 * AJUSTE — Cores dos badges + WhatsApp empty state mais bonito
 * ============================================================================ */

/* Badge PÓS-EDITAL vira verde (positivo, atualizado) */
.cr-busca-page .cr-card__badge--pos-edital {
    background: #059669 !important;
    color: #fff !important;
}

/* Badge PRÉ-EDITAL continua escuro neutro */
.cr-busca-page .cr-card__badge:not(.cr-card__badge--pos-edital):not(.cr-card__badge--trending) {
    background: #1f2937 !important;
    color: #fff !important;
}

/* ============================================================================
 * WhatsApp empty state: botão destacado e moderno
 * ============================================================================ */
.cr-busca-page .cr-empty__whatsapp {
    background: linear-gradient(135deg, #ecfdf5, #f0fdf4) !important;
    border: 1px solid #86efac !important;
    border-radius: 16px !important;
    padding: 24px 20px !important;
    margin-top: 32px !important;
    position: relative !important;
    overflow: hidden !important;
}

.cr-busca-page .cr-empty__whatsapp::before {
    content: '💬' !important;
    display: block !important;
    font-size: 2.5rem !important;
    line-height: 1 !important;
    margin-bottom: 12px !important;
    text-align: center !important;
}

.cr-busca-page .cr-empty__whatsapp p {
    color: #064e3b !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    margin: 0 0 16px 0 !important;
    text-align: center !important;
}

.cr-busca-page .cr-btn-whatsapp {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 360px !important;
    margin: 0 auto !important;
    background: #25D366 !important;
    color: #fff !important;
    padding: 16px 24px !important;
    border-radius: 12px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em !important;
    text-decoration: none !important;
    box-shadow: 0 4px 14px rgba(37, 211, 102, 0.35) !important;
    transition: all 0.2s ease !important;
    position: relative !important;
    overflow: hidden !important;
}

.cr-busca-page .cr-btn-whatsapp:hover,
.cr-busca-page .cr-btn-whatsapp:focus {
    background: #20BA5A !important;
    color: #fff !important;
    box-shadow: 0 6px 20px rgba(37, 211, 102, 0.45) !important;
    transform: translateY(-1px) !important;
}

.cr-busca-page .cr-btn-whatsapp:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 8px rgba(37, 211, 102, 0.3) !important;
}

.cr-busca-page .cr-btn-whatsapp svg {
    width: 22px !important;
    height: 22px !important;
    fill: currentColor !important;
}

/* Efeito shimmer sutil no botao pra chamar atencao */
.cr-busca-page .cr-btn-whatsapp::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: -100% !important;
    width: 50% !important;
    height: 100% !important;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent) !important;
    animation: crBtnShimmer 3s ease-in-out infinite !important;
}

@keyframes crBtnShimmer {
    0%, 100% { left: -100%; }
    50% { left: 200%; }
}
