:root{color:#111827;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f1e8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}.page{color:#111827;font-feature-settings:"tnum";background:#f7f4ee;min-height:100vh;padding:24px;font-family:Inter,SF Pro Display,SF Pro Text,PingFang SC,Microsoft YaHei,system-ui,-apple-system,sans-serif}.login-page{color:#111827;background:#f7f4ee;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border:1px solid #e5d9bf;border-radius:8px;gap:14px;width:min(420px,100%);padding:22px;display:grid}.login-card h1{margin-bottom:6px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.eyebrow{color:#7c5c16;margin:0 0 4px;font-size:13px;font-weight:900}.userline{color:#6b7280;margin:8px 0 0;font-size:13px;font-weight:900}h1{letter-spacing:0;margin:0;font-size:30px;font-weight:950;line-height:1.15}.top-actions,.filters{flex-wrap:wrap;align-items:end;gap:10px;display:flex}.button{cursor:pointer;border:0;border-radius:8px;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-weight:900;display:inline-flex}.button.primary{color:#111827;background:#f3c74d}.button.secondary{color:#111827;background:#fff;border:1px solid #d1d5db}.error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;margin-bottom:12px;padding:10px 12px;font-weight:800}.filters{background:#fff;border:1px solid #e5d9bf;border-radius:8px;margin-bottom:12px;padding:14px}label{color:#374151;gap:6px;font-size:12px;font-weight:900;display:grid}select,input{color:#111827;min-height:40px;font:inherit;background:#fffcf5;border:1.5px solid #c8a94b;border-radius:8px;padding:0 10px}.search{min-width:280px}.search span{background:#fffcf5;border:1.5px solid #c8a94b;border-radius:8px;align-items:center;gap:8px;padding:0 10px;display:flex}.search input{background:0 0;border:0;outline:0;flex:1;padding:0}.summary-grid{grid-template-columns:repeat(4,minmax(160px,1fr));gap:10px;margin-bottom:12px;display:grid}.summary-card{background:#fff;border:1px solid #e5d9bf;border-radius:8px;gap:6px;padding:14px;display:grid}.summary-card p{color:#6b7280;margin:0;font-size:12px;font-weight:900}.summary-card strong{letter-spacing:0;font-size:18px}.stats-grid{grid-template-columns:minmax(520px,1.45fr) minmax(280px,.85fr) minmax(280px,.85fr);gap:14px;margin-bottom:16px;display:grid}.chart-card{background:linear-gradient(#fff 0%,#fffdf8 100%);border:1px solid #e5d9bf;border-radius:10px;min-width:0;padding:16px;box-shadow:0 10px 26px #5c45190f}.chart-card.wide{min-width:0}.chart-title{justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.chart-title strong{font-size:17px}.chart-title span,.category-head span,.category-row small,.legend,.pie-legend{color:#6b7280;font-size:12px;font-weight:850}.histogram{background:linear-gradient(0deg,#11182714 1px,#0000 1px) 0 0/100% 25%,linear-gradient(#f8fafcb3,#fff0);border-radius:8px;align-items:end;gap:12px;height:246px;padding:22px 4px 10px;display:flex;overflow-x:auto}.histogram::-webkit-scrollbar{height:8px}.histogram::-webkit-scrollbar-track{background:#f3f4f6;border-radius:999px}.histogram::-webkit-scrollbar-thumb{background:#c8a94b;border-radius:999px}.day-bars{grid-template-rows:168px auto;grid-template-columns:repeat(2,auto);place-items:end center;gap:8px 6px;min-width:62px;display:grid}.bar-pair{align-items:end;gap:4px;height:100%;padding:0 2px;display:flex}.lrd-bars{opacity:.58}.bar{border-radius:8px 8px 3px 3px;width:10px;min-height:4px;display:block;box-shadow:0 3px 8px #11182721}.good-bg{background:linear-gradient(#07966f,#047857)}.bad-bg{background:linear-gradient(#dc2626,#b91c1c)}.day-label{color:#6b7280;white-space:nowrap;grid-column:1/-1;font-size:11px;font-weight:900;transform:none}.legend{flex-wrap:wrap;align-items:center;gap:14px;margin-top:10px;display:flex}.legend span,.pie-legend span{align-items:center;gap:6px;display:inline-flex}.legend-dot{border-radius:999px;width:10px;height:10px;display:inline-block}.category-bars{gap:12px;display:grid}.category-row{gap:5px;display:grid}.category-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.category-head strong{color:#111827;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.progress-track{background:#eef0f3;border-radius:999px;height:10px;overflow:hidden}.progress-track span{border-radius:inherit;background:linear-gradient(90deg,#f3c74d,#c8a94b);min-width:4px;height:100%;display:block}.pie-wrap{grid-template-columns:148px 1fr;align-items:center;gap:18px;display:grid}.pie{aspect-ratio:1;border-radius:999px;width:148px;position:relative;box-shadow:inset 0 0 0 1px #1118271a,0 12px 24px #11182714}.pie:after{content:"";border-radius:inherit;background:#fffdf8;position:absolute;inset:30px;box-shadow:inset 0 0 0 1px #e5d9bf}.pie-legend{gap:10px;display:grid}.mini{padding:12px}.muted{color:#6b7280}.good{color:#047857}.bad{color:#b91c1c}.exchange{color:#1d4ed8}.table-shell,.days-shell{background:#fff;border:1px solid #e5d9bf;border-radius:8px;overflow:hidden}.table-title{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;min-height:48px;padding:0 14px;display:flex}.table-title span{color:#6b7280;font-size:13px;font-weight:800}.table-wrap{max-height:calc(100vh - 310px);overflow:auto}.day-group{border-top:1px solid #e5e7eb}.day-header{color:#111827;cursor:pointer;background:#fff;border:0;justify-content:space-between;align-items:center;gap:16px;width:100%;padding:12px 14px;display:flex}.day-header:hover{background:#fffcf5}.day-main{align-items:center;gap:10px;min-width:230px;display:flex}.day-main strong{font-size:16px}.day-main span:last-child{color:#6b7280;font-size:12px;font-weight:900}.chevron{background:#f3c74d;border-radius:8px;justify-content:center;align-items:center;width:26px;height:26px;font-weight:900;display:inline-flex}.day-summary{text-align:right;flex:1;grid-template-columns:repeat(5,minmax(170px,1fr));gap:8px 12px;font-size:13px;font-weight:900;display:grid}.day-summary span{white-space:normal;min-width:0}.day-table{border-top:1px solid #e5e7eb;max-height:420px}.day-detail{background:#fffcf5;border-top:1px solid #e5e7eb;padding:12px}table{border-collapse:collapse;width:100%;min-width:1180px;font-size:13px}th,td{text-align:left;white-space:nowrap;border-bottom:1px solid #e5e7eb;padding:10px 12px}th{z-index:1;color:#374151;background:#f9fafb;font-size:12px;position:sticky;top:0}tr:hover td{background:#fffcf5}.amount{font-weight:900}.pill{color:#111827;background:#e5e7eb;border-radius:6px;align-items:center;min-height:24px;padding:0 8px;font-size:12px;font-weight:900;display:inline-flex}.pill.cash_in{color:#065f46;background:#d1fae5}.pill.expense,.pill.transfer{color:#991b1b;background:#fee2e2}.pill.exchange{color:#1e40af;background:#dbeafe}.note{white-space:normal;max-width:320px}.photo-thumb{cursor:pointer;color:#6b7280;background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;justify-content:center;align-items:center;width:46px;height:46px;padding:0;font-size:10px;font-weight:900;display:inline-flex;overflow:hidden}.photo-thumb:hover{border-color:#c8a94b;box-shadow:0 0 0 3px #f3c74d38}.photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.photo-modal{z-index:20;background:#111827b8;justify-content:center;align-items:center;padding:28px;display:flex;position:fixed;inset:0}.photo-modal-panel{background:#fff;border-radius:8px;grid-template-rows:auto minmax(0,1fr) auto;width:min(980px,100%);max-height:calc(100vh - 56px);display:grid;overflow:hidden;box-shadow:0 24px 60px #00000047}.photo-modal-header,.photo-modal-actions{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex}.photo-modal-header div{gap:4px;display:grid}.photo-modal-header strong{font-size:18px}.photo-modal-header span{color:#6b7280;font-size:13px;font-weight:800}.photo-modal-actions{border-top:1px solid #e5e7eb;border-bottom:0;justify-content:flex-end}.photo-large{object-fit:contain;background:#111827;width:100%;max-height:calc(100vh - 190px);display:block}.empty{text-align:center;color:#6b7280;padding:28px}@media (width<=900px){.page{padding:16px}.topbar{flex-direction:column;align-items:stretch}.day-header{flex-direction:column;align-items:flex-start}.day-summary{text-align:left;grid-template-columns:repeat(2,minmax(0,1fr))}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-grid{grid-template-columns:1fr}.pie-wrap{grid-template-columns:120px 1fr}.pie{width:120px}.cash-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-modal{padding:12px}.photo-modal-header{flex-direction:column;align-items:stretch}}
