/* ===== Paleta de Cores W.Vetro ===== */
:root,
body[data-theme="light"] {
    /* Tema Claro (Light Theme) */
    --azul-wv: #0ea5e9;
    --azul-wv-dark: #0d8cc7;
    --azul-wv-gradient: linear-gradient(to right, #0ea5e9, #2563eb);

    --fundo-principal: #f8fafc; /* Branco gelo */
    --fundo-secundario: #eef2f9; /* Azul bem claro */
    --fundo-card: #ffffff;

    --texto-principal: #1e293b; /* Cinza escuro (quase preto) */
    --texto-secundario: #64748b; /* Cinza médio */
    --texto-inverso: #ffffff;

    --borda-padrao: #e2e8f0; /* Cinza claro */
    --borda-foco: var(--azul-wv);
}

body[data-theme="dark"] {
    --azul-wv: #38bdf8;
    --azul-wv-dark: #0ea5e9;
    --azul-wv-gradient: linear-gradient(to right, #0ea5e9, #2563eb);

    --fundo-principal: #0b1220;
    --fundo-secundario: #0f172a;
    --fundo-card: #0b1220;

    --texto-principal: #e2e8f0;
    --texto-secundario: #94a3b8;
    --texto-inverso: #0b1220;

    --borda-padrao: #1f2937;
    --borda-foco: #38bdf8;
}

/* ===== Reset simples ===== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body.bg {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: var(--fundo-principal);
    color: var(--texto-principal);
}

/* ===== Layout base ===== */
.page {
    max-width: 1120px;
    /* Reduce top margin so content starts near header */
    margin: 24px auto 48px;
    padding: 0 24px 24px;
}

.page-narrow {
    max-width: 960px;
}

/* ===== Topbar ===== */
.topbar {
    position: sticky;
    top: 0;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    z-index: 20;
    background: #ffffff;
    border-bottom: 1px solid #e5e7eb;
}
    .topbar-left { display:flex; align-items:center; gap:14px; }
    .topbar-title { font-weight:700; font-size:1rem; letter-spacing:.01em; color:#0f172a; }
    .topbar-subtitle { color:#64748b; font-size:0.85rem; }
    .theme-btn { border:1px solid #e5e7eb; background:#f8fafc; color:#0f172a; padding:8px 12px; border-radius:8px; cursor:pointer; }
    .logout-btn { margin-left:10px; border:1px solid #e5e7eb; background:#f8fafc; color:#0f172a; padding:8px 12px; border-radius:8px; text-decoration:none; display:inline-flex; align-items:center; gap:6px; }
    .logout-btn:hover, .theme-btn:hover { background:#eef2ff; }

    /* Theme-aware header/footer for dark mode */
body[data-theme="dark"] .topbar {
    background: #0b1220;
    border-bottom-color: #1f2937;
}
body[data-theme="dark"] .topbar-title { color:#e2e8f0; }
body[data-theme="dark"] .topbar-subtitle { color:#94a3b8; }
body[data-theme="dark"] .theme-btn,
body[data-theme="dark"] .logout-btn {
    background:#0f172a;
    border-color:#334155;
    color:#e2e8f0;
}
body[data-theme="dark"] .logout-btn:hover,
body[data-theme="dark"] .theme-btn:hover { background:#111827; }

/* ===== Sidebar Layout ===== */
.layout-with-sidebar {
        display: flex;
        min-height: 100vh;
}
.sidebar {
        width: 240px;
        background: linear-gradient(180deg,#0f172a,#1e293b 65%, #0f172a);
        color: #f1f5f9;
        display: flex;
        flex-direction: column;
        padding: 18px 16px 12px;
        gap: 14px;
        border-right: 1px solid rgba(255,255,255,0.06);
        position: sticky;
        top:0;
        height: 100vh;
}
.sidebar.collapsed { width: 72px; }
.sidebar.collapsed .sidebar-footer { opacity:0; pointer-events:none; }
.content-wrapper { flex:1; display:flex; flex-direction:column; }
.sidebar-header { display:flex; align-items:center; gap:10px; }
.sidebar.collapsed .brand { display:none; }
.toggle-btn { background:#1e293b; border:1px solid #334155; color:#f1f5f9; padding:6px 10px; border-radius:8px; cursor:pointer; font-size:13px; }
.toggle-btn:hover { background:#334155; }
.hamburger { background:#0f172a; border:1px solid #334155; color:#f1f5f9; padding:8px 14px; border-radius:10px; cursor:pointer; font-size:16px; line-height:1; display:inline-flex; align-items:center; justify-content:center; box-shadow:0 2px 6px rgba(0,0,0,.25); }
.hamburger:hover { background:#1e293b; }
.nav { display:flex; flex-direction:column; gap:4px; }
.nav-item { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:10px; text-decoration:none; font-size:13px; color:#cbd5e1; background:rgba(255,255,255,0.02); transition:.18s; }
.nav-item:hover { background:rgba(255,255,255,0.08); color:#fff; }
.nav-item.active { background:#0ea5e9; color:#fff; box-shadow:0 4px 14px rgba(14,165,233,.4); }
.sidebar.collapsed .nav-label { display:none; }
.nav-icon { font-size:16px; width:20px; text-align:center; }
.sidebar-footer { margin-top:auto; font-size:11px; display:flex; flex-direction:column; gap:4px; opacity:0.85; }
.sidebar-meta { color:#e2e8f0; }
.sidebar-meta.minor { font-size:10px; color:#94a3b8; }
@media (max-width: 860px) {
    .layout-with-sidebar { flex-direction:column; }
    .sidebar { position:relative; height:auto; width:100%; flex-direction:row; overflow-x:auto; }
    .sidebar.collapsed { width:100%; }
    .nav { flex-direction:row; flex-wrap:wrap; }
    .nav-item { flex:1 1 120px; }
    .content-wrapper { margin-left:0; }
}
.sidebar + .content-wrapper .topbar { margin-left:0; }
.sidebar.collapsed + .content-wrapper .topbar-title { transition:.2s; }


.topbar-left {
    display: flex;
    align-items: center;
    gap: 14px;
}

.logo-circle {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    background: var(--azul-wv-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #f9fafb;
    font-size: 14px;
    letter-spacing: 0.03em;
    box-shadow: 0 0 18px rgba(56, 189, 248, 0.55);
}

.topbar-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--texto-principal);
}

.topbar-subtitle {
    font-size: 12px;
    color: var(--texto-secundario);
}

.topbar-right {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Logout button */
.btn-logout {
    background: #dc2626;
    color: #fff;
    border: 1px solid #dc2626;
}
.btn-logout:hover {
    background: #b91c1c;
    border-color: #b91c1c;
}

/* ===== Cards / containers ===== */
.card {
    background: var(--fundo-card);
    border-radius: 16px;
    padding: 20px;
    border: 1px solid var(--borda-padrao);
    box-shadow: 0 4px 12px rgba(148, 163, 184, 0.15);
    margin-bottom: 18px;
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 16px;
}

.card-header h2 {
    font-size: 16px;
    font-weight: 600;
    color: var(--texto-principal);
    margin-bottom: 4px;
}

.card-header p {
    font-size: 13px;
    color: var(--texto-secundario);
}

.card-header.compact {
    margin-bottom: 10px;
}

/* ===== Grid system ===== */
.grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
    margin-bottom: 18px;
}

.grid-3 {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.theme-btn { background:#1e293b; border:1px solid #334155; color:#f1f5f9; padding:6px 10px; border-radius:8px; cursor:pointer; font-size:13px; }
.theme-btn:hover { background:#334155; }

/* ===== Dark theme component overrides ===== */
body[data-theme="dark"] .card { box-shadow: 0 6px 16px rgba(2, 6, 23, 0.6); }
body[data-theme="dark"] .table tbody tr:nth-child(even) { background: #0f172a; }
body[data-theme="dark"] .table tbody tr:nth-child(odd) { background: #0b1220; }
body[data-theme="dark"] .nav-item { color:#cbd5e1; background: rgba(255,255,255,0.04); }
body[data-theme="dark"] .nav-item:hover { background: rgba(255,255,255,0.08); color:#fff; }
body[data-theme="dark"] .footer { color: #94a3b8; }
body[data-theme="dark"] .json-block { background:#0f172a; color:#e2e8f0; border-color:#1f2937; }
body[data-theme="dark"] .text-input { background:#0f172a; color:#e2e8f0; border-color:#1f2937; }
body[data-theme="dark"] .text-input:focus { box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.35); }
body[data-theme="dark"] .upload-area { background:#0f172a; border-color:#1f2937; }
body[data-theme="dark"] .upload-area:hover { background:#0b1220; }

/* ===== KPI cards ===== */
.kpi-card {
    padding-top: 16px;
    padding-bottom: 16px;
}

.kpi-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--texto-secundario);
    margin-bottom: 6px;
}

.kpi-value {
    font-size: 24px;
    font-weight: 600;
    color: var(--texto-principal);
    margin-bottom: 6px;
}

.kpi-ok {
    color: #4ade80;
    font-size: 20px;
}

.kpi-footer {
    font-size: 12px;
    color: var(--texto-secundario);
}

/* ===== Upload ===== */
.upload-card {
    margin-top: 4px;
}

.upload-form-grid {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.form-label {
    font-size: 13px;
    color: var(--texto-principal);
}

.text-input {
    background: #fff;
    border: 1px solid var(--borda-padrao);
    border-radius: 10px;
    padding: 8px 10px;
    color: var(--texto-principal);
    font-size: 13px;
}

.text-input:focus {
    outline: none;
    border-color: var(--borda-foco);
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.35);
}

.upload-area {
    margin-top: 12px;
    border-radius: 14px;
    border: 2px dashed var(--borda-padrao);
    padding: 22px 18px;
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--fundo-secundario);
    cursor: pointer;
    transition: all 0.2s ease;
}

.upload-area:hover {
    border-color: var(--borda-foco);
    background: rgba(15, 23, 42, 0.95);
    transform: translateY(-1px);
}

.upload-icon {
    font-size: 22px;
}

.upload-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.upload-text strong {
    font-size: 14px;
    color: var(--texto-principal);
}

.upload-text span {
    font-size: 12px;
    color: var(--texto-secundario);
}

.upload-area input[type="file"] {
    display: none;
}

.upload-actions {
    margin-top: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.hint {
    font-size: 12px;
    color: var(--texto-secundario);
}

/* ===== Tabela ===== */
.table-wrapper {
    margin-top: 6px;
    border-radius: 12px;
    border: 1px solid rgba(148, 163, 184, 0.4);
    overflow: hidden;
}

.table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.table thead {
    background: var(--fundo-secundario);
}

.table th,
.table td {
    padding: 10px 12px;
    text-align: left;
}

.table th {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--texto-secundario);
    border-bottom: 1px solid rgba(148, 163, 184, 0.4);
}

.table tbody tr:nth-child(even) {
    background: #fff;
}

.table tbody tr:nth-child(odd) {
    background: var(--fundo-secundario);
}

.table tbody tr:hover {
    background: rgba(14, 165, 233, 0.1);
}

.table-actions {
    display: flex;
    gap: 10px;
}

/* ===== Links / botões ===== */
.link {
    font-size: 13px;
    color: var(--azul-wv);
    text-decoration: none;
}

.link:hover {
    text-decoration: underline;
}

.link-secondary {
    color: #a5b4fc;
}

.btn {
    border-radius: 999px;
    border: none;
    padding: 7px 14px;
    font-size: 13px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
}

.btn-primary {
    background: var(--azul-wv-gradient);
    color: var(--texto-inverso);
    box-shadow: 0 10px 25px rgba(37, 99, 235, 0.55);
}

.btn-primary:hover {
    filter: brightness(1.05);
    transform: translateY(-1px);
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--borda-padrao);
    color: var(--texto-principal);
}

.btn-outline:hover {
    background: var(--fundo-secundario);
    box-shadow: 0 6px 16px rgba(2,6,23,.18);
}

.btn-ghost {
    background: transparent;
    color: var(--texto-secundario);
}

.btn-ghost:hover {
    background: var(--fundo-secundario);
    box-shadow: 0 6px 16px rgba(2,6,23,.12);
}

/* ===== Badges ===== */
.badge {
    font-size: 11px;
    padding: 4px 9px;
    border-radius: 999px;
}

.badge-soft {
    background: rgba(56, 189, 248, 0.15);
    color: #7dd3fc;
    border: 1px solid rgba(56, 189, 248, 0.35);
}

/* ===== Estados ===== */
.empty-state {
    padding: 18px 4px 4px;
    font-size: 13px;
}

.empty-title {
    font-weight: 500;
    color: var(--texto-principal);
    margin-bottom: 3px;
}

.empty-text {
    color: var(--texto-secundario);
}

/* ===== Footer ===== */
.footer {
    max-width: 1120px;
    margin: 0 auto 20px;
    padding: 12px 24px 0;
    font-size: 12px;
    display: flex;
    justify-content: center;
    gap: 6px;
    opacity: 0.9;
    border-top: 1px solid #e5e7eb;
    color:#6b7280;
    background: #ffffff;
}
body[data-theme="dark"] .footer {
    border-top-color:#1f2937;
    color:#94a3b8;
    background:#0b1220;
}

/* Ensure page content does not get hidden under sticky header */
.content-wrapper .page { padding-top: 12px; }
.footer-dot { opacity:.7; }
.footer .links { margin-left:auto; display:flex; gap:12px; }
.footer .links a { color:#cbd5e1; text-decoration:none; font-weight:600; }
.footer .links a:hover { color:#22d3ee; }

.footer-dot {
    opacity: 0.5;
}

/* ===== Relatório ===== */
.json-block {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 12px;
    line-height: 1.45;
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    background: var(--fundo-secundario);
    color: var(--texto-principal);
    overflow-x: auto;
    border: 1px solid rgba(148, 163, 184, 0.5);
}

.mini-card {
    padding-top: 14px;
    padding-bottom: 14px;
}

.mini-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--texto-secundario);
    margin-bottom: 4px;
}

.mini-value {
    font-size: 14px;
    color: var(--texto-principal);
}

.mini-value.code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

/* ===== Sucesso upload ===== */
.success-box {
    margin-top: 12px;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(22, 163, 74, 0.14);
    border: 1px solid rgba(34, 197, 94, 0.45);
    display: flex;
    align-items: center;
    gap: 10px;
}

.success-icon {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: rgba(34, 197, 94, 0.23);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #bbf7d0;
    font-size: 14px;
}

.success-title {
    font-size: 14px;
    font-weight: 500;
    color: #15803d; /* Verde escuro para contraste */
}

.success-text {
    font-size: 12px;
    color: #166534; /* Verde escuro para contraste */
}

/* ===== Overlay de carregamento de upload ===== */
.loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.85);
    backdrop-filter: blur(6px);
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    z-index: 2000;
    color: #f1f5f9;
    text-align: center;
    padding: 24px;
}
.loading-overlay.visible { display: flex; }
.spinner {
    width: 48px;
    height: 48px;
    border: 5px solid rgba(255,255,255,0.25);
    border-top-color: #0ea5e9;
    border-radius: 50%;
    animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loading-text { font-size: 1rem; font-weight: 500; }
.loading-subtext { font-size: 0.75rem; max-width: 420px; line-height: 1.4; opacity: 0.85; }
.loading-files { display:flex; flex-direction:column; gap:6px; font-size:12px; max-width:420px; }
.file-progress-row { display:flex; align-items:center; justify-content:space-between; background:rgba(255,255,255,0.08); padding:6px 10px; border-radius:6px; }
.file-progress-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:240px; }
.badge-stage { font-size:10px; padding:4px 8px; border-radius:999px; background:#334155; color:#f1f5f9; }
.badge-stage.done { background:#166534; }
.badge-stage.error { background:#991b1b; }
.badge-stage.transcribing { background:#0ea5e9; }
.badge-stage.auditing { background:#2563eb; }
.badge-stage.saving { background:#4f46e5; }
.btn-cancel-upload { background:#475569; color:#fff; border:1px solid #475569; }
.btn-cancel-upload:hover { background:#334155; }
.pill-success { background:#dcfce7; border:1px solid #86efac; color:#166534; }
.pill-danger { background:#fee2e2; border:1px solid #fca5a5; color:#991b1b; }
.pill-progress { background:#e0f2fe; border:1px solid #7dd3fc; color:#0369a1; }
.pill-neutral { background:#e2e8f0; border:1px solid #cbd5e1; color:#475569; }

/* Drag & Drop */
.upload-area.drag-over { border-color:#0ea5e9; background:#e0f2fe; }

.actions-row {
    margin-top: 16px;
    display: flex;
    gap: 10px;
}

/* ===== Responsividade ===== */
@media (max-width: 640px) {
    .topbar {
        height: auto;
        padding: 10px 16px;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .page {
        margin-top: 96px;
        padding: 0 16px 18px;
    }

    .topbar-right {
        width: 100%;
        justify-content: flex-end;
    }

    .upload-area {
        flex-direction: column;
        align-items: flex-start;
    }

    .actions-row {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ===== Extensões do painel premium ===== */
.grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.grid-2 {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.grid-badges {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.filter-card .filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
}

.filter-actions {
    display: flex;
    gap: 10px;
    align-items: flex-end;
}

.badge-card {
    text-align: left;
    padding: 20px;
}

.badge-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--texto-secundario);
    margin-bottom: 6px;
}

.badge-value {
    font-size: 1.4rem;
    font-weight: 600;
    color: #f8fafc;
}

.badge-value.highlight {
    color: var(--azul-wv);
}

.badge-live {
    font-size: 0.85rem;
    color: #34d399;
}

.pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    border-radius: 999px;
    padding: 5px 12px;
    background: var(--fundo-secundario);
    color: var(--texto-principal);
    border: 1px solid rgba(148, 163, 184, 0.3);
}
.pill:hover { box-shadow: 0 6px 16px rgba(2,6,23,.12); }

.pill-type { background: rgba(14, 165, 233, 0.15); }
.pill-score { background: rgba(16, 185, 129, 0.15); }
.pill-sat { background: rgba(245, 158, 11, 0.15); }
.pill-risk { font-weight: 500; }
.pill-risk-alto { color: #991b1b; border-color: #fca5a5; background: #fee2e2; }
.pill-risk-medio { color: #92400e; border-color: #fdba74; background: #ffedd5; }
.pill-risk-baixo { color: #166534; border-color: #86efac; background: #dcfce7; }

.chip-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-height: 32px;
}

.chip {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.8rem;
    border: 1px solid rgba(148, 163, 184, 0.4);
    background: var(--fundo-secundario);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.chip-secondary {
    border-color: var(--azul-wv);
}

.chip input[type="checkbox"] {
    width: 14px;
    height: 14px;
}

.empty-inline {
    font-size: 0.85rem;
    color: var(--texto-secundario);
}

.steps-list {
    margin-left: 20px;
    color: var(--texto-principal);
    line-height: 1.5;
}

.relatorio-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.relatorio-item {
    border: 1px solid rgba(148, 163, 184, 0.35);
    border-radius: 16px;
    padding: 18px 20px;
    background: var(--fundo-card);
    backdrop-filter: blur(6px);
}

.relatorio-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
}

.relatorio-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--texto-principal);
}

.relatorio-meta {
    font-size: 0.8rem;
    color: var(--texto-secundario);
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 4px;
}

.relatorio-links {
    display: flex;
    gap: 12px;
    align-items: center;
}

.relatorio-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.advanced-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.advanced-grid .full-width {
    grid-column: 1 / -1;
}

.simple-list {
    list-style: none;
    padding: 0;
    margin: 8px 0 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    color: var(--texto-principal);
}

/* Toast */
.toast { position: fixed; right: 20px; bottom: 20px; background: var(--fundo-card); color: var(--texto-principal); border:1px solid var(--borda-padrao); border-radius:12px; padding:10px 14px; box-shadow: 0 10px 24px rgba(2,6,23,.18); z-index: 9999; }
.toast-success { border-color:#22c55e; }
.toast-error { border-color:#ef4444; }
.toast-info { border-color:#3b82f6; }

/* ===== Modal Overlay (export guard) ===== */
.modal-overlay { position: fixed; inset: 0; background: rgba(2,6,23,0.55); display: none; align-items: center; justify-content: center; z-index: 9998; }
.modal-overlay.visible { display: flex; }
.modal { background: var(--fundo-card); color: var(--texto-principal); border: 1px solid var(--borda-padrao); border-radius: 14px; padding: 16px 18px; max-width: 560px; width: 92%; box-shadow: 0 16px 48px rgba(2,6,23,.45); }
.modal h2 { margin: 0 0 6px; font-size: 18px; color: var(--texto-principal); }
.modal p { margin: 0 0 12px; color: var(--texto-secundario); }
.modal .chips { display:flex; gap:6px; flex-wrap:wrap; margin: 8px 0 14px; }
.modal .actions { display:flex; gap:8px; justify-content:flex-end; }

.chip-group .chip,
.pill,
.badge-card {
    backdrop-filter: blur(6px);
}

@media (max-width: 720px) {
    .relatorio-head {
        flex-direction: column;
    }
    .filter-actions {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ===== Acordeão de Critérios (relatorio.html) ===== */
.criteria-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 12px;
}
.criteria-item {
    border: 1px solid var(--borda-padrao);
    border-radius: 12px;
    background: var(--fundo-card);
}

/* ===== Dark theme fixes for panel cards/pills ===== */
body[data-theme="dark"] .relatorio-item {
    background: var(--fundo-card);
    border-color: var(--borda-padrao);
    backdrop-filter: none;
    box-shadow: 0 6px 16px rgba(2, 6, 23, 0.5);
}
body[data-theme="dark"] .relatorio-title { color: var(--texto-principal); }
body[data-theme="dark"] .relatorio-meta { color: var(--texto-secundario); }
body[data-theme="dark"] .relatorio-details { color: var(--texto-principal); }
body[data-theme="dark"] .pill { border-color: #334155; background: rgba(15,23,42,0.65); color: var(--texto-principal); }
body[data-theme="dark"] .pill-type { background: rgba(14,165,233,0.22); border-color: rgba(14,165,233,0.35); }
body[data-theme="dark"] .pill-score { background: rgba(16,185,129,0.22); border-color: rgba(16,185,129,0.35); }
body[data-theme="dark"] .pill-sat { background: rgba(245,158,11,0.22); border-color: rgba(245,158,11,0.35); }
body[data-theme="dark"] .btn-outline:hover { background: #0f172a; }
.criteria-summary {
    padding: 12px 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 12px;
    list-style: none; /* Remove a seta padrão */
}
.criteria-summary::-webkit-details-marker {
    display: none; /* Remove a seta no Chrome/Safari */
}
.criteria-title {
    flex-grow: 1;
    font-weight: 500;
    color: var(--texto-principal);
}
.criteria-details {
    padding: 0 16px 14px;
    border-top: 1px solid var(--borda-padrao);
    font-size: 0.9rem;
    color: var(--texto-secundario);
    line-height: 1.5;
}
