/* ── PMO Tool Design System ── */
/* Extracted from the original React application */

:root{
  --bg:#f0f4f8;--s1:#ffffff;--s2:#f8fafc;--b1:#e2e8f0;--b2:#cbd5e1;
  --acc:#1d72aa;--amb:#f59e0b;--pur:#818cf8;--red:#f43f5e;--grn:#22c55e;--orn:#fb923c;
  --t1:#0f172a;--t2:#475569;--t3:#94a3b8;
  --serif:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --mono:Consolas,'SF Mono','Fira Code','Courier New',monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;font-family:var(--sans)}
body,html{font-family:var(--sans);color:#0f172a;margin:0;padding:0;height:100%;background:var(--bg)}

/* ── Layout ── */
.app{display:flex;min-height:100vh;background:var(--bg)}

/* ── Sidebar ── */
.sb{width:248px;min-width:248px;background:var(--s1);border-right:1px solid var(--b1);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}
.sb-logo{padding:20px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:12px}
.sb-icon{width:38px;height:38px;background:linear-gradient(135deg,#1d4ed8,var(--acc));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.sb-name{font-family:var(--serif);font-size:15px;line-height:1.2}
.sb-tag{font-size:9px;color:var(--t3);font-family:var(--mono);letter-spacing:2px;text-transform:uppercase}
.sb-nav{flex:1;padding:10px 8px;overflow-y:auto}
.sb-sec{margin-bottom:18px}
.sb-lbl{font-size:9px;letter-spacing:2px;color:var(--t3);font-family:var(--mono);padding:4px 10px 8px;text-transform:uppercase}
.sb-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--t2);transition:all .12s;text-decoration:none}
.sb-item:hover{background:var(--s2);color:var(--t1)}
.sb-item.on{background:rgba(29,114,170,.12);color:var(--acc);font-weight:500}
.sb-ic{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit}
.sb-ic svg{width:16px;height:16px;display:block}
.sb-badge{margin-left:auto;border-radius:99px;font-size:10px;padding:1px 7px;font-family:var(--mono)}
.sb-badge.r{background:var(--red);color:#fff}
.sb-badge.a{background:var(--amb);color:#000}
.sb-foot{padding:14px 18px;border-top:1px solid var(--b1);display:flex;align-items:center;gap:10px}
.av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,var(--acc));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}

/* ── Main ── */
.main{flex:1;overflow:auto;display:flex;flex-direction:column}
.ph{padding:22px 30px 0;border-bottom:1px solid var(--b1);background:var(--s1);position:sticky;top:0;z-index:10}
.ph-title{font-family:var(--serif);font-size:22px;margin-bottom:3px}
.ph-sub{font-size:12px;color:var(--t2);margin-bottom:18px}
.content{padding:26px 30px;flex:1}

/* ── Cards & KPI ── */
.card{background:var(--s1);border:1px solid var(--b1);border-radius:12px;padding:18px}
.kpi{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:22px}
.kpi-label{font-size:10px;color:var(--t3);font-family:var(--mono);letter-spacing:1px;text-transform:uppercase;margin-bottom:5px}
.kpi-val{font-size:26px;font-family:var(--serif)}
.kpi-val.a{color:var(--acc)}.kpi-val.w{color:var(--amb)}.kpi-val.d{color:var(--red)}
.kpi-sub{font-size:11px;color:var(--t3);font-family:var(--mono);margin-top:3px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
.g23{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:22px}

/* ── Table ── */
.tw{background:var(--s1);border:1px solid var(--b1);border-radius:12px;overflow-x:auto;overflow-y:hidden;margin-bottom:22px}
table{width:100%;border-collapse:collapse}
thead th{padding:10px 14px;text-align:left;font-size:10px;color:var(--t3);font-family:var(--mono);letter-spacing:1.2px;text-transform:uppercase;border-bottom:1px solid var(--b1);background:var(--s2);font-weight:400;white-space:nowrap;position:relative;user-select:none}
.col-resizer{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;background:transparent;z-index:1}
.col-resizer:hover,.col-resizer.active{background:var(--acc)}
tbody tr{border-bottom:1px solid var(--b1);transition:background .1s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--s2)}
td{padding:11px 14px;font-size:13px;color:var(--t1);vertical-align:middle}

/* ── Badges ── */
.b{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.b.g{background:rgba(34,197,94,.1);color:var(--grn)}
.b.r{background:rgba(244,63,94,.1);color:var(--red)}
.b.a{background:rgba(245,158,11,.1);color:var(--amb)}
.b.p{background:rgba(129,140,248,.1);color:var(--pur)}
.b.t{background:rgba(46,139,192,.12);color:var(--acc)}
.b.x{background:rgba(71,85,105,.15);color:var(--t2)}

/* ── Progress ── */
.pw{background:var(--b1);border-radius:99px;height:5px;overflow:hidden}
.pf{height:100%;border-radius:99px;transition:width .4s}
.pf.t{background:var(--acc)}.pf.a{background:var(--amb)}.pf.r{background:var(--red)}.pf.g{background:var(--grn)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:7px;font-size:13px;cursor:pointer;border:none;font-family:var(--sans);font-weight:500;transition:all .13s;white-space:nowrap}
.btn-p{background:linear-gradient(135deg,#1d4ed8,var(--acc));color:#fff}
.btn-p:hover{opacity:.88;transform:translateY(-1px)}
.btn-g{background:transparent;color:var(--t2);border:1px solid var(--b1)}
.btn-g:hover{border-color:var(--b2);color:var(--t1);background:var(--s2)}
.btn-d{background:rgba(244,63,94,.1);color:var(--red);border:1px solid rgba(244,63,94,.25)}
.btn-d:hover{background:rgba(244,63,94,.2)}
.btn-s{background:rgba(34,197,94,.1);color:var(--grn);border:1px solid rgba(34,197,94,.25)}
.btn-s:hover{background:rgba(34,197,94,.2)}
.btn-w{background:rgba(245,158,11,.1);color:var(--amb);border:1px solid rgba(245,158,11,.25)}
.sm{padding:5px 10px;font-size:12px}
.sec-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.sec-t{font-family:var(--serif);font-size:18px}
.row-acts{display:flex;gap:6px;align-items:center}

/* ── Modal ── */
.mo{position:fixed;inset:0;background:rgba(15,23,42,.4);display:none;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}
.mo.open{display:flex}
.md{background:#ffffff;border:1px solid var(--b1);border-radius:16px;width:600px;max-width:96vw;max-height:88vh;overflow-y:auto;box-shadow:0 4px 20px rgba(15,23,42,.10)}
.md.lg{width:800px}
.md-h{padding:22px 22px 14px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between}
.md-t{font-family:var(--sans);font-size:17px;font-weight:600}
.md-x{background:none;border:none;color:var(--t2);cursor:pointer;font-size:22px;padding:2px 8px;border-radius:4px;line-height:1}
.md-x:hover{background:var(--s2);color:var(--t1)}
.md-b{padding:18px 22px}
.md-f{padding:14px 22px;border-top:1px solid var(--b1);display:flex;gap:10px;justify-content:flex-end}

/* ── Forms ── */
.fr{margin-bottom:14px}
.fr label{display:block;font-size:10px;color:var(--t2);font-family:var(--mono);letter-spacing:1.3px;text-transform:uppercase;margin-bottom:6px}
.fr input,.fr select,.fr textarea{width:100%;background:var(--s2);border:1px solid var(--b2);border-radius:8px;padding:9px 12px;font-size:13px;color:var(--t1);font-family:var(--sans);outline:none;transition:border .15s,box-shadow .15s}
.fr input:focus,.fr select:focus,.fr textarea:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(46,139,192,.12)}
.fr textarea{resize:vertical;min-height:80px;line-height:1.5}
.fr input[type=range]{padding:4px 0;cursor:pointer}
.fr input[type=number]{-moz-appearance:textfield}
.fr .error-text{color:var(--red);font-size:11px;margin-top:4px}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
select option{background:#ffffff;color:#0f172a}

/* ── Toast ── */
.ta{position:fixed;bottom:22px;right:22px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:#ffffff;border:1px solid var(--b1);border-radius:10px;padding:12px 16px;font-size:13px;min-width:280px;box-shadow:0 4px 16px rgba(15,23,42,.10);animation:tin .2s ease;display:flex;align-items:center;gap:10px}
@keyframes tin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes tout{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}
.toast.success{border-left:3px solid var(--grn)}
.toast.error{border-left:3px solid var(--red)}
.toast.warn{border-left:3px solid var(--amb)}
.toast.info{border-left:3px solid var(--acc)}
.toast.fade-out{animation:tout .3s ease forwards}

/* ── Gantt ── */
.gantt{background:var(--s1);border:1px solid var(--b1);border-radius:12px;overflow:hidden;margin-bottom:22px}
.gh{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid var(--b1);background:var(--s2)}
.gh-l{padding:9px 14px;font-size:10px;color:var(--t3);font-family:var(--mono);letter-spacing:1px;text-transform:uppercase}
.gm{display:flex;flex:1}
.gm-col{flex:1;padding:9px 4px;font-size:10px;color:var(--t3);font-family:var(--mono);border-left:1px solid var(--b1);text-align:center}
.gr{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid var(--b1);min-height:44px}
.gr:last-child{border-bottom:none}
.gr-l{padding:9px 14px;font-size:12px;display:flex;align-items:center;gap:7px;border-right:1px solid var(--b1)}
.gr-bars{position:relative;display:flex;align-items:center}
.gbar{position:absolute;height:22px;border-radius:5px;display:flex;align-items:center;padding:0 7px;font-size:10px;font-family:var(--mono);white-space:nowrap;overflow:hidden;cursor:pointer;transition:filter .15s}
.gbar:hover{filter:brightness(1.2)}
.gbar.t{background:var(--acc);color:#fff}.gbar.a{background:var(--amb);color:#000}.gbar.g{background:var(--grn);color:#000}.gbar.r{background:var(--red);color:#fff}.gbar.p{background:var(--pur);color:#fff}

/* ── Notifications ── */
.ni{padding:13px 16px;border-bottom:1px solid var(--b1);display:flex;gap:11px;align-items:flex-start}
.ni:last-child{border-bottom:none}
.nd{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.nt{font-size:13px;line-height:1.5}.nm{font-size:11px;color:var(--t3);font-family:var(--mono);margin-top:3px}

/* ── Risk Matrix ── */
.rm-cell{aspect-ratio:1;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:12px;font-family:var(--mono);cursor:default;transition:all .15s}

/* ── Kanban (Stage Gate) ── */
.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.kanban-col{background:var(--s2);border:1px solid var(--b1);border-radius:12px;padding:14px;min-height:400px}
.kanban-col.drag-over{background:rgba(29,114,170,.06);border-color:var(--acc)}
.kanban-header{font-size:10px;font-family:var(--mono);letter-spacing:1px;text-transform:uppercase;color:var(--t3);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.kanban-count{background:var(--b1);border-radius:99px;padding:1px 7px;font-size:10px}
.kanban-card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:12px;margin-bottom:8px;cursor:grab;transition:all .15s}
.kanban-card:hover{border-color:var(--b2);box-shadow:0 2px 8px rgba(15,23,42,.06)}
.kanban-card.dragging{opacity:.5;transform:rotate(2deg)}
.kanban-card-name{font-size:13px;font-weight:500;margin-bottom:6px}
.kanban-card-meta{font-size:11px;color:var(--t3);font-family:var(--mono)}

/* ── Tabs ── */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--b1);margin-bottom:18px}
.tab{padding:10px 18px;font-size:13px;color:var(--t2);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;text-decoration:none}
.tab:hover{color:var(--t1)}
.tab.on{color:var(--acc);border-bottom-color:var(--acc);font-weight:500}

/* ── Misc ── */
.sc{max-height:360px;overflow-y:auto}
.sep{height:1px;background:var(--b1);margin:16px 0}
.empty{text-align:center;padding:36px;color:var(--t3);font-size:14px}
.del-confirm{background:rgba(244,63,94,.08);border:1px solid rgba(244,63,94,.2);border-radius:10px;padding:14px 16px;margin-top:14px;font-size:13px;color:var(--t2);line-height:1.6}
.inline-edit{background:transparent;border:none;border-bottom:1px dashed var(--b2);color:var(--t1);font-family:var(--sans);font-size:13px;outline:none;width:100%;padding:2px 4px}
.inline-edit:focus{border-bottom-color:var(--acc)}
.hp{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.text-muted{color:var(--t3);font-size:12px}
.mt-2{margin-top:8px}
.mb-2{margin-bottom:8px}
.gap-2{gap:8px}

/* ── Login ── */
#login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0f4f8;background-image:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(29,78,170,0.08) 0%,transparent 70%)}
.lcard{width:420px;background:#ffffff;border:1px solid #cbd5e1;border-radius:20px;padding:48px;box-shadow:0 8px 32px rgba(15,23,42,.12);position:relative;overflow:hidden}
.lcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#1d4ed8,#1d72aa,#1d4ed8)}
.llogo{width:60px;height:60px;background:linear-gradient(135deg,#1d4ed8,#1d72aa);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 14px}
.ltitle{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;font-size:22px;font-weight:700;color:#0f172a;text-align:center;margin-bottom:4px;letter-spacing:-.3px}
.lsub{font-size:11px;color:#64748b;font-family:Consolas,'SF Mono','Fira Code','Courier New',monospace;letter-spacing:2px;text-align:center;margin-bottom:28px}
.ldivider{height:1px;background:#1e3050;margin-bottom:24px}
.llabel{display:block;font-size:10px;color:var(--t2);font-family:Consolas,'SF Mono','Fira Code','Courier New',monospace;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:7px}
.linput{display:block;width:100%;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:10px;padding:12px 15px;font-size:14px;color:#0f172a;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;outline:none;margin-bottom:18px;transition:border-color .2s;font-weight:400}
.linput:focus{border-color:#2e8bc0}
.lbtn{display:block;width:100%;background:linear-gradient(135deg,#1d4ed8,#1d72aa);border:none;border-radius:10px;padding:14px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif}
.lbtn:hover{opacity:.88}
.lerror{display:none;margin-top:14px;background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.3);color:#f43f5e;border-radius:8px;padding:10px 14px;font-size:13px;text-align:center}
.lerror.show{display:block}
.lfooter{text-align:center;margin-top:24px;font-size:10px;color:#64748b;font-family:Consolas,'SF Mono','Fira Code','Courier New',monospace}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}
.shake{animation:shake .35s ease}

/* ── Filter Bar ── */
.filter-bar{display:flex;gap:10px;margin-bottom:14px;align-items:center;flex-wrap:wrap}
.filter-bar label{font-size:10px;color:var(--t3);font-family:var(--mono);letter-spacing:1px}
.filter-bar select{font-size:13px;padding:6px 10px;border-radius:8px;border:1px solid var(--b2);background:var(--s1);color:var(--t1);font-family:var(--sans)}

/* ── Modern Page Layout ── */
.pg{display:flex;flex-direction:column;gap:22px}

/* Modern KPI Cards */
.pg-kpis{display:grid;gap:16px}
.pg-kpi{border-radius:12px;padding:20px;background:#fff;border:1px solid var(--b1);border-left:4px solid var(--acc);transition:transform .15s,box-shadow .15s}
.pg-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,.07)}
.pg-kpi-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pg-kpi-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pg-kpi-icon svg{width:18px;height:18px}
.pg-kpi-label{font-size:11px;font-family:var(--mono);color:var(--t3);text-transform:uppercase;letter-spacing:.8px}
.pg-kpi-val{font-size:28px;font-family:var(--serif);font-weight:600;line-height:1.1;margin-bottom:4px}
.pg-kpi-sub{font-size:11px;font-family:var(--mono);color:var(--t3)}

/* Section Cards */
.pg-card{background:#fff;border:1px solid var(--b1);border-radius:12px;overflow:hidden}
.pg-card-head{padding:18px 22px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between}
.pg-card-title{font-size:15px;font-weight:600;color:var(--t1)}
.pg-card-body{padding:22px}

/* Modern Tables */
.pg-table{width:100%;border-collapse:collapse}
.pg-table thead th{font-size:10px;font-family:var(--mono);color:var(--t3);text-transform:uppercase;letter-spacing:.8px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--b1);background:var(--s2)}
.pg-table tbody td{font-size:13px;padding:10px 14px;border-bottom:1px solid var(--b1)}
.pg-table tbody tr:last-child td{border-bottom:none}
.pg-table tbody tr:hover{background:var(--s2)}
.pg-table .empty-row td{text-align:center;color:var(--t3);padding:28px 14px}

/* Action Cards (clickable) */
.pg-action{border-radius:12px;padding:22px;background:#fff;border:1px solid var(--b1);border-left:4px solid var(--acc);text-decoration:none;color:inherit;display:block;transition:transform .15s,box-shadow .15s}
.pg-action:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,.07)}

/* Two-column grids */
.pg-row{display:grid;gap:20px}
.pg-row.c2{grid-template-columns:1fr 1fr}
.pg-row.c3{grid-template-columns:repeat(3,1fr)}
.pg-row.c4{grid-template-columns:repeat(4,1fr)}
.pg-row.c5{grid-template-columns:repeat(5,1fr)}
.pg-row.c21{grid-template-columns:2fr 1fr}

/* Modern Tabs */
.pg-tabs{display:flex;gap:0;border-bottom:2px solid var(--b1);margin-bottom:20px}
.pg-tab{padding:10px 20px;font-size:13px;color:var(--t2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;text-decoration:none;font-weight:500}
.pg-tab:hover{color:var(--t1);background:var(--s2);border-radius:6px 6px 0 0}
.pg-tab.on{color:var(--acc);border-bottom-color:var(--acc)}

/* Modern Filter Bar */
.pg-filters{display:flex;gap:12px;margin-bottom:18px;align-items:center;flex-wrap:wrap;padding:12px 16px;background:var(--s1);border:1px solid var(--b1);border-radius:10px}
.pg-filters label{font-size:10px;color:var(--t3);font-family:var(--mono);letter-spacing:1px;text-transform:uppercase}
.pg-filters select{font-size:13px;padding:7px 12px;border-radius:8px;border:1px solid var(--b2);background:var(--s2);color:var(--t1);font-family:var(--sans);transition:border .15s}
.pg-filters select:focus{border-color:var(--acc);outline:none}

@media(max-width:1100px){.pg-row.c5{grid-template-columns:repeat(3,1fr)}.pg-row.c4{grid-template-columns:repeat(2,1fr)}.pg-row.c21,.pg-row.c2{grid-template-columns:1fr}}
@media(max-width:768px){.pg-row.c5,.pg-row.c4,.pg-row.c3{grid-template-columns:1fr 1fr}.pg-kpis{grid-template-columns:1fr 1fr}}
