:root{--pink: #f8a5c2;--pink-deep: #e0608f;--pink-text: #b94a74;--lavender: #c8b6e2;--tint-a: #fde6ef;--tint-b: #ece4f7;--on-accent: #ffffff;--border: #e0608f;--cream: #fff8fa;--ink: #4a3b44;--ink-soft: #7a6b74;--line: #f0d9e2;--ok: #5fae8a;--warn: #d98032;--card: #ffffff}*{box-sizing:border-box}:focus-visible{outline:3px solid var(--pink);outline-offset:2px}html,body{margin:0;padding:0;background:var(--cream);color:var(--ink);font-family:Hiragino Maru Gothic ProN,Hiragino Sans,BIZ UDGothic,Yu Gothic,sans-serif;font-size:16px;line-height:1.7}.shell{max-width:480px;margin:0 auto;min-height:100dvh}.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:6px;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;background:var(--tint-a);border-bottom:1px solid var(--line)}.app-header .brand{display:inline-flex;align-items:center;gap:6px;font-weight:800;color:var(--pink-deep);font-size:18px}.app-header .beta{font-size:11px;font-weight:700;color:var(--pink-text);background:#fff;border-radius:999px;padding:1px 8px}.app-main{padding:16px 16px calc(84px + env(safe-area-inset-bottom))}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:#fff;border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom);z-index:10}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:0;background:none;border:none;padding:8px 0 6px;font-family:inherit;color:var(--ink-soft);cursor:pointer}.tab.active{color:var(--pink-text)}.tab-icon{display:flex;align-items:center;justify-content:center;height:24px}.tab-label{font-size:11px;font-weight:700}.card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:14px 16px;margin-bottom:14px}.card h2{font-size:15px;margin:0 0 8px;color:var(--pink-text)}.big-amount{font-size:32px;font-weight:800;line-height:1.3}.sub{font-size:13px;color:var(--ink-soft)}.stat-row{display:flex;gap:10px}.stat{flex:1;text-align:center;background:var(--tint-a);border-radius:12px;padding:10px 4px}.stat .num{font-size:20px;font-weight:800}.stat .label{font-size:12px;color:var(--ink-soft)}button.btn,a.btn{font-family:inherit;font-size:15px;font-weight:700;border:none;border-radius:999px;padding:10px 22px;cursor:pointer;background:var(--pink-deep);color:var(--on-accent)}.inline-msg{font-size:13px;color:var(--ok);margin-left:10px;font-weight:700}button.btn.secondary,a.btn.secondary{background:var(--lavender);color:var(--pink-text)}button.btn.ghost{background:var(--tint-b);color:var(--ink);font-weight:400;font-size:13px;padding:6px 14px}button.btn svg{vertical-align:-3px;margin-right:6px}button.btn:disabled{opacity:.4;cursor:not-allowed}button.btn.wide{width:100%}.icon-btn{background:none;border:none;color:var(--ink-soft);font-size:16px;cursor:pointer;min-width:40px;min-height:40px}label.field{display:block;font-size:13px;font-weight:700;margin:10px 0 4px}input[type=text],input[type=number],input[type=date],select{width:100%;max-width:100%;min-width:0;font-family:inherit;font-size:16px;border:1.5px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff;color:var(--ink)}input[type=date]{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:block;height:44px;line-height:1.4;text-align:left}input[type=date]::-webkit-date-and-time-value{text-align:left}.field-row{display:flex;gap:10px}.field-row>div{flex:1}.month-head{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;font-weight:800;color:var(--ink-soft);margin:16px 0 6px}.list-item{display:flex;align-items:center;gap:10px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:10px 14px;margin-bottom:8px;width:100%;font-family:inherit;font-size:15px;color:var(--ink);text-align:left;cursor:pointer}.list-item .grow{flex:1;min-width:0}.list-item .title{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item .meta{font-size:12px;color:var(--ink-soft)}.list-item .amount{font-weight:800;font-size:14px;white-space:nowrap}.chip{display:inline-block;font-size:11px;font-weight:700;background:var(--tint-b);color:var(--ink);border-radius:999px;padding:1px 8px;margin-left:6px;vertical-align:middle}.oshi-chips{display:flex;flex-wrap:wrap;gap:8px}.oshi-chip{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:7px 12px;font-family:inherit;font-size:13px;cursor:pointer}.oshi-chip.selected{border-color:var(--pink-deep);background:var(--tint-a);color:var(--pink-text);font-weight:700}textarea.memo{width:100%;max-width:100%;font-family:inherit;font-size:16px;line-height:1.7;border:1.5px solid var(--line);border-radius:10px;padding:10px;background:#fff;color:var(--ink);resize:vertical;min-height:96px}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}.photo-thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;border:1.5px solid var(--line);padding:0;background:#fff;cursor:pointer}.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-add{aspect-ratio:1;border:2px dashed var(--pink);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:400;color:var(--pink-text);background:var(--tint-a);cursor:pointer}.chart{display:flex;gap:8px;align-items:stretch;height:150px;margin-top:8px}.chart-col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:4px;background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.chart-col .bar{width:70%;background:var(--tint-b);border-radius:6px 6px 0 0}.chart-col.selected .bar{background:var(--pink-deep)}.chart-col .m{font-size:11px;font-weight:700;color:var(--ink-soft)}.chart-col.selected .m{color:var(--pink-text)}.cat-row{margin:10px 0}.cat-row .cat-head{display:flex;justify-content:space-between;font-size:14px}.cat-bar{height:8px;background:var(--tint-a);border-radius:999px;overflow:hidden;margin-top:4px}.cat-bar .fill{height:100%;background:var(--pink-deep);border-radius:999px}.dot{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.12);flex-shrink:0}.budget-bar{height:14px;background:var(--tint-a);border-radius:999px;overflow:hidden;margin:8px 0 4px}.budget-bar .fill{height:100%;background:var(--pink-deep);border-radius:999px}.budget-bar .fill.over{background:var(--warn)}.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:8px;margin:6px 0}.swatch{width:100%;aspect-ratio:1;border-radius:50%;border:2px solid rgba(0,0,0,.1);cursor:pointer;padding:0}.swatch.selected{outline:3px solid var(--pink-deep);outline-offset:2px}.records{margin-top:10px}.rec-row{display:flex;align-items:center;gap:8px;border-bottom:1px dashed var(--line);padding:7px 0;font-size:14px}.rec-row .grow{flex:1;min-width:0}.empty{text-align:center;color:var(--ink-soft);font-size:14px;padding:24px 8px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#4a3b448c;display:flex;align-items:center;justify-content:center;padding:calc(20px + env(safe-area-inset-top)) 20px 20px}.modal{background:#fff;border-radius:20px;padding:16px;width:100%;max-width:400px;max-height:90dvh;overflow:auto}.modal img{width:100%;border-radius:12px;border:1px solid var(--line);display:block}.back-row{margin-bottom:10px}.danger{color:#c0392b}.gentle-note{font-size:13px;color:var(--ink-soft);background:var(--tint-a);border-radius:10px;padding:8px 12px}
