: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}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:18px 16px 14px;border-bottom:1px solid var(--border-subtle)}.sidebar-logo-mark{display:flex;align-items:center;gap:8px;text-decoration:none}.logo-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);flex-shrink:0}.logo-name{font-family:var(--font-body);font-size:13.5px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.nav-hub{display:flex;flex-direction:column}.nav-hub-toggle{display:flex;align-items:center;gap:7px;padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-size:12.5px;font-weight:500;-webkit-user-select:none;user-select:none;transition:background .15s var(--ease-fast),color .15s}.nav-hub-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-hub-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hub-arrow{transition:transform .2s var(--ease);flex-shrink:0;color:var(--text-muted)}.hub-arrow.open{transform:rotate(90deg)}.nav-hub-children{padding-left:10px;display:flex;flex-direction:column;gap:1px;margin-top:1px}.nav-child{font-size:13px;padding:7px 10px}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-section-label{font-size:10px;font-weight:600;color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;padding:12px 8px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s var(--ease-fast),color .15s;text-decoration:none;color:var(--text-secondary);font-size:13.5px;font-weight:400;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-active);color:var(--gold);font-weight:500}.nav-item .nav-icon{opacity:.7;flex-shrink:0;transition:opacity .15s}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-badge{margin-left:auto;font-family:var(--font-mono);font-size:10px;background:var(--gold-subtle);color:var(--gold);padding:1px 6px;border-radius:var(--radius-full);font-weight:700}.sidebar-footer{padding:12px 8px 16px;border-top:1px solid var(--border-subtle)}.role-switcher-label{font-size:10px;font-weight:600;color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;padding:0 8px 6px}.role-select{width:100%;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:12.5px;padding:7px 10px;cursor:pointer;outline:none;transition:border-color .15s;-moz-appearance:none;appearance:none;-webkit-appearance:none}.role-select:hover{border-color:var(--border-gold)}.role-select:focus{border-color:var(--gold)}.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}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.kpi-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:18px 20px;transition:border-color .15s}.kpi-card:hover{border-color:var(--border-default)}.kpi-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.kpi-value{font-family:var(--font-body);font-size:28px;font-weight:700;color:var(--kpi-color, var(--gold));line-height:1;margin-bottom:4px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-desc{font-size:11.5px;color:var(--text-muted)}.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)}.pipeline-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;margin-bottom:24px}.pipeline-stage{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px 12px;text-align:center;position:relative;overflow:hidden;transition:border-color .2s}.pipeline-stage:before{content:"";position:absolute;top:0;left:0;bottom:0;width:2px;background:var(--stage-color, var(--gold));opacity:.7}.pipeline-stage-num{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--stage-color, var(--gold));line-height:1}.pipeline-stage-name{font-size:10px;font-weight:500;color:var(--text-muted);margin-top:4px;line-height:1.3}.pipeline-stage-dept{font-size:9px;color:var(--text-dim);margin-top:2px}.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)}.alert-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.alert-panel{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.alert-panel-header{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle)}.alert-panel-title{font-size:12px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px}.alert-list{max-height:220px;overflow-y:auto}.alert-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border-subtle);transition:background .15s}.alert-item:last-child{border-bottom:none}.alert-item:hover{background:var(--bg-hover)}.alert-item-info{flex:1;min-width:0}.alert-item-name{font-size:12.5px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert-item-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.alert-item-days{font-family:var(--font-mono);font-size:11px;font-weight:700;padding:2px 6px;border-radius:var(--radius-xs);flex-shrink:0}.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}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.pipeline-grid{grid-template-columns:repeat(4,1fr);gap:6px}.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}.sidebar{position:fixed;left:0;top:0;bottom:0;height:100dvh;z-index:300;transform:translate(-100%);transition:transform .3s var(--ease);width:260px;box-shadow:none}.sidebar.sidebar-open{transform:translate(0);box-shadow:var(--shadow-lg)}.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}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.kpi-value{font-size:26px}.pipeline-grid{grid-template-columns:repeat(8,minmax(100px,1fr));overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;margin-bottom:16px;scroll-snap-type:x mandatory}.pipeline-stage{scroll-snap-align:start}.alert-grid,.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}
