:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f6f8fb;--surface:#fff;--surface-soft:#f8fafc;--text:#0f172a;--muted:#64748b;--line:#e2e8f0;--line-strong:#cbd5e1;--blue:#1664e8;--green:#16a34a;--teal:#0f9f9a;--orange:#f97316;--purple:#7c3aed;--slate:#64748b;--shadow:0 18px 48px #0f172a14;--radius:22px;--font:"Inter", "PingFang SC", "Microsoft YaHei", "Noto Sans SC", system-ui, sans-serif}*{box-sizing:border-box}html{background:var(--bg);-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;min-height:100%}body{min-height:100vh;font-family:var(--font);color:var(--text);background:linear-gradient(135deg,#f8fbff 0%,#eef6ff 52%,#f7fbfa 100%);margin:0}button,input,select,textarea{font:inherit}input,select,textarea{font-size:16px}button,a{touch-action:manipulation}button{cursor:pointer}.app-shell{grid-template-columns:240px minmax(0,1fr);min-height:100vh;display:grid}.side-nav{border-right:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffc7;height:100vh;padding:28px 16px;position:sticky;top:0}.brand{align-items:center;gap:12px;margin:0 4px 28px;display:flex}.brand-icon{color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal));border-radius:13px;place-items:center;width:42px;height:42px;font-size:24px;font-weight:900;display:grid}.brand strong{font-size:18px}.side-nav nav{gap:8px;display:grid}.side-nav button{color:#334155;text-align:left;background:0 0;border:0;border-radius:12px;min-height:46px;padding:0 18px;font-weight:800}.side-nav button.active,.side-nav button:hover{color:var(--blue);background:#eaf2ff}.account-card{border:1px solid var(--line);background:#fff;border-radius:16px;gap:6px;margin-top:16px;padding:12px;display:grid}.account-card span{color:var(--muted);font-size:12px;font-weight:900}.account-card strong{color:var(--text);font-size:15px}.side-nav .account-card button,.logout-btn{color:#dc2626;text-align:center;background:#fff7f7;border:1px solid #fecaca;border-radius:10px;min-height:34px;font-size:13px;font-weight:950}.side-nav .account-card .account-action-btn,.account-top-btn{color:var(--blue);background:#f7fbff;border-color:#bfdbfe}.account-top-btn{border:1px solid #bfdbfe;border-radius:10px;min-height:34px;padding:0 12px;font-size:13px;font-weight:950}.side-feature-box{border:1px solid var(--line);background:#f8fbffeb;border-radius:18px;gap:8px;padding:12px;display:grid;position:absolute;bottom:88px;left:16px;right:16px}.side-feature-title{color:var(--muted);padding:0 4px;font-size:12px;font-weight:950}.side-nav .side-feature-chip{border:1px solid var(--line);color:#334155;background:#fff;border-radius:10px;min-height:34px;padding:0 10px;font-size:13px;font-weight:850}.side-nav .feature-add-btn{color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal));text-align:center;border:0;border-radius:12px;min-height:42px;padding:0 12px;font-weight:950}.side-nav .feature-add-btn:hover{color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal))}.side-nav small{color:var(--muted);line-height:1.5;position:absolute;bottom:28px;left:24px;right:24px}.workspace{gap:24px;width:100%;max-width:1080px;margin:0 auto;padding:28px;display:grid}.topbar{justify-content:space-between;align-items:center;gap:16px;display:flex}.top-actions{align-items:center;gap:10px;display:flex}h1{letter-spacing:-.05em;margin:0;font-size:clamp(30px,4vw,44px);line-height:1.05}.topbar p{color:var(--muted);margin:10px 0 0;font-weight:700}.date-picker{color:var(--muted);grid-template-columns:auto 162px;align-items:center;gap:10px;font-weight:800;display:grid}input,select,textarea{border:1px solid var(--line);width:100%;min-height:42px;color:var(--text);background:#fff;border-radius:12px;outline:none;padding:0 12px}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px #1664e81f}.dashboard-grid{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}.panel{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#ffffffeb}.today-panel,.summary-panel,.ledger-panel{padding:24px}.panel h2{letter-spacing:-.03em;margin:0 0 18px;font-size:23px}.number-row{border-bottom:1px solid var(--line);grid-template-columns:46px 1fr auto;align-items:center;gap:14px;min-height:72px;display:grid}.number-row:last-child{border-bottom:0}.row-icon{color:#fff;border-radius:50%;place-items:center;width:36px;height:36px;font-size:13px;font-weight:950;display:grid}.row-icon.green{background:var(--green)}.row-icon.orange{background:var(--orange)}.row-icon.blue{background:var(--blue)}.row-icon.purple{background:var(--purple)}.row-icon.teal{background:var(--teal)}.row-icon.slate{background:var(--slate)}.row-label{color:#334155;font-size:16px;font-weight:750}.row-value{letter-spacing:-.04em;font-size:clamp(24px,3vw,36px);line-height:1}.green{color:var(--green)}.orange{color:var(--orange)}.blue{color:var(--blue)}.teal{color:var(--teal)}.slate{color:var(--slate)}.purple{color:var(--purple)}.dark{color:var(--text)}.panel-title-line{justify-content:space-between;align-items:center;gap:12px;display:flex}.panel-title-line h2{margin-bottom:0}.panel-title-line span{color:var(--blue);font-weight:900}.period-tabs,.report-tabs{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:20px;display:grid}.period-tabs button,.report-tabs button,.text-btn{border:1px solid var(--line);color:#334155;background:#fff;border-radius:12px;min-height:44px;font-weight:850}.period-tabs button.active{color:#fff;border-color:var(--blue);background:var(--blue)}.report-tabs{margin-top:10px}.report-tabs button.active{color:var(--blue);background:#f3f7ff;border-color:#b7cdfb}.summary-list{margin-top:24px}.summary-row{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:center;min-height:64px;display:flex}.summary-row:last-child{border-bottom:0}.summary-row span{color:#334155;font-size:17px;font-weight:750}.summary-row strong{letter-spacing:-.035em;font-size:24px}.ledger-panel{padding-bottom:18px}.text-btn{min-height:34px;color:var(--blue);background:#f7fbff;padding:0 12px}.ledger-table{border:1px solid var(--line);border-radius:15px;margin-top:20px;overflow-x:auto}.ledger-head,.ledger-row{grid-template-columns:1.35fr .8fr .8fr .8fr 1fr 1fr 1fr;align-items:center;min-width:760px;display:grid}.ledger-head{min-height:48px;color:var(--muted);background:var(--surface-soft);font-size:13px;font-weight:900}.ledger-row{border-top:1px solid var(--line);min-height:64px;font-size:15px}.ledger-head span,.ledger-row span,.ledger-row strong,.ledger-row em{padding:0 16px}.ledger-row strong{color:var(--green);font-size:18px}.ledger-row em{color:var(--teal);font-style:normal;font-weight:850}.empty-row{color:var(--muted);text-align:center;padding:28px}.add-btn,.primary-btn,.feature-action-btn{color:#fff;background:linear-gradient(135deg, var(--blue), #0f9f9a);border:0;border-radius:14px;min-height:56px;font-size:20px;font-weight:950;box-shadow:0 16px 32px #1664e838}.add-btn{justify-self:center;width:min(360px,100%)}.feature-action-btn{width:min(260px,100%);color:var(--blue);background:#fff;border:1px solid #bfdbfe;justify-self:center;font-size:18px;box-shadow:0 12px 24px #1664e81f}.action-row{grid-template-columns:minmax(180px,360px) minmax(160px,260px);justify-content:center;gap:12px;display:grid}.drawer-backdrop{z-index:30;background:#0f172a47;place-items:end center;padding:20px;display:grid;position:fixed;inset:0}.quick-drawer{background:#fff;border-radius:24px;width:min(560px,100%);max-height:88vh;padding:22px;overflow:auto;box-shadow:0 24px 80px #0f172a38}.quick-form{grid-template-columns:1fr 1fr;gap:14px;margin-top:18px;display:grid}.quick-form label{color:#334155;gap:7px;font-size:13px;font-weight:850;display:grid}.quick-form .primary-btn{grid-column:span 2;font-size:16px}.quick-form label.full{grid-column:span 2}textarea{resize:vertical;min-height:96px;padding-top:10px}.toast{z-index:40;color:var(--blue);box-shadow:var(--shadow);background:#fff;border:1px solid #bfdbfe;border-radius:14px;padding:13px 18px;font-weight:900;position:fixed;bottom:22px;right:22px}.login-shell{background:radial-gradient(circle at 20% 16%,#1664e829,#0000 34%),radial-gradient(circle at 82% 72%,#0f9f9a29,#0000 30%),linear-gradient(135deg,#f8fbff 0%,#eef6ff 55%,#f7fbfa 100%);place-items:center;min-height:100vh;padding:22px;display:grid}.login-card{border:1px solid var(--line);background:#ffffffeb;border-radius:28px;width:min(440px,100%);padding:30px;box-shadow:0 24px 70px #0f172a1f}.login-brand{margin:0 0 22px}.login-card h1{font-size:38px}.login-card>p{color:var(--muted);margin:10px 0 22px;font-weight:750;line-height:1.55}.login-form{gap:14px;display:grid}.login-form label{color:#334155;gap:8px;font-size:13px;font-weight:900;display:grid}.login-form input{min-height:50px;font-size:17px;font-weight:800}.login-form .primary-btn{margin-top:2px;font-size:18px}.login-error{color:#b91c1c;background:#fff1f2;border:1px solid #fecaca;border-radius:12px;padding:11px 12px;font-weight:850}.login-accounts{background:#f8fbff;border:1px dashed #bfdbfe;border-radius:16px;grid-template-columns:1fr;gap:8px;margin-top:20px;padding:14px;display:grid}.login-accounts span{color:var(--muted);font-size:13px;font-weight:900}.login-accounts strong{color:var(--blue)}.loading-card{text-align:center}@media (width<=960px){.app-shell{grid-template-columns:1fr}.side-nav{display:none}.workspace{gap:14px;max-width:640px;padding:18px 14px 28px}.topbar{align-items:flex-start}.top-actions{grid-template-columns:1fr;justify-items:end;display:grid}.logout-btn{min-height:34px;padding:0 12px}h1{font-size:26px}.topbar p{margin-top:6px;font-size:13px}.date-picker{grid-template-columns:1fr;gap:6px;width:142px;font-size:12px}.date-picker input{min-height:38px;font-size:16px}.dashboard-grid{grid-template-columns:1fr;gap:14px}.today-panel,.summary-panel,.ledger-panel{border-radius:18px;padding:16px}.panel h2{font-size:20px}.number-row{grid-template-columns:38px 1fr auto;gap:10px;min-height:58px}.row-icon{width:30px;height:30px;font-size:11px}.row-label{font-size:14px}.row-value{font-size:23px}.period-tabs button,.report-tabs button{min-height:38px;font-size:13px}.summary-row{min-height:48px}.summary-row span{font-size:15px}.summary-row strong{font-size:20px}.ledger-head,.ledger-row{grid-template-columns:1.2fr .8fr .8fr .8fr 1fr 1fr 1fr;min-width:680px}.ledger-row{min-height:52px;font-size:12px}.ledger-head{font-size:11px}.ledger-head span,.ledger-row span,.ledger-row strong,.ledger-row em{padding:0 10px}.add-btn{min-height:48px;font-size:17px}.feature-action-btn{min-height:48px;font-size:16px}.action-row{grid-template-columns:1fr 1fr}.quick-form{grid-template-columns:1fr}.quick-form .primary-btn,.quick-form label.full{grid-column:span 1}.drawer-backdrop{padding:10px}}@supports (-webkit-touch-callout:none){input,select,textarea{font-size:16px!important}}html,body,#root{max-width:100%;overflow-x:hidden}.workspace,.panel,.topbar,.dashboard-grid,.topbar>div{min-width:0}.topbar p{overflow-wrap:anywhere}.ledger-panel{min-width:0;overflow:hidden}.ledger-table{-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain;max-width:100%}@media (width<=960px){input,select,textarea{line-height:1.25;font-size:16px!important}.topbar{width:100%}.topbar p{max-width:210px}}.system-status,.filters-line{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.system-status{border:1px solid var(--line);color:var(--muted);background:#ffffffc7;border-radius:16px;padding:12px 14px;font-size:14px;font-weight:800}.system-status .ok,.system-status .bad{border-radius:999px;align-items:center;min-height:28px;padding:0 10px;display:inline-flex}.system-status .ok{color:#15803d;background:#dcfce7}.system-status .bad{color:#b91c1c;background:#fee2e2}.system-status button{border:1px solid var(--line);min-height:32px;color:var(--blue);background:#fff;border-radius:10px;margin-left:auto;padding:0 12px;font-weight:900}.filters-line input{max-width:260px}.filters-line select{max-width:160px}.error-box{color:#991b1b;background:#fff1f2;border:1px solid #fecaca;border-radius:14px;padding:14px 16px;font-weight:800}.smart-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.feature-panel,.permission-panel{padding:24px}.feature-panel .panel-title-line,.permission-title-line{align-items:flex-start}.feature-panel p,.permission-title-line p{color:var(--muted);margin:8px 0 0;font-size:14px;line-height:1.55}.permission-create-form{background:#f8fbff;border:1px solid #bfdbfe;border-radius:18px;grid-template-columns:1fr 1fr 1fr 160px auto;gap:10px;margin-top:18px;padding:14px;display:grid}.permission-create-form label,.managed-user-row label{color:#334155;gap:7px;font-size:12px;font-weight:950;display:grid}.permission-create-form .primary-btn{white-space:nowrap;align-self:end;min-height:42px;padding:0 16px;font-size:15px}.permission-user-list{gap:10px;margin-top:14px;display:grid}.managed-user-row{border:1px solid var(--line);background:#fff;border-radius:18px;grid-template-columns:1.05fr 1.1fr 130px 120px 1fr auto;align-items:end;gap:10px;padding:14px;display:grid}.managed-user-row.disabled{background:#fff7f7;border-color:#fecaca}.managed-user-main{justify-content:space-between;align-self:stretch;align-items:center;gap:8px;min-height:42px;display:flex}.managed-user-main strong{font-size:18px;display:block}.managed-user-main span{color:var(--muted);margin-top:4px;font-size:12px;font-weight:900;display:block}.managed-user-main b{color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal));border-radius:999px;padding:5px 9px;font-size:12px}.managed-user-row button{min-height:42px;color:var(--blue);background:#f7fbff;border:1px solid #bfdbfe;border-radius:12px;padding:0 14px;font-weight:950}.managed-user-row select:disabled{color:var(--muted);background:#f1f5f9}.feature-list{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:18px;display:grid}.feature-card{border:1px solid var(--line);background:#fff;border-radius:16px;min-height:120px;padding:15px}.feature-card div{justify-content:space-between;align-items:center;gap:10px;display:flex}.feature-card strong{font-size:17px}.feature-card span{color:var(--blue);background:#eff6ff;border-radius:999px;flex:none;padding:4px 8px;font-size:12px;font-weight:950}.feature-suggestions{border-top:1px dashed var(--line);gap:10px;margin-top:18px;padding-top:16px;display:grid}.feature-suggestions>strong{color:#334155;font-size:14px}.feature-suggestions button{min-height:52px;color:var(--blue);text-align:left;background:#f8fbff;border:1px solid #bfdbfe;border-radius:14px;padding:10px 12px;font-weight:950}.feature-suggestions span{color:var(--muted);margin-top:4px;font-size:13px;font-weight:700;line-height:1.45;display:block}.insight-list,.report-cards{gap:10px;margin-top:18px;display:grid}.insight,.report-cards article{border:1px solid var(--line);background:var(--surface-soft);border-radius:14px;padding:14px}.insight strong,.report-cards strong{color:var(--text);margin-bottom:6px;display:block}.insight p,.report-cards p{color:var(--muted);margin:0;font-size:14px;line-height:1.55}.insight.good{background:#f0fdf4;border-color:#bbf7d0}.insight.watch{background:#fff7ed;border-color:#fed7aa}.insight.warning{background:#fff1f2;border-color:#fecaca}.insight.info{background:#eff6ff;border-color:#bfdbfe}.report-table-panel{padding:24px}.report-table-title-line{align-items:flex-start}.report-table-title-line p{color:var(--muted);margin:8px 0 0;font-size:14px;font-weight:750;line-height:1.55}.report-table-grid{grid-template-columns:1fr;gap:14px;margin-top:18px;display:grid}.report-table-card{border:1px solid var(--line);background:#fff;border-radius:18px;padding:16px}.report-card-title{justify-content:space-between;align-items:center;gap:12px;display:flex}.report-card-title strong{font-size:20px}.report-card-title span{color:var(--muted);font-weight:850}.report-mini-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px;display:grid}.report-mini-stats span{background:var(--surface-soft);min-height:58px;color:var(--muted);border-radius:14px;padding:10px 12px;font-weight:900}.report-mini-stats b{margin-top:5px;font-size:20px;display:block}.expense-category-summary{border-top:1px dashed var(--line);flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}.expense-category-summary b{color:#334155;font-size:13px}.expense-category-summary span{color:#c2410c;background:#fff7ed;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:950}.report-mini-table{border:1px solid var(--line);border-radius:14px;margin-top:12px;overflow-x:auto}.report-mini-head,.report-mini-row{grid-template-columns:.8fr 1.25fr .8fr .9fr .75fr .75fr;align-items:center;min-width:760px;display:grid}.report-mini-head{min-height:42px;color:var(--muted);background:var(--surface-soft);padding:0 10px;font-size:12px;font-weight:950}.report-mini-row{border:0;border-top:1px solid var(--line);text-align:left;background:#fff;width:100%;min-height:50px;padding:0 10px}.report-mini-row span,.report-mini-row strong,.report-mini-row em,.report-mini-row b{padding:0 6px;font-size:13px;font-style:normal}.report-mini-row strong{color:var(--green)}.report-mini-row em{color:var(--orange);font-weight:900}.report-mini-row b{color:var(--blue)}.report-more{border-top:1px solid var(--line);color:var(--muted);text-align:center;padding:12px;font-size:13px;font-weight:850}.ledger-head,.ledger-row{grid-template-columns:1.35fr .8fr .8fr .8fr 1fr .8fr .9fr .7fr .9fr 1.05fr;min-width:1080px}.row-actions{gap:6px;display:flex}.row-actions button{border:1px solid var(--line);min-height:30px;color:var(--blue);background:#fff;border-radius:9px;padding:0 8px;font-size:12px;font-weight:900}.row-actions button:last-child{color:#dc2626}.detail-panel{padding:24px}.detail-title-line{align-items:flex-start}.detail-title-line p,.detail-drawer .panel-title-line p,.password-drawer .panel-title-line p{color:var(--muted);margin:7px 0 0;font-size:14px;font-weight:750;line-height:1.5}.detail-period-tabs{margin-top:18px}.detail-summary{grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px;display:grid}.detail-summary div{border:1px solid var(--line);background:#fff;border-radius:16px;min-height:82px;padding:14px}.detail-summary span{color:var(--muted);font-size:13px;font-weight:900;display:block}.detail-summary strong{letter-spacing:-.04em;margin-top:8px;font-size:clamp(22px,3vw,30px);display:block}.detail-list{gap:12px;margin-top:16px;display:grid}.detail-card{border:1px solid var(--line);background:#fff;border-radius:18px;padding:16px}.detail-card-head{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.detail-card-head strong{font-size:18px;display:block}.detail-card-head span{color:var(--muted);margin-top:4px;font-size:13px;font-weight:800;display:block}.detail-card-head b{letter-spacing:-.04em;font-size:24px}.detail-metrics,.detail-info-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px;display:grid}.detail-info-grid{grid-template-columns:repeat(3,1fr)}.detail-metrics span,.detail-info-grid span{min-height:42px;color:var(--muted);background:var(--surface-soft);border-radius:12px;padding:9px 10px;font-size:13px;font-weight:800}.detail-metrics b,.detail-info-grid b{color:var(--text);font-weight:950}.detail-actions,.drawer-actions{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.detail-actions button,.danger-btn{border:1px solid var(--line);min-height:36px;color:var(--blue);background:#fff;border-radius:11px;padding:0 12px;font-weight:950}.detail-actions button:last-child,.danger-btn{color:#dc2626;background:#fff7f7;border-color:#fecaca}.detail-drawer-total{color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal));border-radius:18px;justify-content:space-between;align-items:center;margin-top:18px;padding:16px;display:flex}.detail-drawer-total span{font-weight:900}.detail-drawer-total strong{letter-spacing:-.04em;font-size:32px}.detail-drawer-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;display:grid}.detail-drawer-grid div{border:1px solid var(--line);background:var(--surface-soft);border-radius:14px;min-height:64px;padding:11px 12px}.detail-drawer-grid span{color:var(--muted);font-size:12px;font-weight:900;display:block}.detail-drawer-grid strong{color:var(--text);margin-top:5px;line-height:1.35;display:block}.drawer-actions .primary-btn{flex:180px;min-height:48px;font-size:16px}.drawer-actions .danger-btn{flex:120px;min-height:48px}.password-form .primary-btn:disabled{opacity:.68;cursor:not-allowed}@media (width<=960px){.smart-grid{grid-template-columns:1fr;gap:14px}.feature-panel,.permission-panel,.detail-panel,.report-table-panel{border-radius:18px;padding:16px}.feature-panel .panel-title-line,.permission-title-line,.report-table-title-line{display:grid}.feature-list,.permission-create-form{grid-template-columns:1fr}.managed-user-row{grid-template-columns:1fr;align-items:stretch}.managed-user-row button{width:100%}.filters-line{grid-template-columns:1fr 140px 140px;display:grid}.filters-line input,.filters-line select{max-width:none}.system-status button{margin-left:0}.report-mini-stats{grid-template-columns:1fr}.ledger-head,.ledger-row{grid-template-columns:1.2fr .8fr .8fr .8fr 1fr .85fr .9fr .75fr .9fr 1.1fr;min-width:1040px}.detail-title-line{display:grid}.detail-summary,.detail-metrics{grid-template-columns:1fr 1fr}.detail-info-grid,.detail-drawer-grid{grid-template-columns:1fr}}@media (width<=420px){.filters-line,.action-row{grid-template-columns:1fr}.feature-action-btn{width:100%}}
