* { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; background: #0a0a0a; color: #e0e0e0; font-size: 13px; line-height: 1.5; min-height: 100vh; } .header { padding: 16px 24px; background: #0f0f0f; border-bottom: 1px solid #1e1e1e; display: flex; flex-direction: column; gap: 12px; } .header-left { display: flex; align-items: center; gap: 10px; } .header-icon { width: 32px; height: 32px; } .header-left h1 { font-size: 20px; font-weight: 700; color: #fff; } .version { font-size: 11px; color: #555; font-weight: 400; } .header-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: space-between; } .filter-group { display: flex; gap: 8px; flex-wrap: wrap; } .filter-group select, .filter-group input { padding: 6px 10px; background: #141414; border: 1px solid #2a2a2a; border-radius: 6px; color: #ccc; font-size: 12px; outline: none; } .filter-group select:focus, .filter-group input:focus { border-color: #4a9eff; } .filter-group input { min-width: 180px; } .btn-group { display: flex; gap: 6px; } .btn { padding: 6px 14px; border: none; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: all 0.15s; } .btn-secondary { background: #1a1a1a; color: #ccc; border: 1px solid #2a2a2a; } .btn-secondary:hover { background: #222; border-color: #444; } .btn-danger { background: #2a1515; color: #ff6b6b; border: 1px solid #4a2020; } .btn-danger:hover { background: #3a1a1a; } .stats-bar { display: flex; gap: 1px; padding: 12px 24px; background: #0f0f0f; border-bottom: 1px solid #1e1e1e; } .stat-item { flex: 1; display: flex; flex-direction: column; align-items: center; padding: 10px; background: #111; border-radius: 6px; margin: 0 4px; } .stat-num { font-size: 20px; font-weight: 700; color: #fff; } .stat-lbl { font-size: 10px; color: #555; text-transform: uppercase; letter-spacing: 0.5px; } .stat-critical .stat-num { color: #ff4444; } .stat-high .stat-num { color: #ff8c42; } .stat-medium .stat-num { color: #ffd166; } .stat-low .stat-num { color: #4ecdc4; } .main { padding: 16px 24px; } .findings-table { width: 100%; border-collapse: collapse; font-size: 12px; } .findings-table thead th { padding: 8px 10px; text-align: left; font-size: 10px; font-weight: 600; color: #555; text-transform: uppercase; letter-spacing: 0.5px; border-bottom: 1px solid #1e1e1e; white-space: nowrap; position: sticky; top: 0; background: #0a0a0a; } .findings-table tbody tr { border-bottom: 1px solid #141414; transition: background 0.1s; } .findings-table tbody tr:hover { background: #111; } .findings-table td { padding: 8px 10px; vertical-align: middle; max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .badge { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 700; letter-spacing: 0.3px; } .badge-critical { background: #3a0a0a; color: #ff4444; border: 1px solid #5a1515; } .badge-high { background: #3a1f0a; color: #ff8c42; border: 1px solid #5a3015; } .badge-medium { background: #3a3a0a; color: #ffd166; border: 1px solid #5a5a15; } .badge-low { background: #0a3a30; color: #4ecdc4; border: 1px solid #155a4a; } .type-badge { display: inline-block; padding: 2px 6px; background: #1a1a1a; border: 1px solid #2a2a2a; border-radius: 4px; font-size: 10px; color: #888; font-family: "SF Mono", "Fira Code", monospace; } .match-value { font-family: "SF Mono", "Fira Code", "Consolas", monospace; font-size: 11px; background: #141414; padding: 2px 6px; border-radius: 4px; border: 1px solid #1e1e1e; color: #4ecdc4; max-width: 260px; display: inline-block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; cursor: pointer; } .td-provider { font-weight: 600; color: #aaa; } .td-pattern { color: #888; font-size: 11px; } .td-domain { color: #4a9eff; } .td-time { color: #555; font-size: 11px; white-space: nowrap; } a { color: #4a9eff; text-decoration: none; } a:hover { text-decoration: underline; } .btn-icon { padding: 3px 8px; background: #1a1a1a; border: 1px solid #2a2a2a; border-radius: 4px; color: #888; font-size: 10px; cursor: pointer; margin-right: 4px; transition: all 0.1s; } .btn-icon:hover { background: #222; color: #ccc; } .btn-icon-danger:hover { background: #2a1515; color: #ff6b6b; border-color: #4a2020; } .empty-state { text-align: center; padding: 60px 20px; color: #444; } .empty-icon { font-size: 48px; margin-bottom: 16px; opacity: 0.3; } .empty-state p { font-size: 14px; max-width: 400px; margin: 0 auto; line-height: 1.6; } ::-webkit-scrollbar { width: 6px; height: 6px; } ::-webkit-scrollbar-track { background: transparent; } ::-webkit-scrollbar-thumb { background: #333; border-radius: 4px; }