:root{--bg-base: #0C0B09;--bg-sidebar: #111009;--bg-surface: #161410;--bg-elevated: #1E1B16;--bg-overlay: #26221B;--bg-inset: #100F0D;--bg-hover: rgba(212, 168, 83, .06);--bg-active: rgba(212, 168, 83, .12);--gold: #D4A853;--gold-bright: #E8C068;--gold-dim: #A07A30;--gold-subtle: rgba(212, 168, 83, .15);--teal: #3DD6C8;--teal-dim: rgba(61, 214, 200, .2);--text-primary: #F0EBE3;--text-secondary: #A09480;--text-muted: #6B6050;--text-dim: #3C3830;--border-subtle: rgba(240, 235, 227, .05);--border-default: rgba(240, 235, 227, .1);--border-strong: rgba(240, 235, 227, .18);--border-gold: rgba(212, 168, 83, .3);--critical: #E05252;--critical-bg: rgba(224, 82, 82, .12);--warning: #E0A030;--warning-bg: rgba(224, 160, 48, .12);--info: #5B8AE0;--info-bg: rgba(91, 138, 224, .12);--success: #3DB87A;--success-bg: rgba(61, 184, 122, .12);--stage-1-color: #9B8FD6;--stage-2-color: #5B8AE0;--stage-3-color: #E05252;--stage-4-color: #D4A853;--stage-5-color: #7EC8E3;--stage-6-color: #E07A5F;--stage-7-color: #3DB87A;--stage-8-color: #3DD6C8;--prio-high: #E05252;--prio-medium: #E0A030;--prio-low: #5B8AE0;--sidebar-w: 240px;--topbar-h: 56px;--radius-xs: 2px;--radius-sm: 5px;--radius-md: 7px;--radius-lg: 9px;--radius-xl: 13px;--radius-full: 9999px;--shadow-sm: 0 1px 4px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 8px 32px rgba(0,0,0,.6);--shadow-gold: 0 0 20px rgba(212, 168, 83, .2);--font-display: "Playfair Display", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif;--font-mono: "Space Mono", "Courier New", monospace;--ease: cubic-bezier(.16, 1, .3, 1);--ease-fast: cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-base: #F7F5F2;--bg-sidebar: #EFECEA;--bg-surface: #FFFFFF;--bg-elevated: #F2F0EC;--bg-overlay: #E8E4DC;--bg-inset: #ECEAE6;--bg-hover: rgba(212, 168, 83, .07);--bg-active: rgba(212, 168, 83, .13);--text-primary: #1C1916;--text-secondary: #5A5248;--text-muted: #8A8078;--text-dim: #C4BAB0;--border-subtle: rgba(0, 0, 0, .05);--border-default: rgba(0, 0, 0, .09);--border-strong: rgba(0, 0, 0, .16);--border-gold: rgba(212, 168, 83, .35);--critical-bg: rgba(224, 82, 82, .09);--warning-bg: rgba(224, 160, 48, .09);--info-bg: rgba(91, 138, 224, .09);--success-bg: rgba(61, 184, 122, .09);--shadow-sm: 0 1px 4px rgba(0,0,0,.07);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.14);--shadow-gold: 0 0 20px rgba(212, 168, 83, .15)}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--bg-overlay)}[data-theme=light] .role-select{color-scheme:light}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font-body);font-weight:400;background:var(--bg-base);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-overlay);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{display:flex;height:100vh;width:100vw;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.view-body{flex:1;overflow-y:auto;padding:24px 28px}:root{--sb-w: 240px;--sb-w-collapsed: 52px;--sb-pad-x: 14px;--sb-item-h: 36px;--sb-item-radius: 8px;--sb-nest-indent: 28px;--sb-accent: oklch(.78 .12 75);--sb-accent-dim: oklch(.78 .12 75 / .14);--sb-accent-hover: oklch(.78 .12 75 / .07);--sb-accent-bar: oklch(.78 .12 75 / .85);--sb-text: oklch(.92 .02 75);--sb-text-2: oklch(.68 .04 65);--sb-text-muted: oklch(.48 .04 60);--sb-bg: oklch(.12 .015 65);--sb-bg-hover: oklch(.18 .02 65 / .55);--sb-border: oklch(.22 .015 65);--sb-shadow-active: 0 1px 3px oklch(0 0 0 / .25);--sb-ease: cubic-bezier(.16, 1, .3, 1);--sb-ease-expo: cubic-bezier(.16, 1, .3, 1);--sb-ease-fast: cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--sb-accent: oklch(.62 .14 75);--sb-accent-dim: oklch(.62 .14 75 / .11);--sb-accent-hover: oklch(.62 .14 75 / .06);--sb-accent-bar: oklch(.62 .14 75 / .8);--sb-text: oklch(.22 .02 55);--sb-text-2: oklch(.45 .03 55);--sb-text-muted: oklch(.65 .025 55);--sb-bg: oklch(.95 .008 75);--sb-bg-hover: oklch(.88 .01 70 / .6);--sb-border: oklch(.85 .01 70);--sb-shadow-active: 0 1px 3px oklch(0 0 0 / .07)}.sb{width:var(--sb-w);background:var(--sb-bg);border-right:1px solid var(--sb-border);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow:hidden;transition:width .22s var(--sb-ease);position:relative;z-index:40}.sb-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px var(--sb-pad-x) 20px;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .3s}.sb-scroll:hover{scrollbar-color:oklch(.35 .02 65) transparent}.sb-scroll::-webkit-scrollbar{width:5px}.sb-scroll::-webkit-scrollbar-thumb{background:transparent;border-radius:99px;transition:background .3s}.sb-scroll:hover::-webkit-scrollbar-thumb{background:#423930}.sb-header{padding:16px var(--sb-pad-x) 12px;flex-shrink:0}.sb-header__inner{display:flex;align-items:center;gap:8px}.sb-header__brand{display:flex;align-items:center;gap:9px;flex:1;min-width:0}.sb-logo-dot{width:9px;height:9px;border-radius:50%;background:var(--sb-accent);flex-shrink:0;box-shadow:0 0 8px #e4ac5959}.sb-logo-text{font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--sb-text);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .18s var(--sb-ease-fast)}.sb-collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--sb-item-radius);background:none;border:none;color:var(--sb-text-muted);cursor:pointer;flex-shrink:0;transition:color .15s var(--sb-ease-fast),background .15s var(--sb-ease-fast),transform .22s var(--sb-ease)}.sb-collapse-btn:hover{color:var(--sb-text);background:var(--sb-bg-hover)}.sb-collapse-btn:focus-visible{outline:2px solid var(--sb-accent);outline-offset:2px}.sb-user{display:flex;align-items:center;gap:10px;padding:8px var(--sb-pad-x) 14px;border-bottom:1px solid var(--sb-border);margin-bottom:4px;flex-shrink:0}.sb-user__avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--sb-accent),oklch(.62 .1 70));display:flex;align-items:center;justify-content:center;font-size:10.5px;font-weight:700;color:#0c0806;letter-spacing:.03em}.sb-user__info{min-width:0;overflow:hidden;transition:opacity .18s var(--sb-ease-fast)}.sb-user__name{font-size:12.5px;font-weight:600;color:var(--sb-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sb-user__role{font-size:11px;color:var(--sb-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sb-section-label{font-size:10px;font-weight:650;color:var(--sb-text-muted);letter-spacing:.1em;text-transform:uppercase;padding:16px 2px 5px;-webkit-user-select:none;user-select:none;transition:opacity .18s var(--sb-ease-fast)}.sb-hub{display:flex;flex-direction:column;margin-bottom:2px}.sb-hub__toggle{display:flex;align-items:center;gap:8px;height:34px;padding:0 6px;border-radius:var(--sb-item-radius);cursor:pointer;color:var(--sb-text-2);font-size:12.5px;font-weight:550;-webkit-user-select:none;user-select:none;background:none;border:none;width:100%;text-align:left;transition:background .15s var(--sb-ease-fast),color .15s;position:relative}.sb-hub__toggle:hover{background:var(--sb-bg-hover);color:var(--sb-text)}.sb-hub__toggle:focus-visible{outline:2px solid var(--sb-accent);outline-offset:2px}.sb-hub__caret{flex-shrink:0;color:var(--sb-text-muted);transition:transform .2s var(--sb-ease)}.sb-hub__caret--open{transform:rotate(90deg)}.sb-hub__icon{flex-shrink:0;opacity:.5}.sb-hub__label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .18s var(--sb-ease-fast)}.sb-hub__active-dot{width:5px;height:5px;border-radius:50%;background:var(--sb-accent);flex-shrink:0;box-shadow:0 0 6px #e4ac5966}.sb-hub__body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .2s var(--sb-ease-expo)}.sb-hub__body--open{grid-template-rows:1fr}.sb-hub__children{overflow:hidden;padding-left:var(--sb-nest-indent);display:flex;flex-direction:column;gap:1px;border-left:1px solid var(--sb-border);margin-left:12px;margin-top:2px;margin-bottom:2px}.sb-item{display:flex;align-items:center;gap:10px;height:var(--sb-item-h);padding:0 10px;border-radius:var(--sb-item-radius);cursor:pointer;color:var(--sb-text-2);font-family:var(--font-body);font-size:13px;font-weight:450;-webkit-user-select:none;user-select:none;background:none;border:none;width:100%;text-align:left;position:relative;transition:background .15s var(--sb-ease-fast),color .15s}.sb-item:hover{background:var(--sb-bg-hover);color:var(--sb-text)}.sb-item:focus-visible{outline:2px solid var(--sb-accent);outline-offset:2px}.sb-item--active{background:var(--sb-accent-dim);color:var(--sb-accent);font-weight:600;box-shadow:var(--sb-shadow-active)}.sb-item--active:hover{background:var(--sb-accent-dim);color:var(--sb-accent)}.sb-item__accent{position:absolute;left:0;top:6px;bottom:6px;width:2.5px;border-radius:99px;background:var(--sb-accent-bar)}.sb-item__icon{flex-shrink:0;opacity:.6;transition:opacity .15s}.sb-item:hover .sb-item__icon{opacity:.85}.sb-item--active .sb-item__icon{opacity:1}.sb-item__label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .18s var(--sb-ease-fast)}.sb-item--child{height:33px;font-size:12.5px;padding:0 8px}.sb-badge{margin-left:auto;font-family:var(--font-mono);font-size:10px;font-weight:700;background:#e4ac5924;color:var(--sb-accent);padding:1px 7px;border-radius:var(--radius-full);flex-shrink:0;line-height:1.5;transition:opacity .18s var(--sb-ease-fast)}.sb--collapsed{width:var(--sb-w-collapsed)}.sb--collapsed .sb-logo-text,.sb--collapsed .sb-hub__label,.sb--collapsed .sb-hub__caret,.sb--collapsed .sb-badge,.sb--collapsed .sb-section-label,.sb--collapsed .sb-user__info,.sb--collapsed .sb-item__label{opacity:0;width:0;overflow:hidden;pointer-events:none}.sb--collapsed .sb-scroll{display:none}.sb--collapsed .sb-user{justify-content:center;padding:10px 0;border-bottom:none}.sb--collapsed .sb-user__avatar{margin:0}.sb--collapsed .sb-header{padding:14px 0 10px}.sb--collapsed .sb-header__inner{flex-direction:column;align-items:center;gap:10px}.sb--collapsed .sb-header__brand{justify-content:center;flex:unset}.sb--collapsed .sb-collapse-btn{transform:rotate(180deg)}@media (max-width: 768px){.sb{position:fixed;left:0;top:0;z-index:1000;width:var(--sb-w);transform:translate(-100%);transition:transform .25s var(--sb-ease);box-shadow:var(--shadow-lg)}.sb--mobile-open{transform:translate(0)}.sb--collapsed{width:var(--sb-w)}}.topbar{height:var(--topbar-h);background:var(--bg-sidebar);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.topbar-title{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.topbar-subtitle{font-size:12px;color:var(--text-muted);font-family:var(--font-mono);font-size:11px}.topbar-actions{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s var(--ease-fast);outline:none;white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;line-height:1}.btn-primary{background:var(--gold);color:var(--bg-base)}.btn-primary:hover{background:var(--gold-bright);box-shadow:var(--shadow-gold)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-default)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.btn-danger{background:var(--critical-bg);color:var(--critical);border:1px solid rgba(224,82,82,.3)}.btn-danger:hover{background:#e0525233}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:7px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;position:relative}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;transition:border-color .2s}.card:hover{border-color:var(--border-default)}.card-elevated{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:16px}.db{display:flex;flex-direction:column;gap:16px}.db-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px}.db-header__title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-primary);line-height:1.2;margin:0}.db-header__sub{font-size:10px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;margin-top:2px}.db-filters{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.db-filter-pill{display:inline-flex;align-items:center;padding:5px 14px;border-radius:999;font-size:12px;font-weight:500;font-family:var(--font-body);color:var(--text-muted);background:var(--bg-surface);border:.5px solid var(--border-default);cursor:pointer;transition:background .15s cubic-bezier(.25,1,.5,1),color .15s,border-color .15s;min-height:32px}.db-filter-pill:hover{color:var(--text-primary);border-color:var(--border-strong)}.db-filter-pill--active{background:var(--text-primary);color:var(--bg-base);border-color:var(--text-primary);font-weight:600}.db-filter-pill--active:hover{opacity:.9}.db-filter-pill--time{border-style:dashed}.db-filter-pill:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.db-section-label{font-size:10px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;gap:10px;padding-top:4px}.db-section-label:after{content:"";flex:1;height:.5px;background:var(--border-subtle)}.db-kpi-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr 1fr;gap:10px}.db-kpi{position:relative;background:var(--bg-surface);border:.5px solid var(--border-subtle);border-radius:12px;padding:16px 18px;overflow:hidden;transition:border-color .15s cubic-bezier(.25,1,.5,1)}.db-kpi:hover{border-color:var(--border-default)}.db-kpi__label{font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.db-kpi__value{font-family:var(--font-body);font-size:28px;font-weight:700;line-height:1;margin-bottom:4px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.db-kpi__desc{font-size:11.5px;color:var(--text-muted);line-height:1.4}.db-kpi__accent-bar{position:absolute;bottom:0;left:12px;right:12px;height:2px;border-radius:2px;background:var(--db-kpi-accent, var(--border-subtle));opacity:.7}.db-kpi--hero{background:var(--text-primary);border-color:var(--text-primary)}.db-kpi--hero .db-kpi__label{color:var(--bg-overlay)}.db-kpi--hero .db-kpi__value{color:var(--bg-base)}.db-kpi--hero .db-kpi__desc{color:var(--bg-overlay)}.db-kpi__value--hero{font-size:36px}.db-kpi__tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px}.db-brand-tag{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999;background:color-mix(in oklch,var(--bg-base) 25%,transparent);color:var(--bg-overlay);white-space:nowrap}.kpi-grid{display:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge-stage{font-size:10.5px;padding:2px 7px}.priority-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.progress-bar{height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:2px;background:var(--gold);transition:width .4s var(--ease)}.db-pipeline{display:flex;flex-direction:column;gap:6px}.db-pipeline__row{display:grid;gap:8px}.db-pipeline__row--3{grid-template-columns:repeat(3,1fr)}.db-pipeline__row--bottom{grid-template-columns:1fr 1fr 1.4fr}.db-stage{background:var(--bg-surface);border:.5px solid var(--border-subtle);border-radius:12px;padding:14px 16px;text-align:center;position:relative;overflow:hidden;transition:border-color .15s cubic-bezier(.25,1,.5,1)}.db-stage:hover{border-color:var(--border-default)}.db-stage--parallel{border-top:2px solid var(--sc, var(--gold))}.db-stage__dot{width:6px;height:6px;border-radius:50%;background:var(--sc, var(--text-dim));margin:0 auto 6px;opacity:.7}.db-stage__meta{font-size:10px;font-weight:500;color:var(--text-dim);letter-spacing:.03em;margin-bottom:4px}.db-stage__count{font-family:var(--font-body);font-size:26px;font-weight:700;color:var(--text-primary);line-height:1;font-variant-numeric:tabular-nums}.db-stage__name{font-size:11px;font-weight:600;color:var(--text-muted);margin-top:4px}.db-stage__dept{font-size:10px;color:var(--text-dim);margin-top:2px}.db-stage__progress{height:3px;background:var(--border-subtle);border-radius:2px;margin-top:10px;overflow:hidden}.db-stage__progress-fill{height:100%;border-radius:2px;background:var(--sc, var(--gold));transition:width .4s cubic-bezier(.25,1,.5,1)}.db-stage__progress-label{font-size:10px;color:var(--text-dim);margin-top:3px;font-variant-numeric:tabular-nums}.db-gate{display:flex;align-items:center;gap:8px;padding:4px 0;margin:2px 0}.db-gate:before,.db-gate:after{content:"";flex:1;height:1px}.db-gate--amber{background:color-mix(in oklch,var(--warning) 6%,transparent);border-radius:6px;padding:5px 14px}.db-gate--amber:before,.db-gate--amber:after{background:color-mix(in oklch,var(--warning) 20%,transparent)}.db-gate--green{background:color-mix(in oklch,var(--success) 6%,transparent);border-radius:6px;padding:5px 14px}.db-gate--green:before,.db-gate--green:after{background:color-mix(in oklch,var(--success) 20%,transparent)}.db-gate__dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.db-gate--amber .db-gate__dot{background:var(--warning)}.db-gate--green .db-gate__dot{background:var(--success)}.db-gate__text{font-size:10.5px;font-weight:600;letter-spacing:.03em;white-space:nowrap}.db-gate--amber .db-gate__text{color:var(--warning)}.db-gate--green .db-gate__text{color:var(--success)}.db-health{background:var(--bg-surface);border:.5px solid var(--border-subtle);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;justify-content:center}.db-health__label{font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.db-health__bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--border-subtle);gap:1px}.db-health__seg{min-width:4px;transition:width .4s cubic-bezier(.25,1,.5,1)}.db-health__seg--ok{background:var(--success)}.db-health__seg--delay{background:var(--warning)}.db-health__seg--block{background:var(--critical)}.db-health__legend{display:flex;gap:14px;margin-top:10px;font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}.db-health__dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px;vertical-align:middle}.db-health__dot--ok{background:var(--success)}.db-health__dot--delay{background:var(--warning)}.db-health__dot--block{background:var(--critical)}.pipeline-grid,.pipeline-stage{display:none}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.product-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:transform .2s var(--ease),border-color .2s,box-shadow .2s;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}.product-card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-sm)}.product-card-stage-bar{position:absolute;top:0;left:0;right:0;height:3px;background:var(--stage-c, var(--gold))}.product-card-banner{position:relative;margin:-16px -16px 0;height:110px;background:var(--bg-inset);overflow:hidden;border-radius:var(--radius-md) var(--radius-md) 0 0;flex-shrink:0}.product-card-banner-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s var(--ease)}.product-card:hover .product-card-banner-img{transform:scale(1.03)}.product-card-banner-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);opacity:.35}.product-card-banner-upload{position:absolute;bottom:8px;right:8px;width:26px;height:26px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s;color:var(--text-secondary);font-size:10px;font-family:var(--font-body)}.product-card-banner:hover .product-card-banner-upload,.product-card:hover .product-card-banner-upload{opacity:1}.product-card-banner-upload:hover{background:var(--bg-surface);border-color:var(--border-gold);color:var(--gold)}.product-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.product-card-name{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3}.product-card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.product-card-props{display:flex;flex-direction:column;gap:5px}.product-prop-row{display:flex;align-items:center;gap:6px;font-size:11.5px}.product-prop-label{color:var(--text-muted);font-weight:500;min-width:48px}.product-prop-value{color:var(--text-secondary)}.product-card-footer{display:flex;flex-direction:column;gap:6px}.product-card-progress-label{display:flex;justify-content:space-between;align-items:center;font-size:11px}.barrier-tag{display:flex;align-items:center;gap:5px;font-size:10.5px;font-weight:500;padding:3px 8px;border-radius:var(--radius-sm)}.barrier-critical{background:var(--critical-bg);color:var(--critical)}.barrier-warning{background:var(--warning-bg);color:var(--warning)}.barrier-info{background:var(--info-bg);color:var(--info)}.filter-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}.filter-tab{padding:5px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border-default);background:transparent;color:var(--text-secondary);transition:all .15s;font-family:var(--font-body)}.filter-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.filter-tab.active{background:var(--gold-subtle);border-color:var(--border-gold);color:var(--gold)}.db-alerts{display:grid;grid-template-columns:1fr 1fr;gap:10px}.db-alert-panel{background:var(--bg-surface);border:.5px solid var(--border-subtle);border-radius:12px;overflow:hidden}.db-alert-panel__header{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:.5px solid var(--border-subtle)}.db-alert-panel__header--sub{border-bottom:none;padding-bottom:4px}.db-alert-panel__title{font-size:12.5px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:7px}.db-alert-panel__body{max-height:300px;overflow-y:auto}.db-alert-panel__divider{height:.5px;background:var(--border-subtle);margin:0 16px}.db-link{font-size:11px;font-weight:500;font-family:var(--font-body);color:var(--text-muted);background:none;border:none;cursor:pointer;padding:0;white-space:nowrap;transition:color .15s cubic-bezier(.25,1,.5,1)}.db-link:hover{color:var(--text-primary)}.db-link:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.db-alert-row{display:flex;align-items:center;gap:12px;padding:10px 16px;width:100%;background:none;border:none;border-bottom:.5px solid var(--border-subtle);cursor:pointer;text-align:left;font-family:var(--font-body);transition:background .15s cubic-bezier(.25,1,.5,1)}.db-alert-row:last-child{border-bottom:none}.db-alert-row:hover{background:color-mix(in oklch,var(--text-muted) 6%,transparent)}.db-alert-row:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}.db-alert-row__avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:.03em;background:color-mix(in oklch,var(--av-color, var(--text-dim)) 15%,transparent);color:var(--av-color, var(--text-muted))}.db-alert-row__info{flex:1;min-width:0}.db-alert-row__name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-alert-row__sub{font-size:11px;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-alert-row__barrier{font-size:11px;color:var(--text-dim);margin-top:2px;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-alert-row__right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}.db-alert-row__date{font-size:10.5px;color:var(--text-dim);white-space:nowrap}.db-alert-row--blocked{padding-left:0}.db-alert-row__sev-bar{width:3px;align-self:stretch;flex-shrink:0;background:var(--sev-color, var(--warning));border-radius:0}.db-alert-row--ceo{padding:8px 16px}.db-pill{display:inline-flex;align-items:center;font-size:11px;font-weight:700;font-family:var(--font-mono);padding:2px 8px;border-radius:999;white-space:nowrap;font-variant-numeric:tabular-nums}.db-pill--critical{background:var(--critical-bg);color:var(--critical);border:.5px solid color-mix(in oklch,var(--critical) 25%,transparent)}.db-pill--warning{background:var(--warning-bg);color:var(--warning);border:.5px solid color-mix(in oklch,var(--warning) 25%,transparent)}.db-pill--info{background:var(--info-bg);color:var(--info)}.db-pill--ceo{background:var(--warning-bg);color:var(--warning);border:.5px solid color-mix(in oklch,var(--warning) 25%,transparent);font-family:var(--font-body);font-weight:600}.db-pill--critical-count{background:var(--critical-bg);color:var(--critical);font-family:var(--font-mono);font-size:10.5px;padding:1px 7px;border-radius:999}.db-pill--warning-count,.db-pill--ceo-count{background:var(--warning-bg);color:var(--warning);font-family:var(--font-mono);font-size:10.5px;padding:1px 7px;border-radius:999}.db-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:30px 20px;color:var(--text-dim);font-size:12.5px}.db-empty svg{opacity:.35}.alert-grid,.alert-panel,.alert-item{display:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s var(--ease)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes confirmBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes confirmPanelIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-panel{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:640px;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .25s var(--ease)}.modal-panel-wide{max-width:880px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;gap:12px}.modal-title{font-family:var(--font-body);font-size:16px;font-weight:700;color:var(--text-primary);flex:1;letter-spacing:-.01em}.modal-subtitle{font-size:12px;color:var(--text-muted);margin-top:3px}.modal-body{flex:1;overflow-y:auto;padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:flex-end;gap:8px;background:var(--bg-surface)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.form-required{color:var(--critical);margin-left:2px}.form-input,.form-select,.form-textarea{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:13.5px;padding:9px 12px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-subtle)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;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='%236B6050' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stage-list{display:flex;flex-direction:column;gap:8px}.stage-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s}.stage-item.active-stage{border-color:var(--stage-color, var(--gold))}.stage-item.completed-stage{opacity:.6}.stage-item-header{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer}.stage-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;font-weight:700;flex-shrink:0;background:var(--stage-color, var(--gold));color:var(--bg-base)}.stage-item-name{flex:1;font-size:13px;font-weight:600;color:var(--text-primary)}.stage-item-dept{font-size:11px;color:var(--text-muted)}.stage-item-body{padding:12px 14px;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:10px}.task-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--bg-overlay);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);transition:border-color .15s}.task-check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.task-check.checked{background:var(--success);border-color:var(--success)}.task-check.checked:after{content:"";width:8px;height:5px;border-left:1.5px solid white;border-bottom:1.5px solid white;transform:rotate(-45deg) translateY(-1px)}.task-label{flex:1;font-size:12.5px;color:var(--text-secondary)}.task-label.done{text-decoration:line-through;color:var(--text-muted)}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:500;overflow:hidden;animation:slideUp .2s var(--ease)}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-subtle)}.notif-title{font-size:13px;font-weight:600;color:var(--text-primary)}.notif-list{max-height:360px;overflow-y:auto}.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-subtle);transition:background .15s;cursor:pointer}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:#d4a8530a}.notif-item.unread:before{content:"";position:absolute;left:0;width:3px;height:100%;background:var(--gold);border-radius:0 2px 2px 0}.notif-item{position:relative}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:4px}.notif-dot.read{background:var(--text-dim)}.notif-body{flex:1;min-width:0}.notif-msg{font-size:12.5px;color:var(--text-secondary);line-height:1.4}.notif-msg strong{color:var(--text-primary)}.notif-time{font-size:10.5px;color:var(--text-muted);margin-top:3px}.notif-channels{display:flex;gap:4px;margin-top:4px}.notif-channel-badge{font-size:9px;font-weight:600;padding:1px 5px;border-radius:var(--radius-xs);letter-spacing:.05em}.timeline-controls{display:flex;align-items:center;gap:8px;margin-bottom:20px}.gantt-container{overflow-x:auto;overflow-y:visible}.gantt-row{display:flex;align-items:center;min-height:44px;border-bottom:1px solid var(--border-subtle)}.gantt-label{width:200px;flex-shrink:0;padding:8px 12px;border-right:1px solid var(--border-subtle)}.gantt-label-name{font-size:12.5px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-label-meta{font-size:10.5px;color:var(--text-muted)}.gantt-bar-area{flex:1;position:relative;height:44px}.gantt-bar{position:absolute;top:50%;transform:translateY(-50%);height:20px;border-radius:4px;display:flex;align-items:center;padding:0 8px;font-size:10.5px;font-weight:500;color:var(--bg-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:40px;transition:opacity .15s}.gantt-today-line{position:absolute;top:0;bottom:0;width:1px;background:var(--gold);opacity:.5;z-index:2}.gantt-header-row{display:flex;border-bottom:1px solid var(--border-default);background:var(--bg-surface);position:sticky;top:0;z-index:3}.gantt-header-label{width:200px;flex-shrink:0;padding:8px 12px;font-size:11px;font-weight:600;color:var(--text-muted);border-right:1px solid var(--border-subtle);letter-spacing:.06em;text-transform:uppercase}.gantt-header-dates{flex:1;display:flex;position:relative;overflow:hidden}.gantt-month-label{position:absolute;font-size:10.5px;font-weight:600;color:var(--text-muted);top:8px;padding:0 8px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.calendar-day-header{background:var(--bg-surface);padding:8px 4px;text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.calendar-day{background:var(--bg-surface);min-height:90px;padding:6px;display:flex;flex-direction:column;gap:3px}.calendar-day.other-month{background:var(--bg-sidebar);opacity:.5}.calendar-day.today{background:var(--bg-overlay)}.calendar-date{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:2px}.today .calendar-date{background:var(--gold);color:var(--bg-base);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.calendar-event{font-size:10px;font-weight:500;padding:2px 5px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.team-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.team-card-header{padding:16px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-subtle);position:relative}.team-card-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--dept-color, var(--gold))}.team-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.team-dept-name{font-size:13.5px;font-weight:600;color:var(--text-primary)}.team-dept-sub{font-size:11px;color:var(--text-muted)}.team-stats{display:flex;gap:16px;margin-left:auto}.team-stat{text-align:center}.team-stat-val{font-family:var(--font-mono);font-size:16px;font-weight:700;color:var(--text-primary);line-height:1}.team-stat-label{font-size:9.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.team-card-body{padding:12px 18px}.team-product-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-subtle)}.team-product-item:last-child{border-bottom:none}.team-product-name{flex:1;font-size:12.5px;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section-title{font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;display:flex;align-items:center;gap:8px}.section-title:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;color:var(--text-muted);text-align:center}.empty-state-icon{font-size:32px;opacity:.4}.empty-state-text{font-size:13px}.divider{height:1px;background:var(--border-subtle);margin:16px 0}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--bg-overlay);color:var(--text-primary);font-size:11px;padding:4px 8px;border-radius:var(--radius-xs);border:1px solid var(--border-default);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:100}[data-tooltip]:hover:after{opacity:1}.close-btn{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0}.close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.step-connector{display:flex;align-items:center;gap:6px;padding:0 14px;color:var(--text-dim);font-size:11px}.unread-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;background:var(--critical);color:#fff;font-size:9px;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 3px;font-family:var(--font-mono);border:2px solid var(--bg-sidebar)}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.loading-shimmer{background:linear-gradient(90deg,var(--bg-surface) 25%,var(--bg-elevated) 50%,var(--bg-surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.approval-gate{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--bg-overlay);border-radius:var(--radius-md);border:1px solid var(--border-default)}.approval-gate-title{font-size:12px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.text-gold{color:var(--gold)}.text-muted{color:var(--text-muted)}.text-critical{color:var(--critical)}.text-warning{color:var(--warning)}.text-success{color:var(--success)}.text-mono{font-family:var(--font-mono)}.text-display{font-family:var(--font-display)}.font-600{font-weight:600}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.flex-1{flex:1}.w-full{width:100%}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.hamburger-btn{display:none;padding:8px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;min-width:36px;min-height:36px;transition:all .15s var(--ease-fast)}.hamburger-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:299;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .2s var(--ease)}.sidebar-backdrop.visible{display:block}.product-page-body{display:flex;flex:1;min-height:0}.product-page-left{width:200px;flex-shrink:0;border-right:1px solid var(--border-subtle);padding:16px 14px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.product-page-center{flex:1;overflow-y:auto;padding:16px 20px;min-width:0}.product-page-right{width:300px;flex-shrink:0;border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden;transition:width .22s cubic-bezier(.25,1,.5,1)}.product-page-right--collapsed{width:32px}.activity-log-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.product-page-right--collapsed .activity-log-content{display:none}.product-page-right--collapsed .activity-log-rail{display:flex}.activity-log-rail{display:none;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:14px;gap:10px;height:100%}.activity-log-rail-label{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-size:10.5px;font-weight:600;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;-webkit-user-select:none;user-select:none;white-space:nowrap}.activity-log-toggle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);background:none;border:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color .15s,background .15s}.activity-log-toggle:hover{color:var(--text-primary);background:var(--bg-hover)}@media (max-width: 1024px){.db-kpi-grid{grid-template-columns:1fr 1fr 1fr}.db-kpi--hero{grid-column:1 / -1}.db-pipeline__row--bottom{grid-template-columns:1fr 1fr}.db-health{grid-column:1 / -1}.db-alerts{grid-template-columns:1fr}.view-body{padding:20px}.product-page-left{width:180px}.product-page-right{width:260px}}@media (max-width: 640px){html{font-size:13px}.hamburger-btn{display:flex}.sb{width:var(--sb-w)}.app-shell{position:relative}.main-content{width:100%;min-width:0}.view-body{padding:14px 16px}.topbar{padding:0 14px;gap:8px}.topbar-subtitle{display:none}.topbar-title{font-size:14px}.db-kpi-grid{grid-template-columns:1fr 1fr;gap:8px}.db-kpi--hero{grid-column:1 / -1}.db-kpi__value{font-size:24px}.db-kpi__value--hero{font-size:30px}.db-pipeline__row--3,.db-pipeline__row--bottom,.db-alerts{grid-template-columns:1fr}.db-header{flex-direction:column;align-items:flex-start}.db-filters{width:100%;overflow-x:auto;flex-wrap:nowrap}.form-row,.grid-2{grid-template-columns:1fr}.modal-overlay{padding:0;align-items:flex-end}.modal-panel{max-width:100%;width:100%;max-height:92dvh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:slideUp .3s var(--ease)}.modal-header{padding:18px 20px 14px}.modal-body{padding:16px 20px}.modal-footer{padding:14px 20px}.notif-panel{position:fixed;top:var(--topbar-h);left:12px;right:12px;width:auto;max-height:70dvh;border-radius:var(--radius-lg);animation:slideUp .2s var(--ease)}.notif-list{max-height:55dvh}.team-grid{grid-template-columns:1fr}.filter-tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:10px;scrollbar-width:none;-webkit-overflow-scrolling:touch;margin-bottom:14px}.filter-tabs::-webkit-scrollbar{display:none}.gantt-label,.gantt-header-label{width:130px}.nav-item{min-height:44px}.btn-icon{min-height:36px;min-width:36px}.filter-tab{min-height:36px;padding:6px 14px}.product-page-body{flex-direction:column}.product-page-left{width:100%;border-right:none;border-bottom:1px solid var(--border-subtle);flex-direction:row;flex-wrap:wrap;gap:16px;padding:12px 16px;overflow-y:visible;overflow-x:auto;flex-shrink:0}.product-page-center{padding:14px 16px;overflow-y:visible;min-height:0}.product-page-right{width:100%;border-left:none;border-top:1px solid var(--border-subtle);max-height:50vh;flex-shrink:0}.calendar-day{min-height:60px}.section-title{font-size:11px}.kpi-card{padding:14px 16px}.kanban-column{width:200px}.products-table th,.products-table td{padding:8px 10px}}.task-notes-area{width:100%;background:var(--bg-inset, var(--bg-elevated));border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:13px;line-height:1.65;padding:10px 12px;resize:vertical;transition:border-color .15s;outline:none}.task-notes-area:focus{border-color:var(--border-gold);background:var(--bg-surface)}.task-notes-area:disabled{opacity:.65;cursor:default;resize:none}.task-notes-area::placeholder{color:var(--text-dim);font-style:italic}.ceo-approval-card{display:flex;gap:14px;padding:16px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color .15s,box-shadow .15s;position:relative;overflow:visible}.ceo-approval-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-sm)}.kanban-board{display:flex;gap:12px;overflow-x:auto;align-items:flex-start;padding-bottom:16px;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.kanban-column{flex-shrink:0;width:240px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border-subtle);background:var(--bg-elevated);position:sticky;top:0}.kanban-card{position:relative;margin:8px;padding:10px 11px;background:var(--bg-overlay);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .1s;overflow:hidden}.kanban-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.products-table-wrap{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.products-table{width:100%;border-collapse:collapse;font-size:12.5px;background:var(--bg-surface)}.products-table thead tr{background:var(--bg-elevated);border-bottom:1px solid var(--border-default)}.products-table th{padding:9px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;border-right:1px solid var(--border-subtle)}.products-table th:last-child{border-right:none}.products-table td{padding:10px 14px;border-bottom:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);vertical-align:middle}.products-table td:last-child{border-right:none}.products-table tbody tr:last-child td{border-bottom:none}.products-table-row{cursor:default;transition:background .1s}.products-table-row:hover{background:var(--bg-hover)}.inline-edit-cell{border-radius:4px;transition:background .1s;cursor:text}.inline-edit-cell:hover{background:var(--bg-overlay)}.open-product-btn:hover{background:var(--bg-overlay)!important;color:var(--text-primary)!important;border-color:var(--border-strong)!important}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.projects-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}.project-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .12s;overflow:hidden;display:flex;flex-direction:column}.project-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.kanban-board{display:grid;grid-template-columns:repeat(4,minmax(240px,1fr));gap:14px;align-items:start;min-width:max-content}.kanban-col{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-subtle);background:var(--bg-overlay)}.kanban-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 5px;border-radius:999px;background:var(--bg-active);font-size:10.5px;font-weight:700;color:var(--text-muted)}.kanban-col-body{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:80px}.kanban-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:11px 12px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.kanban-card:hover{border-color:var(--border-strong);box-shadow:0 2px 8px #00000040}.projects-table{width:100%;border-collapse:collapse}.projects-table-row{cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border-subtle)}.projects-table-row:hover{background:var(--bg-hover)}.project-detail-panel{width:400px;min-width:340px;border-left:1px solid var(--border-subtle);background:var(--bg-surface);display:flex;flex-direction:column;height:100%;overflow:hidden;flex-shrink:0;animation:slideInRight .18s var(--ease)}@keyframes slideInRight{0%{transform:translate(30px);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 900px){.project-detail-panel{position:fixed;right:0;top:0;bottom:0;width:100vw;max-width:480px;z-index:300;box-shadow:-4px 0 32px #00000080}.kanban-board{grid-template-columns:repeat(2,minmax(220px,1fr))}.projects-gallery{grid-template-columns:1fr}}.product-mkt-card{display:flex;align-items:stretch;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:border-color .12s,box-shadow .12s;overflow:hidden}.product-mkt-card:hover{border-color:var(--border-strong);box-shadow:0 2px 8px #0003}.product-mkt-card.selected{border-color:var(--gold);background:var(--gold-subtle)}.card-menu-btn:hover{background:var(--bg-hover)!important;color:var(--text-secondary)!important}tr:hover .task-row-actions{opacity:1!important}
