*{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}.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:space-between;align-items:center;gap:12px;margin:12px 0}.report-toggle-group{display:inline-flex;border:2px solid var(--accent);border-radius:12px;overflow:hidden}.report-toggle-group button{border:none;background:#fff;color:var(--accent-dark);padding:8px 12px;cursor:pointer;display:grid;place-items:center;width:44px;height:36px}.report-toggle-group button svg{width:20px;height:20px}.report-toggle-group button.active{background:var(--accent);color:#fff}.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:16px;min-width:0}.entry-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px dotted #c7c7c7;padding-bottom:10px;flex-wrap:wrap;min-width:0}.entry-date{display:flex;align-items:center;gap:8px;font-size:14px;color:#5a5a5a;min-width:0}.entry-date input{border:none;background:transparent;font-size:14px;color:inherit;padding:0;max-width:100%}.entry-date input[type=date]{max-width:160px}.entry-time{border:none;background:transparent;font-size:16px;color:#5a5a5a;padding:0;max-width:100%;min-width:0}.entry-nav{display:grid;grid-template-columns:repeat(2,40px);gap:6px}.entry-row{display:grid;grid-template-columns:56px 1fr;align-items:center;gap:12px;padding-bottom:8px;border-bottom:1px dotted #c7c7c7;min-width:0}.entry-row .category-icon{width:40px;height:40px}.entry-row select{width:100%;min-width:0}.entry-row-controls{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;min-width:0}.entry-row-controls select{width:100%;min-width:0}.entry-type-toggle{grid-template-columns:repeat(2,1fr);margin:0;border-width:1px}.entry-type-toggle button{padding:6px 10px;font-size:12px}.entry-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;min-width:0}.entry-fields input{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-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-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}.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,1fr);text-align:center;font-size:12px;color:#6b6b6b;margin-bottom:6px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-cell{min-height:56px;border-radius:8px;padding:6px;background:#f8f7f4;display:grid;gap:4px;font-size:12px;border:none;text-align:left;cursor:pointer}.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}.calendar-amount{font-size:11px}.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}.bar-scroll{overflow-x:auto;padding:0}.bar-chart{display:grid;grid-auto-flow:column;grid-auto-columns:24px;align-items:end;justify-content:start;gap:4px;padding:0;height:120px;width:max-content}.bar-chart.bar-chart-full{width:100%;grid-auto-columns:minmax(0,1fr)}.bar-item{display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.bar-amount{font-size:10px;color:#6b6b6b}.bar-stack{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;width:100%}.bar-value{width:100%;background:#4a90e2;border-radius:8px 8px 4px 4px;min-height:6px}.bar-label{font-size:11px;text-align:center;color:#6b6b6b;margin-top:0;margin-bottom:6px;line-height:1}.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}.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-section{display:grid;gap:8px}.balance-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:#444}.balance-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.balance-list li{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px dotted #c7c7c7}.balance-info{display:flex;align-items:center;gap:12px}.balance-info span{display:block;font-size:12px;color:#7a7a7a}.balance-icon{width:44px;height:44px;border-radius:12px;background:#9f9489;color:#fff;display:grid;place-items:center}.balance-icon.card{background:#2f3db5}.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}.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}.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 strong{font-size:20px}.menu-brand span{font-size:12px}.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-icon{width:24px;height:24px}.menu-icon svg{width:24px;height:24px}.menu-icon .material-symbols-outlined{font-size:22px}.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}@media(max-width:480px){.category-grid{grid-template-columns:repeat(3,1fr)}}
