:root{--bg:#f3f4f6;--surface:#fff;--surface-raised:#fafbfc;--surface-glass:#ffffffb8;--text:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--accent:#0d9488;--accent-soft:#ccfbf1;--accent-ghost:#0d948814;--accent-strong:#0f766e;--blue:#3b82f6;--blue-soft:#dbeafe;--amber:#d97706;--amber-soft:#fef3c7;--red:#dc2626;--red-soft:#fee2e2;--green:#059669;--green-soft:#d1fae5;--line:#e2e8f0;--line-light:#f1f5f9;--shadow-xs:0 1px 2px #0f172a0a;--shadow-sm:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-md:0 4px 6px -1px #0f172a0f, 0 2px 4px -2px #0f172a0a;--shadow-lg:0 10px 15px -3px #0f172a0f, 0 4px 6px -4px #0f172a08;--shadow-xl:0 20px 25px -5px #0f172a0f, 0 8px 10px -6px #0f172a05;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);letter-spacing:.01em;margin:0;font-family:PingFang SC,Microsoft YaHei,Noto Sans CJK SC,system-ui,sans-serif;font-size:14px;line-height:1.6}button,select,input{font:inherit;color:inherit}#app{min-height:100vh}#app[data-layout=app]{grid-template-columns:auto minmax(0,1fr);display:grid}.sidebar{background:var(--surface);width:300px;height:100vh;color:var(--text);border-right:1px solid var(--line);scrollbar-width:thin;scrollbar-color:transparent transparent;transition:width var(--transition-base), padding var(--transition-base);flex-direction:column;gap:20px;padding:20px 16px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar:hover{scrollbar-color:var(--line) transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:0 0;border-radius:4px}.sidebar:hover::-webkit-scrollbar-thumb{background:var(--line)}.sidebar:hover::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.brand{flex-shrink:0;align-items:center;gap:12px;padding:0 4px;display:flex;position:relative}.brand-mark{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:15px;font-weight:800;display:grid;box-shadow:0 4px 12px #0d948840}.brand-text{transition:opacity var(--transition-fast), width var(--transition-fast);white-space:nowrap;flex-direction:column;gap:1px;display:flex;overflow:hidden}.brand-text strong{letter-spacing:.02em;color:var(--text);font-size:15px;font-weight:700}.brand-text span{color:var(--text-tertiary);font-size:11px}.sidebar-toggle{background:var(--surface);width:28px;height:28px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);opacity:0;z-index:100;box-shadow:var(--shadow-md);border:0;border-radius:50%;place-items:center;display:grid;position:fixed;top:50%;left:300px;transform:translate(-50%,-50%)}.sidebar:hover~.sidebar-toggle,.sidebar-toggle:hover{opacity:1}.sidebar-toggle:hover{color:var(--accent);transform:translate(-50%,-50%)scale(1.1)}#app[data-sidebar-collapsed=true] .sidebar-toggle{left:72px}#app[data-sidebar-collapsed=true] .sidebar-toggle svg{transform:rotate(180deg)}.nav-groups{flex-direction:column;gap:18px;display:flex;position:relative}.nav-group{flex-direction:column;gap:4px;display:flex}.nav-group h2{color:var(--text-tertiary);letter-spacing:.1em;text-transform:uppercase;margin:0;padding:0 10px 4px;font-size:10px;font-weight:700}.nav-item{width:100%;color:var(--text-secondary);text-align:left;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:0;align-items:center;gap:10px;padding:9px 12px;display:flex;position:relative;overflow:hidden}.nav-item:before{content:"";background:var(--accent);width:3px;height:20px;transition:transform var(--transition-base);border-radius:0 3px 3px 0;position:absolute;top:50%;left:0;transform:translateY(-50%)scaleY(0)}.nav-icon{color:currentColor;flex-shrink:0;place-items:center;width:18px;height:18px;display:grid}.nav-item span{white-space:nowrap;font-size:13.5px;font-weight:600}.nav-text{flex-direction:column;gap:2px;min-width:0;display:flex}.nav-text small{color:var(--text-tertiary);transition:color var(--transition-fast);font-size:11px;line-height:1.35}.sidebar.collapsed .nav-text{display:none}.nav-item:hover{background:var(--accent-ghost);color:var(--text)}.nav-item:hover small{color:var(--accent)}.nav-item.active{background:var(--accent-ghost);color:var(--accent-strong)}.nav-item.active:before{transform:translateY(-50%)scaleY(1)}.nav-item.active small{color:var(--accent)}.sidebar.collapsed{width:72px;padding:16px 10px 12px}.sidebar.collapsed .brand-text{opacity:0;width:0}.sidebar.collapsed .nav-group h2{opacity:0;height:0;padding:0;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar.collapsed .nav-item span{display:none}.sidebar.collapsed .nav-badge{position:absolute;top:4px;right:4px}.sidebar.collapsed .sidebar-note{display:none}.sidebar-note{background:var(--surface-raised);border:1px solid var(--line);border-radius:var(--radius-md);flex-shrink:0;align-items:center;gap:6px;margin-top:auto;padding:8px 10px;font-size:11px;display:flex;position:relative}.sidebar-note span{color:var(--text-tertiary)}.sidebar-note strong{color:var(--text);font-weight:600}.sidebar-note small{color:#475569}.main{min-width:0;padding:24px 28px 32px;animation:.4s fadeIn}.topbar{border-bottom:1px solid var(--line-light);justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:20px;display:flex}.eyebrow{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0 0 4px;font-size:11px;font-weight:700}h1,h2,h3{margin:0;font-weight:700;line-height:1.3}h1{letter-spacing:-.02em;font-size:26px}h2{font-size:17px}h3{font-size:15px}.topbar-actions{align-items:center;gap:10px;display:flex}.topbar-divider{background:var(--line);width:1px;height:24px;margin:0 4px}.msg-trigger{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;place-items:center;display:grid;position:relative}.msg-trigger:hover{color:var(--accent);background:var(--accent-ghost)}.msg-badge{background:var(--red);color:#fff;border:2px solid var(--surface);border-radius:100px;place-items:center;min-width:15px;height:15px;padding:0 4px;font-size:9px;font-weight:800;line-height:1;display:grid;position:absolute;top:2px;right:2px}.user-menu{flex-shrink:0;position:relative}.user-menu-trigger{border-radius:var(--radius-sm);height:36px;color:var(--text);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:0 10px 0 2px;display:flex}.user-menu-trigger:hover{background:var(--surface-raised)}.user-avatar-small{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:12px;font-weight:800;display:grid}.user-name{text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:13px;font-weight:600;overflow:hidden}.user-dropdown{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);width:240px;box-shadow:var(--shadow-xl);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100;padding:8px;position:absolute;top:calc(100% + 8px);right:0;transform:translateY(-6px)}.user-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-header{align-items:center;gap:10px;padding:10px 8px;display:flex}.dropdown-header strong{font-size:14px;font-weight:700;display:block}.dropdown-header span{color:var(--text-tertiary);margin-top:2px;font-size:11px;display:block}.dropdown-divider{background:var(--line-light);height:1px;margin:4px 0}.dropdown-item{text-align:left;border-radius:var(--radius-sm);width:100%;color:var(--text);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;font-size:13px;font-weight:500;display:flex}.dropdown-item:hover{background:var(--surface-raised)}.dropdown-item.danger{color:var(--red)}.dropdown-item.danger:hover{background:var(--red-soft)}.dropdown-badge{background:var(--red);color:#fff;border-radius:9px;place-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:800;display:grid}select,.primary-action,.ghost-action,.table-action{border:1px solid var(--line);background:var(--surface);color:var(--text);border-radius:var(--radius-md);min-height:36px;transition:all var(--transition-fast);cursor:pointer;padding:0 14px;font-size:13px;font-weight:500}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}select:hover{border-color:var(--accent)}.primary-action{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;box-shadow:0 1px 3px #0d948840}.primary-action:hover{background:var(--accent-strong);border-color:var(--accent-strong);transform:translateY(-1px);box-shadow:0 4px 12px #0d94884d}.primary-action:active{transform:translateY(0)}.primary-action:disabled,.table-action:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none!important}.ghost-action,.table-action{background:var(--surface)}.ghost-action:hover,.table-action:not(:disabled):hover{background:var(--line-light);border-color:var(--text-tertiary)}.table-action{min-height:28px;padding:4px 10px;font-size:12px}.grid{gap:16px;display:grid}.metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px}.content-grid{grid-template-columns:1.2fr 1fr 1fr;gap:16px;display:grid}.detail-grid{grid-template-columns:1.4fr 1fr;gap:16px;display:grid}.span-2{grid-column:span 2}.stage-detail-preview{border-top:1px solid var(--line-light);margin-top:18px;padding-top:18px}.stage-detail-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.stage-detail-header strong{color:var(--text);font-size:15px;display:block}.stage-detail-header span{color:var(--accent);background:var(--accent-ghost);border-radius:20px;padding:2px 8px;font-size:12px}.stage-detail-header small{color:var(--text-tertiary);font-size:11px}.stage-detail-body{color:var(--text-secondary);flex-direction:column;gap:6px;font-size:13px;display:flex}.stage-detail-body .detail-row{line-height:1.6}.stage-detail-body .detail-row b{color:var(--text);font-weight:600}.metric-card,.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), transform var(--transition-fast)}.metric-card{padding:20px;position:relative;overflow:hidden}.metric-card:after{content:"";background:linear-gradient(90deg, var(--accent), var(--blue));opacity:.6;height:3px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0;right:0}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-card:hover:after{opacity:1}.metric-card span{color:var(--text-tertiary);font-size:12px;font-weight:500}.metric-card strong{letter-spacing:-.03em;background:linear-gradient(135deg, var(--text), var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:10px 0 6px;font-size:32px;font-weight:700;display:block}.metric-card small{color:var(--text-tertiary);font-size:12px}.project-radar-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.project-radar-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--surface), var(--surface-raised));cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);padding:16px}.project-radar-card:hover{box-shadow:var(--shadow-md);border-color:#0d948859;transform:translateY(-2px)}.radar-card-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.radar-card-head strong{color:var(--text);font-size:15px;line-height:1.4;display:block}.radar-card-head small{color:var(--text-tertiary);margin-top:4px;font-size:11px;line-height:1.4;display:block}.radar-stage{border-radius:var(--radius-md);background:var(--accent-ghost);justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding:10px 12px;display:flex}.radar-stage span{color:var(--accent-strong);font-weight:700}.radar-stage small{color:var(--text-tertiary);white-space:nowrap;font-size:11px}.radar-metrics{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px;display:grid}.radar-metrics div{border:1px solid var(--line-light);border-radius:var(--radius-md);text-align:center;background:#fff;padding:9px 6px}.radar-metrics b{color:var(--text);font-size:15px;line-height:1.2;display:block}.radar-metrics span{color:var(--text-tertiary);margin-top:2px;font-size:10px;display:block}.radar-next{border-top:1px solid var(--line-light);padding-top:10px}.radar-next span{color:var(--text-tertiary);font-size:11px;font-weight:700}.radar-next p{color:var(--text-secondary);margin:4px 0 0;font-size:12px;line-height:1.5}.radar-warning{background:var(--red-soft);width:max-content;max-width:100%;color:var(--red);border-radius:999px;margin-top:10px;padding:6px 9px;font-size:12px;font-weight:700}.ops-hero{border-radius:var(--radius-xl);color:#fff;background:radial-gradient(circle at 16% 22%,#2dd4bf47,#0000 26%),radial-gradient(circle at 80% 18%,#3b82f62e,#0000 28%),linear-gradient(135deg,#052e2b 0%,#0f172a 52%,#10233f 100%);border:1px solid #0d948829;justify-content:space-between;align-items:center;gap:24px;margin-bottom:16px;padding:28px;display:flex;position:relative;overflow:hidden;box-shadow:0 24px 50px #0f172a29}.ops-hero:before{content:"";background-image:linear-gradient(#ffffff0f 1px,#0000 1px),linear-gradient(90deg,#ffffff0f 1px,#0000 1px);background-size:42px 42px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#0000,#000 20% 80%,#0000);mask-image:linear-gradient(90deg,#0000,#000 20% 80%,#0000)}.ops-hero>*{z-index:1;position:relative}.ops-hero .eyebrow{color:#5eead4}.ops-hero h2{letter-spacing:-.04em;margin:6px 0 8px;font-size:30px;line-height:1.2}.ops-hero p{color:#ffffffb8;max-width:620px;margin:0}.ops-hero p strong{color:#fff;font-weight:800}.ops-hero-pulse{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center;background:#ffffff14;border:1px solid #ffffff29;min-width:132px;padding:16px}.ops-hero-pulse span{background:radial-gradient(circle,#5eead4 0 24%,#5eead42e 26% 100%);border-radius:50%;width:46px;height:46px;margin:0 auto 8px;animation:2.2s ease-out infinite opsPulse;display:block;box-shadow:0 0 #5eead46b}.ops-hero-pulse strong,.ops-hero-pulse small{display:block}.ops-hero-pulse small{color:#ffffffa8;font-size:11px}.ops-tabs{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);gap:8px;margin-bottom:16px;padding:8px;display:flex;overflow-x:auto}.ops-tabs button{border-radius:var(--radius-md);color:var(--text-secondary);white-space:nowrap;cursor:pointer;min-height:36px;transition:all var(--transition-fast);background:0 0;border:0;padding:0 14px}.ops-tabs button:hover{background:var(--surface-raised);color:var(--text)}.ops-tabs button.active{color:#fff;background:#0f172a;box-shadow:0 8px 18px #0f172a29}.ops-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.ops-kpi-card{border:1px solid var(--line);border-radius:var(--radius-lg);min-height:136px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fffffff5,#f8fafcdb),radial-gradient(circle at 0 0,#0d948829,#0000 36%);justify-content:space-between;align-items:center;gap:14px;padding:18px;animation:.52s both opsRise;display:flex}.ops-kpi-card span,.ops-kpi-card small{color:var(--text-tertiary);font-size:12px;display:block}.ops-kpi-card strong{letter-spacing:-.04em;margin:8px 0 4px;font-size:34px;line-height:1;display:block}.ops-ring{--angle:calc(var(--value) * 3.6deg);background:conic-gradient(var(--ring-color,var(--accent)) var(--angle), #e5e7eb 0);border-radius:50%;flex:0 0 72px;place-items:center;width:72px;height:72px;animation:.8s both opsSpinIn;display:grid;position:relative}.ops-ring:after{content:"";background:#fff;border-radius:50%;position:absolute;inset:8px}.ops-ring b{z-index:1;font-size:13px;position:relative}.ops-kpi-card.green{--ring-color:var(--green)}.ops-kpi-card.amber{--ring-color:var(--amber)}.ops-kpi-card.red{--ring-color:var(--red)}.ops-grid{grid-template-columns:minmax(0,1.35fr) minmax(300px,.75fr);gap:16px;display:grid}.ops-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);min-width:0;box-shadow:var(--shadow-sm);padding:22px;animation:.58s both opsRise}.ops-card-large{grid-column:span 1}.ops-card-head{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;display:flex}.ops-card-head h3{letter-spacing:-.02em;margin:4px 0 0;font-size:17px}.ops-card-head>span{color:var(--text-tertiary);font-size:12px;font-weight:700}.ops-stage-flow{grid-template-columns:repeat(7,minmax(72px,1fr));align-items:end;gap:10px;min-height:260px;padding-top:12px;display:grid}.ops-stage-col{min-height:230px;animation:.5s both opsRise;animation-delay:var(--delay);grid-template-rows:1fr auto auto;gap:8px;display:grid}.ops-stage-bar{background:linear-gradient(#f8fafc,#eef2f7);border-radius:999px;align-items:end;min-height:150px;display:flex;position:relative;overflow:hidden}.ops-stage-bar i{width:100%;height:var(--height);animation:.9s cubic-bezier(.2,.9,.2,1) both opsGrowY;animation-delay:var(--delay);background:linear-gradient(#2dd4bf,#0d9488);border-radius:999px 999px 0 0;display:block}.ops-stage-col strong,.ops-stage-col span{text-align:center}.ops-stage-col strong{font-size:20px}.ops-stage-col span{color:var(--text-tertiary);font-size:11px}.ops-radar-card{background:radial-gradient(circle,#f0fdfa,#fff 56%)}.ops-radar{place-items:center;min-height:260px;display:grid;position:relative}.ops-radar svg{filter:drop-shadow(0 18px 26px #0d948829);width:min(100%,260px)}.ops-radar .radar-grid{fill:#0d94880a;stroke:#0d94882e;stroke-width:1.5px}.ops-radar .radar-grid.inner{fill:#ffffff52}.ops-radar .radar-shape{fill:#0d948847;stroke:#0d9488;stroke-width:3px;transform-origin:50%;animation:4s ease-in-out infinite opsRadarMorph}.ops-radar circle{fill:#0f766e}.ops-radar-labels{pointer-events:none;position:absolute;inset:18px}.ops-radar-labels span{color:var(--text-secondary);font-size:11px;font-weight:800;position:absolute}.ops-radar-labels span:first-child{top:0;left:50%;transform:translate(-50%)}.ops-radar-labels span:nth-child(2){top:22%;right:0}.ops-radar-labels span:nth-child(3){bottom:22%;right:0}.ops-radar-labels span:nth-child(4){bottom:0;left:50%;transform:translate(-50%)}.ops-radar-labels span:nth-child(5){bottom:22%;left:0}.ops-radar-labels span:nth-child(6){top:22%;left:0}.ops-project-strip{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;display:grid}.ops-project-tile{border:1px solid var(--line);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);animation:.56s both opsRise;animation-delay:var(--delay);background:linear-gradient(135deg,#fff,#f8fafc);padding:14px}.ops-project-tile:hover{box-shadow:var(--shadow-lg);border-color:#0d948857;transform:translateY(-3px)}.ops-project-tile.selected{background:linear-gradient(135deg,#f0fdfaf5,#fff),radial-gradient(circle at 100% 0,#2dd4bf47,#0000 30%);border-color:#0d9488b8;box-shadow:0 14px 30px #0d948829}.ops-project-tile.selected:before{content:"当前关注";background:var(--accent);color:#fff;letter-spacing:.04em;border-radius:999px;margin-bottom:8px;padding:3px 8px;font-size:10px;font-weight:800;display:inline-flex}.ops-project-tile>div:first-child,.ops-project-tile footer,.ops-tile-bars p{justify-content:space-between;align-items:center;gap:10px;display:flex}.ops-project-tile strong{font-size:14px}.ops-project-tile>span,.ops-project-tile footer,.ops-tile-bars b,.ops-tile-bars small{color:var(--text-tertiary);font-size:11px}.ops-project-tile>span{margin:6px 0 12px;display:block}.ops-tile-bars{gap:8px;display:grid}.ops-tile-bars p{margin:0}.ops-tile-bars i,.ops-domain-row i{background:#edf2f7;border-radius:999px;flex:1;height:8px;position:relative;overflow:hidden}.ops-tile-bars em,.ops-domain-row em{border-radius:inherit;background:linear-gradient(90deg,#14b8a6,#38bdf8);height:100%;animation:.9s both opsGrowX;display:block}.ops-project-tile footer{border-top:1px solid var(--line-light);margin-top:12px;padding-top:10px}.ops-risk-pulse{gap:10px;display:grid}.ops-risk-line{border-radius:var(--radius-md);animation:.48s both opsSlideIn;animation-delay:var(--delay);background:#f8fafc;grid-template-columns:38px minmax(0,1fr);gap:8px 10px;padding:12px;display:grid}.ops-risk-line b{background:var(--blue-soft);width:34px;height:34px;color:var(--blue);border-radius:50%;grid-row:span 2;place-items:center;font-size:11px;display:grid}.ops-risk-line.hot b{background:var(--red-soft);color:var(--red);animation:1.8s infinite opsPulse}.ops-risk-line.warm b{background:var(--amber-soft);color:var(--amber)}.ops-risk-line span{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.ops-risk-line small{color:var(--text-tertiary)}.ops-domain-bars{gap:13px;display:grid}.ops-domain-row{animation:.46s both opsSlideIn;animation-delay:var(--delay);grid-template-columns:88px minmax(0,1fr) 44px;align-items:center;gap:10px;display:grid}.ops-domain-row span{color:var(--text-secondary);font-size:12px;font-weight:700}.ops-domain-row em{width:var(--value)}.ops-domain-row strong{text-align:right;font-size:12px}@keyframes opsRise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes opsSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes opsGrowX{0%{width:0}}@keyframes opsGrowY{0%{height:0}}@keyframes opsSpinIn{0%{opacity:0;transform:rotate(-24deg)scale(.92)}to{opacity:1;transform:rotate(0)scale(1)}}@keyframes opsPulse{0%{box-shadow:0 0 #2dd4bf61}70%{box-shadow:0 0 0 16px #2dd4bf00}to{box-shadow:0 0 #2dd4bf00}}@keyframes opsRadarMorph{0%,to{opacity:.92;transform:scale(1)}50%{opacity:1;transform:scale(1.035)}}.panel{min-width:0;padding:28px}.panel:hover{box-shadow:var(--shadow-md)}.panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.panel-header p{color:var(--text-secondary);margin:6px 0 0;font-size:13px}.intro-principles,.intro-principles,.intro-grid .panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.intro-actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex;position:relative}.intro-principles{gap:0;display:grid;overflow:hidden}.intro-principles article{border-bottom:1px solid var(--line-light);transition:background var(--transition-fast);padding:18px 20px}.intro-principles article:hover{background:var(--surface-raised)}.intro-principles article:last-child{border-bottom:0}.intro-principles span,.usage-steps>article>span{background:var(--accent-ghost);width:30px;height:30px;color:var(--accent);border-radius:var(--radius-md);place-items:center;margin-bottom:10px;font-size:12px;font-weight:800;display:inline-grid}.intro-principles strong{font-size:14px;display:block}.intro-principles p,.usage-steps p{color:var(--text-secondary);margin:6px 0 0;font-size:13px;line-height:1.6}.intro-grid{grid-template-columns:1.25fr .75fr;gap:16px;margin-bottom:16px;display:grid}.flow-panel,.flow-canvas-panel{margin-bottom:28px}.flow-canvas-panel{overflow:visible}.canvas-shell{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(#f8fafc,#f1f5f9);margin-top:8px;overflow-x:auto}#gtm-flow-canvas{min-width:920px;display:block}.canvas-legend{color:var(--text-secondary);flex-wrap:wrap;gap:16px;margin-top:14px;font-size:12px;display:flex}.canvas-legend span{align-items:center;gap:6px;display:inline-flex}.canvas-legend i{border-radius:50%;width:10px;height:10px;display:inline-block}.legend-l1{background:var(--accent)}.legend-l2{background:var(--blue)}.legend-l3{background:var(--amber)}.l3-map strong,.l3-map p,.system-map strong,.system-map span{display:block}.l3-map p,.system-map span{color:var(--text-secondary);font-size:12px;line-height:1.5}.l3-map{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:24px;display:grid}.l3-map article{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--surface), var(--surface-raised));transition:all var(--transition-fast);padding:16px}.l3-map article:hover{border-color:var(--amber);box-shadow:var(--shadow-md);transform:translateY(-2px)}.system-map{background:var(--surface-raised);border:1px solid var(--line);border-radius:var(--radius-lg);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;padding:20px;display:grid}.system-map article{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);min-height:88px;transition:all var(--transition-fast);padding:12px}.system-map article:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.l2-full-panel{margin-top:16px}.l2-full-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.l2-full-card{border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.l2-full-card header{border-bottom:1px solid var(--line-light);background:radial-gradient(circle at 100% 0,#3b82f61f,#0000 34%),linear-gradient(135deg,#f8fbff,#eff6ff);align-items:center;gap:12px;padding:16px;display:flex}.l2-full-card header>span{color:#fff;background:#2563eb;border-radius:14px;place-items:center;width:38px;height:38px;font-size:13px;font-weight:900;display:grid}.l2-full-card header strong,.l2-full-card header small{display:block}.l2-full-card header strong{color:var(--text);font-size:16px}.l2-full-card header small{color:var(--text-secondary);margin-top:2px;font-size:12px}.l2-full-list{gap:8px;padding:14px;display:grid}.l2-full-item{text-align:left;cursor:pointer;width:100%;transition:all var(--transition-fast);background:#f8fafc;border:1px solid #0f172a0f;border-radius:14px;grid-template-columns:28px minmax(0,1fr);align-items:flex-start;gap:10px;padding:12px;display:grid}.l2-full-item:hover{background:#eff6ff;border-color:#2563eb59;transform:translateY(-1px)}.l2-full-item b{color:#1d4ed8;background:#dbeafe;border-radius:10px;place-items:center;width:26px;height:26px;font-size:12px;display:grid}.l2-full-item span,.l2-full-item strong,.l2-full-item small{display:block}.l2-full-item strong{color:var(--text);font-size:14px}.l2-full-item small{color:var(--text-secondary);margin-top:4px;font-size:12px;line-height:1.55}.flow-localization-panel{margin-top:16px}.localization-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.localization-grid article{border-radius:var(--radius-lg);min-height:128px;box-shadow:var(--shadow-sm);background:radial-gradient(circle at 100% 0,#0d94881f,#0000 34%),#fff;border:1px solid #0d948829;padding:18px;position:relative;overflow:hidden}.localization-grid article:before{content:"";background:var(--accent);border-radius:999px;width:28px;height:4px;position:absolute;top:18px;left:18px}.localization-grid strong{color:var(--text);margin-top:16px;font-size:15px;display:block}.localization-grid p{color:var(--text-secondary);margin:8px 0 0;font-size:13px;line-height:1.65}.flow-stage-nav{z-index:50;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);gap:6px;margin-bottom:16px;padding:10px 14px;display:flex;position:sticky;top:0;overflow-x:auto}.flow-nav-item{border-radius:var(--radius-md);background:var(--surface-raised);border:1px solid var(--line);color:var(--text);white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;text-decoration:none;display:flex}.flow-nav-item span{background:var(--accent-ghost);width:24px;height:24px;color:var(--accent);border-radius:var(--radius-sm);place-items:center;font-size:11px;font-weight:800;display:inline-grid}.flow-nav-item:hover{border-color:var(--accent);background:var(--accent-ghost)}.flow-nav-item.active{background:var(--accent);color:#fff;border-color:var(--accent)}.flow-nav-item.active span{color:#fff;background:#fff3}.stage-detail-page{flex-direction:column;gap:16px;display:flex}.stage-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.stage-detail-nav{gap:10px;display:flex}.flow-stage-panel{margin-bottom:16px}.stage-l1-header{border-bottom:1px solid var(--line);align-items:center;gap:16px;margin-bottom:16px;padding-bottom:16px;display:flex}.stage-num{background:var(--accent);color:#fff;border-radius:var(--radius-md);flex-shrink:0;place-items:center;width:48px;height:48px;font-size:18px;font-weight:800;display:inline-grid}.stage-title h2{margin-bottom:4px;font-size:20px}.stage-title p{color:var(--text-secondary);font-size:13px}.stage-section{margin-bottom:20px}.stage-section:last-child{margin-bottom:0}.stage-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:13px;font-weight:700}.stage-l2-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.l2-card{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--surface), var(--surface-raised));padding:14px}.l2-card strong{color:var(--accent-strong);margin-bottom:6px;font-size:14px;display:block}.l2-card p{color:var(--text-secondary);font-size:12px;line-height:1.6}.checklist-table-wrap{border:1px solid var(--line);border-radius:var(--radius-md);overflow-x:auto}.checklist-table{border-collapse:collapse;width:100%;font-size:13px}.checklist-table thead th{background:var(--surface-raised);text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--line);white-space:nowrap;padding:10px 12px;font-size:12px;font-weight:600}.checklist-table tbody td{border-bottom:1px solid var(--line-light);vertical-align:top;padding:10px 12px;line-height:1.5}.checklist-table tbody tr:last-child td{border-bottom:none}.checklist-table tbody tr:hover td{background:var(--surface-raised)}.col-role{white-space:nowrap;width:100px;color:var(--text-secondary);font-weight:600}.col-activity{min-width:160px}.col-deliverable{min-width:140px}.col-note{min-width:200px;color:var(--text-secondary);font-size:12px}.mermaid-wrap{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);padding:16px;overflow-x:auto}.mermaid-wrap .mermaid{justify-content:center;display:flex}.swimlane-container{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);flex-direction:column;display:flex;position:relative;overflow:hidden}.swimlane-row{border-bottom:1px solid var(--line);grid-template-columns:140px 1fr;min-height:120px;display:grid}.swimlane-row:last-child{border-bottom:none}.swimlane-role-header{background:var(--surface-raised);color:var(--text);border-right:1px solid var(--line);justify-content:center;align-items:center;padding:14px;font-size:13px;font-weight:700;display:flex}.swimlane-row-body{flex-direction:row;justify-content:space-between;align-items:center;min-height:100px;padding:24px 32px;display:flex;position:relative;overflow-x:auto}.swimlane-node-wrapper{flex:1;justify-content:center;max-width:220px;display:flex}.flow-node{border:2px solid var(--line);text-align:center;color:var(--text);box-shadow:var(--shadow-sm);z-index:2;background:#fff;border-radius:8px;max-width:180px;padding:12px 16px;font-size:13px;font-weight:600;line-height:1.5;position:relative}.flow-node.flow-node-start{width:56px;height:56px;max-width:unset;background:#ecfdf5;border:3px solid #10b981;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex}.flow-node.flow-node-start .flow-node-name{color:#065f46;font-size:11px;font-weight:800}.flow-node.flow-node-end{width:56px;height:56px;max-width:unset;background:#fef2f2;border:5px solid #ef4444;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex}.flow-node.flow-node-end .flow-node-name{color:#991b1b;font-size:11px;font-weight:800}.flow-node.flow-node-decision{width:80px;height:80px;max-width:unset;background:#fef3c7;border:2px solid #d97706;border-radius:4px;justify-content:center;align-items:center;padding:0;display:flex;transform:rotate(45deg)}.flow-node.flow-node-decision .flow-node-code{display:none}.flow-node.flow-node-decision .flow-node-name{color:#92400e;text-align:center;word-break:break-all;max-width:70px;font-size:11px;font-weight:700;line-height:1.2;transform:rotate(-45deg)}.flow-node.flow-node-decision .flow-node-doc{display:none}.flow-node-doc{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;align-items:center;gap:4px;margin-top:6px;padding:4px 8px;font-size:10px;display:flex}.doc-icon{flex-shrink:0;font-size:12px}.doc-text{text-overflow:ellipsis;white-space:nowrap;max-width:140px;overflow:hidden}.flow-node-code{color:var(--accent);letter-spacing:.5px;margin-bottom:4px;font-size:10px;font-weight:700}.flow-node-output{color:var(--text-secondary);margin-top:4px;font-size:11px;font-weight:400}.swimlane-svg{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.flow-tooltip{z-index:1000;background:var(--text);color:#fff;pointer-events:none;max-width:280px;box-shadow:var(--shadow-md);white-space:pre-wrap;text-align:left;border-radius:6px;padding:10px 14px;font-size:12px;font-weight:400;line-height:1.5;display:none;position:fixed}.swimlane-chart{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);overflow:hidden}.swimlane-row{border-top:1px solid var(--line);grid-template-columns:140px minmax(0,1fr);display:grid}.swimlane-row:first-child{border-top:none}.swimlane-header{background:var(--surface-raised);color:var(--text-secondary);font-size:12px;font-weight:700}.swimlane-header .swimlane-role,.swimlane-header .swimlane-flow{padding:10px 14px}.swimlane-role{background:var(--surface-raised);border-right:1px solid var(--line);align-items:center;padding:14px;font-size:13px;font-weight:700;display:flex}.swimlane-flow{flex-direction:column;gap:10px;padding:14px;display:flex}.flow-item{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.flow-input,.flow-output{border-radius:var(--radius-sm);text-overflow:ellipsis;white-space:nowrap;max-width:180px;padding:5px 10px;font-size:12px;line-height:1.4;overflow:hidden}.flow-input{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.flow-output{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.flow-activity{border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);padding:8px 16px;font-size:13px;font-weight:600}.flow-arrow{color:var(--text-secondary);font-size:14px;font-weight:700}.usage-steps{gap:10px;display:grid}.usage-steps article{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--surface), var(--surface-raised));transition:all var(--transition-fast);grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px;display:grid}.usage-steps article:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translate(4px)}.project-hero{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-items:flex-start;gap:24px;margin-bottom:16px;padding:24px;display:flex;position:relative;overflow:hidden}.project-hero:before{content:"";background:radial-gradient(circle, var(--accent-soft), transparent 70%);opacity:.4;pointer-events:none;width:160px;height:160px;position:absolute;top:-40px;right:-40px}.project-hero .hero-main{flex:1;min-width:0;position:relative}.project-hero .hero-metrics{flex-shrink:0;grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.project-hero .hero-metrics .metric-card{min-width:120px;margin:0}.project-hero p{color:var(--text-secondary);margin:8px 0 0;position:relative}.hero-facts{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.hero-facts span{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-raised);color:var(--text-tertiary);transition:all var(--transition-fast);padding:12px;font-size:12px}.hero-facts span:hover{border-color:var(--accent);background:var(--accent-ghost)}.hero-facts strong{color:var(--text);margin-top:4px;font-size:14px;display:block}.timeline{grid-template-columns:repeat(7,minmax(100px,1fr));gap:8px;padding-bottom:6px;display:grid;overflow-x:auto}.stage-node{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-raised);min-height:80px;transition:all var(--transition-fast);padding:12px;position:relative}.stage-node:hover{box-shadow:var(--shadow-sm)}.stage-node span,.stage-node small{display:block}.stage-node span{font-size:13px;font-weight:700}.stage-node small{color:var(--text-secondary);margin-top:8px;font-size:11px;line-height:1.4}.stage-node.done{background:var(--accent-soft);border-color:#0d948859}.stage-node.done span{color:var(--accent-strong)}.stage-node.active{border:2px solid var(--accent);background:var(--surface);box-shadow:0 0 0 4px #0d94881a, var(--shadow-md)}.gate-callout{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--surface-raised), var(--surface));justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:16px;display:flex}.gate-callout span{color:var(--text-secondary);margin-top:4px;font-size:13px;display:block}.table-wrap{border-radius:var(--radius-md);border:1px solid var(--line);overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:780px}th,td{border-bottom:1px solid var(--line-light);text-align:left;vertical-align:top;padding:12px 14px;font-size:13px}th{color:var(--text-secondary);background:var(--surface-raised);letter-spacing:.03em;text-transform:uppercase;z-index:1;font-size:11px;font-weight:700;position:sticky;top:0}tr{transition:background var(--transition-fast)}tr:hover{background:#0d948805}tr.row-overdue{border-left:3px solid var(--red);background:#dc262608}tr.row-overdue td:first-child{padding-left:11px}tr.row-canceled{opacity:.5}tr.row-canceled strong{text-decoration:line-through}td strong,td small{display:block}td small{color:var(--text-tertiary);margin-top:4px;font-size:12px}.clickable{cursor:pointer}.clickable:hover{background:#0d94880a}.badge,.priority,.escalated{border-radius:var(--radius-sm);white-space:nowrap;letter-spacing:.01em;align-items:center;min-height:22px;padding:0 8px;font-size:11px;font-weight:700;display:inline-flex}.badge-normal,.badge-ready,.badge-basically_ready,.badge-approved,.badge-completed_task,.badge-closed{color:var(--green);background:var(--green-soft)}.badge-at_risk,.badge-blocked,.badge-deferred,.badge-open{color:var(--red);background:var(--red-soft)}.badge-delayed,.badge-pending_review,.badge-conditionally_approved,.badge-preparing,.badge-in_progress{color:var(--amber);background:var(--amber-soft)}.badge-not_started{color:#475569;background:#f1f5f9}.priority-P0,.priority-P1{color:var(--red);background:var(--red-soft)}.priority-P2,.priority-P3{color:var(--blue);background:var(--blue-soft)}.escalated{color:var(--red);background:var(--red-soft);margin-left:6px}.stage-stack,.risk-list,.bar-list{gap:8px;display:grid}.stack-row{border-bottom:1px solid var(--line-light);transition:all var(--transition-fast);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.stack-row:last-child{border-bottom:0}.stack-row:hover{color:var(--accent);padding-left:4px}.risk-card,.readiness-card{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--surface), var(--surface-raised));transition:all var(--transition-fast);padding:14px}.risk-card:hover,.readiness-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.compact-list{gap:10px;display:grid}.compact-list article{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--surface), var(--surface-raised));transition:all var(--transition-fast);padding:14px}.compact-list article:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translate(2px)}.compact-list strong{font-size:13px;display:block}.compact-list span,.compact-list p{color:var(--text-secondary);margin:5px 0 0;font-size:12px;display:block}.template-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.template-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--surface), var(--surface-raised));min-height:160px;transition:all var(--transition-fast);cursor:default;padding:18px}.template-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-3px)}.template-card>div{justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;display:flex}.template-card>div>span:first-child{color:var(--text-tertiary);letter-spacing:.05em;font-size:11px;font-weight:700}.template-card strong,.template-card p{display:block}.template-card p{color:var(--text-secondary);margin-top:6px;font-size:13px;line-height:1.6}.danger-action{background:var(--red);border-color:var(--red);margin-top:14px}.danger-action:hover{background:#b91c1c;border-color:#b91c1c}.risk-card strong,.risk-card span,.readiness-card strong,.readiness-card p,.readiness-card small{display:block}.risk-card strong,.readiness-card strong{margin:8px 0 5px;font-size:14px}.risk-card span,.readiness-card p{color:var(--text-secondary);margin:0;font-size:12px}.danger-text{color:var(--red);font-weight:600}.readiness-score{place-items:center;gap:10px;min-height:200px;display:grid}.readiness-score strong{color:var(--accent);letter-spacing:-.04em;background:linear-gradient(135deg, var(--accent), var(--accent-strong));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:56px;font-weight:800}.readiness-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.readiness-card>div{justify-content:space-between;align-items:center;gap:10px;display:flex}.readiness-card .table-action{width:100%;margin-top:12px}.bar-row{grid-template-columns:90px 1fr 44px;align-items:center;gap:12px;padding:6px 0;display:grid}.bar-row span{color:var(--text-secondary);font-size:12px}.bar-row div{background:var(--line);border-radius:4px;height:8px;overflow:hidden}.bar-row i{background:linear-gradient(90deg, var(--accent), var(--blue));border-radius:4px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1);display:block}.bar-row strong{color:var(--text-secondary);text-align:right;font-size:12px}.cd-hero{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:32px;margin-bottom:16px;padding:28px 32px;display:flex;position:relative;overflow:hidden}.cd-hero-upgraded{color:#fff;background:radial-gradient(circle at 18% 18%,#2dd4bf47,#0000 26%),radial-gradient(circle at 88% 22%,#d977062e,#0000 26%),linear-gradient(135deg,#052e2b 0%,#0f172a 58%,#2b1f12 100%);border-color:#2dd4bf2e;box-shadow:0 24px 50px #0f172a29}.cd-hero:before{content:"";background:radial-gradient(circle, var(--accent-soft), transparent 70%);opacity:.5;pointer-events:none;width:200px;height:200px;position:absolute;top:-60px;right:-60px}.cd-hero-left{position:relative}.cd-hero-left h2{margin:6px 0;font-size:22px}.cd-hero-upgraded .cd-hero-left h2{letter-spacing:-.04em;font-size:30px}.cd-hero-left p{color:var(--text-secondary);max-width:520px;margin:0;font-size:14px;line-height:1.6}.cd-hero-upgraded .eyebrow{color:#5eead4}.cd-hero-upgraded .cd-hero-left p{color:#ffffffbd}.cd-launch-orbit{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #ffffff24;border-radius:50%;flex:0 0 150px;place-items:center;width:150px;height:150px;display:grid;position:relative}.cd-orbit-ring{border:2px dashed #5eead46b;border-radius:50%;animation:10s linear infinite cdOrbit;position:absolute;inset:14px}.cd-launch-orbit strong{z-index:1;letter-spacing:-.06em;font-size:42px;line-height:1;position:relative}.cd-launch-orbit small{z-index:1;color:#ffffffad;font-size:12px;font-weight:700;position:relative}.cd-launch-orbit.warning .cd-orbit-ring{border-color:#fbbf248f}.cd-launch-orbit.critical .cd-orbit-ring{border-color:#f871719e;animation-duration:4s}.cd-command-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.cd-command-card{border:1px solid var(--line);border-radius:var(--radius-lg);min-height:126px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fff,#f8fafc);padding:18px;animation:.52s both opsRise;position:relative;overflow:hidden}.cd-command-card:after{content:"";background:linear-gradient(90deg, var(--accent), var(--blue));height:4px;position:absolute;inset:auto 0 0}.cd-command-card.warning:after{background:linear-gradient(90deg, var(--amber), #fbbf24)}.cd-command-card.critical:after{background:linear-gradient(90deg, var(--red), #f87171)}.cd-command-card span,.cd-command-card small{color:var(--text-tertiary);font-size:12px;display:block}.cd-command-card strong{letter-spacing:-.04em;margin:10px 0 6px;font-size:28px;line-height:1.05;display:block}.cd-board,.cd-path-card,.cd-risk-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:22px}.cd-board-head{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px;display:flex}.cd-board-head h2{margin:4px 0 0;font-size:18px}.cd-board-head>span{color:var(--text-tertiary);font-size:12px;font-weight:700}.cd-week-ruler{grid-template-columns:repeat(8,minmax(42px,1fr));gap:8px;margin-bottom:10px;margin-left:116px;display:grid}.cd-week-ruler span{color:var(--text-tertiary);text-align:center;animation:.42s both opsRise;animation-delay:var(--delay);background:#f1f5f9;border-radius:999px;padding:6px 0;font-size:11px;font-weight:800}.cd-domain-gantt{gap:10px;display:grid}.cd-gantt-row{animation:.46s both opsSlideIn;animation-delay:var(--delay);grid-template-columns:108px minmax(0,1fr);align-items:center;gap:8px;display:grid}.cd-gantt-row>strong{color:var(--text-secondary);padding-left:12px;font-size:12px;position:relative}.cd-gantt-row>strong:before{content:"";background:var(--domain-color);border-radius:999px;width:6px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.cd-gantt-row>div{grid-template-columns:repeat(8,minmax(42px,1fr));gap:8px;display:grid}.cd-gantt-row span{border-radius:var(--radius-md);color:#fff;background:#f8fafc;place-items:center;min-height:34px;font-size:12px;font-weight:800;display:grid}.cd-gantt-row span.active{background:var(--domain-color);animation:.52s both cdCellPop;animation-delay:var(--delay);box-shadow:0 8px 18px #0f172a14}.cd-insight-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:16px;display:grid}.cd-path-list,.cd-alert-list{gap:12px;display:grid}.cd-path-list article{border:1px solid var(--line-light);border-radius:var(--radius-md);animation:.52s both opsRise;animation-delay:var(--delay);background:linear-gradient(135deg,#fff,#f8fafc);padding:14px}.cd-path-list article div{justify-content:space-between;gap:12px;display:flex}.cd-path-list article p{color:var(--text-tertiary);margin:4px 0 10px;font-size:12px}.cd-path-list i{background:#edf2f7;border-radius:999px;height:8px;display:block;overflow:hidden}.cd-path-list em{width:var(--value);border-radius:inherit;background:linear-gradient(90deg, var(--accent), #38bdf8);height:100%;animation:.9s both opsGrowX;display:block}.cd-alert-list article{border-radius:var(--radius-md);animation:.46s both opsSlideIn;animation-delay:var(--delay);background:#f8fafc;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:10px;padding:12px;display:grid}.cd-alert-list b{background:var(--blue-soft);width:36px;height:36px;color:var(--blue);border-radius:50%;place-items:center;font-size:11px;display:grid}.cd-alert-list .warm b{background:var(--amber-soft);color:var(--amber)}.cd-alert-list .hot b{background:var(--red-soft);color:var(--red);animation:1.8s infinite opsPulse}.cd-alert-list strong,.cd-alert-list span{display:block}.cd-alert-list strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cd-alert-list span{color:var(--text-tertiary);font-size:12px}.cd-clear-state{border-radius:var(--radius-md);background:var(--green-soft);color:var(--green);text-align:center;padding:26px 12px;font-weight:800}.cd-timeline-upgraded{margin-top:6px}.cd-hero-right{flex-shrink:0;gap:20px;display:flex;position:relative}.cd-stat{text-align:center;background:var(--surface-raised);border:1px solid var(--line);border-radius:var(--radius-md);min-width:72px;padding:12px 20px}.cd-stat strong{color:var(--accent);font-size:28px;font-weight:800;line-height:1.1;display:block}.cd-stat span{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.cd-toolbar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding:12px 16px;display:flex}.cd-domain-pills{flex-wrap:wrap;gap:6px;display:flex}.cd-pill{border:1px solid var(--line);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:100px;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.cd-pill:hover{border-color:var(--accent);color:var(--accent)}.cd-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.cd-pill small{opacity:.7;font-size:10px}.cd-timeline{padding-left:80px;position:relative}.cd-timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), var(--amber), var(--red));border-radius:1px;width:2px;position:absolute;top:0;bottom:0;left:38px}.cd-week{gap:16px;margin-bottom:16px;display:flex;position:relative}.cd-week-marker{flex-direction:column;align-items:center;gap:2px;width:56px;display:flex;position:absolute;top:0;left:-80px}.cd-week-num{background:var(--surface);border:2px solid var(--accent);width:44px;height:44px;color:var(--accent);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex;position:relative}.cd-week-label{color:var(--text-tertiary);white-space:nowrap;font-size:10px;font-weight:600}.cd-week-marker.cd-warning .cd-week-num{border-color:var(--amber);color:var(--amber)}.cd-week-marker.cd-critical .cd-week-num{border-color:var(--red);color:var(--red);animation:2s infinite pulse-ring}@keyframes pulse-ring{0%,to{box-shadow:0 0 #dc262633}50%{box-shadow:0 0 0 6px #dc262600}}@keyframes cdOrbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes cdCellPop{0%{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}.cd-week-content{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);transition:box-shadow var(--transition-fast);flex:1;overflow:hidden}.cd-week-content:hover{box-shadow:var(--shadow-sm)}.cd-week-header{background:var(--surface-raised);border-bottom:1px solid var(--line-light);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.cd-week-header strong{font-size:13px}.cd-week-header span{color:var(--text-tertiary);font-size:11px;font-weight:600}.cd-week-items{padding:6px 0}.cd-item{transition:background var(--transition-fast);align-items:center;gap:10px;padding:8px 16px;display:flex}.cd-item:hover{background:var(--surface-raised)}.cd-item-domain{color:#fff;letter-spacing:.02em;text-align:center;border-radius:4px;flex-shrink:0;min-width:56px;padding:2px 8px;font-size:10px;font-weight:700}.cd-item-action{color:var(--text);font-size:13px;line-height:1.4}@media (width<=900px){.cd-command-grid,.cd-insight-grid{grid-template-columns:1fr}.cd-launch-orbit{flex-basis:130px;width:130px;height:130px}.cd-board{overflow-x:auto}.cd-week-ruler,.cd-gantt-row{min-width:720px}.ops-hero{flex-direction:column;align-items:flex-start}.ops-hero-pulse{width:100%}.ops-kpi-grid,.ops-grid{grid-template-columns:1fr}.ops-stage-flow{grid-template-columns:repeat(7,minmax(80px,1fr));overflow-x:auto}.ops-domain-row{grid-template-columns:72px minmax(0,1fr) 40px}.cd-hero{flex-direction:column;align-items:flex-start;padding:20px}.cd-hero-right{justify-content:center;width:100%}.cd-timeline{padding-left:64px}.cd-timeline:before{left:28px}.cd-week-marker{width:44px;left:-64px}.cd-week-num{width:36px;height:36px;font-size:12px}.cd-toolbar{flex-direction:column;align-items:flex-start}}.stage-template-summary{grid-template-columns:repeat(7,minmax(110px,1fr));gap:8px;margin-bottom:16px;padding-bottom:4px;display:grid;overflow-x:auto}.stage-template-summary article{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-raised);cursor:pointer;transition:all var(--transition-fast);text-align:center;padding:12px}.stage-template-summary article:hover{border-color:var(--accent)}.stage-template-summary article.active{border-color:var(--accent);background:var(--accent-soft)}.stage-template-summary span,.stage-template-summary strong{display:block}.stage-template-summary span{color:var(--text-tertiary);font-size:11px}.stage-template-summary strong{color:var(--text);margin-top:6px;font-size:22px;font-weight:800}.stage-template-summary article.active strong{color:var(--accent-strong)}.workflow-library{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.workflow-library article{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--surface), var(--surface-raised));min-height:170px;transition:all var(--transition-fast);padding:16px}.workflow-library article:hover{border-color:var(--blue);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.workflow-library article>div{color:var(--text-tertiary);justify-content:space-between;gap:10px;font-size:11px;font-weight:600;display:flex}.workflow-library h3{margin:12px 0 8px;font-size:14px;font-weight:700}.workflow-library p,.workflow-library small{color:var(--text-secondary);font-size:12px;line-height:1.55;display:block}.workflow-library small{border-top:1px solid var(--line-light);color:var(--text-tertiary);margin-top:8px;padding-top:8px}.link-action{color:var(--accent);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:0;padding:4px 0 0;font-size:12px;font-weight:700}.link-action:hover{color:var(--accent-strong);text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-10px)scale(.95)}}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{pointer-events:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);align-items:center;gap:10px;min-width:240px;max-width:360px;padding:12px 18px;font-size:13px;font-weight:500;animation:.3s toastIn;display:flex}.toast.hiding{animation:.25s forwards toastOut}.toast-icon{border-radius:50%;flex-shrink:0;place-items:center;width:20px;height:20px;font-size:11px;display:grid}.toast-success .toast-icon{background:var(--green-soft);color:var(--green)}.toast-error .toast-icon{background:var(--red-soft);color:var(--red)}.toast-info .toast-icon{background:var(--blue-soft);color:var(--blue)}.empty-state{color:var(--text-tertiary);text-align:center;place-items:center;gap:8px;padding:48px 24px;display:grid}.empty-state strong{color:var(--text-secondary);font-size:14px}.empty-state p{margin:0;font-size:13px}.search-box{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);min-height:36px;transition:all var(--transition-fast);align-items:center;gap:8px;padding:0 12px;display:flex}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #0d94881a}.search-box input{background:0 0;border:0;outline:none;width:180px;font-size:13px}.search-box input::placeholder{color:var(--text-tertiary)}.login-page{background:linear-gradient(135deg,#f0fdfa 0%,#f8fafc 40%,#f1f5f9 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-container{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);width:100%;max-width:1080px;box-shadow:var(--shadow-xl);grid-template-columns:1fr 1fr;min-height:580px;display:grid;overflow:hidden}.login-left{background:linear-gradient(160deg,#0f766e 0%,#0d9488 40%,#14b8a6 100%);flex-direction:column;justify-content:center;gap:28px;padding:40px 36px;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff1a,#0000 70%);width:240px;height:240px;position:absolute;top:-80px;right:-80px}.login-left:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0f,#0000 70%);width:200px;height:200px;position:absolute;bottom:-60px;left:-60px}.login-brand{align-items:center;gap:16px;display:flex;position:relative}.login-brand .brand-mark{color:#fff;background:#fff3;flex-shrink:0}.login-brand h1{color:#fff;letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800;line-height:1.3}.login-brand p{color:#fff9;letter-spacing:.04em;margin:4px 0 0;font-size:12px}.login-desc p{color:#ffffffd9;margin:0;font-size:14px;line-height:1.7;position:relative}.login-features{flex-direction:column;gap:16px;display:flex;position:relative}.login-feature{align-items:flex-start;gap:12px;display:flex}.login-feature-icon{border-radius:var(--radius-sm);color:#fff;background:#ffffff26;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.login-feature-icon svg{width:18px;height:18px}.login-feature strong{color:#fff;font-size:13px;font-weight:700;display:block}.login-feature small{color:#ffffffa6;font-size:12px;line-height:1.4}.login-right{flex-direction:column;justify-content:center;padding:40px 36px;display:flex;overflow-y:auto}.login-right h2{margin:0 0 4px;font-size:20px;font-weight:800}.login-subtitle{color:var(--text-tertiary);margin:0 0 24px;font-size:13px}.login-role-group{margin-bottom:14px}.login-role-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line-light);align-items:center;gap:6px;margin-bottom:10px;padding-bottom:6px;font-size:11px;font-weight:700;display:flex}.login-role-label svg{width:14px;height:14px}.login-user-list{flex-direction:column;gap:8px;display:flex}.login-user-card{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;width:100%;transition:all var(--transition-fast);text-align:left;align-items:center;gap:12px;padding:10px 14px;display:flex}.login-user-card:hover{border-color:var(--accent);background:var(--accent-ghost);box-shadow:var(--shadow-sm)}.login-user-mgmt{border-color:var(--amber);background:linear-gradient(135deg, var(--surface), #fffbeb)}.login-user-mgmt:hover{border-color:var(--amber);background:var(--amber-soft)}.login-avatar{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:grid}.login-user-mgmt .login-avatar{background:linear-gradient(135deg, var(--amber), #92400e)}.login-user-info{flex-direction:column;min-width:0;display:flex}.login-user-info strong{color:var(--text);font-size:14px;font-weight:700}.login-user-info span{color:var(--text-secondary);font-size:12px}.login-user-info small{color:var(--text-tertiary);font-size:11px}@media (width<=768px){.login-container{grid-template-columns:1fr;min-height:auto}.login-left{gap:20px;padding:28px 24px}.login-right{padding:28px 24px}}.sidebar-user{background:var(--surface-raised);border:1px solid var(--line);border-radius:var(--radius-md);align-items:center;gap:10px;margin:-4px 4px 0;padding:10px 12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:13px;font-weight:800;display:grid}.user-meta{flex-direction:column;gap:1px;min-width:0;display:flex}.user-meta strong{color:var(--text);font-size:13px;font-weight:700}.user-meta span{color:var(--text-tertiary);font-size:11px}.nav-badge{background:var(--red);color:#fff;border-radius:100px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 5px;font-size:10px;font-weight:800;display:inline-flex}.message-list{gap:10px;display:grid}.message-item{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--surface), var(--surface-raised));transition:all var(--transition-fast);cursor:default;grid-template-columns:auto 1fr auto;align-items:flex-start;gap:14px;padding:16px;display:grid}.message-item:hover{box-shadow:var(--shadow-sm)}.message-item.unread{border-color:var(--accent);background:linear-gradient(135deg, var(--surface), #f0fdfa)}.message-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.message-body{text-align:left;min-width:0}.message-head{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px;display:flex}.message-head strong{font-size:14px;font-weight:700}.message-type{color:var(--accent);background:var(--accent-soft);border-radius:var(--radius-sm);padding:2px 8px;font-size:11px;font-weight:700}.message-date{color:var(--text-tertiary);margin-left:auto;font-size:11px}.message-body p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.6}.message-status{color:var(--text-tertiary);padding:4px 0;font-size:12px}@media (width<=1100px){#app[data-layout=app],#app[data-layout=app][data-sidebar-collapsed=true]{grid-template-columns:1fr}.sidebar-toggle{display:none}.sidebar{z-index:10;scrollbar-width:none;flex-direction:row;align-items:center;height:auto;max-height:64px;padding:10px 14px;position:relative;overflow:auto hidden}.sidebar::-webkit-scrollbar{display:none}.nav-groups{scrollbar-width:none;flex-direction:row;gap:8px;margin-left:auto;padding-bottom:0;overflow-x:auto}.nav-groups::-webkit-scrollbar{display:none}.nav-group{flex-direction:row;align-items:stretch;gap:4px}.nav-group h2{display:none}.nav-item{min-width:auto;padding:8px 12px}.nav-item small,.sidebar-note{display:none}.content-grid,.detail-grid,.intro-grid,.intro-hero,.metrics-grid{grid-template-columns:1fr}.span-2{grid-column:span 1}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{flex-wrap:wrap;width:100%}.user-name{display:none}.user-dropdown{width:220px;right:-40px}.project-hero,.logic-flow,.l3-map,.l2-full-grid,.localization-grid,.workflow-library,.template-grid{grid-template-columns:1fr}.usage-steps article{grid-template-columns:40px minmax(0,1fr)}.usage-steps .table-action{grid-column:2;justify-self:start}.hero-facts{grid-template-columns:1fr}.timeline{grid-template-columns:repeat(3,minmax(140px,1fr))}}@media (width<=640px){.main{padding:16px}.timeline{grid-template-columns:repeat(2,minmax(140px,1fr))}.metrics-grid{grid-template-columns:repeat(2,1fr)}.readiness-grid,.template-grid,.workflow-library{grid-template-columns:1fr}}.stage-context{padding:14px 20px}.stage-context .detail-row{padding:6px 0;font-size:13px;line-height:1.7}.stage-context .detail-row b{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:11px;font-weight:700;display:block}.inline-tag{background:var(--surface-raised);border:1px solid var(--line);color:var(--text-secondary);border-radius:100px;margin:2px 4px 2px 0;padding:3px 10px;font-size:12px;display:inline-block}.inline-tag.tag-done{background:var(--green-soft);color:var(--green);border-color:#0596694d;text-decoration:line-through}.inline-tag.tag-progress{background:var(--blue-soft);color:var(--blue);border-color:#3b82f64d}.readiness-mini{text-align:center;padding:12px 16px 0}.readiness-mini strong{color:var(--accent);font-size:32px;font-weight:800}.readiness-mini span{color:var(--text-tertiary);margin-left:4px;font-size:12px}.timeline .stage-node{cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.timeline .stage-node:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.timeline .stage-node.future{opacity:.45;cursor:default}.timeline .stage-node.future:hover{box-shadow:none;transform:none}.timeline .stage-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.text-muted{color:var(--text-tertiary);font-size:13px}.stage-detail-panel{border:1px solid var(--accent);border-radius:var(--radius-md);background:var(--surface);margin-top:16px;overflow:hidden}.stage-detail-panel-header{background:var(--accent-soft);border-bottom:1px solid #0d948833;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.stage-detail-panel-header h3{margin:0;font-size:15px}.stage-detail-panel-header p{color:var(--text-secondary);margin:2px 0 0;font-size:12px}.stage-detail-section{border-bottom:1px solid var(--line-light);padding:14px 20px}.stage-detail-section:last-child{border-bottom:none}.stage-detail-section h4{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 10px;font-size:11px;font-weight:700}.stage-detail-columns{grid-template-columns:repeat(3,1fr);display:grid}.stage-detail-columns .stage-detail-section{border-right:1px solid var(--line-light)}.stage-detail-columns .stage-detail-section:last-child{border-right:none}.stage-detail-section .detail-row{padding:4px 0;font-size:13px}.stage-detail-section .detail-row b{color:var(--text-secondary);font-weight:600}.stage-detail-section .compact-list article{padding:8px 0}@media (width<=1100px){.stage-detail-columns{grid-template-columns:1fr}.stage-detail-columns .stage-detail-section{border-right:none;border-bottom:1px solid var(--line-light)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a73;justify-content:center;align-items:center;animation:.2s modalFadeIn;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:min(560px,100vw - 48px);max-height:calc(100vh - 80px);animation:.25s cubic-bezier(.16,1,.3,1) modalSlideIn;overflow-y:auto}.modal-header{border-bottom:1px solid var(--line-light);justify-content:space-between;align-items:center;padding:20px 24px 12px;display:flex}.modal-header h2{margin:0;font-size:17px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.modal-close:hover{background:var(--line-light);color:var(--text)}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--line-light);justify-content:flex-end;gap:10px;padding:12px 24px 20px;display:flex}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--surface);transition:border-color var(--transition-fast);box-sizing:border-box;padding:8px 12px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ghost);outline:none}.form-group textarea{resize:vertical;min-height:72px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-error{color:var(--red);margin-top:4px;font-size:12px}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.my-tasks-group h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:16px 0 8px;font-size:13px;font-weight:700}.my-tasks-group:first-child h3{margin-top:0}.my-task-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:12px;padding:10px 12px;display:flex}.my-task-item:hover{background:var(--line-light)}.my-task-item .task-meta{flex:1;min-width:0}.my-task-item .task-meta strong{white-space:nowrap;text-overflow:ellipsis;font-size:13px;display:block;overflow:hidden}.my-task-item .task-meta small{color:var(--text-tertiary);font-size:12px}.my-task-item .task-due{white-space:nowrap;font-size:12px;font-weight:600}.my-task-item .task-due.overdue{color:var(--red)}.my-task-item .task-due.today{color:var(--amber)}.my-task-item .task-due.upcoming{color:var(--text-tertiary)}.risk-alert-card{border-radius:var(--radius-sm);border-left:3px solid var(--red);background:var(--red-soft);align-items:flex-start;gap:10px;margin-bottom:8px;padding:10px 12px;display:flex}.risk-alert-card.p1-alert{border-left-color:var(--amber);background:var(--amber-soft)}.risk-alert-card .risk-alert-body{flex:1;min-width:0}.risk-alert-card .risk-alert-body strong{font-size:13px;display:block}.risk-alert-card .risk-alert-body small{color:var(--text-tertiary);font-size:12px}.upcoming-review-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:12px;padding:10px 12px;display:flex}.upcoming-review-item:hover{background:var(--line-light)}.upcoming-review-item .review-meta{flex:1;min-width:0}.upcoming-review-item .review-meta strong{font-size:13px;display:block}.upcoming-review-item .review-meta small{color:var(--text-tertiary);font-size:12px}.decision-options{grid-template-columns:1fr 1fr;gap:8px;display:grid}.decision-option{border:2px solid var(--line);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition-fast);background:var(--surface);padding:10px 14px}.decision-option:hover{border-color:var(--accent)}.decision-option.selected{border-color:var(--accent);background:var(--accent-soft)}.decision-option strong{font-size:14px;display:block}.decision-option small{color:var(--text-tertiary);font-size:12px}.conditional-tasks{background:var(--surface-raised);border-radius:var(--radius-sm);border:1px solid var(--line);margin-top:12px;padding:12px}.conditional-tasks h4{margin:0 0 8px;font-size:13px}.history-timeline{padding:16px 0}.history-entry{border-left:2px solid var(--line);gap:12px;margin-left:8px;padding:8px 0 8px 16px;display:flex;position:relative}.history-entry:before{content:"";background:var(--accent);border-radius:50%;width:8px;height:8px;position:absolute;top:10px;left:-5px}.history-entry .history-content{flex:1}.history-entry .history-content strong{font-size:13px}.history-entry .history-content small{color:var(--text-tertiary);font-size:12px;display:block}.l2-overview-bar{background:linear-gradient(135deg,#f0fdfa 0%,#eff6ff 100%);border:1px solid #e2e8f0;border-radius:12px;flex-wrap:wrap;align-items:center;gap:24px;margin:0 0 20px;padding:16px 20px;display:flex}.l2-stat{flex-direction:column;align-items:center;gap:2px;min-width:60px;display:flex}.l2-stat-num{color:var(--accent);font-size:22px;font-weight:800;line-height:1}.l2-stat-label{color:var(--text-secondary);font-size:11px;font-weight:500}.l2-stat-highlight .l2-stat-num{color:#d97706}.l2-role-tags{flex-wrap:wrap;justify-content:flex-end;gap:6px;max-width:50%;margin-left:auto;display:flex}.l2-role-tag{color:var(--text-secondary);white-space:nowrap;background:#fff;border:1px solid #cbd5e1;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.deliverable-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.deliverable-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;align-items:center;padding:16px 12px;transition:all .2s;display:flex}.deliverable-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 2px 8px #0d948814}.deliverable-icon{margin-bottom:8px;font-size:28px}.deliverable-name{color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.4}.deliverable-owner{color:var(--text-tertiary);background:#f1f5f9;border-radius:10px;margin-top:4px;padding:2px 8px;font-size:11px}.role-resp-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.role-resp-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;transition:all .2s}.role-resp-card:hover{border-color:#cbd5e1;box-shadow:0 2px 6px #0000000a}.role-resp-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;display:flex}.role-resp-header strong{color:var(--text-primary);font-size:14px}.role-resp-count{color:var(--accent);background:#f0fdfa;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.role-resp-list{margin:0;padding:0;list-style:none}.role-resp-list li{color:var(--text-secondary);border-bottom:1px dashed #f1f5f9;padding:5px 0;font-size:12px;line-height:1.5}.role-resp-list li:last-child{border-bottom:none}.role-resp-list li:before{content:"•";color:var(--accent);margin-right:6px;font-weight:700}.l2-inner-nav{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-top:24px;padding:16px 0 0;display:flex}.l2-nav-btn{color:var(--text-secondary);cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.l2-nav-btn:hover{border-color:var(--accent);color:var(--accent);background:#f8fafc}.l2-nav-progress{color:var(--text-tertiary);font-size:13px;font-weight:500}@media (width<=768px){.l2-overview-bar{gap:14px;padding:12px 14px}.l2-role-tags{justify-content:flex-start;max-width:100%;margin-top:8px;margin-left:0}.deliverable-grid{grid-template-columns:repeat(2,1fr)}.role-resp-grid{grid-template-columns:1fr}.l2-inner-nav{flex-wrap:wrap;gap:10px}.l2-nav-btn{padding:6px 12px;font-size:12px}}.pd-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:14px;padding-bottom:14px;display:flex}.pd-header-main h1{color:var(--text);letter-spacing:-.8px;margin-bottom:6px;font-size:28px;font-weight:800;line-height:1.2}.pd-header-main p{color:var(--text-secondary);max-width:560px;font-size:15px;line-height:1.5}.pd-header-actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.pd-countdown{flex-direction:column;align-items:flex-end;display:flex}.pd-countdown-num{font-size:32px;font-weight:800;line-height:1}.pd-countdown-label{opacity:.8;font-size:12px;font-weight:500}.pd-health{border-radius:100px;padding:4px 14px;font-size:12px;font-weight:700}.pd-meta{color:var(--text-secondary);align-items:center;gap:10px;margin-bottom:18px;font-size:13px;display:flex}.pd-meta b{color:var(--text-secondary);margin-right:5px;font-weight:600}.pd-meta-dot{background:#cbd5e1;border-radius:50%;width:3px;height:3px}.pd-timeline-wrap{margin-bottom:18px}.pd-kpi-bar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);gap:0;margin-bottom:24px;display:flex;overflow:hidden}.pd-kpi-item{border-right:1px solid var(--line);flex-direction:column;flex:1;gap:4px;padding:16px 20px;display:flex;position:relative}.pd-kpi-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.pd-kpi-value{color:var(--text);font-size:24px;font-weight:800;line-height:1.2}.pd-kpi-value small{color:var(--text-tertiary);margin-left:2px;font-size:14px;font-weight:500}.pd-kpi-track{background:#f1f5f9;border-radius:2px;height:4px;margin-top:4px;overflow:hidden}.pd-kpi-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.pd-kpi-fill.green{background:#10b981}.pd-kpi-fill.amber{background:#f59e0b}.pd-kpi-fill.red{background:#ef4444}.pd-kpi-sublabel{color:var(--text-tertiary);font-size:12px;font-weight:500}.pd-main-layout{grid-template-columns:1fr 300px;gap:20px;margin-bottom:24px;display:grid}.pd-kanban-area{min-width:0}.pd-section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.pd-section-header h3{color:var(--text);font-size:16px;font-weight:700}.pd-section-actions{gap:8px;display:flex}.pd-sidebar{flex-direction:column;gap:14px;display:flex}.pd-sidebar-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px}.pd-sidebar-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);margin-bottom:10px;font-size:11px;font-weight:700}.pd-sidebar-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.pd-sidebar-header .pd-sidebar-title{margin-bottom:0}.pd-current-stage{color:var(--accent);margin-bottom:10px;font-size:18px;font-weight:700}.pd-sidebar-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.pd-sidebar-row:last-child{border-bottom:none}.pd-sidebar-key{color:var(--text-secondary);font-weight:500}.pd-sidebar-val{color:var(--text);text-align:right;max-width:60%;font-weight:600}.pd-gauge-row{align-items:center;gap:14px;display:flex}.pd-gauge-ring{flex-shrink:0;width:72px;height:72px;position:relative}.pd-gauge-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.pd-gauge-text{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.pd-gauge-text strong{color:var(--text);font-size:16px;font-weight:800}.pd-gauge-list{flex-direction:column;flex:1;gap:6px;display:flex}.pd-gauge-item{color:var(--text);align-items:center;gap:8px;font-size:12px;font-weight:500;display:flex}.pd-gauge-item.ready{color:#94a3b8}.pd-gauge-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.pd-risk-list{flex-direction:column;gap:8px;display:flex}.pd-risk-item{border-bottom:1px solid var(--line);padding:10px 0}.pd-risk-item:last-child{border-bottom:none;padding-bottom:0}.pd-risk-title{align-items:center;gap:8px;margin-bottom:4px;display:flex}.pd-risk-title>span:last-child{color:var(--text);font-size:13px;font-weight:600;line-height:1.3}.pd-risk-priority{border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:700}.pd-risk-priority.p0{color:#dc2626;background:#fee2e2}.pd-risk-priority.p1{color:#b45309;background:#fef3c7}.pd-risk-priority.p2{color:#64748b;background:#f1f5f9}.pd-risk-meta{color:var(--text-tertiary);padding-left:24px;font-size:11px}.pd-review-list{flex-direction:column;gap:8px;display:flex}.pd-review-item{border-bottom:1px solid var(--line);padding:10px 0}.pd-review-item:last-child{border-bottom:none;padding-bottom:0}.pd-review-title{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.pd-review-title>span:first-child{color:var(--text);font-size:13px;font-weight:600;line-height:1.3}.pd-review-status{flex-shrink:0;font-size:12px}.pd-review-status.closed{color:#10b981}.pd-review-status.open{color:#b45309}.pd-review-meta{color:var(--text-tertiary);font-size:11px}.pd-more{color:var(--text-tertiary);text-align:center;padding-top:8px;font-size:11px;font-weight:500}.pd-allclear{color:#10b981;align-items:center;gap:8px;padding:12px 0;font-size:13px;font-weight:500;display:flex}.pd-log-section{border-top:1px dashed var(--line);margin-top:18px;padding-top:18px}.kanban-board{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.kanban-column{background:#f8fafc;border-radius:10px;min-height:200px;padding:10px}.kanban-col-header{border-bottom:2px solid;justify-content:space-between;align-items:center;margin-bottom:10px;padding:6px 8px 10px;font-size:12px;font-weight:700;display:flex}.kanban-todo .kanban-col-header{color:#64748b;border-color:#94a3b8}.kanban-doing .kanban-col-header{color:#b45309;border-color:#f59e0b}.kanban-review .kanban-col-header{color:#1d4ed8;border-color:#3b82f6}.kanban-done .kanban-col-header{color:#059669;border-color:#10b981}.kanban-count{background:#fff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.kanban-col-body{flex-direction:column;gap:8px;display:flex}.kanban-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;transition:all .15s;position:relative}.kanban-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000000f}.kanban-border-overdue,.kanban-border-p0{border-left:3px solid #ef4444}.kanban-border-p1{border-left:3px solid #f59e0b}.kanban-card-title{color:var(--text);margin-bottom:8px;font-size:13px;font-weight:600;line-height:1.4}.kanban-card-tags{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.kanban-tag-domain{color:var(--text-tertiary);background:#f1f5f9;border-radius:10px;padding:2px 8px;font-size:10px}.kanban-tag-priority{border-radius:4px;padding:1px 6px;font-size:10px;font-weight:700}.kanban-tag-priority.p0{color:#dc2626;background:#fee2e2}.kanban-tag-priority.p1{color:#b45309;background:#fef3c7}.kanban-tag-priority.p2{color:#475569;background:#f1f5f9}.kanban-card-footer{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.kanban-card-owner,.kanban-card-due{color:var(--text-tertiary);font-size:11px}.kanban-card-due.overdue{color:#dc2626;font-weight:600}.kanban-card-due.urgent{color:#b45309;font-weight:600}.kanban-card-action{width:100%;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-soft);cursor:pointer;border-radius:6px;padding:6px;font-size:12px;font-weight:600;transition:all .15s}.kanban-card-action:hover{background:var(--accent);color:#fff}.pd-page{animation:.52s both opsRise}.pd-hero-shell{border-radius:var(--radius-xl);color:#fff;background:radial-gradient(circle at 14% 16%,#2dd4bf4d,#0000 28%),radial-gradient(circle at 88% 20%,#3b82f633,#0000 24%),linear-gradient(135deg,#052e2b 0%,#0f172a 58%,#12213a 100%);border:1px solid #2dd4bf2e;align-items:stretch;margin-bottom:12px;padding:28px;position:relative;overflow:hidden;box-shadow:0 24px 50px #0f172a29}.pd-hero-shell:before{content:"";background-image:linear-gradient(#ffffff0f 1px,#0000 1px),linear-gradient(90deg,#ffffff0f 1px,#0000 1px);background-size:44px 44px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#0000,#000 18% 82%,#0000);mask-image:linear-gradient(90deg,#0000,#000 18% 82%,#0000)}.pd-hero-shell>*{z-index:1;position:relative}.pd-hero-shell .eyebrow{color:#5eead4}.pd-hero-shell .pd-header-main h1{color:#fff;letter-spacing:-.05em;margin:6px 0 10px;font-size:34px}.pd-hero-shell .pd-header-main p{color:#ffffffb8;max-width:680px}.pd-hero-tags{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.pd-hero-tags span{color:#ffffffd1;background:#ffffff14;border:1px solid #ffffff24;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.pd-hero-shell .pd-header-actions{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #ffffff24;align-items:center;padding:16px}.pd-hero-shell .pd-countdown{background:#ffffff14;border-radius:50%;justify-content:center;align-items:center;width:104px;height:104px;position:relative}.pd-hero-shell .pd-countdown:before{content:"";opacity:.42;border:2px dashed;border-radius:50%;animation:10s linear infinite cdOrbit;position:absolute;inset:8px}.pd-hero-shell .pd-countdown.critical:before{animation-duration:4s}.pd-hero-shell .pd-countdown-num,.pd-hero-shell .pd-countdown-label{z-index:1;position:relative}.pd-hero-shell .pd-health{border:1px solid #ffffff29;font-size:13px}.pd-meta{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:12px 16px}.pd-action-strip{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#f0fdfae0,#fffffff5),radial-gradient(circle at 0 0,#2dd4bf29,#0000 34%);border:1px solid #0d948838;grid-template-columns:4px minmax(280px,1fr) auto auto auto auto;align-items:center;gap:10px;margin-bottom:16px;padding:14px;display:grid}.pd-detail-tabs{z-index:4;border:1px solid var(--line);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);background:#ffffffe0;gap:8px;margin-bottom:16px;padding:8px;display:flex;position:sticky;top:0}.pd-detail-tabs button{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;min-height:36px;transition:all var(--transition-fast);background:0 0;border:0;padding:0 16px;font-weight:700}.pd-detail-tabs button:hover{background:var(--surface-raised);color:var(--text)}.pd-detail-tabs button.active{background:var(--text);color:#fff;box-shadow:0 8px 18px #0f172a29}.pd-action-strip:before{content:"";background:var(--accent);border-radius:999px;align-self:stretch}.pd-next-action span,.pd-next-action small,.pd-next-action strong{display:block}.pd-next-action span{color:var(--accent-strong);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:800}.pd-next-action strong{margin:2px 0;font-size:16px}.pd-next-action small{color:var(--text-secondary)}.pd-timeline-wrap{border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fff,#f8fafc),radial-gradient(circle at 100% 0,#3b82f614,#0000 30%);padding:18px}.pd-timeline-wrap .timeline{position:relative}.pd-timeline-wrap .timeline:before{content:"";background:linear-gradient(90deg, var(--accent), var(--blue), var(--amber));opacity:.2;height:2px;position:absolute;top:28px;left:4%;right:4%}.pd-timeline-wrap .stage-node{background:linear-gradient(135deg,#fff,#f8fafc);padding-top:40px;animation:.48s both opsRise;overflow:hidden}.stage-node-icon{width:24px;height:24px;color:var(--text-tertiary);border:1px solid var(--line);box-shadow:var(--shadow-xs);background:#fff;border-radius:8px;place-items:center;display:grid;position:absolute;top:14px;right:14px}.stage-node-icon svg{width:14px;height:14px}.pd-timeline-wrap .stage-node:before{content:"";background:#cbd5e1;border-radius:50%;width:16px;height:16px;position:absolute;top:18px;left:14px;box-shadow:0 0 0 6px #f1f5f9}.pd-timeline-wrap .stage-node.done:before{background:var(--accent);box-shadow:0 0 0 6px var(--accent-soft)}.pd-timeline-wrap .stage-node.active:before{background:var(--blue);box-shadow:0 0 0 7px var(--blue-soft);animation:2s infinite opsPulse}.pd-timeline-wrap .stage-node.active{background:linear-gradient(135deg,#eff6ff,#fff)}.pd-timeline-wrap .stage-node.done{background:linear-gradient(135deg,#f0fdfa,#fff)}.pd-timeline-wrap .stage-node.done .stage-node-icon{color:var(--accent);background:var(--accent-soft);border-color:#0d948842}.pd-timeline-wrap .stage-node.active .stage-node-icon{color:var(--blue);background:var(--blue-soft);border-color:#3b82f647}.pd-kpi-bar{background:0 0;border:0;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid;overflow:visible}.pd-kpi-item{border:1px solid var(--line);border-radius:var(--radius-lg);min-height:128px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fff,#f8fafc);animation:.52s both opsRise}.pd-kpi-item:last-child{border-right:1px solid var(--line)}.pd-kpi-fill{animation:.9s both opsGrowX}.pd-main-layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start}.pd-overview-grid,.pd-governance-grid{gap:16px;margin-bottom:20px;display:grid}.pd-overview-grid{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr)}.pd-governance-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pd-kanban-area,.pd-log-section{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:20px}.pd-kanban-area .pd-log-section{border:0;border-top:1px dashed var(--line);box-shadow:none;background:0 0;border-radius:0;padding:18px 0 0}.pd-section-header .eyebrow{margin-bottom:2px}.pd-sidebar{position:sticky;top:18px}.pd-sidebar-card{box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast)}.pd-sidebar-card:hover{box-shadow:var(--shadow-md);border-color:#0d948840;transform:translateY(-2px)}.pd-current-stage{background:var(--accent-ghost);border-radius:999px;margin-bottom:12px;padding:7px 11px;display:inline-flex}.pd-sidebar-row{align-items:flex-start;gap:12px}.pd-sidebar-val{line-height:1.45}.pd-gauge-ring circle:nth-child(2){transition:stroke-dashoffset .9s}.pd-risk-item,.pd-review-item{border-radius:var(--radius-md);border:1px solid var(--line-light);background:#f8fafc;padding:10px}.pd-allclear{border-radius:var(--radius-md);background:var(--green-soft);justify-content:center;padding:14px}.pd-page .kanban-board{gap:12px}.pd-page .kanban-column{border:1px solid var(--line);background:linear-gradient(#f8fafc,#fff);min-height:360px}.pd-page .kanban-card{box-shadow:var(--shadow-xs);animation:.42s both opsRise}.pd-page .kanban-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.pd-brief-shell{border-radius:var(--radius-xl);box-shadow:var(--shadow-md);background:linear-gradient(135deg,#fffffffa,#f8fafcf0),radial-gradient(circle at 0 0,#0d948829,#0000 34%);border:1px solid #0d948838;align-items:stretch;margin-bottom:12px;padding:24px;position:relative}.pd-brief-shell:before{content:"";border-radius:inherit;pointer-events:none;background-image:linear-gradient(#0f766e0a 1px,#0000 1px),linear-gradient(90deg,#0f766e0a 1px,#0000 1px);background-size:34px 34px;position:absolute;inset:0}.pd-brief-shell:after{content:"";border-radius:var(--radius-xl) 0 0 var(--radius-xl);background:linear-gradient(180deg, var(--accent), var(--blue));width:6px;position:absolute;inset:0 auto 0 0}.pd-brief-shell>*{z-index:1;position:relative}.pd-brief-shell .pd-header-main h1{color:var(--text);letter-spacing:-.04em;margin:6px 0 8px;font-size:31px}.pd-brief-shell .pd-header-main p{color:var(--text-secondary);max-width:700px}.pd-brief-shell .pd-hero-tags span{background:var(--accent-ghost);color:var(--accent-strong);border-color:#0d94882e}.pd-brief-shell .pd-header-actions{border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#ffffffd6;align-items:center;padding:14px}.pd-brief-shell .pd-countdown{background:#fff;border:1px solid;border-radius:18px;justify-content:center;align-items:center;width:96px;height:96px;position:relative}.pd-brief-shell .pd-countdown:before{content:"";opacity:.34;border:1px dashed;border-radius:13px;position:absolute;inset:8px}.pd-brief-shell .pd-countdown-num,.pd-brief-shell .pd-countdown-label{z-index:1;position:relative}.pd-brief-shell .pd-health{border:1px solid}.pd-brief-shell+.pd-meta{margin-top:0}@media (width<=1100px){.pd-main-layout,.pd-overview-grid,.pd-governance-grid{grid-template-columns:1fr}.pd-sidebar{flex-flow:wrap;position:static}.pd-sidebar-card{flex:1;min-width:240px}.pd-action-strip{grid-template-columns:4px 1fr 1fr}.pd-next-action{grid-column:2/-1}}@media (width<=768px){.pd-header{flex-direction:column;align-items:flex-start}.pd-header-actions{flex-wrap:wrap;justify-content:flex-start;width:100%}.pd-hero-shell{padding:20px}.pd-hero-shell .pd-header-main h1{font-size:26px}.pd-action-strip{grid-template-columns:4px 1fr}.pd-detail-tabs{overflow-x:auto}.pd-detail-tabs button{white-space:nowrap}.pd-kpi-bar{grid-template-columns:1fr 1fr}.pd-kpi-item{border-right:none;border-bottom:1px solid var(--line)}.pd-kpi-item:nth-child(odd){border-right:1px solid var(--line)}.pd-meta{flex-wrap:wrap}.pd-meta-dot{display:none}.kanban-board{grid-template-columns:1fr}}.pj-hero{border:1px solid var(--line);border-radius:var(--radius-xl);background:linear-gradient(135deg,#f0fdfa 0%,#f8fafc 50%,#eff6ff 100%);justify-content:space-between;align-items:center;gap:24px;margin-bottom:16px;padding:28px;display:flex;position:relative;overflow:hidden}.pj-hero:before{content:"";pointer-events:none;background-image:linear-gradient(#0d94880a 1px,#0000 1px),linear-gradient(90deg,#0d94880a 1px,#0000 1px);background-size:42px 42px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#0000,#000 15% 85%,#0000);mask-image:linear-gradient(90deg,#0000,#000 15% 85%,#0000)}.pj-hero>*{z-index:1;position:relative}.pj-hero-text .eyebrow{color:var(--accent)}.pj-hero-text h2{letter-spacing:-.03em;margin:6px 0 8px;font-size:28px}.pj-hero-text p{max-width:520px;color:var(--text-secondary);margin:0;font-size:14px}.pj-hero-stat{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);text-align:center;min-width:110px;box-shadow:var(--shadow-sm);padding:16px 20px}.pj-hero-stat strong{color:var(--text);font-size:32px;font-weight:800;line-height:1;display:block}.pj-hero-stat span{color:var(--text-tertiary);margin-top:4px;font-size:12px;display:block}.pj-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.pj-kpi-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:16px 18px;transition:all .2s}.pj-kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.pj-kpi-card span{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600;display:block}.pj-kpi-card strong{letter-spacing:-.03em;color:var(--text);margin:8px 0 4px;font-size:30px;font-weight:800;line-height:1;display:block}.pj-kpi-card small{color:var(--text-secondary);font-size:12px;display:block}.pj-kpi-card.green{border-top:3px solid var(--green)}.pj-kpi-card.amber{border-top:3px solid var(--amber)}.pj-kpi-card.red{border-top:3px solid var(--red)}.pj-toolbar{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px;padding:10px 14px;display:flex}.pj-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pj-toolbar-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pj-view-btn{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);color:var(--text-secondary);cursor:pointer;padding:6px 12px;font-size:13px;font-weight:500;transition:all .15s}.pj-view-btn:hover{background:var(--surface-raised);color:var(--text)}.pj-view-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.pj-main-layout{grid-template-columns:1fr 280px;align-items:start;gap:16px;display:grid}.pj-content{min-width:0}.pj-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.pj-card{border:1px solid var(--line);border-radius:var(--radius-lg);cursor:pointer;background:linear-gradient(135deg,#fff,#f8fafc);padding:18px;transition:all .2s;position:relative}.pj-card:hover{box-shadow:var(--shadow-md);border-color:#0d94884d;transform:translateY(-2px)}.pj-card.selected{border-color:var(--accent);background:linear-gradient(135deg,#f0fdfa,#fff);box-shadow:0 8px 24px #0d94881a}.pj-card-top{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;display:flex}.pj-card-top strong{color:var(--text);font-size:15px;font-weight:700;line-height:1.3}.pj-card-goal{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.pj-card-meta{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.pj-card-meta span{color:var(--text-tertiary);background:#f1f5f9;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.pj-card-bars{gap:8px;margin-bottom:14px;display:grid}.pj-card-bars p{align-items:center;gap:8px;margin:0;font-size:12px;display:flex}.pj-card-bars b{color:var(--text-tertiary);min-width:30px;font-weight:600}.pj-card-bars i{background:#edf2f7;border-radius:999px;flex:1;height:6px;position:relative;overflow:hidden}.pj-card-bars em{border-radius:inherit;background:linear-gradient(90deg,#14b8a6,#38bdf8);height:100%;display:block}.pj-card-bars small{color:var(--text-tertiary);text-align:right;min-width:32px;font-size:11px}.pj-card footer{border-top:1px solid var(--line-light);justify-content:space-between;align-items:center;padding-top:12px;font-size:12px;display:flex}.pj-card-launch{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-top:10px;font-size:12px;display:flex}.pj-card-launch .urgent{color:#b45309;font-weight:600}.pj-card-launch .overdue{color:#dc2626;font-weight:600}.pj-card-link{border:1px solid var(--accent-soft);border-radius:var(--radius-md);background:var(--accent-soft);width:100%;color:var(--accent);cursor:pointer;margin-top:12px;padding:8px;font-size:12px;font-weight:600;transition:all .15s}.pj-card-link:hover{background:var(--accent);color:#fff}.pj-insight{flex-direction:column;gap:14px;display:flex}.pj-insight-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:18px}.pj-insight-head{margin-bottom:14px}.pj-stage-mini{grid-template-columns:repeat(7,1fr);align-items:end;gap:6px;min-height:140px;padding-top:8px;display:grid}.pj-stage-mini-col{flex-direction:column;align-items:center;gap:6px;display:flex}.pj-stage-mini-bar{width:100%;min-height:4px;height:var(--h);background:linear-gradient(#2dd4bf,#0d9488);border-radius:999px;transition:height .6s}.pj-stage-mini-col strong{font-size:14px;font-weight:700}.pj-stage-mini-col span{color:var(--text-tertiary);text-align:center;font-size:10px;line-height:1.2}.pj-insight-list{flex-direction:column;gap:8px;display:flex}.pj-insight-item{border-radius:var(--radius-md);cursor:pointer;background:#f8fafc;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;transition:all .15s;display:flex}.pj-insight-item:hover{background:#f0fdfa}.pj-insight-item.hot{background:#fef2f2;border-left:3px solid #ef4444}.pj-insight-item.hot:hover{background:#fee2e2}.pj-insight-item>div:first-child{min-width:0}.pj-insight-item strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;display:block;overflow:hidden}.pj-insight-item span{color:var(--text-tertiary);font-size:11px}.pj-insight-item .urgent{color:#b45309;font-weight:600}.pj-insight-item>span:last-child{color:var(--text-tertiary);flex-shrink:0;font-size:11px}.pj-insight-empty{text-align:center;color:var(--text-secondary);padding:16px 0;font-size:13px}@media (width<=1100px){.pj-main-layout{grid-template-columns:1fr}.pj-insight{flex-flow:wrap}.pj-insight-card{flex:1;min-width:240px}}@media (width<=768px){.pj-hero{flex-direction:column;align-items:flex-start;padding:20px}.pj-kpi-grid{grid-template-columns:repeat(2,1fr)}.pj-toolbar{flex-direction:column;align-items:stretch}.pj-filters,.pj-toolbar-actions{justify-content:space-between}.pj-grid{grid-template-columns:1fr}.pj-stage-mini{min-height:100px}}.wb-page{gap:16px;display:grid}.wb-command-strip{background:radial-gradient(circle at 12% 0,#14b8a638,#0000 34%),radial-gradient(circle at 92% 18%,#2563eb2e,#0000 32%),linear-gradient(135deg,#fff 0%,#f8fbff 52%,#eef7ff 100%);border:1px solid #0f172a14;border-radius:28px;grid-template-columns:minmax(0,1fr) 420px;align-items:stretch;gap:22px;padding:24px;display:grid;position:relative;overflow:hidden;box-shadow:0 18px 46px #0f172a14}.wb-command-strip:after{content:"";border:42px solid #14b8a614;border-radius:50%;width:320px;height:320px;position:absolute;bottom:-120px;right:-80px}.wb-command-strip>*{z-index:1;position:relative}.wb-command-copy .eyebrow,.wb-panel-head .eyebrow{color:var(--accent)}.wb-command-copy h2{letter-spacing:-.04em;color:#102033;margin:8px 0 10px;font-size:clamp(26px,3vw,36px);line-height:1.12}.wb-command-copy p:not(.eyebrow){max-width:680px;color:var(--text-secondary);margin:0;font-size:14px;line-height:1.8}.wb-command-actions{flex-wrap:wrap;gap:10px;margin-top:20px;display:flex}.wb-command-actions .primary-action{align-items:center;gap:8px;display:inline-flex}.wb-command-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.wb-stat{background:#fffc;border:1px solid #0f172a14;border-radius:22px;flex-direction:column;justify-content:space-between;min-height:128px;padding:16px;display:flex;box-shadow:0 14px 30px #0f172a12}.wb-stat span{color:var(--text-secondary);font-size:12px;font-weight:700}.wb-stat strong{letter-spacing:-.05em;color:#102033;font-size:34px;line-height:1}.wb-stat small{color:var(--text-tertiary);font-size:12px}.wb-stat.blue{background:linear-gradient(145deg,#eff6ff,#fff)}.wb-stat.amber{background:linear-gradient(145deg,#fff7ed,#fff)}.wb-stat.red{background:linear-gradient(145deg,#fef2f2,#fff)}.wb-stat.green{background:linear-gradient(145deg,#ecfdf5,#fff)}.wb-stat.purple{background:linear-gradient(145deg,#f5f3ff,#fff)}.wb-top-grid{grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);align-items:start;gap:16px;display:grid}.wb-focus-panel,.wb-panel,.wb-portfolio-panel{background:#fffffff0;border:1px solid #0f172a14;border-radius:24px;padding:20px;box-shadow:0 14px 36px #0f172a0f}.wb-focus-panel{background:linear-gradient(#fffffff5,#f8fafcf5),repeating-linear-gradient(135deg,#14b8a614 0 1px,#0000 1px 14px);min-height:430px}.wb-escalation-stack{gap:16px;display:grid}.wb-alert-panel{background:linear-gradient(145deg,#fff,#fff8f5)}.wb-panel-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.wb-panel-head h3{color:#102033;letter-spacing:-.03em;margin:4px 0 0;font-size:18px}.wb-panel-note{color:var(--text-secondary);margin:-4px 0 16px;font-size:13px}.wb-panel-meta{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.wb-panel-meta span,.wb-soft-badge{color:#1e5fa8;background:#eef7ff;border-radius:999px;align-items:center;min-height:28px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.wb-lower-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);align-items:start;gap:16px;display:grid}.wb-rule-panel{background:radial-gradient(circle at 100% 0,#14b8a61f,#0000 28%),#fff}.wb-rule-list{gap:10px;display:grid}.wb-rule-list div{background:#f8fafc;border:1px solid #0f172a0f;border-radius:16px;grid-template-columns:34px 1fr;align-items:center;gap:10px;padding:12px;display:grid}.wb-rule-list strong{color:#fff;background:#0f766e;border-radius:12px;place-items:center;width:34px;height:34px;font-size:14px;display:grid}.wb-rule-list span{color:var(--text-secondary);font-size:13px;line-height:1.55}.pj-insight-head{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.pj-insight-head .eyebrow{color:var(--accent)}.pj-insight-head h3{margin:4px 0 0;font-size:15px;font-weight:700}.wb-radar-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.wb-stage-stack{flex-direction:column;gap:6px;display:flex}.wb-stack-row{border-radius:var(--radius-md);cursor:pointer;background:#f8fafc;border:1px solid #0f172a0d;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;font-size:13px;transition:all .15s;display:flex}.wb-stack-row:hover{background:#f0fdfa}.wb-stack-row span{color:var(--text-secondary);font-weight:500}.wb-stack-row strong{color:var(--text);text-align:right;min-width:20px;font-size:14px;font-weight:700}@media (width<=1100px){.wb-command-strip,.wb-top-grid,.wb-lower-grid{grid-template-columns:1fr}}@media (width<=768px){.wb-command-strip{border-radius:22px;padding:18px}.wb-command-stats{grid-template-columns:1fr}.wb-panel-head{flex-direction:column;align-items:flex-start}.wb-panel-meta{justify-content:flex-start}.wb-radar-grid{grid-template-columns:1fr}}.pd-header-actions .danger-action{align-items:center;gap:4px;margin-top:0;padding:8px 12px;font-size:13px;display:inline-flex}.login-form{flex-direction:column;gap:14px;margin-bottom:20px;display:flex}.login-form .form-group{flex-direction:column;gap:6px;display:flex}.login-form .form-group label{color:var(--text-secondary);font-size:13px;font-weight:600}.login-form .form-group input{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);color:var(--text);padding:10px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-form .form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.login-form .form-group input::placeholder{color:var(--text-tertiary)}.login-demo{border-top:1px dashed var(--line-light);padding-top:16px}.login-demo-title{color:var(--text-tertiary);align-items:center;gap:6px;margin:0 0 10px;font-size:12px;font-weight:600;display:flex}.login-demo-title svg{width:14px;height:14px}.login-demo-list{gap:10px;max-height:360px;margin-bottom:10px;padding-right:4px;display:grid;overflow-y:auto}.login-demo-tag{border:1px solid var(--line);background:var(--surface-raised);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;align-items:center;padding:4px 10px;font-size:11px;font-weight:500;transition:all .15s;display:inline-flex}.login-demo-tag:hover{border-color:var(--accent);background:var(--accent-ghost);color:var(--accent)}.login-demo-hint{color:var(--text-tertiary);margin:0;font-size:11px}.login-demo-hint strong{color:var(--text-secondary);font-weight:600}
