:root{--bg: #f1eee7;--surface: #fbfaf6;--surface-2: #e8e4da;--surface-3: #dedad0;--ink: #18170f;--ink-2: #6f6a5e;--ink-3: #a29c8e;--red: #e8442e;--red-ink: #c22c18;--red-soft: #fbe3dd;--ok-ink: #22633f;--ok-soft: #e2ecdd;--border: rgba(24, 23, 15, .1);--radius: 18px;--radius-sm: 12px;--radius-xs: 8px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--nav-height: 72px;--tap: 44px;--shadow: 0 1px 2px rgba(24, 23, 15, .05), 0 4px 16px rgba(24, 23, 15, .06);--shadow-raised: 0 4px 12px rgba(24, 23, 15, .14), 0 12px 32px rgba(24, 23, 15, .16)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none}input,select,textarea{background:var(--surface)}:focus-visible{outline:3px solid var(--red);outline-offset:2px;border-radius:4px}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.money{font-variant-numeric:tabular-nums;letter-spacing:-.01em}.money--neg{color:var(--red-ink)}.shell{min-height:100vh;min-height:100dvh}.shell__main{max-width:640px;margin:0 auto;padding:16px 16px calc(var(--nav-height) + 32px + env(safe-area-inset-bottom))}.sidebar{display:none}@media(min-width:900px){.shell{display:grid;grid-template-columns:232px 1fr}.shell__main{max-width:880px;padding:32px 40px 64px;margin:0;width:100%;justify-self:start}.sidebar{display:flex;flex-direction:column;gap:4px;padding:24px 16px;border-right:1px solid var(--border);background:var(--surface);position:sticky;top:0;height:100vh}.bottom-nav{display:none}}.sidebar__brand{font-weight:800;font-size:20px;letter-spacing:-.02em;padding:8px 12px 20px;display:flex;align-items:center;gap:8px}.sidebar__brand-dot{width:12px;height:12px;border-radius:50%;background:var(--red)}.sidebar__item{display:flex;align-items:center;gap:12px;padding:10px 12px;min-height:var(--tap);border-radius:var(--radius-sm);font-weight:600;font-size:15px;color:var(--ink-2);text-align:left}.sidebar__item:hover{background:var(--surface-2);color:var(--ink)}.sidebar__item[aria-current=page]{background:var(--ink);color:var(--surface)}.sidebar__add{margin-top:16px;background:var(--red);color:#fff;font-weight:700;border-radius:var(--radius-sm);padding:12px;min-height:var(--tap);display:flex;align-items:center;justify-content:center;gap:8px}.sidebar__add:hover{background:var(--red-ink)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:40}.bottom-nav__row{display:grid;grid-template-columns:repeat(5,1fr);align-items:center;height:var(--nav-height);max-width:640px;margin:0 auto}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;height:100%;min-width:var(--tap);font-size:11px;font-weight:600;color:var(--ink-3)}.bottom-nav__item svg{width:24px;height:24px}.bottom-nav__item[aria-current=page]{color:var(--ink)}.bottom-nav__add{width:56px;height:56px;margin:0 auto;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-raised);transform:translateY(-10px)}.bottom-nav__add:active{transform:translateY(-8px) scale(.96)}.bottom-nav__add svg{width:28px;height:28px}.card{background:var(--surface);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card+.card,.stack>*+*{margin-top:12px}.card--flat{box-shadow:none;border:1px solid var(--border)}.card--attention{background:var(--red-soft)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-2 .card+.card{margin-top:0}@media(min-width:900px){.grid-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}.grid-cards .card+.card{margin-top:0}}.page-title{font-size:24px;font-weight:800;letter-spacing:-.02em;margin:8px 0 16px;display:flex;align-items:center;justify-content:space-between;gap:8px}.section-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2);margin:20px 0 8px}.hero{padding:24px 20px;border-radius:var(--radius);background:var(--ink);color:var(--surface);box-shadow:var(--shadow)}.hero__label{font-size:13px;font-weight:600;color:#fbfaf6b3}.hero__amount{font-size:44px;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-top:4px}.hero__amount--warn{color:#ff9d8f}.hero__sub{margin-top:8px;font-size:13px;color:#fbfaf6b3}.big-number{font-size:26px;font-weight:800;letter-spacing:-.02em}.card__label{font-size:13px;font-weight:600;color:var(--ink-2)}.card__hint{font-size:13px;color:var(--ink-2);margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--tap);padding:10px 18px;border-radius:999px;font-weight:700;font-size:15px;background:var(--ink);color:var(--surface);transition:transform 80ms ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:default}.btn--red{background:var(--red);color:#fff}.btn--red:hover{background:var(--red-ink)}.btn--ghost{background:var(--surface-2);color:var(--ink)}.btn--ghost:hover{background:var(--surface-3)}.btn--danger-ghost{background:var(--red-soft);color:var(--red-ink)}.btn--small{min-height:36px;padding:6px 14px;font-size:14px}.btn--block{width:100%}.icon-btn{width:var(--tap);height:var(--tap);display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:var(--ink-2)}.icon-btn:hover{background:var(--surface-2);color:var(--ink)}.row{display:flex;align-items:center;gap:12px;min-height:56px;padding:8px 4px;width:100%;text-align:left;border-radius:var(--radius-sm)}button.row:hover{background:var(--surface-2)}.row+.row{border-top:1px solid var(--border)}.row__icon{width:40px;height:40px;flex:none;border-radius:var(--radius-sm);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:18px}.row__body{flex:1;min-width:0}.row__title{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row__sub{font-size:13px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row__amount{text-align:right;flex:none}.row__amount-main{font-weight:700;font-size:15px}.row__amount-sub{font-size:12px;color:var(--ink-2)}.date-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2);padding:16px 4px 4px}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;background:var(--surface-2);color:var(--ink-2)}.pill--ok{background:var(--ok-soft);color:var(--ok-ink)}.pill--warn{background:var(--red-soft);color:var(--red-ink)}.chip-row{display:flex;gap:8px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:6px 14px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;flex:none}.chip[aria-pressed=true],.chip--active{background:var(--ink);color:var(--surface);border-color:var(--ink)}.bar{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}.bar__fill{height:100%;border-radius:999px;background:var(--ink);transition:width .2s ease}.bar__fill--red{background:var(--red)}.bar__fill--ok{background:var(--ok-ink)}.field{display:block;margin-bottom:14px}.field__label{display:block;font-size:13px;font-weight:700;color:var(--ink-2);margin-bottom:6px}.field input[type=text],.field input[type=number],.field input[type=date],.field select,.field textarea,.input{width:100%;min-height:var(--tap);padding:10px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);font-size:16px}.field input:focus,.field select:focus,.field textarea:focus,.input:focus{outline:none;border-color:var(--ink)}.segment{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;background:var(--surface-2);border-radius:999px;padding:3px}.segment__btn{min-height:38px;border-radius:999px;font-weight:700;font-size:14px;color:var(--ink-2)}.segment__btn[aria-pressed=true]{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:var(--keyboard-inset, 0px);left:0;background:#18170f66;z-index:50;display:flex;align-items:flex-end;justify-content:center;padding-top:24px;overflow:hidden;animation:sheet-backdrop-in .22s ease-out;transition:bottom .22s cubic-bezier(.22,1,.36,1)}.sheet{background:var(--bg);width:100%;max-width:640px;max-height:calc(100dvh - 24px - var(--keyboard-inset, 0px));border-radius:24px 24px 0 0;padding:8px 16px calc(16px + env(safe-area-inset-bottom));overflow-y:auto;box-shadow:0 -10px 32px #18170f2e;overscroll-behavior:contain;transform-origin:bottom center;animation:sheet-slide-up .32s cubic-bezier(.22,1,.36,1);will-change:transform,opacity;-webkit-overflow-scrolling:touch}@media(min-width:900px){.sheet-backdrop{align-items:center}.sheet{border-radius:24px;max-height:85vh;padding:8px 24px 24px;box-shadow:var(--shadow-raised);transform-origin:center;animation-name:sheet-pop-in}}.sheet__handle{width:40px;height:4px;border-radius:2px;background:var(--surface-3);margin:4px auto 8px}.sheet__header{display:flex;align-items:center;justify-content:space-between;min-height:var(--tap);margin-bottom:8px}.sheet__title{font-size:18px;font-weight:800;letter-spacing:-.01em}@keyframes sheet-slide-up{0%{transform:translateY(100%) scale(.98);opacity:.72}60%{transform:translateY(-6px) scale(1);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}@keyframes sheet-pop-in{0%{transform:translateY(12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes sheet-backdrop-in{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){.sheet-backdrop,.sheet{animation:none;transition:none}}.amount-display{text-align:center;padding:12px 0 4px}.amount-display__value{font-size:56px;font-weight:800;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}.amount-display__value--in{color:var(--ok-ink)}.amount-display__hint{font-size:13px;color:var(--ink-2);margin-top:6px}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.keypad__key{min-height:56px;border-radius:var(--radius-sm);background:var(--surface);font-size:24px;font-weight:700;box-shadow:var(--shadow)}.keypad__key:active{background:var(--surface-2)}.keypad__key--muted{background:var(--surface-2);box-shadow:none;font-size:18px}@media(min-width:900px){.keypad{display:none}}.desktop-amount{display:none}@media(min-width:900px){.desktop-amount{display:block}.amount-display{display:none}}.suggestion-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0 8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.suggestion-scroll::-webkit-scrollbar{display:none}.toast-region{position:fixed;bottom:calc(var(--nav-height) + 16px + env(safe-area-inset-bottom));left:16px;right:16px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:70;pointer-events:none}@media(min-width:900px){.toast-region{bottom:24px}}.toast{background:var(--ink);color:var(--surface);border-radius:var(--radius-sm);padding:12px 18px;font-size:14px;font-weight:600;max-width:480px;box-shadow:var(--shadow-raised);animation:toast-in .22s cubic-bezier(.22,1,.36,1);pointer-events:auto}@keyframes toast-in{0%{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}.empty{text-align:center;padding:40px 20px;color:var(--ink-2)}.empty__emoji{font-size:40px;margin-bottom:8px}.empty__title{font-weight:800;font-size:18px;color:var(--ink);margin-bottom:4px}.empty__body{font-size:14px;margin-bottom:16px}.divider{border:none;border-top:1px solid var(--border);margin:12px 0}.month-nav{display:flex;align-items:center;gap:4px}.month-nav__label{font-weight:700;font-size:15px;min-width:130px;text-align:center}.report-bar-row{display:flex;align-items:center;gap:10px;padding:6px 0}.report-bar-row__label{flex:none;width:130px;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-bar-row__track{flex:1}.report-bar-row__value{flex:none;width:80px;text-align:right;font-size:13px;font-weight:700}.view{animation:view-in .18s cubic-bezier(.22,1,.36,1)}@keyframes view-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.check{width:26px;height:26px;flex:none;border-radius:50%;border:2px solid var(--ink-3);background:var(--surface);color:transparent;display:inline-flex;align-items:center;justify-content:center;transition:background .14s ease,border-color .14s ease,transform .14s ease;padding:2px}.check:active{transform:scale(.88)}.check--on{background:var(--ink);border-color:var(--ink);color:var(--surface);animation:check-pop .22s cubic-bezier(.34,1.56,.64,1)}.check svg{width:100%;height:100%;opacity:0;transition:opacity .12s ease}.check--on svg{opacity:1}@keyframes check-pop{0%{transform:scale(.8)}60%{transform:scale(1.12)}to{transform:scale(1)}}.row--done .row__title{text-decoration:line-through;color:var(--ink-3)}.row--done .row__sub{color:var(--ink-3)}.row--leaving,.card--leaving{animation:row-out .2s ease forwards;pointer-events:none}@keyframes row-out{to{opacity:0;transform:translate(24px)}}.badge{position:absolute;top:8px;right:calc(50% - 22px);min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--red);color:#fff;font-size:10.5px;font-weight:800;line-height:17px;text-align:center}.bottom-nav__item,.sidebar__item{position:relative}.sidebar__item .badge{top:50%;right:12px;transform:translateY(-50%)}.sidebar__section{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:14px 12px 4px}.sidebar__foot{margin-top:auto}.capture-input{width:100%;min-height:52px;padding:14px 16px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);font-size:16px}.capture-input:focus{outline:none;border-color:var(--ink)}.capture-preview{margin-top:10px;padding:14px;border-radius:var(--radius-sm);background:var(--surface);border:1.5px solid var(--border);animation:view-in .16s ease}.capture-preview--high{border-color:var(--ok-ink)}.capture-preview--low{border-color:var(--border)}.capture-preview__summary{font-weight:700;font-size:15px}.capture-preview__needs{font-size:13px;color:var(--ink-2);margin-top:4px}.capture-examples{display:grid;gap:6px;margin-top:14px}.capture-examples__item{text-align:left;font-size:14px;color:var(--ink-2);padding:10px 12px;border-radius:var(--radius-xs);background:var(--surface);border:1px solid var(--border)}.capture-examples__item:hover{background:var(--surface-2);color:var(--ink)}.hero__stats{display:flex;gap:8px;margin-top:16px}.hero__stat{flex:1;background:#fbfaf617;border-radius:var(--radius-sm);padding:10px 12px;text-align:left;color:var(--surface)}.hero__stat:hover{background:#fbfaf629}.hero__stat-label{font-size:11.5px;font-weight:600;color:#fbfaf6a6}.hero__stat-value{font-size:16px;font-weight:800;margin-top:2px}.home-date{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);margin:8px 0 2px}.home-greeting{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:14px}.card__head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.card__head .card__label{margin:0}.card__link{font-size:13px;font-weight:700;color:var(--ink-2);min-height:32px;padding:4px 10px;border-radius:999px}.card__link:hover{background:var(--surface-2);color:var(--ink)}.more-list .row__icon{background:var(--surface-2);color:var(--ink);padding:8px}.more-list .row__icon svg{width:22px;height:22px}.event-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex:none}.audit-line{display:flex;gap:10px;align-items:baseline;padding:8px 4px;font-size:13.5px;border-top:1px solid var(--border)}.audit-line:first-child{border-top:none}.audit-line__when{flex:none;color:var(--ink-3);font-size:12px;min-width:64px}.member-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-weight:700;font-size:14px}.member-chip__dot{width:10px;height:10px;border-radius:50%}.login{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login__card{width:100%;max-width:400px;background:var(--surface);border-radius:var(--radius);padding:32px 28px;box-shadow:var(--shadow);animation:view-in .22s cubic-bezier(.22,1,.36,1)}.login__title{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}.login__body{font-size:15px;color:var(--ink-2);margin-bottom:20px;line-height:1.5}.sync-dot{width:8px;height:8px;border-radius:50%;flex:none;display:inline-block}.sync-dot--synced{background:var(--ok-ink)}.sync-dot--connecting{background:var(--ink-3)}.sync-dot--offline{background:var(--red)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
