:root{--navy: #0B1530;--teal: #00A79D;--teal-600: #008C84;--teal-700: #00736C;--mint: #66E0D6;--red: #EF4444;--amber: #F59E0B;--green: #10B981;--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--fs-h1: 30px;--ease: cubic-bezier(.4, 0, .2, 1);--density-mul: 1;--gap-base: 12px;--pad-base: 14px;--topbar-h: 64px;--fs-base: 14px;--type-weight: 500;--type-spacing: -.02em}:root,[data-theme=light]{--canvas: #F1F5F9;--surface: #FFFFFF;--surface-2: #F8FAFC;--surface-3: #EEF2F7;--border: #E3E8EF;--border-strong: #CBD5E1;--text: #0B1530;--text-2: #5B677A;--text-3: #94A3B8;--sidebar-bg: #0B1530;--sidebar-2: #0F1C3D;--sidebar-text: rgba(255, 255, 255, .62);--sidebar-text-strong: #FFFFFF;--sidebar-hover: rgba(255, 255, 255, .07);--sidebar-active: rgba(0, 167, 157, .16);--sidebar-border: rgba(255, 255, 255, .08);--primary: var(--teal);--primary-hover: var(--teal-600);--primary-soft: #E2F6F4;--primary-text: #00736C;--green-soft: #DCFCE7;--green-text: #047857;--amber-soft: #FEF3C7;--amber-text: #B45309;--red-soft: #FEE2E2;--red-text: #B91C1C;--slate-soft: #EEF2F6;--slate-text: #5B677A;--shadow-sm: 0 1px 2px rgba(11, 21, 48, .06);--shadow: 0 1px 3px rgba(11, 21, 48, .07), 0 6px 18px rgba(11, 21, 48, .05);--shadow-lg: 0 12px 40px rgba(11, 21, 48, .14);--gantt-track: #EEF2F7;--drag-ghost: #fff}[data-theme=dark]{--canvas: #070D1C;--surface: #0F1A33;--surface-2: #13213F;--surface-3: #182A4D;--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .16);--text: #EEF3FA;--text-2: #93A1B8;--text-3: #64748B;--sidebar-bg: #050A18;--sidebar-2: #0B1530;--sidebar-text: rgba(255, 255, 255, .6);--sidebar-text-strong: #FFFFFF;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active: rgba(0, 167, 157, .2);--sidebar-border: rgba(255, 255, 255, .07);--primary: var(--teal);--primary-hover: var(--mint);--primary-soft: rgba(0, 167, 157, .16);--primary-text: #5BE2D6;--green-soft: rgba(16, 185, 129, .16);--green-text: #4ADE9E;--amber-soft: rgba(245, 158, 11, .16);--amber-text: #FBBF6E;--red-soft: rgba(239, 68, 68, .17);--red-text: #FB8585;--slate-soft: rgba(148, 163, 184, .14);--slate-text: #93A1B8;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 1px 3px rgba(0, 0, 0, .35), 0 8px 24px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .5);--gantt-track: #16243F;--drag-ghost: #13213F}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:Inter,system-ui,sans-serif;background:var(--canvas);color:var(--text);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{height:100%}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--text-3);background-clip:padding-box}.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:248px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;border-right:1px solid var(--sidebar-border);transition:width .2s var(--ease)}.sidebar.collapsed{width:70px}.sb-brand{display:flex;align-items:center;gap:12px;padding:22px 20px 20px;height:78px}.sb-logo-mark{flex-shrink:0}.sb-wordmark{font-size:23px;font-weight:800;letter-spacing:.15em;color:#fff;white-space:nowrap}.sb-wordmark-pm{color:#00a79d}.sidebar.collapsed .sb-wordmark{display:none}.sidebar.collapsed .sb-brand{padding:20px 0;justify-content:center}.sb-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 12px}.sb-scroll::-webkit-scrollbar{width:0}.sb-section{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffff52;padding:16px 12px 7px}.sidebar.collapsed .sb-section{opacity:0;height:22px;padding:4px 0}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;margin:2px 0;border-radius:var(--r-sm);color:var(--sidebar-text);font-size:13.5px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;transition:background .14s,color .14s;white-space:nowrap}.nav-item:hover{background:var(--sidebar-hover);color:#fff}.nav-item.active{background:var(--sidebar-active);color:#fff}.nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--teal)}.nav-item .ni-icon{width:19px;height:19px;flex-shrink:0;display:grid;place-items:center}.nav-item .ni-icon svg{width:18px;height:18px}.nav-item .ni-badge{margin-left:auto;font-size:10.5px;font-weight:700;background:var(--red);color:#fff;min-width:18px;height:18px;padding:0 5px;border-radius:99px;display:grid;place-items:center}.sidebar.collapsed .nav-item{justify-content:center;gap:0;padding:10px 0}.sidebar.collapsed .nav-item .ni-label,.sidebar.collapsed .nav-item .ni-badge{display:none}.sidebar.collapsed .nav-item.active:before{left:-12px}.nav-project{display:flex;align-items:center;gap:10px;padding:9px 12px;margin:2px 0;border-radius:var(--r-sm);cursor:pointer;color:var(--sidebar-text);font-size:13px;font-weight:600;transition:background .14s,color .14s;-webkit-user-select:none;user-select:none}.nav-project:hover{background:var(--sidebar-hover);color:#fff}.nav-project.active{color:#fff}.nav-project .np-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.nav-project .np-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.nav-project .np-chevron{color:#ffffff59;transition:transform .2s var(--ease);display:grid;place-items:center;flex-shrink:0}.nav-project.expanded .np-chevron{transform:rotate(90deg)}.nav-subtabs{padding-left:4px;border-left:1px solid rgba(255,255,255,.09);margin:1px 0 8px 16px}.nav-subtab{display:flex;align-items:center;gap:9px;padding:6px 12px 6px 14px;margin:1px 0;border-radius:var(--r-xs);cursor:pointer;color:#ffffff80;font-size:12.5px;font-weight:500;transition:background .14s,color .14s;white-space:nowrap}.nav-subtab:hover{background:var(--sidebar-hover);color:#fff}.nav-subtab.active{background:var(--sidebar-active);color:#fff;font-weight:600}.nav-subtab .st-icon{width:16px;height:16px;display:grid;place-items:center;flex-shrink:0;opacity:.85}.nav-subtab .st-badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--red);color:#fff;min-width:16px;height:16px;padding:0 4px;border-radius:99px;display:grid;place-items:center}.sidebar.collapsed .nav-project .np-name,.sidebar.collapsed .nav-project .np-chevron,.sidebar.collapsed .nav-subtabs{display:none}.sidebar.collapsed .nav-project{justify-content:center;gap:0;padding:10px 0}.sb-foot{border-top:1px solid var(--sidebar-border);padding:12px}.sb-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;transition:background .14s}.sb-user:hover{background:var(--sidebar-hover)}.sb-avatar{width:32px;height:32px;border-radius:9px;flex-shrink:0;background:linear-gradient(135deg,var(--teal),#0B6E78);color:#fff;font-size:12px;font-weight:700;display:grid;place-items:center}.sb-user-meta{min-width:0}.sb-user-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user-role{font-size:11px;color:#fff6;white-space:nowrap}.sidebar.collapsed .sb-user-meta{display:none}.sidebar.collapsed .sb-user{justify-content:center;padding:8px 0}.sb-collapse-btn{margin-left:auto;flex-shrink:0;width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--sidebar-border);background:transparent;color:var(--sidebar-text);display:grid;place-items:center;cursor:pointer;transition:background .14s,color .14s}.sb-collapse-btn:hover{background:var(--sidebar-hover);color:#fff}.sidebar.collapsed .sb-logo-mark{display:none}.sidebar.collapsed .sb-collapse-btn{margin-left:0}.sb-actions{display:flex;align-items:center;gap:6px;padding:4px 2px 10px}.sidebar.collapsed .sb-actions{justify-content:center;flex-direction:column;gap:4px}.sb-act-btn{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--sidebar-border);background:transparent;color:var(--sidebar-text);display:grid;place-items:center;cursor:pointer;position:relative;flex-shrink:0;transition:background .14s,color .14s}.sb-act-btn:hover{background:var(--sidebar-hover);color:#fff}.sb-act-btn .dot-alert{position:absolute;top:6px;right:7px;width:6px;height:6px;border-radius:50%;background:var(--red);border:2px solid var(--sidebar-bg)}.icon-btn{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-2);display:grid;place-items:center;position:relative;transition:background .14s,color .14s,border .14s}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn .dot-alert{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--red);border:2px solid var(--surface)}.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 calc(var(--pad-base) + 12px) calc(var(--pad-base) + 12px)}.content-inner{max-width:1380px;margin:0 auto}.page-head{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap;position:sticky;top:0;z-index:30;background:var(--canvas);padding:calc(var(--pad-base) + 12px) calc(var(--pad-base) + 12px) 16px;margin:0 calc(-1 * (var(--pad-base) + 12px)) 22px;border-bottom:1px solid var(--border)}.page-head h1{font-size:23px;font-weight:700;letter-spacing:-.02em}.page-head .ph-sub{font-size:13px;color:var(--text-2);margin-top:3px}.page-head .ph-actions{margin-left:auto;display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:13px;font-weight:600;transition:background .14s,border .14s,transform .06s,box-shadow .14s;white-space:nowrap}.btn:hover{background:var(--surface-2)}.btn:active{transform:translateY(1px)}.btn svg{width:16px;height:16px}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px 2px #00a79d59}.btn-primary:hover{background:var(--primary-hover);color:#fff}.btn-ghost{border-color:transparent;background:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-sm{padding:6px 11px;font-size:12px;gap:5px}.btn-danger{color:var(--red-text)}.btn-danger:hover{background:var(--red-soft);border-color:transparent}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm)}.card-head{display:flex;align-items:center;gap:var(--gap-base);padding:calc(var(--pad-base) + 1px) calc(var(--pad-base) + 4px);border-bottom:1px solid var(--border)}.card-head h3{font-size:13px;font-weight:700;letter-spacing:-.01em}.card-head .ch-actions{margin-left:auto;display:flex;gap:6px;align-items:center}.card-body{padding:var(--pad-base)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;line-height:1;padding:4px 9px;border-radius:99px;white-space:nowrap}.badge .b-dot{width:6px;height:6px;border-radius:50%}.b-green{background:var(--green-soft);color:var(--green-text)}.b-amber{background:var(--amber-soft);color:var(--amber-text)}.b-red{background:var(--red-soft);color:var(--red-text)}.b-teal{background:var(--primary-soft);color:var(--primary-text)}.b-slate{background:var(--slate-soft);color:var(--slate-text)}.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-green{background:var(--green)}.dot-amber{background:var(--amber)}.dot-red{background:var(--red)}.dot-teal{background:var(--teal)}.dot-slate{background:var(--border-strong)}.prog{height:7px;border-radius:99px;background:var(--gantt-track);overflow:hidden;flex:1;min-width:60px}.prog>i{display:block;height:100%;border-radius:99px;background:var(--teal);transition:width .5s var(--ease)}.prog.warn>i{background:var(--amber)}.prog.crit>i{background:var(--red)}.kpi{padding:18px 20px;display:flex;flex-direction:column;gap:3px;min-height:132px;position:relative}.kpi-label{font-size:12px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:7px}.kpi-label svg{width:15px;height:15px;color:var(--text-3)}.kpi-value{font-size:30px;font-weight:800;letter-spacing:-.02em;margin-top:4px;line-height:1.1}.kpi-sub{font-size:12px;color:var(--text-2);margin-top:auto}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);text-align:left;padding:11px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.tbl td{padding:13px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .12s}.tbl tbody tr:hover{background:var(--surface-2)}.seg{display:inline-flex;gap:3px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px}.seg button{padding:6px 14px;border:none;background:transparent;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--text-2);transition:all .14s;display:inline-flex;align-items:center;gap:7px}.seg button:hover{color:var(--text)}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.seg button .seg-count{font-size:11px;font-weight:700;color:var(--text-3)}.seg button.active .seg-count{color:var(--primary-text)}.act{width:30px;height:30px;border-radius:var(--r-xs);border:1px solid var(--border);background:var(--surface);color:var(--text-2);display:inline-grid;place-items:center;transition:all .13s}.act svg{width:15px;height:15px}.act:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.act.act-danger:hover{background:var(--red-soft);color:var(--red-text);border-color:transparent}.act-row{display:inline-flex;gap:6px}.drag-handle{display:inline-grid;grid-template-columns:repeat(2,4px);grid-template-rows:repeat(3,4px);gap:3px;padding:4px;border-radius:5px;flex-shrink:0;color:var(--text-3);transition:background .13s,color .13s;touch-action:none;cursor:grab}.drag-handle:hover{background:var(--surface-3);color:var(--text-2)}.drag-handle:active{cursor:grabbing}.drag-handle i{width:4px;height:4px;border-radius:50%;background:currentColor;display:block}.draggable-row{transition:box-shadow .15s,transform .12s,opacity .15s}.draggable-row.dragging{opacity:.92;background:var(--drag-ghost);box-shadow:var(--shadow-lg);border-radius:var(--r-sm);position:relative;z-index:30;cursor:grabbing}.draggable-row.drop-target{box-shadow:inset 0 2px 0 var(--teal)}.drop-line{height:2px;background:var(--teal);border-radius:2px;margin:0;box-shadow:0 0 0 2px var(--primary-soft)}.chk{display:flex;align-items:center;gap:11px;padding:10px 10px 10px 6px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);margin-bottom:7px}.chk.done{background:var(--surface-2)}.chk-box{width:19px;height:19px;border-radius:6px;flex-shrink:0;border:2px solid var(--border-strong);background:var(--surface);display:grid;place-items:center;transition:all .14s}.chk-box:hover{border-color:var(--teal)}.chk.done .chk-box{background:var(--teal);border-color:var(--teal)}.chk-box svg{width:12px;height:12px;color:#fff;opacity:0;transition:opacity .12s}.chk.done .chk-box svg{opacity:1}.chk-text{flex:1;font-size:13px;color:var(--text)}.chk.done .chk-text{text-decoration:line-through;color:var(--text-3)}.chk-prio{width:8px;height:8px;border-radius:50%;flex-shrink:0}.prio-high{background:var(--red)}.prio-mid{background:var(--amber)}.prio-low{background:var(--green)}.prio-picker{display:flex;align-items:center;gap:5px;flex-shrink:0}.prio-btn{width:14px;height:14px;border-radius:50%;border:2px solid transparent;background:var(--prio-c);cursor:pointer;padding:0;opacity:.4;transition:opacity .15s,transform .15s}.prio-btn:hover{opacity:.75;transform:scale(1.15)}.prio-btn.active{opacity:1;border-color:var(--surface-3);transform:scale(1.2);box-shadow:0 0 0 2px color-mix(in srgb,var(--prio-c) 30%,transparent)}.chk.chk-editing{align-items:flex-start;padding:8px 10px;background:var(--surface-2);border-radius:8px;margin-bottom:4px}.gw{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.gw.dragging{box-shadow:var(--shadow-lg);opacity:.95}.gw-head{display:flex;align-items:center;gap:13px;padding:15px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .13s}.gw-head:hover{background:var(--surface-2)}.gw-head.gw-head-edit{cursor:default;background:var(--surface-2);align-items:flex-start;flex-wrap:wrap;gap:10px}.gw-edit-fields{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.gw-edit-row{display:flex;flex-direction:column;gap:3px}.gw-edit-label{font-size:10.5px;font-weight:700;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase}.gw-edit-actions{display:flex;align-items:center;gap:6px;padding-top:2px}.gw-chevron{color:var(--text-3);transition:transform .2s var(--ease);display:grid;place-items:center}.gw.open .gw-chevron{transform:rotate(90deg)}.gw-title{font-size:15px;font-weight:700;letter-spacing:-.01em}.gw-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2);margin-top:2px}.gw-body{padding:4px 18px 20px;border-top:1px solid var(--border)}.gw-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:26px}.gw-head-title{flex:1;min-width:0;cursor:pointer}.gw-head-right{display:flex;align-items:center;gap:18px;flex-shrink:0}.gw-col-resp{width:150px}.gw-col-term{width:112px}.gw-col-oil{width:124px;display:flex;align-items:center}.gw-col-prog{width:150px}.gw-col-status{width:116px;display:flex;align-items:center}.gw-stat{display:flex;flex-direction:column;gap:1px;min-width:0}.gw-stat .gs-label{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.gw-stat .gs-value{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:5px}.gw-stat .gs-value svg{flex-shrink:0}.gw-divider{width:1px;height:30px;background:var(--border);flex-shrink:0}.acards{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:12px}.acard{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);padding:13px 14px 12px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .15s,border .15s}.acard:hover{box-shadow:var(--shadow);border-color:var(--border-strong)}.acard.dragging{box-shadow:var(--shadow-lg);border-color:var(--teal)}.acard-head{display:flex;align-items:flex-start;gap:8px}.acard-title{font-size:13.5px;font-weight:700;letter-spacing:-.01em;line-height:1.25}.acard-sub{font-size:11px;color:var(--text-3);margin-top:2px;display:flex;align-items:center;gap:6px}.acard-specs{display:grid;grid-template-columns:1fr 1fr;gap:5px 12px}.aspec{min-width:0}.aspec-k{font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3)}.aspec-v{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acard-foot{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--border)}.fat-chip{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;color:var(--text-2)}.fat-chip b{font-weight:700}.pcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}.pcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:0;overflow:hidden;cursor:pointer;transition:box-shadow .15s,border .15s,transform .1s;position:relative}.pcard:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--pc-accent, var(--teal))}.pcard:hover{box-shadow:var(--shadow);border-color:var(--border-strong);transform:translateY(-2px)}.pcard-body{padding:16px 18px 16px 20px}.pcard-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px}.pcard-name{font-size:16px;font-weight:700;letter-spacing:-.01em}.pcard-cust{font-size:12px;color:var(--text-3);margin-top:1px}.pcard-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:15px 0 14px}.pmetric-k{font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}.pmetric-v{font-size:16px;font-weight:700;margin-top:2px}.pmetric-v.mono{font-variant-numeric:tabular-nums}.pcard-foot{display:flex;align-items:center;gap:8px;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface-2);font-size:12px}.pcard-next{display:flex;align-items:center;gap:7px;min-width:0}.pcard-next .pn-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pstatus-bar{display:flex;height:10px;border-radius:99px;overflow:hidden;gap:2px}.pstatus-bar>span{height:100%}.sub-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin:18px 0 10px;display:flex;align-items:center;gap:8px}.sub-label .sl-add{margin-left:auto}.machine{display:flex;align-items:center;gap:11px;padding:11px 12px 11px 6px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);margin-bottom:7px}.machine-name{font-size:13px;font-weight:600}.machine-spec{font-size:11.5px;color:var(--text-3);margin-top:1px}.gantt-wrap{overflow-x:auto}.gantt{min-width:760px}.gantt-months{display:grid;border-bottom:1px solid var(--border)}.gantt-month{font-size:11px;font-weight:600;color:var(--text-3);text-align:center;padding:7px 0;border-left:1px solid var(--border)}.gantt-row{display:flex;align-items:center;height:42px;border-bottom:1px solid var(--border);position:relative}.gantt-row:hover{background:var(--surface-2)}.gantt-label{width:150px;flex-shrink:0;font-size:13px;font-weight:600;padding-left:4px;display:flex;align-items:center;gap:9px}.gantt-track-area{flex:1;position:relative;height:100%}.gantt-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--border)}.gantt-bar{position:absolute;height:11px;border-radius:4px;top:50%}.gantt-bar.soll{background:var(--teal);transform:translateY(-50%) translateY(-8px)}.gantt-bar.ist{background:var(--border-strong);transform:translateY(-50%) translateY(7px)}.gantt-today{position:absolute;top:0;bottom:0;width:2px;background:var(--red);z-index:4}.gantt-today:after{content:"Heute";position:absolute;bottom:-19px;left:50%;transform:translate(-50%);font-size:10px;font-weight:700;color:var(--red);white-space:nowrap}.gantt-diamond{position:absolute;width:13px;height:13px;background:var(--teal);top:50%;transform:translate(-50%,-50%) rotate(45deg);border-radius:2px;z-index:3}.gantt-diamond.done{background:var(--green)}.tl-wrap{display:flex;flex-direction:column;height:100%;overflow:hidden}.tl-scrollx{overflow-x:auto;overflow-y:auto;flex:1}.tl-inner{position:relative}.tl-leftw{width:300px}.tl-headrow{display:flex;align-items:stretch;border-bottom:1px solid var(--border);height:46px;flex-shrink:0}.tl-head-left{width:300px;flex-shrink:0;position:sticky;left:0;z-index:7;background:var(--surface);display:flex;align-items:flex-end;padding:0 0 7px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);border-right:1px solid var(--border)}.tl-head-track{position:relative;flex-shrink:0}.tl-head-month{position:absolute;top:6px;font-size:11px;font-weight:700;color:var(--text-2)}.tl-head-week{position:absolute;bottom:6px;font-size:9px;font-weight:600;color:var(--text-3);transform:translate(-50%)}.tl-monthband{position:absolute;top:0;bottom:0;background:var(--surface-2);opacity:.5}.tl-gl{position:absolute;top:0;bottom:0;width:1px;background:var(--border)}.tl-gl.week{background:var(--border);opacity:.45}.tl-gl.month{background:var(--border-strong);opacity:.6}.tl-todayline{position:absolute;top:0;bottom:0;width:2px;background:var(--red);z-index:6}.tl-todayline span{position:absolute;top:-1px;left:4px;font-size:9.5px;font-weight:700;color:var(--red);background:var(--surface);padding:0 3px}.tl-grouprow{display:flex;align-items:stretch;height:38px;position:sticky;top:0;z-index:5}.tl-group-left{width:300px;flex-shrink:0;position:sticky;left:0;z-index:6;background:var(--surface);display:flex;align-items:center;gap:10px;padding:0 10px 0 6px;cursor:pointer;-webkit-user-select:none;user-select:none;border-right:1px solid var(--border)}.tl-group-left:hover{background:var(--surface-2)}.tl-group-track{position:relative;flex-shrink:0}.tl-group-chevron{color:var(--text-3);transition:transform .2s var(--ease);display:grid;place-items:center;flex-shrink:0}.tl-group.open .tl-group-chevron{transform:rotate(90deg)}.tl-group-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-group-count{font-size:10.5px;color:var(--text-3);font-weight:600;flex-shrink:0}.tl-group-track .tl-group-span{position:absolute;top:50%;transform:translateY(-50%);height:6px;border-radius:3px;background:var(--border-strong);opacity:.55}.tl-row2{display:flex;align-items:stretch;height:44px}.tl-left{width:300px;flex-shrink:0;position:sticky;left:0;z-index:5;background:var(--surface);display:flex;align-items:center;gap:8px;padding:0 10px 0 28px;border-right:1px solid var(--border)}.tl-row2:hover .tl-left,.tl-row2:hover .tl-track2{background:var(--surface-2)}.tl-left-main{min-width:0;flex:1}.tl-left-name{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-left-dates{font-size:10px;margin-top:1px;display:flex;gap:8px;white-space:nowrap}.tl-left-dates .d-ist{color:var(--primary-text);font-weight:600}.tl-left-dates .d-soll{color:var(--text-3);font-weight:500}.tl-track2{position:relative;flex-shrink:0;height:100%}.tl-soll{position:absolute;height:12px;border-radius:4px;top:50%;transform:translateY(-50%) translateY(-7px);background:var(--border-strong);z-index:1;opacity:.85}[data-theme=dark] .tl-soll{background:#3a4a6b}.tl-soll-empty{background:transparent;outline:1px dashed var(--border-strong);opacity:.7}.tl-ist{position:absolute;height:15px;border-radius:4px;top:50%;transform:translateY(-50%) translateY(4px);background:var(--teal);z-index:3;box-shadow:0 1px 3px #00a79d59;touch-action:none;display:flex;align-items:stretch}.tl-ist.tl-ist-open{background-image:repeating-linear-gradient(45deg,var(--teal) 0 6px,var(--teal-600) 6px 11px)}.tl-ist.dragging{box-shadow:var(--shadow-lg);z-index:9}.tl-ist-mid{flex:1;cursor:grab}.tl-ist.dragging .tl-ist-mid{cursor:grabbing}.tl-ist-h{width:8px;flex-shrink:0;cursor:ew-resize;position:relative}.tl-ist-h:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:9px;border-radius:2px;background:#ffffffd9}.tl-ist-hl{border-radius:4px 0 0 4px}.tl-ist-hr{border-radius:0 4px 4px 0}.tl-ist-duration{display:block;padding:0 6px;line-height:15px;font-size:9.5px;font-weight:700;color:#fff;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-shadow:0 1px 1px rgba(0,0,0,.25);font-variant-numeric:tabular-nums}.tl-variance{position:absolute;top:50%;transform:translateY(-50%) translateY(4px);font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;z-index:4;pointer-events:none;font-variant-numeric:tabular-nums;letter-spacing:.01em;line-height:1;height:17px;display:inline-flex;align-items:center}.tl-var-on{background:var(--green-soft);color:var(--green-text)}.tl-var-early{background:var(--primary-soft);color:var(--primary-text)}.tl-var-slight{background:var(--amber-soft);color:var(--amber-text)}.tl-var-late{background:var(--red-soft);color:var(--red-text)}.tl-ist.s-done{background:#10b981}.tl-ist.s-done .tl-ist-h{background:#059669}.tl-ist.s-watch{background:repeating-linear-gradient(135deg,#f59e0b,#f59e0b 6px,#f59e0b47 6px,#f59e0b47 12px)}.tl-ist.s-crit{background:repeating-linear-gradient(135deg,#ef4444,#ef4444 6px,#ef444447 6px,#ef444447 12px)}.tl-ist.s-blocked{background:repeating-linear-gradient(135deg,#6b7280,#6b7280 6px,#6b728047 6px,#6b728047 12px)}.tl-ist.s-watch .tl-ist-h,.tl-ist.s-crit .tl-ist-h,.tl-ist.s-blocked .tl-ist-h{background:#ffffff40}.tl-phase-sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;display:inline-block;margin-right:5px;vertical-align:middle;margin-top:-1px}.tl-phase-name-text{cursor:pointer;transition:color .12s}.tl-phase-name-text:hover{color:var(--teal);text-decoration:underline;text-underline-offset:2px}.tl-phase-note-icon{margin-left:5px;color:var(--amber-text, #b45309);opacity:.75;vertical-align:middle;display:inline-grid;place-items:center}.tl-edit-pop{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 12px 40px #00000038,0 2px 8px #0000001a;padding:18px;width:288px;display:flex;flex-direction:column;gap:13px}.tl-edit-pop-header{display:flex;align-items:center;justify-content:space-between}.tl-edit-pop-title{font-size:13px;font-weight:700;color:var(--text-1)}.tl-edit-close-btn{background:none;border:none;cursor:pointer;color:var(--text-3);padding:3px;border-radius:4px;display:grid;place-items:center;transition:color .12s}.tl-edit-close-btn:hover{color:var(--text-1)}.tl-edit-field{display:flex;flex-direction:column;gap:5px}.tl-edit-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}.tl-edit-input{width:100%;padding:7px 10px;font-size:13px;font-family:inherit;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);outline:none;box-sizing:border-box;transition:border-color .12s}.tl-edit-input:focus{border-color:var(--teal)}.tl-edit-textarea{resize:none;line-height:1.5}.tl-edit-status-row{display:flex;flex-wrap:wrap;gap:5px}.tl-edit-status-btn{display:flex;align-items:center;gap:5px;padding:4px 10px 4px 7px;border-radius:99px;font-size:11px;font-weight:600;border:1.5px solid var(--border);cursor:pointer;transition:all .12s;background:var(--surface-2);color:var(--text-2)}.tl-edit-status-btn .tl-esb-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tl-edit-status-btn:hover{border-color:var(--s-col);color:var(--text-1)}.tl-edit-status-btn.active{background:var(--s-col);border-color:var(--s-col);color:#fff}.tl-edit-status-btn.active .tl-esb-dot{background:#ffffffb3!important}.tl-edit-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:2px}.tl-datechip{position:absolute;bottom:calc(100% + 3px);left:50%;transform:translate(-50%);background:var(--navy);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;white-space:nowrap;z-index:12;pointer-events:none;box-shadow:var(--shadow)}[data-theme=dark] .tl-datechip{background:var(--surface-3);border:1px solid var(--border)}.list-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.muted{color:var(--text-2)}.t3{color:var(--text-3)}.fade-in{animation:fadeIn .3s var(--ease) both}@keyframes fadeIn{0%{transform:translateY(7px)}to{transform:none}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#070d1c8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:100;animation:fadeIn .18s;padding:24px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:fit-content;min-width:420px;max-width:min(92vw,860px);max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}.modal-head h3{font-size:16px;font-weight:700}.modal-body{padding:22px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--surface)}.modal-section-label{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}.field{margin-bottom:16px}.field label{display:block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);margin-bottom:7px}.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--text);font-size:13.5px;outline:none;transition:border .14s,box-shadow .14s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--primary-soft)}.field-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.toast-wrap{position:fixed;bottom:22px;left:50%;transform:translate(-50%);z-index:400;display:flex;flex-direction:column;gap:9px;align-items:center;max-width:min(560px,calc(100vw - 32px))}.toast{background:var(--navy);color:#fff;padding:11px 18px;border-radius:99px;font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;animation:toastIn .25s var(--ease)}[data-theme=dark] .toast{background:var(--surface-3);border:1px solid var(--border)}.toast svg{width:16px;height:16px;flex-shrink:0;color:var(--mint)}.toast.toast-err{background:#7f1d1d}[data-theme=dark] .toast.toast-err{background:#7f1d1d;border-color:#ffffff1f}.toast.toast-err svg{color:#fca5a5}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.loading-state{display:flex;align-items:center;justify-content:center;gap:11px;padding:80px 20px;color:var(--text-3);font-size:13px;font-weight:500}.spinner{width:18px;height:18px;border-radius:50%;flex-shrink:0;border:2.5px solid var(--border-strong);border-top-color:var(--teal);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes matrixPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.85}50%{transform:translate(-50%,-50%) scale(1.55);opacity:.45}}.matrix-dot{position:absolute;border-radius:50%;transform:translate(-50%,-50%);cursor:default;transition:box-shadow .2s}.matrix-dot:hover{opacity:1!important;z-index:10}.matrix-dot-pulse{animation:matrixPulse 1.5s ease-in-out infinite}.matrix-dot-slow{animation:matrixPulse 3s ease-in-out infinite}.empty{text-align:center;padding:30px;color:var(--text-3);font-size:13px}:root{--text1: var(--text-1);--text2: var(--text-2);--text3: var(--text-3);--bg2: var(--surface-2);--bg3: var(--surface-3);--border2: var(--border-strong);--blue: #3B82F6;--blue-soft: #EFF6FF;--purple: #7C3AED;--purple-soft: #F5F3FF}.badge-green{background:var(--green-soft);color:var(--green-text)}.badge-red{background:var(--red-soft);color:var(--red-text)}.badge-amber{background:var(--amber-soft);color:var(--amber-text)}.badge-teal{background:var(--teal-soft);color:var(--teal-700)}.badge-blue{background:var(--blue-soft);color:var(--blue)}.badge-purple{background:var(--purple-soft);color:var(--purple)}.badge-gray{background:var(--surface-2);color:var(--text-2)}.card-header{display:flex;align-items:center;gap:var(--gap-base);padding:calc(var(--pad-base) + 1px) calc(var(--pad-base) + 4px);border-bottom:1px solid var(--border);background:var(--surface-2)}.card-pad{padding:var(--pad-base) calc(var(--pad-base) + 4px)}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-row.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.field-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);display:block;margin-bottom:5px}.section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:10px}.empty-state{padding:40px;text-align:center;color:var(--text-3);font-size:13px;line-height:1.7}.overdue{color:var(--red)!important}.progress-bar{height:6px;border-radius:3px;background:var(--border-strong);overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .35s}.divider{height:1px;background:var(--border);margin:10px 0}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.tabs{display:flex;gap:2px;background:var(--surface-2);border-radius:var(--r-sm);padding:3px}.tab{padding:5px 12px;border-radius:calc(var(--r-sm) - 1px);font-size:13px;font-weight:500;cursor:pointer;color:var(--text-2);transition:all .15s;-webkit-user-select:none;user-select:none}.tab:hover{color:var(--text-1);background:var(--surface)}.tab.active{background:var(--surface);color:var(--text-1);font-weight:600;box-shadow:0 1px 3px #00000014}.login-wrap{min-height:100vh;background:var(--navy);display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:40px;box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:6px}.login-wordmark{font-size:22px;font-weight:800;letter-spacing:.12em;color:var(--text)}.login-wordmark-pm{color:#00a79d}.login-subtitle{font-size:13px;color:var(--text-2);margin-bottom:28px}.login-error{background:var(--red-soft);color:var(--red-text);border:1px solid var(--red-text);border-radius:var(--r-sm);padding:10px 13px;font-size:13px;margin-bottom:16px}.login-submit{width:100%;justify-content:center;margin-top:4px}.login-demo{text-align:center;font-size:11px;color:var(--text-3);margin-top:20px}.ov-kpi-grid{grid-template-columns:repeat(4,1fr)}.ov-main-grid{grid-template-columns:1fr 1.3fr 1fr}@media (max-width: 1180px){.ov-kpi-grid{grid-template-columns:repeat(2,1fr)}.ov-main-grid{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 960px){.sidebar{width:70px}.sb-wordmark,.sb-logo-mark{display:none}.sb-brand{padding:20px 0;justify-content:center}.sb-collapse-btn{margin-left:0}.sb-section{opacity:0;height:22px;padding:4px 0}.nav-item{justify-content:center;gap:0;padding:10px 0}.nav-item .ni-label,.nav-item .ni-badge{display:none}.nav-project{justify-content:center;gap:0;padding:10px 0}.nav-project .np-name,.nav-project .np-chevron,.nav-subtabs,.sb-user-meta{display:none}.sb-user{justify-content:center;padding:8px 0}.sb-actions{justify-content:center;flex-direction:column;gap:4px}.content{padding:0 16px 16px}.page-head{padding:14px 16px 12px;margin:0 -16px 18px}.page-head h1{font-size:20px}.grid-3{grid-template-columns:repeat(2,1fr)}.gw-grid{grid-template-columns:1fr;gap:18px}.gw-col-oil,.gw-col-resp{display:none}}@media (max-width: 720px){.ov-kpi-grid{grid-template-columns:1fr}.kpi{min-height:0}.grid-2,.grid-3,.grid-4,.field-2,.form-row.form-row-2,.form-row.form-row-3{grid-template-columns:1fr}.overlay{padding:12px}.modal{min-width:0!important;width:100%;max-width:100%;max-height:92vh}.modal-body,.modal-head,.modal-foot{padding-left:16px;padding-right:16px}.gw-head-right{gap:10px}.gw-divider,.gw-col-term{display:none}.gw-col-prog{width:110px}.tbl th,.tbl td{padding:10px 8px}.login-card{padding:28px 22px}}
