@font-face{font-family:__GeistSans_245d8d;src:url(/_next/static/media/27834908180db20f-s.p.woff2) format("woff2");font-display:swap;font-weight:100 900}@font-face{font-family:__GeistSans_Fallback_245d8d;src:local("Arial");ascent-override:94.56%;descent-override:27.76%;line-gap-override:0.00%;size-adjust:106.28%}.__className_245d8d{font-family:__GeistSans_245d8d,__GeistSans_Fallback_245d8d}.__variable_245d8d{--font-geist-sans:"__GeistSans_245d8d","__GeistSans_Fallback_245d8d"}@font-face{font-family:__GeistMono_97c177;src:url(/_next/static/media/78fec81b34c4a365.p.woff2) format("woff2");font-display:swap;font-weight:100 900}.__className_97c177{font-family:__GeistMono_97c177,ui-monospace,SFMono-Regular,Roboto Mono,Menlo,Monaco,Liberation Mono,DejaVu Sans Mono,Courier New,monospace}.__variable_97c177{--font-geist-mono:"__GeistMono_97c177",ui-monospace,SFMono-Regular,Roboto Mono,Menlo,Monaco,Liberation Mono,DejaVu Sans Mono,Courier New,monospace}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-geist-sans);font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--font-geist-mono);font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.uppercase{text-transform:uppercase}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--bg:#faf8f4;--bg-card:#fff;--bg-elev:#f2eee7;--bg-sidebar:#1a1815;--bg-sidebar-active:#2a2722;--text:#1a1815;--text-mute:#6b665d;--text-soft:#9a958b;--border:#e8e3d9;--border-strong:#d4cdbe;--accent:#fb923c;--gold:#c9a961;--shadow-sm:0 1px 2px rgba(26,24,21,.04);--shadow-md:0 4px 16px rgba(26,24,21,.06);--radius:14px;--radius-sm:8px;--row-pad:14px;--font:var(--font-geist-sans),"Inter",system-ui,-apple-system,sans-serif;--font-num:var(--font-geist-mono),"JetBrains Mono","SF Mono",monospace}[data-theme=dark]{--bg:#0f0e0c;--bg-card:#1a1815;--bg-elev:#232017;--bg-sidebar:#0a0908;--bg-sidebar-active:#1f1c18;--text:#f2efe9;--text-mute:#a8a29a;--text-soft:#6b665d;--border:#2a2722;--border-strong:#3a362f;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 16px rgba(0,0,0,.4)}.density-compact{--row-pad:8px}.density-comfortable{--row-pad:14px}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased}.app{min-height:100vh}.app,.main{display:flex}.main{flex:1;flex-direction:column;min-width:0}.content{flex:1;padding:24px 32px 48px;max-width:1600px;width:100%}.sidebar{width:240px;background:var(--bg-sidebar);color:#e8e3d9;padding:20px 16px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;padding:8px 8px 24px}.brand-mark{width:36px;height:36px;border-radius:10px;display:grid;place-items:center}.brand-name{font-weight:600;font-size:16px;letter-spacing:-.01em}.brand-sub{font-size:11px;color:#9a958b;font-variant-numeric:tabular-nums}.nav{display:flex;flex-direction:column;gap:2px}.nav-item{position:relative;background:transparent;border:none;color:#b8b2a6;padding:10px 12px;border-radius:8px;font-size:14px;font-family:inherit;display:flex;align-items:center;gap:12px;cursor:pointer;text-align:left;transition:background .15s,color .15s}.nav-item:hover{background:hsla(0,0%,100%,.04);color:#f2efe9}.nav-item.active{background:var(--bg-sidebar-active);color:#fff}.nav-dot{position:absolute;right:12px;width:6px;height:6px;border-radius:50%}.nav-spacer{flex:1}.user-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;background:hsla(0,0%,100%,.03)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.user-name{color:#f2efe9;font-weight:500;font-size:13px}.user-sub{color:#6b665d;font-size:11px}.topbar{justify-content:space-between;padding:18px 32px;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:24px}.topbar-title{font-size:18px;font-weight:600;letter-spacing:-.01em}.month-switch{display:flex;align-items:center;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;padding:4px}.month-switch>button:not(.month-current-btn){background:transparent;border:none;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;cursor:pointer;color:var(--text-mute);flex-shrink:0}.month-switch>button:not(.month-current-btn):hover{background:var(--bg-elev);color:var(--text)}.month-switch>button:not(.month-current-btn):disabled{opacity:.3;cursor:not-allowed}.month-current{padding:0 10px;display:flex;flex-direction:column;align-items:center;line-height:1;min-width:110px}.month-name{font-weight:600;font-size:13px;white-space:nowrap}.month-year{font-size:10px;color:var(--text-mute);margin-top:2px}.topbar-right{display:flex;align-items:center;gap:8px}.ghost-btn{background:transparent;border:1px solid var(--border);width:36px;height:36px;border-radius:10px;display:grid;place-items:center;cursor:pointer;color:var(--text);position:relative}.ghost-btn:hover{background:var(--bg-card)}.ghost-btn .badge{position:absolute;top:8px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.primary-btn{background:var(--text);color:var(--bg);border:none;padding:0 14px;height:36px;border-radius:10px;font-size:13px;font-weight:500;font-family:inherit;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.primary-btn:hover{opacity:.85}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.card-title{font-size:15px;font-weight:600;margin:0;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.card-sub{font-size:12px;color:var(--text-mute);margin-top:2px}.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;margin-bottom:16px}.hero-main{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;justify-content:space-between}.hero-label{font-size:12px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.hero-value{font-size:44px;font-weight:600;letter-spacing:-.02em;margin:12px 0 24px;font-variant-numeric:tabular-nums;white-space:nowrap}.hero-progress{display:flex;flex-direction:column;gap:10px}.hero-progress-bar{height:8px;background:var(--bg-elev);border-radius:999px;overflow:hidden}.hero-progress-fill{height:100%;border-radius:999px;transition:width .4s ease}.hero-progress-text{display:flex;justify-content:space-between;font-size:13px;color:var(--text-mute);padding-bottom:4px}.hero-progress-text strong{color:var(--text);font-weight:600}.hero-stats{display:grid;grid-template-rows:repeat(auto-fit,1fr);gap:8px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;align-items:center;gap:14px;flex:1}.stat-icon{width:32px;height:32px;border-radius:10px;display:grid;place-items:center}.stat-label{font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.stat-value{font-size:16px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.dash-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:16px}.dash-col-main,.dash-col-side{display:flex;flex-direction:column;gap:16px}.seg{display:flex;background:var(--bg-elev);border-radius:999px;padding:3px;gap:2px}.seg button{background:transparent;border:none;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;color:var(--text-mute)}.seg button.on{background:var(--bg-card);color:var(--text);box-shadow:var(--shadow-sm)}.payment-groups{display:flex;flex-direction:column;gap:16px}.group-head{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;border-bottom:1px solid var(--border);margin-bottom:4px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:opacity .1s}.group-head:hover{opacity:.75}.group-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-mute)}.group-dot{width:8px;height:8px;border-radius:50%}.group-count{background:var(--bg-elev);color:var(--text-mute);padding:1px 6px;border-radius:10px;font-size:11px}.group-head-right{display:flex;align-items:center;gap:10px}.group-sum{font-family:var(--font-num);font-size:13.5px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em;white-space:nowrap;min-width:110px;text-align:right}.group-chevron{color:var(--text-soft);transition:transform .18s ease;flex-shrink:0}.group-chevron.collapsed{transform:rotate(-90deg)}.payment-row{display:grid;grid-template-columns:28px 4px 1fr 130px 90px 110px;align-items:center;gap:10px;padding:var(--row-pad) 4px;border-bottom:1px solid var(--border);transition:opacity .2s}.payment-row:last-child{border-bottom:none}.payment-row.paid{opacity:.5}.payment-row.paid .payment-name{text-decoration:line-through;text-decoration-color:var(--text-soft)}.payment-date-wrap{display:flex;align-items:center;gap:4px;color:var(--text-soft);visibility:visible}.payment-date-wrap.ph{visibility:hidden}.payment-date-input{font-family:var(--font-num);font-size:11.5px;padding:3px 5px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;color:var(--text-mute);cursor:pointer;outline:none;width:108px;transition:border-color .1s,color .1s}.payment-date-input:focus,.payment-date-input:hover{border-color:var(--border-strong);color:var(--text)}[data-theme=dark] .payment-date-input{color-scheme:dark}.payment-date-input::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer;margin-left:1px}.payment-method-select{font-family:var(--font);font-size:11.5px;padding:3px 20px 3px 8px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;color:var(--text-mute);cursor:pointer;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239A958B' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center;width:90px;visibility:visible;transition:border-color .1s,color .1s}.payment-method-select.ph{visibility:hidden}.payment-method-select:focus,.payment-method-select:hover{border-color:var(--border-strong);color:var(--text)}[data-theme=dark] .payment-method-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23A8A29A' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.payment-amount{text-align:right;font-family:var(--font-num);white-space:nowrap}.payment-amount.negative{color:var(--accent)}.check{background:transparent;border:none;padding:0;cursor:pointer;display:grid;place-items:center;width:28px;height:28px}.check-box{width:18px;height:18px;border-radius:6px;border:1.5px solid var(--border-strong);display:grid;place-items:center;color:#fff;transition:all .15s}.check:hover .check-box{border-color:var(--accent)}.payment-cat{width:4px;height:18px;border-radius:2px}.payment-name{font-size:14px;font-weight:500}.payment-amount{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.payment-amount.negative{color:#4a8060}.donut-wrap{display:grid;grid-template-columns:180px 1fr;gap:20px;align-items:center}.donut-total{font-size:24px;font-weight:600;fill:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.donut-label{font-size:11px;fill:var(--text-mute);text-transform:uppercase;letter-spacing:.05em}.donut-legend{display:flex;flex-direction:column;gap:8px}.legend-row{display:grid;grid-template-columns:8px 1fr auto auto;gap:8px;align-items:center;font-size:12px}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-label{color:var(--text)}.legend-pct{color:var(--text-mute);font-weight:500}.legend-val{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums;min-width:70px;text-align:right}.gold-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(201,169,97,.18);margin-right:4px}.next-up{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:linear-gradient(135deg,rgba(201,169,97,.14),rgba(201,169,97,.06));border:1px solid rgba(201,169,97,.35);border-radius:10px;padding:14px 16px;margin-bottom:12px;position:relative}.next-up-tag{position:absolute;top:-8px;left:14px;background:var(--gold);color:#1a1815;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 8px;border-radius:4px}.next-up-body{display:flex;flex-direction:column;gap:4px;min-width:0}.next-up-name{font-weight:600;font-size:15px;letter-spacing:-.01em}.next-up-meta{display:flex;gap:6px;font-size:12px;align-items:center;color:var(--text-mute)}.next-up-when{color:var(--text);font-weight:500}.next-up-sep{color:var(--text-soft)}.next-up-amount{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}.next-up-pay{background:var(--text);color:var(--bg);border:none;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap}.next-up-pay:hover{opacity:.85}.irregular-list{display:flex;flex-direction:column;gap:4px}.irregular-row{display:grid;grid-template-columns:44px 1fr 32px;gap:12px;align-items:center;padding:10px 8px;border-radius:8px;border:1px solid transparent;transition:opacity .2s}.irregular-row.current{border-color:var(--border);background:rgba(201,169,97,.04)}.irregular-row.paid{opacity:.45}.irregular-row.paid .ir-name{text-decoration:line-through}.ir-month{background:var(--bg-elev);border-radius:8px;padding:6px 0;text-align:center;line-height:1}.ir-month-num{font-size:13px;font-weight:600;color:var(--text)}.ir-month-name{font-size:9px;color:var(--text-mute);text-transform:uppercase;margin-top:2px;letter-spacing:.05em}.ir-name{font-size:13px;font-weight:500}.ir-amount{font-size:12px;color:var(--text-mute);font-variant-numeric:tabular-nums;margin-top:2px}.ir-check{background:transparent;border:none;padding:0;cursor:pointer;display:grid;place-items:center}.empty{text-align:center;padding:20px;color:var(--text-mute);font-size:13px}.year-strip-card{margin-top:16px}.year-strip{display:grid;grid-template-columns:repeat(12,1fr);gap:8px;height:120px}.ystrip-month{background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;gap:6px;border-radius:8px;padding:6px 4px;transition:background .15s}.ystrip-month.selected,.ystrip-month:hover{background:var(--bg-elev)}.ystrip-month.current .ystrip-label:after{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--accent);margin-left:4px;vertical-align:middle}.ystrip-bars{flex:1;justify-content:center}.ystrip-bar-bg,.ystrip-bars{display:flex;align-items:flex-end}.ystrip-bar-bg{background:var(--bg-elev);position:relative;min-height:4px}.ystrip-bar-bg,.ystrip-bar-paid{width:100%;border-radius:4px 4px 0 0}.ystrip-bar-paid{transition:height .3s,background .2s}.ystrip-label{font-size:11px;text-align:center;color:var(--text-mute);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.ystrip-month.selected .ystrip-label{color:var(--text)}.ystrip-total{font-size:10px;text-align:center;color:var(--text-soft);font-variant-numeric:tabular-nums}.year-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.ysummary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.ysummary-card.highlight{border-color:var(--accent)}.ys-label{font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.ys-value{font-size:28px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;margin:6px 0 4px;white-space:nowrap}.ys-sub{font-size:12px;color:var(--text-mute)}.year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.year-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:left;font-family:inherit;cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,transform .15s}.year-card:hover{border-color:var(--border-strong);transform:translateY(-1px)}.yc-head{display:flex;justify-content:space-between;align-items:baseline}.yc-name{font-weight:600;font-size:14px}.yc-pct{font-size:11px;color:var(--text-mute);font-variant-numeric:tabular-nums}.yc-amount{font-size:20px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em;white-space:nowrap}.yc-bar{height:4px;background:var(--bg-elev);border-radius:999px;overflow:hidden}.yc-bar-fill{height:100%;border-radius:999px}.yc-irreg{font-size:11px;color:var(--text-mute);display:flex;align-items:center;gap:4px;margin-top:4px}.cv-intro{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:20px}.cv-intro-label{font-size:12px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.cv-intro-value{font-size:40px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;margin:4px 0;white-space:nowrap}.cv-intro-sub{font-size:13px;color:var(--text-mute)}.cv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.cv-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:10px}.cv-card-head{display:flex;justify-content:space-between;align-items:baseline}.cv-card-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px}.cv-card-dot{width:10px;height:10px;border-radius:50%}.cv-card-pct{font-size:12px;color:var(--text-mute);font-variant-numeric:tabular-nums}.cv-card-value{font-size:22px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;white-space:nowrap}.cv-card-sub{font-size:11px;color:var(--text-mute)}.cv-spark{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;height:40px;align-items:end;margin-top:6px}.cv-spark-bar{height:100%;display:flex;align-items:end}.cv-spark-bar>div{width:100%;min-height:2px;border-radius:2px 2px 0 0}.cv-spark-labels{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;font-size:9px;color:var(--text-soft);text-align:center}.cv-items{display:flex;flex-direction:column;gap:4px;margin-top:8px;padding-top:12px;border-top:1px solid var(--border)}.cv-item{display:flex;justify-content:space-between;font-size:12px}.cv-item-name{color:var(--text)}.cv-item-amount{color:var(--text-mute);font-variant-numeric:tabular-nums}.cv-more{font-size:11px;color:var(--text-soft);margin-top:4px}.dashboard{display:flex;flex-direction:column}.payment-due{font-family:var(--font-num);font-size:10.5px;color:var(--text-soft);margin-left:10px;padding:2px 6px;background:var(--bg-elev);border-radius:4px;letter-spacing:-.01em}.add-payment-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;background:var(--accent);color:#0a0a0b;border:0;border-radius:8px;font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:filter .12s,transform .12s,box-shadow .12s;box-shadow:0 4px 16px color-mix(in oklab,var(--accent) 28%,transparent)}.add-payment-btn:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 6px 20px color-mix(in oklab,var(--accent) 36%,transparent)}.add-payment-btn:active{transform:translateY(0)}.add-payment-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;animation:modalFadeIn .14s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:16px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.25),0 0 0 1px hsla(0,0%,100%,.04);animation:modalSlideUp .16s cubic-bezier(.32,.72,0,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 0}.modal-title{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em}.modal-close{background:transparent;border:0;padding:6px;border-radius:8px;cursor:pointer;color:var(--text-mute);display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.modal-close:hover{background:var(--bg-elev);color:var(--text)}.modal-form{gap:16px;padding:20px 24px 24px}.mf-field,.modal-form{display:flex;flex-direction:column}.mf-field{gap:6px;flex:1}.mf-label{font-size:11.5px;font-weight:500;color:var(--text-mute)}.mf-input{height:38px;padding:0 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;font-size:13.5px;font-family:inherit;color:var(--text);outline:none;transition:border-color .12s,background .12s;width:100%}.mf-input:focus{border-color:var(--accent);background:var(--bg-card)}.mf-input::-moz-placeholder{color:var(--text-soft)}.mf-input::placeholder{color:var(--text-soft)}.mf-textarea{height:auto;padding:8px 12px;resize:none}.mf-narrow{width:80px;flex:none}.mf-amount-wrap{display:flex;align-items:center;gap:8px}.mf-amount{width:150px;flex:none;font-family:var(--font-num)}.mf-currency{font-size:13px;color:var(--text-mute)}.mf-amount-hint{font-size:11.5px;color:var(--text-soft)}.mf-row{display:flex;gap:16px;align-items:flex-end}.mf-seg{display:flex;background:var(--bg-elev);border-radius:8px;padding:3px;gap:3px}.mf-seg-btn{flex:1;padding:7px 12px;background:transparent;border:0;border-radius:6px;font-family:inherit;font-size:12.5px;font-weight:500;color:var(--text-mute);cursor:pointer;transition:background .1s,color .1s}.mf-seg-btn.on{background:var(--bg-card);color:var(--text);box-shadow:var(--shadow-sm)}.mf-select-wrap{position:relative;display:flex;align-items:center}.mf-select{width:100%;height:38px;padding:0 32px 0 34px;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;font-size:13.5px;font-family:inherit;color:var(--text);outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239A958B' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;transition:border-color .12s}.mf-select:focus{border-color:var(--accent)}.mf-cat-dot{position:absolute;left:10px;width:12px;height:12px;border-radius:50%;pointer-events:none;flex-shrink:0}.mf-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mf-checkbox input{accent-color:var(--accent);width:15px;height:15px;cursor:pointer}.mf-error{padding:10px 12px;background:rgba(251,113,133,.08);border:1px solid rgba(251,113,133,.2);border-radius:8px;color:#fb7185;font-size:12.5px}.modal-footer{display:flex;justify-content:flex-end;padding-top:4px}.month-current-btn{background:transparent;border:0;padding:6px 10px;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;font-family:inherit;color:inherit;min-width:110px;height:auto;transition:background .12s}.month-current-btn:hover{background:var(--bg-elev)}.cal-popover{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);z-index:120;width:272px;padding:16px;border-radius:16px;overflow:hidden;background:hsla(40,37%,97%,.82);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);border:1px solid hsla(0,0%,100%,.7);box-shadow:0 8px 32px rgba(26,24,21,.14),0 2px 8px rgba(26,24,21,.08),inset 0 1px 0 hsla(0,0%,100%,.9);animation:calPop .18s cubic-bezier(.34,1.36,.64,1) both}[data-theme=dark] .cal-popover{background:rgba(23,23,27,.82);border:1px solid hsla(0,0%,100%,.09);box-shadow:0 8px 40px rgba(0,0,0,.5),0 2px 10px rgba(0,0,0,.3),inset 0 1px 0 hsla(0,0%,100%,.05)}@keyframes calPop{0%{opacity:0;transform:translateX(-50%) scale(.92) translateY(-6px)}to{opacity:1;transform:translateX(-50%) scale(1) translateY(0)}}.cal-orb{position:absolute;top:-40px;right:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,color-mix(in oklab,var(--accent) 40%,transparent) 0,transparent 70%);filter:blur(20px);pointer-events:none;opacity:.6}.cal-year-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-year-label{font-family:var(--font-num);font-size:15px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.cal-year-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:8px;cursor:pointer;color:var(--text-mute);transition:background .1s,color .1s,transform 80ms}.cal-year-btn:hover{background:rgba(0,0,0,.06);color:var(--text)}[data-theme=dark] .cal-year-btn:hover{background:hsla(0,0%,100%,.08)}.cal-year-btn:active{transform:scale(.88)}.cal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.cal-month-btn{padding:8px 4px;background:transparent;border:1.5px solid transparent;border-radius:10px;font-family:inherit;font-size:12.5px;font-weight:500;color:var(--text);cursor:pointer;text-align:center;transition:background .11s,color .11s,transform .11s,border-color .11s;position:relative}.cal-month-btn:hover:not(.selected){background:rgba(0,0,0,.06);transform:scale(1.06)}[data-theme=dark] .cal-month-btn:hover:not(.selected){background:hsla(0,0%,100%,.08)}.cal-month-btn:active{transform:scale(.94)}.cal-month-btn.today{border-color:color-mix(in oklab,var(--accent) 55%,transparent);color:var(--accent)}.cal-month-btn.selected{background:var(--accent);color:#0a0a0b;font-weight:700;transform:scale(1.04);box-shadow:0 3px 12px color-mix(in oklab,var(--accent) 35%,transparent)}.cal-month-btn.selected:hover{filter:brightness(1.08)}.payment-row{position:relative}.payment-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;gap:2px;opacity:0;pointer-events:none;transition:opacity .14s;background:var(--bg-card);padding:4px 4px 4px 12px;background:linear-gradient(to right,transparent,var(--bg-card) 18%);border-radius:0 8px 8px 0}.payment-row:hover .payment-actions{opacity:1;pointer-events:auto}.payment-row:hover .payment-amount{opacity:0;transition:opacity 80ms}.action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:7px;cursor:pointer;color:var(--text-mute);transition:background .1s,color .1s,border-color .1s}.action-btn:hover{background:var(--bg-elev);border-color:var(--border);color:var(--text)}.action-btn.danger:hover{background:rgba(251,113,133,.1);border-color:rgba(251,113,133,.25);color:#fb7185}.mf-cancel-btn{padding:9px 16px;background:transparent;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:13.5px;font-weight:500;color:var(--text-mute);cursor:pointer;transition:background .1s,color .1s}.mf-cancel-btn:hover:not(:disabled){background:var(--bg-elev);color:var(--text)}.mf-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.income-edit-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;border:1px solid var(--border);border-radius:7px;font-family:inherit;font-size:11.5px;font-weight:500;color:var(--text-mute);cursor:pointer;transition:background .1s,color .1s,border-color .1s}.income-edit-btn:hover{background:var(--bg-elev);color:var(--text);border-color:var(--border-strong)}.income-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--border)}.income-row:last-of-type{border-bottom:none}.income-row-label{display:flex;align-items:center;gap:10px}.income-row-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.income-row-input{display:flex;align-items:center;gap:6px}.income-total{display:flex;justify-content:space-between;align-items:center;padding:12px 0 4px;font-size:13px;color:var(--text-mute);border-top:2px solid var(--border);margin-top:4px}.income-total-value{font-family:var(--font-num);font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em}.mobile-nav-toggle{display:none;position:fixed;top:14px;left:14px;z-index:110;width:40px;height:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.08)}.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:95;backdrop-filter:blur(2px)}@media (max-width:1024px){.dash-grid,.hero{grid-template-columns:1fr}.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:none}.content{padding:20px 20px 48px}}@media (max-width:640px){.mobile-nav-toggle{display:flex}.sidebar{position:fixed;top:0;left:0;height:100vh;transform:translateX(-100%);transition:transform .24s cubic-bezier(.32,.72,0,1);z-index:100;box-shadow:8px 0 40px rgba(0,0,0,.25);width:280px}.sidebar.open{transform:translateX(0)}.sidebar.open+.sidebar-backdrop{display:block}.content{padding:60px 14px 80px}.topbar{flex-direction:column;align-items:stretch;gap:12px;padding:12px 0 16px}.topbar-left{justify-content:space-between;padding-left:48px}.topbar-right{justify-content:flex-end}.topbar-title{font-size:18px}.hero-main{padding:20px}.hero-value{font-size:32px;margin:8px 0 18px}.hero-stats{grid-template-columns:1fr}.stat-card{padding:14px 16px}.card{padding:16px 14px!important;border-radius:12px}.card-head{flex-direction:column;align-items:stretch;gap:12px}.payment-row{grid-template-columns:26px 4px 1fr auto;gap:8px;padding:8px 2px}.payment-date-wrap,.payment-method-select,.payment-row.paid .payment-date-wrap,.payment-row.paid .payment-method-select{display:none!important}.payment-amount,.payment-name{font-size:13px}.payment-actions{position:static;background:transparent;padding:0;opacity:0;pointer-events:none}.group-head{padding:10px 2px}.group-sum{min-width:80px;font-size:12.5px}.year-strip{overflow-x:auto;-webkit-overflow-scrolling:touch}.modal-overlay{padding:12px}.modal-box{max-width:100%!important;max-height:92vh}.modal-form{padding:16px 18px 20px}.mf-row{flex-direction:column;gap:12px}.add-payment-btn{padding:8px 14px;font-size:13px}.month-current-btn{min-width:90px}.month-name{font-size:12px}.seg button{padding:5px 10px;font-size:11.5px}}@media (min-width:641px){.mobile-nav-toggle{display:none!important}}