:root{color-scheme:light;--mango: #f5a623;--mango-dark: #d98a12;--ink: #1f2430;--muted: #6b7280;--bg: #f7f8fa;--card: #ffffff;--border: #e5e7eb;--card-border: #f3d9b0;--stripe: rgba(0, 0, 0, .025);--net-bg: #f3f4f6;--pos: #2e7d32;--neg: #c62828;--zero: #2563eb;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}:root[data-theme=dark]{color-scheme:dark;--mango-dark: #f0b64c;--ink: #e8eaed;--muted: #9aa0aa;--bg: #0f1115;--card: #1a1d24;--border: #2b2f3a;--card-border: rgba(245, 166, 35, .28);--stripe: rgba(255, 255, 255, .045);--net-bg: #23272f;--pos: #4ade80;--neg: #f87171;--zero: #60a5fa}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink)}a{color:var(--mango-dark);text-decoration:none}.app-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;background:var(--card);border-bottom:1px solid var(--border)}.app-header .brand{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink)}.app-header nav{display:flex;gap:.35rem}.nav-tab{padding:.4rem .8rem;border-radius:8px;color:var(--muted);font-weight:600;font-size:.95rem;transition:background .12s ease,color .12s ease}.nav-tab:hover{background:var(--bg);color:var(--ink)}.nav-tab.is-active{background:#f5a62324;color:var(--mango-dark)}.header-right{margin-left:auto;display:flex;align-items:center;gap:1rem}.user-name{font-size:.9rem}.account-menu{position:relative}.burger{font-size:1.1rem;line-height:1;padding:.3rem .55rem}.account-menu-dropdown{position:absolute;right:0;top:calc(100% + .4rem);min-width:9rem;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #1f24301f;display:flex;flex-direction:column;padding:.3rem;z-index:20}.account-menu-dropdown a,.account-menu-dropdown button{text-align:left;border:none;background:none;padding:.5rem .6rem;border-radius:6px;color:var(--ink);font:inherit}.account-menu-dropdown a:hover,.account-menu-dropdown button:hover{background:var(--bg)}.app-main{width:100%;max-width:1500px;margin:0 auto;padding:1.5rem clamp(1rem,4vw,3rem)}.card{background:var(--card);border:1.5px solid var(--card-border);border-radius:14px;padding:1.25rem;box-shadow:0 2px 8px #d98a120f}.muted{color:var(--muted)}.accent{color:var(--mango)}.login-card{max-width:400px;margin:4rem auto;text-align:center;border:none;position:relative;background:linear-gradient(var(--card),var(--card)) padding-box,linear-gradient(135deg,var(--mango),var(--mango-dark) 45%,#ffcf7a 100%) border-box;border:2px solid transparent;box-shadow:0 10px 30px #d98a122e}.login-wordmark{margin:.25rem 0 0;font-size:2.4rem;letter-spacing:-.02em;color:var(--ink)}.login-tagline{margin:.25rem 0 .5rem;color:var(--muted);font-size:.95rem;font-weight:500}.google-signin{position:relative;display:inline-flex;align-items:center;gap:.75rem;margin-top:1rem;line-height:0}.google-signin-glyph{position:absolute;top:50%;left:20px;width:20px;height:20px;transform:translate(-50%,-50%);pointer-events:none}.apple-signin{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:50%;border:1px solid var(--border);background:#000;color:#fff}.apple-signin:hover{background:#111}.apple-signin-glyph{width:20px;height:20px}.error{color:var(--neg);font-size:.85rem}button{cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--ink);border-radius:6px;padding:.3rem .6rem;font:inherit}button:hover{border-color:var(--mango)}input,select,textarea{font:inherit;padding:.3rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--card);color:var(--ink)}.project-switcher,.project-create{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.project-create .currency{width:4rem;text-transform:uppercase}.project-create .fy{display:flex;align-items:center;gap:.3rem;font-size:.85rem;color:var(--muted)}.project-create .fy input[type=number]{width:3.5rem}.category-list{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.5rem}.category-list li{display:flex;align-items:center;gap:.6rem}.category-list input[type=color]{width:2.2rem;height:2.2rem;padding:0;border-radius:6px}.category-list .cat-name{flex:1;max-width:20rem}.badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:.05rem .5rem}button.danger{color:var(--neg)}button.danger:hover{border-color:var(--neg)}.category-add{display:flex;align-items:center;gap:.5rem;margin-top:1rem;border-top:1px solid var(--border);padding-top:1rem}.category-add input[type=color]{width:2.2rem;height:2.2rem;padding:0}.settings-name{width:100%;max-width:22rem;font-size:1rem;padding:.5rem .7rem}.currency-pills{display:flex;flex-wrap:wrap;gap:.4rem}.currency-pill{padding:.35rem .9rem;border:1px solid var(--border);border-radius:999px;background:var(--card);color:var(--ink);font-weight:600;font-size:.9rem;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.currency-pill:hover:not(:disabled){border-color:var(--mango)}.currency-pill.is-active{background:var(--mango);border-color:var(--mango);color:#fff}.currency-pill:disabled{opacity:.55;cursor:default}.fy-table{border-collapse:collapse;width:100%;max-width:32rem;margin-top:.5rem}.fy-table td{padding:.25rem .6rem .25rem 0;vertical-align:middle}.fy-table-label{font-weight:600;white-space:nowrap}.fy-table-picker input[type=date]{padding:.35rem .5rem;border:1px solid var(--border);border-radius:8px;font:inherit;color:var(--ink);background:var(--card)}.fy-table-picker input[type=date]:focus{outline:none;border-color:var(--mango);box-shadow:0 0 0 3px #f5a6232e}.fy-table-end{font-size:.8rem;white-space:nowrap}.fy-table-reset{text-align:right}.linklike{border:none;background:none;color:var(--mango-dark);font:inherit;cursor:pointer;padding:0;text-decoration:underline}.category-flags{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.3rem}.category-flag{display:flex;align-items:center;gap:.6rem;border:1px solid var(--border);border-radius:8px;padding:.35rem .55rem}.category-flag-swatch{position:relative;width:1.7rem;height:1.05rem;flex-shrink:0;cursor:pointer;clip-path:polygon(0 0,100% 0,80% 50%,100% 100%,0 100%)}.category-flag-swatch input[type=color]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;border:none;padding:0;cursor:pointer}.category-flag-name{flex:1;border:none;background:transparent;font:inherit;color:var(--ink);padding:.15rem .25rem}.category-flag-name:focus{outline:none;background:var(--bg);border-radius:4px}.category-flag-name:disabled{color:var(--ink)}.category-flag-delete{border:none;background:none;color:var(--muted);font-size:1.2rem;line-height:1;cursor:pointer;padding:0 .3rem}.category-flag-delete:hover{color:var(--neg)}.txn-form,.txn-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:1rem 0}.txn-filters{border-top:1px solid var(--border);padding-top:1rem;font-size:.9rem}.txn-head{margin-bottom:0}.txn-form .txn-amount{width:7rem}.txn-filter-date{display:flex;align-items:center;gap:.3rem;color:var(--muted)}.txn-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.9rem}.txn-table th,.txn-table td{text-align:left;padding:.4rem .6rem;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}.txn-row-alt td{background:var(--stripe)}.txn-row:hover td{background:#6366f112}.txn-col-clip{width:1%;text-align:center;padding-left:.4rem;padding-right:.2rem}.txn-date-cell{font-variant-numeric:tabular-nums}.txn-memo{color:var(--muted);max-width:16rem;overflow:hidden;text-overflow:ellipsis}.txn-table th.num,.txn-table td.num{text-align:right;white-space:nowrap}.txn-table td.income{color:var(--pos)}.txn-table td.expense{color:var(--neg)}.txn-table tfoot td{border-bottom:none;border-top:2px solid var(--border)}.cat-tag{display:inline-flex;align-items:center;gap:.4rem}.cat-dot{width:.7rem;height:.7rem;border-radius:50%;display:inline-block}.txn-actions{display:flex;gap:.4rem;align-items:center;justify-content:flex-end;white-space:nowrap}.receipt-toggle{border-radius:8px;padding:.25rem .5rem;line-height:1}.txn-edit-btn{padding:.25rem .6rem}.txn-editing td{background:#6366f117;vertical-align:middle}.txn-editing input,.txn-editing select{width:100%}.txn-edit-amount{display:flex;gap:.4rem;align-items:center}.txn-edit-amount select{flex:none;width:auto}.txn-search{display:flex;align-items:center;gap:.5rem;margin:.5rem 0 0;padding:.5rem .75rem;border:1px solid var(--border);border-radius:10px;background:var(--card)}.txn-search:focus-within{border-color:var(--mango);box-shadow:0 0 0 3px #f5a62326}.txn-search-icon{font-size:.9rem;opacity:.6;line-height:1}.txn-search input{flex:1;border:none;background:none;padding:0;font-size:.95rem;outline:none}.txn-search-clear{border:none;background:none;color:var(--muted);font-size:1.2rem;line-height:1;padding:0 .25rem;cursor:pointer}.txn-search-clear:hover{color:var(--ink)}.txn-entry-row td{background:#6366f117;vertical-align:middle}.txn-entry-row input,.txn-entry-row select{width:100%}.txn-entry-row td.num .txn-amount{text-align:right;padding-right:.15rem;font-variant-numeric:tabular-nums}.txn-empty-row td{text-align:center;padding:1.25rem .6rem}.receipt-toggle.is-open{border-color:var(--mango);background:#f5a6231f}.receipts-row td{background:var(--bg)}.receipts{display:flex;flex-direction:column;gap:.6rem;padding:.25rem .25rem .5rem}.receipt-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.receipt-item{display:flex;align-items:center;gap:.6rem}.receipt-item a{display:inline-flex;align-items:center;gap:.4rem;font-weight:500}.receipt-clip{font-size:.9em}.receipt-size{font-size:.8rem}.receipt-remove{margin-left:auto;font-size:.8rem;padding:.15rem .5rem}.receipt-upload{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);cursor:pointer;width:fit-content}.receipt-upload input[type=file]{max-width:16rem}.journey{display:flex;flex-direction:column;gap:1.25rem}.journey-hero{text-align:center;background:linear-gradient(var(--card),var(--card)) padding-box,linear-gradient(135deg,var(--mango),var(--mango-dark) 45%,#ffcf7a 100%) border-box;border:2px solid transparent;box-shadow:0 10px 30px #d98a1226}.journey-emoji{font-size:2.5rem}.journey-title{margin:.5rem 0 .25rem;font-size:1.8rem}.brand-two-tone{color:var(--ink);font-weight:800}.journey-lede{color:var(--muted);max-width:34rem;margin:0 auto .5rem}.journey-steps{text-align:left;max-width:30rem;margin:1rem auto 0;color:var(--ink);line-height:1.6}.project-create-form{display:flex;flex-direction:column;gap:.75rem;max-width:24rem;margin-top:1rem}.project-create-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--muted)}.project-create-form .fy-inputs{display:flex;gap:.4rem}.project-create-form .fy-inputs input[type=number]{width:4rem}.project-create-form .currency{width:5rem;text-transform:uppercase}.project-create-actions{display:flex;gap:.5rem;margin-top:.25rem}.project-create-panel{border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem;background:var(--bg)}.projects-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:1rem;margin-top:1rem}.project-kpi-card{display:flex;flex-direction:column;gap:.5rem;align-items:stretch;text-align:left;cursor:pointer;padding:1.1rem}.project-kpi-card:hover{border-color:var(--mango);box-shadow:0 4px 14px #1f243014}.project-kpi-card.is-selected{border-color:var(--mango);box-shadow:0 0 0 1px var(--mango)}.project-kpi-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.project-kpi-name{font-weight:700;font-size:1.05rem;color:var(--ink)}.project-kpi-meta{font-size:.78rem}.project-kpi-net{display:flex;flex-direction:column;gap:.1rem;margin-top:.35rem;font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--ink)}.project-kpi-net.positive{color:#15803d}.project-kpi-net.negative{color:#b91c1c}.project-kpi-net-label{font-size:.72rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.project-kpi-years{display:flex;flex-direction:column;gap:.25rem;margin-top:.35rem;border-top:1px solid var(--border);padding-top:.6rem}.project-kpi-years-label{font-size:.72rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.1rem}.project-kpi-year-row{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;font-size:.85rem}.project-kpi-year{color:var(--muted);font-variant-numeric:tabular-nums}.project-kpi-year-net{font-weight:600;font-variant-numeric:tabular-nums}.project-kpi-year-net.positive{color:#15803d}.project-kpi-year-net.negative{color:#b91c1c}.project-new-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;min-height:11rem;cursor:pointer;border:2px dashed var(--border);background:transparent;box-shadow:none;color:var(--muted)}.project-new-card:hover{border-color:var(--mango);color:var(--mango-dark)}.project-new-plus{font-size:2rem;line-height:1;font-weight:300}.project-new-label{font-weight:600}button{transition:border-color .15s ease,background .15s ease,box-shadow .15s ease,transform .05s ease}button:active{transform:translateY(1px)}button:focus-visible{outline:none;box-shadow:0 0 0 3px #f5a62359}.btn-primary{border:1px solid transparent;color:#fff;font-weight:600;padding:.5rem 1rem;border-radius:8px;background:linear-gradient(135deg,var(--mango),var(--mango-dark));box-shadow:0 1px 2px #d98a1259}.btn-primary:hover{border-color:transparent;filter:brightness(1.05);box-shadow:0 3px 10px #d98a1259}.btn-primary:disabled{opacity:.6;cursor:default;box-shadow:none;filter:none}.btn-ghost{border-radius:8px;padding:.5rem .9rem;color:var(--ink);background:var(--card)}.btn-toggle{display:inline-flex;align-items:center;gap:.4rem;border-radius:8px;padding:.5rem .9rem;font-weight:600;color:var(--mango-dark);background:var(--card)}.btn-toggle .chevron{display:inline-block;transition:transform .2s ease;font-size:.9em;line-height:1}.btn-toggle.is-open .chevron{transform:rotate(90deg)}.fy-picker{display:inline-flex;align-items:stretch;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--card);width:fit-content}.fy-picker:focus-within{border-color:var(--mango);box-shadow:0 0 0 3px #f5a6232e}.fy-picker select,.fy-picker input{border:none;border-radius:0;background:transparent;padding:.5rem .7rem;color:var(--ink);font-weight:600;-webkit-appearance:none;-moz-appearance:none;appearance:none}.fy-picker select:focus,.fy-picker input:focus{outline:none}.fy-picker .fy-day{width:3.5rem;text-align:center;border-right:1px solid var(--border);-moz-appearance:textfield}.fy-picker .fy-day::-webkit-outer-spin-button,.fy-picker .fy-day::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.fy-picker .fy-month{padding-right:1.8rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7280' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.page-header{position:relative;display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.9rem 1.25rem;border-radius:14px;background:var(--card);border:1.5px solid var(--card-border);color:var(--ink);box-shadow:0 2px 8px #d98a120f;cursor:pointer}.page-header-titles{display:flex;flex-direction:column;gap:.1rem;min-width:0;pointer-events:none}.page-header-project{font-size:1.4rem;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.page-header-page{font-size:.85rem;color:var(--muted)}.page-header-switch{margin-left:auto;display:flex;align-items:center;pointer-events:none}.page-header-switch select{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;pointer-events:auto}.page-header-chev{font-size:1.1rem;color:var(--mango-dark);padding:.35rem .5rem;border-radius:8px;transition:background .15s ease}.page-header:hover .page-header-chev{background:#d98a121f}.page-header-icon-btn{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;padding:.3rem;border:none;background:none;border-radius:8px;color:#9ca3af;cursor:pointer;pointer-events:auto;transition:background .15s ease,color .15s ease}.page-header-icon-btn:hover{color:var(--mango-dark);background:#d98a121f}.share-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;background:#11182773}.share-dialog{width:100%;max-width:640px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;background:var(--card);border-radius:16px;box-shadow:0 20px 50px #00000040}.share-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.share-head h2{margin:0;font-size:1.15rem}.share-close{border:none;background:none;font-size:1.6rem;line-height:1;color:var(--muted);cursor:pointer}.share-close:hover{color:var(--ink)}.share-body{display:grid;grid-template-columns:40% 60%;min-height:0;overflow:auto}.share-projects{list-style:none;margin:0;padding:.5rem;border-right:1px solid var(--border)}.share-project-btn{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.5rem .6rem;border:none;background:none;border-radius:10px;cursor:pointer;text-align:left}.share-project-btn:hover{background:#f5a62314}.share-project.is-active .share-project-btn{background:#f5a62329}.share-project-name{font-weight:600;color:var(--ink)}.share-badge{font-size:.7rem;font-weight:600;padding:.1rem .45rem;border-radius:999px;background:#2e7d321f;color:var(--pos)}.share-badge-private{background:#6b72801f;color:var(--muted)}.share-badge-pending{background:#d98a1224;color:var(--mango-dark);margin-left:.4rem}.share-detail{padding:.9rem 1.1rem;min-width:0}.share-detail h3{margin:0 0 .75rem;font-size:1rem}.share-members{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.4rem}.share-member{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem .5rem;border:1px solid var(--border);border-radius:10px}.share-member-info{display:flex;align-items:center;min-width:0}.share-member-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-member-controls{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.share-role-label{font-size:.8rem;color:var(--muted);flex-shrink:0}.share-invite{display:flex;gap:.4rem;align-items:center}.share-invite input[type=email]{flex:1;min-width:0}.share-note{font-size:.85rem}.share-msg{color:var(--pos);font-size:.85rem;margin:.5rem 0 0}@media (max-width: 560px){.share-body{grid-template-columns:1fr}.share-projects{border-right:none;border-bottom:1px solid var(--border)}}.admin-dialog{max-width:560px}.admin-dialog-body{min-height:0;overflow:auto;padding:.5rem 1.25rem 1.25rem}.admin-section{padding:1rem 0;border-bottom:1px solid var(--border)}.admin-section:last-child{border-bottom:none}.admin-section>h3{margin:0 0 .25rem;font-size:1.05rem}.admin-subsection{margin-top:.75rem;padding-top:.85rem;border-top:1px solid var(--border)}.admin-subsection>h4{margin:0 0 .25rem;font-size:.9rem;font-weight:600}.login-methods{margin-top:.6rem}.login-method-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.login-method{display:flex;align-items:center;gap:.75rem;padding:.6rem .7rem;border:1px solid var(--border);border-radius:10px}.login-method-name{font-weight:600}.login-method-actions{margin-left:auto;display:inline-flex;align-items:center;gap:.6rem}.login-method-connect{margin-left:auto;display:inline-flex}.login-method-note{font-size:.8rem;color:var(--muted)}.login-method .btn-primary{margin-left:auto}.login-method .danger:disabled{opacity:.45;cursor:not-allowed}.login-method-hint{margin:.5rem 0 0;font-size:.8rem}.admin-share-list{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.4rem}.admin-share-row{display:flex;align-items:center;gap:.75rem;padding:.55rem .6rem;border:1px solid var(--border);border-radius:10px}.admin-share-name{font-weight:600}.admin-share-btn{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;padding:.35rem;border:none;background:none;border-radius:8px;color:#9ca3af;cursor:pointer;transition:background .15s ease,color .15s ease}.admin-share-btn:hover{color:var(--mango-dark);background:#d98a121f}.dashboard-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.fy-dates{font-size:.82rem;color:var(--muted);font-variant-numeric:tabular-nums}.year-picker{display:inline-flex;align-items:center;gap:.25rem;border:1px solid var(--border);border-radius:999px;padding:.15rem .3rem;background:var(--card)}.year-picker span{min-width:3.5rem;text-align:center;font-weight:600;font-variant-numeric:tabular-nums}.year-picker button{border:none;background:none;padding:.2rem .55rem;border-radius:999px;font-size:1.1rem;line-height:1;color:var(--muted)}.year-picker button:hover{background:var(--bg);color:var(--ink)}.year-picker-title{padding:.2rem .4rem}.year-picker-title span{min-width:auto;padding:0 .5rem;font-size:1.4rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}.year-picker-title button{font-size:1.35rem;padding:.1rem .5rem}.pnl-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1.25rem 0}.pnl-card{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.1rem;border-radius:12px;border:1px solid var(--border);background:var(--card)}.pnl-card.income{border-color:#16a34a40;background:linear-gradient(180deg,rgba(22,163,74,.06),transparent)}.pnl-card.expense{border-color:#c6282838;background:linear-gradient(180deg,rgba(198,40,40,.06),transparent)}.pnl-card.net{background:var(--net-bg);border-width:2px}.pnl-card.net.positive{border-color:var(--pos)}.pnl-card.net.negative{border-color:var(--neg)}.pnl-card.net.zero{border-color:var(--zero)}.pnl-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.pnl-value{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums}.pnl-card.net.negative .pnl-value{color:var(--neg)}.pnl-ticker{display:inline-flex;align-items:center;gap:.25rem;font-size:.8rem;font-weight:600;font-variant-numeric:tabular-nums}.pnl-ticker.good{color:var(--pos)}.pnl-ticker.bad{color:var(--neg)}.pnl-ticker.neutral{color:var(--muted)}.breakdown-title{margin:1.5rem 0 .5rem}.breakdown{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.breakdown-row{display:grid;grid-template-columns:minmax(8rem,1fr) minmax(6rem,2fr) auto;align-items:center;gap:1rem;padding:.6rem .5rem;border-bottom:1px solid var(--border);border-radius:6px;transition:background .12s ease}.breakdown-row:last-child{border-bottom:none}.breakdown-row.highlight{background:#f5a6231f;box-shadow:inset 3px 0 0 var(--mango)}.month-matrix tbody tr{transition:background .12s ease}.month-matrix tbody tr.highlight{background:#f5a6231f}.month-matrix tbody tr.highlight .matrix-cat{box-shadow:inset 3px 0 0 var(--mango)}.breakdown-row:focus-visible,.month-matrix tbody tr:focus-visible{outline:none}.breakdown-name{display:flex;align-items:center;gap:.5rem;font-weight:500}.breakdown-bars{display:flex;flex-direction:column;gap:3px}.breakdown-bars .bar{height:8px;border-radius:999px;min-width:2px}.breakdown-bars .bar.income{background:#16a34a}.breakdown-bars .bar.expense{background:var(--neg)}.breakdown-net{font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.breakdown-net.positive{color:#16a34a}.breakdown-net.negative{color:var(--neg)}.matrix-wrap{overflow-x:auto;margin-top:.25rem}.month-matrix{border-collapse:collapse;width:100%;font-size:.85rem;font-variant-numeric:tabular-nums}.month-matrix th,.month-matrix td{padding:.35rem .6rem;border-bottom:1px solid var(--border);white-space:nowrap}.month-matrix thead th{text-align:right;color:var(--muted);font-weight:600;border-bottom:2px solid var(--border)}.month-matrix th.num,.month-matrix td.num{text-align:right}.month-matrix .matrix-corner,.month-matrix .matrix-cat{text-align:left;position:sticky;left:0;background:var(--card)}.month-matrix .matrix-cat{display:flex;align-items:center;gap:.45rem;font-weight:500}.month-matrix td.positive{color:#16a34a}.month-matrix td.negative{color:var(--neg)}.month-matrix td.matrix-zero{color:var(--muted)}.month-matrix .matrix-total{font-weight:700;border-left:1px solid var(--border)}.month-matrix tfoot td{border-bottom:none;border-top:2px solid var(--border);font-weight:700}
