:root{color-scheme:light;font-family:SF Pro Text,SF Pro Display,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;background:#f7f5f2;color:#171717;--surface-muted: #f7f5f2;--surface: #ffffff;--surface-soft: #f8f6f2;--surface-strong: #171717;--text-primary: #171717;--text-secondary: #5f5a54;--text-tertiary: #a49d96;--text-inverse: #ffffff;--border: #ece7e1;--border-soft: #f2ede8;--shadow: 0 20px 48px rgba(23, 23, 23, .06);--shadow-soft: 0 10px 28px rgba(23, 23, 23, .035);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100%;margin:0}html{-webkit-text-size-adjust:100%}body{min-height:100dvh;background:var(--surface-muted);color:var(--text-primary);overscroll-behavior:none}button,input{font:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent}button{border:0;padding:0;background:none;color:inherit}input{border:0;outline:0;background:transparent;color:inherit}.app-frame{height:100dvh;min-height:100dvh;padding:12px;background:var(--surface-muted)}.phone-shell{width:min(100%,390px);height:calc(100dvh - 24px);min-height:calc(100dvh - 24px);margin:0 auto;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border-soft);border-radius:34px;box-shadow:var(--shadow);overflow:hidden}.screen{height:100%;min-height:calc(100dvh - 24px);display:flex;flex-direction:column;background:var(--surface);padding-top:calc(env(safe-area-inset-top) + 24px)}.screen__header{padding:0 22px 18px;border-bottom:1px solid var(--border-soft)}.screen__body{flex:1;min-height:0;padding:22px;overflow-y:auto;-webkit-overflow-scrolling:touch}.screen__body--stack{display:flex;flex-direction:column;gap:20px}.screen__body--list{display:flex;flex-direction:column;gap:12px}.screen__body--grouped{display:flex;flex-direction:column;gap:16px}.screen__footer{flex-shrink:0;padding:14px 22px 22px;padding-bottom:max(env(safe-area-inset-bottom),22px);border-top:1px solid var(--border-soft);background:var(--surface)}.screen__footer--nav{padding-top:12px}.header-split,.header-triple{display:flex;align-items:center;justify-content:space-between;gap:16px}.header-split{margin-bottom:4px}.header-split--start{align-items:flex-start}.header-triple{min-height:32px}.header-triple--list{margin-bottom:16px}.eyebrow,.section-label{font-size:11px;line-height:1.2;letter-spacing:.24em;text-transform:uppercase;color:var(--text-tertiary)}.section-label{margin-bottom:8px}.screen-title{margin:0;font-size:31px;line-height:1;font-weight:600;letter-spacing:-.04em}.circle-button{width:44px;height:44px;display:grid;place-items:center;border-radius:999px;border:1px solid var(--border);background:var(--surface-soft);box-shadow:var(--shadow-soft);color:var(--text-secondary);font-size:1.25rem}.add-button{width:56px;height:56px;display:grid;place-items:center;border-radius:999px;background:var(--surface-strong);color:var(--text-inverse);font-size:2rem;line-height:1;box-shadow:0 10px 24px #17171724}.add-button--thumb{width:64px;height:64px;flex:0 0 auto}.header-text-button{font-size:.95rem;color:var(--text-secondary)}.header-text-button--strong{color:var(--text-primary);font-weight:600}.header-spacer{min-width:52px}.header-text-button:disabled{color:var(--text-tertiary)}.screen-stack{display:flex;flex-direction:column;gap:12px}.screen-stack--compact{gap:8px}.amount-card{width:100%;min-height:104px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:20px;border-radius:28px;border:1px solid var(--border-soft);background:var(--surface-soft);box-shadow:var(--shadow-soft);text-align:left}.amount-card--interactive{cursor:pointer}.amount-card__currency{margin-bottom:4px;font-size:.95rem;color:var(--text-tertiary)}.amount-card__currency--center{margin-bottom:8px;text-align:center}.amount-card__value,.amount-screen__value,.detail-summary__amount{font-size:3rem;line-height:.95;font-weight:600;letter-spacing:-.04em}.amount-card__action{font-size:.95rem;color:var(--text-tertiary)}.quick-grid,.toggle-grid{display:grid;gap:12px}.quick-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.toggle-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.owner-switch{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));border:1px solid var(--border-soft);border-radius:24px;overflow:hidden;background:var(--surface)}.owner-switch--two{grid-template-columns:repeat(2,minmax(0,1fr))}.owner-switch__item{min-height:52px;padding:10px 12px;border-right:1px solid var(--border-soft);color:var(--text-secondary);font-size:.92rem;font-weight:500;background:transparent}.owner-switch__item:last-child{border-right:0}.owner-switch__item--active{background:var(--surface-strong);color:var(--text-inverse)}.owner-switch--quiet{border-color:var(--border-soft);background:var(--surface-soft)}.owner-switch--quiet .owner-switch__item{min-height:48px;color:var(--text-tertiary);border-right-color:var(--border-soft)}.owner-switch--quiet .owner-switch__item--active{background:var(--surface);color:var(--text-primary);font-weight:600}.chip-wrap{display:flex;flex-wrap:wrap;gap:8px}.chip-wrap--categories,.category-section{margin-top:6px}.watch-hint{margin-top:10px;padding:0 4px;font-size:.9rem;color:var(--text-tertiary)}.watch-hint--near,.watch-hint--over{color:var(--text-secondary)}.chip,.toggle-button,.bottom-nav__item{min-height:44px;padding:10px 16px;border-radius:999px;border:1px solid var(--border-soft);background:var(--surface-soft);color:var(--text-secondary);font-size:.95rem;font-weight:500}.chip--block{width:100%;border-radius:18px;text-align:center}.chip--category{min-height:38px;padding:8px 12px;font-size:.88rem;font-weight:500}.chip:disabled{opacity:.34}.chip--active,.toggle-button--active,.bottom-nav__item--active{background:var(--surface-strong);border-color:var(--surface-strong);color:var(--text-inverse)}.toggle-button{min-height:56px;border-radius:24px}.field-row{position:relative;width:100%;min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:24px;border:1px solid var(--border-soft);background:var(--surface-soft);text-align:left}.field-row--interactive,.field-row--action{cursor:pointer}.field-row--input{align-items:center}.field-row__label{font-size:.95rem;color:var(--text-primary)}.field-row__value{margin-top:4px;font-size:.95rem;color:var(--text-tertiary)}.field-row__chevron{font-size:1.4rem;color:#d4d4d4}.field-row__date-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0}.field-row__text-input{width:52%;font-size:16px;color:var(--text-secondary);text-align:right}.field-row__text-input::placeholder{color:var(--text-tertiary)}.note-row{padding-right:16px}.note-row--inline{min-height:60px}.note-row__input{width:48%;font-size:16px;color:var(--text-secondary);text-align:right}.note-row__input::placeholder,.search-field input::placeholder{color:var(--text-tertiary)}.button{width:100%;min-height:56px;padding:16px 20px;border-radius:24px;font-size:1rem;font-weight:600}.button--compact{min-height:52px}.button--primary{background:var(--surface-strong);color:var(--text-inverse);box-shadow:0 10px 24px #1717171f}.button--secondary{background:var(--surface-soft);color:var(--text-secondary)}.button--tertiary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.button:disabled{background:#d4d4d4;color:#fafafa}.saved-screen{align-items:center;justify-content:center;gap:8px;padding:calc(env(safe-area-inset-top) + 24px) 20px 24px;padding-bottom:max(env(safe-area-inset-bottom),24px);text-align:center}.saved-screen__icon{width:72px;height:72px;display:grid;place-items:center;border-radius:999px;background:var(--surface-strong);color:var(--text-inverse);box-shadow:var(--shadow-soft);margin-bottom:4px}.saved-screen__icon svg{width:28px;height:28px}.saved-screen__title{margin:0;font-size:2rem;line-height:1.05;letter-spacing:-.03em;font-weight:600}.saved-screen__context{max-width:240px;margin:0 0 20px;color:var(--text-secondary);line-height:1.5}.saved-screen__actions,.footer-stack{display:flex;flex-direction:column;gap:12px}.footer-action-row{display:flex;align-items:center;gap:12px}.footer-action-row .button{flex:1 1 auto}.footer-action-row--end{justify-content:flex-end}.date-note-stack{display:flex;flex-direction:column;gap:10px}.date-note-row{display:flex;align-items:stretch;gap:10px}.date-note-row__date{flex:1 1 auto}.note-icon-button{width:60px;min-width:60px;min-height:68px;display:grid;place-items:center;border-radius:24px;border:1px solid var(--border-soft);background:var(--surface-soft);color:var(--text-tertiary)}.note-icon-button svg{width:20px;height:20px}.note-icon-button--active{background:var(--surface-strong);border-color:var(--surface-strong);color:var(--text-inverse)}.settings-action-grid{display:flex;flex-direction:column;gap:12px}.settings-action-grid--split{flex-direction:row}.settings-action-grid--split .button{flex:1 1 0}.total-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}.total-grid--stack{grid-template-columns:1fr}.total-card{padding:14px 16px;border-radius:24px;background:var(--surface-soft);box-shadow:var(--shadow-soft)}.total-card--dark{background:var(--surface-strong);color:var(--text-inverse)}.total-card__label,.detail-summary__meta,.detail-summary__date,.entry-card__meta,.amount-screen__context{color:var(--text-tertiary);font-size:.95rem}.total-card--dark .total-card__label{color:#a3a3a3}.total-card__amount{margin-top:8px;font-size:clamp(1.45rem,6.2vw,1.85rem);line-height:1;font-weight:600;letter-spacing:-.04em;font-variant-numeric:tabular-nums;white-space:nowrap}.calm-note{padding:18px 16px;border-radius:22px;background:var(--surface-soft);font-size:.95rem;color:var(--text-tertiary);text-align:center}.owner-balance-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border:0;border-radius:24px;background:var(--surface-soft);-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;text-align:left;cursor:pointer;box-shadow:var(--shadow-soft)}.owner-balance-row:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}.owner-balance-row__title{font-size:.95rem;font-weight:500}.owner-balance-row__meta{margin-top:4px;font-size:.9rem;color:var(--text-tertiary)}.owner-balance-row__value{flex:0 0 auto;text-align:right}.owner-balance-row__amount{font-size:.95rem;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.owner-balance-row__state{margin-top:2px;font-size:.82rem;color:var(--text-tertiary);line-height:1.2}.watch-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-soft);background:transparent}.watch-list{display:flex;flex-direction:column;gap:0}.watch-row:first-child{border-top:1px solid var(--border-soft)}.watch-row__title{font-size:.92rem;font-weight:500;line-height:1.2}.watch-row__meta{margin-top:2px;font-size:.84rem;color:var(--text-tertiary);line-height:1.2}.watch-row__amount{flex:0 0 auto;padding-top:1px;font-size:.9rem;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap;line-height:1.2}.watch-row--near .watch-row__amount,.watch-row--over .watch-row__amount{color:var(--text-primary)}.entry-card{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:24px;border:1px solid var(--border);background:var(--surface);text-align:left;box-shadow:var(--shadow-soft)}.entry-card--selection{cursor:pointer}.entry-card--selected{border-color:var(--text-primary);background:var(--surface-soft)}.entry-card__text{min-width:0}.entry-card__right{flex:0 0 auto;display:flex;align-items:center;gap:10px}.entry-card__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:500}.entry-card__meta{margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-card__amount{white-space:nowrap;padding-top:2px;font-size:.92rem;font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--text-secondary)}.entry-card__amount--strong{color:var(--text-primary)}.entry-card__selection-indicator{width:22px;height:22px;display:grid;place-items:center;border-radius:999px;border:1px solid var(--border);color:transparent;font-size:.75rem;line-height:1;flex:0 0 auto}.entry-card__selection-indicator--selected{border-color:var(--text-primary);background:var(--surface-strong);color:var(--text-inverse)}.empty-state{padding:18px 16px;border-radius:22px;background:var(--surface-soft);font-size:.95rem;color:var(--text-tertiary);text-align:center}.search-field{display:block;width:100%;min-height:64px;padding:0 16px;border-radius:24px;border:1px solid var(--border-soft);background:var(--surface-soft)}.search-field input{width:100%;min-height:64px;font-size:16px}.bottom-nav-wrap{border:1px solid var(--border-soft);border-radius:24px;background:#fffffff5;padding:8px;box-shadow:var(--shadow-soft)}.bottom-nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px}.bottom-nav__item{display:grid;align-items:center;justify-items:center;min-height:56px;padding:8px;border-color:transparent;background:transparent}.bottom-nav__item.bottom-nav__item--active{background:var(--surface-strong);border-color:var(--surface-strong);color:var(--text-inverse);box-shadow:inset 0 0 0 1px #ffffff0d}.bottom-nav__icon{width:21px;height:21px;flex:0 0 auto}.amount-screen__summary{padding:30px 24px 18px;text-align:center}.amount-screen__status{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}.amount-screen__base{min-height:20px;font-size:.9rem;color:var(--text-tertiary)}.amount-screen__clear{color:var(--text-secondary);font-size:.92rem}.amount-screen__chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:0 24px 10px}.amount-screen__body{display:flex;align-items:flex-end}.keypad{width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.keypad__key{min-height:76px;border-radius:24px;border:1px solid var(--border-soft);background:var(--surface-soft);font-size:2rem;font-weight:500;box-shadow:var(--shadow-soft)}.keypad__key--soft{border-color:var(--border-soft);background:#f1ede7;color:var(--text-secondary)}.detail-header{margin-bottom:20px}.detail-summary{text-align:center}.detail-summary__date{margin-top:10px}@media(max-width:480px){.app-frame{height:100dvh;padding:0;background:var(--surface)}.phone-shell{width:100%;height:100dvh;min-height:100dvh;border:0;border-radius:0;box-shadow:none}.screen{height:100dvh;min-height:100dvh}}
