:root{--c-primary:#0f3460;--c-accent:#e94560;--c-bg:#f8f9ff;--c-text:#1a1a2e;--c-surface:#fff;--c-border:#e2e6ef;--c-muted:#6b7a99;--sidebar-w:200px;--topbar-h:56px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--c-bg);color:var(--c-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.login-wrap{background:linear-gradient(135deg,#0f3460 0%,#16213e 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:var(--c-surface);text-align:center;border-radius:16px;width:380px;max-width:90vw;padding:48px 40px;box-shadow:0 20px 60px #0000004d}.login-logo{background:var(--c-primary);width:64px;height:64px;color:var(--c-accent);border-radius:16px;margin:0 auto 16px;font-size:36px;font-weight:800;line-height:64px}.login-box h1{color:var(--c-primary);margin-bottom:4px;font-size:22px}.login-sub{color:var(--c-muted);margin-bottom:28px;font-size:13px}.login-box input{border:2px solid var(--c-border);border-radius:8px;outline:none;width:100%;margin-bottom:16px;padding:12px 16px;font-size:14px;transition:border-color .2s}.login-box input:focus{border-color:var(--c-primary)}.login-box button{background:var(--c-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s}.login-box button:hover{background:#16213e}.login-box button:disabled{opacity:.5;cursor:not-allowed}.login-err{color:var(--c-accent);margin-top:12px;font-size:13px}.app{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;min-height:100vh;display:grid}.topbar{background:var(--c-primary);color:#fff;z-index:10;grid-column:1/-1;justify-content:space-between;align-items:center;padding:0 24px;display:flex;box-shadow:0 2px 8px #00000026}.topbar-left{align-items:center;gap:12px;display:flex}.logo{background:var(--c-accent);text-align:center;border-radius:8px;width:32px;height:32px;font-size:18px;font-weight:800;line-height:32px}.brand{letter-spacing:.5px;font-size:17px;font-weight:600}.topbar-right{align-items:center;gap:12px;display:flex}.refresh-time{opacity:.7;font-size:12px}.btn-refresh,.btn-logout{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff4d;border-radius:6px;padding:6px 14px;font-size:12px;transition:all .2s}.btn-refresh:hover{background:#ffffff1a}.btn-logout{border-color:var(--c-accent);color:var(--c-accent)}.btn-logout:hover{background:var(--c-accent);color:#fff}.sidebar{background:var(--c-surface);border-right:1px solid var(--c-border);flex-direction:column;gap:2px;padding:16px 0;display:flex}.nav-btn{cursor:pointer;color:var(--c-muted);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:12px 20px;font-size:14px;transition:all .15s;display:flex}.nav-btn:hover{color:var(--c-primary);background:#f0f2f8}.nav-btn.active{color:var(--c-primary);border-right:3px solid var(--c-accent);background:#e8ecf6;font-weight:600}.nav-icon{text-align:center;width:20px;font-size:16px}.content{padding:24px;overflow-y:auto}.panel{background:var(--c-surface);border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 1px 4px #0000000f}.panel h2{color:var(--c-primary);align-items:center;gap:8px;margin-bottom:20px;font-size:18px;display:flex}.panel h3{color:var(--c-muted);margin-top:4px;margin-bottom:12px;font-size:14px}.badge{background:var(--c-accent);color:#fff;border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.metric-card{text-align:center;border:1px solid var(--c-border);background:#f5f7fb;border-radius:10px;padding:20px;transition:all .2s}.metric-card:hover{border-color:var(--c-primary);transform:translateY(-1px)}.metric-card.accent{border-color:var(--c-accent);background:linear-gradient(135deg,#fff5f7,#fff)}.metric-val{color:var(--c-primary);font-size:28px;font-weight:700}.metric-card.accent .metric-val{color:var(--c-accent)}.metric-label{color:var(--c-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:12px}.metric-sub{color:var(--c-muted);margin-top:4px;font-size:11px}.chart-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px;display:grid}.chart-card{border:1px solid var(--c-border);background:#fafbfe;border-radius:10px;padding:16px}.chart-scroll{overflow-x:auto}.chart-svg{display:block}.chart-empty{color:var(--c-muted);text-align:center;padding:40px;font-size:13px}.pie-wrap{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.pie-legend{flex-direction:column;gap:6px;display:flex}.legend-item{color:var(--c-text);align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.table-wrap{margin-top:8px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;color:var(--c-muted);border-bottom:2px solid var(--c-border);white-space:nowrap;background:#f5f7fb;padding:10px 12px;font-weight:600}tbody td{border-bottom:1px solid var(--c-border);padding:10px 12px}tbody tr:hover{background:#f8f9ff}.mono{letter-spacing:.5px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.date-cell{color:var(--c-muted);white-space:nowrap;font-size:12px}.warn-row{background:#fff8f0!important}.warn-row td{color:#b35900}.scale-tag{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.scale-tag.startup{color:#1565c0;background:#e3f2fd}.scale-tag.sme{color:#e65100;background:#fff3e0}.scale-tag.enterprise{color:#7b1fa2;background:#f3e5f5}.status-dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.status-dot.active{background:#4caf50}.status-dot.pending{background:#ff9800}.status-dot.delivered{background:#2196f3}.status-dot.adopted{background:#4caf50}.status-dot.dismissed{background:#9e9e9e}.status-dot.dormant{background:#ff9800}.status-dot.revoked{background:#f44336}.type-tag{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.type-tag.common_blind_spot{color:#e65100;background:#fff3e0}.type-tag.success_pattern{color:#2e7d32;background:#e8f5e9}.type-tag.failure_pattern{color:#c62828;background:#fce4ec}.type-tag.config_correlation,.type-tag.config_suggestion{color:#1565c0;background:#e3f2fd}.type-tag.prompt_suggestion{color:#7b1fa2;background:#f3e5f5}.type-tag.warning{color:#e65100;background:#fff3e0}.type-tag.methodology_update{color:#006064;background:#e0f7fa}.pattern-list{flex-direction:column;gap:8px;display:flex}.pattern-item{border:1px solid var(--c-border);cursor:pointer;border-radius:8px;padding:12px 16px;transition:all .15s}.pattern-item:hover{border-color:var(--c-primary);background:#fafbfe}.pattern-header{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pattern-desc{flex:1;min-width:200px;font-size:13px}.conf-badge{background:var(--c-primary);color:#fff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.brain-count{color:var(--c-muted);white-space:nowrap;font-size:12px}.pattern-evidence{border-top:1px solid var(--c-border);color:var(--c-muted);word-break:break-all;margin-top:12px;padding-top:12px;font-size:12px;line-height:1.6}.pattern-meta{color:#999;margin-top:8px;font-size:11px}.empty-state{text-align:center;color:var(--c-muted);padding:40px;font-size:14px}.skeleton .skeleton-bar{background:linear-gradient(90deg,#eee 25%,#f5f5f5 50%,#eee 75%) 0 0/200% 100%;border-radius:4px;height:20px;margin-bottom:12px;animation:1.5s infinite shimmer}.skeleton .skeleton-bar.short{width:60%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=768px){:root{--sidebar-w:0px}.app{grid-template-columns:1fr}.sidebar{z-index:20;border-right:none;border-top:1px solid var(--c-border);background:var(--c-surface);flex-direction:row;padding:0;position:fixed;bottom:0;left:0;right:0;overflow-x:auto;box-shadow:0 -2px 8px #00000014}.nav-btn{text-align:center;flex-direction:column;gap:2px;min-width:60px;padding:10px 16px;font-size:11px}.nav-btn.active{border-right:none;border-top:2px solid var(--c-accent)}.nav-icon{font-size:18px}.content{padding:16px 16px 80px}.metric-grid{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}.brand{font-size:14px}}@media (width<=480px){.metric-grid{grid-template-columns:1fr}.login-box{padding:32px 24px}.topbar{padding:0 12px}}
