.auth-shell{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{max-width:400px;width:100%;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:32px 36px;box-shadow:var(--shadow-md)}.auth-brand{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:28px}.auth-brand .brand-mark{width:38px;height:38px;border-radius:11px;background:var(--accent);color:var(--ink);display:grid;place-items:center;font-family:IBM Plex Sans,system-ui,sans-serif;font-weight:700;font-size:19px}.auth-brand h1{margin:0;font-family:IBM Plex Sans,system-ui,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.auth-title{margin:0 0 6px;font-family:IBM Plex Sans,system-ui,sans-serif;font-size:24px;font-weight:600;letter-spacing:-.015em;color:var(--ink);text-align:center}.auth-sub{margin:0 0 22px;color:var(--ink-mute);font-size:14px;text-align:center}.auth-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.auth-field label{font-size:12px;font-weight:500;color:var(--ink-soft);display:flex;justify-content:space-between;align-items:center}.auth-field label .forgot{font-size:12px;color:var(--ink-mute);background:0;border:0;cursor:pointer;font-weight:400;padding:0}.auth-field label .forgot:hover{color:var(--ink)}.auth-input{border:1px solid var(--line);background:var(--bg-elev);border-radius:10px;padding:11px 13px;font:inherit;color:var(--ink);outline:none;transition:border-color .15s,background .15s,box-shadow .15s}.auth-input:focus{border-color:var(--ink);background:var(--surface);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 15%,transparent)}.auth-input.error{border-color:var(--past);background:color-mix(in oklab,var(--past-soft) 50%,var(--bg-elev))}.auth-error{color:var(--past-ink);font-size:12px;margin-top:4px}.auth-submit{width:100%;border:0;background:var(--ink);color:var(--bg);padding:12px;border-radius:10px;font:inherit;font-weight:500;font-size:14px;cursor:pointer;margin-top:6px;transition:background .15s,transform .1s}.auth-submit:hover{background:color-mix(in oklab,var(--ink) 88%,var(--accent))}.auth-submit:active{transform:translateY(1px)}.auth-submit:disabled{opacity:.6;cursor:wait}.auth-foot{margin-top:22px;text-align:center;font-size:13px;color:var(--ink-mute)}.auth-foot button{border:0;background:0;color:var(--ink);font:inherit;font-weight:500;cursor:pointer;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--line);padding:0}.auth-foot button:hover{text-decoration-color:var(--accent)}.auth-back{display:inline-flex;align-items:center;gap:6px;border:0;background:0;color:var(--ink-mute);font:inherit;font-size:13px;cursor:pointer;margin-bottom:14px;padding:0}.auth-back:hover{color:var(--ink)}.auth-success{border:1px solid color-mix(in oklab,var(--paid) 30%,var(--line));background:var(--paid-soft);color:var(--paid-ink);padding:12px 14px;border-radius:10px;font-size:13px;margin-bottom:14px}:root{--bg: oklch(97.5% .012 85);--bg-elev: oklch(99% .008 85);--surface: oklch(100% 0 0);--line: oklch(90% .012 75);--line-soft: oklch(94% .01 75);--ink: oklch(22% .015 60);--ink-soft: oklch(42% .018 60);--ink-mute: oklch(58% .015 60);--accent: oklch(58% .14 150);--accent-soft: oklch(92% .05 150);--accent-ink: oklch(38% .11 150);--paid: oklch(58% .09 145);--paid-soft: oklch(93% .04 145);--paid-ink: oklch(35% .08 145);--soon: oklch(68% .14 70);--soon-soft: oklch(94% .05 75);--soon-ink: oklch(42% .1 60);--past: oklch(58% .18 25);--past-soft: oklch(93% .06 25);--past-ink: oklch(40% .15 25);--upcoming: oklch(62% .1 220);--upcoming-soft: oklch(94% .03 220);--upcoming-ink: oklch(38% .08 220);--radius: 16px;--radius-sm: 10px;--radius-xs: 6px;--shadow-sm: 0 1px 2px oklch(30% .02 60 / .04), 0 1px 1px oklch(30% .02 60 / .03);--shadow-md: 0 2px 6px oklch(30% .02 60 / .05), 0 8px 24px oklch(30% .02 60 / .06);--font-display: "IBM Plex Sans", system-ui, -apple-system, Segoe UI, Helvetica, sans-serif;--font-ui: "IBM Plex Sans", system-ui, -apple-system, Segoe UI, Helvetica, sans-serif;--font-mono: "IBM Plex Sans", system-ui, -apple-system, Segoe UI, Helvetica, sans-serif}:root[data-theme=dark]{--bg: oklch(20% .012 260);--bg-elev: oklch(24% .014 260);--surface: oklch(27% .016 260);--line: oklch(36% .018 260);--line-soft: oklch(31% .016 260);--ink: oklch(96% .008 250);--ink-soft: oklch(78% .014 250);--ink-mute: oklch(60% .016 250);--accent: oklch(72% .16 150);--accent-soft: oklch(32% .09 150);--accent-ink: oklch(88% .13 150);--paid: oklch(72% .14 165);--paid-soft: oklch(30% .07 165);--paid-ink: oklch(88% .12 165);--soon: oklch(78% .15 85);--soon-soft: oklch(33% .09 85);--soon-ink: oklch(90% .13 85);--past: oklch(70% .18 15);--past-soft: oklch(33% .1 15);--past-ink: oklch(88% .14 15);--upcoming: oklch(72% .13 280);--upcoming-soft: oklch(32% .08 280);--upcoming-ink: oklch(88% .1 280);--shadow-sm: 0 1px 2px #0008;--shadow-md: 0 2px 6px #0007, 0 12px 32px #0008}:root[data-theme=cool]{--bg: oklch(97.5% .012 230);--bg-elev: oklch(99% .008 230);--surface: oklch(100% 0 0);--line: oklch(90% .018 230);--line-soft: oklch(94% .014 230);--ink: oklch(22% .02 245);--ink-soft: oklch(42% .02 240);--ink-mute: oklch(58% .018 235);--accent: oklch(58% .15 250);--accent-soft: oklch(92% .04 250);--accent-ink: oklch(38% .12 250)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--font-ui);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-.01em}button{font:inherit;color:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}.app{max-width:1280px;margin:0 auto;padding:32px 28px 80px}.app-footer{text-align:center;padding:28px 16px 8px;margin-top:32px;color:var(--ink-mute);font-size:12px;letter-spacing:.02em}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px}.brand{display:flex;align-items:baseline;gap:14px}.brand-mark{width:38px;height:38px;border-radius:12px;background:var(--accent);color:#fff;display:inline-grid;place-items:center;font-family:var(--font-display);font-size:24px;line-height:1;box-shadow:var(--shadow-sm);align-self:center}.brand h1{font-family:var(--font-display);font-size:34px;letter-spacing:-.015em;white-space:nowrap}.brand-sub{color:var(--ink-mute);font-size:13px}.month-nav{display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:4px;box-shadow:var(--shadow-sm)}.month-nav button{border:0;background:transparent;width:32px;height:32px;border-radius:999px;display:grid;place-items:center;color:var(--ink-soft);transition:background .15s}.month-nav button:hover{background:var(--bg);color:var(--ink)}.month-nav .label{font-family:var(--font-display);font-size:19px;padding:0 12px;letter-spacing:-.01em;min-width:140px;text-align:center}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px 20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.kpi .kpi-label{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;display:flex;align-items:center;gap:8px}.kpi .kpi-value{font-family:var(--font-display);font-size:clamp(26px,4.2vw,38px);line-height:1.1;margin-top:6px;color:var(--ink);letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi .kpi-sub{margin-top:6px;font-size:13px;color:var(--ink-soft)}.kpi .kpi-value .cents{font-size:.58em;color:var(--ink-mute)}.kpi{min-width:0}.kpi.past-tint{background:linear-gradient(180deg,var(--past-soft),var(--surface) 70%);border-color:color-mix(in oklab,var(--past) 30%,var(--line))}.kpi.paid-tint{background:linear-gradient(180deg,var(--paid-soft),var(--surface) 70%);border-color:color-mix(in oklab,var(--paid) 30%,var(--line))}.kpi.soon-tint{background:linear-gradient(180deg,var(--soon-soft),var(--surface) 70%);border-color:color-mix(in oklab,var(--soon) 30%,var(--line))}.pill-dot{width:8px;height:8px;border-radius:999px;display:inline-block}.insights{display:grid;grid-template-columns:1.15fr 1fr;gap:14px;margin-bottom:24px}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow-sm)}.panel-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}.panel-title{font-family:var(--font-display);font-size:22px;letter-spacing:-.01em}.panel-sub{font-size:12px;color:var(--ink-mute);letter-spacing:.02em;text-transform:uppercase}.type-rows{display:flex;flex-direction:column;gap:10px}.type-row{display:grid;grid-template-columns:16px 1fr auto;align-items:center;gap:10px;font-size:14px}.type-row .type-dot{width:10px;height:10px;border-radius:3px}.type-row .type-bar{height:8px;background:var(--line-soft);border-radius:999px;overflow:hidden;position:relative}.type-row .type-bar .fill{height:100%;border-radius:999px;display:flex;align-items:center;padding-left:10px;color:#fff;font-family:var(--font-mono);font-size:11px;white-space:nowrap}.type-row .type-name{display:flex;align-items:center;gap:8px;color:var(--ink-soft)}.type-row .type-amount{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink);font-size:13px}.progress-panel{display:flex;gap:24px;align-items:center}.ring-wrap{position:relative;width:140px;height:140px;flex-shrink:0}.ring-wrap svg{transform:rotate(-90deg)}.ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center}.ring-center .big{font-family:var(--font-display);font-size:34px;line-height:1}.ring-center .sub{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-mute);margin-top:4px}.ring-stats{flex:1;display:flex;flex-direction:column;gap:10px}.ring-stat{display:flex;align-items:baseline;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--line-soft)}.ring-stat:last-child{border:0}.ring-stat .k{color:var(--ink-soft);font-size:13px;display:flex;align-items:center;gap:8px}.ring-stat .v{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:14px}.upcoming{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.upcoming-empty-state{padding:16px 20px}.upcoming-header{background:transparent;border:0;padding:16px 20px;display:flex;align-items:center;gap:18px;width:100%;text-align:left;cursor:pointer;color:inherit;font:inherit}.upcoming-header:hover{background:color-mix(in oklab,var(--ink) 3%,transparent)}.upcoming.expanded .upcoming-header{border-bottom:1px solid var(--line-soft)}.upcoming-chev{margin-left:auto;color:var(--ink-mute);flex-shrink:0;transition:transform .15s}.upcoming.expanded .upcoming-chev{transform:rotate(180deg)}.upcoming-label{flex-shrink:0;display:flex;align-items:center;gap:10px}.upcoming-label .icon{width:34px;height:34px;border-radius:10px;background:var(--soon-soft);color:var(--soon-ink);display:grid;place-items:center}.upcoming-label .t{font-family:var(--font-display);font-size:18px;line-height:1.1}.upcoming-label .s{font-size:11px;color:var(--ink-mute);letter-spacing:.04em;text-transform:uppercase}.upcoming-list{display:flex;gap:10px;overflow-x:auto;scrollbar-width:thin;padding:14px 20px 16px}.upcoming-card{flex-shrink:0;min-width:180px;border:1px solid var(--line);border-radius:12px;padding:10px 14px;background:var(--bg-elev);cursor:pointer;transition:transform .12s,border-color .12s}.upcoming-card:hover{transform:translateY(-2px);border-color:var(--accent)}.upcoming-card .title{font-weight:500;font-size:14px}.upcoming-card .row{display:flex;justify-content:space-between;align-items:baseline;margin-top:4px}.upcoming-card .row .amt{font-family:var(--font-mono);font-size:13px}.upcoming-card .row .days{font-size:11px;color:var(--soon-ink);font-weight:600}.upcoming-card.past .row .days{color:var(--past-ink)}.upcoming-empty{color:var(--ink-mute);font-style:italic;padding:8px 0}.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.toolbar{display:flex;gap:10px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}.search{flex:1;min-width:180px;position:relative}.search input{width:100%;padding:9px 38px 9px 34px;border:1px solid var(--line);background:var(--bg-elev);border-radius:10px;outline:none;transition:border-color .15s,background .15s}.search input:focus{border-color:var(--accent);background:var(--surface)}.search .icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-mute)}.search-cols-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:0;background:transparent;border-radius:7px;display:grid;place-items:center;color:var(--ink-mute);cursor:pointer;transition:background .15s,color .15s}.search-cols-btn:hover{background:var(--bg);color:var(--ink)}.toolbar select.type-select{padding:8px 30px 8px 12px;background-image:linear-gradient(45deg,transparent 50%,var(--ink-soft) 50%),linear-gradient(135deg,var(--ink-soft) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;-webkit-appearance:none;-moz-appearance:none;appearance:none}.filter-group{display:flex;gap:6px;align-items:center}.filter-group .chip{border:1px solid var(--line);background:var(--bg-elev);padding:7px 12px;border-radius:999px;font-size:13px;color:var(--ink-soft);transition:all .15s}.filter-group .chip:hover{border-color:var(--accent);color:var(--ink)}.filter-group .chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn{border:1px solid var(--line);background:var(--bg-elev);padding:8px 14px;border-radius:10px;font-size:14px;color:var(--ink);display:inline-flex;align-items:center;gap:6px;transition:all .15s}.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.05)}.tbl{width:100%;border-collapse:collapse;table-layout:fixed}.tbl th,.tbl td{text-align:left;padding:12px 14px;font-size:14px;vertical-align:middle;overflow:hidden}.tbl thead th{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;background:var(--bg-elev);border-bottom:1px solid var(--line);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.resizable-th{padding-right:18px}.col-resizer{position:absolute;top:0;right:0;width:10px;height:100%;cursor:col-resize;-webkit-user-select:none;user-select:none;z-index:5;display:flex;align-items:center;justify-content:center}.col-resizer:before{content:"";width:1px;height:60%;background:var(--line);transition:background .15s,width .15s}.resizable-th:hover .col-resizer:before{background:var(--ink-mute);width:2px}.col-resizer:hover:before,.col-resizer:active:before{background:var(--accent)!important;width:2px!important}.tbl thead th:hover{color:var(--ink)}.tbl thead th .sort-ind{margin-left:4px;opacity:.5;font-size:10px}.tbl thead th.sorted .sort-ind{opacity:1;color:var(--accent)}.tbl tbody tr{border-bottom:1px solid var(--line-soft);transition:background .1s}.tbl tbody tr:hover{background:var(--bg)}.tbl tbody tr:last-child{border-bottom:0}.tbl tbody tr td,.tbl tbody tr td.num,.tbl tbody tr td.status,.tbl tbody tr td.title,.tbl tbody tr td.actions{vertical-align:middle!important}.tbl td.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.tbl td.title{font-weight:500}.tbl td.actions{width:60px;min-width:60px;text-align:right}.tbl th.actions-h{width:60px;min-width:60px}.tbl td .edit-cell,.tbl td input.edit-cell{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;letter-spacing:.01em;white-space:nowrap;border:1px solid transparent;cursor:pointer;transition:transform .1s,filter .1s;vertical-align:middle}.badge:hover{filter:brightness(1.03);transform:translateY(-1px)}.badge .dot{width:6px;height:6px;border-radius:999px;background:currentColor}.badge.paid{background:var(--paid-soft);color:var(--paid-ink)}.badge.past{background:var(--past-soft);color:var(--past-ink)}.badge.soon{background:var(--soon-soft);color:var(--soon-ink)}.badge.upcoming{background:var(--upcoming-soft);color:var(--upcoming-ink)}.badge.neutral{background:var(--line-soft);color:var(--ink-soft)}.type-tag{display:inline-flex;padding:3px 10px;border-radius:6px;font-size:12px;color:#fff;letter-spacing:.01em}.edit-cell{border:1px solid transparent;background:transparent;padding:6px 8px;border-radius:6px;font:inherit;color:inherit;width:100%;outline:none;transition:border-color .15s,background .15s}.edit-cell:hover{border-color:var(--line)}.edit-cell:focus{border-color:var(--accent);background:var(--bg-elev)}input.edit-cell[type=number],input.edit-cell[type=date]{font-family:var(--font-mono)}input.edit-cell[type=number]{text-align:left}button.edit-cell.edit-display{border:1px solid transparent;background:transparent;font:inherit;color:inherit;padding:6px 8px;border-radius:6px;text-align:left}button.edit-cell.edit-display:hover{border-color:var(--line);background:var(--bg-elev)}.icon-btn{width:28px;height:28px;border:0;background:transparent;border-radius:8px;display:inline-grid;place-items:center;color:var(--ink-mute);opacity:0;transition:opacity .15s,background .15s,color .15s}.tbl tr:hover .icon-btn,.schedule-row .icon-btn,.history-row .icon-btn{opacity:1}.schedule-row{transition:background .12s}.schedule-row:hover{background:var(--bg-elev)}.schedule-row.paused{font-style:italic}.bill-row.skipped{opacity:.55;font-style:italic}.bill-row.skipped:hover{opacity:.85}.icon-btn:hover,.icon-btn-danger:hover{background:var(--past-soft);color:var(--past-ink)}.check-pill{width:22px;height:22px;border:1.5px solid var(--line);border-radius:999px;display:inline-grid;place-items:center;background:transparent;transition:all .15s;padding:0;margin-right:4px;vertical-align:middle}.check-pill.checked{background:var(--paid);border-color:var(--paid);color:#fff}.check-pill:hover{border-color:var(--paid)}.tfoot{padding:14px 16px;border-top:1px solid var(--line);background:var(--bg-elev);display:flex;justify-content:space-between;font-size:13px}.tfoot .val{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:15px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b150f59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;animation:fade .2s;padding:24px;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius);padding:16px 24px 24px;width:440px;max-width:100%;max-height:calc(100vh - 48px);overflow-y:auto;box-shadow:var(--shadow-md);border:1px solid var(--line);animation:rise .2s}.modal h3{font-family:var(--font-display);font-size:24px;margin-bottom:14px}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.field label{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute)}.field input,.field select,.field textarea{border:1px solid var(--line);background:var(--bg-elev);padding:9px 12px;border-radius:10px;outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);background:var(--surface)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;min-height:28px}.modal-head h3{margin:0;line-height:1.2}.modal-del{color:var(--past-ink)}.modal-del:hover{background:var(--past-soft)}.scope-block{margin-top:12px;padding:12px;border:1px solid var(--line);border-radius:10px;background:var(--bg-elev)}.scope-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-mute);margin-bottom:8px}.scope-options{display:flex;flex-direction:column;gap:6px}.scope-opt{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);cursor:pointer;transition:border-color .12s,background .12s}.scope-opt:hover{border-color:var(--accent)}.scope-opt.active{border-color:var(--accent);background:var(--accent-soft)}.scope-opt input{accent-color:var(--accent);margin-top:2px;flex-shrink:0}.scope-opt-title{font-size:14px;font-weight:500}.scope-opt-sub{font-size:12px;color:var(--ink-mute);margin-top:1px}.tbl tbody tr.bill-row{cursor:pointer}.tbl tbody tr.bill-row:hover{background:var(--bg)}.recur-toggle{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--bg-elev);cursor:pointer;margin-top:6px}.recur-toggle input{accent-color:var(--accent);width:18px;height:18px;flex-shrink:0}.recur-pill{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:999px;background:var(--accent-soft);color:var(--accent-ink);font-size:11px;flex-shrink:0;cursor:help}.notes-cell{display:flex;align-items:center;gap:6px;width:100%;border:1px solid transparent;background:transparent;padding:6px 8px;border-radius:6px;text-align:left;font:inherit;color:var(--ink-soft);cursor:pointer;min-height:30px;transition:border-color .12s,background .12s}.notes-cell:hover{border-color:var(--line);background:var(--bg-elev)}.notes-cell.has-note{color:var(--ink-soft)}.notes-cell .notes-preview{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;flex:1;min-width:0}.notes-cell .notes-placeholder{color:var(--ink-mute);font-size:13px;font-style:italic}.notes-popover{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(440px,90vw);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:80;padding:16px;animation:rise .15s}.notes-popover-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.notes-popover-title{font-weight:500;font-size:15px;color:var(--ink)}.notes-popover-close{border:0;background:transparent;color:var(--ink-mute);font-size:22px;line-height:1;width:28px;height:28px;border-radius:6px}.notes-popover-close:hover{background:var(--bg);color:var(--ink)}.notes-popover-textarea{width:100%;border:1px solid var(--line);border-radius:10px;background:var(--bg-elev);padding:10px 12px;font:inherit;color:var(--ink);resize:vertical;min-height:120px;outline:none}.notes-popover-textarea:focus{border-color:var(--accent);background:var(--surface)}.notes-popover-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:12px}.notes-popover-hint{font-size:11px;color:var(--ink-mute);letter-spacing:.02em}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.tweaks-panel{position:fixed;bottom:20px;right:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-md);width:260px;z-index:90;font-size:13px}.tweaks-panel h4{font-family:var(--font-display);font-size:18px;margin-bottom:12px}.tweaks-panel .t-field{margin-bottom:10px}.tweaks-panel .t-field label{display:block;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px}.tweaks-panel .t-opts{display:flex;gap:4px;flex-wrap:wrap}.tweaks-panel .t-opt{border:1px solid var(--line);background:var(--bg-elev);padding:5px 10px;border-radius:8px;font-size:12px;color:var(--ink-soft)}.tweaks-panel .t-opt.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}:root[data-density=compact] .tbl th,:root[data-density=compact] .tbl td{padding:8px 12px;font-size:13px}:root[data-density=compact] .kpi{padding:14px 16px}:root[data-density=compact] .kpi .kpi-value{font-size:30px}:root[data-layout=table-first] .kpis{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}:root[data-layout=table-first] .kpi .kpi-value{font-size:26px}:root[data-layout=table-first] .insights{display:none}:root[data-layout=table-first] .upcoming{display:none}.tbl-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.tbl-scroll .tbl{min-width:720px}.toolbar{position:relative}.cols-pop{position:absolute;top:calc(100% - 4px);right:16px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);padding:10px 12px;z-index:60;max-height:calc(100vh - 140px);overflow-y:auto;z-index:20;min-width:200px}.cols-pop-title{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);padding:4px 2px 8px;border-bottom:1px solid var(--line-soft);margin-bottom:6px}.cols-pop-row{display:flex;align-items:center;gap:10px;padding:6px 2px;font-size:14px;cursor:pointer;border-radius:6px}.cols-pop-row:hover{background:var(--bg)}.cols-pop-row.required{cursor:not-allowed;color:var(--ink-mute)}.cols-pop-row input{accent-color:var(--accent)}.req-tag{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-mute);margin-left:6px}.topbar-right,.topbar-actions{display:flex;align-items:center;gap:10px}.view-toggle{display:flex;border:1px solid var(--line);border-radius:999px;padding:4px;background:var(--surface);box-shadow:var(--shadow-sm);gap:2px}.view-toggle-btn{border:0;background:transparent;width:36px;height:32px;border-radius:999px;display:grid;place-items:center;color:var(--ink-soft);transition:background .15s,color .15s}.view-toggle-btn:hover{color:var(--ink)}.view-toggle-btn.active{background:var(--ink);color:var(--bg)}.settings-page{display:flex;flex-direction:column;gap:28px;max-width:760px}.settings-section-head{margin-bottom:12px}.settings-section-head h2{font-size:22px;font-weight:500;letter-spacing:-.01em;margin-bottom:4px}.settings-section-head p{margin:0;color:var(--ink-mute);font-size:13px}.settings-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 22px;border-bottom:1px solid var(--line-soft)}.setting-row:last-child{border-bottom:0}.setting-row-text{flex:1;min-width:0}.setting-row-label{font-weight:500;font-size:15px;color:var(--ink)}.setting-row-desc{font-size:13px;color:var(--ink-mute);margin-top:2px}.setting-row-control{flex-shrink:0}.btn.danger{border-color:color-mix(in oklab,var(--past) 40%,var(--line));color:var(--past-ink)}.btn.danger:hover{background:var(--past-soft);border-color:var(--past)}.setting-btn-row{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px}.seg-control{display:inline-flex;background:var(--bg-elev);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}.seg-opt{border:0;background:transparent;padding:6px 14px;border-radius:7px;font-size:13px;color:var(--ink-soft);transition:all .15s}.seg-opt.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.theme-picker{display:flex;gap:10px}.theme-swatch{border:2px solid var(--line);background:var(--surface);padding:8px 8px 6px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:border-color .15s,transform .1s}.theme-swatch:hover{transform:translateY(-2px)}.theme-swatch.active{border-color:var(--accent)}.theme-swatch-preview{width:56px;height:36px;border-radius:6px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #00000014}.theme-swatch-preview .surf{position:absolute;top:6px;left:6px;right:6px;bottom:14px;border-radius:3px}.theme-swatch-preview .acc{position:absolute;bottom:5px;left:6px;width:18px;height:5px;border-radius:999px}.theme-swatch-label{font-size:12px;color:var(--ink-soft)}.theme-swatch.active .theme-swatch-label{color:var(--ink);font-weight:500}.about-card .about-row{display:flex;justify-content:space-between;gap:16px;padding:14px 22px;border-bottom:1px solid var(--line-soft);font-size:14px;white-space:nowrap}.about-card .about-row:last-child{border-bottom:0}.about-card .muted{color:var(--ink-mute)}.types-manager{padding:14px 18px 18px}.type-list{list-style:none;margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:4px}.type-item{display:flex;align-items:center;gap:8px;padding:4px;border-radius:8px;transition:background .12s}.type-item:hover{background:var(--bg)}.type-label{flex:1;text-align:left;border:0;background:transparent;padding:8px 10px;border-radius:7px;font:inherit;color:var(--ink);font-size:14px;cursor:text}.type-label:hover{background:var(--bg-elev)}.type-edit-input{flex:1;border:1px solid var(--accent);background:var(--surface);padding:7px 10px;border-radius:7px;font:inherit;color:var(--ink);font-size:14px;outline:none}.type-del{width:30px;height:30px;border:0;background:transparent;border-radius:7px;display:grid;place-items:center;color:var(--ink-mute);cursor:pointer;opacity:0;transition:opacity .12s,background .12s,color .12s}.type-item:hover .type-del{opacity:1}.type-del:hover{background:var(--past-soft);color:var(--past-ink)}.type-empty{color:var(--ink-mute);font-style:italic;padding:12px 10px;font-size:13px}.type-add{display:flex;gap:8px;padding-top:14px;border-top:1px solid var(--line-soft)}.type-add input{flex:1;border:1px solid var(--line);background:var(--bg-elev);padding:9px 12px;border-radius:9px;font:inherit;color:var(--ink);outline:none;transition:border-color .15s,background .15s}.type-add input:focus{border-color:var(--accent);background:var(--surface)}.type-add .btn.primary:disabled{opacity:.5;cursor:not-allowed}.income-input{display:inline-flex;align-items:center;border:1px solid var(--line);background:var(--bg-elev);border-radius:8px;padding:0 4px 0 12px;transition:border-color .15s,background .15s}.income-input:focus-within{border-color:var(--accent);background:var(--surface)}.income-prefix{color:var(--ink-mute);font-family:var(--font-mono);margin-right:4px}.income-input input{border:0;outline:none;background:transparent;padding:8px 6px;width:110px;font-family:var(--font-mono);font-size:14px;text-align:right;color:var(--ink)}.toast-host{position:fixed;top:0;left:0;right:0;display:flex;flex-direction:column;gap:0;z-index:200;pointer-events:none}.toast{width:100%;background:var(--ink);color:var(--bg);padding:12px 28px;border-radius:0;border-bottom:1px solid oklch(100% 0 0 / .08);display:flex;align-items:center;justify-content:center;gap:16px;box-shadow:var(--shadow-md);animation:slideDown .22s ease-out;pointer-events:auto;font-size:14px;font-weight:500}.toast-msg{flex:0 1 auto;text-align:center}.toast-action{background:transparent;color:var(--accent);border:0;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;padding:4px 10px;border-radius:6px;transition:background .15s}.toast-action:hover{background:#ffffff14}.toast-close{position:absolute;right:16px;background:transparent;border:0;color:var(--bg);opacity:.5;font-size:20px;line-height:1;cursor:pointer;padding:0 6px}.toast-close:hover{opacity:1}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 720px){.toast{padding:10px 44px 10px 16px;font-size:13px}.toast-msg{text-align:left}}.popover-anchor{position:relative}.popover{position:absolute;top:calc(100% + 6px);left:0;z-index:60;min-width:220px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);padding:6px;display:flex;flex-direction:column;max-height:320px;overflow-y:auto}.popover-item{display:flex;align-items:center;justify-content:space-between;gap:12px;background:transparent;border:0;color:var(--ink);font-size:14px;padding:8px 12px;border-radius:6px;text-align:left;cursor:pointer;transition:background-color .1s}.popover-item:hover{background:var(--bg)}.popover-item.selected{color:var(--accent);background:color-mix(in oklab,var(--accent) 10%,transparent)}.btn.btn-picker{min-width:200px;padding:9px 14px;justify-content:space-between;gap:10px}.btn-picker-chev{color:var(--ink-mute);flex-shrink:0;transition:transform .15s}.btn-picker[aria-expanded=true] .btn-picker-chev{transform:rotate(180deg)}.col-select{width:32px;padding:0 8px!important}.col-select input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;margin:0}.tbl tbody tr.selected td,.tbl tbody tr.selected:hover td{background:var(--accent-soft)}.bulk-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--bg);border-radius:14px;padding:8px 8px 8px 16px;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-md);z-index:90;animation:rise .25s}.bulk-count{font-size:14px;font-weight:500;white-space:nowrap}.bulk-clear{background:transparent;border:0;color:var(--bg);opacity:.6;width:24px;height:24px;font-size:18px;line-height:1;cursor:pointer;border-radius:6px}.bulk-clear:hover{opacity:1;background:#ffffff1a}.bulk-divider{width:1px;height:20px;background:#ffffff26}.bulk-btn{background:transparent;border:0;color:var(--bg);font-size:13px;padding:6px 10px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:background .15s;white-space:nowrap}.bulk-btn:hover{background:#ffffff1a}.bulk-btn.danger{color:#fa8880}.bulk-btn.danger:hover{background:#c6595433}.bulk-type-wrap{position:relative}.bulk-type-pop{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--surface);color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:4px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;min-width:140px}.bulk-type-opt{background:transparent;border:0;text-align:left;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px;color:var(--ink)}.bulk-type-opt:hover{background:var(--bg)}@media (max-width: 720px){.bulk-bar{left:12px;right:12px;transform:none;flex-wrap:wrap;bottom:12px}}@media (max-width: 720px){.app{padding:20px 14px 64px}.topbar{flex-direction:column;align-items:stretch;gap:14px}.brand{justify-content:center}.brand h1{font-size:26px}.topbar-right{flex-direction:column;align-items:center;gap:10px;width:100%}.topbar-actions{order:1;display:flex;justify-content:center;align-items:center;gap:10px}.month-nav{order:2;width:auto;justify-content:center}.month-nav .label{flex:none;min-width:0;padding:0 16px}.owners-pill{display:flex;width:fit-content;margin:0 auto}.kpis{grid-template-columns:repeat(2,1fr);gap:10px}.kpi .kpi-value{font-size:26px}.kpi .kpi-value .cents{font-size:16px}.insights{grid-template-columns:1fr}.upcoming-empty-state{padding:14px 16px}.upcoming-header{padding:14px 16px;gap:12px}.upcoming-list{flex-direction:column;overflow-x:visible;gap:8px;padding:12px 16px 14px}.upcoming-card{min-width:0;width:100%}.toolbar{padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.search{grid-column:1 / -1}.filter-group{grid-column:1 / -1;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:2px}.filter-group .chip{flex-shrink:0}.toolbar select.btn{min-width:0!important}.btn.btn-picker{min-width:0;width:100%;grid-column:1 / -1}.toolbar>.btn.primary{grid-column:1 / -1}.cols-pop{right:12px;left:12px}.tbl th,.tbl td{padding:10px;font-size:13px}.tbl th{font-size:10px}.tfoot{flex-direction:column;align-items:stretch;gap:4px;font-size:12.5px}.tfoot>span{display:block}.tweaks-panel{left:12px;right:12px;bottom:12px;width:auto}.setting-row{flex-direction:column;align-items:flex-start;gap:12px;padding:16px}.setting-row-control,.seg-control{width:100%}.seg-opt{flex:1}.theme-picker{width:100%;justify-content:space-between}}.tbl td.actions .icon-btn{opacity:1}@media (hover: hover){.tbl td.actions .icon-btn{opacity:0}.tbl tr:hover .icon-btn{opacity:1}}.kpi-value,.tbl .num,.drawer-item-amt,.upcoming-card .amt,.history-row-sentence,.share-preview{font-variant-numeric:tabular-nums}.owners-pill{display:inline-flex;border:1px solid var(--line);background:var(--bg-elev);border-radius:999px;padding:3px;gap:2px}.owners-pill-seg{border:0;background:transparent;padding:6px 12px;border-radius:999px;font:inherit;font-size:12.5px;color:var(--ink-soft);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.owners-pill-seg:hover{color:var(--ink)}.owners-pill-seg.active{background:var(--ink);color:var(--bg)}.kpi{position:relative}.kpi-spark{margin-top:10px;margin-left:-2px;margin-right:-2px;display:flex;justify-content:stretch}.kpi-spark .spark{width:100%;height:28px;display:block}.bell-btn{position:relative;width:36px;height:36px;border-radius:10px;border:1px solid var(--line);background:var(--bg-elev);color:var(--ink-soft);display:grid;place-items:center;cursor:pointer;margin-right:4px;transition:background .15s,color .15s,border-color .15s}.bell-btn:hover{color:var(--ink);border-color:var(--accent)}.bell-badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;border-radius:999px;background:var(--past);color:#fff;font-size:10px;font-weight:600;display:grid;place-items:center;padding:0 5px;border:2px solid var(--bg)}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in oklab,var(--ink) 25%,transparent);opacity:0;pointer-events:none;transition:opacity .2s;z-index:90}.drawer-scrim.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:var(--bg);border-left:1px solid var(--line);z-index:91;transform:translate(100%);transition:transform .25s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;box-shadow:-10px 0 30px #0000000f}.drawer.open{transform:translate(0)}.drawer-head{padding:18px 20px 14px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between}.drawer-title-wrap{display:flex;align-items:center;gap:10px}.drawer-head h3{margin:0;font-family:var(--font-display);font-size:17px;font-weight:600}.drawer-count{background:var(--accent-soft);color:var(--accent-ink);border-radius:999px;padding:2px 9px;font-size:12px;font-weight:600;min-width:20px;text-align:center}.drawer-body{flex:1;overflow:auto;padding:8px}.drawer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.drawer-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;border:0;background:transparent;padding:10px 12px;border-radius:10px;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:background .15s}.drawer-item:hover{background:var(--bg-elev)}.drawer-item-main{min-width:0}.drawer-item-title{font-weight:500;font-size:14px}.drawer-item-sub{margin-top:2px;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-mute)}.drawer-type-dot{width:7px;height:7px;border-radius:50%;display:inline-block}.drawer-item-right{text-align:right;flex-shrink:0}.drawer-item-amt{font-size:14px;font-weight:500}.drawer-item-pill{margin-top:3px;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px}.drawer-item-pill-soon{background:var(--soon-soft);color:var(--soon-ink)}.drawer-item-pill-upcoming{background:var(--accent-soft);color:var(--accent-ink)}.drawer-item-pill-past{background:var(--past-soft);color:var(--past-ink)}.drawer-empty{padding:60px 20px;text-align:center;color:var(--ink-mute)}.drawer-empty-mark{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--paid-soft);color:var(--paid-ink);font-size:22px;font-weight:600;margin-bottom:14px}.dot-sep{color:var(--ink-mute)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in oklab,var(--ink) 30%,transparent);display:grid;place-items:center;padding:20px;z-index:100}.settle-modal{background:var(--surface);border:1px solid var(--line);border-radius:16px;width:min(440px,100%);overflow:hidden;box-shadow:0 20px 60px #0000002e}.settle-modal .modal-head,.modal .modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--line-soft)}.modal-head h3{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.01em}.modal-close{border:0;background:transparent;color:var(--ink-mute);font-size:22px;line-height:1;width:28px;height:28px;border-radius:7px;cursor:pointer}.modal-close:hover{background:var(--bg-elev);color:var(--ink)}.modal-body{padding:16px 22px 8px;display:flex;flex-direction:column;gap:14px}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 22px 18px;border-top:1px solid var(--line-soft)}.btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink);font-weight:500}.btn-primary:hover{background:color-mix(in oklab,var(--ink) 88%,var(--accent))}.form-row{display:flex;flex-direction:column;gap:6px}.form-row label{font-size:12px;font-weight:500;color:var(--ink-soft)}.form-row .muted{color:var(--ink-mute);font-weight:400}.form-row input[type=text],.form-row input[type=date],.form-row input[type=number]{border:1px solid var(--line);background:var(--bg-elev);border-radius:10px;padding:9px 12px;font:inherit;color:var(--ink);outline:none;transition:border-color .15s,background .15s}.form-row input:focus{border-color:var(--accent);background:var(--surface)}.amt-input-wrap{position:relative;display:flex;align-items:center}.amt-prefix{position:absolute;left:12px;color:var(--ink-mute);font-size:16px}.amt-input{padding-left:26px!important;font-size:18px!important;font-weight:500;width:100%;font-variant-numeric:tabular-nums}.direction-toggle{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--bg-elev)}.direction-opt{flex:1;border:0;background:transparent;padding:9px 10px;font:inherit;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:background .15s,color .15s}.direction-opt:hover{color:var(--ink)}.direction-opt.active{background:var(--ink);color:var(--bg)}.direction-opt+.direction-opt{border-left:1px solid var(--line)}.direction-opt.active+.direction-opt,.direction-opt:has(+.direction-opt.active){border-left-color:var(--ink)}.history-view{padding:22px;max-width:920px;margin:0 auto}.history-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px}.page-title{margin:0 0 4px;font-family:var(--font-display);font-size:26px;font-weight:600;letter-spacing:-.015em}.page-sub{margin:0;color:var(--ink-mute);font-size:14px}.history-empty{border:1px dashed var(--line);background:var(--bg-elev);border-radius:14px;padding:60px 30px;text-align:center;color:var(--ink-mute)}.history-empty-icon{display:inline-grid;place-items:center;width:64px;height:64px;border-radius:50%;background:var(--surface);border:1px solid var(--line-soft);color:var(--ink-mute);margin-bottom:14px}.history-list{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:14px;background:var(--surface);overflow:hidden}.history-row{display:grid;grid-template-columns:64px 1fr auto;gap:16px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line-soft)}.history-row:last-child{border-bottom:0}.history-row-date{text-align:center;border-right:1px solid var(--line-soft);padding-right:16px}.history-row-day{font-family:var(--font-display);font-size:22px;font-weight:600;line-height:1;color:var(--ink)}.history-row-mo{font-size:11px;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase;margin-top:4px}.history-row-sentence{font-weight:500;font-size:14.5px}.history-row-pos{color:var(--paid-ink)}.history-row-neg{color:var(--past-ink)}.history-row-meta{margin-top:3px;font-size:12px;color:var(--ink-mute);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.history-row-note{color:var(--ink-soft)}.history-row-actions{display:flex;gap:4px}.history-row-actions .icon-btn{width:32px;height:32px;border-radius:8px;border:0;background:transparent;color:var(--ink-mute);display:grid;place-items:center;cursor:pointer;transition:background .15s,color .15s}.history-row-actions .icon-btn:hover{background:var(--bg-elev);color:var(--ink)}.history-row-actions .icon-btn-danger:hover{background:var(--past-soft);color:var(--past-ink)}.share-block{border:1px solid var(--line-soft);background:var(--bg-elev);border-radius:12px;padding:14px;margin-top:4px;display:flex;flex-direction:column;gap:12px}.share-row{display:flex}.share-segs{display:inline-flex;border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:3px;gap:2px}.share-seg{border:0;background:transparent;padding:6px 14px;border-radius:999px;font:inherit;font-size:12.5px;color:var(--ink-soft);cursor:pointer}.share-seg:hover{color:var(--ink)}.share-seg.active{background:var(--ink);color:var(--bg)}.share-pct-row{display:flex;align-items:center;gap:14px}.share-pct-field{flex:1;display:flex;flex-direction:column;gap:4px}.share-pct-label{font-size:12px;color:var(--ink-soft)}.share-pct-input{display:flex;align-items:center;gap:4px;border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:7px 10px;font-variant-numeric:tabular-nums}.share-pct-input input{border:0;outline:none;background:transparent;width:100%;font:inherit;font-size:14px;font-weight:500;color:var(--ink);-moz-appearance:textfield}.share-pct-input input::-webkit-outer-spin-button,.share-pct-input input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.share-pct-input.readonly{color:var(--ink-mute)}.share-pct-input.readonly span:first-child{font-weight:500;color:var(--ink)}.share-pct-divider{color:var(--ink-mute);padding-top:18px}.share-preview{display:flex;align-items:center;gap:12px;padding:8px 0 2px;font-size:13px;color:var(--ink-soft)}.share-preview strong{color:var(--ink);font-weight:600;margin-left:4px}.share-preview-divider{width:4px;height:4px;border-radius:50%;background:var(--ink-mute);display:inline-block}.share-payer{padding-top:4px}.seg-control{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}.seg-opt{border:0;background:var(--surface);padding:8px 12px;font:inherit;font-size:13px;color:var(--ink-soft);cursor:pointer}.seg-opt:hover{color:var(--ink)}.seg-opt.active{background:var(--ink);color:var(--bg)}.seg-opt+.seg-opt{border-left:1px solid var(--line)}.share-pill{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:999px;background:var(--accent-soft);color:var(--accent-ink);flex-shrink:0}.share-sub{font-size:11.5px;color:var(--ink-mute);margin-top:-1px}.tbl-scroll{overflow:auto;max-height:calc(100vh - 200px)}.tbl thead th{position:sticky;top:0;z-index:2;background:var(--bg-elev)}.bill-row.is-today td:first-of-type{position:relative}.bill-row.is-today{box-shadow:inset 3px 0 0 var(--accent)}.bill-row.is-today .col-dueDate{color:var(--accent-ink);font-weight:500}.upcoming-list{padding:4px 0}.upcoming-week-label{flex-shrink:0;display:flex;align-items:center;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);align-self:stretch;border-left:1px dashed var(--line);padding:0 4px 0 12px;margin-left:4px}.upcoming-week-label:first-child{border-left:0;padding-left:0;margin-left:0}.upcoming-card.shared{border-style:solid}.upcoming-card .sub-date{font-size:11px;color:var(--ink-mute);margin-top:2px}.hh-name-input,.setting-input{border:1px solid var(--line);background:var(--bg-elev);border-radius:8px;padding:8px 10px;font:inherit;color:var(--ink);outline:none;transition:border-color .15s,background .15s,box-shadow .15s}.hh-name-input{width:200px}.setting-input{width:100%;max-width:360px}.toolbar{border-top-left-radius:calc(var(--radius) - 1px);border-top-right-radius:calc(var(--radius) - 1px)}.tfoot{border-bottom-left-radius:calc(var(--radius) - 1px);border-bottom-right-radius:calc(var(--radius) - 1px)}@media (min-width: 1600px){.app{max-width:1520px}}@media (min-width: 2000px){.app{max-width:1800px}}.hh-name-input:focus,.setting-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 15%,transparent)}.setting-input::placeholder{color:var(--ink-mute)}.setting-input.error{border-color:var(--past);background:color-mix(in oklab,var(--past-soft) 50%,var(--bg-elev))}.hh-color-picker{display:flex;gap:8px}.hh-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;outline:1px solid var(--line);outline-offset:-2px;transition:transform .15s,border-color .15s,outline-color .15s}.hh-swatch:hover{transform:scale(1.08)}.hh-swatch.active{border-color:var(--surface);outline:2px solid var(--ink);outline-offset:1px}:root{--partner: oklch(62% .14 295);--partner-soft: oklch(94% .04 295);--partner-ink: oklch(40% .13 295)}[data-partner-color=violet]{--partner: oklch(62% .14 295);--partner-soft: oklch(94% .04 295);--partner-ink: oklch(40% .13 295)}[data-partner-color=teal]{--partner: oklch(62% .12 195);--partner-soft: oklch(94% .04 195);--partner-ink: oklch(38% .1 195)}[data-partner-color=amber]{--partner: oklch(70% .13 75);--partner-soft: oklch(94% .05 75);--partner-ink: oklch(44% .11 75)}[data-partner-color=rose]{--partner: oklch(64% .15 15);--partner-soft: oklch(94% .04 15);--partner-ink: oklch(42% .13 15)}[data-partner-color=indigo]{--partner: oklch(58% .13 260);--partner-soft: oklch(94% .04 260);--partner-ink: oklch(38% .12 260)}[data-partner-color=forest]{--partner: oklch(56% .1 150);--partner-soft: oklch(94% .04 150);--partner-ink: oklch(36% .09 150)}[data-theme=dark][data-partner-color=violet]{--partner-soft: oklch(32% .06 295);--partner-ink: oklch(86% .12 295)}[data-theme=dark][data-partner-color=teal]{--partner-soft: oklch(32% .06 195);--partner-ink: oklch(86% .1 195)}[data-theme=dark][data-partner-color=amber]{--partner-soft: oklch(34% .07 75);--partner-ink: oklch(86% .12 75)}[data-theme=dark][data-partner-color=rose]{--partner-soft: oklch(32% .07 15);--partner-ink: oklch(86% .13 15)}[data-theme=dark][data-partner-color=indigo]{--partner-soft: oklch(32% .07 260);--partner-ink: oklch(86% .12 260)}[data-theme=dark][data-partner-color=forest]{--partner-soft: oklch(32% .05 150);--partner-ink: oklch(86% .1 150)}.owners-pill-seg[aria-selected=true]:nth-child(4){background:var(--partner);color:var(--surface)}.share-pill{background:var(--partner-soft);color:var(--partner-ink)}.tbl thead th.col-partnerPaidDate .th-label{color:var(--partner-ink)}
