/* =============================================
   table.css — Tabela e paginação
   Power BI Modern Theme
   ============================================= */

.table-section {
    background: var(--pbi-card);
    border-radius: var(--pbi-radius-md);
    padding: 16px 20px;
    margin-bottom: 14px;
    box-shadow: var(--pbi-shadow-sm);
    border: 1px solid var(--pbi-border);
}

.table-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--pbi-border2);
    gap: 12px;
    flex-wrap: wrap;
}

.table-title-search {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.table-header h2 {
    color: var(--pbi-text);
    margin: 0;
    white-space: nowrap;
    font-size: 13px;
    font-weight: 700;
    display: flex;
    align-items: center;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.search-input {
    flex: 1;
    max-width: 320px;
    padding: 6px 12px;
    border: 1px solid var(--pbi-border);
    border-radius: var(--pbi-radius);
    font-size: 12px;
    font-family: inherit;
    color: var(--pbi-text);
    background: #FAFAFA;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.search-input:focus {
    outline: none;
    border-color: var(--pbi-blue);
    background: var(--pbi-card);
    box-shadow: 0 0 0 2px rgba(0,120,212,0.15);
}

.table-info {
    margin-bottom: 10px;
    padding: 7px 12px;
    background: var(--pbi-blue-lt);
    border-radius: var(--pbi-radius);
    border-left: 3px solid var(--pbi-blue);
}

.table-info-text {
    color: var(--pbi-blue);
    font-weight: 600;
    font-size: 12px;
}

.table-wrapper {
    overflow-x: auto;
    border: 1px solid var(--pbi-border);
    border-radius: var(--pbi-radius);
    margin-bottom: 14px;
}

table {
    width: 100%;
    border-collapse: collapse;
    background: var(--pbi-card);
}

table thead {
    background: var(--pbi-dark);
    color: #FFFFFF;
}

table th {
    padding: 9px 12px;
    text-align: left;
    font-weight: 600;
    position: sticky;
    top: 0;
    font-size: 11px;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    border-right: 1px solid #3A3A3A;
}

table th:last-child {
    border-right: none;
}

table td {
    padding: 7px 12px;
    border-bottom: 1px solid var(--pbi-border2);
    font-size: 12px;
    color: var(--pbi-text);
    transition: background 0.1s ease;
}

table tbody tr { transition: background 0.1s ease; }
table tbody tr:hover { background: var(--pbi-blue-lt); }
table tbody tr:nth-child(even) { background: #FAFAFA; }
table tbody tr:nth-child(even):hover { background: var(--pbi-blue-lt); }

/* ── Paginação ── */
.pagination-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 10px 4px 4px;
}

.pagination-info {
    display: flex;
    align-items: center;
    gap: 8px;
}

.rows-select {
    padding: 5px 10px;
    border: 1px solid var(--pbi-border);
    border-radius: var(--pbi-radius);
    font-size: 12px;
    font-weight: 600;
    color: var(--pbi-text);
    background: var(--pbi-card);
    cursor: pointer;
    font-family: inherit;
    transition: border-color 0.15s ease;
}

.rows-select:focus { outline: none; border-color: var(--pbi-blue); box-shadow: 0 0 0 2px rgba(0,120,212,0.15); }
.rows-select:hover { border-color: var(--pbi-blue); }

.pagination-controls {
    display: flex;
    align-items: center;
    gap: 4px;
}

.pagination-btn {
    padding: 5px 8px;
    background: var(--pbi-card);
    border: 1px solid var(--pbi-border);
    border-radius: var(--pbi-radius);
    cursor: pointer;
    transition: background 0.12s ease, border-color 0.12s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    font-family: inherit;
}

.pagination-btn svg {
    width: 14px;
    height: 14px;
    stroke: var(--pbi-text-muted);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.pagination-btn:hover:not(:disabled) {
    background: var(--pbi-dark);
    border-color: var(--pbi-dark);
}

.pagination-btn:hover:not(:disabled) svg { stroke: var(--pbi-yellow); }
.pagination-btn:disabled { opacity: 0.3; cursor: not-allowed; }

.page-numbers {
    display: flex;
    gap: 3px;
    align-items: center;
}

.page-number {
    padding: 5px 8px;
    background: var(--pbi-card);
    border: 1px solid var(--pbi-border);
    border-radius: var(--pbi-radius);
    cursor: pointer;
    transition: background 0.12s ease, border-color 0.12s ease, color 0.12s ease;
    font-weight: 600;
    min-width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--pbi-text-muted);
    font-size: 12px;
    font-family: inherit;
}

.page-number:hover {
    background: var(--pbi-blue-lt);
    border-color: var(--pbi-blue);
    color: var(--pbi-blue);
}

.page-number.active {
    background: var(--pbi-dark);
    color: var(--pbi-yellow);
    border-color: var(--pbi-dark);
    font-weight: 700;
}

.page-ellipsis {
    padding: 5px 6px;
    color: var(--pbi-text-muted);
    font-weight: 600;
    font-size: 12px;
}

.pagination-jump {
    display: flex;
    align-items: center;
    gap: 6px;
}

.pagination-jump span {
    font-weight: 600;
    color: var(--pbi-text-muted);
    font-size: 12px;
}

.page-jump-input {
    width: 52px;
    padding: 5px 8px;
    border: 1px solid var(--pbi-border);
    border-radius: var(--pbi-radius);
    text-align: center;
    font-weight: 600;
    color: var(--pbi-text);
    font-size: 12px;
    font-family: inherit;
    transition: border-color 0.15s ease;
}

.page-jump-input:focus {
    outline: none;
    border-color: var(--pbi-blue);
    box-shadow: 0 0 0 2px rgba(0,120,212,0.15);
}

.btn-jump {
    padding: 5px 12px;
    background: var(--pbi-blue);
    color: white;
    border: none;
    border-radius: var(--pbi-radius);
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease;
    font-size: 12px;
    font-family: inherit;
    height: 30px;
}

.btn-jump:hover {
    background: var(--pbi-blue-dk);
}
