@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap");:root{--c-bg:#0d0d0d;--c-layer-1:#141414;--c-layer-2:#1a1a1a;--c-layer-3:#222222;--c-layer-4:#2a2a2a;--c-border:rgba(255,255,255,0.07);--c-border-med:rgba(255,255,255,0.12);--c-text:#f0f0f0;--c-text-2:#a0a0a0;--c-text-3:#606060;--c-green:#3d9e52;--c-green-light:#52c76c;--c-green-dim:rgba(61,158,82,0.12);--c-green-glow:rgba(61,158,82,0.25);--c-amber:#e8a020;--c-amber-dim:rgba(232,160,32,0.12);--c-red:#e05252;--c-red-dim:rgba(224,82,82,0.12);--c-blue:#4a9edd;--c-blue-dim:rgba(74,158,221,0.12);--sidebar-w:220px;--topbar-h:56px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 4px rgba(0,0,0,0.4);--shadow-md:0 4px 16px rgba(0,0,0,0.5);--shadow-lg:0 8px 32px rgba(0,0,0,0.6)}*,:after,:before{box-sizing:border-box;margin:0}html{font-size:14px}body{background:var(--c-bg);color:var(--c-text);font-family:DM Sans,ui-sans-serif,system-ui,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select{font:inherit}img{display:block;max-width:100%}::selection{background:var(--c-green-dim);color:var(--c-green-light)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-layer-4);border-radius:2px}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"topbar topbar" "sidebar content";min-height:100vh}.topbar{grid-area:topbar;justify-content:space-between;gap:24px;padding:0 20px 0 0;background:var(--c-layer-1);border-bottom:1px solid var(--c-border);position:-webkit-sticky;position:sticky;top:0;z-index:100}.topbar,.topbar-brand{display:flex;align-items:center}.topbar-brand{width:var(--sidebar-w);flex:0 0 auto;gap:10px;padding:0 16px;height:100%;border-right:1px solid var(--c-border)}.topbar-logo{height:26px;width:auto;filter:brightness(0) invert(1) opacity(.9)}.topbar-center{flex:1 1;display:flex;align-items:center;gap:8px}.topbar-page-label{font-size:13px;font-weight:600;color:var(--c-text);letter-spacing:.01em}.topbar-right{display:flex;align-items:center;gap:12px}.topbar-meta{text-align:right;line-height:1.3}.topbar-meta-label{font-size:10px;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.08em}.topbar-meta-value{font-size:11px;color:var(--c-text-2);font-family:DM Mono,monospace}.sidebar{grid-area:sidebar;background:var(--c-layer-1);border-right:1px solid var(--c-border);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:var(--topbar-h);height:calc(100vh - var(--topbar-h));overflow-y:auto;padding:12px 0}.nav-section-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-3);padding:12px 16px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;margin:1px 8px;border-radius:var(--radius);color:var(--c-text-2);font-size:13.5px;font-weight:400;transition:background .1s,color .1s;position:relative;white-space:nowrap}.nav-item:hover{background:var(--c-layer-3);color:var(--c-text)}.nav-item-active{background:var(--c-green-dim);color:var(--c-green-light);font-weight:500}.nav-item-active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--c-green);border-radius:0 2px 2px 0}.nav-icon{width:32px;height:32px;border-radius:8px;background:var(--c-layer-3);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--c-text-2);flex:0 0 auto;font-family:DM Mono,monospace;letter-spacing:-.03em;transition:background .1s,color .1s}.nav-item-active .nav-icon{background:var(--c-green-dim);color:var(--c-green-light)}.sidebar-spacer{flex:1 1}.sidebar-session{padding:12px;margin:0 8px;border-top:1px solid var(--c-border)}.session-name{font-size:12px;font-weight:500;color:var(--c-text)}.session-role{font-size:11px;color:var(--c-text-3);margin-top:1px}.page-content{grid-area:content;min-width:0;padding:24px;display:flex;flex-direction:column;gap:20px}.btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:var(--radius);padding:0 14px;height:34px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.btn-primary{background:var(--c-green);color:#fff}.btn-primary:hover{background:var(--c-green-light)}.btn-ghost{background:transparent;color:var(--c-text-2);border:1px solid var(--c-border-med)}.btn-ghost:hover{background:var(--c-layer-3);color:var(--c-text)}.btn-danger{background:var(--c-red-dim);color:var(--c-red);border:1px solid rgba(224,82,82,.2)}.btn-danger:hover{background:rgba(224,82,82,.2)}.btn-sm{height:28px;padding:0 10px;font-size:12px}.btn:disabled{opacity:.4;cursor:not-allowed}.card{background:var(--c-layer-2);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:20px}.card-sm{padding:14px 16px}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.card-title{font-size:13px;font-weight:600;color:var(--c-text);margin:0}.card-kicker{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-3);margin-bottom:4px}.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px}.kpi-card{background:var(--c-layer-2);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:16px 18px;position:relative;overflow:hidden;transition:border-color .15s}.kpi-card:hover{border-color:var(--c-border-med)}.kpi-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-3);margin-bottom:8px}.kpi-value{font-size:1.65rem;font-weight:700;color:var(--c-text);letter-spacing:-.03em;line-height:1;font-family:DM Mono,monospace;margin-bottom:6px}.kpi-hint{font-size:11px;color:var(--c-text-3);line-height:1.4}.kpi-accent-bar{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--c-green);opacity:.5}.kpi-card-danger .kpi-accent-bar{background:var(--c-red)}.kpi-card-amber .kpi-accent-bar{background:var(--c-amber)}.kpi-card-blue .kpi-accent-bar{background:var(--c-blue)}.alert-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;flex-wrap:wrap}.alert-bar-danger{background:var(--c-red-dim);border:1px solid rgba(224,82,82,.2);color:var(--c-red)}.alert-bar-amber{background:var(--c-amber-dim);border:1px solid rgba(232,160,32,.2);color:var(--c-amber)}.alert-dot{width:6px;height:6px;border-radius:50%;flex:0 0 auto;animation:pulse 2s infinite}.alert-dot-danger{background:var(--c-red)}.alert-dot-amber{background:var(--c-amber)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.overview-grid{display:grid;grid-template-columns:1fr 300px;grid-gap:16px;gap:16px;align-items:start}.overview-left{gap:16px}.overview-left,.phase-list{display:flex;flex-direction:column}.phase-list{gap:8px}.phase-row{display:grid;grid-template-columns:180px 1fr 80px 90px 100px;align-items:center;grid-gap:16px;gap:16px;padding:12px 16px;background:var(--c-layer-2);border:1px solid var(--c-border);border-radius:var(--radius);transition:border-color .15s,background .15s;text-decoration:none;color:inherit}.phase-row:hover{border-color:var(--c-border-med);background:var(--c-layer-3)}.phase-row-name{font-size:13px;font-weight:500;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.phase-row-bar-wrap{display:flex;flex-direction:column;gap:4px}.progress-bar{height:4px;background:var(--c-layer-4);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:inherit;background:var(--c-green);transition:width .4s ease}.progress-fill-amber{background:var(--c-amber)}.progress-fill-red{background:var(--c-red)}.phase-row-pct{color:var(--c-text-3)}.phase-row-budget,.phase-row-pct{font-size:12px;font-family:DM Mono,monospace}.phase-row-budget{color:var(--c-text-2);text-align:right}.phase-row-budget-over{color:var(--c-red)}.phase-row-status{justify-self:end}.overview-right{gap:12px}.deadline-item,.deadline-list,.overview-right{display:flex;flex-direction:column}.deadline-item{gap:2px;padding:10px 0;border-bottom:1px solid var(--c-border)}.deadline-item:last-child{border-bottom:none}.deadline-name{font-size:12px;font-weight:500;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deadline-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--c-text-3)}.deadline-overdue{color:var(--c-red)}.deadline-soon{color:var(--c-amber)}.health-list{display:flex;flex-direction:column}.health-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--c-border);font-size:12px}.health-item:last-child{border-bottom:none}.health-item-label{color:var(--c-text-2)}.health-item-val{font-family:DM Mono,monospace;font-size:12px}.health-ok{color:var(--c-green-light)}.health-warn{color:var(--c-amber)}.health-bad{color:var(--c-red)}.chart-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.badge-green{background:var(--c-green-dim);color:var(--c-green-light)}.badge-amber{background:var(--c-amber-dim);color:var(--c-amber)}.badge-red{background:var(--c-red-dim);color:var(--c-red)}.badge-blue{background:var(--c-blue-dim);color:var(--c-blue)}.badge-muted{background:var(--c-layer-4);color:var(--c-text-3)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:8px 12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-3);background:var(--c-layer-1);white-space:nowrap;position:-webkit-sticky;position:sticky;top:0;z-index:2}.data-table td,.data-table th{border-bottom:1px solid var(--c-border)}.data-table td{padding:10px 12px;font-size:13px;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--c-layer-3)}.data-table tfoot td{font-weight:600;background:var(--c-layer-1);border-top:1px solid var(--c-border-med)}.td-mono{font-family:DM Mono,monospace;font-size:12px}.td-right{text-align:right}.td-muted{color:var(--c-text-3)}.row-overdue{background:rgba(224,82,82,.04)}.row-overdue:hover td{background:rgba(224,82,82,.08)!important}.row-over-budget{background:rgba(232,160,32,.04)}.form-row{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));align-items:end}.field{display:flex;flex-direction:column;gap:5px}.field-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:var(--c-text-3)}.field-input,.field-select{height:36px;border:1px solid var(--c-border-med);border-radius:var(--radius);padding:0 10px;background:var(--c-layer-1);color:var(--c-text);font-size:13px;transition:border-color .15s,box-shadow .15s}.field-input:focus,.field-select:focus{outline:none;border-color:var(--c-green);box-shadow:0 0 0 2px var(--c-green-dim)}.field-select option{background:var(--c-layer-2)}.chart-container{width:100%;position:relative}.donut-wrap{display:grid;grid-template-columns:120px 1fr;grid-gap:16px;gap:16px;align-items:center}.donut-svg{width:120px;height:120px}.legend-list{display:flex;flex-direction:column;gap:7px}.legend-item{justify-content:space-between;gap:8px;font-size:12px}.legend-item,.legend-left{display:flex;align-items:center}.legend-left{gap:7px;min-width:0}.legend-dot{width:8px;height:8px;border-radius:2px;flex:0 0 auto}.legend-label{color:var(--c-text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-val{color:var(--c-text-3);font-family:DM Mono,monospace;font-size:11px;white-space:nowrap}.bar-list{gap:10px}.bar-item,.bar-list{display:flex;flex-direction:column}.bar-item{gap:5px}.bar-item-head{display:flex;justify-content:space-between;gap:8px;font-size:12px}.bar-item-label{color:var(--c-text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-item-val{color:var(--c-text-3);font-family:DM Mono,monospace;flex:0 0 auto}.bar-track{height:6px;background:var(--c-layer-4);border-radius:3px;overflow:hidden;position:relative}.bar-fill{position:absolute;inset:0 auto 0 0;border-radius:inherit;background:var(--c-green)}.bar-fill-planned{background:var(--c-layer-3);width:100%!important}.bar-fill-actual{background:var(--c-green)}.bar-fill-over{background:var(--c-red)}.bar-fill-amber{background:var(--c-amber)}.line-chart-svg{width:100%;overflow:visible}.line-path{fill:none;stroke-linecap:round;stroke-linejoin:round}.line-grid-line{stroke:var(--c-border)}.line-dot{stroke-width:2}.timeline-header,.timeline-row-grid{display:grid;grid-template-columns:220px 1fr;grid-gap:12px;gap:12px}.timeline-scale,.timeline-track{position:relative;border-radius:var(--radius);background:var(--c-layer-1);border:1px solid var(--c-border)}.timeline-scale{height:32px}.timeline-track{min-height:44px}.timeline-month-label{position:absolute;top:0;bottom:0;display:flex;align-items:center;padding:0 8px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-3);border-right:1px solid var(--c-border)}.timeline-today-line{position:absolute;top:0;bottom:0;width:1px;background:var(--c-green);opacity:.8}.timeline-bar-wrap{position:absolute;top:8px;bottom:8px;border-radius:4px;overflow:hidden}.timeline-bar-bg{position:absolute;inset:0;background:var(--c-green-dim);border:1px solid rgba(61,158,82,.2)}.timeline-bar-progress{position:absolute;inset:0 auto 0 0;background:var(--c-green);opacity:.7}.timeline-bar-label{position:absolute;inset:0 6px;display:flex;align-items:center;font-size:11px;font-weight:500;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;z-index:1}.timeline-bar-overdue .timeline-bar-bg{background:var(--c-red-dim);border-color:rgba(224,82,82,.2)}.timeline-bar-overdue .timeline-bar-progress{background:var(--c-red)}.flash{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;border:1px solid transparent}.flash-success{background:var(--c-green-dim);border-color:rgba(61,158,82,.2);color:var(--c-green-light)}.flash-error{background:var(--c-red-dim);border-color:rgba(224,82,82,.2);color:var(--c-red)}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--c-bg)}.login-card{width:min(100%,420px);background:var(--c-layer-2);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-lg);gap:20px}.login-brand,.login-card{display:flex;flex-direction:column}.login-brand{align-items:center;gap:12px;padding-bottom:20px;border-bottom:1px solid var(--c-border)}.login-logo{height:36px;filter:brightness(0) invert(1) opacity(.9)}.login-tagline{font-size:12px;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.1em}.login-fields{display:flex;flex-direction:column;gap:14px}.users-add-form{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:12px;gap:12px;align-items:end}.role-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.role-admin{background:var(--c-red-dim);color:var(--c-red)}.role-finance{background:var(--c-blue-dim);color:var(--c-blue)}.role-editor{background:var(--c-amber-dim);color:var(--c-amber)}.role-viewer{background:var(--c-layer-4);color:var(--c-text-3)}.remuneration-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.budget-summary{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.budget-charts{display:grid;grid-template-columns:1fr 320px;grid-gap:12px;gap:12px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.section-title{font-size:14px;font-weight:600;color:var(--c-text)}.section-kicker{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-3);margin-bottom:3px}.stack{display:flex;flex-direction:column;gap:16px}.stack-sm{gap:8px}.stack-lg{gap:24px}.grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.text-mono{font-family:DM Mono,monospace}.text-muted{color:var(--c-text-2)}.text-faint{color:var(--c-text-3)}.text-green{color:var(--c-green-light)}.text-amber{color:var(--c-amber)}.text-red{color:var(--c-red)}.text-right{text-align:right}.text-sm{font-size:12px}.text-xs{font-size:11px}.divider{height:1px;background:var(--c-border);margin:0}@media (max-width:1100px){.kpi-strip{grid-template-columns:repeat(2,1fr)}.budget-charts,.overview-grid,.remuneration-grid{grid-template-columns:1fr}.budget-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){:root{--sidebar-w:180px}}@media (max-width:700px){.shell{grid-template-columns:1fr;grid-template-areas:"topbar" "content"}.sidebar{display:none}.page-content{padding:16px}.kpi-strip{grid-template-columns:1fr 1fr}.budget-summary,.grid-2,.grid-3,.overview-grid{grid-template-columns:1fr}.phase-row{grid-template-columns:1fr 80px}.phase-row>:nth-child(2),.phase-row>:nth-child(4){display:none}}