*{box-sizing:border-box}body{margin:0;background:#f3f2ef}button,input,select{font:inherit}:root{color-scheme:light;font-family:"M PLUS 1p",Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif}.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:#9bcf3b;padding:6px 8px 0;gap:6px;border-bottom:6px solid #c8d1b3}.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:#4c6b0f}.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:#9bcf3b;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 #9bcf3b;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:#7ba52a;cursor:pointer}.pill-toggle button.active{background:#9bcf3b;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 #9bcf3b;border-radius:12px;overflow:hidden}.report-toggle-group button{border:none;background:#fff;color:#7ba52a;padding:8px 12px;cursor:pointer}.report-toggle-group button.active{background:#9bcf3b;color:#fff}.report-type{border:none;padding:8px 16px;border-radius:12px;background:#9bcf3b;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}.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:grid;gap:4px;font-size:14px;color:#5a5a5a;min-width:0}.entry-date span{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.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-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:right;padding-right:16px}.calc-key.function{background:#8a8a8a}.entry-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center;min-width:0}.entry-method{background:#9f9489;color:#fff;border:none;border-radius:12px;padding:12px;font-size:16px;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 #5a7f13}.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 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%}.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}.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:#dfe9cc}.calendar-detail{margin-top:16px;display:grid;gap:8px}.entry-group{display:grid;gap:8px;background:transparent;padding:0;grid-template-columns:1fr}.entry-group-header{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#6b6b6b}.entry-group-totals{display:flex;gap:8px}.entry-group-list{display:grid;gap:8px}.entry-group-list .entry-button{background:#f7f5f2;padding:10px 12px;border-radius:12px}.calendar-date{font-weight:600}.calendar-amount{font-size:11px}.calendar-amount.expense{color:#d05532}.calendar-amount.income{color:#2f6db4}.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}.bar-chart{display:grid;grid-template-columns:repeat(auto-fit,minmax(24px,1fr));align-items:end;gap:8px;padding:16px 8px 8px;height:220px}.bar-item{display:grid;align-items:end;gap:6px;height: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}.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-row{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:16px;box-shadow:0 2px 6px #0000000f}.category-actions{display:grid;gap:6px;justify-items:end}.reorder-buttons{display:grid;gap:4px}.reorder-buttons button{border:none;background:#d6d6d6;color:#fff;border-radius:8px;padding:4px 6px;cursor:pointer}.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-actions{display:flex;justify-content:flex-end;gap:8px}.icon-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.icon-choice{border:1px solid #dad3c6;background:#faf8f4;border-radius:12px;padding:8px;display:grid;gap:4px;justify-items:center;font-size:12px;cursor:pointer}.icon-choice.active{border-color:#9bcf3b;background:#e6f1ce}.icon-preview svg{width:24px;height: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}.rule-card span{display:block;font-size:12px;color:#7a6b5b}.rule-icon{width:40px;height:40px;border-radius:50%;background:#f0f0f0;display:grid;place-items:center}.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:#9bcf3b;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-divider{height:1px;background:#ddd;margin:8px 0}.backdrop{position:fixed;inset:0;background:#0006;z-index:9}.row{display:grid;grid-template-columns:1fr 120px;gap:8px}.muted{color:#7a6b5b;font-size:13px}@media(max-width:480px){.category-grid{grid-template-columns:repeat(3,1fr)}}
