html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;min-width:320px;min-height:100dvh;margin:0}button,input,select,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}button:disabled{opacity:.55;cursor:not-allowed}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#94a3b8;--bg:#030306;--bg-elevated:#0a0a10;--surface:#0f0f16;--surface-2:#16161f;--surface-hover:#1c1c28;--border:#ffffff12;--border-strong:#ffffff1f;--border-glow:#34d39959;--text:#f1f5f9;--text-secondary:#94a3b8;--muted:#64748b;--accent:#34d399;--accent-soft:#34d39924;--accent-dim:#34d39914;--accent-strong:#10b981;--danger:#f87171;--danger-soft:#f871711f;--success:#34d399;--warn:#fbbf24;--mono:"SF Mono", ui-monospace, "Cascadia Code", monospace;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--shadow-card:0 4px 24px #00000059;--shadow-glow:0 0 48px #34d3991f;--sidebar-width:252px;--sat:env(safe-area-inset-top,0px);--sab:env(safe-area-inset-bottom,0px);--sal:env(safe-area-inset-left,0px);--sar:env(safe-area-inset-right,0px);background:#030306;font-family:SF Pro Text,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:radial-gradient(ellipse 120% 80% at 50% -30%, #34d39917, transparent 55%), radial-gradient(ellipse 60% 40% at 100% 0%, #38bdf80a, transparent 50%), var(--bg);min-height:100vh;margin:0}#root{min-height:100vh}::selection{color:var(--text);background:#34d39940}.brand-mark{border-radius:var(--radius-md);background:linear-gradient(145deg, var(--accent-soft), var(--accent-dim));border:1px solid var(--border-glow);width:2.5rem;height:2.5rem;box-shadow:var(--shadow-glow);flex-shrink:0;justify-content:center;align-items:center;display:flex}.brand-mark-lg{border-radius:var(--radius-lg);width:3.25rem;height:3.25rem;margin:0 auto 1rem}.brand-icon,.nav-icon{width:1.25rem;height:1.25rem;color:var(--accent)}.brand-mark-lg .brand-icon{width:1.5rem;height:1.5rem}.menu-icon{width:1.125rem;height:1.125rem;color:var(--text-secondary)}.layout{min-height:100vh;display:flex}.layout-main{min-width:0;padding-bottom:calc(4.25rem + var(--sab));z-index:1;flex-direction:column;flex:1;display:flex;position:relative}body.sidebar-open{overflow:hidden}.layout-content{flex-direction:column;flex:1;gap:.65rem;width:100%;max-width:680px;margin:0 auto;padding:1rem 1rem 1.5rem;display:flex}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;opacity:0;pointer-events:none;background:#000000a6;transition:opacity .22s;display:none;position:fixed;inset:0}.sidebar-backdrop.visible{opacity:1;pointer-events:auto}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--border);z-index:50;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0a10f7;flex-direction:column;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar.sidebar-dragging{transition:none}.sidebar-brand{border-bottom:1px solid var(--border);align-items:flex-start;gap:.85rem;padding:1.35rem 1.1rem 1.1rem;display:flex}.sidebar-brand-text{flex:1;min-width:0}.sidebar-close{border-radius:var(--radius-sm);background:var(--surface-2);width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;margin:-.25rem -.25rem 0 0;padding:0;font-size:1.35rem;line-height:1;transition:background .15s,color .15s;display:flex}.sidebar-close:hover{background:var(--surface-hover);color:var(--text)}.sidebar-title{color:var(--text);letter-spacing:-.02em;margin:0;font-size:1.125rem;font-weight:700}.sidebar-tagline{font-size:.6875rem;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:.1rem 0 0}.sidebar-email{color:var(--muted);word-break:break-all;margin:.35rem 0 0;font-size:.6875rem;line-height:1.35}.sidebar-nav{flex-direction:column;flex:1;gap:.2rem;padding:.85rem .65rem;display:flex}.sidebar-link{border-radius:var(--radius-md);width:100%;color:var(--text-secondary);font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:.75rem;padding:.7rem .8rem;font-size:.9375rem;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar-link:hover{background:var(--surface-hover);color:var(--text)}.sidebar-link.active{background:var(--accent-soft);color:var(--accent)}.sidebar-icon-wrap{border-radius:var(--radius-sm);background:var(--surface-2);justify-content:center;align-items:center;width:2rem;height:2rem;display:flex}.sidebar-link.active .sidebar-icon-wrap{background:#34d3992e}.sidebar-footer{padding:1rem 1.1rem calc(1rem + env(safe-area-inset-bottom));border-top:1px solid var(--border);flex-direction:column;gap:.5rem;display:flex}.status-pill{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);border-radius:999px;align-items:center;gap:.4rem;width:fit-content;padding:.3rem .65rem;font-size:.75rem;display:inline-flex}.status-pill.online{color:var(--accent);border-color:#34d39940}.status-pill.offline{color:var(--warn);border-color:#fbbf2440}.status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.status-dot.online{background:var(--success);box-shadow:0 0 8px #34d39999}.status-dot.offline{background:var(--warn)}.sidebar-pending{color:var(--warn);font-size:.75rem}.topbar{padding:.5rem 1rem;padding-top:max(.5rem, var(--sat));padding-left:max(1rem, var(--sal));padding-right:max(1rem, var(--sar));border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px)saturate(1.2);backdrop-filter:blur(16px)saturate(1.2);z-index:30;background:#030306eb;align-items:center;gap:.75rem;display:flex;position:sticky;top:0}.menu-btn{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;justify-content:center;align-items:center;width:2.35rem;height:2.35rem;transition:background .15s;display:flex}.menu-btn:active{background:var(--surface-hover)}.topbar-center{flex:1;min-width:0}.topbar-eyebrow{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0;font-size:.625rem}.topbar-title{color:var(--text);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;margin:.05rem 0 0;font-size:1.0625rem;font-weight:600;overflow:hidden}.topbar-status{justify-content:center;align-items:center;width:2rem;height:2rem;display:flex}.bottom-nav{padding:.5rem .75rem calc(.5rem + env(safe-area-inset-bottom));border-top:1px solid var(--border);-webkit-backdrop-filter:blur(20px)saturate(1.3);backdrop-filter:blur(20px)saturate(1.3);z-index:30;background:#08080eeb;justify-content:space-around;gap:.25rem;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:.2rem;min-width:4rem;padding:.25rem .5rem;transition:color .15s;display:flex}.bottom-nav-icon-wrap{border-radius:var(--radius-md);justify-content:center;align-items:center;width:2.25rem;height:2rem;transition:background .15s,transform .15s;display:flex}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item.active .bottom-nav-icon-wrap{background:var(--accent-soft)}.bottom-nav-label{letter-spacing:.02em;font-size:.625rem;font-weight:500}@media (width>=768px){.sidebar{flex-shrink:0;position:sticky;transform:none}.sidebar-close{display:none}body.sidebar-open{overflow:auto}.sidebar-backdrop{display:none!important}.menu-btn,.bottom-nav{display:none}.layout-main{padding-bottom:0}.layout-content{padding:1.5rem 2rem 2.5rem}}.section-head{margin-bottom:.25rem}.section-head h2,.section-title{color:var(--text);letter-spacing:-.02em;margin:0;font-size:1.0625rem;font-weight:600}.section-head-inline{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.section-desc{color:var(--muted);margin:.35rem 0 0;font-size:.8125rem;line-height:1.5}.auth-shell{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;min-height:100dvh;padding:max(.65rem, var(--sat)) max(.75rem, var(--sar)) max(.75rem, var(--sab)) max(.75rem, var(--sal));flex-direction:column;justify-content:flex-start;align-items:stretch;display:flex;overflow-y:auto}.auth-shell .auth-card{flex-shrink:0;width:100%;max-width:440px;margin:0 auto}.auth-card{border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-card), var(--shadow-glow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f0f16eb;padding:1.75rem}.auth-card-brand h1{letter-spacing:-.03em;color:var(--text);margin:0;font-size:1.5rem;font-weight:700}.auth-brand-row{align-items:center;gap:.85rem;margin-bottom:1.25rem;display:flex}.auth-form{margin-top:.25rem}.auth-loading-text{text-align:center;color:var(--text-secondary);margin:0;font-size:.9375rem}.subtitle{color:var(--muted);margin:.2rem 0 0;font-size:.875rem}.standalone-notice{border-radius:var(--radius-md);border:1px solid var(--border-glow);background:var(--accent-dim);margin-bottom:1rem;padding:.9rem 1rem;font-size:.8125rem;line-height:1.55}.standalone-notice strong{color:var(--accent);letter-spacing:.04em;text-transform:uppercase;margin-bottom:.35rem;font-size:.75rem;display:block}.standalone-notice p{color:var(--text-secondary);margin:0}.paste-details{border-top:1px solid var(--border)}.paste-details summary{cursor:pointer;color:var(--text-secondary);font-size:.875rem;font-weight:500;list-style:none}.paste-details summary::-webkit-details-marker{display:none}.paste-details[open] summary{color:var(--text);margin-bottom:.5rem}.paste-verify{margin-top:1rem;padding-top:1rem}.code-input{font-family:var(--mono);letter-spacing:.45em;text-align:center;font-size:1.625rem;padding-left:.45em!important}.code-verify{border:1px solid var(--border-glow);border-radius:var(--radius-lg);background:linear-gradient(180deg, var(--accent-dim), transparent);margin-top:1rem;padding:1.1rem}.code-verify h2{color:var(--text);margin:0 0 .35rem;font-size:.875rem;font-weight:600}.verify-box{border-radius:var(--radius-md);border:1px solid var(--border-glow);background:var(--accent-dim);text-align:center;margin-top:1rem;padding:1rem}.verify-box p{color:var(--muted);margin:0 0 .75rem;font-size:.8125rem}.verify-link{color:#052e16;text-decoration:none;display:inline-block}.auth-tip{margin-top:.75rem}.hero-card{border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:linear-gradient(155deg,#0f0f16f2 0%,#0a0a10fa 100%);padding:1.35rem 1.4rem;position:relative;overflow:hidden}.hero-card-compact{padding:.75rem .85rem .65rem}.hero-row{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex;position:relative}.hero-card-compact .hero-value{margin-top:.15rem;font-size:1.65rem}.hero-card-compact .hero-stats{flex-direction:column;align-items:flex-end;gap:.25rem;margin-top:0}.hero-card-compact .stat-chip{padding:.15rem .45rem;font-size:.6875rem}.hero-glow{pointer-events:none;background:radial-gradient(circle,#34d39926,#0000 70%);width:60%;height:120%;position:absolute;top:-40%;right:-20%}.hero-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0;font-size:.6875rem;position:relative}.hero-value{letter-spacing:-.04em;color:var(--text);margin:.4rem 0 0;font-size:2.25rem;font-weight:700;line-height:1.1;position:relative}.hero-stats{flex-wrap:wrap;gap:.5rem;margin-top:.85rem;display:flex;position:relative}.stat-chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);border-radius:999px;padding:.25rem .65rem;font-size:.75rem;font-weight:500}.stat-chip-warn{color:var(--warn);background:#fbbf2414;border-color:#fbbf244d}.panel{flex-direction:column;gap:.85rem;display:flex}.panel-block,.panel-card,.form-card,.calendar-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-card);padding:1.15rem}.form-card-elevated{border-color:var(--border-strong)}.panel-block h2,.panel-card h2{margin:0}.panel-value{font-family:var(--mono);color:var(--accent);word-break:break-all;margin:.5rem 0;font-size:.8125rem}.panel-hint{color:var(--muted);margin:0 0 .75rem;font-size:.8125rem;line-height:1.55}.panel-hint:last-child{margin-bottom:0}.btn-logout{margin-top:.25rem}.card,.sub-card{--card-accent:var(--accent);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-card);padding:1rem 1.1rem;position:relative;overflow:hidden}.sub-card:before{content:"";background:var(--card-accent);border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.card-title-block h3{color:var(--text);letter-spacing:-.02em;margin:0;font-size:1rem;font-weight:600}.card-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.amount{color:var(--accent);font-size:1.0625rem;font-weight:700;font-family:var(--mono);white-space:nowrap;margin:0}.badge{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);border-radius:999px;margin-top:.35rem;padding:.15rem .55rem;font-size:.6875rem;font-weight:500;display:inline-block}.badge-accent{background:var(--accent-dim);color:var(--accent);border-color:#34d39933}.card-meta{flex-wrap:wrap;gap:.4rem;margin-top:.75rem;display:flex}.meta-chip{border-radius:var(--radius-sm);background:var(--surface-2);color:var(--muted);border:1px solid var(--border);padding:.2rem .55rem;font-size:.6875rem;font-weight:500}.notes{border-top:1px solid var(--border);color:var(--text-secondary);margin:.65rem 0 0;padding-top:.65rem;font-size:.8125rem;line-height:1.45}.card-badges{flex-wrap:wrap;gap:.35rem;margin-top:.35rem;display:flex}.badge-due-today{color:#fbbf24;background:#fbbf2426;border-color:#fbbf2459}.badge-due-soon{color:var(--accent);background:#34d3991f;border-color:#34d3994d}.badge-due-past{color:#f87171;background:#f871711f;border-color:#f871714d}.meta-chip-paid{color:var(--accent);border-color:#34d39940}.filter-bar{flex-wrap:wrap;gap:.4rem;display:flex}.filter-chip{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font:inherit;cursor:pointer;border-radius:999px;padding:.35rem .75rem;font-size:.75rem;font-weight:500}.filter-chip.active{background:var(--accent-soft);border-color:var(--border-glow);color:var(--accent)}.kind-toggle{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem;display:grid}.kind-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font:inherit;cursor:pointer;padding:.55rem .75rem;font-size:.8125rem;font-weight:500}.kind-btn.active{background:var(--accent-soft);border-color:var(--border-glow);color:var(--accent)}.payment-history{margin-top:.5rem}.payment-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.payment-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem 0;display:flex}.payment-row:last-child{border-bottom:none}.payment-name{color:var(--text);margin:0;font-size:.875rem;font-weight:500}.payment-date{color:var(--muted);margin:.15rem 0 0;font-size:.75rem}.payment-amount{font-family:var(--mono);color:var(--accent);white-space:nowrap;margin:0;font-size:.875rem}.calendar-features{color:var(--muted);margin:0 0 .85rem;padding-left:1.15rem;font-size:.8125rem;line-height:1.55}.card-footer{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.empty-state{text-align:center;border:1px dashed var(--border-strong);border-radius:var(--radius-xl);background:var(--accent-dim);padding:2.5rem 1.25rem}.empty-icon{border-radius:var(--radius-lg);background:var(--accent-soft);border:1px solid var(--border-glow);justify-content:center;align-items:center;width:3rem;height:3rem;margin-bottom:.85rem;display:inline-flex}.empty-icon-svg{width:1.35rem;height:1.35rem;color:var(--accent)}.empty-title{color:var(--text);margin:0 0 .35rem;font-size:1rem;font-weight:600}.empty-desc{color:var(--muted);margin:0 0 1rem;max-width:260px;margin-inline:auto;font-size:.8125rem;line-height:1.5}.skeleton-list{flex-direction:column;gap:.75rem;display:flex}.skeleton-card{border-radius:var(--radius-lg);background:linear-gradient(90deg, var(--surface) 0%, var(--surface-2) 50%, var(--surface) 100%);border:1px solid var(--border);background-size:200% 100%;height:5.5rem;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.list{flex-direction:column;gap:.4rem;display:flex}.sub-card-compact{padding:.55rem .65rem .55rem .75rem}.sub-card-row{align-items:center;gap:.5rem;display:flex}.sub-card-main{flex:1;min-width:0}.sub-card-top{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.sub-card-top h3{color:var(--text);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.875rem;font-weight:600;overflow:hidden}.amount-sm{font-size:.8125rem}.sub-card-meta{flex-wrap:wrap;align-items:center;gap:.25rem;margin-top:.2rem;display:flex}.meta-chip-date{color:var(--text-secondary);font-weight:600}.meta-chip-muted{background:0 0;border-color:#0000;padding:.1rem .25rem}.badge-sm{margin-top:0;padding:.1rem .4rem;font-size:.625rem}.notes-compact{margin:.35rem 0 0;padding-top:.35rem;font-size:.75rem}.sub-card-actions{flex-direction:column;flex-shrink:0;gap:.2rem;display:flex}.btn-icon{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);width:2rem;min-width:2rem;height:2rem;min-height:2rem;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;font-size:1rem;line-height:1;transition:background .15s,color .15s;display:flex}.btn-icon-ok:hover{background:var(--accent-dim);color:var(--accent);border-color:#34d3994d}.btn-icon-del:hover{background:var(--danger-soft);color:#f87171;border-color:#f871714d}.spending-overview{border-top:1px solid var(--border);margin-top:.65rem;padding-top:.65rem;position:relative}.spending-overview-charts{grid-template-columns:1fr auto;align-items:center;gap:.5rem;display:grid}.chart-bars-wrap{min-width:0}.chart-bars-title{font-size:.625rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 .35rem}.chart-bars{align-items:flex-end;gap:2px;height:56px;display:flex}.chart-bar-col{flex-direction:column;flex:1;align-items:center;min-width:0;height:100%;display:flex}.chart-bar{background:var(--surface-2);border-radius:2px 2px 0 0;width:100%;max-width:8px;margin-top:auto;transition:background .15s}.chart-bar-has .chart-bar{background:#34d39973}.chart-bar-today .chart-bar{background:var(--accent)}.chart-bar-label{color:var(--muted);height:.6rem;margin-top:2px;font-size:.5rem}.chart-donut-wrap{flex-direction:column;flex-shrink:0;align-items:center;gap:.25rem;width:110px;display:flex;position:relative}.chart-donut{width:72px;height:72px}.chart-donut-total{font-size:.5625rem;font-family:var(--mono);color:var(--text-secondary);text-align:center;max-width:48px;font-weight:600;line-height:1.2;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chart-donut-empty{background:var(--surface-2);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.chart-legend{width:100%;margin:0;padding:0;list-style:none}.chart-legend li{color:var(--muted);grid-template-columns:6px 1fr auto;align-items:center;gap:.25rem;font-size:.5625rem;line-height:1.3;display:grid}.chart-legend-dot{border-radius:50%;width:6px;height:6px}.chart-legend-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.chart-legend-pct{font-family:var(--mono);color:var(--text-secondary)}@media (width<=380px){.spending-overview-charts{grid-template-columns:1fr}.chart-donut-wrap{flex-direction:row;justify-content:center;gap:.75rem;width:100%}.chart-legend{flex:1;width:auto}}.payment-history-collapsible{padding:.5rem .75rem}.payment-history-toggle{width:100%;color:inherit;font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:.35rem 0;display:flex}.payment-history-toggle .section-title{margin:0;font-size:.8125rem}.payment-history-chevron{color:var(--muted);font-size:.75rem}.payment-history-collapsible .payment-list{margin-top:.35rem}.payment-history-collapsible .payment-row{padding:.4rem 0}.week-strip{padding:.5rem 0}.week-strip-title{font-size:.6875rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 .35rem}.week-strip-row{gap:.35rem;padding-bottom:.15rem;display:flex;overflow-x:auto}.week-day{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);flex:0 0 4.5rem;padding:.35rem;font-size:.625rem}.week-day-today{background:var(--accent-dim);border-color:#34d39966}.week-day-label{color:var(--text-secondary);margin-bottom:.2rem;font-weight:600;display:block}.week-day-list{margin:0;padding:0;list-style:none}.week-day-name{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.week-day-amt{color:var(--accent);font-family:var(--mono)}.week-day-empty,.week-day-more{color:var(--muted)}.search-sort-bar{gap:.4rem;display:flex}.search-input{flex:1;margin:0;padding:.45rem .65rem;font-size:.8125rem}.sort-select{width:auto;margin:0;padding:.45rem .5rem;font-size:.75rem}.modal{background:0 0;border:none;max-width:calc(100% - 2rem);padding:0}.modal::backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6}.modal-card{border:1px solid var(--border-strong);border-radius:var(--radius-lg);background:var(--surface);width:min(400px,100%);padding:1rem}.modal-card h3{margin:0 0 .75rem;font-size:1rem}.toast-host{bottom:calc(5rem + var(--sab));z-index:200;border-radius:var(--radius-lg);border:1px solid var(--border-strong);box-shadow:var(--shadow-card);background:#0f0f16f5;align-items:center;gap:.75rem;padding:.65rem 1rem;font-size:.8125rem;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast-action{flex-shrink:0}.budget-bar-wrap{margin-bottom:.5rem}.budget-bar-labels{color:var(--muted);justify-content:space-between;margin-bottom:.25rem;font-size:.625rem;display:flex}.budget-bar{background:var(--surface-2);border-radius:2px;height:4px;overflow:hidden}.budget-bar-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.budget-bar-fill.warn{background:#fbbf24}.budget-bar-fill.over{background:#f87171}.chart-bars-head{justify-content:space-between;align-items:center;gap:.25rem;margin-bottom:.25rem;display:flex}.chart-bars-head .chart-bars-title{text-align:center;flex:1;margin:0}.btn-icon-sm{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);width:1.5rem;height:1.5rem;color:var(--text-secondary);cursor:pointer;font-size:1rem;line-height:1}.sub-card-tap{text-align:left;min-width:0;color:inherit;font:inherit;cursor:pointer;background:0 0;border:none;flex:1;padding:0}.sub-card-swipe{transition:transform .1s ease-out}.meta-chip-warn{color:#fbbf24;border-color:#fbbf244d}.checkbox-label{flex-direction:row;align-items:center;gap:.5rem}.panel-mono{font-family:var(--mono);font-size:.6875rem}.quick-templates{flex-direction:column;gap:.75rem;display:flex}.quick-templates-intro{color:var(--muted);margin:0;font-size:.75rem;line-height:1.45}.quick-templates-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0 0 .35rem;font-size:.6875rem;font-weight:600}.quick-templates-row{flex-wrap:wrap;gap:.4rem;display:flex}.quick-template-chip{text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);min-width:8.5rem;color:var(--text);cursor:pointer;flex:calc(50% - .4rem);padding:.5rem .6rem;transition:border-color .15s,background .15s}.quick-template-chip:hover{background:var(--accent-dim);border-color:#34d39966}.quick-template-chip-label{font-size:.8125rem;font-weight:600;display:block}.quick-template-chip-hint{color:var(--muted);margin-top:.15rem;font-size:.625rem;line-height:1.35;display:block}.quick-templates-back{margin-bottom:.5rem}.entry-mode-toggle{gap:.5rem;margin-bottom:.65rem;display:flex}.quick-template-chip-featured{background:#34d39914;border-color:#34d39973}.quick-templates-suggested{border-bottom:1px solid var(--border);margin-bottom:.25rem;padding-bottom:.5rem}.import-panel{flex-direction:column;gap:.5rem;display:flex}.import-title{margin:0;font-size:.9375rem}.import-textarea{resize:vertical;width:100%;min-height:6rem;font-size:.8125rem;line-height:1.45}.import-actions{gap:.5rem;display:flex}.import-preview-label{color:var(--muted);margin:.5rem 0 .25rem;font-size:.75rem}.import-preview-list{max-height:14rem;margin:0 0 .5rem;padding:0;list-style:none;overflow-y:auto}.import-preview-row{border-bottom:1px solid var(--border);font-size:.8125rem}.import-row-check{cursor:pointer;align-items:flex-start;gap:.5rem;padding:.45rem 0;display:flex}.import-row-amount{color:var(--accent);font-family:var(--mono)}.import-row-meta{color:var(--muted);margin-top:.1rem;font-size:.6875rem;display:block}.import-confidence-low{opacity:.85}.banner{border-radius:var(--radius-md);background:var(--accent-dim);border:1px solid var(--border-glow);color:var(--text-secondary);margin:0;padding:.75rem 1rem;font-size:.8125rem;line-height:1.45}.banner.error{background:var(--danger-soft);color:#fca5a5;border-color:#f8717147}.update-banner{bottom:calc(5.25rem + env(safe-area-inset-bottom));z-index:100;border-radius:var(--radius-lg);border:1px solid var(--border-glow);width:min(420px,100% - 1.5rem);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0a10f7;flex-direction:column;gap:.5rem;padding:.9rem 1rem;display:flex;position:fixed;left:50%;transform:translate(-50%)}.update-banner p{color:var(--text);margin:0;font-size:.8125rem;line-height:1.45}.update-dismiss{align-self:flex-start;margin-top:0!important}@media (width>=768px){.update-banner{bottom:1.25rem}}.btn-primary,.btn-secondary,.btn-danger,.btn-ghost-danger,.btn-text{border-radius:var(--radius-md);font:inherit;cursor:pointer;border:none;padding:.7rem 1rem;font-weight:500;transition:transform .12s,opacity .12s,background .12s}.btn-primary{background:linear-gradient(180deg, #3eeaa3 0%, var(--accent-strong) 100%);color:#042f1a;font-weight:600;box-shadow:0 2px 12px #34d39940}.btn-primary:active{transform:scale(.98)}.btn-glow{box-shadow:0 4px 20px #34d3994d}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border-strong)}.btn-danger{color:var(--danger);background:0 0;border:1px solid #f8717159}.btn-ghost-danger{color:var(--muted);background:0 0;padding:.35rem .65rem;font-size:.8125rem}.btn-ghost-danger:hover,.btn-ghost-danger:active{color:var(--danger);background:var(--danger-soft)}.btn-text{color:var(--accent);background:0 0;padding:.35rem .5rem;font-size:.8125rem;font-weight:600}.btn-add{width:100%}.btn-sm{padding:.5rem .85rem;font-size:.8125rem}.btn-link{color:var(--muted);cursor:pointer;background:0 0;border:none;margin-top:.5rem;padding:0;font-size:.8125rem;text-decoration:underline}.inline-link{color:var(--accent);font:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}label{color:var(--text-secondary);flex-direction:column;gap:.4rem;margin-bottom:.85rem;font-size:.8125rem;font-weight:500;display:flex}input,select,textarea{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);font:inherit;-webkit-user-select:text;user-select:text;padding:.7rem .85rem;transition:border-color .15s,box-shadow .15s}input::placeholder,textarea::placeholder{color:var(--muted)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.paste-verify textarea{resize:vertical;width:100%;min-height:4.5rem;line-height:1.4}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.form-actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.calendar-actions{flex-wrap:wrap;gap:.5rem;margin-top:.85rem;display:flex}.calendar-help{color:var(--muted);margin-top:.85rem;font-size:.8125rem}.calendar-help ol{margin:.5rem 0 0;padding-left:1.25rem;line-height:1.6}@media (width<=767px){.layout-content{gap:.75rem;padding:.65rem .85rem 1.25rem}.topbar{padding-top:max(.4rem, var(--sat));gap:.5rem;padding-bottom:.4rem}.topbar-eyebrow{display:none}.topbar-title{font-size:1rem}.menu-btn{width:2.1rem;height:2.1rem}.hero-card{padding:1rem 1.05rem}.hero-value{font-size:1.75rem}.hero-stats{gap:.35rem;margin-top:.6rem}.stat-chip{padding:.2rem .5rem;font-size:.6875rem}.section-head-inline{margin-bottom:0}.section-title{font-size:.9375rem}.auth-card{border-radius:var(--radius-lg);padding:1.1rem}.auth-brand-row{gap:.65rem;margin-bottom:.85rem}.auth-card-brand h1{font-size:1.25rem}.brand-mark{width:2.15rem;height:2.15rem}.brand-icon,.nav-icon{width:1.1rem;height:1.1rem}.subtitle{font-size:.8125rem}.standalone-notice{margin-bottom:.75rem;padding:.65rem .75rem;font-size:.75rem}label{margin-bottom:.65rem;font-size:.75rem}input,select,textarea{padding:.6rem .75rem}.btn-primary,.btn-secondary,.btn-danger{padding:.6rem .85rem}.code-input{letter-spacing:.3em;font-size:1.35rem;padding-left:.3em!important}.code-verify,.paste-verify{margin-top:.75rem;padding-top:.75rem}.code-verify{padding:.75rem}.paste-verify textarea{min-height:3.25rem}.paste-details summary{cursor:pointer;color:var(--text-secondary);padding:.15rem 0;font-size:.8125rem;font-weight:500;list-style:none}.paste-details summary::-webkit-details-marker{display:none}.paste-details[open] summary{margin-bottom:.5rem}.card,.sub-card{padding:.85rem .9rem}.panel-block,.panel-card,.form-card,.calendar-card{padding:.9rem}.bottom-nav{padding:.35rem .5rem calc(.35rem + var(--sab))}.bottom-nav-item{min-width:3.25rem;padding:.15rem .35rem}.bottom-nav-icon-wrap{width:2rem;height:1.75rem}.bottom-nav-label{font-size:.5625rem}.layout-main{padding-bottom:calc(3.75rem + var(--sab))}.update-banner{bottom:calc(4.5rem + var(--sab));width:calc(100% - 1rem);padding:.75rem}.empty-state{padding:1.75rem 1rem}}@media (width<=560px){.form-row{grid-template-columns:1fr}}
