:root{--ink-900: #0f1226;--ink-700: #1f2347;--ink-500: #4b4f73;--ink-400: #6b6f93;--ink-300: #9aa0c3;--ink-200: #c8ccdf;--ink-100: #e6e8f2;--ink-50: #f3f4fb;--surface: #ffffff;--shell: #f5f6fb;--primary-900: #2a2f6e;--primary-700: #3b46a3;--primary-600: #4d5fbd;--primary-500: #5f6ccf;--primary-400: #8a7ad9;--primary-200: #c9c8ee;--primary-100: #e7e6fa;--primary-50: #f3f2fd;--accent-purple: #7a4dbd;--accent-rose: #e9b5b1;--ok: #2f9e7a;--ok-50: #e2f3ec;--warn: #c98515;--warn-50: #fbecd2;--danger: #c0392b;--danger-50: #fbe1dd;--info: #3a6fc4;--info-50: #e0eaf8;--dark-bg: #0a0d1f;--dark-bg-2: #11142b;--dark-line: #1f244a;--dark-glow: #5566d6;--radius-card: 22px;--radius-sm: 10px;--radius-pill: 999px;--shadow-soft: 0 1px 2px rgba(15, 18, 38, .04), 0 6px 22px -10px rgba(15, 18, 38, .08);--shadow-card: 0 1px 2px rgba(15, 18, 38, .04), 0 16px 40px -18px rgba(15, 18, 38, .18);--font-sans: "Satoshi", system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-sans);background:var(--shell);color:var(--ink-900);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","ss02"}a{color:inherit;text-decoration:none}button{font-family:inherit}.app{display:grid;grid-template-columns:256px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--ink-100);padding:24px 16px;display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:8px;padding:0 8px 4px}.brand-mark{width:30px;height:30px}.brand-text{font-weight:900;font-size:19px;letter-spacing:.04em;background:linear-gradient(90deg,var(--primary-700),var(--accent-purple));-webkit-background-clip:text;background-clip:text;color:transparent}.lang-toggle{display:inline-flex;background:var(--ink-50);border-radius:var(--radius-pill);padding:4px;width:max-content;margin:0 8px}.lang-toggle button{border:0;background:transparent;padding:6px 16px;font-size:12px;font-weight:700;color:var(--ink-400);border-radius:var(--radius-pill);cursor:pointer;letter-spacing:.04em}.lang-toggle button.active{background:var(--surface);color:var(--primary-700);box-shadow:0 1px 2px #0f122614}.nav-group{display:flex;flex-direction:column;gap:2px}.nav-group-label{font-size:10.5px;font-weight:700;letter-spacing:.14em;color:var(--ink-300);padding:14px 12px 8px;text-transform:uppercase;border-top:1px solid var(--ink-100);margin-top:6px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;color:var(--ink-500);font-weight:500;font-size:14.5px;cursor:pointer;border:0;background:transparent;width:100%;text-align:left;transition:background .12s ease,color .12s ease}.nav-item:hover{background:var(--ink-50);color:var(--ink-900)}.nav-item.active{background:var(--primary-50);color:var(--primary-700);font-weight:700}.nav-item .icon{width:18px;height:18px;display:inline-flex}.sidebar .spacer{flex:1}.cta-button{background:linear-gradient(135deg,var(--primary-700),var(--primary-600));color:#fff;border:0;padding:12px 16px;border-radius:14px;font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 8px 20px -10px #4d5fbdb3;display:inline-flex;align-items:center;justify-content:center;gap:8px}.cta-button:hover{filter:brightness(1.05)}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:16px;padding:16px 28px;background:var(--surface);border-bottom:1px solid var(--ink-100);position:sticky;top:0;z-index:10}.crumb{font-weight:700;color:var(--primary-700);font-size:14px}.search{flex:1;max-width:540px;display:flex;align-items:center;gap:8px;background:var(--ink-50);border-radius:var(--radius-pill);padding:8px 16px;border:1px solid transparent}.search:focus-within{border-color:var(--primary-200);background:var(--surface)}.search input{flex:1;border:0;outline:0;background:transparent;font-size:14px;color:var(--ink-900);font-family:inherit}.search input::placeholder{color:var(--ink-300)}.topbar-icons{display:flex;gap:10px;align-items:center;margin-left:auto}.icon-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--ink-100);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-500);cursor:pointer;position:relative}.icon-btn:hover{color:var(--primary-700);border-color:var(--primary-200)}.icon-btn .dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}.content{padding:28px;display:flex;flex-direction:column;gap:24px;max-width:1400px;width:100%}.hero{background:var(--surface);border-radius:var(--radius-card);padding:36px 40px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-40px;top:-40px;width:320px;height:320px;background:radial-gradient(circle at center,var(--accent-rose) 0%,transparent 70%);opacity:.35;pointer-events:none}.hero-pill{display:inline-block;background:var(--accent-rose);color:var(--ink-900);font-weight:700;font-size:11px;letter-spacing:.14em;padding:6px 14px;border-radius:var(--radius-pill);text-transform:uppercase}.hero h1{font-size:clamp(34px,4.6vw,56px);line-height:1.04;font-weight:900;letter-spacing:-.02em;margin:16px 0 14px;max-width:880px}.hero h1 .accent{background:linear-gradient(90deg,var(--primary-700),var(--accent-purple));-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{font-size:17px;color:var(--ink-500);max-width:640px;margin:0 0 22px;line-height:1.5}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.btn{padding:12px 20px;border-radius:14px;font-weight:700;font-size:14px;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease,filter .12s ease}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--primary-700);color:#fff;box-shadow:0 10px 24px -12px #3b46a3b3}.btn-secondary{background:var(--surface);color:var(--primary-700);border:1.5px solid var(--primary-200)}.btn-ghost{background:transparent;color:var(--ink-500);border:1.5px solid var(--ink-100)}.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi{background:var(--surface);border-radius:var(--radius-card);padding:22px 24px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.kpi-label{font-size:12px;color:var(--ink-400);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.kpi-value{font-size:32px;font-weight:900;letter-spacing:-.02em;color:var(--ink-900);font-family:var(--font-sans)}.kpi-trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--ok)}.kpi-trend.down{color:var(--danger)}.kpi.feature{background:linear-gradient(135deg,var(--primary-700) 0%,var(--primary-600) 100%);color:#fff}.kpi.feature .kpi-label,.kpi.feature .kpi-value{color:#fff}.kpi.feature .kpi-label{color:#ffffffb3}.section{background:var(--surface);border-radius:var(--radius-card);padding:24px 28px;box-shadow:var(--shadow-soft)}.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:16px;flex-wrap:wrap}.section-title{font-size:20px;font-weight:800;letter-spacing:-.01em;margin:0;color:var(--ink-900)}.section-sub{margin:4px 0 0;color:var(--ink-400);font-size:13.5px}.tabs{display:inline-flex;background:var(--ink-50);border-radius:var(--radius-pill);padding:4px;gap:2px}.tabs button{border:0;background:transparent;padding:7px 14px;font-size:13px;font-weight:600;color:var(--ink-400);border-radius:var(--radius-pill);cursor:pointer}.tabs button.active{background:var(--surface);color:var(--primary-700);box-shadow:0 1px 2px #0f122614}.tabs.dark{background:#ffffff0d}.tabs.dark button{color:#ffffff8c}.tabs.dark button.active{background:linear-gradient(135deg,var(--primary-700),var(--primary-500));color:#fff;box-shadow:0 4px 14px -4px #4d5fbd99}.graph-section{background:var(--dark-bg);color:#ffffffeb;border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-card);position:relative}.graph-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 0%,rgba(85,102,214,.18),transparent 60%),radial-gradient(ellipse at 90% 100%,rgba(122,77,189,.16),transparent 60%);pointer-events:none}.graph-header{padding:24px 28px 12px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;position:relative;z-index:1}.graph-header .section-title{color:#fff}.graph-header .section-sub{color:#ffffff80}.graph-body{display:grid;grid-template-columns:1fr 320px;gap:0;position:relative;z-index:1}.graph-canvas{position:relative;height:540px;border-top:1px solid var(--dark-line);background:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px) 0 0 / 28px 28px,linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px) 0 0 / 28px 28px}.graph-canvas svg{width:100%;height:100%;display:block}.graph-detail{border-left:1px solid var(--dark-line);border-top:1px solid var(--dark-line);padding:22px;background:#ffffff05;display:flex;flex-direction:column;gap:14px;min-height:540px}.graph-detail h3{margin:0;font-size:16px;font-weight:800;color:#fff}.graph-detail .kicker{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#ffffff8c;font-weight:700}.graph-detail .quote{background:#ffffff0a;border-left:3px solid var(--primary-500);padding:12px 14px;border-radius:8px;font-size:13px;line-height:1.5;color:#fffc;font-family:var(--font-mono)}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}.detail-row:last-child{border-bottom:0}.detail-row .key{color:#ffffff8c;font-weight:600}.detail-row .val{color:#fff;font-weight:700;font-family:var(--font-mono)}.review-actions{display:flex;gap:8px;margin-top:auto;flex-wrap:wrap}.chip-btn{flex:1;border:1px solid var(--dark-line);background:#ffffff0a;color:#fff;padding:9px 10px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;text-align:center}.chip-btn:hover{background:#ffffff14;border-color:var(--primary-500)}.chip-btn.approve{background:#2f9e7a26;border-color:#2f9e7a66;color:#8fe2c6}.chip-btn.reject{background:#c0392b26;border-color:#c0392b66;color:#f0a99e}.chip-btn.is-current{outline:2px solid rgba(255,255,255,.5);outline-offset:-2px;font-weight:800}.chip-btn:disabled{opacity:.35;cursor:not-allowed}.graph-filters{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:8px 28px 14px;position:relative;z-index:1;border-bottom:1px solid var(--dark-line)}.filter-group{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px}.filter-label{font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#ffffff80;margin-right:4px}.filter-chip{background:#ffffff0a;border:1px solid var(--dark-line);color:#ffffffb3;padding:5px 11px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.filter-chip:hover{background:#ffffff14;color:#fff}.filter-chip.active{background:linear-gradient(135deg,var(--primary-700),var(--primary-500));color:#fff;border-color:transparent;box-shadow:0 4px 14px -4px #4d5fbd99}.filter-count{margin-left:auto;font-size:12px;color:#ffffffa6;display:inline-flex;align-items:center;gap:10px}.filter-count .mono{color:#fff;font-weight:700}.filter-active-tag{background:#7a4dbd33;color:#d3c4ee;padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.graph-canvas svg [role=button]:focus{outline:none}.graph-canvas svg [role=button]:focus-visible rect,.graph-canvas svg [role=button]:focus-visible circle,.graph-canvas svg [role=button]:focus-visible polygon,.graph-canvas svg [role=button]:focus-visible path{stroke:#fff;stroke-width:2.6}.graph-legend{display:flex;flex-wrap:wrap;gap:14px;padding:12px 28px 20px;font-size:12px;color:#fff9;border-top:1px solid var(--dark-line);position:relative;z-index:1}.legend-item{display:inline-flex;align-items:center;gap:6px}.legend-swatch{width:16px;height:16px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center}.heatmap{display:grid;grid-template-columns:220px repeat(6,1fr);gap:4px;background:var(--ink-100);border-radius:14px;padding:4px;overflow:hidden}.heat-cell{background:var(--surface);padding:12px;display:flex;flex-direction:column;gap:4px;min-height:64px;font-size:12px;position:relative}.heat-head{background:var(--ink-50);font-weight:700;color:var(--ink-500);font-size:11px;letter-spacing:.06em;text-transform:uppercase;min-height:40px;align-items:flex-start;justify-content:center}.heat-row-label{background:var(--ink-50);font-weight:700;color:var(--ink-900);font-size:13.5px;letter-spacing:-.01em;text-transform:none;justify-content:center}.heat-cell.covered{background:var(--ok-50)}.heat-cell.partial{background:var(--warn-50)}.heat-cell.missing{background:var(--danger-50)}.heat-cell.conflict{background:#f0e1e6}.heat-cell.unknown{background:var(--ink-50)}.heat-status{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:11.5px;letter-spacing:.02em}.heat-status .badge-icon{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center}.heat-meta{font-size:11px;color:var(--ink-400);font-family:var(--font-mono)}.heat-cell.partial:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(135deg,transparent 0 6px,rgba(201,133,21,.12) 6px 7px);pointer-events:none;border-radius:inherit}.heat-cell.missing:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,transparent 0 8px,rgba(192,57,43,.1) 8px 9px);pointer-events:none;border-radius:inherit}.anomaly-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.anomaly-card{background:var(--surface);border:1px solid var(--ink-100);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.anomaly-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card);border-color:var(--primary-200)}.anomaly-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.anomaly-type{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-400)}.severity-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.severity-badge .dot{width:6px;height:6px;border-radius:50%}.severity-badge.high{background:var(--danger-50);color:var(--danger)}.severity-badge.high .dot{background:var(--danger)}.severity-badge.medium{background:var(--warn-50);color:var(--warn)}.severity-badge.medium .dot{background:var(--warn)}.severity-badge.low{background:var(--info-50);color:var(--info)}.severity-badge.low .dot{background:var(--info)}.anomaly-title{font-size:15px;font-weight:800;line-height:1.3;color:var(--ink-900);margin:0}.anomaly-body{font-size:13px;color:var(--ink-500);margin:0;line-height:1.45}.anomaly-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:11.5px;color:var(--ink-400)}.anomaly-meta .pill{background:var(--ink-50);border-radius:var(--radius-pill);padding:3px 10px;font-weight:600}.anomaly-action{margin-top:auto;display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:10px;border-top:1px dashed var(--ink-100)}.anomaly-action .next{font-size:12px;color:var(--ink-500);font-weight:600}.anomaly-action .go{background:var(--primary-50);color:var(--primary-700);font-weight:700;font-size:12px;padding:6px 12px;border-radius:var(--radius-pill);border:0;cursor:pointer}.anomaly-action .go:hover{background:var(--primary-100)}.source-list{display:flex;flex-direction:column;gap:10px}.source-row{display:grid;grid-template-columns:28px 1fr auto auto;gap:14px;padding:12px 14px;border-radius:14px;background:var(--ink-50);align-items:center}.source-row .file-icon{width:28px;height:28px;border-radius:6px;background:var(--primary-100);color:var(--primary-700);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;font-family:var(--font-mono)}.source-row .name{font-weight:700;font-size:14px;color:var(--ink-900)}.source-row .meta{font-size:12px;color:var(--ink-400)}.source-row .tag{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--surface);padding:4px 10px;border-radius:var(--radius-pill);color:var(--ink-500);border:1px solid var(--ink-100)}@media (max-width: 1100px){.graph-body{grid-template-columns:1fr}.graph-detail{min-height:auto;border-left:0}.graph-canvas{height:420px}.heatmap{grid-template-columns:160px repeat(6,minmax(110px,1fr));overflow-x:auto}.kpi-strip{grid-template-columns:repeat(2,1fr)}.graph-filters{padding:8px 18px 12px;gap:10px}.filter-count{margin-left:0;width:100%}}@media (max-width: 820px){.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:12px;padding:14px 16px}.sidebar .nav-group{display:none}.sidebar .nav-group.mobile{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px}.sidebar .nav-group.mobile .nav-item{width:auto;padding:8px 12px}.sidebar .nav-group.mobile .nav-group-label,.sidebar .spacer{display:none}.sidebar .lang-toggle{margin:0}.sidebar .cta-button{margin-left:auto}.content{padding:16px}.hero{padding:24px}.topbar{padding:12px 16px;gap:10px}.topbar .crumb{display:none}.kpi-strip{grid-template-columns:1fr 1fr}.heatmap{grid-template-columns:140px repeat(6,minmax(100px,1fr))}.graph-canvas{height:360px}.hero h1{font-size:32px}.section{padding:18px}.source-row{grid-template-columns:24px 1fr auto}.source-row>button{display:none}}.flex{display:flex}.row{display:flex;align-items:center;gap:8px}.muted{color:var(--ink-400)}.mono{font-family:var(--font-mono)}.grow{flex:1}.hidden{display:none}
