:root{--canvas: #f5f7f4;--surface: #ffffff;--surface-subtle: #eef3ef;--ink: #17231d;--muted: #647169;--border: #dce5df;--brand: #146b4a;--brand-dark: #0e5238;--positive: #19764f;--warning: #a86612;--negative: #b64235;--info: #366a91;--shadow: 0 18px 50px rgb(22 47 35 / 10%)}*{box-sizing:border-box}[hidden]{display:none!important}html{color-scheme:light}body{margin:0;color:var(--ink);background:var(--canvas);font:14px/1.5 Inter,Geist,system-ui,sans-serif}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}a{color:var(--brand);text-decoration:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgb(54 106 145 / 28%);outline-offset:2px}h1,h2,h3,p{margin-top:0}h1,h2,h3,.metric-value,.amount{font-variant-numeric:tabular-nums}.eyebrow{margin-bottom:6px;color:var(--muted);font-size:11px;font-weight:750;letter-spacing:.12em;text-transform:uppercase}.muted,small{color:var(--muted)}.brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink);font-size:17px;font-weight:800;letter-spacing:-.02em}.brand-mark{display:grid;width:34px;height:34px;place-items:center;border-radius:10px;color:#fff;background:var(--brand);font-size:12px;letter-spacing:.04em}.button,.icon-button,.avatar-button{min-height:44px;border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px}.button.primary{color:#fff;background:var(--brand)}.button.primary:hover{background:var(--brand-dark)}.button.secondary,.icon-button,.avatar-button{color:var(--ink);background:var(--surface);border-color:var(--border)}.button.ghost{color:var(--brand);background:transparent}.button.danger{color:var(--negative);background:#fff7f5;border-color:#f0d2cc}.help-tip{display:inline-grid;width:18px;height:18px;place-items:center;border:1px solid var(--border);border-radius:50%;color:var(--muted);font-size:11px;cursor:help}.icon-button{width:44px;padding:0;font-size:20px}.avatar-button{padding:0 14px}.surface{border:1px solid var(--border);border-radius:16px;background:var(--surface)}.auth-body{min-height:100vh;background:var(--surface)}.auth-shell{display:grid;min-height:100vh;grid-template-columns:minmax(360px,.9fr) minmax(480px,1.1fr)}.auth-story{display:flex;flex-direction:column;justify-content:space-between;padding:48px clamp(32px,6vw,88px);background:var(--surface-subtle);border-right:1px solid var(--border)}.auth-story h1{max-width:620px;margin-bottom:20px;font-size:clamp(38px,5vw,64px);line-height:1.02;letter-spacing:-.055em}.auth-lead{max-width:500px;color:var(--muted);font-size:17px}.fine-print{color:var(--muted);font-size:12px}.auth-panel{display:grid;padding:32px;place-items:center}.auth-form{display:grid;width:min(100%,420px);gap:18px}.auth-form h2{margin-bottom:8px;font-size:30px;letter-spacing:-.04em}label{display:grid;gap:7px;color:var(--muted);font-size:12px;font-weight:650}input,select,textarea{width:100%;min-height:44px;padding:10px 12px;color:var(--ink);background:var(--surface);border:1px solid var(--border);border-radius:9px}textarea{min-height:96px;resize:vertical}.form-switch{margin:0;color:var(--muted);text-align:center}.form-error{min-height:21px;margin:0;color:var(--negative);font-size:13px}.center-shell{display:grid;min-height:100vh;padding:32px;place-content:center;gap:24px}.invite-card{width:min(100vw - 32px,520px);padding:32px}.app-shell{display:grid;min-height:100vh;grid-template-columns:252px minmax(0,1fr)}.sidebar{position:fixed;inset:0 auto 0 0;z-index:10;display:flex;width:252px;padding:24px 16px;flex-direction:column;background:var(--surface);border-right:1px solid var(--border)}.family-chip{display:grid;gap:2px;margin:28px 0 20px;padding:12px;border-radius:12px;background:var(--surface-subtle)}.family-chip span{color:var(--muted);font-size:11px}.family-chip strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-list{display:grid;gap:3px}.nav-list a{display:flex;min-height:44px;padding:10px 12px;align-items:center;gap:11px;color:var(--muted);border-radius:10px;font-weight:650}.nav-list a span{width:20px;color:currentColor;text-align:center}.nav-list a:hover,.nav-list a.active{color:var(--brand);background:var(--surface-subtle)}.sync-card{display:flex;margin-top:auto;padding:12px;align-items:flex-start;gap:9px;border:1px solid var(--border);border-radius:12px}.sync-card div{display:grid}.sync-card small{line-height:1.3}.status-dot{width:8px;height:8px;margin-top:6px;border-radius:50%;background:var(--positive)}.status-dot.warning{background:var(--warning)}.app-main{grid-column:2;min-width:0}.topbar{position:sticky;top:0;z-index:8;display:flex;min-height:84px;padding:16px 32px;align-items:center;justify-content:space-between;background:#f5f7f4eb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar h1{margin:0;font-size:28px;line-height:1.1;letter-spacing:-.04em}.topbar-actions,.page-actions,.inline-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-content{width:min(100%,1440px);padding:28px 32px 64px}.page-heading{display:flex;margin-bottom:22px;align-items:end;justify-content:space-between;gap:24px}.page-heading h2{margin-bottom:6px;font-size:21px;letter-spacing:-.03em}.metric-grid{display:grid;margin-bottom:20px;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric-card{min-width:0;padding:18px;border:1px solid var(--border);border-radius:14px;background:var(--surface)}.metric-card span{display:block;margin-bottom:8px;color:var(--muted);font-size:12px}.metric-value{display:block;overflow:hidden;font-size:clamp(21px,2.3vw,29px);letter-spacing:-.045em;text-overflow:ellipsis;white-space:nowrap}.metric-card small{display:block;margin-top:5px}.content-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.75fr);gap:16px}.stack{display:grid;align-content:start;gap:16px}.panel{min-width:0;padding:20px;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.panel-header{display:flex;margin-bottom:18px;align-items:start;justify-content:space-between;gap:16px}.panel-header h2,.panel-header h3{margin-bottom:4px;font-size:17px;letter-spacing:-.025em}.status-banner{display:flex;margin-bottom:20px;padding:14px 16px;align-items:center;justify-content:space-between;gap:16px;border:1px solid #d4e5db;border-radius:13px;background:#f0f7f3}.status-banner.warning{border-color:#ead8ba;background:#fff9ef}.status-banner p{margin:0}.financial-table-wrap{overflow:auto}.financial-table{width:100%;border-collapse:collapse}.financial-table th,.financial-table td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.financial-table th{color:var(--muted);font-size:11px;letter-spacing:.05em;text-transform:uppercase}.financial-table .amount{text-align:right;white-space:nowrap}.transaction-button{width:100%;padding:0;color:inherit;background:none;border:0;cursor:pointer;text-align:left}.transaction-title{display:block;max-width:300px;overflow:hidden;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.pill{display:inline-flex;min-height:25px;padding:3px 8px;align-items:center;gap:5px;color:var(--muted);background:var(--surface-subtle);border-radius:999px;font-size:11px;font-weight:700}.pill.warning{color:#7b4a08;background:#fff3dc}.pill.positive{color:var(--positive);background:#eaf7ef}.positive-text{color:var(--positive)}.negative-text{color:var(--negative)}.filters{display:grid;margin-bottom:16px;padding:14px;grid-template-columns:minmax(220px,1.5fr) repeat(4,minmax(140px,.7fr));gap:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface)}.filters input,.filters select{min-width:0}.category-list,.connection-list,.member-list,.invitation-list{display:grid;gap:10px}.category-row,.connection-row,.member-row,.invitation-row{display:grid;padding:15px;align-items:center;gap:14px;border:1px solid var(--border);border-radius:13px;background:var(--surface)}.category-row{grid-template-columns:minmax(150px,.8fr) minmax(200px,1.4fr) auto auto}.member-row,.invitation-row{grid-template-columns:minmax(180px,1fr) auto auto}.connection-row{grid-template-columns:minmax(180px,1fr) auto auto auto}.credit-cycle-panel{margin-top:22px}.credit-cycle-row{grid-template-columns:minmax(180px,1fr) auto minmax(210px,.8fr) auto}.progress-track{height:8px;overflow:hidden;border-radius:999px;background:var(--surface-subtle)}.progress-track>span{display:block;height:100%;border-radius:inherit;background:var(--brand)}.goal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.goal-card{display:grid;min-height:250px;padding:22px;align-content:space-between;gap:22px;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.goal-card.primary{grid-column:1 / -1;min-height:280px;background:#f0f7f3;border-color:#cfe1d6}.goal-card.empty{place-content:center;color:var(--muted);border-style:dashed;text-align:center}.goal-card h2{margin-bottom:8px;font-size:24px;letter-spacing:-.04em}.goal-numbers{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}.history-chart{display:flex;min-height:190px;padding-top:18px;align-items:end;gap:10px;border-bottom:1px solid var(--border)}.history-column{display:grid;min-width:44px;height:170px;flex:1;align-items:end;gap:3px}.history-column div{display:flex;height:135px;align-items:end;gap:3px}.history-column i{display:block;width:50%;min-height:2px;border-radius:5px 5px 0 0;background:var(--brand)}.history-column i.expense{background:#d9a39b}.history-column small{overflow:hidden;text-align:center;text-overflow:ellipsis}.empty-state{display:grid;min-height:180px;padding:24px;place-content:center;color:var(--muted);text-align:center}.empty-state h3{margin-bottom:6px;color:var(--ink)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#17231d47}.drawer{position:fixed;inset:0 0 0 auto;z-index:31;width:min(100%,500px);padding:24px;overflow:auto;background:var(--surface);box-shadow:var(--shadow)}.drawer-header{display:flex;margin-bottom:24px;align-items:start;justify-content:space-between;gap:16px}.drawer form{display:grid;gap:16px}.classification-explanation{display:grid;gap:10px;margin-bottom:22px;padding:16px;border:1px solid color-mix(in srgb,var(--positive) 24%,transparent);border-radius:14px;background:color-mix(in srgb,var(--positive) 7%,var(--surface))}.classification-explanation .pill{justify-self:start}.classification-explanation p,.classification-explanation small{margin:4px 0 0;color:var(--muted)}.pagination{display:flex;margin-top:20px;align-items:center;justify-content:center;gap:12px}#transaction-pagination[aria-busy=true]{opacity:.55;pointer-events:none}.pagination select{width:auto;min-width:72px}.filter-summary{margin-bottom:20px;grid-template-columns:repeat(3,minmax(0,1fr))}.category-open-link{display:block;color:inherit}.category-open-link small{display:block}.rule-preview-list,.investment-list{display:grid;margin-bottom:20px;gap:10px}.rule-preview-list article,.investment-row{display:grid;padding:12px;align-items:center;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;border:1px solid var(--border);border-radius:12px}.rule-preview-list small,.investment-row small{display:block;margin-top:4px;color:var(--muted)}.check-row{display:flex;min-height:44px;align-items:center;gap:10px;color:var(--ink);font-size:14px}.check-row input{width:18px;min-height:18px}.toast{position:fixed;right:24px;bottom:24px;z-index:50;max-width:360px;padding:12px 16px;color:#fff;background:var(--ink);border-radius:10px;opacity:0;pointer-events:none;transform:translateY(8px);transition:.2s ease}.toast.show{opacity:1;transform:translateY(0)}.page-skeleton{display:grid;gap:14px}.page-skeleton div,.skeleton-block{min-height:130px;border-radius:15px;background:linear-gradient(90deg,#edf1ee 25%,#f7f9f7,#edf1ee 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}.mobile-nav{display:none}@keyframes shimmer{to{background-position:-200% 0}}@media(max-width:1100px){.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid{grid-template-columns:1fr}.filters{grid-template-columns:repeat(2,minmax(0,1fr))}.category-row{grid-template-columns:1fr 1.5fr auto}}@media(max-width:760px){.auth-shell{display:block}.auth-story{min-height:250px;padding:24px;border-right:0;border-bottom:1px solid var(--border)}.auth-story h1{margin-top:48px;font-size:38px}.auth-story .fine-print{display:none}.auth-panel{padding:32px 20px}.app-shell{display:block}.sidebar{display:none}.app-main{min-width:0}.topbar{min-height:74px;padding:13px 16px}.topbar h1{font-size:24px}.topbar-actions .avatar-button{display:none}.page-content{padding:20px 16px 96px}.page-heading{align-items:start;flex-direction:column}.metric-grid,.goal-grid,.filters{grid-template-columns:1fr}.goal-card.primary{grid-column:auto}.financial-table thead{display:none}.financial-table,.financial-table tbody,.financial-table tr,.financial-table td{display:block;width:100%}.financial-table tr{display:grid;margin-bottom:10px;padding:13px;grid-template-columns:1fr auto;gap:7px;border:1px solid var(--border);border-radius:12px}.financial-table td{padding:0;border:0}.financial-table td:nth-child(1),.financial-table td:nth-child(2),.financial-table td:nth-child(5){color:var(--muted);font-size:12px}.financial-table .amount{grid-column:2;grid-row:1}.category-row,.connection-row,.member-row,.invitation-row,.investment-row,.rule-preview-list article{grid-template-columns:1fr}.pagination{flex-wrap:wrap}.filter-summary{grid-template-columns:1fr}.mobile-nav{position:fixed;inset:auto 0 0;z-index:20;display:grid;height:66px;padding:7px 8px calc(7px + env(safe-area-inset-bottom));grid-template-columns:repeat(4,1fr);background:var(--surface);border-top:1px solid var(--border)}.mobile-nav a{display:grid;place-items:center;color:var(--muted);border-radius:9px;font-size:11px;font-weight:700}.mobile-nav a.active{color:var(--brand);background:var(--surface-subtle)}.drawer{width:100%}.toast{right:16px;bottom:82px;left:16px;max-width:none}}
