*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; -webkit-font-smoothing: antialiased; }

body {
    font-family: var(--font);
    font-size: var(--fs-base);
    color: var(--text);
    background: var(--bg);
    line-height: 1.5;
    min-height: 100vh;
    overflow: hidden;
}

a { color: var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; }

button {
    font-family: inherit;
    font-size: inherit;
    cursor: pointer;
    border: none;
    background: none;
}

img, svg { display: block; max-width: 100%; }

input, select, textarea {
    font-family: inherit;
    font-size: inherit;
}

/* Utility */
.sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); border: 0;
}

.badge {
    display: inline-flex;
    align-items: center;
    padding: var(--sp-1) var(--sp-2);
    border-radius: var(--radius-full);
    font-size: var(--fs-xs);
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.badge-a { background: var(--score-a); color: #fff; }
.badge-b { background: var(--score-b); color: #fff; }
.badge-c { background: var(--score-c); color: #1a1a1a; }
.badge-d { background: var(--score-d); color: #fff; }
.badge-e { background: var(--score-e); color: #fff; }

.badge-nenhuma { background: var(--sev-nenhuma); color: #fff; }
.badge-baixa { background: var(--sev-baixa); color: #fff; }
.badge-media { background: var(--sev-media); color: #1a1a1a; }
.badge-alta { background: var(--sev-alta); color: #fff; }
.badge-critica { background: var(--sev-critica); color: #fff; }

.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    padding: var(--sp-2) var(--sp-4);
    border-radius: var(--radius);
    font-weight: 500;
    font-size: var(--fs-sm);
    transition: all var(--transition);
    white-space: nowrap;
}

.btn-primary {
    background: var(--color-primary);
    color: #fff;
}
.btn-primary:hover { background: var(--color-primary-hover); }

.btn-outline {
    border: 1px solid var(--card-border);
    color: var(--text);
    background: var(--card);
}
.btn-outline:hover { border-color: var(--color-primary); color: var(--color-primary); }

.btn-ghost {
    color: var(--text-secondary);
}
.btn-ghost:hover { color: var(--text); background: rgba(0,0,0,0.04); }

.card {
    background: var(--card);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-5);
    box-shadow: var(--shadow);
}

.card-dark {
    background: var(--dark-card);
    border-color: var(--dark-card-border);
    color: var(--text-on-dark);
}

.loading-spinner {
    width: 24px; height: 24px;
    border: 3px solid var(--card-border);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.empty-state {
    text-align: center;
    padding: var(--sp-12) var(--sp-4);
    color: var(--text-muted);
}
.empty-state svg { margin: 0 auto var(--sp-4); opacity: 0.4; }

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--text-muted); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-secondary); }
