:root{--navy-900: #00222b;--navy-800: #002b34;--navy-700: #003642;--navy-600: #0d4b59;--navy-500: #2a6675;--ink: #16323b;--muted: #5d6b72;--muted-2: #93a3aa;--line: #e6ecee;--line-2: #eef2f4;--bg: #e7f0f1;--card: #ffffff;--gold: #70b8d0;--gold-soft: #dcecf3;--gold-ink: #2c6d82;--green: #1f9d6b;--green-soft: #e3f4ec;--amber: #d9961f;--amber-soft: #fbeed2;--red: #d2493f;--red-soft: #f8e3e1;--blue: #3667c9;--blue-soft: #e4ecfb;--radius: 13px;--shadow: 0 1px 2px rgba(16, 26, 49, .04), 0 8px 24px -12px rgba(16, 26, 49, .14);--shadow-lg: 0 24px 60px -20px rgba(16, 26, 49, .3)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Plus Jakarta Sans,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}.tnum{font-variant-numeric:tabular-nums}::selection{background:var(--gold-soft)}button{font-family:inherit}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:248px;flex:none;height:100vh;background:var(--navy-800);color:#cdd5e6;display:flex;flex-direction:column;position:relative;z-index:5}.brand{padding:20px 20px 14px;display:flex;align-items:center;gap:11px}.brand .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--gold) 0%,#a9d6e6 100%);display:grid;place-items:center;color:var(--navy-900);font-weight:800;font-size:17px;flex:none}.brand b{color:#fff;font-weight:600;font-size:18px;letter-spacing:.2px;line-height:1}.brand small{display:block;color:#8fa6ae;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-top:3px}.switch{margin:6px 14px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:4px;display:flex;gap:3px}.switch button{flex:1;border:0;background:transparent;color:#9ab3bc;font:inherit;font-size:12.5px;font-weight:600;padding:7px 8px;border-radius:7px;cursor:pointer;transition:.18s}.switch button.on{background:var(--navy-600);color:#fff}.nav{padding:6px 12px;display:flex;flex-direction:column;gap:2px}.nav button{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:#a9c0c8;border:0;background:transparent;width:100%;text-align:left;font-size:14px;font-weight:500;cursor:pointer;transition:.16s}.nav button svg{width:17px;height:17px;flex:none;opacity:.85}.nav button:hover{background:#ffffff0d;color:#fff}.nav button.active{background:var(--navy-600);color:#fff}.nav button.active svg{opacity:1;color:var(--gold)}.seclabel{padding:18px 24px 8px;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#7d959d;font-weight:700}.cats{padding:0 12px;display:flex;flex-direction:column;gap:1px;overflow:auto}.cat{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;cursor:pointer;color:#b0c4cb;font-size:13.5px;font-weight:500;border:0;background:transparent;width:100%;text-align:left;transition:.15s}.cat:hover{background:#ffffff0d;color:#fff}.cat.on{background:#70b8d029;color:#fff}.dot{width:7px;height:7px;border-radius:50%;flex:none}.cat .count{margin-left:auto;font-size:12px;color:#8197a0;font-variant-numeric:tabular-nums}.cat.on .count{color:#bfe0ec}.me{margin-top:auto;padding:14px;display:flex;align-items:center;gap:10px;border-top:1px solid rgba(255,255,255,.07)}.me .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#2a6675,#4d8597);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px}.me b{color:#fff;font-size:13.5px;font-weight:600;display:block;line-height:1.2}.me span{color:#8fa6ae;font-size:11.5px}.main{flex:1;height:100vh;display:flex;flex-direction:column;min-width:0}.topbar{height:64px;flex:none;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 26px}.topbar h1{font-weight:600;font-size:21px;letter-spacing:.2px}.crumb{color:var(--muted-2);font-size:13px;font-weight:500}.search{margin-left:auto;position:relative}.search input{width:260px;border:1px solid var(--line);background:var(--bg);border-radius:10px;padding:9px 12px 9px 34px;font:inherit;font-size:13.5px;color:var(--ink);outline:none;transition:.18s}.search input:focus{border-color:var(--navy-500);background:#fff;box-shadow:0 0 0 3px #2a66751f}.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--muted-2)}.btn{border:0;border-radius:10px;font:inherit;font-weight:600;font-size:13.5px;cursor:pointer;padding:10px 15px;display:inline-flex;align-items:center;gap:7px;transition:.16s;background:var(--bg);color:var(--ink)}.btn:hover{background:var(--line)}.btn svg{width:15px;height:15px}.btn.primary{background:var(--navy-700);color:#fff;box-shadow:0 6px 16px -8px #003642b3}.btn.primary:hover{background:var(--navy-600);transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.scroll{flex:1;overflow:auto;padding:22px 26px 40px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:15px 17px;box-shadow:var(--shadow)}.stat .k{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:7px}.stat .v{font-size:27px;font-weight:700;margin-top:7px;letter-spacing:-.02em}.stat .v small{font-size:13px;color:var(--muted);font-weight:600}.pip{width:8px;height:8px;border-radius:50%}.tablewrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.thead,.row{display:grid;grid-template-columns:64px 1.7fr 1.3fr 150px 120px 120px;gap:14px;align-items:center}.thead{padding:13px 22px;border-bottom:1px solid var(--line);background:#fbfcfe}.thead span{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted-2);font-weight:700}.row{padding:15px 22px;border-bottom:1px solid var(--line-2);cursor:pointer;transition:background .14s}.row:last-child{border-bottom:0}.row:hover{background:#fafbfe}.row .num{font-size:13px;color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums}.client{font-weight:600;font-size:14.5px}.client small{display:block;color:var(--muted);font-weight:500;font-size:12px;margin-top:2px}.proj{font-size:13.5px;color:#36405a}.status{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:#445}.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.phase-assets{background:var(--gold-soft);color:var(--gold-ink)}.phase-design{background:var(--blue-soft);color:#274d99}.phase-development{background:#e2eef0;color:#1d6172}.phase-approval{background:#ece7fb;color:#5b3fb0}.phase-go_live{background:var(--amber-soft);color:#8a5e12}.phase-complete{background:var(--green-soft);color:#0f7a4f}.phase-none{background:#eef1f3;color:var(--muted)}.empty{text-align:center;color:var(--muted);padding:60px 20px;font-size:14px}.loading{text-align:center;color:var(--muted-2);padding:60px 20px;font-size:13px;letter-spacing:.03em}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#101a3157;opacity:0;pointer-events:none;transition:.25s;z-index:40;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.scrim.show{opacity:1;pointer-events:auto}.panel{position:fixed;top:0;right:0;height:100vh;width:520px;max-width:94vw;background:var(--card);box-shadow:var(--shadow-lg);transform:translate(102%);transition:transform .32s cubic-bezier(.22,.61,.36,1);z-index:41;display:flex;flex-direction:column}.panel.show{transform:none}.panel .ph{padding:22px 24px;border-bottom:1px solid var(--line)}.panel .ph .x{float:right;border:0;background:var(--bg);width:32px;height:32px;border-radius:8px;cursor:pointer;color:var(--muted);font-size:16px}.panel .ph .x:hover{background:var(--line)}.panel .ph h2{font-weight:600;font-size:22px;margin-bottom:4px}.panel .ph p{color:var(--muted);font-size:13.5px}.panel .body{padding:22px 24px;overflow:auto;flex:1}.panel h3{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-weight:700;margin:6px 0 16px}.stepper{position:relative;margin-left:6px}.step{display:flex;gap:14px;padding-bottom:20px;position:relative}.step:last-child{padding-bottom:4px}.step:before{content:"";position:absolute;left:9px;top:22px;bottom:-2px;width:2px;background:var(--line)}.step:last-child:before{display:none}.step .node{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);background:#fff;flex:none;display:grid;place-items:center;z-index:1}.step.done .node{background:var(--green);border-color:var(--green)}.step.done .node svg{width:11px;height:11px;color:#fff}.step.now .node{border-color:var(--gold);background:var(--gold);box-shadow:0 0 0 4px var(--gold-soft)}.step.now:before{background:linear-gradient(var(--green),var(--line))}.step .lbl b{font-size:14px;font-weight:600;display:block}.step .lbl span{font-size:12.5px;color:var(--muted)}.step.now .lbl b{color:var(--gold-ink)}.kv{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line-2);font-size:13.5px}.kv span{color:var(--muted)}.kv b{font-weight:600}.tag{display:inline-block;background:var(--green-soft);color:#0f7a4f;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px}.tag.warn{background:var(--amber-soft);color:#8a5e12}.tag.muted{background:#eef1f3;color:var(--muted)}.note{margin-top:18px;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:13px 15px;font-size:13px;color:#46506a;line-height:1.5}.note b{color:var(--ink)}.chat{display:flex;flex-direction:column;gap:10px;margin-top:4px}.msg{max-width:84%;padding:10px 13px;border-radius:13px;font-size:13.5px;line-height:1.45;white-space:pre-wrap}.msg .who{display:block;font-size:11px;font-weight:700;opacity:.7;margin-bottom:3px}.msg.outbound{align-self:flex-end;background:var(--navy-700);color:#fff;border-bottom-right-radius:4px}.msg.inbound{align-self:flex-start;background:var(--bg);color:var(--ink);border-bottom-left-radius:4px}.chat-empty{color:var(--muted-2);font-size:13px;text-align:center;padding:24px}.composer{display:flex;gap:8px;margin-top:14px}.composer textarea{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font:inherit;font-size:13.5px;resize:vertical;min-height:44px;outline:none}.composer textarea:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #2a66751f}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#101a316b;display:grid;place-items:center;z-index:60;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:460px;max-width:92vw;padding:24px}.modal h2{font-size:20px;font-weight:600;margin-bottom:4px}.modal p.sub{color:var(--muted);font-size:13px;margin-bottom:18px}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:6px}.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font:inherit;font-size:14px;outline:none}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #2a66751f}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.err{color:var(--red);font-size:12.5px;margin-top:8px}.navbadge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;min-width:19px;height:19px;border-radius:10px;display:grid;place-items:center;padding:0 5px}.flowtip{background:var(--green-soft);border:1px solid #bde7d1;border-radius:10px;padding:11px 15px;font-size:13px;color:#0f7a4f;margin-bottom:18px;line-height:1.5}.flowtip b{color:#0c623f}.desk{display:grid;grid-template-columns:360px 1fr;gap:18px;align-items:start}@media (max-width: 900px){.desk{grid-template-columns:1fr}}.deskcol{display:flex;flex-direction:column}.ch{background:#eef5f6;color:var(--navy-700);font-weight:600;padding:12px 16px;border-bottom:1px solid var(--line);font-size:14px;display:flex;justify-content:space-between;align-items:center;gap:10px}.ch-sub{font-size:12px;color:var(--muted);font-weight:400;margin-right:auto;margin-left:8px}.ch-btn{padding:6px 11px;font-size:12px}.poll-msg{font-size:12px;color:var(--muted);padding:8px 16px;border-bottom:1px solid var(--line-2);background:#fbfdfd}.ticket{padding:13px 16px;border-bottom:1px solid var(--line-2);cursor:pointer;transition:background .12s}.ticket:hover{background:#f6fafb}.ticket.sel{background:#eef5f6;border-left:3px solid var(--gold);padding-left:13px}.t-row1{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.t-who{font-weight:700;font-size:13.5px}.t-when{font-size:11px;color:var(--muted-2)}.t-subj{font-size:13px;color:#36454c;margin-bottom:7px}.t-meta{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.t-summary{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.4}.t-cat{font-size:11px;color:var(--gold-ink);background:var(--gold-soft);padding:2px 7px;border-radius:6px;text-transform:capitalize}.t-ai{font-size:10px;font-weight:800;letter-spacing:.04em;color:#5b3fb0;background:#ece7fb;padding:2px 6px;border-radius:6px}.t-status{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:capitalize}.st-open{background:var(--blue-soft);color:#2563a8}.st-pending{background:var(--amber-soft);color:#8a5e12}.st-closed{background:#e9eef0;color:#6b7b82}.pr{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:capitalize}.pr-urgent{background:var(--red-soft);color:var(--red)}.pr-high{background:var(--amber-soft);color:#8a5e12}.pr-normal{background:var(--blue-soft);color:#2563a8}.pr-low{background:#e9eef0;color:#6b7b82}.thread{padding:18px;min-height:320px;max-height:calc(100vh - 320px);overflow:auto}.tmsg{margin-bottom:16px;max-width:80%}.tmsg.outbound{margin-left:auto}.tmsg-meta{font-size:11px;color:var(--muted);margin-bottom:5px}.tmsg.outbound .tmsg-meta{text-align:right}.tmsg-b{border-radius:12px;padding:11px 14px;font-size:13.5px;line-height:1.5;white-space:pre-wrap}.tmsg.inbound .tmsg-b{background:#f1f5f6;border:1px solid var(--line);color:#26333a}.tmsg.outbound .tmsg-b{background:var(--navy-700);color:#fff}.desk-reply{border-top:1px solid var(--line);padding:14px 18px;background:#fafcfc}.desk-reply textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:11px;font:inherit;font-size:13.5px;resize:vertical;outline:none}.desk-reply textarea:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #2a66751f}.rbar{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:10px;flex-wrap:wrap}.assign{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.assign select{font:inherit;font-size:12px;border:1px solid var(--line);border-radius:7px;padding:5px 8px;text-transform:capitalize}.lockbar{display:flex;align-items:center;gap:8px;background:var(--navy-700);color:#d4eef6;font-size:12.5px;font-weight:700;padding:10px 16px;border-radius:10px}.mt-sub{color:var(--muted);font-size:13.5px;margin:14px 0 18px}.mt-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px;margin-bottom:18px}.mt-card.pad0{padding:0;overflow:hidden}.finhead{display:flex;align-items:center;gap:12px;margin-bottom:16px}.finhead h2{font-size:18px;font-weight:600}.finhead .sel{margin-left:auto}.fin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 820px){.fin-stats{grid-template-columns:1fr 1fr}}.fin-stat{padding:15px 17px;border:1px solid var(--line);border-radius:12px;background:#f1f7f8}.fin-stat .k{font-size:12px;color:var(--muted);font-weight:600}.fin-stat .v{font-size:24px;font-weight:700;margin-top:6px;letter-spacing:-.02em}.fin-stat .v.t-good{color:var(--green)}.fin-stat .v.t-ok{color:var(--amber)}.fin-stat .v.t-bad{color:var(--red)}.marginbar{margin-top:18px}.mb-top{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);margin-bottom:7px}.mb-track{height:34px;border-radius:9px;background:#eef1f6;position:relative;overflow:hidden;border:1px solid var(--line)}.mb-fill{position:absolute;left:0;top:0;bottom:0;display:flex;align-items:center;padding-left:12px;color:#fff;font-size:12.5px;font-weight:700;background:linear-gradient(90deg,#2a3a63,#3a4d80);transition:width .5s}.mb-fill.over{background:linear-gradient(90deg,#a8362e,var(--red))}.mb-quoteline{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--ink)}.fin-thead,.fin-row{display:grid;grid-template-columns:1.6fr 1fr 1fr .8fr 1.2fr;gap:12px;padding:13px 20px;align-items:center}.fin-thead{background:#f1f7f8;border-bottom:1px solid var(--line)}.fin-thead span{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);font-weight:700}.fin-row{border-bottom:1px solid var(--line-2);font-size:13.5px}.fin-row:last-child{border-bottom:0}.fin-row .cl{font-weight:600}.fin-row .cl small{display:block;color:var(--muted);font-weight:500;font-size:12px}.fin-row .money{font-variant-numeric:tabular-nums}.mtag{display:inline-block;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.m-good{background:var(--green-soft);color:#0f7a4f}.m-ok{background:var(--amber-soft);color:#8a5e12}.m-bad{background:var(--red-soft);color:#a8362e}.bchart{display:flex;align-items:flex-end;gap:14px;height:220px;padding-top:16px}.bcol{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.bbar{width:100%;max-width:80px;background:linear-gradient(180deg,#3a4d80,#2a3a63);border-radius:8px 8px 0 0;transition:height .5s cubic-bezier(.22,.61,.36,1)}.bhh{font-size:12px;font-weight:700;margin-bottom:7px}.bdd{font-size:12px;color:var(--muted);margin-top:9px}.mt-two{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}@media (max-width: 820px){.mt-two{grid-template-columns:1fr}}.lrow{display:flex;align-items:center;gap:11px;padding:12px 18px;border-bottom:1px solid var(--line-2);font-size:13.5px}.lrow:last-child{border-bottom:0}.lav{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700;flex:none}.lnm{font-weight:600}.lhrs{margin-left:auto;font-weight:700;font-variant-numeric:tabular-nums}.lcost{width:78px;text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}.gl-count{font-size:12px;font-weight:700;color:var(--gold-ink);background:var(--gold-soft);padding:2px 9px;border-radius:999px;margin-left:6px}.gl-prog{height:7px;border-radius:5px;background:var(--line);overflow:hidden;margin-bottom:14px}.gl-prog-fill{height:100%;background:linear-gradient(90deg,var(--green),#2bbd84);transition:width .3s}.gl-group{margin-bottom:12px}.gl-gname{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted-2);font-weight:700;margin:6px 0}.gl-item{display:flex;align-items:flex-start;gap:10px;padding:7px 0;font-size:13.5px;cursor:pointer}.gl-item.locked{cursor:default}.gl-item input{width:18px;height:18px;margin:1px 0 0;flex:none;accent-color:var(--green)}.gl-item.done span{color:var(--muted);text-decoration:line-through}.filelist{display:flex;flex-direction:column;gap:8px}.fileitem{display:flex;align-items:center;gap:10px;padding:10px 13px;border:1px solid var(--line);border-radius:10px;text-decoration:none;color:var(--ink);font-size:13.5px;transition:border-color .14s,background .14s}.fileitem:hover{border-color:var(--gold);background:var(--gold-soft)}.fi-ico{font-size:15px}.fi-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fi-by{margin-left:auto;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.set-thead,.set-row{display:grid;grid-template-columns:1.1fr 1.6fr .9fr 1.3fr;gap:12px;align-items:center;padding:11px 18px}.set-thead{background:#f1f7f8;border-bottom:1px solid var(--line)}.set-thead span{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);font-weight:700}.set-row{border-bottom:1px solid var(--line-2);font-size:13.5px}.set-row:last-child{border-bottom:0}.set-row.inactive{opacity:.5}.set-nm{font-weight:600}.set-em{color:var(--muted);font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.set-row select{border:1px solid var(--line);border-radius:8px;padding:6px 8px;font:inherit;font-size:12.5px}.set-rate{display:flex;align-items:center;gap:6px;position:relative}.set-rate .dollar{color:var(--muted);font-weight:600}.set-rate input{width:64px;border:1px solid var(--line);border-radius:8px;padding:7px 9px;font:inherit;font-size:13.5px}.set-rate input:focus{outline:none;border-color:var(--navy-500);box-shadow:0 0 0 3px #2a66751f}.set-row.new input{width:auto;border:1px solid var(--line);border-radius:8px;padding:7px 9px;font:inherit;font-size:13px}.btn.mini{padding:6px 10px;font-size:12px}.placeholder{display:grid;place-items:center;height:100%;text-align:center;color:var(--muted);padding:40px}.placeholder h2{font-size:19px;color:var(--ink);margin-bottom:8px;font-weight:600}.placeholder p{font-size:14px;max-width:420px;line-height:1.5}
