@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=Manrope:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500&display=swap";:root{--paper: #f7f1e8;--paper-strong: #fffaf3;--ink: #1d1710;--ink-soft: #5f5345;--line: #d7c6b1;--accent: #c14e2f;--accent-soft: #f8e2d9;--ok: #1b6f4b;--ok-soft: #ddefe4;--warn: #9a2a24;--warn-soft: #f7deda;--pending: #7f5c22;--pending-soft: #f5ebd4;--shadow-sm: 0 1px 3px rgb(73 48 24 / 8%);--shadow: 0 4px 16px rgb(73 48 24 / 10%);--radius-lg: 16px;--radius-sm: 10px;--tab-bar-h: 3.5rem;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:var(--ink);background:var(--paper)}.app-shell{position:relative;max-width:600px;margin:0 auto;padding-bottom:calc(var(--tab-bar-h) + var(--safe-bottom) + .5rem);min-height:100dvh}.app-shell--guest{padding-bottom:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem 1rem;border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:20}.brand-title{margin:0;font-family:Fraunces,Georgia,serif;font-size:1.35rem;line-height:1;flex-shrink:0}.desktop-nav{display:none}.topbar-right{display:flex;align-items:center;gap:.5rem}.session-chip{padding:.25rem .6rem;border-radius:999px;background:var(--accent-soft);color:var(--ink-soft);font-size:.72rem;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-button{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--line);border-radius:999px;background:transparent;color:var(--ink-soft);cursor:pointer;transition:color .12s ease,border-color .12s ease}.logout-button:hover{color:var(--warn);border-color:var(--warn)}.logout-button:disabled{opacity:.5;cursor:progress}.tab-bar{position:fixed;bottom:0;left:0;right:0;z-index:30;display:flex;height:calc(var(--tab-bar-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#f7f1e8e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line)}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;font-size:.68rem;font-weight:600;color:var(--ink-soft);text-decoration:none;transition:color .12s ease;-webkit-tap-highlight-color:transparent}.tab.active{color:var(--accent)}.page-wrap{padding:0 1rem}.page{display:grid;gap:.75rem;animation:fade-up .3s ease both;padding-top:.75rem}.panel{border-radius:var(--radius-lg);background:var(--paper-strong);box-shadow:var(--shadow-sm);padding:1rem}.quick-add{position:sticky;top:0;z-index:10;padding:.75rem 0;background:var(--paper)}.quick-add-form{display:flex;gap:.5rem}.quick-add-input{flex:1;min-width:0;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;padding:.7rem .85rem;background:var(--paper-strong);color:var(--ink);font-size:.95rem}.quick-add-input:focus{outline:2px solid var(--accent);outline-offset:1px}.quick-add-button{flex-shrink:0;border:0;border-radius:var(--radius-sm);background:var(--ink);color:#fff;font:inherit;font-weight:700;font-size:.85rem;padding:.7rem 1rem;cursor:pointer;white-space:nowrap;transition:opacity .12s ease}.quick-add-link{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:var(--radius-sm);background:var(--ink);color:#fff;text-decoration:none;font:inherit;font-weight:700;padding:.7rem 1rem}.quick-add-button:disabled{opacity:.55;cursor:progress}.feedback{margin:.5rem 0 0;color:var(--ink-soft);font-size:.88rem}.feedback.error{color:var(--warn)}.feedback.success{color:var(--ok)}.panel-header{display:flex;align-items:flex-end;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.panel-header h2{margin:.15rem 0 0;font-family:Fraunces,Georgia,serif;font-size:1.15rem;line-height:1.1}.panel-kicker{margin:0;font-family:IBM Plex Mono,monospace;text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;color:var(--ink-soft)}.panel-count{margin:0;font-size:.8rem;color:var(--ink-soft);white-space:nowrap}.filters{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.filter-field{display:grid;gap:.3rem;font-size:.82rem;color:var(--ink-soft)}.filter-field input,.filter-field select,.filter-field textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;padding:.65rem .75rem;background:var(--paper-strong);color:var(--ink)}.filter-field input:focus,.filter-field select:focus,.filter-field textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.expense-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}.expense-item{display:flex;justify-content:space-between;gap:.75rem;border-radius:var(--radius-sm);padding:.75rem;background:#ffffff8c;transition:background .12s ease}.expense-main{min-width:0;flex:1}.expense-title{margin:0;font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-meta{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center;margin:.25rem 0 0;color:var(--ink-soft);font-size:.78rem}.expense-category{display:inline-flex;padding:.15rem .4rem;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:.72rem}.expense-side{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.expense-amount{margin:0;font-family:IBM Plex Mono,monospace;font-weight:500;font-size:.95rem}.status-copy{margin:0;display:inline-flex;align-items:center;gap:.3rem;font-size:.68rem;padding:.15rem .4rem;border-radius:999px}.status-copy.pending{color:var(--pending);background:var(--pending-soft)}.status-copy.resolved{color:var(--ok);background:var(--ok-soft)}.status-copy.failed{color:var(--warn);background:var(--warn-soft)}.expense-edit-button{border:1px solid var(--line);border-radius:999px;background:transparent;color:var(--ink-soft);font:inherit;font-size:.72rem;font-weight:600;padding:.25rem .55rem;cursor:pointer;min-height:28px;transition:color .12s ease,border-color .12s ease}.expense-edit-button:hover{border-color:var(--accent);color:var(--accent)}.spinner{width:.6rem;height:.6rem;border-radius:999px;border:2px solid rgb(127 92 34 / 30%);border-top-color:var(--pending);animation:spin .7s linear infinite}.empty-state{border:1px dashed var(--line);border-radius:var(--radius-sm);background:#ffffff59;padding:1.25rem 1rem;text-align:center}.empty-state h3{margin:0;font-family:Fraunces,Georgia,serif;font-size:1rem}.empty-state p{margin:.3rem 0 0;color:var(--ink-soft);font-size:.88rem}.login-panel{max-width:380px;margin:0 auto}.login-panel h2{margin:0 0 .25rem;font-family:Fraunces,Georgia,serif}.login-form{display:grid;gap:.7rem;margin-top:.75rem}.login-form .quick-add-button{width:100%}.sent-panel{border:1px solid rgb(27 111 75 / 25%);background:linear-gradient(160deg,#f7fcf9,#eef8f2)}.sent-panel-actions{margin-top:.75rem}.auth-error-panel{max-width:380px;margin:0 auto}.auth-error-panel p{color:var(--ink-soft)}.auth-error-actions{margin-top:.75rem}.edit-expense-backdrop{position:fixed;inset:0;z-index:40;background:#140d0873;display:flex;align-items:flex-end;justify-content:center;animation:backdrop-in .2s ease both}.edit-expense-modal{width:100%;max-height:85dvh;overflow:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--paper-strong);padding:.5rem 1rem 1.25rem;animation:sheet-up .28s ease both}.sheet-handle{width:2.5rem;height:.25rem;border-radius:999px;background:var(--line);margin:.25rem auto .75rem}.edit-expense-header h3{margin:.15rem 0 0;font-family:Fraunces,Georgia,serif;font-size:1.1rem}.edit-expense-raw{margin:.35rem 0 0;color:var(--ink-soft);font-size:.82rem}.edit-expense-form{margin-top:.75rem;display:grid;gap:.65rem}.edit-note-field textarea{min-height:80px;resize:vertical}.edit-expense-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}.edit-expense-actions>button,.edit-expense-actions>.delete-confirm{width:100%}.delete-confirm{display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;background:var(--warn-soft);border-radius:var(--radius-sm);animation:fade-up .2s ease both}.delete-confirm span{flex:1;font-size:.85rem;font-weight:600;color:var(--warn)}.nav-button{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper-strong);color:var(--ink);font:inherit;font-weight:600;padding:.6rem 1rem;cursor:pointer}.nav-button:disabled{opacity:.55;cursor:progress}.danger-button{border:1px solid var(--warn);border-radius:var(--radius-sm);background:var(--warn);color:#fff;font:inherit;font-size:.85rem;font-weight:700;padding:.6rem 1rem;cursor:pointer}.danger-button.ghost{background:transparent;color:var(--warn)}.danger-button:disabled{opacity:.55;cursor:progress}.landing{display:flex;flex-direction:column;gap:2rem;padding:2.5rem 1.25rem 3rem;animation:fade-up .4s ease both}.landing-hero{text-align:center}.landing-title{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(2.5rem,10vw,3.5rem);line-height:1;color:var(--ink)}.landing-tagline{margin:.5rem 0 0;font-size:1.1rem;color:var(--ink-soft)}.landing-description{margin:1rem auto 0;max-width:360px;color:var(--ink-soft);font-size:.92rem;line-height:1.5}.landing-actions{margin-top:1.5rem}.landing-cta{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 2rem;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font:inherit;font-weight:700;font-size:1rem;text-decoration:none;transition:opacity .12s ease}.landing-cta:hover{opacity:.9}.landing-features{display:grid;gap:1rem;max-width:400px;margin:0 auto}.landing-feature{padding:1rem;border-radius:var(--radius-lg);background:var(--paper-strong);box-shadow:var(--shadow-sm)}.landing-feature h3{margin:0;font-family:Fraunces,Georgia,serif;font-size:1rem}.landing-feature p{margin:.3rem 0 0;color:var(--ink-soft);font-size:.88rem;line-height:1.45}@media(min-width:768px){.app-shell{max-width:640px;padding-bottom:1rem}.desktop-nav{display:flex;gap:.25rem;margin-left:.5rem}.desktop-nav-link{padding:.35rem .75rem;border-radius:999px;text-decoration:none;font-weight:600;font-size:.85rem;color:var(--ink-soft);transition:color .12s ease,background-color .12s ease}.desktop-nav-link:hover{color:var(--ink);background:#0000000a}.desktop-nav-link.active{color:var(--accent);background:var(--accent-soft)}.tab-bar{display:none}.panel{padding:1.25rem}.edit-expense-backdrop{align-items:center}.edit-expense-modal{width:min(500px,92%);max-height:calc(100dvh - 3rem);border-radius:var(--radius-lg);animation:fade-up .22s ease both}.sheet-handle{display:none}.edit-expense-actions{flex-direction:row;justify-content:flex-end}.edit-expense-actions>button{width:auto}.landing-features{grid-template-columns:1fr 1fr 1fr;max-width:640px}.landing{padding-top:4rem}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes sheet-up{0%{opacity:0;transform:translateY(40%)}to{opacity:1;transform:translateY(0)}}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}
