@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--brand:#2563eb;--brand-600:#1d4ed8;--brand-700:#1e40af;--brand-50:#eff6ff;--ink:#0f172a;--ink-2:#334155;--muted:#64748b;--faint:#94a3b8;--bg:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--line:#e2e8f0;--line-2:#cbd5e1;--good:#16a34a;--good-bg:#dcfce7;--warn:#d97706;--warn-bg:#fef3c7;--bad:#dc2626;--bad-bg:#fee2e2;--info:#0ea5e9;--info-bg:#e0f2fe;--sb-from:#0b1220;--sb-to:#111c34;--r:12px;--r-sm:8px;--r-lg:16px;--sh-sm:0 1px 2px #0f172a0f, 0 1px 3px #0f172a14;--sh:0 1px 3px #0f172a0f, 0 8px 24px -8px #0f172a1f;--sh-lg:0 20px 48px -16px #0f172a47}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,system-ui,Segoe UI,sans-serif;font-size:14px;line-height:1.5}a{color:var(--brand-600);text-decoration:none}h1,h2,h3,h4{letter-spacing:-.01em;margin:0;font-weight:700}button{cursor:pointer;font:inherit}::selection{background:var(--brand-50)}.app{min-height:100vh;display:flex}.sidebar{background:linear-gradient(180deg, var(--sb-from), var(--sb-to));color:#cbd5e1;flex-direction:column;width:248px;height:100vh;display:flex;position:sticky;top:0}.brand{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:18px 20px;display:flex}.brand .logo{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;width:34px;height:34px;box-shadow:0 6px 16px -6px var(--brand);border-radius:9px;place-items:center;display:grid}.brand b{color:#fff;letter-spacing:-.02em;font-size:16px}.brand small{color:#64748b;font-size:11px;font-weight:500;display:block}.nav{flex:1;padding:12px;overflow-y:auto}.nav .group{color:#475569;text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px;font-size:10.5px;font-weight:700}.nav a{color:#cbd5e1;border-radius:9px;align-items:center;gap:11px;margin:2px 0;padding:9px 12px;font-weight:500;transition:all .12s;display:flex}.nav a svg{opacity:.8;flex:none;width:18px;height:18px}.nav a:hover{color:#fff;background:#ffffff0f}.nav a.active{background:linear-gradient(90deg, var(--brand), var(--brand-600));color:#fff;box-shadow:0 6px 16px -8px var(--brand)}.nav a.active svg{opacity:1}.sb-foot{border-top:1px solid #ffffff14;padding:12px}.userchip{border-radius:10px;align-items:center;gap:10px;padding:8px;display:flex}.userchip .av{background:var(--brand);color:#fff;border-radius:50%;flex:none;place-items:center;width:34px;height:34px;font-weight:700;display:grid}.userchip .nm{color:#fff;font-size:13px;font-weight:600;line-height:1.2}.userchip .rl{color:#64748b;font-size:11px}.content{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:20;background:#ffffffd9;justify-content:space-between;align-items:center;height:60px;padding:0 26px;display:flex;position:sticky;top:0}.topbar h2{font-size:17px}.topbar .sub{color:var(--muted);font-size:12px}.main{width:100%;padding:24px 28px}@media (width<=640px){.main{padding:16px 14px}.topbar{padding:0 14px}}.muted{color:var(--muted)}.faint{color:var(--faint)}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.page-head h2{font-size:22px}.page-head .sub{color:var(--muted);margin-top:2px;font-size:13px}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.spread{justify-content:space-between;align-items:center;gap:12px;display:flex}.grid{gap:16px;display:grid}.kpis{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);padding:18px}.card.pad-lg{padding:22px}.section-title{align-items:center;gap:8px;margin-bottom:14px;font-size:14px;font-weight:700;display:flex}.kpi{color:#fff;border:0;flex-direction:column;align-items:flex-start;min-height:132px;padding:18px 18px 16px;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 24px -12px #0f172a80}.kpi>*{z-index:1;position:relative}.kpi .ic{background:#ffffff38;border-radius:12px;place-items:center;width:42px;height:42px;margin-bottom:auto;display:grid}.kpi .ic svg{color:#fff;width:22px;height:22px}.kpi .k{opacity:.92;margin-top:12px;font-size:12.5px;font-weight:600}.kpi .v{letter-spacing:-.02em;white-space:nowrap;margin-top:3px;font-size:clamp(18px,1.5vw,24px);font-weight:800;line-height:1.15}.kpi .spark{opacity:.16;z-index:0;pointer-events:none;position:absolute;bottom:-16px;right:-12px}.kpi .spark svg{color:#fff;width:92px;height:92px}.kpi.blue{background:linear-gradient(135deg,#2563eb,#3b82f6)}.kpi.violet{background:linear-gradient(135deg,#7c3aed,#a855f7)}.kpi.green{background:linear-gradient(135deg,#059669,#10b981)}.kpi.amber{background:linear-gradient(135deg,#d97706,#f59e0b)}.kpi.red{background:linear-gradient(135deg,#dc2626,#f43f5e)}.kpi.teal{background:linear-gradient(135deg,#0891b2,#06b6d4)}.kpi.indigo{background:linear-gradient(135deg,#4f46e5,#6366f1)}.kpi.pink{background:linear-gradient(135deg,#db2777,#ec4899)}.ic.blue{background:var(--brand-50);color:var(--brand)}.ic.green{background:var(--good-bg);color:var(--good)}.ic.amber{background:var(--warn-bg);color:var(--warn)}.ic.red{background:var(--bad-bg);color:var(--bad)}.ic.sky{background:var(--info-bg);color:var(--info)}.dash-2col{grid-template-columns:2fr 1fr;gap:16px;margin-top:16px;display:grid}.rep-2col{grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;display:grid}@media (width<=1000px){.dash-2col,.rep-2col{grid-template-columns:1fr}}.tablewrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--line);padding:11px 14px;font-size:13.5px}th{background:var(--surface-2);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:11.5px;font-weight:600}tbody tr:last-child td{border-bottom:0}tbody tr:hover td{background:var(--surface-2)}.right{text-align:right}.center{text-align:center}.empty{text-align:center;color:var(--faint);padding:40px}input,select,textarea{font:inherit;border:1px solid var(--line-2);border-radius:var(--r-sm);width:100%;color:var(--ink);background:#fff;padding:9px 11px;transition:border .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-50);outline:none}label{color:var(--ink-2);margin-bottom:5px;font-size:12.5px;font-weight:500;display:block}.field{margin-bottom:14px}textarea{resize:vertical;min-height:70px}.btn{background:var(--brand);color:#fff;border:1px solid var(--brand);border-radius:var(--r-sm);box-shadow:var(--sh-sm);align-items:center;gap:7px;padding:9px 15px;font-weight:600;transition:all .12s;display:inline-flex}.btn:hover{background:var(--brand-600);border-color:var(--brand-600)}.btn svg{width:16px;height:16px}.btn.ghost{color:var(--ink-2);border-color:var(--line-2);box-shadow:none;background:#fff}.btn.ghost:hover{background:var(--surface-2);border-color:var(--muted)}.btn.sm{padding:6px 10px;font-size:12.5px}.btn.danger{background:var(--bad);border-color:var(--bad)}.btn.danger:hover{filter:brightness(.95)}.btn.success{background:var(--good);border-color:var(--good)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-row{justify-content:flex-end;gap:9px;margin-top:16px;display:flex}.badge{background:var(--line);color:var(--ink-2);border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge:before{content:"";opacity:.7;background:currentColor;border-radius:50%;width:6px;height:6px}.badge.Open{background:var(--info-bg);color:#0369a1}.badge.InProgress{background:var(--warn-bg);color:#b45309}.badge.AwaitingApproval{color:#a16207;background:#fef9c3}.badge.Approved{color:#6d28d9;background:#ede9fe}.badge.ReadyForCollection{background:var(--good-bg);color:#15803d}.badge.Invoiced{color:#6d28d9;background:#ede9fe}.badge.Closed{background:var(--line);color:var(--muted)}.badge.Cancelled{background:var(--bad-bg);color:#b91c1c}.badge.Paid{background:var(--good-bg);color:#15803d}.badge.Partial{background:var(--warn-bg);color:#b45309}.badge.Unpaid{background:var(--bad-bg);color:#b91c1c}.badge.plain:before{display:none}.modal-bg{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--r-lg);width:520px;max-width:100%;max-height:92vh;box-shadow:var(--sh-lg);background:#fff;padding:24px;overflow:auto}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toolbar input,.toolbar select{max-width:260px}.search{position:relative}.search svg{width:16px;height:16px;color:var(--faint);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search input{padding-left:32px}.err{color:var(--bad);background:var(--bad-bg);border-radius:var(--r-sm);border:1px solid #fecaca;margin:8px 0;padding:8px 11px;font-size:13px}hr{border:0;border-top:1px solid var(--line);margin:12px 0}.login-wrap{background:radial-gradient(1200px 600px at 70% -10%,#1e3a8a 0%,#0b1220 55%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{width:380px;box-shadow:var(--sh-lg);background:#fff;border-radius:18px;padding:34px}.login-box .blogo{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;border-radius:13px;place-items:center;width:48px;height:48px;margin-bottom:14px;display:grid}.bars{align-items:flex-end;gap:6px;height:160px;padding-top:8px;display:flex}.bars .col{flex-direction:column;flex:1;justify-content:flex-end;gap:2px;min-width:0;display:flex}.bars .seg{border-radius:3px 3px 0 0}.bars .seg.s{background:var(--brand)}.bars .seg.p{background:#60a5fa}.bars .lbl{color:var(--faint);text-align:center;white-space:nowrap;text-overflow:ellipsis;margin-top:5px;font-size:9px;overflow:hidden}.legend{color:var(--muted);gap:16px;font-size:12px;display:flex}.legend i{vertical-align:middle;border-radius:3px;width:10px;height:10px;margin-right:6px;display:inline-block}@media (width<=820px){.sidebar{width:64px}.brand b,.brand small,.nav .group,.nav a span,.userchip .nm,.userchip .rl{display:none}.nav a{justify-content:center}}
