@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;600;700&display=swap";:root,:root[data-theme=dark]{--bg: #0a0a0c;--bg-elev: #161618;--bg-elev2: #1f1f23;--bg-hover: #2a2a30;--glass: rgba(28, 28, 32, .72);--border-soft: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .16);--text: #f5f5f7;--text-dim: rgba(235, 235, 245, .6);--text-faint: rgba(235, 235, 245, .34);--blue: #10b981;--blue-bright: #34d399;--blue-glow: rgba(16, 185, 129, .42);--green: #30d158;--red: #ff453a;--orange: #ff9f0a;--sidebar: rgba(22, 22, 24, .8);--topbar-bg: rgba(14, 14, 16, .7);--thead-bg: rgba(30, 30, 34, .86);--input-bg: #0e0e11;--avatar-from: #2c2c2e;--avatar-to: #3a3a3c;--avatar-text: #ebebf5;--glow1: rgba(10, 132, 255, .1);--glow2: rgba(48, 209, 88, .05);--dot: rgba(235, 235, 245, .07);--scrollbar: rgba(255, 255, 255, .16);--scrollbar-hover: rgba(255, 255, 255, .26);--skeleton-1: #1c1c20;--skeleton-2: #26262c;--shadow: 0 16px 50px rgba(0, 0, 0, .5);--shadow-soft: 0 1px 2px rgba(0, 0, 0, .3), 0 8px 24px rgba(0, 0, 0, .22)}:root[data-theme=light]{--bg: #f2f2f7;--bg-elev: #ffffff;--bg-elev2: #f2f2f7;--bg-hover: #ebebf0;--glass: rgba(255, 255, 255, .72);--border-soft: rgba(0, 0, 0, .07);--border: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .14);--text: #1d1d1f;--text-dim: rgba(60, 60, 67, .6);--text-faint: rgba(60, 60, 67, .35);--blue: #059669;--blue-bright: #10b981;--blue-glow: rgba(5, 150, 105, .26);--green: #34c759;--red: #ff3b30;--orange: #ff9500;--sidebar: rgba(255, 255, 255, .8);--topbar-bg: rgba(255, 255, 255, .72);--thead-bg: rgba(248, 248, 250, .9);--input-bg: #ffffff;--avatar-from: #e2e8f0;--avatar-to: #cbd5e1;--avatar-text: #334155;--glow1: rgba(0, 122, 255, .06);--glow2: rgba(52, 199, 89, .05);--dot: rgba(60, 60, 67, .07);--scrollbar: rgba(0, 0, 0, .18);--scrollbar-hover: rgba(0, 0, 0, .3);--skeleton-1: #ececf1;--skeleton-2: #e0e0e6;--shadow: 0 16px 44px rgba(15, 23, 42, .16);--shadow-soft: 0 1px 2px rgba(15, 23, 42, .06), 0 6px 18px rgba(15, 23, 42, .06)}:root{--radius: 16px;--radius-sm: 11px;--radius-lg: 22px;--ease: cubic-bezier(.32, .72, 0, 1);--spring: cubic-bezier(.5, 1.4, .5, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(1200px 700px at 100% -10%,var(--glow1),transparent 60%),radial-gradient(900px 600px at -10% 110%,var(--glow2),transparent 55%),var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,Inter,system-ui,sans-serif;font-size:14px;line-height:1.5;letter-spacing:-.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color .3s var(--ease),color .3s var(--ease)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}::selection{background:var(--blue-glow)}.num,.value,.stat .value,.hero-value,td.num,.mono{font-family:ui-monospace,SF Mono,JetBrains Mono,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.02em}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:8px;border:3px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover);background-clip:padding-box}:focus-visible{outline:none;box-shadow:0 0 0 4px var(--blue-glow);border-radius:8px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(10px) scale(.96)}}@keyframes rise{0%{opacity:0;transform:translateY(16px)}}@keyframes contentIn{0%{opacity:0;transform:translateY(8px) scale(.995)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes loaderPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes fadePulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes glowPulse{0%,to{box-shadow:0 0 10px 0 var(--blue);opacity:.85}50%{box-shadow:0 0 18px 2px var(--blue);opacity:1}}@keyframes toastIn{0%{opacity:0;transform:translate(28px) scale(.92)}}@keyframes iosbar{to{opacity:.18}}.app{display:flex;min-height:100vh}.sidebar{width:248px;flex-shrink:0;background:var(--sidebar);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;padding:22px 14px;gap:2px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:11px;padding:4px 10px 24px}.brand .logo{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--blue),var(--blue-bright));display:grid;place-items:center;font-weight:800;color:#fff;font-size:17px;box-shadow:0 6px 20px var(--blue-glow)}.brand b{font-size:15px;letter-spacing:-.3px}.brand span{color:var(--text-faint);font-size:10px;display:block;text-transform:uppercase;letter-spacing:1.5px}.nav-section{color:var(--text-faint);font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:16px 12px 6px}.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:var(--text-dim);font-weight:500;font-size:13.5px;position:relative;transition:background .22s var(--ease),color .22s var(--ease),box-shadow .22s var(--ease)}.nav-link svg{width:18px;height:18px;flex-shrink:0;opacity:.8;transition:transform .25s var(--spring)}.nav-link:hover{background:var(--bg-hover);color:var(--text)}.nav-link:hover svg{transform:scale(1.14)}.nav-link.active{background:linear-gradient(90deg,color-mix(in srgb,var(--blue) 22%,transparent),color-mix(in srgb,var(--blue) 6%,transparent));color:var(--blue-bright);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--blue) 22%,transparent)}.nav-link.active svg{opacity:1}.nav-link.active:before{content:"";position:absolute;left:-14px;top:50%;width:3px;height:22px;border-radius:0 4px 4px 0;background:var(--blue);transform:translateY(-50%);animation:glowPulse 2.6s var(--ease) infinite}.sidebar .spacer{flex:1}.who{padding:11px;border:1px solid var(--border-soft);border-radius:13px;background:var(--bg-elev);margin-top:8px;display:flex;align-items:center;gap:10px}.who .avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--avatar-from),var(--avatar-to));display:grid;place-items:center;font-weight:700;color:var(--avatar-text);font-size:13px;flex-shrink:0}.who .meta{min-width:0}.who b{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.who small{color:var(--text-faint);font-size:11px}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:64px;flex-shrink:0;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;padding:0 30px;background:var(--topbar-bg);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);position:sticky;top:0;z-index:20}.topbar h1{font-size:16px;margin:0;font-weight:600;letter-spacing:-.4px}.topbar .sub{color:var(--text-faint);font-size:12px}.topbar-actions{display:flex;align-items:center;gap:10px}.icon-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--bg-elev2);color:var(--text-dim);display:grid;place-items:center;transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--spring)}.icon-btn:hover{background:var(--bg-hover);color:var(--text);transform:scale(1.08)}.icon-btn:active{transform:scale(.94)}.icon-btn svg{width:18px;height:18px}.content{padding:30px;max-width:1280px;width:100%;background-image:radial-gradient(var(--dot) 1.4px,transparent 1.4px);background-size:26px 26px;background-position:12px 12px;animation:contentIn .4s var(--ease) both}.grid{display:grid;gap:16px}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 1000px){.cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.cols-3,.cols-2{grid-template-columns:1fr}.sidebar{width:74px}.brand b,.brand span,.nav-link span,.who .meta{display:none}.nav-link{justify-content:center}}.card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-soft);transition:border-color .25s var(--ease),transform .25s var(--spring),box-shadow .25s var(--ease)}.grid>.card{animation:rise .55s var(--ease) both}.grid>.card:nth-child(2){animation-delay:.05s}.grid>.card:nth-child(3){animation-delay:.1s}.grid>.card:nth-child(4){animation-delay:.15s}.stat,.metric{position:relative;overflow:hidden}.stat:hover,.metric:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.stat .label{color:var(--text-dim);font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.stat .value{font-size:28px;font-weight:700;margin-top:8px;letter-spacing:-.6px;line-height:1.05}.stat .sub{color:var(--text-faint);font-size:12px;margin-top:6px}.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,color-mix(in srgb,var(--blue) 18%,var(--bg-elev)),var(--bg-elev) 60%);border-color:var(--border);padding:24px;animation:rise .6s var(--ease) both}.hero .label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);font-weight:600}.hero-value{font-size:42px;font-weight:700;margin:10px 0 4px;line-height:1}.hero .sub{color:var(--text-faint);font-size:13px}.metric{display:flex;gap:14px;align-items:flex-start}.metric-icon{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;flex-shrink:0;transition:transform .25s var(--spring)}.metric:hover .metric-icon{transform:scale(1.1) rotate(-4deg)}.metric-icon svg{width:21px;height:21px}.metric-icon.blue{background:color-mix(in srgb,var(--blue) 16%,transparent);color:var(--blue-bright)}.metric-icon.green{background:color-mix(in srgb,var(--green) 16%,transparent);color:var(--green)}.metric-icon.red{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red)}.metric-icon.orange{background:color-mix(in srgb,var(--orange) 14%,transparent);color:var(--orange)}.metric-icon.gray{background:var(--bg-elev2);color:var(--text-dim)}.metric-body{min-width:0}.metric .label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);font-weight:600}.metric .value{font-size:23px;font-weight:700;margin-top:4px;letter-spacing:-.4px}.metric .sub{font-size:12px;color:var(--text-faint);margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 17px;border-radius:980px;border:1px solid var(--border);background:var(--bg-elev2);color:var(--text);font-weight:600;font-size:13px;transition:filter .18s var(--ease),background .18s var(--ease),border-color .18s var(--ease),transform .18s var(--spring),box-shadow .18s var(--ease);white-space:nowrap}.btn:hover{background:var(--bg-hover);transform:scale(1.03)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn.primary{background:linear-gradient(180deg,var(--blue-bright),var(--blue));border-color:transparent;color:#fff;box-shadow:0 4px 14px var(--blue-glow)}.btn.primary:hover{filter:brightness(1.06)}.btn.danger{background:transparent;border-color:color-mix(in srgb,var(--red) 45%,transparent);color:var(--red)}.btn.danger:hover{background:color-mix(in srgb,var(--red) 10%,transparent)}.btn.ghost{background:transparent;border-color:transparent;color:var(--text-dim)}.btn.ghost:hover{background:var(--bg-hover);color:var(--text)}.btn.sm{padding:6px 12px;font-size:12px}.table-wrap{overflow-x:auto;border:1px solid var(--border-soft);border-radius:var(--radius);background:var(--bg-elev);box-shadow:var(--shadow-soft);animation:rise .55s var(--ease) both}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--border-soft);white-space:nowrap}thead th{position:sticky;top:0;background:var(--thead-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1;color:var(--text-faint);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}tbody tr{transition:background .16s var(--ease)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}.num{text-align:right}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-elev2);color:var(--text-dim);border:1px solid transparent}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9}.badge.green{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green);border-color:color-mix(in srgb,var(--green) 24%,transparent)}.badge.red{background:color-mix(in srgb,var(--red) 12%,transparent);color:var(--red);border-color:color-mix(in srgb,var(--red) 22%,transparent)}.badge.blue{background:color-mix(in srgb,var(--blue) 14%,transparent);color:var(--blue-bright);border-color:color-mix(in srgb,var(--blue) 24%,transparent)}.badge.orange{background:color-mix(in srgb,var(--orange) 14%,transparent);color:var(--orange);border-color:color-mix(in srgb,var(--orange) 22%,transparent)}.badge.gray{background:var(--bg-elev2);color:var(--text-faint)}.badge.gray:before{opacity:.5}.pos{color:var(--green)}.neg{color:var(--red)}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:15px}.field label{font-size:12px;color:var(--text-dim);font-weight:600}.input,.select{background:var(--input-bg);border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius-sm);padding:11px 13px;font-size:14px;outline:none;width:100%;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.input::placeholder{color:var(--text-faint)}.input:focus,.select:focus{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-glow)}.select{cursor:pointer}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.row>*{flex:0 0 auto}.seg{display:flex;gap:4px;background:var(--bg-elev2);padding:3px;border-radius:12px;border:1px solid var(--border-soft)}.seg-btn{flex:1;padding:9px;border:none;background:transparent;color:var(--text-dim);font-weight:600;font-size:13px;border-radius:9px;transition:background .25s var(--ease),color .2s var(--ease)}.seg-btn:hover{color:var(--text)}.seg-btn.on{background:var(--bg-elev);color:var(--text);box-shadow:var(--shadow-soft)}.seg-btn.on.income{color:var(--green)}.seg-btn.on.expense{color:var(--red)}.chip{display:inline-flex;align-items:center;gap:8px;padding:5px 8px 5px 6px;border-radius:999px;background:var(--bg-elev2);border:1px solid var(--border-soft);font-size:13px;font-weight:500;transition:border-color .18s var(--ease),transform .18s var(--spring)}.chip:hover{border-color:var(--border-strong);transform:translateY(-1px)}.chip-x{width:18px;height:18px;border-radius:50%;border:none;background:transparent;color:var(--text-faint);font-size:15px;line-height:1;display:grid;place-items:center;transition:background .15s,color .15s}.chip-x:hover{background:color-mix(in srgb,var(--red) 16%,transparent);color:var(--red)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(8px) saturate(140%);-webkit-backdrop-filter:blur(8px) saturate(140%);display:grid;place-items:center;z-index:50;padding:20px;animation:fade .2s var(--ease)}.modal{background:var(--glass);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:100%;max-width:460px;padding:26px;box-shadow:var(--shadow);animation:pop .3s var(--spring)}.modal h2{margin:0 0 20px;font-size:19px;letter-spacing:-.4px;font-weight:700}.modal-msg{color:var(--text-dim);font-size:14px;line-height:1.5;margin:-6px 0 20px}.toast-wrap{position:fixed;top:18px;right:18px;z-index:100;display:flex;flex-direction:column;gap:10px;max-width:92vw}.toast{display:flex;align-items:center;gap:11px;min-width:250px;max-width:380px;padding:12px 14px;border-radius:14px;background:var(--glass);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid var(--border-strong);box-shadow:var(--shadow);animation:toastIn .35s var(--spring);font-size:13.5px;font-weight:500}.toast .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.toast.success .dot{background:var(--green);box-shadow:0 0 10px var(--green)}.toast.error .dot{background:var(--red);box-shadow:0 0 10px var(--red)}.toast.info .dot{background:var(--blue);box-shadow:0 0 10px var(--blue)}.toast .toast-close{margin-left:auto;color:var(--text-faint);background:none;border:none;font-size:16px;line-height:1;padding:0 2px}.toast .toast-close:hover{color:var(--text)}.spinner{width:30px;height:30px;border-radius:50%;margin:34px auto;background:conic-gradient(from 90deg,transparent 0deg,var(--blue) 300deg);-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 0);mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 0);animation:spin .8s linear infinite}.loader{display:grid;place-items:center;gap:18px;min-height:55vh}.loader-logo{width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg,var(--blue),var(--blue-bright));display:grid;place-items:center;color:#fff;font-weight:800;font-size:26px;box-shadow:0 14px 40px var(--blue-glow);animation:loaderPulse 1.5s var(--ease) infinite;position:relative}.loader-logo:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:24px;border:2.5px solid transparent;border-top-color:var(--blue-bright);border-right-color:var(--blue-bright);animation:spin 1s linear infinite}.loader-label{color:var(--text-faint);font-size:13px;animation:fadePulse 1.5s ease infinite}.skeleton{background:linear-gradient(90deg,var(--skeleton-1) 25%,var(--skeleton-2) 50%,var(--skeleton-1) 75%);background-size:200% 100%;animation:shimmer 1.4s ease infinite;border-radius:8px}.sk-row{height:16px;margin:14px 16px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-head h1{margin:0;font-size:26px;font-weight:700;letter-spacing:-.8px}.muted{color:var(--text-faint)}.center{display:grid;place-items:center;min-height:100vh}.error{color:var(--red);font-size:13px;margin-top:8px;background:color-mix(in srgb,var(--red) 9%,transparent);border:1px solid color-mix(in srgb,var(--red) 22%,transparent);padding:10px 13px;border-radius:12px;animation:rise .3s var(--ease) both}.sparkline{width:100%;height:56px;display:block}.login-card{width:100%;max-width:400px;background:var(--glass);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border:1px solid var(--border-strong);border-radius:26px;padding:38px;box-shadow:var(--shadow);animation:pop .4s var(--spring)}.login-card .logo{width:56px;height:56px;border-radius:16px;margin:0 auto 20px;background:linear-gradient(135deg,var(--blue),var(--blue-bright));display:grid;place-items:center;font-weight:800;color:#fff;font-size:25px;box-shadow:0 12px 30px var(--blue-glow)}.login-card h1{text-align:center;font-size:22px;margin:0 0 4px;letter-spacing:-.5px}.login-card p.sub{text-align:center;color:var(--text-faint);margin:0 0 26px;font-size:13px}@media (min-width: 2200px){body{font-size:16px}.content{max-width:1760px;padding:46px}.sidebar{width:304px}.topbar{height:76px;padding:0 46px}.page-head h1,.stat .value,.metric .value{font-size:32px}.hero-value{font-size:58px}.nav-link{font-size:15px;padding:11px 14px}.nav-link svg{width:21px;height:21px}th,td{padding:16px 20px;font-size:15px}}@media (min-width: 3400px){body{font-size:21px}.content{max-width:2560px;padding:64px}.sidebar{width:380px}.topbar{height:96px;padding:0 64px}.page-head h1{font-size:42px}.hero-value{font-size:76px}.nav-link svg{width:26px;height:26px}th,td{padding:20px 26px;font-size:19px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}
