@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Unbounded:wght@300;400;700;900&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0A0A0A;--white:#F5F4F0;--gray-1:#E8E7E2;--gray-2:#C8C7C0;
  --gray-3:#8A8980;--gray-4:#3A3A36;--red:#D94030;--yellow:#E8C840;
  --green:#3A8C5C;--blue:#2A5CAA;--col:72px;
}
html{font-size:13px}
body{background:var(--white);color:var(--black);font-family:'DM Mono',monospace;min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.03) 0,rgba(0,0,0,.03) 1px,transparent 1px,transparent var(--col));pointer-events:none;z-index:0}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--gray-1)}
::-webkit-scrollbar-thumb{background:var(--gray-2)}
::-webkit-scrollbar-thumb:hover{background:var(--black)}

/* ── SHELL ────────────────────────────── */
.shell{display:grid;grid-template-columns:220px 1fr;grid-template-rows:48px 1fr;min-height:100vh;position:relative;z-index:1}

/* ── TOPBAR ───────────────────────────── */
.topbar{grid-column:1/-1;background:var(--black);color:var(--white);display:flex;align-items:center;padding:0 24px;position:sticky;top:0;z-index:500}
.logo{font-family:'Unbounded',sans-serif;font-size:14px;font-weight:900;letter-spacing:.12em;color:var(--white);padding-right:26px;border-right:1px solid var(--gray-4);margin-right:26px;text-decoration:none}
.logo span{color:var(--yellow)}
.topbar-nav{display:flex;align-items:center;flex:1}
.topbar-nav a{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-3);text-decoration:none;padding:0 15px;height:48px;display:flex;align-items:center;border-right:1px solid var(--gray-4);transition:color .15s,background .15s}
.topbar-nav a:first-child{border-left:1px solid var(--gray-4)}
.topbar-nav a.active{color:var(--white);background:var(--gray-4)}
.topbar-nav a:hover:not(.active){color:var(--white)}
.topbar-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.topbar-date{font-size:10px;color:var(--gray-3);letter-spacing:.06em}
.plan-badge-top{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-3);padding:3px 8px;border:1px solid var(--gray-4)}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--black);cursor:pointer;flex-shrink:0;text-decoration:none}
.user-menu-wrap{position:relative}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--black);border:1px solid var(--gray-4);width:190px;display:none;z-index:600}
.user-dropdown.open{display:block}
.udd{display:block;padding:10px 16px;font-size:11px;letter-spacing:.04em;color:var(--gray-2);cursor:pointer;border-bottom:1px solid var(--gray-4);transition:background .1s,color .1s;text-decoration:none}
.udd:last-child{border-bottom:none}
.udd:hover{background:var(--gray-4);color:var(--white)}
.udd.u-name{color:var(--white);font-size:10px;cursor:default}
.udd.u-name:hover{background:transparent}
.udd.danger{color:var(--red)}
.udd.danger:hover{background:rgba(217,64,48,.12)}

/* ── SIDEBAR ──────────────────────────── */
.sidebar{background:var(--black);color:var(--white);display:flex;flex-direction:column;position:sticky;top:48px;height:calc(100vh - 48px);overflow-y:auto}
.sb-sec{padding:16px 0 6px;border-bottom:1px solid var(--gray-4)}
.sb-lbl{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-3);padding:0 20px 8px}
.sb-item{display:flex;align-items:center;gap:10px;padding:8px 20px;font-size:11px;letter-spacing:.04em;color:var(--gray-2);cursor:pointer;transition:background .1s,color .1s;border-left:2px solid transparent;text-decoration:none}
.sb-item:hover{background:var(--gray-4);color:var(--white)}
.sb-item.active{color:var(--white);border-left-color:var(--yellow);background:rgba(255,255,255,.04)}
.sb-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.sb-count{margin-left:auto;font-size:10px;background:var(--gray-4);color:var(--gray-2);padding:1px 7px;border-radius:2px}
.sb-item.active .sb-count{background:var(--yellow);color:var(--black)}

/* ── MAIN ─────────────────────────────── */
.main{background:var(--white);overflow-y:auto}
.page-header{display:flex;align-items:flex-end;justify-content:space-between;padding:26px 36px 20px;border-bottom:2px solid var(--black)}
.page-title{font-family:'Unbounded',sans-serif;font-size:20px;font-weight:700;letter-spacing:-.01em;line-height:1}
.page-sub{font-size:11px;color:var(--gray-3);letter-spacing:.06em;margin-top:5px}
.hdr-btns{display:flex}
.btn{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:9px 15px;border:1px solid var(--black);background:transparent;cursor:pointer;transition:background .15s,color .15s;margin-left:-1px;text-decoration:none;color:var(--black)}
.btn:hover{background:var(--black);color:var(--white)}
.btn.primary{background:var(--black);color:var(--white)}
.btn.primary:hover{background:var(--gray-4)}
.divider{height:1px;background:var(--gray-1);margin:18px 0}

/* ── STATS ────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--gray-1)}
.stat-cell{padding:20px 32px;border-right:1px solid var(--gray-1);animation:fadeUp .4s ease both}
.stat-cell:last-child{border-right:none}
.sn{font-family:'Unbounded',sans-serif;font-size:28px;font-weight:900;line-height:1;letter-spacing:-.02em}
.sl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-3);margin-top:4px}
.sd{font-size:10px;margin-top:3px}
.up{color:var(--green)}.dn{color:var(--red)}
.stat-cell:nth-child(1){animation-delay:.05s}.stat-cell:nth-child(2){animation-delay:.1s}.stat-cell:nth-child(3){animation-delay:.15s}.stat-cell:nth-child(4){animation-delay:.2s}

/* ── CONTENT GRID ─────────────────────── */
.content-grid{display:grid;grid-template-columns:1fr 320px}
.col-left{border-right:1px solid var(--gray-1);padding:24px 32px}
.col-right{padding:24px 20px}
.sec-hdr{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}
.sec-title{font-family:'Unbounded',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.sec-action{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-3);cursor:pointer;text-decoration:none}
.sec-action:hover{color:var(--black)}

/* ── PHASE TRACKER ────────────────────── */
.phase-tracker{display:flex;align-items:center;margin-top:7px}
.phase-step{display:flex;align-items:center;flex:1}
.phase-pill{font-size:9px;font-weight:500;letter-spacing:.08em;padding:2px 5px;border:1px solid var(--gray-2);color:var(--gray-3);background:transparent;white-space:nowrap;flex-shrink:0}
.phase-pill.done{background:var(--black);border-color:var(--black);color:var(--white)}
.phase-pill.curr{border-width:1.5px;color:var(--white);font-weight:700}
.phase-conn{height:1px;flex:1;background:var(--gray-2);min-width:3px}
.phase-conn.done{background:var(--black)}

/* ── PROJECT CARDS ────────────────────── */
.project-list{display:flex;flex-direction:column;margin-bottom:32px}
.project-card{display:flex;gap:13px;padding:14px 0;border-bottom:1px solid var(--gray-1);cursor:pointer;transition:background .1s;animation:fadeUp .4s ease both}
.project-card:hover{background:rgba(0,0,0,.015);margin:0 -8px;padding:14px 8px}
.p-accent{width:4px;border-radius:1px;min-height:32px;flex-shrink:0}
.p-name{font-family:'Unbounded',sans-serif;font-size:11px;font-weight:400;letter-spacing:.02em}
.p-meta{display:flex;gap:12px;margin-top:3px;margin-bottom:0;font-size:10px;color:var(--gray-3);letter-spacing:.04em}
.stag{font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:1px}
.s-active{background:rgba(58,140,92,.12);color:var(--green)}
.s-hold{background:rgba(232,200,64,.15);color:#9A8010}
.s-review{background:rgba(42,92,170,.12);color:var(--blue)}
.s-complete{background:var(--gray-1);color:var(--gray-3)}
.project-card:nth-child(1){animation-delay:.07s}.project-card:nth-child(2){animation-delay:.12s}.project-card:nth-child(3){animation-delay:.17s}.project-card:nth-child(4){animation-delay:.22s}.project-card:nth-child(5){animation-delay:.27s}

/* ── CONSULTANTS ──────────────────────── */
.proj-lower{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--gray-1);margin-top:9px;padding-top:9px}
.cg{padding-right:12px}
.cg+.cg{padding-right:0;padding-left:12px;border-left:1px solid var(--gray-1)}
.cg-lbl{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-3);margin-bottom:4px}
.c-row{display:flex;align-items:center;justify-content:space-between;padding:2px 0;gap:6px}
.c-nm{font-size:10px;letter-spacing:.02em}
.cbdg{font-size:9px;letter-spacing:.06em;padding:1px 5px;border-radius:1px;white-space:nowrap;flex-shrink:0}
.bc{background:rgba(58,140,92,.12);color:var(--green)}
.bpend{background:rgba(232,200,64,.15);color:#9A8010}
.bna{background:var(--gray-1);color:var(--gray-3)}
.breq{border:1px solid var(--gray-2);color:var(--gray-3);background:transparent}

/* ── SITE CHIPS ───────────────────────── */
.site-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid var(--gray-1)}
.chip{display:flex;align-items:center;gap:4px;font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:2px 6px 2px 5px;border:1px solid;border-radius:1px;white-space:nowrap}
.cdot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.chip-ok{border-color:rgba(58,140,92,.3);background:rgba(58,140,92,.07);color:var(--green)}.chip-ok .cdot{background:var(--green)}
.chip-warn{border-color:rgba(232,200,64,.4);background:rgba(232,200,64,.09);color:#9A8010}.chip-warn .cdot{background:#E8C840}
.chip-miss{border-color:rgba(217,64,48,.3);background:rgba(217,64,48,.06);color:var(--red)}.chip-miss .cdot{background:var(--red)}
.chip-flag{border-color:rgba(42,92,170,.3);background:rgba(42,92,170,.07);color:var(--blue)}.chip-flag .cdot{background:var(--blue)}
.chip-na{border-color:var(--gray-1);background:transparent;color:var(--gray-3)}.chip-na .cdot{background:var(--gray-2)}

/* ── MINI TIMELINE ────────────────────── */
.tl-mrow{display:grid;grid-template-columns:120px 1fr;gap:8px;margin-bottom:4px}
.tl-mlbls{display:flex;justify-content:space-between}
.tl-m{font-size:9px;color:var(--gray-3);letter-spacing:.06em;text-transform:uppercase}
.tl-row{display:grid;grid-template-columns:120px 1fr;gap:8px;margin-bottom:8px;align-items:center}
.tl-lbl{font-size:10px;color:var(--gray-3);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-track{height:20px;background:var(--gray-1);position:relative;overflow:hidden}
.tl-bar{position:absolute;top:0;height:100%;display:flex;align-items:center;padding:0 7px;font-size:9px;letter-spacing:.05em;color:var(--white);white-space:nowrap}

/* ── CALENDAR ─────────────────────────── */
.mini-cal{margin-bottom:22px}
.cal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
.cal-month{font-family:'Unbounded',sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em}
.cal-nav{display:flex}
.cal-btn{width:21px;height:21px;border:1px solid var(--gray-1);background:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;color:var(--gray-3);transition:background .1s}
.cal-btn:hover{background:var(--black);color:var(--white)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cdl{font-size:9px;color:var(--gray-3);text-align:center;letter-spacing:.06em;text-transform:uppercase;padding:3px 0}
.cd{font-size:10px;text-align:center;padding:4px 2px;cursor:pointer;border-radius:1px;transition:background .1s;position:relative}
.cd:hover{background:var(--gray-1)}
.cd.today{background:var(--black);color:var(--white);font-weight:500}
.cd.has-ev::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:3px;height:3px;border-radius:50%;background:var(--yellow)}
.cd.other{color:var(--gray-2)}

/* ── TASKS ────────────────────────────── */
.task-list{display:flex;flex-direction:column}
.task-item{display:flex;align-items:flex-start;gap:9px;padding:8px 0;border-bottom:1px solid var(--gray-1);animation:fadeUp .4s ease both}
.task-chk{width:14px;height:14px;border:1.5px solid var(--gray-2);border-radius:2px;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s;cursor:pointer}
.task-chk:hover{border-color:var(--black)}
.task-chk.checked{background:var(--black);border-color:var(--black)}
.task-chk.checked::after{content:'✓';font-size:9px;color:var(--white)}
.task-txt{font-size:11px;letter-spacing:.02em;line-height:1.5;flex:1}
.task-txt.done{text-decoration:line-through;color:var(--gray-3)}
.task-due{font-size:9px;letter-spacing:.06em;color:var(--gray-3);white-space:nowrap}
.task-due.urgent{color:var(--red)}

/* ── TEAM MINI ────────────────────────── */
.team-list-mini{display:flex;flex-direction:column}
.t-mb{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--gray-1);animation:fadeUp .4s ease both}
.t-av{width:29px;height:29px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--black);flex-shrink:0}
.t-nm{font-size:11px;letter-spacing:.02em;font-weight:500}
.t-rl{font-size:10px;color:var(--gray-3);letter-spacing:.04em}
.t-dots{margin-left:auto;display:flex;gap:3px}
.t-dot{width:7px;height:7px;border-radius:50%}

/* ── PROJECTS TABLE ───────────────────── */
.proj-table{width:100%;border-collapse:collapse}
.proj-table th{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-3);padding:10px 14px;text-align:left;border-bottom:2px solid var(--black);background:var(--white);white-space:nowrap}
.proj-table td{padding:13px 14px;border-bottom:1px solid var(--gray-1);font-size:11px;letter-spacing:.02em;vertical-align:middle}
.proj-table tr:hover td{background:rgba(0,0,0,.015);cursor:pointer}
.ptcolor{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px;vertical-align:middle}
.pt-pills{display:flex;gap:2px}
.pt-pill{font-size:8px;padding:2px 4px;letter-spacing:.06em;border:1px solid var(--gray-2);color:var(--gray-3)}
.pt-pill.done{background:var(--black);border-color:var(--black);color:var(--white)}
.pt-pill.curr{color:var(--white);font-weight:700;border-width:1.5px}
.pt-prog{display:flex;align-items:center;gap:7px}
.pt-bar{width:55px;height:3px;background:var(--gray-1)}
.pt-fill{height:100%;transition:width 1s ease}
.pt-pct{font-size:10px;color:var(--gray-3)}

/* ── GANTT ────────────────────────────── */
.gantt-wrap{padding:24px 32px}
.gantt-hdr{display:grid;grid-template-columns:175px 1fr;border-bottom:2px solid var(--black)}
.gantt-pcol{padding:8px 0;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-3)}
.gantt-months{display:flex}
.gantt-month{flex:1;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-3);padding:8px 0 8px 8px;border-left:1px solid var(--gray-1)}
.gantt-row{display:grid;grid-template-columns:175px 1fr;align-items:center;border-bottom:1px solid var(--gray-1);min-height:50px;animation:fadeUp .35s ease both}
.gantt-row:hover{background:rgba(0,0,0,.015)}
.gantt-info{padding:10px 14px 10px 0}
.gantt-pname{font-size:11px;font-weight:500;letter-spacing:.02em}
.gantt-pphase{font-size:9px;color:var(--gray-3);letter-spacing:.06em;margin-top:2px}
.gantt-bars{position:relative;height:50px}
.gantt-bar{position:absolute;top:13px;height:24px;display:flex;align-items:center;padding:0 8px;font-size:9px;letter-spacing:.05em;color:var(--white);white-space:nowrap;overflow:hidden}
.gantt-today{position:absolute;top:0;bottom:0;width:1px;background:var(--red);opacity:.7;z-index:5}
.gantt-today::before{content:'TODAY';position:absolute;top:4px;left:4px;font-size:8px;letter-spacing:.06em;color:var(--red);white-space:nowrap}
.gantt-row:nth-child(1){animation-delay:.05s}.gantt-row:nth-child(2){animation-delay:.1s}.gantt-row:nth-child(3){animation-delay:.15s}.gantt-row:nth-child(4){animation-delay:.2s}.gantt-row:nth-child(5){animation-delay:.25s}

/* ── TEAM PAGE ────────────────────────── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));padding:24px 32px}
.team-card{border:1px solid var(--gray-1);margin:-1px -1px 0 0;padding:22px;animation:fadeUp .35s ease both;cursor:pointer;transition:background .1s}
.team-card:hover{background:rgba(0,0,0,.015)}
.tc-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:var(--black);margin-bottom:12px}
.tc-nm{font-family:'Unbounded',sans-serif;font-size:12px;font-weight:700;letter-spacing:.04em;margin-bottom:2px}
.tc-rl{font-size:10px;color:var(--gray-3);letter-spacing:.06em;margin-bottom:14px}
.tc-div{height:1px;background:var(--gray-1);margin-bottom:12px}
.tc-stats{display:flex;gap:16px;margin-bottom:12px}
.tc-sn{font-family:'Unbounded',sans-serif;font-size:18px;font-weight:700;line-height:1}
.tc-sl{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-3);margin-top:2px}
.tc-projs{display:flex;flex-wrap:wrap;gap:4px}
.tc-pdot{width:8px;height:8px;border-radius:50%}
.tc-email{font-size:10px;color:var(--gray-3);letter-spacing:.03em;margin-top:9px}

/* ── REPORTS ──────────────────────────── */
.reports-grid{display:grid;grid-template-columns:1fr 1fr;padding:24px 32px}
.report-card{border:1px solid var(--gray-1);margin:-1px -1px 0 0;padding:22px;animation:fadeUp .35s ease both}
.rc-title{font-family:'Unbounded',sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.rc-sub{font-size:10px;color:var(--gray-3);letter-spacing:.04em;margin-bottom:18px;line-height:1.6}
.bar-chart{display:flex;flex-direction:column;gap:7px}
.bc-row{display:grid;grid-template-columns:105px 1fr 34px;gap:7px;align-items:center}
.bc-lbl{font-size:10px;color:var(--gray-3);letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bc-track{height:9px;background:var(--gray-1)}
.bc-fill{height:100%;transition:width 1s ease}
.bc-val{font-size:10px;color:var(--gray-3);text-align:right}
.phase-dist{display:flex;height:18px;width:100%;margin-bottom:9px;border:1px solid var(--gray-1);overflow:hidden}
.pd-seg{display:flex;align-items:center;justify-content:center;font-size:9px;letter-spacing:.06em;color:var(--white);overflow:hidden;white-space:nowrap}
.status-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.ss-item{padding:12px;background:var(--gray-1)}
.ss-num{font-family:'Unbounded',sans-serif;font-size:20px;font-weight:900}
.ss-lbl{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-3);margin-top:2px}
.cs-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--gray-1)}
.cs-lbl{font-size:10px;letter-spacing:.04em}
.cs-dots{display:flex;gap:4px}
.cs-dot{width:10px;height:10px;border-radius:50%}
.cs-dot.empty{background:var(--gray-1)}
.rep-legend{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}
.rl-item{display:flex;align-items:center;gap:4px;font-size:9px;color:var(--gray-3);letter-spacing:.04em}
.rl-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.report-card:nth-child(1){animation-delay:.05s}.report-card:nth-child(2){animation-delay:.1s}.report-card:nth-child(3){animation-delay:.15s}.report-card:nth-child(4){animation-delay:.2s}

/* ── ANIMATIONS ───────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(9px)}to{opacity:1;transform:translateY(0)}}
