:root{--bg:#f5f7fa;--surface:#fff;--surface-2:#f0f3f7;--border:#e2e8f0;--text:#1a2233;--text-muted:#64748b;--primary:#2563eb;--primary-dark:#1d4ed8;--sidebar-bg:#0f172a;--sidebar-text:#cbd5e1;--sidebar-active:#1e293b;--green:#16a34a;--green-bg:#dcfce7;--yellow:#ca8a04;--yellow-bg:#fef9c3;--orange:#ea580c;--orange-bg:#ffedd5;--red:#dc2626;--red-bg:#fee2e2;--gray:#475569;--gray-bg:#e2e8f0;--radius:10px;--shadow:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.04)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px}a{color:inherit;text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;height:100vh}.sidebar-brand{padding:20px 20px 12px;font-size:18px;font-weight:700;color:#fff;letter-spacing:.3px}.sidebar-brand small{display:block;font-size:11px;font-weight:400;color:#64748b;margin-top:2px}.sidebar-section{padding:16px 20px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--sidebar-text);font-size:14px;border-left:3px solid transparent}.nav-item.active,.nav-item:hover{background:var(--sidebar-active);color:#fff}.nav-item.active{border-left-color:var(--primary)}.nav-item.disabled{opacity:.5;cursor:not-allowed}.nav-badge{margin-left:auto;font-size:10px;background:#334155;border-radius:6px;padding:1px 6px}.main{flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px}.topbar .spacer{flex:1 1}.content{padding:24px;width:100%}.page-title{font-size:22px;font-weight:700;margin:0 0 4px}.page-subtitle{color:var(--text-muted);margin:0 0 20px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card.clickable{cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.card.clickable:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(15,23,42,.1);border-color:var(--primary)}.card-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.card-value{font-size:28px;font-weight:700;margin-top:6px}.card-sub{font-size:12px;color:var(--text-muted);margin-top:6px}.progress{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden;margin-top:10px}.progress>span{display:block;height:100%;background:var(--primary)}.progress.warn>span{background:var(--orange)}.progress.full>span{background:var(--red)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.panel-header{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);flex-wrap:wrap}.panel-title{font-weight:600;font-size:15px}.table-wrap{overflow-x:auto;width:100%}table{width:100%;min-width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}td,th{text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.cell-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}th{background:var(--surface-2);font-weight:600;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}th .sort-ind{color:var(--primary);margin-left:4px}tbody tr.clickable{cursor:pointer}tbody tr.clickable:hover{background:var(--surface-2)}.empty{padding:32px;text-align:center;color:var(--text-muted)}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.6}.badge.green{color:var(--green);background:var(--green-bg)}.badge.yellow{color:var(--yellow);background:var(--yellow-bg)}.badge.orange{color:var(--orange);background:var(--orange-bg)}.badge.red{color:var(--red);background:var(--red-bg)}.badge.gray{color:var(--gray);background:var(--gray-bg)}.badge.blue{color:var(--primary);background:#dbeafe}input,select,textarea{font:inherit;padding:7px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text)}textarea{resize:vertical;width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:-1px}label.field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}label.check{display:flex;align-items:center;gap:6px;font-size:13px}.btn,label.check{color:var(--text);cursor:pointer}.btn{font:inherit;font-weight:600;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface)}.btn:hover{background:var(--surface-2)}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn:disabled{opacity:.6;cursor:not-allowed}.filters{gap:12px;align-items:flex-end;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}.filters,.toolbar{display:flex;flex-wrap:wrap}.toolbar{gap:10px;align-items:center}.reasons{display:flex;flex-direction:column;gap:3px;white-space:normal;max-width:280px}.reason-chip{font-size:11px;color:var(--text-muted)}.center-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px}.muted{color:var(--text-muted)}.banner{padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid var(--border)}.banner.error{background:var(--red-bg);border-color:#fca5a5;color:var(--red)}.banner.info{background:#dbeafe;border-color:#93c5fd;color:var(--primary-dark)}.sidebar-logo{display:block;max-height:40px;max-width:180px;margin-bottom:8px;object-fit:contain}.delta{margin-top:8px;font-size:13px;font-weight:600}.delta .delta-arrow{font-size:11px}.delta.good{color:var(--green)}.delta.bad{color:var(--red)}.delta.neutral{color:var(--text-muted);font-weight:500}.delta .delta-note{color:var(--text-muted);font-weight:400;font-size:12px}.chip-group{display:flex;flex-wrap:wrap;gap:6px}.chip{font:inherit;font-size:12px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}.chip:hover{background:var(--surface-2)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.floating-layer{z-index:1000}.score-cell{display:inline-block}.score-trigger{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:0;font:inherit}.score-num{font-size:11px;color:var(--text-muted)}.score-popover{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(15,23,42,.18);padding:12px;white-space:normal;text-align:left}.score-popover-head{font-weight:700;margin-bottom:8px}.score-popover-list{margin:0;padding-left:16px;font-size:13px;line-height:1.6}.score-popover-list strong{color:var(--primary)}.score-popover-foot{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:13px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px}.chart-body{padding:16px}.diff-row{display:flex;flex-wrap:wrap;gap:28px;padding:18px}.diff-item{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.diff-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.diff-item .badge{font-size:16px}.multiselect{position:relative}.multiselect-trigger{font:inherit;display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer;min-width:160px}.multiselect-trigger .caret{margin-left:auto;color:var(--text-muted)}.multiselect-panel{max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(15,23,42,.18);padding:8px}.multiselect-panel label{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;white-space:nowrap}.multiselect-panel label:hover{background:var(--surface-2)}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:100;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 20px 60px rgba(15,23,42,.3);width:100%;max-width:720px}.modal-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-title{font-size:17px;font-weight:700}.modal-close{margin-left:auto;background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--text-muted)}.modal-body{padding:20px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:14px 24px;gap:14px 24px;margin-bottom:18px}.detail-item .detail-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.detail-item .detail-value{font-size:14px;margin-top:2px}.detail-section-title{font-weight:600;margin:18px 0 8px;font-size:14px}.license-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:3px 8px;margin:0 4px 4px 0;font-size:12px}@media (max-width:720px){.chart-grid{grid-template-columns:1fr}.sidebar{width:200px}.cell-truncate{max-width:160px}}