:root{color-scheme:light;--bg: #f6f7f5;--surface: #ffffff;--surface-muted: #f0f3f0;--text: #1e2421;--muted: #69716c;--border: #dde4df;--teal: #168271;--teal-soft: #e2f3ef;--coral: #c85544;--coral-soft: #f9e7e3;--amber: #b58424;--amber-soft: #fbf1d8;--shadow: 0 16px 40px rgba(30, 36, 33, .08);--overlay: rgba(24, 30, 27, .42);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root[data-theme=dark]{color-scheme:dark;--bg: #11140f;--surface: #191d17;--surface-muted: #222720;--text: #e9ede6;--muted: #9aa399;--border: #2c322a;--teal: #45b39c;--teal-soft: #16302a;--coral: #e07a68;--coral-soft: #34211d;--amber: #d8a64a;--amber-soft: #322813;--shadow: 0 16px 40px rgba(0, 0, 0, .45);--overlay: rgba(0, 0, 0, .6)}*{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;min-width:320px;background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}button,input,select{font:inherit}button{cursor:pointer;touch-action:manipulation}input,select{width:100%;min-height:44px;padding:0 12px;font-size:16px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:10px;outline:none;-webkit-appearance:none;appearance:none}input:focus,select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #1682712e}.login-page{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:24px}.login-panel{width:min(100%,390px);display:grid;gap:18px;padding:30px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow)}.login-mark{width:52px;height:52px;display:grid;place-items:center;color:var(--teal);background:var(--teal-soft);border-radius:12px}.login-panel h1,.brand h1,.panel-heading h2,.modal-head h2{margin:0;letter-spacing:0}.login-panel h1{font-size:30px;line-height:1.1}.login-panel p,.brand p,.panel-heading p,.modal-head p{margin:0;color:var(--muted)}.login-panel label,.field{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:650}.primary-action,.ghost-action,.danger-action,.icon-button,.text-icon{min-height:44px;border:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.primary-action{gap:8px;padding:0 18px;color:#fff;background:var(--teal);font-weight:760}.primary-action:hover{filter:brightness(.95)}.primary-action:disabled{opacity:.5;cursor:not-allowed}.ghost-action{gap:8px;padding:0 18px;color:var(--text);background:var(--surface-muted);font-weight:700}.danger-action{gap:8px;padding:0 18px;color:#fff;background:var(--coral);font-weight:760}.icon-button{width:44px;color:var(--text);background:var(--surface);border:1px solid var(--border)}.icon-button:hover,.text-icon:hover{background:var(--surface-muted)}.icon-button:disabled{opacity:.45;cursor:not-allowed}.icon-button.accent{color:#fff;background:var(--teal);border-color:var(--teal)}.text-icon{width:36px;min-height:36px;color:var(--muted);background:transparent}.form-error,.app-error{padding:12px 14px;color:var(--coral);background:var(--coral-soft);border:1px solid var(--border);border-radius:10px}:root[data-theme=light] .form-error,:root[data-theme=light] .app-error{color:#8f2f22;border-color:#edc8c1}.app-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:20px 0 calc(96px + env(safe-area-inset-bottom))}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;margin-bottom:14px;background:var(--bg)}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand svg{color:var(--teal);flex-shrink:0}.brand h1{font-size:22px;line-height:1.1}.brand p{margin-top:2px;font-size:13px}.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.month-select{height:44px;display:flex;align-items:center;gap:8px;padding-left:12px;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:10px}.month-select select{width:160px;min-height:42px;border:0;box-shadow:none;background:transparent}.add-desktop{display:inline-flex}.fab{display:none}.metrics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:14px}.metric-card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px}.metric-card{display:grid;gap:8px;padding:16px}.metric-card span{color:var(--muted);font-size:13px;font-weight:700}.metric-card strong{font-size:24px;line-height:1.1}.metric-caption{color:var(--muted);font-size:12px;font-weight:600}.metric-card.positive{border-color:color-mix(in srgb,var(--teal) 35%,var(--border));background:linear-gradient(180deg,var(--surface) 0%,var(--teal-soft) 140%)}.metric-card.negative{border-color:color-mix(in srgb,var(--coral) 35%,var(--border));background:linear-gradient(180deg,var(--surface) 0%,var(--coral-soft) 140%)}.metric-card.neutral{border-color:color-mix(in srgb,var(--amber) 35%,var(--border));background:linear-gradient(180deg,var(--surface) 0%,var(--amber-soft) 140%)}.panel{padding:18px}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.panel-heading h2{font-size:17px;line-height:1.2}.panel-heading p{margin-top:3px;font-size:13px}.content-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.8fr);gap:14px;align-items:start}.right-column{display:grid;gap:14px}.modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-sheet{width:min(100%,520px);max-height:calc(100vh - 40px);max-height:calc(100dvh - 40px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:20px;animation:pop .16s ease-out}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}.modal-head h2{font-size:19px}.modal-head p{margin-top:3px;font-size:13px}.transaction-form{display:grid;gap:14px}.type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;background:var(--surface-muted);border-radius:12px}.type-toggle button{min-height:40px;border:0;border-radius:9px;background:transparent;color:var(--muted);font-weight:700}.type-toggle button.active{background:var(--surface);box-shadow:0 1px 4px #0000001f}.type-toggle button.active.expense{color:var(--coral)}.type-toggle button.active.income{color:var(--teal)}.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.confirm-body{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}.confirm-body p{margin:0;line-height:1.45}.confirm-mark{flex-shrink:0;width:42px;height:42px;display:grid;place-items:center;color:var(--coral);background:var(--coral-soft);border-radius:10px}.confirm-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.filter-bar{display:grid;gap:10px;margin-bottom:14px}.search-field{position:relative;display:flex;align-items:center}.search-field svg{position:absolute;left:12px;color:var(--muted);pointer-events:none}.search-field input{padding-left:36px;padding-right:40px}.search-field .text-icon{position:absolute;right:4px}.type-filter{display:flex;align-items:center;gap:4px;padding:4px;background:var(--surface-muted);border-radius:12px;color:var(--muted)}.type-filter svg{margin-left:6px;margin-right:2px}.type-filter button{flex:1;min-height:36px;border:0;border-radius:8px;background:transparent;color:var(--muted);font-weight:650;font-size:13px}.type-filter button.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000001a}.budget-form{display:grid;grid-template-columns:minmax(0,1fr) 120px 44px;gap:8px;margin-bottom:15px}.budget-list,.breakdown-list{display:grid;gap:13px}.budget-row,.breakdown-row{display:grid;gap:8px}.budget-row-top,.breakdown-top{display:grid;align-items:center;gap:10px;font-size:14px}.budget-row-top{grid-template-columns:minmax(0,1fr) auto 36px}.breakdown-top{grid-template-columns:minmax(0,1fr) auto}.budget-row-top strong,.breakdown-top strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-row-top span,.breakdown-top span{color:var(--muted);white-space:nowrap}.budget-row-top span.over{color:var(--coral);font-weight:700}.breakdown-top em{font-style:normal;color:var(--text);font-weight:700}.progress-track{height:8px;overflow:hidden;background:var(--surface-muted);border-radius:999px}.progress-fill{height:100%;background:var(--teal);border-radius:999px;transition:width .3s ease}.progress-fill.cat{background:var(--teal)}.progress-fill.near{background:var(--amber)}.progress-fill.over{background:var(--coral)}.chart-legend{display:flex;gap:16px;margin-bottom:10px;color:var(--muted);font-size:12px;font-weight:650}.chart-legend span{display:inline-flex;align-items:center;gap:6px}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.income,.income-point{background:var(--teal);fill:var(--teal)}.legend-dot.expense,.expense-point{background:var(--coral);fill:var(--coral)}.line-chart{width:100%}.line-chart svg{width:100%;height:190px;overflow:visible}.line-chart line{stroke:var(--border);stroke-width:1}.line-chart polyline{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.income-line{stroke:var(--teal)}.expense-line{stroke:var(--coral)}.chart-labels{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));color:var(--muted);text-align:center;font-size:11px}.transactions-list{display:grid}.transaction-row{min-height:66px;display:grid;grid-template-columns:10px minmax(0,1fr) 100px 132px 80px;align-items:center;gap:13px;border-top:1px solid var(--border)}.transaction-row:first-child{border-top:0}.type-dot{width:10px;height:10px;border-radius:50%}.type-dot.income{background:var(--teal)}.type-dot.expense{background:var(--coral)}.transaction-main{min-width:0;display:grid;gap:4px}.transaction-main strong,.transaction-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-main span,.transaction-row time,.empty-text,.loading-panel{color:var(--muted);font-size:13px}.loading-panel{text-align:center;padding:40px 18px}.empty-text{padding:8px 0}.amount{text-align:right;white-space:nowrap}.amount.income{color:var(--teal)}.amount.expense{color:var(--coral)}.row-actions{display:flex;justify-content:flex-end;gap:2px}@media(max-width:920px){.app-shell{width:min(100% - 24px,760px)}.content-grid{grid-template-columns:1fr}}@media(max-width:680px){.app-shell{width:calc(100% - 24px);padding-top:0}.topbar{flex-wrap:wrap;padding:12px 0}.brand h1{font-size:19px}.brand p{display:none}.topbar-actions{width:100%;flex-wrap:wrap}.month-select{flex:1;min-width:150px}.month-select select{width:100%}.add-desktop{display:none}.fab{display:inline-flex;align-items:center;justify-content:center;position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:40;width:60px;height:60px;border:0;border-radius:50%;color:#fff;background:var(--teal);box-shadow:0 10px 26px #16827173}.metrics-grid{grid-template-columns:1fr;gap:10px}.metric-card{grid-template-columns:minmax(0,1fr) auto;align-items:baseline;column-gap:12px;overflow:hidden}.metric-card span{grid-row:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metric-card strong{grid-row:1;grid-column:2;text-align:right;font-size:21px;white-space:nowrap}.metric-caption{grid-column:1 / -1}.modal-overlay{padding:0;align-items:flex-end}.modal-sheet{width:100%;max-height:92vh;max-height:92dvh;border-radius:18px 18px 0 0;padding:18px 18px calc(20px + env(safe-area-inset-bottom));animation:slideup .2s ease-out}@keyframes slideup{0%{transform:translateY(100%)}}.transaction-row{grid-template-columns:10px minmax(0,1fr) auto;gap:10px 12px;padding:13px 0}.transaction-row time{grid-column:2;grid-row:2}.transaction-row .amount{grid-column:2 / 4;grid-row:3;text-align:left;font-size:15px}.row-actions{grid-column:3;grid-row:1}}@media(max-width:380px){.budget-form{grid-template-columns:1fr}.budget-form .icon-button.accent{width:100%}}
