/* ═══════════════════════════════════════════════════════════════════════════
   Rel-Alumn – Frontend CSS
   Especificidade máxima para vencer estilos de temas / Elementor / page builders.
   TODOS os seletores usam .ra-report-wrapper como pai e !important nos
   estilos de layout críticos para garantir que o visual seja idêntico ao admin.
   ═══════════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ── Variáveis (sobrescritas pelo PHP via wp_add_inline_style) ───────────── */
.ra-report-wrapper {
    --ra-primary: #3b82f6;
    --ra-primary-dark: #1d4ed8;
    --ra-accent: #10b981;
    --ra-accent-dark: #059669;
    --ra-header-text: #ffffff;
    --ra-row-hover: #eff6ff;
    --ra-filter-bg: #ffffff;
    --ra-border: #e5e7eb;
    --ra-input-bg: #f9fafb;
    --ra-text: #111827;
    --ra-text-muted: #6b7280;
    --ra-table-bg: #ffffff;
    --ra-radius: 10px;
    --ra-radius-sm: 6px;
    --ra-shadow: 0 1px 3px rgba(0, 0, 0, .10), 0 1px 2px rgba(0, 0, 0, .06);
    --ra-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .10), 0 2px 4px -1px rgba(0, 0, 0, .06);

    width: 100% !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: var(--ra-text) !important;
    background: transparent !important;
    box-sizing: border-box !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAINEL DE FILTROS  — layout horizontal obrigatório
   ═══════════════════════════════════════════════════════════════════════════ */
.ra-report-wrapper .ra-filters {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
    align-items: flex-end !important;

    background: var(--ra-filter-bg) !important;
    border: 1px solid var(--ra-border) !important;
    border-radius: var(--ra-radius) !important;
    padding: 20px 24px !important;
    margin: 0 0 20px 0 !important;
    box-shadow: var(--ra-shadow) !important;
    box-sizing: border-box !important;
    width: 100% !important;
}

.ra-report-wrapper .ra-filters__group {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    flex: 1 1 170px !important;
    min-width: 150px !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

.ra-report-wrapper .ra-filters__group label,
.ra-report-wrapper .ra-filters__group>label {
    display: block !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: var(--ra-text-muted) !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    margin: 0 0 4px 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
}

/* ── Inputs ──────────────────────────────────────────────────────────────── */
.ra-report-wrapper .ra-filter-input,
.ra-report-wrapper input.ra-filter-input,
.ra-report-wrapper select.ra-filter-input {
    display: block !important;
    width: 100% !important;
    height: 40px !important;
    padding: 0 12px !important;
    margin: 0 !important;
    border: 1.5px solid var(--ra-border) !important;
    border-radius: var(--ra-radius-sm) !important;
    background: var(--ra-input-bg) !important;
    background-image: none !important;
    color: var(--ra-text) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    box-shadow: none !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-sizing: border-box !important;
    transition: border-color .2s, box-shadow .2s;
}

.ra-report-wrapper .ra-filter-input:focus,
.ra-report-wrapper input.ra-filter-input:focus,
.ra-report-wrapper select.ra-filter-input:focus {
    border-color: var(--ra-primary) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, .15) !important;
    background: #ffffff !important;
    outline: none !important;
}

.ra-report-wrapper select.ra-filter-input {
    cursor: pointer !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%236b7280' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    background-size: 20px !important;
    padding-right: 36px !important;
}

/* ── Área de botões ─────────────────────────────────────────────────────── */
.ra-report-wrapper .ra-filters__actions {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: flex-end !important;
    flex-shrink: 0 !important;
}

.ra-report-wrapper .ra-btn,
.ra-report-wrapper button.ra-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    height: 40px !important;
    padding: 0 18px !important;
    margin: 0 !important;
    border: none !important;
    border-radius: var(--ra-radius-sm) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    transition: background .2s, transform .1s, box-shadow .2s;
    vertical-align: middle !important;
}

.ra-report-wrapper .ra-btn:active,
.ra-report-wrapper button.ra-btn:active {
    transform: translateY(1px);
}

.ra-report-wrapper .ra-btn .dashicons {
    font-family: 'dashicons' !important;
    font-size: 16px !important;
    width: 16px !important;
    height: 16px !important;
    line-height: 1 !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none !important;
    -webkit-font-smoothing: antialiased;
}

/* Botão Filtrar */
.ra-report-wrapper .ra-btn--primary,
.ra-report-wrapper button.ra-btn.ra-btn--primary {
    background: var(--ra-primary) !important;
    color: var(--ra-header-text) !important;
    box-shadow: 0 2px 4px rgba(59, 130, 246, .30) !important;
}

.ra-report-wrapper .ra-btn--primary:hover,
.ra-report-wrapper button.ra-btn.ra-btn--primary:hover {
    background: var(--ra-primary-dark) !important;
    box-shadow: 0 4px 8px rgba(59, 130, 246, .35) !important;
}

/* Botão Limpar */
.ra-report-wrapper .ra-btn--secondary,
.ra-report-wrapper button.ra-btn.ra-btn--secondary {
    background: #f3f4f6 !important;
    color: #374151 !important;
    border: 1.5px solid var(--ra-border) !important;
    box-shadow: none !important;
}

.ra-report-wrapper .ra-btn--secondary:hover,
.ra-report-wrapper button.ra-btn.ra-btn--secondary:hover {
    background: #e5e7eb !important;
}

/* Botão Exportar */
.ra-report-wrapper .ra-btn--success,
.ra-report-wrapper button.ra-btn.ra-btn--success {
    background: var(--ra-accent) !important;
    color: var(--ra-header-text) !important;
    box-shadow: 0 2px 4px rgba(16, 185, 129, .30) !important;
}

.ra-report-wrapper .ra-btn--success:hover,
.ra-report-wrapper button.ra-btn.ra-btn--success:hover {
    background: var(--ra-accent-dark) !important;
    box-shadow: 0 4px 8px rgba(16, 185, 129, .35) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ÁREA DE RESULTADOS
   ═══════════════════════════════════════════════════════════════════════════ */
.ra-report-wrapper .ra-results {
    width: 100% !important;
    box-sizing: border-box !important;
}

.ra-report-wrapper .ra-results__info {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    min-height: 24px !important;
}

.ra-report-wrapper .ra-total-count {
    font-size: 12px !important;
    color: var(--ra-text-muted) !important;
    font-weight: 500 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TABELA — visual idêntico ao admin
   ═══════════════════════════════════════════════════════════════════════════ */
.ra-report-wrapper .ra-table-wrapper {
    overflow-x: auto !important;
    overflow-y: visible !important;
    border-radius: var(--ra-radius) !important;
    box-shadow: var(--ra-shadow-md) !important;
    border: 1px solid var(--ra-border) !important;
    background: var(--ra-table-bg) !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.ra-report-wrapper .ra-table {
    width: 100% !important;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
    font-size: 13px !important;
    background: var(--ra-table-bg) !important;
    margin: 0 !important;
    padding: 0 !important;
    table-layout: auto !important;
}

/* ── Cabeçalho da tabela — gradiente igual ao admin ─────────────────────── */
.ra-report-wrapper .ra-table thead,
.ra-report-wrapper table.ra-table thead {
    background: linear-gradient(135deg, #1e3a8a 0%, #2563eb 60%, #3b82f6 100%) !important;
}

.ra-report-wrapper .ra-table thead tr,
.ra-report-wrapper table.ra-table thead tr {
    background: transparent !important;
    border: none !important;
}

.ra-report-wrapper .ra-th,
.ra-report-wrapper .ra-table th.ra-th,
.ra-report-wrapper table th.ra-th {
    padding: 13px 16px !important;
    text-align: left !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    text-transform: uppercase !important;
    letter-spacing: .07em !important;
    white-space: nowrap !important;
    cursor: pointer !important;
    user-select: none !important;
    background: transparent !important;
    border-right: 1px solid rgba(255, 255, 255, .12) !important;
    border-top: none !important;
    border-bottom: none !important;
    border-left: none !important;
    vertical-align: middle !important;
    transition: background .15s;
}

.ra-report-wrapper .ra-th:last-child,
.ra-report-wrapper table th.ra-th:last-child {
    border-right: none !important;
}

.ra-report-wrapper .ra-th:hover,
.ra-report-wrapper table th.ra-th:hover {
    background: rgba(0, 0, 0, .12) !important;
}

.ra-report-wrapper .ra-th.ra-sort-asc::after {
    content: ' ↑';
    opacity: .9;
}

.ra-report-wrapper .ra-th.ra-sort-desc::after {
    content: ' ↓';
    opacity: .9;
}

/* ── Linhas do corpo ─────────────────────────────────────────────────────── */
.ra-report-wrapper .ra-tbody tr,
.ra-report-wrapper .ra-table tbody tr {
    background: var(--ra-table-bg) !important;
    border-bottom: 1px solid var(--ra-border) !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    transition: background .15s;
}

.ra-report-wrapper .ra-tbody tr:last-child,
.ra-report-wrapper .ra-table tbody tr:last-child {
    border-bottom: none !important;
}

.ra-report-wrapper .ra-tbody tr:hover,
.ra-report-wrapper .ra-table tbody tr:hover {
    background: var(--ra-row-hover) !important;
}

.ra-report-wrapper .ra-tbody tr:nth-child(even),
.ra-report-wrapper .ra-table tbody tr:nth-child(even) {
    background: rgba(0, 0, 0, .018) !important;
}

.ra-report-wrapper .ra-tbody tr:nth-child(even):hover,
.ra-report-wrapper .ra-table tbody tr:nth-child(even):hover {
    background: var(--ra-row-hover) !important;
}

/* ── Células ────────────────────────────────────────────────────────────── */
.ra-report-wrapper .ra-tbody td,
.ra-report-wrapper .ra-table tbody td {
    padding: 11px 16px !important;
    color: var(--ra-text) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    vertical-align: middle !important;
    word-break: break-word !important;
    background: transparent !important;
    border: none !important;
}

/* ── Estado: carregando / sem resultados ─────────────────────────────────── */
.ra-report-wrapper .ra-loading,
.ra-report-wrapper .ra-table td.ra-loading,
.ra-report-wrapper .ra-no-results,
.ra-report-wrapper .ra-table td.ra-no-results {
    text-align: center !important;
    padding: 48px 16px !important;
    color: var(--ra-text-muted) !important;
    font-size: 14px !important;
    background: transparent !important;
}

.ra-report-wrapper .ra-loading::before {
    content: '';
    display: inline-block !important;
    width: 20px !important;
    height: 20px !important;
    border: 2.5px solid var(--ra-border) !important;
    border-top-color: var(--ra-primary) !important;
    border-radius: 50% !important;
    animation: ra-spin .7s linear infinite;
    vertical-align: middle !important;
    margin-right: 10px !important;
    background: none !important;
}

@keyframes ra-spin {
    to {
        transform: rotate(360deg);
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGINAÇÃO
   ═══════════════════════════════════════════════════════════════════════════ */
.ra-report-wrapper .ra-pagination {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 20px 0 4px !important;
    margin: 0 !important;
    list-style: none !important;
    background: transparent !important;
}

.ra-report-wrapper .ra-page-btn,
.ra-report-wrapper button.ra-page-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 36px !important;
    min-width: 36px !important;
    padding: 0 10px !important;
    margin: 0 !important;
    border: 1.5px solid var(--ra-border) !important;
    border-radius: var(--ra-radius-sm) !important;
    background: #ffffff !important;
    color: var(--ra-text) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all .2s;
    box-sizing: border-box !important;
    text-decoration: none !important;
}

.ra-report-wrapper .ra-page-btn:hover:not(:disabled),
.ra-report-wrapper button.ra-page-btn:hover:not(:disabled) {
    border-color: var(--ra-primary) !important;
    color: var(--ra-primary) !important;
    background: rgba(59, 130, 246, .06) !important;
}

.ra-report-wrapper .ra-page-btn.ra-page-current,
.ra-report-wrapper button.ra-page-btn.ra-page-current {
    background: var(--ra-primary) !important;
    border-color: var(--ra-primary) !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    cursor: default !important;
}

.ra-report-wrapper .ra-page-btn:disabled,
.ra-report-wrapper button.ra-page-btn:disabled {
    opacity: .4 !important;
    cursor: not-allowed !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVO
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 700px) {
    .ra-report-wrapper .ra-filters {
        flex-direction: column !important;
        padding: 16px !important;
    }

    .ra-report-wrapper .ra-filters__group {
        flex: 1 1 100% !important;
        min-width: 100% !important;
    }

    .ra-report-wrapper .ra-filters__actions {
        width: 100% !important;
    }

    .ra-report-wrapper .ra-btn,
    .ra-report-wrapper button.ra-btn {
        flex: 1 !important;
        justify-content: center !important;
    }

    .ra-report-wrapper .ra-th,
    .ra-report-wrapper table th.ra-th,
    .ra-report-wrapper .ra-tbody td,
    .ra-report-wrapper .ra-table tbody td {
        padding: 10px 12px !important;
    }
}