:root{--ink:#15211d;--muted:#718078;--line:#e4e9e5;--paper:#ffffff;--canvas:#f5f7f4;--green:#1f6b50;--green-dark:#17513e;--green-soft:#e7f2ec;--orange:#f97316;--shadow:0 18px 42px rgba(27,49,40,0.08)}*{box-sizing:border-box}body,html{margin:0;min-height:100%;background:var(--canvas);color:var(--ink);font-family:Inter,SF Pro Display,PingFang SC,Microsoft YaHei,Arial,sans-serif}button,input,select,textarea{font:inherit}a,button{-webkit-tap-highlight-color:transparent}button{cursor:pointer}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;z-index:5;display:flex;width:246px;flex-direction:column;padding:22px 14px;background:#123f32;color:#fff}.brand,.mobile-brand{display:flex;align-items:center;gap:11px}.brand{padding:0 8px 27px;border-bottom:1px solid rgba(255,255,255,.11)}.brand strong,.mobile-brand strong{display:block;font-size:16px;letter-spacing:.04em}.brand span{display:block;margin-top:4px;color:rgba(255,255,255,.53);font-size:9px;letter-spacing:.18em}.brand-mark{display:grid;width:37px;height:37px;flex:0 0 auto;place-items:center;border-radius:12px;background:#f3b661;color:#173e33;font-family:Georgia,serif;font-size:20px;font-weight:800}.brand-mark.large{width:52px;height:52px;margin:auto;border-radius:16px;font-size:27px}.brand-mark.small{width:32px;height:32px;border-radius:10px;font-size:17px}.sidebar-title{display:flex;align-items:center;justify-content:space-between;padding:24px 8px 9px;color:rgba(255,255,255,.48);font-size:11px;font-weight:700;letter-spacing:.14em}.project-nav{display:flex;flex-direction:column;gap:3px}.project-nav-item{display:flex;width:100%;align-items:center;gap:10px;border:0;border-radius:11px;background:transparent;color:rgba(255,255,255,.72);padding:11px 8px;text-align:left;transition:.16s ease}.project-nav-item:hover{background:rgba(255,255,255,.07)}.project-nav-item.active{background:rgba(255,255,255,.13);color:#fff}.project-nav-item small,.project-nav-item strong{display:block}.project-nav-item strong{max-width:160px;overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.project-nav-item small{margin-top:4px;color:rgba(255,255,255,.43);font-size:11px}.folder-icon{display:grid;width:30px;height:30px;flex:0 0 auto;place-items:center;border-radius:9px;background:rgba(243,182,97,.14);color:#f3b661}.sidebar-bottom{display:flex;align-items:center;gap:8px;margin-top:auto;padding:14px 9px 2px;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.54);font-size:11px}.status-dot{width:7px;height:7px;border-radius:50%;background:#6ee7a4;box-shadow:0 0 0 4px rgba(110,231,164,.12)}.main-content{min-width:0;flex:1 1;margin-left:246px}.topbar{display:flex;height:66px;align-items:center;justify-content:space-between;padding:0 34px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.84);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar p{margin:0;color:var(--muted);font-size:13px}.topbar-actions{display:flex;align-items:center;gap:8px}.mobile-brand{display:none}.workspace{max-width:1440px;margin:auto;padding:32px 34px 48px}.project-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:25px}.eyebrow{margin:0 0 7px;color:var(--green);font-size:10px;font-weight:800;letter-spacing:.16em}h1,h2,h3,p{margin-top:0}.project-heading h1{margin:0;font-size:clamp(26px,3vw,35px);letter-spacing:-.04em}.project-heading p:last-child{margin:8px 0 0;color:var(--muted);font-size:13px}.footer-actions,.heading-actions,.modal-footer{display:flex;gap:9px}.ai-button,.ghost-button,.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:9px;padding:10px 14px;font-size:13px;font-weight:700;line-height:1;text-decoration:none;transition:.16s ease}.primary-button{border:1px solid var(--green);background:var(--green);color:#fff;box-shadow:0 6px 14px rgba(31,107,80,.16)}.primary-button:hover{border-color:var(--green-dark);background:var(--green-dark)}.ai-button:disabled,.primary-button:disabled{cursor:not-allowed;opacity:.55}.secondary-button{border:1px solid var(--line);background:#fff;color:#516057}.ghost-button:hover,.secondary-button:hover{border-color:#cad4cf;background:#f8faf8}.ghost-button{border:1px solid transparent;background:transparent;color:var(--muted)}.full{width:100%}.icon-button{display:inline-grid;width:34px;height:34px;flex:0 0 auto;place-items:center;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--muted);transition:.16s ease}.sidebar .icon-button{border-color:rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:rgba(255,255,255,.8)}.icon-button.small{width:30px;height:30px}.icon-button:hover{border-color:#cdd8d2;color:var(--green)}.icon-button.danger:hover{border-color:#fecaca;background:#fff6f6;color:#ef4444}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px;margin-bottom:14px}.stat-card{position:relative;overflow:hidden;padding:19px;border:1px solid var(--line);border-radius:14px;background:var(--paper)}.stat-card.primary{border-color:#286f58;background:linear-gradient(135deg,#1f6b50,#245f4c);color:#fff}.stat-card small,.stat-card span,.stat-card strong{display:block}.stat-card span{margin-bottom:11px;color:var(--muted);font-size:12px}.stat-card.primary small,.stat-card.primary span{color:rgba(255,255,255,.62)}.stat-card strong{margin-bottom:9px;font-size:clamp(19px,2vw,25px);letter-spacing:-.05em}.stat-card small{color:var(--muted);font-size:11px}.stat-icon{position:absolute;top:18px;right:17px;display:grid;width:38px;height:38px;place-items:center;border-radius:11px;background:rgba(255,255,255,.15);color:rgba(255,255,255,.92)}.stat-icon.blue{background:#e9f6fb;color:#0ea5e9}.stat-icon.green{background:#e9f8ef;color:#22a05a}.panel{border:1px solid var(--line);border-radius:14px;background:var(--paper)}.budget-panel{margin-bottom:14px;padding:16px 18px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:18px 19px 0}.panel-heading.compact{padding:0 0 13px}.panel-heading h2{margin:0;font-size:16px;letter-spacing:-.02em}.panel-heading p:last-child,.panel-heading.compact p{margin:4px 0 0;color:var(--muted);font-size:11px}.panel-heading.compact strong{color:var(--green);font-size:12px}.panel-actions{display:flex;flex-wrap:wrap;gap:9px;justify-content:flex-end}.budget-track{overflow:hidden;height:8px;border-radius:999px;background:#e9eeeb}.budget-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#2e8062,#54ad82);transition:width .5s ease}.budget-fill.over{background:linear-gradient(90deg,#f97316,#fb923c)}.overview-grid{display:grid;grid-template-columns:minmax(0,1.34fr) minmax(315px,.66fr);grid-gap:14px;gap:14px;margin-bottom:14px}.category-panel,.quick-panel{min-height:261px}.soft-badge{border-radius:99px;background:var(--green-soft);color:var(--green);padding:5px 9px;font-size:10px;font-weight:700}.category-layout{display:flex;align-items:center;gap:16px;padding:4px 18px 16px}.category-chart{width:185px;height:185px;flex:0 0 auto}.category-legend{display:flex;min-width:0;flex:1 1;flex-direction:column;gap:12px}.legend-item{display:grid;grid-template-columns:8px 1fr auto;align-items:center;grid-gap:8px;gap:8px;color:var(--muted);font-size:12px}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-item strong{color:var(--ink);font-size:12px}.quick-panel{padding-bottom:18px}.quick-upload{display:flex;width:calc(100% - 36px);align-items:center;gap:11px;margin:14px 18px 0;border:1px solid #dbe8e1;border-radius:11px;background:#f6fbf8;padding:13px 11px;color:var(--ink);text-align:left;transition:.16s ease}.quick-upload:hover{border-color:#b7d5c8;background:#eff8f3}.quick-upload.muted{border-color:var(--line);background:#fafbfa}.quick-upload>svg{margin-left:auto;color:var(--muted)}.quick-upload small,.quick-upload strong{display:block}.quick-upload strong{margin-bottom:4px;font-size:12px}.quick-upload small{color:var(--muted);font-size:10px}.quick-icon{display:grid;width:36px;height:36px;flex:0 0 auto;place-items:center;border-radius:10px;background:var(--green-soft);color:var(--green)}.detail-panel{overflow:hidden}.detail-panel .panel-heading{padding-bottom:17px;border-bottom:1px solid var(--line)}.expense-list{padding:0 19px}.expense-row{display:grid;grid-template-columns:39px minmax(0,1fr) auto auto;align-items:center;grid-gap:14px;gap:14px;padding:15px 0;border-bottom:1px solid #edf0ee}.expense-row:last-child{border-bottom:0}.expense-date{display:grid;height:39px;place-items:center;align-content:center;border-radius:9px;background:#f4f6f4}.expense-date strong{font-size:14px;line-height:1}.expense-date span{margin-top:3px;color:var(--muted);font-size:9px}.expense-main{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:10px}.expense-main span,.expense-main strong{display:block}.expense-main strong{font-size:13px}.expense-main div>span,.expense-main strong{overflow:hidden;max-width:420px;text-overflow:ellipsis;white-space:nowrap}.expense-main div>span{margin-top:5px;color:var(--muted);font-size:11px}.category-pill{display:inline-flex!important;flex:0 0 auto;align-items:center;gap:5px;border-radius:99px;background:#f5f7f5;padding:5px 8px;color:var(--muted);font-size:10px}.category-pill i{width:6px;height:6px;border-radius:50%}.expense-amount{min-width:104px;color:var(--ink);font-size:14px;text-align:right}.expense-actions{display:flex;gap:5px}.empty-detail,.empty-mini,.empty-project{display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--muted);text-align:center}.empty-mini{min-height:182px;gap:8px;font-size:12px}.empty-detail{min-height:252px;padding:25px}.empty-detail span,.empty-project-art{display:grid;width:58px;height:58px;place-items:center;border-radius:18px;background:var(--green-soft);color:var(--green)}.empty-detail h3{margin:13px 0 6px;color:var(--ink);font-size:16px}.empty-detail p{margin-bottom:16px;font-size:12px}.empty-project{min-height:calc(100vh - 66px);padding:35px}.empty-project-art{width:82px;height:82px;margin-bottom:18px;border-radius:25px}.empty-project h1{margin:1px 0 9px;color:var(--ink);font-size:26px;letter-spacing:-.04em}.empty-project p:not(.eyebrow){max-width:390px;margin-bottom:21px;color:var(--muted);font-size:13px;line-height:1.8}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:rgba(16,30,25,.42);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal-card{overflow:hidden;width:min(100%,610px);max-height:min(92vh,880px);border-radius:16px;background:#fff;box-shadow:0 30px 80px rgba(10,32,24,.26)}.modal-card.wide{width:min(100%,1120px)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:19px 20px 16px;border-bottom:1px solid var(--line)}.modal-header h2{margin:0;font-size:19px;letter-spacing:-.03em}.modal-body{overflow-y:auto;max-height:calc(92vh - 77px);padding:19px 20px 20px}.field{display:block;margin-bottom:14px}.field>span{display:block;margin-bottom:7px;color:#536159;font-size:12px;font-weight:700}input,select,textarea{width:100%;border:1px solid #dfe5e1;border-radius:9px;outline:none;background:#fff;color:var(--ink);padding:10px 11px;font-size:13px;transition:.16s ease}input:focus,select:focus,textarea:focus{border-color:#64a68d;box-shadow:0 0 0 3px rgba(31,107,80,.1)}textarea{resize:vertical;line-height:1.6}.money-input{position:relative}.money-input i{position:absolute;top:50%;left:11px;color:var(--muted);font-size:13px;font-style:normal;transform:translateY(-50%)}.money-input input{padding-left:27px}.form-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:0 13px;gap:0 13px}.modal-footer{justify-content:flex-end;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}.modal-footer.spread{justify-content:space-between}.danger-text-button{display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:#dc2626;padding:8px 0;font-size:12px;font-weight:700}.danger-text-button:hover{color:#b91c1c}.import-modal-body{padding-bottom:14px}.import-upload-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;grid-gap:13px;gap:13px}.import-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px;margin:15px 0 10px}.import-column-map span,.import-summary-grid span{border:1px solid var(--line);border-radius:10px;background:#f8faf8;color:var(--muted);padding:9px 10px;font-size:12px}.import-summary-grid strong{display:block;margin-top:4px;color:var(--ink)}.import-column-map{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px}.import-table-wrap{overflow:auto;max-height:min(50vh,520px);border:1px solid var(--line);border-radius:12px}.import-table{width:100%;min-width:1050px;border-collapse:collapse;font-size:12px}.import-table td,.import-table th{border-bottom:1px solid #edf0ee;padding:8px;text-align:left;vertical-align:top}.import-table th{position:-webkit-sticky;position:sticky;top:0;z-index:1;background:#f6f8f6;color:#536159;font-weight:800}.import-table input,.import-table select{min-width:105px;padding:7px 8px;font-size:12px}.import-table input[type=checkbox]{min-width:0;width:17px;height:17px}.import-table tr.has-error{background:#fff7f7}.import-table tr.is-duplicate:not(.has-error){background:#fffaf0}.import-row-status{display:inline-block;min-width:90px;color:#b45309;font-weight:700}.has-error .import-row-status{color:#dc2626}.import-row-ok{color:var(--green);font-weight:700}.form-error{margin:5px 0 0;color:#dc2626;font-size:12px}.cloud-status-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-bottom:12px}.cloud-status-grid span{border-radius:8px;background:#f2f4f3;color:var(--muted);padding:9px 10px;font-size:12px;font-weight:700}.cloud-status-grid span.configured{background:#eaf7f0;color:#18724e}.settings-note{margin:0 0 15px;color:var(--muted);font-size:12px;line-height:1.65}.segmented{display:grid;grid-template-columns:1fr 1fr;grid-gap:4px;gap:4px;margin-bottom:15px;border-radius:10px;background:#f1f4f2;padding:4px}.segmented button{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;border-radius:7px;background:transparent;color:var(--muted);padding:9px;font-size:12px;font-weight:700}.segmented button.active{background:#fff;color:var(--green);box-shadow:0 2px 5px rgba(25,48,39,.08)}.upload-zone{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:9px;gap:9px;align-items:stretch;margin-bottom:14px}.upload-drop{position:relative;display:flex;min-height:118px;align-items:center;justify-content:center;flex-direction:column;overflow:hidden;border:1px dashed #b9cdc3;border-radius:10px;background:#f8fbf9;color:var(--muted);text-align:center}.upload-drop input{position:absolute;inset:0;z-index:2;cursor:pointer;opacity:0}.upload-drop span{display:grid;width:36px;height:36px;margin-bottom:7px;place-items:center;border-radius:11px;background:var(--green-soft);color:var(--green)}.upload-drop small,.upload-drop strong{display:block}.upload-drop strong{color:var(--ink);font-size:12px}.upload-drop small{margin-top:5px;font-size:10px}.upload-drop.has-preview img{width:100%;height:160px;object-fit:cover}.ai-button{align-self:stretch;border:1px solid #d7c6f6;background:#f7f2ff;color:#7040b8;padding:12px}.ai-button:hover{background:#f1e9ff}.ai-notice{gap:6px;margin:0 0 15px;border-radius:8px;background:#f7f2ff;color:#7040b8;padding:9px 10px;font-size:11px;line-height:1.5}.ai-notice,.toast{display:flex;align-items:center}.toast{position:fixed;right:22px;bottom:22px;z-index:50;gap:7px;border-radius:10px;background:#173f33;color:#fff;padding:11px 14px;box-shadow:var(--shadow);font-size:12px;font-weight:700}.loading-screen,.login-page{display:grid;min-height:100vh;place-items:center}.loading-screen{align-content:center;gap:13px;color:var(--muted);font-size:13px}.login-page{position:relative;overflow:hidden;padding:20px;background:radial-gradient(circle at 15% 15%,rgba(243,182,97,.2),transparent 27%),radial-gradient(circle at 85% 80%,rgba(62,135,106,.26),transparent 29%),#123f32}.login-page:before{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 0),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 0);background-size:44px 44px;content:""}.login-card{position:relative;width:min(100%,368px);border-radius:18px;background:#fff;padding:29px;box-shadow:0 28px 80px rgba(0,0,0,.2);text-align:center}.login-card .eyebrow{margin-top:18px}.login-card h1{margin:0;font-size:26px;letter-spacing:-.05em}.login-description{margin:8px 0 23px;color:var(--muted);font-size:13px}.login-form{text-align:left}.login-form label{display:block;margin-bottom:13px;color:#536159;font-size:12px;font-weight:700}.login-form input{margin-top:7px}.login-form button{margin-top:5px;padding:12px}.login-footnote{margin:18px 0 0;color:#9ba69f;font-size:10px}.mobile-fab{display:none}@media (max-width:1080px){.overview-grid{grid-template-columns:1fr}.quick-panel{min-height:auto}}@media (max-width:760px){.sidebar{display:none}.main-content{margin-left:0}.topbar{height:58px;padding:0 16px}.desktop-only{display:none}.mobile-brand{display:flex}.workspace{padding:22px 15px 90px}.project-heading{display:block;margin-bottom:18px}.project-heading h1{font-size:28px}.heading-actions{margin-top:16px}.heading-actions .primary-button{display:none}.stat-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px}.stat-card:first-child{grid-column:1/-1}.stat-card strong{font-size:20px}.stat-icon{top:13px;right:13px;width:34px;height:34px}.budget-panel{padding:14px}.category-layout{gap:4px;padding:4px 12px 14px}.category-chart{width:150px;height:170px}.category-legend{gap:10px}.legend-item{gap:6px}.legend-item,.legend-item strong{font-size:11px}.expense-list{padding:0 13px}.expense-row{grid-template-columns:34px minmax(0,1fr) auto;gap:9px;padding:13px 0}.expense-main{display:block}.expense-main div>span,.expense-main strong{max-width:170px}.category-pill{display:inline-flex!important;margin-top:6px}.expense-amount{align-self:start;min-width:76px;padding-top:4px;font-size:13px}.expense-actions{grid-column:2/-1;justify-content:flex-end;margin-top:-2px}.mobile-fab{position:fixed;right:20px;bottom:20px;z-index:20;display:grid;width:55px;height:55px;place-items:center;border:0;border-radius:50%;background:var(--green);color:#fff;box-shadow:0 12px 25px rgba(31,107,80,.3)}.modal-backdrop{align-items:end;padding:0}.modal-card{width:100%;max-height:94vh;border-radius:18px 18px 0 0}.modal-card.wide{width:100%}.modal-body{max-height:calc(94vh - 77px)}.import-summary-grid,.import-upload-row,.upload-zone{grid-template-columns:1fr}.ai-button{padding:11px}.toast{right:16px;bottom:86px;left:16px;justify-content:center}}