*{box-sizing:border-box}body{margin:0;background:#f3f2ef}.material-symbols-outlined{font-family:Material Symbols Outlined,sans-serif;font-weight:400;font-style:normal;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;font-size:22px;line-height:1;display:inline-flex;align-items:center;justify-content:center;letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased}button,input,select{font:inherit}:root{color-scheme:light;font-family:"M PLUS 1p",Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif;--accent: #2f8f9d;--accent-dark: #21666f;--accent-soft: #d5e8eb;--accent-border: #b9d1d4}.app{min-height:100vh;background:#f3f2ef;color:#222;display:flex;flex-direction:column}.top-bar{position:sticky;top:0;z-index:6;display:grid;grid-template-columns:48px 1fr 80px;align-items:center;padding:12px 16px;background:#4a4a4a;color:#fff}.title-group h1{margin:0;font-size:20px;text-align:center}.icon-button{background:transparent;border:none;font-size:20px;color:inherit;cursor:pointer}.icon-button.subtle{color:#8a8a8a}.ghost{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;cursor:pointer;justify-self:end}.ghost:disabled{opacity:.7}.icon-bar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--accent);padding:6px 8px 0;gap:6px;border-bottom:6px solid var(--accent-border)}.icon-bar button{background:transparent;border:none;color:#fff;padding:10px 0 14px;border-bottom:4px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center}.icon-bar button svg{width:28px;height:28px}.icon-bar button.active{border-bottom-color:var(--accent-dark)}.content{flex:1;padding:16px 16px 32px}.card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 6px 18px #00000014}.card+.card{margin-top:16px}.page{padding-bottom:80px}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px}.auth-card{width:100%;max-width:360px;background:#fff;border-radius:18px;padding:24px 20px;box-shadow:0 10px 24px #0000001f;display:grid;gap:12px;text-align:center}.auth-card h1{margin:0;font-size:22px}.auth-actions{display:grid;gap:8px}.auth-error{color:#c4472d;font-size:12px;margin:0}.form{display:grid;gap:12px;margin-top:16px}.field{display:grid;gap:6px}.field label{font-size:12px;color:#6b6b6b}input,select{padding:10px 12px;border-radius:10px;border:1px solid #dad3c6;background:#faf8f4;font-size:14px}.primary{background:var(--accent);border:none;color:#fff;padding:10px 14px;border-radius:999px;font-weight:600;cursor:pointer}.primary.full{width:100%}.pill{border:1px solid #c8c8c8;border-radius:999px;padding:4px 8px;font-size:12px;color:#8a8a8a}.pill-toggle{display:grid;grid-template-columns:repeat(2,1fr);border:2px solid var(--accent);border-radius:999px;overflow:hidden;margin:16px 0}.pill-toggle.small{grid-template-columns:repeat(3,1fr);margin:12px 0}.pill-toggle button{background:#fff;border:none;padding:10px 0;color:var(--accent-dark);cursor:pointer}.pill-toggle button.active{background:var(--accent);color:#fff;font-weight:600}.report-toggle{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin:12px 0}.report-type{border:none;padding:8px 16px;border-radius:12px;background:var(--accent);color:#fff;font-weight:600;cursor:pointer}.summary-panel{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 4px;font-size:18px}.summary-panel strong{font-size:28px}.summary-progress{height:6px;background:#deded1;border-radius:999px;overflow:hidden;margin-bottom:12px}.summary-progress span{display:block;height:100%;background:#16b3eb}.summary-progress.negative span{background:#d55b4a}.entry-input{display:grid;gap:12px;min-width:0}.entry-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;border-bottom:1px dotted #c7c7c7;padding-bottom:8px;min-width:0}.entry-meta-field{display:grid;gap:2px;background:#f6f4ef;border:1px solid #ddd9cf;border-radius:10px;padding:6px 10px 7px;min-width:0;overflow:hidden}.entry-meta-field-time{max-width:100%;justify-self:stretch}.entry-meta-label{font-size:10px;letter-spacing:.04em;color:#7a7a7a}.entry-meta-input{border:none;background:transparent;font-size:17px;line-height:1.2;color:#3f3f3f;font-weight:600;letter-spacing:.02em;padding:0;width:100%;min-width:0;max-width:100%;font-variant-numeric:tabular-nums;appearance:none;-webkit-appearance:none}.entry-meta-input-date{font-size:16px}.entry-meta-input-time{font-size:17px;width:100%}.entry-meta-input::-webkit-date-and-time-value{text-align:left;min-width:0}.entry-meta-input::-webkit-datetime-edit{padding:0}.entry-meta-input::-webkit-datetime-edit-fields-wrapper{min-width:0;padding:0}.entry-meta-input::-webkit-calendar-picker-indicator{opacity:.72;margin:0}@media(max-width:360px){.entry-meta-input-date{font-size:15px}.entry-meta-input-time{font-size:16px}}.entry-nav{display:grid;grid-template-columns:repeat(2,40px);gap:6px}.entry-row{display:grid;grid-template-columns:56px minmax(0,1fr);align-items:stretch;gap:12px;padding-bottom:8px;border-bottom:1px dotted #c7c7c7;min-width:0}.entry-row .entry-row-icon{width:56px;height:56px;box-shadow:none;border:none;align-self:center}.entry-row-controls{display:grid;grid-template-columns:minmax(0,1fr);align-items:stretch;min-width:0}.entry-category-trigger{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:3px 8px;align-items:center;width:100%;border:1px solid #ddd9cf;border-radius:11px;background:#f6f4ef;padding:6px 10px;min-width:0;text-align:left;cursor:pointer}.entry-inline-label{font-size:10px;color:#787878;letter-spacing:.04em;grid-column:1 / -1}.entry-category-name{color:#3f3f3f;font-size:15px;font-weight:600;line-height:1.2;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.entry-category-arrow{color:#6f6f6f;display:grid;place-items:center}.entry-category-arrow .material-symbols-outlined{font-size:20px}.entry-type-toggle{margin:0}.entry-type-toggle button{padding:8px 0;font-size:13px;font-weight:600}.entry-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;min-width:0}.entry-fields input{padding:9px 10px;min-width:0}.calc-display{display:grid;grid-template-columns:48px 1fr 48px;align-items:center;gap:8px;padding:8px 4px;min-width:0}.calc-value{font-size:32px;text-align:right;font-weight:600}.calc-action{background:#cfcfcf;border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-weight:600;cursor:pointer}.calc-keypad{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;min-width:0}.calc-key{background:#6f6f6f;color:#fff;border:none;padding:18px 0;font-size:20px;border-radius:8px;cursor:pointer}.calc-key.operator{background:#5a5a5a;text-align:center}.calc-key.function{background:#8a8a8a}.entry-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;min-width:0}.entry-actions>button{flex:1}.entry-actions>.entry-delete{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:#e2dcd4;color:#5b4f45;display:grid;place-items:center}.entry-actions>.entry-delete .material-symbols-outlined{font-size:20px}.entry-method{background:#9f9489;color:#fff;border:none;border-radius:12px;padding:12px;font-size:16px;cursor:pointer}.entry-category-sheet{width:min(360px,92vw);gap:10px}.entry-category-options{list-style:none;padding:0;margin:0;display:grid;gap:8px;max-height:min(52vh,360px);overflow-y:auto}.entry-category-option{width:100%;border:1px solid #ddd9cf;border-radius:12px;background:#f7f5f2;padding:8px 10px;display:grid;grid-template-columns:56px minmax(0,1fr) 20px;align-items:center;gap:14px;text-align:left;color:#3f3f3f;cursor:pointer}.entry-category-option.active{border-color:var(--accent);background:var(--accent-soft)}.entry-category-option .entry-category-option-icon{width:56px;height:56px}.entry-category-option-name{font-size:14px;font-weight:600;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.entry-category-option-check{color:var(--accent-dark);display:grid;place-items:center}.entry-category-option-check .material-symbols-outlined{font-size:18px}.entry-payment-sheet{width:min(360px,92vw);gap:10px}.entry-payment-options{list-style:none;padding:0;margin:0;display:grid;gap:8px;max-height:min(52vh,360px);overflow-y:auto}.entry-payment-option{width:100%;border:1px solid #ddd9cf;border-radius:12px;background:#f7f5f2;padding:8px 10px;display:grid;grid-template-columns:40px minmax(0,1fr) 20px;align-items:center;gap:10px;text-align:left;color:#3f3f3f;cursor:pointer}.entry-payment-option.active{border-color:var(--accent);background:var(--accent-soft)}.entry-payment-option-icon{width:40px;height:40px;border-radius:10px;background:#ece8e2;display:grid;place-items:center;color:#6a6a6a}.entry-payment-option-icon .material-symbols-outlined{font-size:20px}.entry-payment-option-text{display:grid;gap:2px;min-width:0}.entry-payment-option-text strong{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-payment-option-text span{font-size:11px;color:#7a7a7a}.entry-payment-option-check{color:var(--accent-dark);display:grid;place-items:center}.entry-payment-option-check .material-symbols-outlined{font-size:18px}.entry-clear{background:#d7d0c8;color:#5b4f45;border:none;border-radius:12px;padding:12px;font-size:14px;cursor:pointer}.report-summary{display:grid;justify-items:center;gap:6px;margin-bottom:12px}.report-summary div{display:grid;justify-items:center;gap:4px}.report-summary span{font-size:12px;color:#6b6b6b}.report-summary strong{font-size:28px}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 10px;margin:12px 0 8px}.category-card{border:none;background:transparent;display:grid;justify-items:center;gap:6px;cursor:pointer}.category-card.active .category-icon{outline:3px solid var(--accent-dark)}.category-card.settings .category-icon{background:#7a7a7a}.category-card.settings .category-label{color:#5f5f5f}.category-icon{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff}.category-icon .material-symbols-outlined{font-size:26px}.category-icon svg{width:28px;height:28px}.category-fallback{font-size:16px;font-weight:600}.category-label{font-size:12px;color:#444;text-align:center}.list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:10px}.list li{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:10px 12px;background:#f7f5f2;border-radius:12px}.entry-button{border:none;background:transparent;text-align:left;display:grid;gap:6px;cursor:pointer;padding:0;width:100%}.entry-button.planned{cursor:default}.entry-button:disabled{cursor:default}.entry-row-main{display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:center}.entry-info{display:grid;gap:4px;min-width:0}.entry-top-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.entry-name{margin-right:auto}.entry-memo{font-size:12px;color:#7a6b5b}.entry-badges{display:flex;gap:6px;align-items:center}.entry-amount-row strong{font-size:16px}.entry-category-icon{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;position:relative}.entry-category-icon .material-symbols-outlined{font-size:20px}.entry-payment-overlay{position:absolute;right:-4px;bottom:-4px;width:18px;height:18px;border-radius:50%;border:2px solid #f7f5f2;background:#ebe6df;color:#6b6b6b;display:grid;place-items:center}.entry-payment-overlay .material-symbols-outlined{font-size:12px}.entry-creator-overlay{position:absolute;right:-4px;top:-4px;width:18px;height:18px;border-radius:50%;border:2px solid #f7f5f2;background:#fff;display:block;overflow:hidden}.entry-creator-overlay img{width:100%;height:100%;object-fit:cover;display:block}.entry-payment-overlay.cash{background:#f1e6dd;color:#8a6b55}.entry-payment-overlay.bank{background:#e0eef8;color:#2f6db4}.entry-payment-overlay.emoney{background:#e0f2f2;color:#2f8f9d}.entry-payment-overlay.credit-card{background:#e6e9f6;color:#3a4bb8}.list.compact li{font-size:13px}.list.compact li .progress-row{grid-column:1 / -1}.list.compact li.report-category-item{grid-template-columns:1fr;gap:10px;align-items:stretch}.report-category-row{width:100%;border:none;background:transparent;padding:0;color:inherit;text-align:left;cursor:pointer;display:grid;gap:10px}.report-category-main{display:flex;align-items:center;justify-content:space-between;gap:10px}.report-category-arrow{color:#9b9b9b;font-size:22px;line-height:1;padding:0 2px;display:inline-block}.report-category-progress{margin-left:44px}.entry-main{display:flex;align-items:center;gap:12px}.entry-sub{display:flex;gap:8px;font-size:12px;color:#7a6b5b;flex-wrap:wrap}.text-button{background:transparent;border:none;color:#d05532;cursor:pointer}.badge{font-size:10px;padding:4px 8px;border-radius:999px;background:#f1e3d5;color:#7a6b5b}.badge.income{background:#d9f5e4;color:#2e7a57}.badge.expense{background:#ffe2d9;color:#b4512f}.badge.recurring{background:#e0ecff;color:#2f6db4}.badge.planned{background:#e6e6e6;color:#6b6b6b}.badge.carryover{background:#e2e2e2;color:#5f5f5f}.month-header{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.month-header h2{margin:0}.calendar{margin-top:12px}.calendar-week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));text-align:center;font-size:12px;color:#6b6b6b;margin-bottom:6px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.calendar-cell{min-width:0;min-height:56px;border-radius:8px;padding:6px;background:#f8f7f4;display:grid;align-content:start;gap:4px;font-size:12px;border:none;text-align:left;cursor:pointer;overflow:hidden}.calendar-cell.sunday .calendar-date{color:#d05532}.calendar-cell.saturday .calendar-date{color:#2f6db4}.calendar-cell.muted{opacity:.4;cursor:default}.calendar-cell.selected{background:var(--accent-soft)}.calendar-detail{margin-top:16px;display:grid;gap:8px}.entry-group{display:grid;gap:8px;background:transparent;padding:0;grid-template-columns:1fr}.list .entry-group{grid-template-columns:1fr;align-items:stretch;gap:8px;padding:0;background:transparent;border-radius:0}.entry-group-header{display:grid;gap:6px;font-size:12px;color:#6b6b6b}.entry-group-date{font-size:14px;color:#444}.entry-group-totals{display:flex;gap:8px;flex-wrap:wrap}.entry-group-card{background:#f7f5f2;padding:10px 12px;border-radius:12px}.entry-group-list{display:grid;gap:8px;position:relative}.entry-group-list .entry-button{background:transparent;padding:6px 0;border-radius:0;position:relative;z-index:1}.calendar-date{font-weight:600;line-height:1.2}.calendar-amount{display:block;font-size:11px;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-amount.expense{color:#d05532}.calendar-amount.income{color:#2f6db4}.calendar-amount.planned{font-size:10px;color:#9a9a9a}.calendar-amount.carryover{font-size:10px;color:#6b6b6b}.calendar-amount.carryover.income{color:#2f6db4}.calendar-amount.carryover.expense{color:#d05532}.donut{width:220px;height:220px;border-radius:50%;margin:16px auto;display:grid;place-items:center;position:relative}.donut:after{content:"";position:absolute;width:140px;height:140px;background:#fff;border-radius:50%}.donut-center{position:relative;z-index:1;text-align:center}.donut-center span{display:block;font-size:12px;color:#6b6b6b;margin-bottom:4px}.donut-center strong{font-size:22px}.report-range{text-align:center;font-size:12px;color:#6b6b6b;margin-bottom:8px}.summary-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.summary-strip div{background:#e0e0e0;border-radius:12px;padding:8px;text-align:center;font-size:12px}.report-section{margin-top:12px}.entity-summary-strip{margin-bottom:12px}.report-header{display:flex;justify-content:space-between;font-size:12px;color:#6b6b6b;padding:0 8px}.progress{background:#deded1;border-radius:999px;height:6px;overflow:hidden}.progress-row{display:grid;gap:6px}.progress span{display:block;height:100%}.mini-icon{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff}.chevron{color:#b8b8b8;font-size:20px;justify-self:end}.balance-card{display:grid;gap:16px}.balance-total-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:12px;background:#ece7df}.balance-total-row span{font-size:13px;color:#5b5b5b}.balance-total-row strong{font-size:22px}.balance-section{display:grid;gap:8px}.balance-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:#444}.balance-header-total{font-size:13px;color:#5b5b5b}.balance-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.balance-list li{display:block;padding:10px 12px;border-bottom:1px dotted #c7c7c7}.balance-item-button{width:100%;border:none;background:transparent;padding:0;display:flex;align-items:center;justify-content:space-between;gap:12px;color:inherit;text-align:left;cursor:pointer}.balance-info{display:flex;align-items:center;gap:12px}.balance-info>div span{display:block;font-size:12px;color:#7a7a7a}.balance-card-meta{font-size:11px;color:#6a6a6a}.payment-method-icon{width:44px;height:44px;border-radius:12px;background:#9f9489;color:#fff;display:grid;place-items:center;flex-shrink:0}.payment-method-icon .material-symbols-outlined{font-size:22px}.balance-amount{display:flex;align-items:center;gap:8px;color:#222}.link-button{background:transparent;border:none;color:#1a4cff;text-decoration:underline;cursor:pointer}.toggle-row{display:flex;align-items:center;justify-content:space-between;background:#e0e0e0;padding:10px 14px;border-radius:12px;font-weight:600}.toggle-switch{background:#b0b0b0;border:none;color:#fff;padding:6px 16px;border-radius:12px;cursor:pointer}.toggle-switch.active{background:#7f7f7f}.category-list{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:12px}.category-list.scrollable{max-height:calc(100vh - 240px);overflow-y:auto;padding-bottom:80px}.category-row{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:16px;padding:12px;background:#fff;border-radius:16px;box-shadow:0 2px 6px #0000000f}.category-title{margin-left:2px}.payment-method-title-wrap{display:grid;gap:4px;min-width:0}.payment-method-title-wrap .category-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.payment-method-title-wrap .pill{justify-self:start}.payment-method-meta{font-size:11px;color:#777;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.payment-method-row .category-actions{justify-content:flex-end}.category-actions,.category-action-buttons{display:flex;align-items:center;gap:8px}.icon-button-small{border:none;background:#f1f1f1;color:#555;width:34px;height:34px;border-radius:10px;cursor:pointer;display:grid;place-items:center}.icon-button-small.danger{background:#ffe9e3;color:#c04a2b}.reorder-buttons{display:flex;align-items:center;gap:6px}.reorder-buttons button:disabled{opacity:.5;cursor:default}.sheet{position:fixed;inset:0;background:#00000073;display:grid;place-items:center;z-index:20}.sheet-card{background:#fff;border-radius:16px;padding:20px;display:grid;gap:12px;width:min(320px,90vw)}.sheet-card.scrollable{max-height:80vh;overflow-y:auto}.sheet-actions{display:flex;justify-content:flex-end;gap:8px}.sheet-actions.spread{justify-content:space-between;align-items:center}.sheet-action-buttons{display:flex;gap:8px}.sheet-actions .ghost{border-color:#c9c1b6;color:#5b4f45;background:#f4f1ec}.sheet-field-label{font-size:12px;color:#6b6b6b;font-weight:600}.payment-settings-sheet{width:min(720px,92vw);gap:14px}.payment-settings-sheet h3{margin:0}.payment-settings-sheet input,.payment-settings-sheet select{width:100%;box-sizing:border-box}.payment-settings-sheet.scrollable{max-height:calc(100vh - 44px)}.payment-settings-sheet .sheet-actions{justify-content:flex-end;flex-wrap:wrap}.payment-settings-sheet .icon-picker{grid-template-columns:repeat(4,minmax(0,1fr));max-height:min(30vh,220px)}.payment-settings-sheet .icon-choice{min-height:54px}.payment-settings-sheet .color-picker{grid-template-columns:repeat(6,minmax(0,1fr))}.card-setting-grid{display:grid;gap:8px;background:#f7f5f2;border:1px solid #ddd9cf;border-radius:12px;padding:10px}.icon-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-height:240px;overflow-y:auto;padding-right:4px}.icon-choice{border:1px solid #dad3c6;background:#faf8f4;border-radius:12px;padding:10px;display:grid;justify-items:center;cursor:pointer}.icon-choice.active{border-color:var(--accent);background:var(--accent-soft)}.icon-preview .material-symbols-outlined{font-size:24px}.color-picker{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer}.color-swatch.active{border-color:#4a4a4a}.floating-button{position:fixed;right:20px;bottom:24px;width:56px;height:56px;border-radius:50%;border:none;background:#2f6db4;color:#fff;font-size:28px;cursor:pointer;box-shadow:0 8px 16px #0003;z-index:8}.rule-group{margin-top:16px}.rule-group h3{margin-bottom:8px}.rule-list{display:grid;gap:12px}.rule-card{display:grid;grid-template-columns:40px 1fr auto;gap:12px;align-items:center;padding:12px;background:#fff;border-radius:16px;box-shadow:0 2px 6px #0000000f;border:none;text-align:left;cursor:pointer;color:inherit}.rule-card .rule-meta{display:block;font-size:12px;color:#7a6b5b}.rule-icon{width:40px;height:40px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;line-height:1}.rule-icon .material-symbols-outlined{font-size:20px;line-height:1;display:block}.rule-icon svg{width:20px;height:20px;display:block}.recurring-item{align-items:center}.recurring-item.future{color:#9a9a9a}.recurring-info{display:grid;gap:2px}.recurring-amount{display:grid;justify-items:end;gap:4px}.settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px 16px;padding:24px 0}.settings-item{border:none;background:transparent;display:grid;justify-items:center;gap:8px;color:#444;cursor:pointer}.settings-icon{width:40px;height:40px;display:grid;place-items:center}.side-menu{position:fixed;top:0;left:0;height:100%;width:82%;max-width:320px;background:#fff;box-shadow:6px 0 20px #0000001f;transform:translate(-100%);transition:transform .2s ease;z-index:10;overflow-y:auto}.side-menu.open{transform:translate(0)}.menu-brand{background:var(--accent);color:#fff;padding:20px 16px;display:grid;gap:6px}.menu-brand-row{display:flex;align-items:baseline;gap:8px}.menu-brand strong{font-size:20px}.menu-version{font-size:11px;opacity:.9}.brand-mark{font-size:32px}.menu-list{display:grid;padding:12px;gap:8px}.menu-item{display:grid;grid-template-columns:32px 1fr;align-items:center;gap:12px;border:none;background:transparent;font-size:16px;padding:8px 4px;cursor:pointer}.menu-item.disabled{opacity:.4;cursor:default}.menu-item.danger{color:#b4512f}.menu-icon{width:24px;height:24px}.menu-icon svg{width:24px;height:24px}.menu-icon .material-symbols-outlined{font-size:22px}.toast{position:fixed;left:50%;bottom:72px;transform:translate(-50%);background:#333;color:#fff;padding:10px 14px;border-radius:999px;font-size:13px;text-align:center;max-width:calc(100% - 32px);box-shadow:0 6px 18px #0000002e;z-index:30;pointer-events:none}.toast.error{background:#c0392b}.toast.info{background:#333}.sync-error-copy-wrap{position:fixed;right:12px;top:calc(62px + env(safe-area-inset-top));z-index:31}.sync-error-copy-button{border:1px solid #d8897d;background:#fff7f5;color:#a13b2d;padding:7px 10px;border-radius:999px;font-size:11px;font-weight:600;cursor:pointer;box-shadow:0 6px 18px #0000001f}.backdrop{position:fixed;inset:0;background:#0006;z-index:9}.row{display:grid;grid-template-columns:1fr 120px;gap:8px}.row.row-3{grid-template-columns:1fr 1fr 1fr}.muted{color:#7a6b5b;font-size:13px}.entity-page-header{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12px;color:#6b6b6b;margin-bottom:10px}.entity-page-header strong{color:#3d3d3d}.entity-list{margin-top:0}.entity-row{grid-template-columns:minmax(0,1fr) auto}.entity-main{display:grid;gap:4px;min-width:0}.entity-main span{font-size:11px;color:#7a6b5b}.entity-right{display:grid;justify-items:end;gap:4px}.entity-sub{font-size:11px;color:#7a6b5b}.entity-entry-header{display:flex;align-items:center;gap:8px}.entity-mini-icon{width:24px;height:24px}.entity-total-header{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:6px}.entity-total-header span{font-size:13px;color:#6b6b6b}.entity-total-header strong{font-size:24px}.entity-total-meta{margin-bottom:12px;font-size:12px;color:#6b6b6b}@media(max-width:480px){.category-grid{grid-template-columns:repeat(3,1fr)}.payment-method-row{grid-template-columns:44px minmax(0,1fr);grid-template-areas:"icon title" "actions actions";row-gap:10px;column-gap:12px}.payment-method-row>.payment-method-icon{grid-area:icon}.payment-method-row>.payment-method-title-wrap{grid-area:title}.payment-method-row>.category-actions{grid-area:actions;justify-content:space-between}.payment-settings-sheet .icon-picker{grid-template-columns:repeat(3,minmax(0,1fr))}.payment-method-meta{white-space:normal;line-height:1.35}}
