/* ============================================
   ANTIGRAVITY DAST — PAGE STYLES
   ============================================ */

/* === LOGIN PAGE === */
.login-page {
    display: flex; align-items: center; justify-content: center;
    min-height: 100vh; padding: 2rem;
}
.login-card {
    width: 100%; max-width: 420px;
    background: var(--bg-card); border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl); padding: 2.5rem;
    backdrop-filter: blur(16px); animation: slideUp 0.5s ease;
}
.login-logo { text-align: center; margin-bottom: 2rem; }
.login-logo h1 { font-size: 1.5rem; background: var(--accent-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.login-logo p { color: var(--text-muted); font-size: 0.875rem; margin-top: 0.25rem; }
.login-error { padding: 0.75rem; background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.2); border-radius: var(--radius-sm); color: var(--color-fail); font-size: 0.8125rem; margin-bottom: 1rem; }

/* === DASHBOARD === */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 2rem; }
.stat-card { text-align: center; padding: 1.5rem; }
.stat-label { font-size: 0.75rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.5rem; }
.stat-value { font-size: 2rem; font-weight: 800; }
.stat-value.critical { color: var(--color-critical); }
.stat-value.moderate { color: var(--color-moderate); }
.stat-value.low { color: var(--color-low); }
.stat-value.total { background: var(--accent-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

/* === TEST SELECTOR === */
.category-section { margin-bottom: 2rem; }
.category-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0.75rem 1rem; background: var(--bg-tertiary);
    border-radius: var(--radius-md); margin-bottom: 1rem; cursor: pointer;
}
.category-badge { font-size: 0.75rem; font-weight: 700; padding: 0.25rem 0.75rem; border-radius: 999px; }
.category-critical { background: rgba(239,68,68,0.15); color: var(--color-critical); }
.category-moderate { background: rgba(245,158,11,0.15); color: var(--color-moderate); }
.category-low { background: rgba(34,197,94,0.15); color: var(--color-low); }

/* === RESULTS === */
.result-row { cursor: pointer; }
.result-detail {
    padding: 1.5rem; background: var(--bg-tertiary);
    border-radius: var(--radius-md); margin: 0.5rem 0;
    animation: fadeIn 0.3s ease;
}
.evidence-screenshot { max-width: 100%; border-radius: var(--radius-md); border: 1px solid var(--border-subtle); margin-top: 1rem; }
.evidence-json { font-family: var(--font-mono); font-size: 0.8125rem; background: var(--bg-primary); padding: 1rem; border-radius: var(--radius-sm); overflow-x: auto; white-space: pre-wrap; color: var(--text-accent); }

/* === AUDIT LOG === */
.audit-filters { display: flex; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.audit-filters .form-input { width: auto; min-width: 200px; }
.action-tag { font-family: var(--font-mono); font-size: 0.75rem; padding: 0.125rem 0.5rem; border-radius: var(--radius-sm); }
.action-login { background: rgba(16,185,129,0.15); color: var(--color-pass); }
.action-failed { background: rgba(239,68,68,0.15); color: var(--color-fail); }
.action-change { background: rgba(59,130,246,0.15); color: var(--color-info); }
.action-run { background: rgba(99,102,241,0.15); color: var(--accent-secondary); }

/* === RUNNING INDICATOR === */
.run-progress { margin: 2rem 0; }
.run-status { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.spinner { width: 20px; height: 20px; border: 2px solid var(--border-medium); border-top-color: var(--accent-primary); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* === REPORT CUSTOM === */
.report-meta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    background: rgba(255, 255, 255, 0.03);
    padding: 15px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.report-details-row.hidden {
    display: none !important;
}

.report-details-row {
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}
