@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";:root{--bg: #0f1117;--surface: #181c27;--card: #1e2336;--border: #2a3050;--border-faint: rgba(42, 48, 80, .13);--accent: #4f8ef7;--accent-dim: #2a4a8a;--green: #34d399;--yellow: #fbbf24;--red: #f87171;--teal: #2dd4bf;--text: #e8ecf4;--muted: #7a85a0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;height:100vh;height:100dvh;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-shell{display:flex;height:100vh;height:100dvh;overflow:hidden}.flex-col{display:flex;flex-direction:column}.gap-16{gap:16px}.gap-20{gap:20px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}@media(max-width:700px){.grid2,.grid3{grid-template-columns:1fr}}.sidebar{width:188px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-logo{padding:24px 16px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.logo{font-size:22px;font-weight:600;letter-spacing:-.5px}.logo span{color:var(--accent)}.logo-sub{font-size:12px;color:var(--muted);margin-top:2px;font-weight:400}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-group{margin-bottom:4px}.nav-group__label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.6;padding:10px 16px 4px;display:block}.nav-item{display:block;width:100%;text-align:left;background:none;border:none;border-left:2px solid transparent;cursor:pointer;padding:9px 16px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;color:var(--muted);transition:color .15s,background .15s,border-color .15s;white-space:nowrap;text-decoration:none}.nav-item:hover{color:var(--text);background:#2a305033}.nav-item.active{color:var(--accent);border-left-color:var(--accent);background:#4f8ef712}.nav-item--records.active{color:var(--teal);border-left-color:var(--teal);background:#2dd4bf12}.nav-item--records:hover{color:var(--text)}.sidebar-user{padding:12px;flex-shrink:0;border-top:1px solid var(--border)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.content-toolbar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;display:flex;align-items:stretch;padding:0 4px;gap:2px}.content{flex:1;overflow-y:auto;padding:28px 32px 60px}.month-strip{display:flex;align-items:stretch;flex:1}.month-pill-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1px;padding:10px 8px;background:none;border:none;cursor:pointer;font-family:DM Sans,sans-serif;color:var(--muted);border-bottom:2px solid transparent;transition:color .15s,background .15s,border-color .15s}.month-pill-btn:hover{color:var(--text);background:#2a305026}.month-pill-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.month-pill-month{font-size:13px;font-weight:600;line-height:1}.month-pill-year{font-size:10px;font-weight:400;opacity:.65;line-height:1}.month-pill-btn.today .month-pill-month:after{content:"";display:block;width:4px;height:4px;border-radius:50%;background:var(--accent);margin:3px auto 0}.strip-nav{background:none;border:none;color:var(--muted);cursor:pointer;font-size:20px;padding:0 10px;display:flex;align-items:center;flex-shrink:0;transition:color .15s;line-height:1}.strip-nav:hover{color:var(--text)}.btn-today{background:#4f8ef71f;border:1px solid rgba(79,142,247,.3);border-radius:6px;color:var(--accent);font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;padding:5px 10px;cursor:pointer;white-space:nowrap;flex-shrink:0;align-self:center;margin:0 6px;transition:background .15s}.btn-today:hover{background:#4f8ef738}.user-menu-wrap{position:relative;z-index:102}.user-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;font-weight:600;color:#fff;font-family:DM Sans,sans-serif;transition:background .15s;flex-shrink:0}.user-btn:hover{background:#ffffff38}.user-menu-backdrop{position:fixed;inset:0;z-index:99}.user-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1px solid var(--border);border-radius:10px;min-width:200px;box-shadow:0 8px 32px #00000073;z-index:101;overflow:hidden}.user-menu--sidebar{top:auto;bottom:calc(100% + 8px);right:auto;left:0}.user-menu-header{padding:14px 16px 10px;border-bottom:1px solid var(--border)}.user-menu-name{font-size:14px;font-weight:600;color:var(--text)}.user-menu-email{font-size:12px;color:var(--muted);margin-top:2px}.user-menu-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13.5px;font-family:DM Sans,sans-serif;color:var(--text);background:none;border:none;width:100%;text-align:left;cursor:pointer;transition:background .12s;text-decoration:none}.user-menu-item:hover{background:#2a305033}.user-menu-item.danger{color:var(--red)}.user-menu-item.danger:hover{background:#f871711a}.user-menu-divider{height:1px;background:var(--border);margin:2px 0}.user-menu-item.family-item{justify-content:flex-start}.family-check{margin-left:auto;color:var(--accent);font-weight:600}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px 22px}.card-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}.stat-value{font-size:28px;font-weight:600;font-family:DM Mono,monospace;letter-spacing:-1px}.stat-sub{font-size:12px;color:var(--muted);margin-top:4px}.month-pill{display:inline-block;font-size:11px;font-weight:600;border-radius:6px;padding:2px 8px;margin-left:6px;vertical-align:middle}.pill-accent{background:var(--accent-dim);color:var(--accent)}.pill-muted{background:#2a305087;color:var(--muted)}.info-banner{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 16px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;border-radius:8px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s;border:none;padding:8px 16px;text-decoration:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#6fa0ff}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-ghost:hover{background:var(--border)}.btn-danger{background:#f8717126;border:1px solid rgba(248,113,113,.3);color:var(--red)}.btn-danger:hover{background:#f8717140}.btn-sm{font-size:12px;padding:5px 10px;border-radius:6px}.badge{display:inline-block;border-radius:5px;padding:2px 7px;font-size:11px;font-weight:600}.badge-blue{background:#4f8ef726;color:var(--accent)}.badge-green{background:#34d39926;color:var(--green)}.badge-yellow{background:#fbbf2426;color:var(--yellow)}.badge-red{background:#f8717126;color:var(--red)}.badge-teal{background:#2dd4bf26;color:var(--teal)}.badge-gray{background:#7a85a026;color:var(--muted)}.tbl{width:100%;border-collapse:collapse;font-size:13.5px}.tbl th{text-align:left;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--border)}.tbl td{padding:11px 10px;border-bottom:1px solid rgba(42,48,80,.13);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.empty{text-align:center;color:var(--muted);font-size:14px;padding:32px 0;font-style:italic}.inp{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;padding:9px 12px;outline:none;transition:border-color .15s}.inp:focus{border-color:var(--accent)}.field{margin-bottom:16px}.field-row{display:flex;align-items:center;gap:12px}.lbl{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;display:block;margin-bottom:6px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.sec-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px}.sec-title{font-size:19px;font-weight:600;letter-spacing:-.3px;margin-bottom:3px}.sec-sub{font-size:12px;color:var(--muted);margin-top:3px}.mono{font-family:DM Mono,monospace;font-size:14px}.month-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}.month-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:5px 12px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.month-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.cal-event-bill{background:#fbbf242e;color:var(--yellow)}.cal-event-card{background:#f871712e;color:var(--red)}.cal-event-paid{background:#34d3992e;color:var(--green)}.cal-event-no-amt{background:#2a305033;color:var(--muted);opacity:.7}.todo-item{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid rgba(42,48,80,.13)}.todo-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border);background:transparent;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--green)}.todo-check.done{background:#34d39926;border-color:var(--green)}.todo-text{flex:1;font-size:14px}.todo-text.done{text-decoration:line-through;color:var(--muted)}.todo-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:2px 4px;border-radius:4px}.todo-del:hover{color:var(--red)}.prog-wrap{height:5px;background:var(--border);border-radius:3px;overflow:hidden}.prog-fill{height:100%;border-radius:3px;transition:width .3s}.trip-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:4px}.trip-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;cursor:pointer}.trip-header:hover{background:#2a305026}.trip-dest{font-size:16px;font-weight:600}.trip-dates{font-size:12px;color:var(--muted);margin-top:3px}.trip-meta{display:flex;align-items:center;gap:16px}.trip-total{font-size:18px;font-weight:600;font-family:DM Mono,monospace}.trip-body{border-top:1px solid var(--border)}.trip-notes{padding:14px 20px;font-size:13px;color:var(--muted);font-style:italic;border-bottom:1px solid rgba(42,48,80,.13)}.trip-month-header{display:flex;justify-content:space-between;padding:10px 20px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface)}.trip-item-row{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid rgba(42,48,80,.13);font-size:13.5px}.chevron{font-size:12px;color:var(--muted);transition:transform .2s}.chevron.open{transform:rotate(180deg)}.list-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0}.row-left{display:flex;align-items:center;gap:10px}.row-right{display:flex;align-items:center;gap:8px}.cat-group{background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;overflow:hidden}.cat-group-header{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer}.cat-group-header:hover{background:#2a305026}.cat-group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cat-group-name{flex:1;font-size:14px;font-weight:600}.cat-group-count{font-size:12px;color:var(--muted);background:var(--surface);border-radius:10px;padding:2px 8px}.cat-group-body{padding:14px 16px;border-top:1px solid var(--border)}.subcat-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.subcat-inp{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:DM Sans,sans-serif;font-size:13px;padding:6px 10px;outline:none}.drag-handle{color:var(--muted);cursor:grab;font-size:14px}.color-swatch{width:28px;height:28px;border-radius:6px;border:2px solid var(--border);cursor:pointer;padding:0}.plaid-banner{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 18px}.plaid-banner__icon{font-size:22px;flex-shrink:0}.plaid-banner__body{flex:1;min-width:0}.plaid-banner__title{font-size:13.5px;font-weight:600;color:var(--text)}.plaid-banner__sub{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45}.stmt-account-list{display:flex;flex-direction:column;gap:8px}.stmt-account{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.stmt-account__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;gap:12px}.stmt-account__info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.stmt-account__name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stmt-account__count{font-size:11.5px;color:var(--muted);background:var(--surface);border-radius:10px;padding:2px 8px;white-space:nowrap}.stmt-account__actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.stmt-file-list{border-top:1px solid var(--border)}.stmt-file-row{display:flex;align-items:center;gap:12px;padding:10px 18px;border-bottom:1px solid rgba(42,48,80,.13)}.stmt-file-row:last-child{border-bottom:none}.stmt-file-row__icon{font-size:18px;flex-shrink:0;line-height:1}.stmt-file-row__info{flex:1;min-width:0}.stmt-file-row__name{font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stmt-file-row__meta{font-size:11.5px;color:var(--muted);margin-top:2px}.file-drop{border:2px dashed var(--border);border-radius:8px;padding:22px 18px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:border-color .15s,background .15s}.file-drop:hover{border-color:var(--accent);background:#4f8ef70a}.file-drop--has-file{border-style:solid;border-color:var(--accent);background:#4f8ef70f}.file-drop__icon{font-size:26px;flex-shrink:0;line-height:1}.file-drop__name{font-size:13.5px;font-weight:500;color:var(--text)}.file-drop__meta{font-size:11.5px;color:var(--muted);margin-top:3px}.file-drop__hint{font-size:13px;color:var(--muted);line-height:1.5}.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-left:3px solid;border-radius:10px;min-width:260px;max-width:360px;box-shadow:0 8px 32px #00000073;pointer-events:all;font-size:13.5px;color:var(--text)}.toast--success{border-left-color:var(--green)}.toast--error{border-left-color:var(--red)}.toast--info{border-left-color:var(--accent)}.toast__icon{font-size:13px;font-weight:700;flex-shrink:0}.toast--success .toast__icon{color:var(--green)}.toast--error .toast__icon{color:var(--red)}.toast--info .toast__icon{color:var(--accent)}.toast__msg{flex:1;line-height:1.4}.toast__close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:11px;padding:2px 4px;border-radius:4px;flex-shrink:0;transition:color .12s}.toast__close:hover{color:var(--text)}.toast-enter-active{transition:all .25s ease}.toast-leave-active{transition:all .2s ease}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(20px)}
