*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0b;--bg-card:#111113;--bg-card-hover:#18181b;--border:rgba(255,255,255,0.08);--border-hover:rgba(255,255,255,0.15);--text-primary:#f4f4f5;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent:#f5b301;--accent-dim:rgba(245,179,1,0.15);--radius:12px;--radius-sm:8px;--shadow:0 4px 24px rgba(0,0,0,0.6);--shadow-lg:0 8px 48px rgba(0,0,0,0.8);--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}body,html{background:var(--bg);color:var(--text-primary);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}#__next,body,html{height:100%}.app-shell{flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app-shell,.header{display:flex;position:relative}.header{z-index:30;align-items:center;justify-content:space-between;padding:12px 20px;background:rgba(10,10,11,.92);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-shrink:0;gap:16px}.header-left{gap:12px;min-width:0}.header-left,.header-logo{display:flex;align-items:center}.header-logo{width:32px;height:32px;background:var(--accent);border-radius:8px;justify-content:center;font-size:16px;font-weight:700;color:#000;flex-shrink:0}.header-title{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap}.header-title span{color:var(--accent)}.header-stats{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.stat-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:20px;font-size:11px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.stat-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.search-wrap{position:relative;flex-shrink:0}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;font-size:13px}.search-input{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:13px;padding:7px 12px 7px 30px;width:220px;outline:none;transition:border-color .15s,background .15s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent);background:rgba(245,179,1,.05)}.main-area{flex:1 1;display:flex;overflow:hidden;position:relative;min-height:0}.graph-container{flex:1 1;position:relative;min-width:0;background:var(--bg)}.graph-container canvas{display:block}.side-panel{width:300px;flex-shrink:0;background:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width .2s ease,opacity .2s ease}.side-panel.hidden{width:0;opacity:0;pointer-events:none;border-left:none}.panel-header{padding:16px 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:10px}.panel-header-content{flex:1 1;min-width:0}.panel-type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;border:1px solid}.panel-name{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1.2;word-break:break-word}.panel-role{font-size:12px;color:var(--text-secondary);margin-top:3px}.panel-close{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;padding:4px 8px;font-size:13px;transition:color .15s,border-color .15s;flex-shrink:0;line-height:1}.panel-close:hover{color:var(--text-primary);border-color:var(--border-hover)}.panel-body{flex:1 1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:14px}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:transparent}.panel-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}.info-row{display:flex;flex-direction:column;gap:3px}.info-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.info-value{font-size:13px;color:var(--text-primary);word-break:break-word}.info-value.mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;color:var(--accent)}.dept-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.dept-badge .badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.panel-desc{font-size:12px;color:var(--text-secondary);line-height:1.6;padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-sm)}.members-list{display:flex;flex-direction:column;gap:6px}.member-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,border-color .15s}.member-item:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.member-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.member-label{font-size:12px;font-weight:500;color:var(--text-primary)}.legend{position:absolute;bottom:16px;left:16px;z-index:20;background:rgba(10,10,11,.9);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;max-width:220px;max-height:40vh;overflow-y:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow);transition:opacity .2s}.legend::-webkit-scrollbar{width:3px}.legend::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}.legend-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.legend-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:6px;cursor:pointer;transition:background .12s;margin-bottom:2px;border:1px solid transparent}.legend-item:hover{background:rgba(255,255,255,.05);border-color:var(--border)}.legend-item.active{background:rgba(255,255,255,.07);border-color:var(--border-hover)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-label{font-size:11px;color:var(--text-secondary);flex:1 1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-count{font-size:10px;color:var(--text-muted);font-weight:500}.node-tooltip{position:fixed;z-index:100;pointer-events:none;background:rgba(17,17,19,.95);border:1px solid var(--border-hover);border-radius:var(--radius-sm);padding:8px 12px;max-width:200px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tooltip-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.tooltip-role{font-size:11px;color:var(--text-secondary)}.graph-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);font-size:13px}.loading-pulse{width:48px;height:48px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.link-legend{position:absolute;bottom:16px;right:16px;z-index:20;background:rgba(10,10,11,.9);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow)}.link-legend-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.link-legend-item{display:flex;align-items:center;gap:8px;margin-bottom:5px}.link-legend-item:last-child{margin-bottom:0}.link-line{width:24px;height:2px;border-radius:1px;flex-shrink:0}.link-legend-label{font-size:11px;color:var(--text-secondary)}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.view-toggle{display:flex;align-items:center;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;padding:2px;gap:2px;flex-shrink:0}.view-tab{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:500;padding:5px 12px;transition:background .15s,color .15s;white-space:nowrap;line-height:1}.view-tab:hover{color:var(--text-secondary);background:rgba(255,255,255,.06)}.view-tab--active{background:rgba(245,179,1,.15);color:var(--accent)}.view-tab--active:hover{background:rgba(245,179,1,.2)}.demo-btn{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:500;padding:6px 14px;flex-shrink:0;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;line-height:1}.demo-btn:hover{color:var(--text-primary);border-color:var(--border-hover);background:rgba(255,255,255,.08)}.demo-btn--active{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.4);color:#ef4444}.demo-btn--active:hover{background:rgba(239,68,68,.18)}.demo-mode .header{padding:16px 28px}.demo-mode .header-title{font-size:20px}.demo-mode .header-logo{width:40px;height:40px;font-size:20px}.demo-mode .stat-pill{font-size:13px;padding:6px 14px}.demo-mode .view-tab{font-size:14px;padding:7px 16px}.search-hidden{visibility:hidden;pointer-events:none;opacity:0}.projects-view{min-width:0}.projects-board,.projects-view{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.projects-board{padding:20px 24px 16px;gap:16px}.projects-board-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:12px}.projects-counts{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.count-item{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--text-secondary);padding:4px 10px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:20px;white-space:nowrap}.count-item.count-blocked{color:#ef4444;background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25)}.count-item.count-in-progress{color:#22c55e;background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.25)}.count-item.count-with-blockers{color:#f97316;background:rgba(249,115,22,.08);border-color:rgba(249,115,22,.25)}.count-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.projects-source{font-size:10px;color:var(--text-muted);white-space:nowrap;font-style:italic}.data-source-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0}.data-source-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap;border:1px solid transparent;transition:opacity .2s}.data-source-badge--live{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.35);color:#22c55e}.data-source-badge--snapshot{background:rgba(161,161,170,.1);border-color:rgba(161,161,170,.25);color:var(--text-muted)}.data-source-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:currentColor}.data-source-badge--live .data-source-dot{animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.4}}.kanban-board{display:flex;gap:16px;flex:1 1;min-height:0;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.kanban-board::-webkit-scrollbar{height:4px}.kanban-board::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}.kanban-column{flex:1 1;min-width:220px;max-width:360px;display:flex;flex-direction:column;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.kanban-column--blocked{border-color:rgba(239,68,68,.25);box-shadow:inset 0 0 0 1px rgba(239,68,68,.08)}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 10px;border-top:2px solid transparent;border-bottom:1px solid var(--border);flex-shrink:0}.kanban-column-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.kanban-column-count{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.kanban-cards{flex:1 1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.kanban-cards::-webkit-scrollbar{width:3px}.kanban-cards::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}.kanban-empty{display:flex;align-items:center;justify-content:center;padding:24px 12px;font-size:12px;color:var(--text-muted);border:1px dashed rgba(255,255,255,.07);border-radius:var(--radius-sm)}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 12px 10px;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,background .15s}.project-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.project-card--blocked{border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.04)}.project-card--blocked:hover{border-color:rgba(239,68,68,.5);background:rgba(239,68,68,.07)}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.project-name{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3;flex:1 1;min-width:0}.owner-pill-btn{background:none;border:none;padding:0;cursor:pointer;flex-shrink:0}.owner-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;cursor:pointer;transition:opacity .15s;white-space:nowrap}.owner-pill:hover{opacity:.8}.project-next-action{font-size:11px;color:var(--text-secondary);line-height:1.5;margin:0}.project-blockers{display:flex;flex-direction:column;gap:4px}.blocker-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:6px;font-size:11px;color:#f87171;font-weight:500;line-height:1.4}.blocker-icon{font-size:10px;flex-shrink:0}.project-card-footer{display:flex;align-items:center;justify-content:flex-end;margin-top:2px}.project-updated{font-size:10px;color:var(--text-muted)}.projects-error{flex:1 1;display:flex;align-items:center;justify-content:center;color:#ef4444;font-size:13px}.demo-mode .projects-board{padding:28px 36px 20px;gap:20px}.demo-mode .count-item{font-size:15px;padding:6px 16px}.demo-mode .project-name{font-size:15px}.demo-mode .project-next-action{font-size:13px}.demo-mode .owner-pill{font-size:13px;padding:3px 10px}.demo-mode .blocker-chip{font-size:13px;padding:4px 10px}.demo-mode .project-updated{font-size:12px}.demo-mode .kanban-column-label{font-size:14px}.demo-mode .kanban-column-count{font-size:13px}.demo-mode .kanban-column-header{padding:14px 18px 12px}.demo-mode .project-card{padding:16px 16px 12px;gap:10px}.demo-mode .kanban-board{gap:20px}.demo-mode .kanban-cards{gap:12px;padding:12px}