@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Public+Sans:wght@300;400;500;600;700;800;900&display=swap');

:root {
    --bg-dark: #f4faff;
    --bg-card: #ffffff;
    --bg-card-hover: #f9fbfd;
    --bg-input: #ffffff;
    --bg-sidebar: #ffffff;
    --text-primary: #111d23;
    --text-secondary: #424750;
    
    /* Paleta Institucional (DESIGN.md) */
    --color-primary: #002f5f;
    --color-primary-container: #004587;
    --color-on-primary-container: #87b5fe;
    --color-secondary: #48626e;
    --color-secondary-container: #cbe7f5;
    --color-on-secondary-container: #4e6874;
    --color-tertiary: #233139;
    --color-outline: #737782;
    --color-outline-variant: #c2c6d2;
    
    /* Cores Semânticas */
    --color-success: #2e7d32;
    --color-success-bg: #e8f5e9;
    --color-warning: #ed6c02;
    --color-warning-bg: #fff3e0;
    --color-error: #ba1a1a;
    --color-error-bg: #fde8e8;
    --color-info: #0288d1;
    --color-info-bg: #e1f5fe;

    /* Bordas e Sombras */
    --border-cyber: 1px solid var(--color-outline-variant);
    --border-cyber-hover: 1px solid var(--color-primary);
    --font-heading: 'Public Sans', 'Inter', sans-serif;
    --font-body: 'Inter', 'Public Sans', sans-serif;
    --shadow-sm: 0 2px 4px rgba(0, 47, 95, 0.04);
    --shadow-md: 0 4px 12px rgba(0, 47, 95, 0.08);
    --shadow-lg: 0 8px 24px rgba(0, 47, 95, 0.12);
}

/* Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background-color: var(--bg-dark);
    color: var(--text-primary);
    font-family: var(--font-body);
    min-height: 100vh;
    overflow-x: hidden;
    line-height: 1.5;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: var(--bg-dark);
}
::-webkit-scrollbar-thumb {
    background: var(--color-primary);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: var(--color-primary-container);
}

/* Elegant Corporate Typography */
.glitch-text {
    font-family: var(--font-heading);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-primary);
    position: relative;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-container) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Layout Shell */
.app-container {
    display: flex;
    min-height: 100vh;
    min-width: 0;
}

/* Sidebar Navigation (Modern Light Design) */
.sidebar {
    width: 260px;
    background-color: var(--bg-sidebar);
    border-right: 1px solid var(--color-outline-variant);
    display: flex;
    flex-direction: column;
    padding: 24px 16px;
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 100;
    box-shadow: 2px 0 10px rgba(0, 47, 95, 0.02);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    overflow-y: auto;
}

.sidebar-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 35px;
    padding: 0 8px;
}

.sidebar-header .logo-icon {
    width: 38px;
    height: 38px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-container));
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 47, 95, 0.15);
}

.sidebar-header .logo-icon span {
    font-size: 1.375rem;
    color: #ffffff;
    font-weight: bold;
}

.sidebar-brand h2 {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: 0.5px;
}

.sidebar-brand p {
    font-size: 0.625rem;
    color: var(--color-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 600;
}

.nav-menu {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex-grow: 1;
}

.nav-item a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 8px;
    border: 1px solid transparent;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.nav-item a span {
    font-size: 1.25rem;
    color: var(--color-secondary);
    transition: transform 0.2s ease;
}

.nav-item a:hover {
    color: var(--color-primary);
    background-color: var(--bg-dark);
}

.nav-item a:hover span {
    color: var(--color-primary);
}

.nav-item.active a {
    color: var(--color-primary);
    background-color: var(--color-secondary-container);
    font-weight: 600;
}

.nav-item.active a span {
    color: var(--color-primary);
}

.sidebar-footer {
    border-top: 1px solid var(--color-outline-variant);
    padding-top: 16px;
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.sidebar-footer a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.875rem;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.sidebar-footer a:hover {
    color: var(--color-primary);
    background-color: var(--bg-dark);
}

.sidebar-footer a.logout:hover {
    color: var(--color-error);
    background-color: var(--color-error-bg);
}

/* ================================================================
   SIDEBAR COLAPSO (modo ícone apenas)
   Ativado por: .sidebar.collapsed
   ================================================================ */
.sidebar.collapsed {
    width: 64px;
    padding: 24px 8px;
    overflow: hidden;
}

/* Oculta textos quando colapsado */
.sidebar.collapsed .sidebar-brand,
.sidebar.collapsed .nav-item a span.nav-label,
.sidebar.collapsed .sidebar-footer .footer-label {
    display: none;
}

/* Centraliza ícones quando colapsado */
.sidebar.collapsed .sidebar-header {
    justify-content: center;
    padding: 0;
}

.sidebar.collapsed .nav-item a {
    justify-content: center;
    padding: 10px;
    gap: 0;
}

.sidebar.collapsed .sidebar-footer a {
    justify-content: center;
    padding: 10px;
    gap: 0;
}

/* Oculta o texto das âncoras do footer */
.sidebar.collapsed .sidebar-footer a > span:last-child {
    display: none;
}

/* Tooltip ao hover no modo colapsado */
.sidebar.collapsed .nav-item a {
    position: relative;
}

.sidebar.collapsed .nav-item a::after {
    content: attr(data-label);
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--bg-card);
    color: var(--text-primary);
    border: 1px solid var(--color-outline-variant);
    padding: 5px 10px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
    box-shadow: var(--shadow-md);
    z-index: 200;
}

.sidebar.collapsed .nav-item a:hover::after {
    opacity: 1;
}

.sidebar.collapsed .sidebar-footer a {
    position: relative;
}

.sidebar.collapsed .sidebar-footer a::after {
    content: attr(data-label);
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--bg-card);
    color: var(--text-primary);
    border: 1px solid var(--color-outline-variant);
    padding: 5px 10px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
    box-shadow: var(--shadow-md);
    z-index: 200;
}

.sidebar.collapsed .sidebar-footer a:hover::after {
    opacity: 1;
}

/* Mobile and Tablet overlay */
@media (max-width: 1024px) {
    .sidebar {
        transform: translateX(-100%);
    }
    .sidebar.mobile-open {
        transform: translateX(0);
    }
    .sidebar.collapsed {
        transform: translateX(-100%);
    }
    .main-content {
        margin-left: 0 !important;
    }
    .bento-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .app-header {
        padding: 10px 15px !important;
        height: auto !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px !important;
    }
    .header-actions {
        justify-content: flex-start !important;
        width: 100% !important;
        gap: 8px !important;
    }
    .search-bar {
        width: auto !important;
        flex-grow: 1 !important;
    }
    .search-bar input {
        width: 100% !important;
        max-width: 150px !important;
    }
    .search-bar input:focus {
        width: 100% !important;
        max-width: 180px !important;
    }
    .user-info {
        display: none !important;
    }
    .page-container {
        padding: 15px !important;
    }
    .section-header {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 15px !important;
    }
    .section-header div {
        align-self: flex-start !important;
        width: 100% !important;
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 10px !important;
    }
    .section-header .cyber-btn {
        flex: 1 1 auto !important;
        justify-content: center !important;
    }
    .cyber-modal-content {
        grid-template-columns: 1fr !important;
    }
    .page-container > div[style*="display: grid"],
    .page-container > div[style*="grid-template-columns"],
    .cyber-modal-content > div[style*="display: grid"],
    .cyber-modal-content > div[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
    }
    .filters-row-main {
        flex-direction: column !important;
        align-items: stretch !important;
    }
    .filters-row-main > div {
        width: 100% !important;
    }
    .filters-row-main .cyber-btn,
    .filters-row-main a.cyber-btn {
        flex-grow: 1 !important;
        text-align: center !important;
        justify-content: center !important;
    }
    .filters-row-dates {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }
    .filters-row-dates > div {
        flex-direction: column !important;
        align-items: stretch !important;
        width: 100% !important;
    }
    .filters-row-dates select,
    .filters-row-dates input {
        width: 100% !important;
    }
    .charts-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 576px) {
    .bento-grid {
        grid-template-columns: 1fr !important;
    }
}

.filters-panel {
    padding: 18px 24px;
    margin-bottom: 25px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}
.filters-row-main {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 15px;
}
.filters-row-dates {
    border-top: 1px solid var(--color-outline-variant);
    padding-top: 12px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px;
}

/* Main Content Area */
.main-content {
    margin-left: 260px;
    flex-grow: 1;
    min-width: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    transition: margin-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.main-content.sidebar-collapsed {
    margin-left: 64px;
}

/* Botão de colapso da sidebar */
.mobile-menu-toggle {
    background: none;
    border: 1px solid transparent;
    color: var(--text-secondary);
    cursor: pointer;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.mobile-menu-toggle:hover {
    color: var(--color-primary);
    background-color: var(--color-secondary-container);
    border-color: var(--color-outline-variant);
}

.mobile-menu-toggle .material-symbols-outlined {
    font-size: 1.375rem;
}

/* Header (Modern Glass/White) */
.app-header {
    height: 70px;
    border-bottom: 1px solid var(--color-outline-variant);
    background-color: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 30px;
    position: sticky;
    top: 0;
    z-index: 90;
    box-shadow: 0 2px 10px rgba(0, 47, 95, 0.02);
}

.header-title h2 {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 16px;
}

.search-bar {
    position: relative;
    display: flex;
    align-items: center;
}

.search-bar input {
    background-color: var(--bg-dark);
    border: 1px solid var(--color-outline-variant);
    border-radius: 20px;
    padding: 8px 15px 8px 38px;
    color: var(--text-primary);
    font-size: 0.813rem;
    width: 220px;
    outline: none;
    transition: all 0.3s ease;
}

.search-bar input:focus {
    border-color: var(--color-primary);
    background-color: #ffffff;
    box-shadow: 0 0 0 3px rgba(0, 47, 95, 0.08);
    width: 280px;
}

.search-bar span {
    position: absolute;
    left: 14px;
    color: var(--text-secondary);
    pointer-events: none;
    font-size: 1.125rem;
}

.icon-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid transparent;
    transition: all 0.2s ease;
    vertical-align: middle;
}

.icon-btn:hover {
    color: var(--color-primary);
    background-color: var(--bg-dark);
}

.actions-wrapper {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
}

.user-profile {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-left: 10px;
    border-left: 1px solid var(--color-outline-variant);
}

.user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--color-primary);
    overflow: hidden;
}

.user-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.user-info p {
    font-size: 0.813rem;
    font-weight: 600;
    line-height: 1.2;
}

.user-info span {
    font-size: 0.625rem;
    color: var(--color-secondary);
    font-weight: 500;
}

/* Page Container */
.page-container {
    padding: 30px;
    max-width: 1300px;
    width: 100%;
    margin: 0 auto;
    flex-grow: 1;
}

/* Section Header */
.section-header {
    margin-bottom: 25px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.section-title h1 {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--color-primary);
    letter-spacing: -0.5px;
}

.section-title p {
    color: var(--text-secondary);
    font-size: 0.813rem;
}

/* Modern Minimalist Cards */
.cyber-card {
    background-color: var(--bg-card);
    border: 1px solid var(--color-outline-variant);
    border-radius: 12px;
    padding: 24px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    box-shadow: var(--shadow-sm);
}

.cyber-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background-color: var(--color-primary);
    transition: width 0.2s ease;
}

.cyber-card:hover {
    transform: translateY(-2px);
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
}

.cyber-card.magenta::before {
    background-color: var(--color-secondary);
}
.cyber-card.magenta:hover {
    border-color: var(--color-secondary);
}

.cyber-card.green::before {
    background-color: var(--color-success);
}
.cyber-card.green:hover {
    border-color: var(--color-success);
}

.cyber-card.yellow::before {
    background-color: var(--color-warning);
}
.cyber-card.yellow:hover {
    border-color: var(--color-warning);
}

/* Bento Grid */
.bento-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 25px;
}

.bento-item {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.bento-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 15px;
}

.bento-header span {
    font-size: 0.688rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.bento-header .bento-icon {
    font-size: 1.25rem;
    color: var(--color-secondary);
}

.bento-value {
    font-family: var(--font-heading);
    font-size: 1.875rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.1;
    margin-bottom: 5px;
}

.bento-trend {
    font-size: 0.75rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 5px;
}

.bento-trend.positive {
    color: var(--color-success);
    font-weight: 600;
}

/* Buttons (Clean Corporate) */
.cyber-btn {
    background-color: var(--color-primary);
    border: 1px solid var(--color-primary);
    color: #ffffff;
    font-family: var(--font-heading);
    font-size: 0.813rem;
    font-weight: 600;
    padding: 10px 18px;
    border-radius: 6px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.2s ease;
    box-shadow: 0 2px 4px rgba(0, 47, 95, 0.15);
}

.cyber-btn span {
    font-size: 1rem;
}

.cyber-btn:hover {
    background-color: var(--color-primary-container);
    border-color: var(--color-primary-container);
    box-shadow: 0 4px 8px rgba(0, 47, 95, 0.2);
}

.cyber-btn:active {
    transform: scale(0.98);
}

.cyber-btn.magenta {
    background-color: var(--color-secondary);
    border-color: var(--color-secondary);
}

.cyber-btn.magenta:hover {
    background-color: var(--color-tertiary);
    border-color: var(--color-tertiary);
}

.cyber-btn.sec {
    background-color: transparent;
    border-color: var(--color-outline-variant);
    color: var(--text-primary);
    box-shadow: none;
}

.cyber-btn.sec:hover {
    background-color: var(--bg-dark);
    border-color: var(--color-outline);
    color: var(--color-primary);
}

/* Charts and Progress Bar Section */
.charts-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
    margin-bottom: 25px;
}

.bar-chart-container {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.progress-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.progress-label {
    display: flex;
    justify-content: space-between;
    font-size: 0.813rem;
    color: var(--text-secondary);
}

.progress-label span:first-child {
    font-weight: 600;
    color: var(--text-primary);
}

.progress-label span:last-child {
    font-family: var(--font-heading);
    color: var(--color-primary);
    font-weight: bold;
}

.progress-track {
    height: 8px;
    background-color: var(--bg-dark);
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--color-outline-variant);
}

.progress-fill {
    height: 100%;
    border-radius: 4px;
    width: 0;
    transition: width 1.5s cubic-bezier(0.1, 1, 0.1, 1);
}

.progress-fill.cyan {
    background: linear-gradient(90deg, var(--color-primary), var(--color-primary-container));
}
.progress-fill.magenta {
    background: linear-gradient(90deg, var(--color-secondary), var(--color-tertiary));
}
.progress-fill.green {
    background-color: var(--color-success);
}
.progress-fill.yellow {
    background-color: var(--color-warning);
}

/* Donut Chart */
.donut-chart-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 10px 0;
}

.donut-svg-wrapper {
    position: relative;
    width: 130px;
    height: 130px;
    margin-bottom: 15px;
}

.donut-svg-wrapper svg {
    transform: rotate(-90deg);
}

.donut-bg {
    fill: none;
    stroke: var(--bg-dark);
    stroke-width: 3.5;
}

.donut-value-ring {
    fill: none;
    stroke: var(--color-primary);
    stroke-width: 3.5;
    stroke-linecap: round;
    stroke-dasharray: 0, 100;
    transition: stroke-dasharray 1.5s cubic-bezier(0.1, 1, 0.1, 1);
}

.donut-center-text {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.donut-number {
    font-family: var(--font-heading);
    font-size: 1.375rem;
    font-weight: 800;
    color: var(--color-primary);
}

.donut-desc {
    font-size: 0.625rem;
    text-transform: uppercase;
    color: var(--text-secondary);
    letter-spacing: 0.5px;
    font-weight: 600;
}

/* Modern Tables */
.table-container {
    background-color: var(--bg-card);
    border: 1px solid var(--color-outline-variant);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.table-header-bar {
    padding: 18px 24px;
    border-bottom: 1px solid var(--color-outline-variant);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: #ffffff;
}

.table-header-bar h3 {
    font-family: var(--font-heading);
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: 0.5px;
}

.cyber-table-wrapper {
    overflow-x: auto;
}

.cyber-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.cyber-table th {
    background-color: var(--bg-dark);
    padding: 14px 24px;
    font-family: var(--font-heading);
    font-size: 0.688rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
    border-bottom: 1px solid var(--color-outline-variant);
    border-right: 1px solid var(--color-outline-variant);
}

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

.cyber-table td {
    padding: 16px 24px;
    font-size: 0.875rem;
    border-bottom: 1px solid var(--color-outline-variant);
    border-right: 1px solid var(--color-outline-variant);
    color: var(--text-primary);
}

.cyber-table td:last-child {
    border-right: none;
}

.cyber-table tbody tr {
    transition: all 0.2s ease;
}

.cyber-table tbody tr:hover {
    background-color: var(--bg-dark);
}

.cyber-table tbody tr:last-child td {
    border-bottom: none;
}

.badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
}

.badge.success {
    background-color: var(--color-success-bg);
    color: var(--color-success);
    border: 1px solid rgba(46, 125, 50, 0.2);
}

.badge.warning {
    background-color: var(--color-warning-bg);
    color: var(--color-warning);
    border: 1px solid rgba(237, 108, 2, 0.2);
}

.badge.info {
    background-color: var(--color-info-bg);
    color: var(--color-info);
    border: 1px solid rgba(2, 136, 209, 0.2);
}

.badge.danger {
    background-color: var(--color-error-bg);
    color: var(--color-error);
    border: 1px solid rgba(186, 26, 26, 0.2);
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background-color: #ffffff;
    border-top: 1px solid var(--color-outline-variant);
    font-size: 0.813rem;
    color: var(--text-secondary);
}

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

.pagination-btn {
    background: none;
    border: 1px solid var(--color-outline-variant);
    color: var(--text-secondary);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.813rem;
    transition: all 0.2s ease;
}

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

.pagination-btn.active {
    background-color: var(--color-primary);
    color: #ffffff;
    font-weight: bold;
    border-color: var(--color-primary);
}

.pagination-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Footer Section */
.app-footer {
    margin-top: auto;
    padding: 20px 30px;
    border-top: 1px solid var(--color-outline-variant);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.75rem;
    color: var(--text-secondary);
    background-color: #ffffff;
}

.footer-links {
    display: flex;
    gap: 20px;
}

.footer-links a {
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.footer-links a:hover {
    color: var(--color-primary);
}

/* Glitch Button */
.glitch-btn {
    width: 100%;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-container) 100%);
    border: none;
    padding: 14px 20px;
    color: #ffffff;
    font-family: var(--font-heading);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    transition: all 0.2s ease;
    box-shadow: 0 4px 10px rgba(0, 47, 95, 0.2);
}

.glitch-btn:hover {
    box-shadow: 0 6px 15px rgba(0, 47, 95, 0.3);
    background: var(--color-primary-container);
}

.glitch-btn:active {
    transform: translateY(1px);
}

/* Inputs & Form Controls */
.cyber-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 20px;
}

.cyber-form-group label {
    font-size: 0.688rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-secondary);
}

.cyber-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.cyber-input-wrapper span.prefix-icon {
    position: absolute;
    left: 15px;
    color: var(--text-secondary);
    font-size: 1.125rem;
}

.cyber-input {
    width: 100%;
    background-color: var(--bg-input);
    border: 1px solid var(--color-outline-variant);
    padding: 12px 15px 12px 42px;
    color: var(--text-primary);
    border-radius: 6px;
    font-size: 0.875rem;
    outline: none;
    transition: all 0.2s ease;
}

.cyber-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 47, 95, 0.08);
}

.cyber-input-wrapper button.visibility-btn {
    position: absolute;
    right: 15px;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
}

.cyber-checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.813rem;
    color: var(--text-secondary);
    cursor: pointer;
    user-select: none;
}

.cyber-checkbox-label input {
    display: none;
}

.checkbox-custom {
    width: 18px;
    height: 18px;
    border: 1px solid var(--color-outline-variant);
    background-color: var(--bg-input);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.cyber-checkbox-label:hover .checkbox-custom {
    border-color: var(--color-primary);
}

.cyber-checkbox-label input:checked + .checkbox-custom {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

.cyber-checkbox-label input:checked + .checkbox-custom::after {
    content: '✓';
    color: #ffffff;
    font-size: 0.75rem;
    font-weight: 700;
}

/* Modals */
.cyber-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 40px 20px;
    background-color: rgba(17, 29, 35, 0.4);
    backdrop-filter: blur(4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
    overflow-y: auto;
}

.cyber-modal.active {
    opacity: 1;
    pointer-events: auto;
}

.cyber-modal-container {
    background-color: var(--bg-card);
    border: 1px solid var(--color-outline-variant);
    border-radius: 12px;
    width: 100%;
    max-width: 600px;
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    transform: scale(0.95);
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.cyber-modal.active .cyber-modal-container {
    transform: scale(1);
}

.cyber-modal-header {
    padding: 18px 24px;
    border-bottom: 1px solid var(--color-outline-variant);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--bg-dark);
}

.cyber-modal-header h3 {
    font-family: var(--font-heading);
    color: var(--color-primary);
    font-size: 0.938rem;
    font-weight: 700;
}

.cyber-modal-close {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cyber-modal-close:hover {
    color: var(--color-error);
}

.cyber-modal-content {
    padding: 24px;
}

.cyber-modal-footer {
    padding: 18px 24px;
    border-top: 1px solid var(--color-outline-variant);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    background-color: var(--bg-dark);
}

/* Notifications Alert */
.cyber-notifications-container {
    position: fixed;
    top: 30px;
    right: 30px;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.cyber-notification {
    background-color: #ffffff;
    border: 1px solid var(--color-outline-variant);
    border-left: 4px solid var(--color-primary);
    box-shadow: var(--shadow-md);
    border-radius: 8px;
    padding: 14px 18px;
    width: 320px;
    display: flex;
    align-items: center;
    gap: 12px;
    transform: translateX(120%);
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.cyber-notification.active {
    transform: translateX(0);
}

.cyber-notification.success {
    border-left-color: var(--color-success);
}
.cyber-notification.success .notif-icon { color: var(--color-success); }

.cyber-notification.error {
    border-left-color: var(--color-error);
}
.cyber-notification.error .notif-icon { color: var(--color-error); }

.cyber-notification.warning {
    border-left-color: var(--color-warning);
}
.cyber-notification.warning .notif-icon { color: var(--color-warning); }

.notif-icon {
    font-size: 1.25rem;
    color: var(--color-primary);
}

.notif-content {
    flex-grow: 1;
}

.notif-title {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 2px;
    color: var(--text-primary);
}

.notif-message {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Showcase grid alignment adjustment */
.showcase-item {
    display: flex;
    flex-direction: column;
}

/* ==========================================================
   LOGIN, REGISTER & RECOVERY PAGES LAYOUT (FIRJAN SENAI)
   ========================================================== */
.login-page-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: var(--bg-dark);
}

.login-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 40px;
    background-color: transparent;
}

.login-logo-group {
    display: flex;
    align-items: center;
    gap: 12px;
}

.login-logo-icon {
    width: 38px;
    height: 38px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-container));
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 47, 95, 0.15);
}

.login-logo-icon span {
    font-size: 1.375rem;
    color: #ffffff;
    font-weight: bold;
}

.login-brand-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: 0.5px;
}

.login-main {
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.login-card {
    display: flex;
    width: 100%;
    max-width: 900px;
    background-color: var(--bg-card);
    border: var(--border-cyber);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    transition: all 0.3s ease;
}

.login-branding-panel {
    flex: 1;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-container) 100%);
    color: #ffffff;
    padding: 40px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
}

.login-branding-bg-pattern {
    position: absolute;
    inset: 0;
    opacity: 0.04;
    background-image: radial-gradient(circle at 1px 1px, #ffffff 1px, transparent 0);
    background-size: 16px 16px;
    pointer-events: none;
}

.login-branding-content {
    position: relative;
    z-index: 2;
}

.login-branding-content h1 {
    font-family: var(--font-heading);
    font-size: 1.625rem;
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 15px;
    letter-spacing: -0.5px;
    color: #ffffff;
}

.login-branding-content p {
    font-size: 0.813rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.85);
}

.login-image-wrapper {
    position: relative;
    z-index: 2;
    margin-top: 30px;
    height: 220px;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.login-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.login-form-panel {
    flex: 1;
    padding: 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background-color: var(--bg-card);
}

.login-form-header {
    margin-bottom: 25px;
}

.login-form-header h2 {
    font-family: var(--font-heading);
    font-size: 1.375rem;
    font-weight: 800;
    color: var(--color-primary);
    margin-bottom: 6px;
}

.login-form-header p {
    font-size: 0.813rem;
    color: var(--text-secondary);
}

.login-form-footer {
    margin-top: 25px;
    text-align: center;
    font-size: 0.813rem;
    color: var(--text-secondary);
}

.login-form-footer a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}

.login-form-footer a:hover {
    color: var(--color-primary-container);
    text-decoration: underline;
}

.login-footer {
    padding: 20px 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.75rem;
    color: var(--text-secondary);
    border-top: 1px solid var(--color-outline-variant);
    background-color: #ffffff;
}

.login-footer-links {
    display: flex;
    gap: 20px;
}

.login-footer-links a {
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.login-footer-links a:hover {
    color: var(--color-primary);
}

/* Visibility button inside inputs */
.visibility-btn {
    position: absolute;
    right: 15px;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
    border-radius: 50%;
    transition: all 0.2s ease;
}

.visibility-btn:hover {
    color: var(--color-primary);
    background-color: var(--bg-dark);
}

/* Responsive adjustment for stacked panels */
@media (max-width: 768px) {
    .login-card {
        flex-direction: column;
        max-width: 450px;
    }
    
    .login-branding-panel {
        padding: 30px;
    }
    
    .login-image-wrapper {
        display: none;
    }
    
    .login-form-panel {
        padding: 30px;
    }
    
    .login-header {
        padding: 15px 20px;
    }
    
    .login-footer {
        flex-direction: column;
        gap: 10px;
        text-align: center;
        padding: 15px 20px;
    }
}

/* ================================================================
   DARK THEME — Institucional Profissional
   Aplicado via: [data-theme="dark"] no <html>
   ================================================================ */
[data-theme="dark"] {
    --bg-dark:                   #0d1117;
    --bg-card:                   #161b22;
    --bg-card-hover:             #1c2128;
    --bg-input:                  #1c2128;
    --bg-sidebar:                #0d1117;
    --bg-surface:                #161b22;
    --text-primary:              #e6edf3;
    --text-secondary:            #8b949e;

    /* Paleta Institucional — Dark */
    --color-primary:             #58a6ff;
    --color-primary-container:   #1f6feb;
    --color-on-primary-container:#cae8ff;
    --color-secondary:           #79c0ff;
    --color-secondary-container: #0d2045;
    --color-on-secondary-container: #79c0ff;
    --color-tertiary:            #388bfd;
    --color-outline:             #484f58;
    --color-outline-variant:     #30363d;

    /* Semânticas — Dark */
    --color-success:             #3fb950;
    --color-success-bg:          #0d2e18;
    --color-warning:             #e3b341;
    --color-warning-bg:          #2e1f04;
    --color-error:               #f85149;
    --color-error-bg:            #2d1318;
    --color-info:                #58a6ff;
    --color-info-bg:             #0d1f3c;

    /* Sombras — Dark */
    --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.45);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.6);

    /* Bordas */
    --border-cyber:       1px solid var(--color-outline-variant);
    --border-cyber-hover: 1px solid var(--color-primary);
}

/* === Correções de cores hardcoded no tema escuro === */
[data-theme="dark"] .app-header {
    background-color: rgba(13, 17, 23, 0.92);
    border-bottom-color: var(--color-outline-variant);
}
[data-theme="dark"] .table-header-bar  { background-color: var(--bg-card); }
[data-theme="dark"] .pagination        { background-color: var(--bg-card); }
[data-theme="dark"] .app-footer        { background-color: var(--bg-card); }
[data-theme="dark"] .login-footer      { background-color: var(--bg-card); }
[data-theme="dark"] .cyber-notification{ background-color: var(--bg-card); border-color: var(--color-outline-variant); }
[data-theme="dark"] .cyber-modal-header{ background-color: #0d1117; }
[data-theme="dark"] .cyber-modal-footer{ background-color: #0d1117; }
[data-theme="dark"] .login-form-panel  { background-color: var(--bg-card); }
[data-theme="dark"] .cyber-modal-container { background-color: var(--bg-card); }
[data-theme="dark"] .search-bar input:focus { background-color: var(--bg-card); }

[data-theme="dark"] .glitch-text {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-on-primary-container) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Badge ajustes no escuro */
[data-theme="dark"] .badge.success { border-color: rgba(63, 185, 80, 0.3); }
[data-theme="dark"] .badge.warning { border-color: rgba(227, 179, 65, 0.3); }
[data-theme="dark"] .badge.info    { border-color: rgba(88, 166, 255, 0.3); }
[data-theme="dark"] .badge.danger  { border-color: rgba(248, 81, 73, 0.3); }

/* Sidebar accent no escuro */
[data-theme="dark"] .nav-item.active a {
    background-color: var(--color-secondary-container);
    color: var(--color-primary);
}
[data-theme="dark"] .nav-item a:hover {
    background-color: #1c2128;
}
[data-theme="dark"] .sidebar-footer a:hover {
    background-color: #1c2128;
}
[data-theme="dark"] .sidebar-footer a.logout:hover {
    background-color: var(--color-error-bg);
    color: var(--color-error);
}

/* ================================================================
   BOTÃO DE ALTERNÂNCIA DE TEMA
   ================================================================ */
.theme-toggle-btn {
    background: none;
    border: 1px solid var(--color-outline-variant);
    color: var(--text-secondary);
    cursor: pointer;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.theme-toggle-btn:hover {
    color: var(--color-primary);
    background-color: var(--color-secondary-container);
    border-color: var(--color-primary);
    transform: rotate(20deg);
}

.theme-toggle-btn .icon-light,
.theme-toggle-btn .icon-dark {
    position: absolute;
    font-size: 1.125rem;
    transition: opacity 0.2s ease, transform 0.3s ease;
}

/* Tema claro: mostra sol. Tema escuro: mostra lua */
.theme-toggle-btn .icon-light  { opacity: 1;  transform: scale(1);   }
.theme-toggle-btn .icon-dark   { opacity: 0;  transform: scale(0.5); }

[data-theme="dark"] .theme-toggle-btn .icon-light { opacity: 0;  transform: scale(0.5); }
[data-theme="dark"] .theme-toggle-btn .icon-dark  { opacity: 1;  transform: scale(1);   }

/* Ajuste de largura total para o TinyMCE */
.tox-tinymce {
    width: 100% !important;
    flex-grow: 1;
    min-height: 180px;
}
.cyber-input-wrapper:has(.tox-tinymce) {
    width: 100%;
}
.cyber-input-wrapper:has(.tox-tinymce) .prefix-icon {
    display: none !important;
}
