html,body,#root{margin:0;padding:0;width:100%;height:100%;background:#f7f8fa}body{font-family:Noto Sans SC,PingFang SC,sans-serif;color:#0f172a}:root{--bg-page: #F7F8FA;--bg-surface: #FFFFFF;--bg-surface-2: #F4F6FA;--bg-elevated: #FFFFFF;--bg-hover: rgba(15, 23, 42, .04);--bg-active: rgba(0, 168, 138, .08);--border: #ECEEF2;--border-strong: #DDE1E8;--border-accent: rgba(0, 168, 138, .45);--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #64748B;--text-muted: #94A3B8;--text-on-accent: #FFFFFF;--accent: #00A88A;--accent-hover: #00C29D;--accent-dim: rgba(0, 168, 138, .12);--accent-soft: rgba(0, 168, 138, .05);--sev-critical: #DC2626;--sev-critical-bg: rgba(220, 38, 38, .08);--sev-high: #EA580C;--sev-high-bg: rgba(234, 88, 12, .08);--sev-medium: #B45309;--sev-medium-bg: rgba(180, 83, 9, .1);--sev-low: #2563EB;--sev-low-bg: rgba(37, 99, 235, .08);--sev-none: #94A3B8;--sev-none-bg: rgba(148, 163, 184, .12);--lic-risk-high: #DC2626;--lic-risk-med: #EA580C;--lic-risk-low: #2563EB;--lic-risk-ok: #00A88A;--status-success: #00A88A;--status-warning: #B45309;--status-error: #DC2626;--status-info: #2563EB;--status-pending: #94A3B8;--font-sans: "Space Grotesk", "Inter", -apple-system, "PingFang SC", "Microsoft YaHei", "Noto Sans SC", sans-serif;--font-cn: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", ui-monospace, Menlo, Consolas, monospace;--shadow-card: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);--shadow-pop: 0 20px 50px -20px rgba(15,23,42,.18), 0 0 0 1px rgba(15,23,42,.04);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px}*{box-sizing:border-box}.sca-app,.sca-app *{font-family:var(--font-cn);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sca-app{background:var(--bg-page);color:var(--text-primary);width:100%;height:100%;position:relative;overflow:hidden;letter-spacing:.005em}.sca-app:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(15,23,42,.04) 1px,transparent 0);background-size:24px 24px;pointer-events:none;z-index:0;-webkit-mask-image:linear-gradient(180deg,#0009,#0000004d);mask-image:linear-gradient(180deg,#0009,#0000004d)}.mono{font-family:var(--font-mono);font-feature-settings:"ss01","cv01"}.num{font-family:var(--font-sans);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.app-shell{display:grid;grid-template-columns:232px 1fr;height:100vh;position:relative;z-index:1}.main{display:flex;flex-direction:column;min-width:0;background:var(--bg-page);height:100vh}.content{flex:1;padding:28px 36px 40px;overflow:auto}.sidebar{background:#fbfcfd;border-right:1px solid var(--border);padding:22px 14px 18px;display:flex;flex-direction:column;gap:4px;position:relative}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:4px 10px 22px;border-bottom:1px solid var(--border);margin-bottom:16px}.brand-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,#008C72 100%);display:grid;place-items:center;font-family:var(--font-sans);font-weight:700;font-size:13px;color:#fff;letter-spacing:-.03em;position:relative;box-shadow:0 0 0 1px #00a88a33,0 4px 10px -2px #00a88a66}.brand-mark:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1.5px solid rgba(255,255,255,.5);border-radius:4px;border-bottom-color:transparent;border-right-color:transparent}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-text .product{font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:.01em}.brand-text .company{font-size:10.5px;color:var(--text-tertiary);margin-top:2px;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-sans)}.nav-section-label{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding:14px 10px 6px;font-family:var(--font-sans);font-weight:600}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:var(--r-sm);color:var(--text-secondary);font-size:13.5px;font-weight:500;cursor:pointer;position:relative;text-decoration:none}.nav-item .nav-icon{width:16px;height:16px;opacity:.7;flex-shrink:0}.nav-item .nav-count{margin-left:auto;font-family:var(--font-sans);font-variant-numeric:tabular-nums;font-size:11px;color:var(--text-tertiary);background:var(--bg-surface-2);border-radius:4px;padding:1px 6px}.nav-item:hover{background:var(--bg-hover)}.nav-item.active{background:var(--bg-active);color:var(--accent);font-weight:600}.nav-item.active .nav-icon{opacity:1}.nav-item.active:before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:2px;background:var(--accent);border-radius:0 2px 2px 0}.nav-item.active .nav-count{background:var(--accent-dim);color:var(--accent)}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#5b8def,#3955b5);display:grid;place-items:center;font-size:11px;font-weight:600;color:#fff;letter-spacing:.02em}.user-info{flex:1;min-width:0;line-height:1.2}.user-info .name{font-size:12.5px;color:var(--text-primary);font-weight:500}.user-info .org{font-size:10.5px;color:var(--text-tertiary);margin-top:2px;font-family:var(--font-sans)}.topbar{height:56px;border-bottom:1px solid var(--border);padding:0 36px;display:flex;align-items:center;gap:16px;background:var(--bg-surface);flex-shrink:0}.crumb{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-tertiary);font-family:var(--font-sans)}.crumb .here{color:var(--text-primary);font-weight:500}.crumb .sep{color:var(--text-muted)}.search-input{margin-left:8px;background:var(--bg-surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:7px 12px 7px 32px;color:var(--text-tertiary);font-size:12.5px;width:280px;position:relative}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:var(--r-sm);color:var(--text-secondary);background:transparent;border:1px solid transparent;position:relative;cursor:pointer}.icon-btn:hover{background:var(--bg-hover)}.icon-btn .dot{position:absolute;top:7px;right:7px;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px var(--bg-surface)}.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.page-head .pg-title{font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--text-primary)}.page-head .pg-sub{font-size:13px;color:var(--text-tertiary);margin-top:4px;line-height:1.5}.page-head .pg-actions{margin-left:auto;display:flex;gap:10px;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 14px;border-radius:var(--r-sm);font-size:13px;font-weight:500;font-family:var(--font-cn);border:1px solid transparent;cursor:pointer;letter-spacing:.01em;white-space:nowrap}.btn svg{width:14px;height:14px}.btn-primary{background:var(--accent);color:#fff;font-weight:600;box-shadow:0 1px 2px #00a88a33,0 4px 12px -4px #00a88a73}.btn-primary:hover{background:var(--accent-hover);transition:background 50ms}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-strong);box-shadow:0 1px 2px #0f172a0a}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover)}.btn-danger{background:var(--sev-critical-bg);color:var(--sev-critical);border-color:#dc262640}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon-only{padding:7px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);position:relative;box-shadow:var(--shadow-card)}.card-head{padding:16px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.card-head .ttl{font-size:13.5px;font-weight:600;letter-spacing:.005em;color:var(--text-primary)}.card-head .sub{font-size:11.5px;color:var(--text-tertiary);font-family:var(--font-sans);margin-left:4px}.card-head .right{margin-left:auto;display:flex;gap:8px;align-items:center}.card-body{padding:18px}.card-body.compact{padding:12px 18px}.stat{padding:18px 18px 16px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-surface);position:relative;overflow:hidden;box-shadow:var(--shadow-card)}.stat .label{font-size:11.5px;color:var(--text-tertiary);font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.stat .value{margin-top:10px;font-size:30px;font-weight:600;font-family:var(--font-sans);letter-spacing:-.025em;font-variant-numeric:tabular-nums;line-height:1;color:var(--text-primary)}.stat .delta{margin-top:10px;display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-family:var(--font-sans);font-variant-numeric:tabular-nums}.delta.up{color:var(--sev-critical)}.delta.down{color:var(--accent)}.delta.flat{color:var(--text-tertiary)}.sev{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:11px;font-family:var(--font-sans);font-weight:600;letter-spacing:.04em;text-transform:uppercase;line-height:1.5}.sev:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.sev.critical{background:var(--sev-critical-bg);color:var(--sev-critical)}.sev.high{background:var(--sev-high-bg);color:var(--sev-high)}.sev.medium{background:var(--sev-medium-bg);color:var(--sev-medium)}.sev.low{background:var(--sev-low-bg);color:var(--sev-low)}.sev.none{background:var(--sev-none-bg);color:var(--sev-none)}.tag{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--r-sm);font-size:11px;font-family:var(--font-sans);font-weight:500;border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-surface);line-height:1.5}.tag.success{color:var(--accent);background:var(--accent-soft);border-color:#00a88a40}.tag.warning{color:var(--sev-medium);background:var(--sev-medium-bg);border-color:#b4530940}.tag.danger{color:var(--sev-critical);background:var(--sev-critical-bg);border-color:#dc262640}.tag.info{color:var(--sev-low);background:var(--sev-low-bg);border-color:#2563eb40}.tag.muted{color:var(--text-tertiary);background:var(--bg-surface-2)}.tag .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.tbl{width:100%;border-collapse:collapse;font-size:12.5px}.tbl th{text-align:left;font-weight:500;font-size:11px;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:11px 14px;border-bottom:1px solid var(--border);background:var(--bg-surface-2)}.tbl td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--bg-hover)}.tbl .nm{color:var(--text-primary);font-weight:500}.tbl .mono{color:var(--text-secondary);font-size:12px}.tbl .num{color:var(--text-primary);font-variant-numeric:tabular-nums}.input,.select{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:8px 12px;color:var(--text-primary);font-size:13px;font-family:var(--font-cn);width:100%;height:36px;display:flex;align-items:center;box-shadow:inset 0 1px #0f172a05}.input:focus,.select:focus{outline:none;border-color:var(--accent)}.input.with-prefix{padding-left:32px}.label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:7px}.label .req{color:var(--sev-critical);margin-left:2px}.help{font-size:11.5px;color:var(--text-tertiary);margin-top:6px;line-height:1.5;font-family:var(--font-sans)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:10px 14px;font-size:13px;color:var(--text-secondary);border-bottom:2px solid transparent;font-weight:500;margin-bottom:-1px;display:flex;align-items:center;gap:7px;cursor:pointer}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.tab .ct{font-size:11px;font-family:var(--font-sans);background:var(--bg-surface-2);border-radius:4px;padding:1px 6px;font-variant-numeric:tabular-nums;color:var(--text-tertiary)}.tab.active .ct{background:var(--accent-dim);color:var(--accent)}.divider{height:1px;background:var(--border);margin:16px 0}.row{display:flex;align-items:center;gap:10px}.col{display:flex;flex-direction:column;gap:10px}.spread{display:flex;align-items:center;justify-content:space-between}.hairline{border-bottom:1px dashed var(--border-strong)}.kbd{font-family:var(--font-mono);font-size:10.5px;padding:1px 5px;background:var(--bg-surface-2);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;color:var(--text-secondary)}
