@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--bg: #f4f6f8;--surface: #ffffff;--surface-2: #f8fafb;--sidebar: #0f1623;--sidebar-2: #161f30;--ink: #0e1726;--muted: #6b7682;--line: #e7ebef;--line-dark: #243044;--brand: #0fae7e;--brand-dark: #0c8c66;--brand-soft: #e6f7f1;--pos: #0fae7e;--neg: #e0533d;--neg-soft: #fdeae6;--warn: #d99a16;--radius: 14px;--shadow: 0 1px 2px rgba(16, 24, 40, .04), 0 8px 24px rgba(16, 24, 40, .06);--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Plus Jakarta Sans,ui-sans-serif,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-variant-numeric:tabular-nums}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.02em}button{font-family:inherit}.tnum{font-variant-numeric:tabular-nums}.shell{display:flex;min-height:100vh}.sidebar{width:252px;flex-shrink:0;background:var(--sidebar);color:#c8d2e0;display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:11px;padding:0 8px 22px}.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand),#14d49a);display:grid;place-items:center;color:#04261c;flex-shrink:0}.brand-name{font-weight:800;font-size:16px;color:#fff;letter-spacing:-.02em;line-height:1.1}.brand-sub{font-size:11px;color:#6b7890;letter-spacing:.08em;text-transform:uppercase}.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}.nav-label{font-size:11px;color:#5d6b82;text-transform:uppercase;letter-spacing:.1em;padding:14px 12px 6px}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:#aeb9ca;font-size:14.5px;font-weight:500;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:background .15s,color .15s}.nav-item:hover{background:var(--sidebar-2);color:#fff}.nav-item.active{background:var(--brand);color:#04261c;font-weight:700}.side-foot{margin-top:auto;border-top:1px solid var(--line-dark);padding-top:14px}.side-user{display:flex;align-items:center;gap:10px;padding:6px 8px}.avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:var(--sidebar-2);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}.side-user .nm{font-size:13.5px;color:#fff;font-weight:600;line-height:1.2}.side-user .rl{font-size:11.5px;color:#7e8aa0}.logout{margin-top:10px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:9px;border-radius:10px;border:1px solid var(--line-dark);background:transparent;color:#aeb9ca;cursor:pointer;font-size:13.5px;font-weight:600}.logout:hover{color:#fff;border-color:#3a4863}.main{flex:1;min-width:0}.topbar{height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 30px;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}.topbar h1{font-size:19px}.topbar .sub{font-size:13px;color:var(--muted);font-weight:500;margin-top:1px}.content{padding:28px 30px 56px;max-width:1120px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:22px 24px}.card-head{padding:18px 24px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-head h3{font-size:16px}.card-head .desc{font-size:13px;color:var(--muted);margin-top:2px;font-weight:500}.grid{display:grid;gap:16px}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 900px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-2{grid-template-columns:1fr}}@media (max-width: 560px){.cols-4{grid-template-columns:1fr}}.stat{padding:18px 20px}.stat .lbl{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);font-weight:600}.stat .val{font-size:26px;font-weight:800;margin-top:12px;letter-spacing:-.03em}.stat .meta{font-size:12.5px;color:var(--muted);margin-top:4px;font-weight:500}.ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center}.ic.pos{background:var(--brand-soft);color:var(--brand-dark)}.ic.neg{background:var(--neg-soft);color:var(--neg)}.ic.brand{background:#eef2ff;color:#4356d6}.ic.warn{background:#fdf3dc;color:var(--warn)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 16px;border-radius:11px;border:1px solid transparent;font-size:14px;font-weight:700;cursor:pointer;transition:filter .15s,background .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-brand{background:var(--brand);color:#04261c}.btn-brand:hover:not(:disabled){background:var(--brand-dark);color:#fff}.btn-ghost{background:var(--surface);border-color:var(--line);color:var(--ink)}.btn-ghost:hover{background:var(--surface-2)}.btn-danger{background:var(--neg-soft);color:var(--neg)}.btn-danger:hover{background:#f9d6ce}.btn-sm{padding:7px 11px;border-radius:9px;font-size:13px}.icon-btn{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:8px;display:grid;place-items:center}.icon-btn:hover{background:var(--surface-2);color:var(--neg)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12.5px;font-weight:600;color:var(--muted)}.input,.select{width:100%;padding:11px 13px;border-radius:11px;border:1px solid var(--line);background:var(--surface);font-size:14.5px;color:var(--ink);font-family:inherit;outline:none;transition:border .15s,box-shadow .15s}.input:focus,.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.row{display:grid;gap:12px}.row-3{grid-template-columns:repeat(3,1fr)}.row-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 640px){.row-3,.row-2{grid-template-columns:1fr}}.seg{display:flex;gap:8px}.seg button{flex:1;padding:11px;border-radius:11px;border:1.5px solid var(--line);background:var(--surface);color:var(--muted);font-weight:700;font-size:14px;cursor:pointer}.seg button.on-pos{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-dark)}.seg button.on-neg{border-color:var(--neg);background:var(--neg-soft);color:var(--neg)}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;padding:12px 24px;border-bottom:1px solid var(--line)}.tbl td{padding:14px 24px;border-bottom:1px solid var(--line);font-size:14px}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--surface-2)}.right{text-align:right}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:700}.badge.pos{background:var(--brand-soft);color:var(--brand-dark)}.badge.neg{background:var(--neg-soft);color:var(--neg)}.badge.gray{background:#eef1f4;color:#5b6675}.chip{display:inline-flex;gap:6px;align-items:center;padding:3px 9px;border-radius:8px;font-size:11.5px;font-weight:700;background:#eef1f4;color:#566}.amt-pos{color:var(--pos);font-weight:700}.amt-neg{color:var(--neg);font-weight:700}.stmt{width:100%;border-collapse:collapse}.stmt td{padding:9px 0;font-size:15px}.stmt .lbl-cell{color:var(--ink)}.stmt .indent{padding-left:20px;color:var(--muted)}.stmt .num{text-align:right;font-weight:600}.stmt .total td{border-top:1px solid var(--line);font-weight:800}.stmt .grand td{border-top:2px solid var(--ink);font-size:18px;font-weight:800;padding-top:14px}.stmt .section td{padding-top:16px;font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}.note-inline{font-size:12px;color:var(--muted);font-weight:500;margin-left:8px}.empty{text-align:center;padding:44px 20px;color:var(--muted)}.empty svg{opacity:.4;margin-bottom:10px}.spacer{height:16px}.hint{font-size:13px;color:var(--muted);line-height:1.6}.muted{color:var(--muted)}.flex{display:flex}.between{justify-content:space-between}.aic{align-items:center}.gap8{gap:8px}.gap12{gap:12px}.checks{display:grid;grid-template-columns:1fr 1fr;gap:10px}.check{display:flex;align-items:center;gap:9px;padding:11px 13px;border:1px solid var(--line);border-radius:11px;cursor:pointer;font-size:14px;font-weight:600;-webkit-user-select:none;user-select:none}.check input{width:17px;height:17px;accent-color:var(--brand)}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:12px 18px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:var(--shadow);z-index:50}.toast.err{background:var(--neg)}.full-loader{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.spin{width:26px;height:26px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:sp .7s linear infinite}@keyframes sp{to{transform:rotate(360deg)}}.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}@media (max-width: 880px){.auth-wrap{grid-template-columns:1fr}.auth-aside{display:none}}.auth-aside{background:radial-gradient(120% 120% at 0% 0%,#14d49a,#0fae7e 35%,#0f1623);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between}.auth-aside h2{font-size:34px;line-height:1.1;max-width:380px}.auth-aside p{color:#ffffffd9;font-size:15px;line-height:1.6;max-width:360px}.auth-form-side{display:grid;place-items:center;padding:32px}.auth-card{width:100%;max-width:380px}.auth-card h1{font-size:26px;margin-bottom:6px}.auth-card .lead{color:var(--muted);font-size:14.5px;margin-bottom:24px}.auth-card .field+.field{margin-top:14px}.auth-switch{font-size:13.5px;color:var(--muted);text-align:center;margin-top:18px}.auth-switch button{background:none;border:none;color:var(--brand-dark);font-weight:700;cursor:pointer;font-size:13.5px}.alert{padding:11px 14px;border-radius:11px;font-size:13.5px;font-weight:600;margin-bottom:14px}.alert.err{background:var(--neg-soft);color:var(--neg)}.alert.ok{background:var(--brand-soft);color:var(--brand-dark)}.no-access{display:grid;place-items:center;padding:80px 20px;text-align:center;color:var(--muted)}.no-access .ic-lg{width:56px;height:56px;border-radius:16px;background:var(--neg-soft);color:var(--neg);display:grid;place-items:center;margin:0 auto 16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e172680;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:40;padding:20px}.modal{width:100%;max-width:440px;background:var(--surface);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}.pw-wrap{position:relative}.pw-toggle{position:absolute;right:7px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;padding:7px;display:grid;place-items:center;border-radius:8px}.pw-toggle:hover{color:var(--ink);background:var(--surface-2)}.icon-btn.edit:hover{color:var(--brand-dark)}.pager{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-top:1px solid var(--line)}.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:14px 20px;border-bottom:1px solid var(--line);background:var(--surface-2)}.toolbar .field{gap:5px}.toolbar .field label{font-size:11px}.toolbar .input,.toolbar .select{padding:8px 10px;font-size:13.5px}.tb-spacer{flex:1;min-width:0}.presets{display:flex;gap:6px;align-self:center}.preset{padding:8px 12px;border-radius:9px;border:1px solid var(--line);background:var(--surface);font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer}.preset:hover{color:var(--ink)}.preset.on{background:var(--brand-soft);border-color:var(--brand);color:var(--brand-dark)}.tx-list{display:flex;flex-direction:column}.tx-row{display:flex;align-items:center;gap:14px;padding:13px 20px;border-bottom:1px solid var(--line);transition:background .12s}.tx-row:last-child{border-bottom:none}.tx-row:hover{background:var(--surface-2)}.tx-ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}.tx-ic.pos{background:var(--brand-soft);color:var(--brand-dark)}.tx-ic.neg{background:var(--neg-soft);color:var(--neg)}.tx-main{flex:1;min-width:0}.tx-cat{font-weight:700;font-size:14.5px}.tx-meta{font-size:12.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-amt{font-weight:800;font-size:15px;white-space:nowrap}.pager2{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:14px 20px;border-top:1px solid var(--line)}.pages{display:flex;gap:5px;align-items:center}.pg-num{min-width:34px;height:34px;padding:0 9px;border-radius:9px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:13.5px;font-weight:700;cursor:pointer;display:grid;place-items:center}.pg-num:hover:not(:disabled):not(.on){background:var(--surface-2)}.pg-num.on{background:var(--brand);border-color:var(--brand);color:#04261c}.pg-num:disabled{opacity:.4;cursor:not-allowed}.pg-dots{color:var(--muted);padding:0 2px}.del-preview{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px}.ratio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 760px){.ratio-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.ratio-grid{grid-template-columns:1fr}}.ratio{padding:14px 16px;border:1px solid var(--line);border-radius:13px;background:var(--surface-2)}.ratio .rt-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.ratio .rt-name{font-size:13px;font-weight:600;color:var(--muted)}.ratio .rt-val{font-size:22px;font-weight:800;letter-spacing:-.02em}.ratio .rt-bar{height:6px;border-radius:99px;background:var(--line);margin-top:10px;overflow:hidden}.ratio .rt-fill{height:100%;border-radius:99px}.ratio .rt-note{font-size:11.5px;color:var(--muted);margin-top:7px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px}.tab{padding:11px 16px;border:none;background:transparent;color:var(--muted);font-size:14.5px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--ink)}.tab.on{color:var(--ink);font-weight:700;border-bottom-color:var(--brand)}.form-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.form-row .field{flex:1}.collapse-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px;background:transparent;border:none;cursor:pointer}.collapse-head:hover{background:var(--surface-2)}.collapse-head h3{font-size:16px}.collapse-head .chev{color:var(--muted);transition:transform .18s}.collapse-head .chev.open{transform:rotate(180deg)}.cash-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 26px;margin-bottom:16px;border-radius:16px;color:#eafff7;background:radial-gradient(140% 140% at 0% 0%,#14d49a,#0fae7e 42%,#0f1623 120%);box-shadow:var(--shadow)}.cash-hero .ch-label{font-size:12.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#fffc}.cash-hero .ch-value{font-size:34px;font-weight:800;letter-spacing:-.03em;margin-top:4px;color:#fff}.cash-hero .ch-break{font-size:13px;margin-top:8px;color:#ffffffd1}.cash-hero .ch-icon{width:56px;height:56px;border-radius:16px;background:#ffffff26;display:grid;place-items:center;flex-shrink:0}@media (max-width: 520px){.cash-hero .ch-value{font-size:27px}.cash-hero .ch-icon{display:none}}.mobile-only{display:none}.tb-left{display:flex;align-items:center;gap:12px;min-width:0}.bottom-nav{display:none}@media (max-width: 860px){.sidebar{display:none}.topbar{padding:0 16px;height:60px}.topbar h1{font-size:17px}.topbar .sub{display:none}.content{padding:16px 14px calc(84px + env(safe-area-inset-bottom))}.mobile-only{display:inline-flex}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:30;background:var(--surface);border-top:1px solid var(--line);padding:6px 6px calc(6px + env(safe-area-inset-bottom));box-shadow:0 -2px 12px #1018280d}.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 4px;border-radius:12px;color:var(--muted);font-size:11px;font-weight:600;text-decoration:none}.bn-item.active{color:var(--brand-dark);background:var(--brand-soft)}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap}.form-row .field{min-width:100%!important}.form-row .btn{width:100%}.card-pad{padding:16px}.card-head{padding:14px 16px}.toolbar,.tx-row{padding:12px 14px}.stmt td{font-size:14px}}@media (max-width: 420px){.cash-hero{padding:18px}.stat .val{font-size:22px}}
