:root{--bg:#f6f7f3;--surface:#fff;--surface-soft:#eef2ec;--text:#19201d;--muted:#68746d;--line:#dfe5dc;--green:#1f7a4d;--green-dark:#145c3a;--coral:#c6533c;--gold:#a77720;--blue:#256f91;--shadow:0 16px 42px #21292314;--radius:8px;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Microsoft YaHei,PingFang SC,Noto Sans SC,system-ui,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;color:var(--text);background:var(--bg);margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}h1,h2,h3,p{margin:0}svg{display:block}.app-shell{width:min(1400px,100%);margin:0 auto;padding:24px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.topbar h1{letter-spacing:0;font-size:clamp(26px,4vw,40px);line-height:1.15}.eyebrow{color:var(--green);letter-spacing:0;margin-bottom:6px;font-size:13px;font-weight:700}.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.summary-mobile{display:none}.project-nav{scrollbar-width:thin;gap:10px;margin-bottom:4px;padding:2px 0 14px;display:flex;overflow-x:auto}.project-nav-button{border:1px solid var(--line);background:var(--surface);color:var(--text);text-align:left;border-radius:8px;align-items:center;gap:10px;min-width:180px;min-height:58px;padding:10px 12px;display:inline-flex;box-shadow:0 8px 22px #2129230d}.project-nav-button .nav-icon{background:var(--surface-soft);width:36px;height:36px;color:var(--green);border-radius:8px;flex:none;place-items:center;display:grid}.project-nav-button strong,.project-nav-button small{letter-spacing:0;display:block}.project-nav-button strong{font-size:15px;line-height:1.2}.project-nav-button small{color:var(--muted);margin-top:4px;font-size:12px}.project-nav-button.active{border-color:var(--green);background:#edf6ef;box-shadow:0 0 0 3px #1f7a4d1f}.project-nav-button.active .nav-icon{color:#fff;background:var(--green)}.metric,.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.metric{align-items:flex-start;gap:14px;min-height:118px;padding:18px;display:flex}.metric-icon{background:var(--surface-soft);width:40px;height:40px;color:var(--green);border-radius:8px;flex:none;place-items:center;display:grid}.metric span,.metric small{color:var(--muted);font-size:13px;display:block}.metric strong{letter-spacing:0;margin:6px 0;font-size:clamp(20px,2vw,29px);line-height:1.15;display:block}.workspace-grid,.dashboard-grid{grid-template-columns:minmax(0,1.35fr) minmax(360px,.65fr);gap:16px;margin-bottom:16px;display:grid}.panel{padding:18px}.panel-heading{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.panel-heading h2{letter-spacing:0;font-size:21px;line-height:1.2}.entry-form,.project-form,.person-form{gap:14px;display:grid}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.field{gap:7px;display:grid}.field span{color:var(--muted);font-size:13px;font-weight:650}.field input,.field select,.field textarea{border:1px solid var(--line);width:100%;color:var(--text);background:#fff;border-radius:7px;outline:none;min-height:42px;padding:9px 11px}.field textarea{resize:vertical;min-height:78px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px #1f7a4d1f}.extra-fields{border:1px solid var(--line);background:#fff;border-radius:8px}.extra-fields summary{min-height:42px;color:var(--text);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-weight:800;list-style:none;display:flex}.extra-fields summary::-webkit-details-marker{display:none}.extra-fields summary:after{content:"+";color:var(--green);font-size:18px;line-height:1}.extra-fields[open] summary:after{content:"-"}.extra-fields summary small{color:var(--muted);margin-left:auto;font-size:12px;font-weight:600}.form-grid-extra{padding:0 12px 12px}.segmented{flex-wrap:wrap;gap:8px;display:flex}.segmented button{border:1px solid var(--line);min-height:40px;color:var(--muted);background:#fff;border-radius:7px;align-items:center;gap:7px;padding:8px 12px;font-weight:700;display:inline-flex}.segmented button.active{color:#fff;background:var(--green);border-color:var(--green)}.primary-button,.secondary-button,.ghost-button,.icon-button{border:0;border-radius:7px;justify-content:center;align-items:center;gap:8px;min-height:40px;display:inline-flex}.primary-button,.secondary-button{padding:10px 15px;font-weight:800}.primary-button{color:#fff;background:var(--green)}.primary-button:hover{background:var(--green-dark)}.secondary-button{color:#fff;background:var(--blue)}.ghost-button,.icon-button{color:var(--muted);background:var(--surface-soft)}.ghost-button{padding:8px 12px}.icon-button{flex:none;width:40px;height:40px}.fab-button,.mobile-tabbar{display:none}.filter-stack{gap:12px;display:grid}.search-field div{position:relative}.search-field svg{color:var(--muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-field input{padding-left:38px}.mini-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.mini-stats div,.project-metrics div{background:var(--surface-soft);border-radius:7px;padding:10px}.mini-stats span,.project-metrics span{color:var(--muted);margin-bottom:5px;font-size:12px;display:block}.mini-stats strong,.project-metrics strong{word-break:break-word;font-size:16px;line-height:1.2}.project-panel{min-width:0}.project-list{gap:12px;display:grid}.project-card{border:1px solid var(--line);border-radius:8px;padding:14px}.project-title{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.project-title h3{letter-spacing:0;font-size:18px}.project-title span{color:var(--green);background:#1f7a4d1a;border-radius:6px;margin-top:6px;padding:3px 8px;font-size:12px;font-weight:750;display:inline-flex}.project-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.category-bars{gap:14px;display:grid}.bar-label{justify-content:space-between;align-items:center;gap:12px;margin-bottom:7px;font-size:14px;display:flex}.bar-label strong{color:var(--muted);white-space:nowrap;font-size:13px}.bar-track{background:var(--surface-soft);border-radius:99px;height:9px;overflow:hidden}.bar-track div{border-radius:inherit;background:var(--gold);height:100%}.entry-list{gap:10px;display:grid}.entry-row{border:1px solid var(--line);border-radius:8px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:14px;padding:12px;display:grid}.entry-main{align-items:flex-start;gap:12px;min-width:0;display:flex}.entry-icon{border-radius:8px;flex:none;place-items:center;width:38px;height:38px;display:grid}.entry-icon.income{color:var(--green);background:#1f7a4d1f}.entry-icon.expense{color:var(--coral);background:#c6533c1f}.entry-title{flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:5px;display:flex}.entry-title strong{font-size:16px}.entry-title span{color:var(--muted);background:var(--surface-soft);border-radius:6px;padding:2px 7px;font-size:12px}.entry-main p,.entry-main small{color:var(--muted);font-size:13px}.entry-main small{margin-top:5px;display:block}.entry-amount{text-align:right;gap:4px;display:grid}.entry-amount strong{white-space:nowrap;font-size:17px}.entry-amount strong.income{color:var(--green)}.entry-amount strong.expense{color:var(--coral)}.entry-amount span{color:var(--muted);font-size:12px}.entry-actions{gap:6px;display:flex}.alert{color:#9d3c25;background:#fff5ef;border:1px solid #f2c5b7;border-radius:8px;margin-bottom:16px;padding:12px 14px}.empty-text{color:var(--muted);padding:12px 0}.loading-screen{text-align:center;place-content:center;justify-items:center;gap:14px;min-height:100vh;padding:24px;display:grid}.auth-screen{place-items:center;min-height:100vh;padding:24px;display:grid}.auth-form{background:var(--surface);border:1px solid var(--line);width:min(420px,100%);box-shadow:var(--shadow);border-radius:8px;gap:16px;padding:24px;display:grid}.auth-form h1{letter-spacing:0;font-size:28px;line-height:1.2}.auth-form p:not(.eyebrow){color:var(--muted)}.loading-screen h1{letter-spacing:0;font-size:26px}.loader{color:var(--green);animation:1.1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1100px){.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.workspace-grid,.dashboard-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=680px){.app-shell{padding:10px 10px calc(74px + env(safe-area-inset-bottom))}.topbar{z-index:20;padding:calc(8px + env(safe-area-inset-top)) 10px 8px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f6f7f3f0;border-bottom:1px solid #dfe5dcd1;align-items:center;gap:10px;margin:-10px -10px 8px;position:sticky;top:0}.topbar h1{font-size:18px}.eyebrow{display:none}#refresh-button{width:36px;height:36px}.project-nav{scroll-snap-type:x mandatory;gap:7px;margin:0 -10px 6px;padding:0 10px 8px;scroll-padding:10px}.project-nav-button{min-width:104px;min-height:36px;box-shadow:none;scroll-snap-align:start;gap:0;padding:7px 10px}.project-nav-button .nav-icon{display:none}.project-nav-button strong{font-size:13px}.project-nav-button small{display:none}.workspace-grid{flex-direction:column;display:flex}[data-mobile-section]{display:none}[data-mobile-view=entry] [data-mobile-section=entry],[data-mobile-view=stats] [data-mobile-section=stats],[data-mobile-view=entries] [data-mobile-section=entries],[data-mobile-view=projects] [data-mobile-section=projects]{display:grid}[data-mobile-view=entry] .entry-panel,[data-mobile-view=stats] .summary-grid.summary-mobile{display:flex}[data-mobile-view=entry] .entry-panel,[data-mobile-view=stats] .dashboard-grid,[data-mobile-view=stats] .compact-panel,[data-mobile-view=entries] .entries-panel,[data-mobile-view=projects] .project-settings-panel{display:block}[data-mobile-view=entry] .project-nav,[data-mobile-view=stats] .project-nav,[data-mobile-view=entries] .project-nav,[data-mobile-view=projects] .project-nav{display:flex}.entry-panel{order:1}.metrics-strip{order:2}.compact-panel{order:3}.summary-grid{scroll-snap-type:x mandatory;gap:8px;margin:0 -10px 10px;padding:0 10px 2px;scroll-padding:10px;display:flex;overflow-x:auto}.summary-grid.summary-desktop,.summary-grid.summary-mobile{display:none}.metric{min-height:64px;box-shadow:none;scroll-snap-align:start;flex:0 0 148px;gap:7px;padding:9px 10px}.metric-icon{display:none}.metric span,.metric small{font-size:10px}.metric strong{overflow-wrap:anywhere;margin:2px 0;font-size:18px}.metric small{-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.25;display:-webkit-box;overflow:hidden}.workspace-grid,.dashboard-grid{gap:10px;margin-bottom:10px}.panel{box-shadow:none;padding:10px}.panel-heading{align-items:center;margin-bottom:8px}.entry-panel:not(.is-editing) .panel-heading{display:none}.panel-heading h2{font-size:16px}.entry-form,.project-form,.person-form{gap:10px}.settings-person-form{margin-bottom:18px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.form-grid-primary{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid-primary .field-amount,.field-project-name,.form-grid:not(.form-grid-primary) .field-projectId,.form-grid:not(.form-grid-primary) .field-category,.form-grid-extra .field-vendor,.form-grid-extra .field-platform,.form-grid-extra .field-paymentMethod,.form-grid-extra .field-date{grid-column:1/-1}.field span{font-size:12px}.field input,.field select,.field textarea{min-height:44px;padding:10px 11px;font-size:16px}.field textarea{min-height:48px}.note-field textarea{min-height:46px}.extra-fields summary{min-height:40px;padding:9px 10px}.extra-fields summary small{display:none}.form-grid-extra{padding:0 10px 10px}.segmented{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;display:grid}.segmented[data-segmented=direction]{grid-template-columns:repeat(2,minmax(0,1fr))}.segmented button{justify-content:center;min-height:40px;padding:8px 6px}.primary-button,.secondary-button{width:100%;min-height:48px}.filter-stack{gap:10px}.mini-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}.mini-stats div,.project-metrics div{padding:9px 8px}.mini-stats span,.project-metrics span{margin-bottom:4px;font-size:11px}.mini-stats strong,.project-metrics strong{font-size:14px}.project-list,.entry-list{gap:10px}.project-card{padding:12px}.project-title{margin-bottom:10px}.project-title h3{font-size:17px}.project-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.category-bars{gap:12px}.bar-label{font-size:13px}.entry-row{grid-template-columns:1fr;gap:10px;padding:12px}.entry-main{gap:10px}.entry-icon{width:34px;height:34px}.entry-title{gap:5px}.entry-title strong{width:100%;font-size:16px}.entry-title span{padding:2px 6px;font-size:11px}.entry-main p,.entry-main small{font-size:12px;line-height:1.45}.entry-amount{border-top:1px solid var(--line);text-align:left;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:6px 10px;padding-top:10px;display:flex}.entry-amount strong{font-size:18px}.entry-actions{justify-content:space-between}.entry-actions .icon-button{width:46px;height:40px}.fab-button{right:14px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:30;color:#fff;background:var(--green);opacity:0;pointer-events:none;border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:0 16px;font-weight:800;transition:opacity .16s,transform .16s;display:inline-flex;position:fixed;transform:translateY(18px);box-shadow:0 12px 28px #1f7a4d47}.fab-button.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-tabbar{z-index:32;padding:7px 10px calc(7px + env(safe-area-inset-bottom));border-top:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;display:grid;position:fixed;bottom:0;left:0;right:0}.mobile-tab-button{min-height:48px;color:var(--muted);background:0 0;border:0;border-radius:8px;align-content:center;place-items:center;gap:3px;font-size:12px;font-weight:800;display:grid}.mobile-tab-button.active{color:var(--green);background:#1f7a4d1a}#entry-form,#project-settings{scroll-margin-top:72px}}@media (width<=390px){.metric{flex-basis:136px;padding:9px}.mini-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
