@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root,[data-theme=light]{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;--navy: #0D1B2A;--navy-2: #1B2A3B;--teal: #00C896;--orange: #FF6B35;--orange-hover: #ff8255;--red: #E53E3E;--gold: #F6C90E;--bg: #F5F6FA;--card: #FFFFFF;--card-border: #E5E7EB;--text: #0D1B2A;--text-secondary: #8492A6;--text-muted: #A0AEC0;--positive: var(--teal);--negative: var(--red);--cta: var(--orange);--cta-hover: var(--orange-hover);--accent: var(--teal);--radius: 12px;--radius-lg: 16px;--btn-h: 40px;--card-pad: 16px;--font-base: .875rem;color:var(--text);background-color:var(--bg)}[data-accent=purple]{--accent: #8B5CF6;--teal: #8B5CF6}[data-accent=blue]{--accent: #3B82F6;--teal: #3B82F6}[data-font-scale=xs]{--font-base: .75rem}[data-font-scale=sm]{--font-base: .8rem}[data-font-scale=lg]{--font-base: .96rem}[data-font-scale=xl]{--font-base: 1.1rem}[data-theme=dark]{--bg: #0D1B2A;--card: #1B2A3B;--card-border: #2D3E50;--text: #E2E8F0;--text-secondary: #8492A6;--text-muted: #5A6A7E;--navy: #0D1B2A;--navy-2: #162535}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);font-size:var(--font-base)}#root{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:0}h1,h2,h3,h4,h5{color:var(--text)}.app-shell{display:flex;min-height:100vh;width:100%;background:var(--bg);position:relative}.sidebar{display:none}.hamburger-btn{position:fixed;top:.65rem;left:.65rem;z-index:50;width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--card-border);background:var(--card);color:var(--text);font-size:1.15rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;box-shadow:0 2px 6px #00000014}.sidebar-overlay,.sidebar-bottom,.sidebar-logout,.brand-dot{display:none}.shell-main{flex:1;min-width:0;padding-bottom:64px}.bottom-tabs{position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--card);border-top:1px solid var(--card-border);display:flex;align-items:center;justify-content:space-around;z-index:40}.tab-item{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--text-muted);font-size:.6rem;font-weight:600;padding:.3rem .5rem;position:relative;transition:color .12s}.tab-item.active{color:var(--accent)}.tab-item.active:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:999px;background:var(--accent)}.tab-icon{font-size:1.15rem}.tab-label{font-size:.6rem}.dashboard-page{width:100%;max-width:600px;margin:0 auto;min-height:100vh;background:var(--bg)}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.25rem;background:var(--navy)}.top-bar-greeting{color:#fff9;font-size:.82rem;font-weight:500}.top-bar-actions{display:flex;gap:.75rem}.link-button{background:none;border:none;color:#ffffff80;font-size:.78rem;font-weight:500;cursor:pointer;padding:0;transition:color .15s}.link-button:hover{color:#fff}.hero{background:var(--navy);padding:1.25rem 1.25rem 2rem;text-align:center;border-radius:0 0 24px 24px}.hero-loading,.hero-error{color:#ffffff80;font-size:.85rem;margin:0}.hero-error{color:#fca5a5}.hero-label{margin:0;color:#ffffff73;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700}.hero-balance{margin:.2rem 0 0;font-size:3rem;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.1}.hero-balance.healthy{text-shadow:0 0 30px rgba(0,200,150,.3)}.hero-balance.warning{text-shadow:0 0 30px rgba(229,62,62,.35)}.hero-sub{margin:.4rem 0 0;color:#fff6;font-size:.78rem}.hero-next-pill{display:inline-block;margin-top:.85rem;padding:.35rem .8rem;background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:999px;color:#fff9;font-size:.75rem}.hero-next-pill strong{color:var(--teal)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;padding:0 1.25rem;margin-top:-.85rem;position:relative;z-index:1}.stat-card{background:var(--card);border-radius:var(--radius);padding:var(--card-pad);display:flex;flex-direction:column;gap:2px;box-shadow:0 2px 8px #0000000d;border:1px solid var(--card-border);height:72px;justify-content:center}.stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);font-weight:700}.stat-value{font-size:1.1rem;font-weight:700;color:var(--text)}.stat-value.bills{color:var(--red)}.stat-value.teal{color:var(--teal)}.quick-add{padding:.75rem 1.25rem}.quick-add-form{display:flex;gap:.35rem;align-items:stretch}.quick-input{padding:0 .65rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-family:inherit;font-size:var(--font-base);background:var(--card);color:var(--text);transition:border-color .15s}.quick-input:focus{outline:none;border-color:var(--accent)}.quick-desc{flex:2;min-width:0}.quick-amount{flex:1;min-width:0;max-width:85px}.quick-cat{flex:1;min-width:0;max-width:125px;font-size:.78rem}.quick-date{flex:0 0 auto;min-width:0;max-width:140px;font-size:.78rem}.quick-future-note{margin:.4rem 0 0;font-size:.72rem;color:var(--accent)}.quick-add-btn{height:var(--btn-h);padding:0 .85rem;border:none;border-radius:var(--radius);background:var(--cta);color:#fff;font-weight:700;font-size:var(--font-base);cursor:pointer;white-space:nowrap;transition:background .15s}.quick-add-btn:hover{background:var(--cta-hover)}.quick-add-btn:disabled{opacity:.5;cursor:default}.quick-error{margin:.3rem 0 0;font-size:.75rem;color:var(--red)}.planner-section{padding:0 1.25rem .75rem}.planner-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.planner-header-row .link-button{color:var(--accent);font-size:.75rem}.planner-header-row .link-button:hover{opacity:.8}.section-title{margin:0;font-size:.9rem;font-weight:700;color:var(--text)}.activity-list{list-style:none;margin:0;padding:0}.activity-list li{border-bottom:1px solid var(--card-border)}.activity-list li:last-child{border-bottom:none}.activity-row{display:flex;align-items:center;gap:.65rem;width:100%;padding:.6rem .15rem;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .1s}.activity-row:hover{background:var(--card);border-radius:var(--radius)}.activity-date{flex-shrink:0;width:50px;font-weight:700;font-size:.78rem;color:var(--text);display:flex;align-items:center;gap:.25rem}.payday-dot{width:6px;height:6px;border-radius:999px;background:var(--gold);flex-shrink:0}.activity-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.activity-item{font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-item.bill-item{color:var(--red);font-weight:600}.activity-item.expense-item{color:var(--text)}.activity-item.empty-item{color:var(--text-muted);font-style:italic}.activity-item.payday-label{color:var(--gold);font-weight:700}.activity-total{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:1px}.amt-income{font-size:.78rem;font-weight:700;color:#8b5cf6}.amt-bill{font-size:.78rem;font-weight:700;color:var(--red)}.amt-exp{font-size:.78rem;font-weight:600;color:var(--text)}.activity-item.income-item{color:#8b5cf6;font-weight:600}.planner-hint{margin:.4rem 0 0;font-size:.68rem;color:var(--text-muted)}.up-row{display:flex;align-items:center;gap:.6rem;padding:.55rem .35rem;border-bottom:1px solid var(--card-border);cursor:pointer;transition:background .1s;list-style:none}.up-row:last-child{border-bottom:none}.up-row:hover{background:var(--bg);border-radius:var(--radius)}.up-accent{width:3px;height:32px;border-radius:2px;flex-shrink:0}.up-accent-red{background:var(--red)}.up-accent-purple{background:#8b5cf6}.up-accent-gold{background:var(--gold)}.up-accent-gray{background:var(--text-muted)}.up-body{flex:1;min-width:0}.up-name{display:block;font-size:var(--font-base);font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.up-date{display:block;font-size:.7rem;color:var(--text-muted);margin-top:1px}.up-amt{flex-shrink:0;font-weight:700;font-size:var(--font-base);color:var(--text)}.up-amt-red{color:var(--red)}.up-amt-purple{color:#8b5cf6}.up-amt-gold{color:var(--gold)}.up-income{background:#8b5cf60a}.up-payday{background:#f6c90e0f}.bi-sub-label{margin:0 0 .25rem;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.empty-hint{padding:1rem 0;font-size:.82rem;color:var(--text-muted);text-align:center}.panels-section{padding:0 1.25rem 2rem;display:flex;flex-direction:column;gap:.65rem}.dash-columns{display:flex;flex-direction:column;gap:1rem;padding:0 1.25rem 1.5rem}.dash-chart-col{min-width:0}.status{margin:0 0 .75rem;padding:.65rem .85rem;border-radius:var(--radius);background:var(--card);color:var(--text-secondary);text-align:center;font-size:.82rem;border:1px solid var(--card-border)}.status-error{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.empty-state{padding:1.75rem 1.25rem;border-radius:var(--radius-lg);background:var(--card);border:1px dashed var(--card-border);text-align:center}.empty-state h3{margin:0 0 .4rem}.empty-state p{color:var(--text-secondary);margin:0}.primary-button{height:var(--btn-h);padding:0 1.15rem;border-radius:var(--radius);border:none;background:var(--cta);color:#fff;font-size:var(--font-base);font-weight:700;cursor:pointer;transition:background .15s,transform .1s;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.primary-button:hover{background:var(--cta-hover);transform:translateY(-1px)}.secondary-button{height:var(--btn-h);padding:0 1rem;border-radius:var(--radius);border:1px solid var(--card-border);background:var(--card);color:var(--text);font-weight:600;font-size:var(--font-base);cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;justify-content:center}.secondary-button:hover{background:var(--navy);color:#fff}.ghost-button{height:var(--btn-h);background:transparent;border:1px solid var(--card-border);border-radius:var(--radius);padding:0 .75rem;cursor:pointer;font-weight:600;font-size:.82rem;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center}.delete-button{height:var(--btn-h);padding:0 .7rem;border-radius:8px;border:none;background:var(--red);color:#fff;font-size:.82rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.onboarding-actions{display:flex;gap:.65rem;justify-content:center;margin-top:.85rem}.recurring-panel{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--card-border);padding:var(--card-pad)}.recurring-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-bottom:.55rem;border-bottom:1px solid var(--card-border);margin-bottom:.4rem}.recurring-header h2{margin:0;font-size:.9rem;font-weight:700}.recurring-header .ghost-button{display:none}.recurring-section{display:flex;flex-direction:column;gap:.55rem;padding:.65rem 0;border-bottom:1px solid var(--card-border)}.recurring-section:last-of-type{border-bottom:none}.recurring-section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.recurring-card{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.6rem .7rem;border:1px solid var(--card-border);border-radius:var(--radius);background:var(--bg)}.recurring-list{display:flex;flex-direction:column;gap:.3rem}.recurring-actions{display:flex;align-items:center;gap:.4rem}.entry-title{font-weight:600;font-size:var(--font-base);margin-right:.4rem}.entry-amount{font-weight:700;font-size:var(--font-base)}.entry-amount.positive{color:var(--teal)}.entry-amount.negative{color:var(--red)}.empty-row{color:var(--text-muted);margin:0;font-size:.82rem}.muted{color:var(--text-secondary);margin:.15rem 0 0;font-size:.78rem}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:.65rem;color:var(--text-muted);font-weight:700}.pill{background:#eef2ff;color:#4338ca;padding:.1rem .4rem;border-radius:999px;font-size:.65rem;font-weight:700;margin-left:.3rem}.pill.primary-pill{background:#dbeafe;color:#1e40af;font-size:.6rem;text-transform:uppercase;letter-spacing:.02em}.pill.ends-pill{background:#fef3c7;color:#92400e;font-size:.6rem}.pill.payday{background:var(--gold);color:var(--navy);border-radius:999px;padding:.1rem .45rem;font-size:.65rem;font-weight:700}.progress-bar{width:100%;height:6px;background:var(--card-border);border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:999px}.investment-form{display:grid;grid-template-columns:1fr 1fr auto;gap:.4rem;margin:.65rem 0}.investment-contrib{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:.3rem;width:100%}.investment-contrib input{width:100%}.modal-overlay{position:fixed;inset:0;background:#0d1b2a80;display:flex;align-items:center;justify-content:center;z-index:30}.modal-card{width:min(420px,92%);background:var(--card);padding:1.15rem;border-radius:var(--radius-lg);box-shadow:0 20px 50px #0000004d}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-form{display:flex;flex-direction:column;gap:.65rem;margin-top:.65rem}.modal-form label{display:flex;flex-direction:column;gap:.2rem;font-weight:600;font-size:.82rem;color:var(--text)}.modal-form input,.modal-form select{padding:0 .7rem;height:var(--btn-h);border-radius:var(--radius);border:1px solid var(--card-border);font-size:var(--font-base);font-family:inherit;background:var(--bg);color:var(--text)}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:.4rem;margin-top:.2rem}.inline-error{color:var(--red);font-weight:600;font-size:.82rem}.day-modal-backdrop{position:fixed;inset:0;background:#0d1b2a80;display:flex;align-items:center;justify-content:center;z-index:20}.day-modal{background:var(--card);border-radius:var(--radius-lg);width:min(440px,92%);padding:1.15rem;box-shadow:0 20px 50px #0000004d;display:flex;flex-direction:column;gap:.65rem}.day-modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.day-modal-header button{border:none;background:transparent;font-size:1.4rem;cursor:pointer;color:var(--text)}.error-banner{background:#fee2e2;color:#991b1b;padding:.4rem .65rem;border-radius:var(--radius);font-size:.82rem}.day-modal-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.4rem}.day-modal-form input,.day-modal-form select,.day-modal-form button{padding:0 .65rem;height:var(--btn-h);border-radius:var(--radius);border:1px solid var(--card-border);font-family:inherit;font-size:var(--font-base)}.day-modal-form button{border:none;background:var(--cta);color:#fff;cursor:pointer;font-weight:700}.day-modal-list{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:.35rem}.day-expense-row{display:flex;align-items:center;justify-content:space-between;padding:.45rem .6rem;border-radius:var(--radius);background:var(--bg);font-size:var(--font-base)}.day-expense-row button{border:none;background:var(--red);color:#fff;padding:.2rem .55rem;border-radius:8px;cursor:pointer;font-size:.75rem}.calendar-page{padding:1rem 1rem 2rem;max-width:960px;margin:0 auto}.cal-header{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-bottom:.65rem}.cal-month-label{margin:0;font-size:1.15rem;font-weight:800;color:var(--text);min-width:180px;text-align:center}.cal-nav-btn{width:var(--btn-h);height:var(--btn-h);display:flex;align-items:center;justify-content:center;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);font-size:1rem;cursor:pointer;color:var(--text);transition:background .12s}.cal-nav-btn:hover{background:var(--bg)}.cal-toolbar{display:flex;align-items:center;gap:.65rem;margin-bottom:.65rem;padding:0 .15rem}.cal-toggle{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text-secondary);cursor:pointer}.cal-toggle input{accent-color:var(--accent)}.premium-badge{background:linear-gradient(135deg,var(--gold),#F59E0B);color:var(--navy);font-size:.58rem;font-weight:800;padding:.12rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}.premium-lock{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.premium-lock .primary-button{margin-top:.75rem}.premium-lock-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .65rem;background:linear-gradient(135deg,#d97706,#f59e0b);color:#fff;font-size:.72rem;font-weight:700;border-radius:999px;text-decoration:none;white-space:nowrap;flex-shrink:0}.premium-locked-row{opacity:.85}.premium-locked-section{opacity:.85;border:1px dashed var(--card-border);border-radius:var(--radius-lg);padding:.75rem 1rem}.cal-grid-wrapper{border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--card)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--navy)}.cal-weekday{text-align:center;font-size:.65rem;font-weight:700;color:#fff9;padding:.45rem 0;text-transform:uppercase;letter-spacing:.06em}.cal-week{display:grid;grid-template-columns:repeat(7,1fr)}.cal-week:not(:last-child){border-bottom:1px solid var(--card-border)}.cal-cell{min-height:90px;padding:.4rem .45rem;border-right:1px solid var(--card-border);background:var(--card);display:flex;flex-direction:column;gap:2px;cursor:pointer;text-align:left;border-top:none;border-bottom:none;border-left:none;font-family:inherit;transition:background .1s;color:var(--text)}.cal-cell:last-child{border-right:none}.cal-cell:hover{background:var(--bg)}.cal-cell.empty{cursor:default;background:var(--bg);opacity:.5}.cal-cell.today .cal-day-num{background:var(--teal);color:#fff;width:24px;height:24px;border-radius:999px;display:flex;align-items:center;justify-content:center}.cal-cell.payday-cell{background:#22c55e14}.cal-day-num{font-size:.75rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:3px}.cal-payday-dot{width:6px;height:6px;border-radius:999px;background:#22c55e}.cal-bill-dot{display:inline-block;width:5px;height:5px;border-radius:999px;background:var(--red);margin-right:2px}.cal-exp-dot{display:inline-block;width:5px;height:5px;border-radius:999px;background:#f97316;margin-right:2px}.cal-bill-tag{font-size:.58rem;color:var(--red);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-exp-tag{font-size:.58rem;color:#f97316;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-paid-tag{font-size:.58rem;color:#3b82f6;font-weight:600}.cal-paid-badge{font-size:.78rem;color:#3b82f6;font-weight:600;margin-left:.35rem}.cal-month-chart{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--card-pad);margin:.85rem 0}.cal-month-chart .chart-label{margin-bottom:.5rem}.cal-month-summary{display:flex;gap:1rem;flex-wrap:wrap;font-size:.82rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--card-border)}.cal-income-tag{font-size:.58rem;color:#8b5cf6;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-income-dot{display:inline-block;width:5px;height:5px;border-radius:999px;background:#8b5cf6;margin-right:2px}.manage-income-page{padding:1.25rem;max-width:700px;margin:0 auto}.manage-income-page h1{text-align:left;font-size:1.25rem;margin:0}.cal-detail{width:min(500px,94%);max-height:88vh;overflow-y:auto}.cal-detail-section{margin-top:.65rem}.cal-detail-section h5{margin:0 0 .3rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-weight:700}.cal-detail-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--card-border);font-size:var(--font-base)}.cal-detail-row:last-child{border-bottom:none}.cal-detail-row.bill-row{flex-direction:column;align-items:stretch;gap:.15rem}.cal-detail-row.bill-row>div{display:flex;align-items:center;gap:.4rem}.cal-detail-amt{font-weight:700}.cal-detail-amt.bill-amt{color:var(--red)}.cal-edit-btn{font-size:.72rem;color:var(--accent)!important;padding:0}.paycheck-snapshot{background:var(--bg);border-radius:var(--radius);padding:var(--card-pad);margin-bottom:.65rem;border-left:3px solid var(--gold)}.paycheck-snapshot h5{margin:0 0 .5rem;font-size:.78rem;color:var(--gold);text-transform:uppercase;letter-spacing:.05em}.snapshot-row{display:flex;justify-content:space-between;padding:.2rem 0;font-size:.82rem}.snapshot-row.total{font-weight:700;border-top:1px solid var(--card-border);padding-top:.4rem;margin-top:.25rem}.snapshot-row .positive{color:var(--teal)}.snapshot-row .negative{color:var(--red)}.cal-override-form{margin-top:.4rem;padding:.65rem;background:var(--bg);border-radius:var(--radius);display:flex;flex-direction:column;gap:.4rem}.cal-override-form label{display:flex;flex-direction:column;gap:.15rem;font-weight:600;font-size:.78rem;color:var(--text)}.cal-override-form input{padding:0 .6rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:var(--font-base);font-family:inherit;background:var(--card);color:var(--text)}.cal-override-label{margin:0;font-size:.78rem;color:var(--text-secondary)}.cal-add-exp{margin-top:.65rem;padding-top:.65rem;border-top:1px solid var(--card-border)}.cal-add-exp h5{margin:0 0 .3rem;font-size:.78rem;color:var(--text)}.cal-add-row{display:flex;gap:.3rem}.cal-add-row input,.cal-add-row select{flex:1;min-width:0;padding:0 .55rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:.78rem;font-family:inherit;background:var(--card);color:var(--text)}.cal-add-row .primary-button{padding:0 .65rem;font-size:.78rem}.settings-page{padding:1.25rem;max-width:600px;margin:0 auto}.settings-section{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--card-pad);margin-bottom:.85rem}.settings-section .section-title{font-size:.82rem;margin-bottom:.65rem;padding-bottom:.4rem;border-bottom:1px solid var(--card-border)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:.45rem 0;font-size:var(--font-base)}.settings-row label{color:var(--text);font-weight:500}.settings-radios{display:flex;gap:.5rem}.settings-radios label{display:flex;align-items:center;gap:.25rem;font-size:.78rem;font-weight:500;cursor:pointer;color:var(--text-secondary)}.settings-radios input{accent-color:var(--accent)}.accent-dot{width:20px;height:20px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:border-color .12s}.accent-dot:hover,.accent-dot.active{border-color:var(--text)}.accent-teal{background:#00c896}.accent-purple{background:#8b5cf6}.accent-blue{background:#3b82f6}.avatar-initials{width:48px;height:48px;border-radius:999px;background:var(--navy);color:#fff;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center}.coming-soon{font-size:.6rem;background:var(--card-border);color:var(--text-secondary);padding:.1rem .4rem;border-radius:999px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-left:.4rem}.danger-zone{border-color:var(--red)}.danger-zone .section-title{color:var(--red);border-bottom-color:#e53e3e33}.ad-slot{display:flex;justify-content:center;padding:.5rem 0}.ad-placeholder{background:var(--bg);border:1px dashed var(--card-border);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;color:var(--text-muted);font-size:.68rem}.ad-banner .ad-placeholder{width:100%;max-width:728px;height:90px}.ad-sidebar .ad-placeholder{width:100%;max-width:300px;height:250px}.ad-inline .ad-placeholder{width:100%;max-width:468px;height:60px}.ad-label{font-weight:700;text-transform:uppercase;letter-spacing:.05em}.ad-dims{font-size:.6rem}.auth-split{display:flex;min-height:100vh}.auth-brand-panel{display:none}.auth-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem;background:var(--card)}.auth-form-inner{width:100%;max-width:380px}.auth-form-inner h1{text-align:left;font-size:1.5rem;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:.75rem;text-align:left}.auth-form label{font-size:.82rem;font-weight:600;color:var(--text);display:flex;flex-direction:column;gap:.2rem}.auth-form input{width:100%;padding:0 .75rem;height:var(--btn-h);border-radius:var(--radius);border:1px solid var(--card-border);font-size:var(--font-base);font-family:inherit;background:var(--bg);color:var(--text)}.auth-form input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #00c8961a}.auth-name-row{display:flex;gap:.5rem}.auth-name-row label{flex:1}.auth-error{color:var(--red);font-size:.82rem;font-weight:600;margin:0}.auth-info{color:var(--teal);font-size:.82rem;margin:0 0 .5rem}.auth-switch{margin-top:1rem;font-size:.82rem;color:var(--text-secondary)}.auth-switch a{color:var(--cta);font-weight:600}.auth-field-error{color:var(--red);font-size:.72rem;font-weight:600;margin-top:.15rem;display:block}.auth-phone-row{display:flex;gap:.35rem}.auth-country-select{width:120px;flex-shrink:0;padding:0 .5rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:.78rem;font-family:inherit;background:var(--bg);color:var(--text)}.auth-phone-input{flex:1}.auth-checkbox-row{display:flex;align-items:flex-start;gap:.5rem;font-size:.78rem;color:var(--text-secondary);cursor:pointer}.auth-checkbox-row input[type=checkbox]{width:16px;height:16px;margin-top:.15rem;accent-color:var(--teal);flex-shrink:0;cursor:pointer;-webkit-appearance:checkbox;appearance:checkbox}.auth-checkbox-row a{color:var(--cta);font-weight:600}.auth-brand-logo{font-size:1.75rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.auth-brand-tagline{font-size:1.15rem;color:#ffffffb3;line-height:1.6;margin:0 0 1.5rem}.auth-brand-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.65rem}.auth-brand-list li{color:#fff9;font-size:.9rem;padding-left:1.25rem;position:relative}.auth-brand-list li:before{content:"";position:absolute;left:0;top:.5em;width:6px;height:6px;border-radius:999px;background:var(--teal)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--bg)}.auth-card{width:min(400px,100%);background:var(--card);padding:2rem;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000000f;text-align:center}.auth-subtitle{margin-top:0;margin-bottom:1.5rem;color:var(--text-secondary)}.auth-footer{margin-top:1.25rem;color:var(--text-secondary)}.auth-footer a{color:var(--cta);font-weight:600}.lp{background:var(--card)}.lp-nav{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.5rem;background:var(--navy)}.lp-brand{font-size:1.15rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:.4rem}.lp-dot{width:8px;height:8px;border-radius:999px;background:var(--teal);display:inline-block;flex-shrink:0}.lp-nav-right{display:flex;align-items:center;gap:.75rem}.lp-nav-link{color:#fff9;text-decoration:none;font-size:.85rem;font-weight:500}.lp-nav-link:hover{color:#fff}.lp-hero{background:var(--navy);padding:4rem 1.5rem 5rem;text-align:center}.lp-hero-inner{max-width:700px;margin:0 auto}.lp-hero h1{font-size:1.75rem;color:#fff;line-height:1.4;margin:0 0 1rem;font-weight:800}.lp-highlight{color:var(--teal)}.lp-hero-sub{font-size:1rem;color:#ffffff8c;line-height:1.6;margin:0 0 2rem}.lp-hero-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.lp-cta{padding:.75rem 2rem;font-size:1rem;height:auto;text-decoration:none}.lp-cta-ghost{color:#fff;border-color:#ffffff4d;text-decoration:none;padding:.75rem 2rem;font-size:1rem;height:auto}.lp-section{padding:4rem 1.5rem;max-width:960px;margin:0 auto}.lp-section.lp-gray{background:var(--bg);max-width:100%}.lp-section.lp-gray>*{max-width:960px;margin-left:auto;margin-right:auto}.lp-section-title{text-align:center;font-size:1.35rem;font-weight:800;margin:0 0 2rem;color:var(--text)}.lp-steps{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.lp-step{flex:1;min-width:200px;max-width:280px;text-align:center}.lp-step-icon{font-size:2rem;display:block;margin-bottom:.5rem}.lp-step h3{margin:0 0 .35rem;font-size:1rem}.lp-step p{margin:0;color:var(--text-secondary);font-size:.88rem;line-height:1.5}.lp-features{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.lp-feature{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1.5rem}.lp-feature h3{margin:0 0 .5rem;font-size:1rem}.lp-feature p{margin:0;color:var(--text-secondary);font-size:.88rem;line-height:1.5}.lp-badge{display:inline-block;margin-left:.5rem;padding:.1rem .5rem;background:var(--gold);color:var(--navy);font-size:.6rem;font-weight:700;border-radius:999px;text-transform:uppercase;vertical-align:middle}.lp-pricing{display:flex;gap:1.25rem;justify-content:center;flex-wrap:wrap}.lp-price-card{flex:1;min-width:260px;max-width:340px;border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center}.lp-price-card h3{margin:0 0 .35rem;font-size:1.15rem}.lp-price{font-size:2rem;font-weight:800;margin:0 0 1rem}.lp-price span{font-size:.82rem;font-weight:400;color:var(--text-secondary)}.lp-price-card ul{list-style:none;padding:0;margin:0 0 1.5rem;text-align:left}.lp-price-card li{padding:.35rem 0;font-size:.88rem;color:var(--text-secondary);border-bottom:1px solid var(--card-border)}.lp-price-card li:last-child{border-bottom:none}.lp-premium{border-color:var(--cta);position:relative}.lp-save-badge{position:absolute;top:-10px;right:16px;background:var(--cta);color:#fff;font-size:.65rem;font-weight:700;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase}.lp-trial-note{margin:.5rem 0 0;font-size:.75rem;color:var(--text-muted)}.lp-footer{background:var(--navy);padding:2rem 1.5rem;text-align:center}.lp-footer-inner{max-width:700px;margin:0 auto}.lp-footer-brand{font-size:1.1rem;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:.75rem}.lp-footer-links{display:flex;gap:1.25rem;justify-content:center;margin-bottom:.75rem}.lp-footer-links a{color:#ffffff73;text-decoration:none;font-size:.82rem}.lp-footer-links a:hover{color:#fff}.lp-footer-copy{margin:0;font-size:.75rem;color:#ffffff4d}.budget-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.85rem;margin-bottom:1.25rem}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label{font-weight:600;font-size:.82rem}.budget-form input,.budget-form select{padding:0 .75rem;height:var(--btn-h);border-radius:var(--radius);border:1px solid var(--card-border);font-size:var(--font-base);font-family:inherit;background:var(--card);color:var(--text)}.budget-form input:focus,.budget-form select:focus{outline:none;border-color:var(--accent)}.note-group{grid-column:span 2}.table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--card-border)}table{width:100%;border-collapse:collapse;min-width:500px}thead{background:var(--bg)}th,td{padding:.65rem .85rem;text-align:left;border-bottom:1px solid var(--card-border)}tbody tr:nth-child(2n){background:var(--card)}tbody tr:nth-child(odd){background:var(--bg)}.income-source-list{display:flex;flex-direction:column;gap:.45rem;margin-bottom:.85rem}.income-source-card{display:flex;align-items:center;justify-content:space-between;gap:.65rem;padding:.6rem .8rem;background:var(--bg);border:1px solid var(--card-border);border-radius:var(--radius)}.income-source-info{flex:1;min-width:0}.income-source-name{font-weight:600;display:flex;align-items:center;gap:.4rem}.income-source-actions{display:flex;gap:.3rem;flex-shrink:0}.income-breakdown{margin-top:.65rem;padding:.55rem .75rem;background:var(--bg);border-radius:var(--radius)}.income-breakdown h4{margin:0 0 .35rem;font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.income-breakdown-list{display:flex;flex-direction:column;gap:.25rem}.income-breakdown-item{display:flex;justify-content:space-between;align-items:center;font-size:.82rem}.form-row{display:flex;gap:.65rem;justify-content:flex-end;margin-top:.4rem}h1{margin-top:0;margin-bottom:.85rem;font-size:1.75rem;text-align:center}.app{background:var(--card);width:min(900px,100%);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:0 4px 20px #0000000f}.onboarding-page{max-width:500px;margin:0 auto;padding:2rem 1.25rem;min-height:100vh;display:flex;flex-direction:column}.ob-progress{margin-bottom:1.5rem}.ob-progress-bar{height:4px;background:var(--card-border);border-radius:999px;overflow:hidden}.ob-progress-fill{height:100%;background:var(--teal);border-radius:999px;transition:width .3s}.ob-step-label{font-size:.7rem;color:var(--text-muted);margin-top:.35rem;display:block}.ob-step{flex:1;display:flex;flex-direction:column}.ob-welcome{align-items:center;justify-content:center;text-align:center}.ob-welcome h1{font-size:1.75rem;margin-bottom:.5rem}.ob-subtitle{color:var(--text-secondary);font-size:.88rem;margin:0 0 1.5rem}.ob-cta{width:100%;max-width:300px;font-size:1rem;height:48px}.ob-form{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1rem}.ob-form label{display:flex;flex-direction:column;gap:.25rem;font-weight:600;font-size:.85rem;color:var(--text)}.ob-form input{padding:0 .75rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:1rem;font-family:inherit;background:var(--card);color:var(--text)}.ob-form input:focus{outline:none;border-color:var(--accent)}.ob-pills{display:flex;gap:.35rem;flex-wrap:wrap}.ob-pill{padding:.45rem .85rem;border-radius:999px;border:1px solid var(--card-border);background:var(--card);font-size:.82rem;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .12s}.ob-pill.active{background:var(--teal);color:#fff;border-color:var(--teal);font-weight:700}.ob-bill-form{display:flex;gap:.3rem;flex-wrap:wrap;align-items:stretch;margin-bottom:.65rem}.ob-bill-form input,.ob-bill-form select{flex:1;min-width:0;padding:0 .6rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:.82rem;font-family:inherit;background:var(--card);color:var(--text)}.ob-bill-list{list-style:none;padding:0;margin:0 0 .65rem;display:flex;flex-direction:column;gap:.25rem}.ob-bill-list li{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;background:var(--bg);border-radius:var(--radius);font-size:.85rem}.ob-bill-list li .ghost-button{height:28px;padding:0 .5rem;font-size:.75rem}.ob-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:auto;padding-top:1rem}.ob-skip{color:var(--text-muted)!important;font-size:.82rem}.ob-error{color:var(--red);font-size:.82rem;font-weight:600}.ob-done{align-items:center;text-align:center}.ob-snapshot{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--card-pad);width:100%;margin:1rem 0;text-align:left}.ob-snapshot-title{margin:0 0 .5rem;font-size:.82rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.ob-snapshot-row{display:flex;justify-content:space-between;padding:.3rem 0;font-size:.9rem}.ob-snapshot-row.negative span:last-child{color:var(--red)}.ob-snapshot-row.total{font-weight:700;font-size:1.1rem;border-top:1px solid var(--card-border);padding-top:.5rem;margin-top:.25rem}.ob-snapshot-row .teal{color:var(--teal)}.ob-msg{color:var(--text-secondary);font-size:.88rem;margin:0 0 1.5rem}.spending-section{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--card-pad)}.spending-section .section-title{margin-bottom:.65rem}.spending-layout{display:flex;flex-direction:column;gap:.5rem}.spending-legend{display:flex;flex-direction:column;gap:.25rem}.legend-row{display:flex;align-items:center;gap:.4rem;font-size:.78rem;padding:.2rem 0}.legend-dot-color{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend-name{flex:1;color:var(--text)}.legend-amount{font-weight:700;color:var(--text);min-width:60px;text-align:right}.legend-pct{color:var(--text-muted);min-width:32px;text-align:right}.spending-comparison{font-size:.78rem;margin:.5rem 0 0;font-weight:600}.spending-comparison.negative{color:var(--red)}.spending-comparison.positive{color:var(--teal)}.history-page{padding:1.25rem;max-width:700px;margin:0 auto}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.history-header h1{margin:0;font-size:1.25rem;text-align:left}.history-filters{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.65rem}.history-filters input,.history-filters select{padding:0 .6rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:.78rem;font-family:inherit;background:var(--card);color:var(--text);flex:1;min-width:0}.hf-bar{margin-bottom:.85rem}.hf-pills{display:flex;gap:.25rem;flex-wrap:wrap;margin-bottom:.5rem}.hf-pill{padding:.3rem .7rem;border-radius:999px;border:1px solid var(--card-border);background:var(--card);font-size:.75rem;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .12s}.hf-pill.active{background:var(--navy);color:#fff;border-color:var(--navy)}.hf-controls{display:flex;gap:.3rem;flex-wrap:wrap}.hf-input{padding:0 .5rem;height:34px;border:1px solid var(--card-border);border-radius:var(--radius);font-size:.75rem;font-family:inherit;background:var(--card);color:var(--text);min-width:0;flex:1}.hf-search{flex:2}.history-chart-single{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:.85rem;text-align:center}.history-summary{display:flex;justify-content:space-between;padding:.45rem .65rem;background:var(--card);border-radius:var(--radius);margin-bottom:.65rem;font-size:.82rem;color:var(--text-secondary);border:1px solid var(--card-border)}.history-list{list-style:none;padding:0;margin:0}.history-row{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--card-border);font-size:var(--font-base)}.history-row:last-child{border-bottom:none}.history-date{flex-shrink:0;width:75px;font-size:.75rem;color:var(--text-secondary)}.history-icon{flex-shrink:0;width:20px;text-align:center}.history-desc{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.period-pill{display:inline-block;margin-left:.5rem;padding:.1rem .45rem;border-radius:999px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;vertical-align:middle}.period-pill-current{background:#00c8961f;color:var(--teal)}.period-pill-upcoming{background:#f973161f;color:var(--accent)}.period-pill-past{background:#8492a626;color:var(--text-muted)}.history-amount{flex-shrink:0;font-weight:700}.history-row .ghost-button{height:28px;padding:0 .4rem;font-size:.7rem}.history-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 0;font-size:.82rem;color:var(--text-secondary)}.settings-page h1{text-align:left;font-size:1.25rem;margin-bottom:1rem}.s-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid var(--card-border)}.s-row:last-child{border-bottom:none}.s-label{font-size:var(--font-base);font-weight:500;color:var(--text)}.s-pills{display:flex;gap:.25rem}.s-pill{padding:.35rem .75rem;border-radius:999px;border:1px solid var(--card-border);background:var(--card);font-size:.78rem;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .12s}.s-pill.active{background:var(--navy);color:#fff;border-color:var(--navy)}.s-size-track{display:flex;gap:.35rem;align-items:baseline}.s-size-btn{width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--card-border);background:var(--card);cursor:pointer;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.s-size-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}.s-preview{font-style:italic;color:var(--text-muted);margin:.35rem 0 0}.s-avatar{width:52px;height:52px;border-radius:999px;background:var(--navy);color:#fff;font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin-bottom:.65rem}.s-field-list{display:flex;flex-direction:column;gap:0}.s-field{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--card-border);gap:.5rem}.s-field:last-child{border-bottom:none}.s-field-label{font-size:.82rem;font-weight:500;color:var(--text-secondary);flex-shrink:0;min-width:90px}.s-field input{flex:1;min-width:0;padding:0 .5rem;height:34px;border:1px solid transparent;border-radius:var(--radius);font-size:var(--font-base);font-family:inherit;background:transparent;color:var(--text);text-align:right}.s-field input:focus{border-color:var(--accent);background:var(--bg);outline:none}.s-field input[type=date]{-webkit-appearance:none;appearance:none;flex:1 1 auto;min-width:0;width:100%;box-sizing:border-box;padding:0 .5rem;height:34px;line-height:34px;text-align:right;font-family:inherit;font-size:var(--font-base);font-weight:400;color:var(--text);background:transparent;border:1px solid transparent;border-radius:var(--radius)}.s-field input[type=date]::-webkit-date-and-time-value{text-align:right;margin:0;padding:0}.s-field input[type=date]::-webkit-datetime-edit{text-align:right;padding:0}.s-field input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0}.s-field input[type=date]::-webkit-calendar-picker-indicator{margin:0 0 0 .4rem;padding:0;filter:invert(.55);cursor:pointer;opacity:.8}.s-field input[type=date]::-webkit-inner-spin-button{display:none}.s-field input[type=date]:focus{border-color:var(--accent);background:var(--bg);outline:none}.s-pw-row{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end}.s-pw-dots{color:var(--text-muted);font-size:.9rem;letter-spacing:.1em}.s-change-pw{color:var(--accent)!important;font-size:.78rem!important}.s-save-bar{display:flex;align-items:center;gap:.5rem;margin-top:.65rem}.s-sub-block{margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--card-border);display:flex;flex-direction:column;gap:.3rem}.s-sub-status{margin:0;font-size:.82rem;color:var(--text-secondary);font-weight:600}.s-sub-canceled{color:var(--red)}.s-cancel-btn{align-self:flex-start;font-size:.78rem;color:var(--red);font-weight:600;padding:0}.s-save-msg{font-size:.78rem;color:var(--teal)}.s-toggle-row{display:flex;align-items:flex-start;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid var(--card-border);cursor:pointer;gap:.75rem}.s-toggle-row:last-child{border-bottom:none}.s-toggle-label{font-size:var(--font-base);font-weight:500;color:var(--text);display:block}.s-toggle-sub{font-size:.75rem;color:var(--text-muted);display:block;margin-top:.1rem}.s-toggle{accent-color:var(--accent);width:18px;height:18px;flex-shrink:0;margin-top:.1rem}.s-threshold-row{display:flex;align-items:center;gap:.25rem;padding:.25rem 0 .55rem;font-size:var(--font-base)}.s-threshold-row input{width:80px;padding:0 .5rem;height:34px;border:1px solid var(--card-border);border-radius:var(--radius);font-family:inherit;font-size:var(--font-base)}.s-danger-btn{padding:.5rem 1rem;border-radius:var(--radius);border:1px solid var(--red);background:transparent;color:var(--red);font-weight:600;font-size:var(--font-base);cursor:pointer}.s-danger-btn:hover{background:var(--red);color:#fff}.settings-two-col{display:flex;flex-direction:column;gap:.85rem}.settings-col{display:flex;flex-direction:column;gap:.85rem;flex:1;min-width:0}.s-threshold-edit{display:flex;align-items:center;gap:.25rem;margin-top:.15rem}.s-threshold-input{width:65px;padding:.15rem .35rem;border:1px solid var(--card-border);border-radius:6px;font-size:.78rem;font-family:inherit;background:var(--bg);color:var(--text);-moz-appearance:textfield}.s-threshold-input::-webkit-outer-spin-button,.s-threshold-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.s-login-list{display:flex;flex-direction:column;gap:.15rem}.s-login-entry{font-size:.78rem;color:var(--text-secondary);padding:.3rem 0;border-bottom:1px solid var(--card-border)}.s-login-entry:last-child{border-bottom:none}.coming-soon{font-size:.58rem;background:var(--card-border);color:var(--text-secondary);padding:.1rem .35rem;border-radius:999px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-left:.35rem}.s-mobile-logout{display:block;margin:.75rem 0 0;background:none;border:none;color:var(--text-muted);font-size:.82rem;cursor:pointer;padding:0}.terms-page{min-height:100vh;background:var(--bg);padding:2rem 1.25rem}.terms-inner{max-width:680px;margin:0 auto;background:var(--card);border-radius:var(--radius-lg);padding:2rem}.terms-inner h1{text-align:left;font-size:1.5rem;margin-bottom:.25rem}.terms-updated{color:var(--text-muted);font-size:.78rem;margin-bottom:1.5rem}.terms-inner h2{font-size:1rem;margin:1.5rem 0 .5rem}.terms-inner p,.terms-inner li{font-size:.88rem;line-height:1.6;color:var(--text-secondary)}.terms-highlight{background:#e53e3e0f;border:1px solid rgba(229,62,62,.2);border-radius:var(--radius);padding:1.25rem;margin:1rem 0}.terms-highlight h2{margin-top:0;color:var(--red)}.terms-back{margin-top:2rem}.terms-back a{color:var(--cta);font-weight:600}.lp-section-sub{text-align:center;color:var(--text-secondary);margin-top:-.5rem;margin-bottom:2rem;font-size:.95rem}.lp-hiw-section{overflow:hidden}.hiw-flow{display:flex;flex-direction:column;align-items:center;gap:0;max-width:540px;margin:0 auto}.hiw-step{display:flex;align-items:flex-start;gap:1.25rem;background:var(--card);border:2px solid var(--card-border);border-radius:var(--radius-lg);padding:1.5rem 1.75rem;width:100%;opacity:0;transform:translateY(28px);transition:opacity .5s ease,transform .5s ease}.hiw-step-2{transition-delay:.18s}.hiw-step-3{transition-delay:.36s;flex-direction:column}.hiw-visible .hiw-step{opacity:1;transform:translateY(0)}.hiw-icon-wrap{width:3rem;height:3rem;border-radius:50%;background:color-mix(in srgb,var(--accent) 15%,var(--card));display:flex;align-items:center;justify-content:center;flex-shrink:0}.hiw-icon-warn{background:color-mix(in srgb,#f59e0b 15%,var(--card))}.hiw-icon-green{background:color-mix(in srgb,var(--teal) 15%,var(--card))}.hiw-icon{font-size:1.4rem;line-height:1}.hiw-text{flex:1}.hiw-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0 0 .2rem}.hiw-title{font-size:1rem;font-weight:700;color:var(--text);margin:0 0 .4rem}.hiw-desc{font-size:.86rem;color:var(--text-secondary);line-height:1.55;margin:0}.hiw-connector{display:flex;flex-direction:column;align-items:center;gap:0;position:relative;opacity:0;transition:opacity .4s ease .1s}.hiw-visible .hiw-connector{opacity:1}.hiw-arrow-line{width:2px;height:2rem;background:linear-gradient(to bottom,var(--card-border),var(--accent))}.hiw-arrow-head{color:var(--accent);font-size:.8rem;margin-top:-2px}.hiw-minus-badge,.hiw-equals-badge{position:absolute;left:calc(50% + 12px);top:50%;transform:translateY(-50%);font-size:.72rem;font-weight:700;padding:.2rem .5rem;border-radius:99px;white-space:nowrap}.hiw-minus-badge{background:color-mix(in srgb,#ef4444 18%,var(--card));color:#ef4444}.hiw-equals-badge{background:color-mix(in srgb,var(--teal) 18%,var(--card));color:var(--teal)}.hiw-balance-pill{display:inline-flex;flex-direction:column;align-items:center;background:color-mix(in srgb,var(--accent) 12%,var(--card));border:2px solid var(--accent);border-radius:var(--radius-lg);padding:.75rem 2rem;margin-top:1.1rem;width:100%}.hiw-balance-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.hiw-balance-amount{font-size:2rem;font-weight:800;color:var(--accent);margin-top:.1rem}.lp-step-num{width:32px;height:32px;border-radius:999px;background:var(--navy);color:#fff;font-weight:800;font-size:.88rem;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem}.bill-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.bill-card-actions{display:flex;gap:.25rem}.bill-icon-btn{width:26px;height:26px;border-radius:6px;border:1px solid var(--card-border);background:var(--card);color:var(--text-muted);font-size:.72rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}.bill-icon-btn:hover{background:var(--bg);color:var(--text)}.bill-icon-del:hover{background:var(--red);color:#fff;border-color:var(--red)}.ob-bill-form-v2{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.ob-bill-row{display:flex;gap:.5rem}.ob-bill-field{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0;font-size:.78rem;font-weight:600;color:var(--text-secondary)}.ob-bill-field-wide{flex:2}.ob-bill-field input,.ob-bill-field select{padding:0 .6rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:var(--font-base);font-family:inherit;background:var(--card);color:var(--text)}.ob-bill-field input:focus,.ob-bill-field select:focus{outline:none;border-color:var(--accent)}.ob-bill-list-v2{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.ob-bill-card{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius)}.ob-bill-card-name{font-weight:600;font-size:var(--font-base);display:block}.ob-bill-card-meta{font-size:.72rem;color:var(--text-muted)}.ob-bill-card-right{display:flex;align-items:center;gap:.5rem}.ob-bill-card-amt{font-weight:700;color:var(--red);font-size:var(--font-base)}.ob-freq-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1rem 0 1.5rem}.ob-freq-card{padding:1.1rem .75rem;border-radius:var(--radius-lg);border:2px solid var(--card-border);background:var(--card);font-size:1rem;font-weight:600;cursor:pointer;color:var(--text);text-align:center;transition:all .12s}.ob-freq-card:hover{border-color:var(--teal);color:var(--teal)}.ob-freq-card.selected{background:var(--teal);color:#fff;border-color:var(--teal)}.ob-payday-choices{display:flex;flex-direction:column;gap:.75rem;margin:1.25rem 0 .5rem;width:100%}.ob-payday-choice{display:flex;align-items:center;gap:.85rem;padding:1rem 1.1rem;border-radius:var(--radius-lg);border:2px solid var(--card-border);background:var(--card);text-align:left;cursor:pointer;transition:all .13s;width:100%}.ob-payday-choice:hover{border-color:var(--accent)}.ob-payday-choice.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--card))}.ob-choice-icon{font-size:1.6rem;flex-shrink:0}.ob-choice-label{font-size:.97rem;font-weight:600;color:var(--text)}.ob-freq-label{font-size:.82rem;color:var(--text-secondary);margin:0 0 .75rem}.ob-freq-label strong{color:var(--text)}.ob-actions-col{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1rem}.ob-checkmark{font-size:3.5rem;color:var(--teal);animation:ob-pop .4s ease;margin-bottom:.5rem}@keyframes ob-pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.ob-skip-note{color:var(--text-secondary);font-size:.85rem;margin:.5rem 0 1.5rem;text-align:center;max-width:320px}.ob-income-type-grid{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0;width:100%}.ob-income-type-card{display:flex;flex-direction:column;align-items:flex-start;gap:.3rem;padding:1.1rem 1rem;border-radius:var(--radius-lg);border:2px solid var(--card-border);background:var(--card);text-align:left;cursor:pointer;transition:all .12s}.ob-income-type-card:hover{border-color:var(--teal)}.ob-income-type-icon{font-size:1.5rem}.ob-income-type-title{font-weight:700;font-size:.95rem;color:var(--text)}.ob-income-type-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.ob-tip{font-size:.82rem;color:var(--text-secondary);background:var(--bg);border-radius:var(--radius);padding:.6rem .75rem;margin:0 0 1rem;line-height:1.5}.dash-setup-banner{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#ffa3001f;border:1px solid rgba(255,163,0,.3);border-radius:var(--radius-lg);color:var(--text);text-decoration:none;font-size:.85rem;margin-bottom:.75rem}.dash-setup-banner:hover{background:#ffa30033}.dash-variable-banner{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#00c8961a;border:1px solid rgba(0,200,150,.25);border-radius:var(--radius-lg);color:var(--text);text-decoration:none;font-size:.85rem;margin-bottom:.75rem}.dash-variable-banner:hover{background:#00c8962e}.dash-setup-banner-cta{font-weight:700;white-space:nowrap;color:var(--accent);font-size:.82rem}.sub-page{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.25rem}.sub-heading{font-size:1.5rem;margin:0 0 .25rem;text-align:center}.sub-subtitle{color:var(--text-secondary);margin:0 0 1.5rem;text-align:center}.sub-trial-banner{background:#00c8961a;border:1px solid var(--teal);color:var(--teal);border-radius:var(--radius);padding:.5rem 1rem;font-size:.82rem;font-weight:600;margin-bottom:1rem;text-align:center}.sub-error-banner{background:#e53e3e14;border:1px solid var(--red);color:var(--red);border-radius:var(--radius);padding:.6rem 1rem;font-size:.85rem;font-weight:500;margin-bottom:1rem;max-width:720px;margin-left:auto;margin-right:auto}.sub-plans{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;width:100%;max-width:640px}.sub-plan-card{flex:1;min-width:260px;max-width:300px;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;position:relative}.sub-plan-card h3{margin:0 0 .25rem}.sub-price{font-size:2rem;font-weight:800;margin:0 0 .5rem}.sub-price span{font-size:.82rem;font-weight:400;color:var(--text-secondary)}.sub-savings{font-size:.78rem;color:var(--teal);font-weight:600;margin:-.25rem 0 .75rem}.sub-plan-card ul{list-style:none;padding:0;margin:0 0 1rem;text-align:left}.sub-plan-card li{padding:.3rem 0;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--card-border)}.sub-plan-card li:last-child{border-bottom:none}.sub-trial-note{font-size:.72rem;color:var(--text-muted);margin:-.5rem 0 .75rem}.sub-plan-best{border-color:var(--cta)}.sub-best-badge{position:absolute;top:-10px;right:16px;background:var(--cta);color:#fff;font-size:.62rem;font-weight:700;padding:.15rem .55rem;border-radius:999px;text-transform:uppercase}.sub-card-active{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:2rem;text-align:center;max-width:420px}.sub-card-active h1{font-size:1.25rem;margin:0 0 .5rem}.sub-spinner{width:40px;height:40px;margin:0 auto 1rem;border:3px solid var(--card-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sub-back{margin-top:1.25rem;color:var(--text-muted);font-size:.82rem;display:block;text-align:center}.upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem 1rem;background:linear-gradient(135deg,var(--navy),var(--navy-2, #1B2A3B));border-radius:var(--radius);margin:0 1.25rem .5rem}.upgrade-banner-text{color:#fffc;font-size:.78rem}.upgrade-banner-text strong{color:var(--teal)}.upgrade-banner .primary-button{font-size:.75rem;height:32px;padding:0 .75rem;white-space:nowrap}.admin-page{padding:1.5rem 2rem;max-width:1024px;margin:0 auto}.admin-page h1{text-align:left;font-size:1.25rem;margin-bottom:.75rem}.admin-search{width:100%;max-width:400px;padding:0 .75rem;height:var(--btn-h);border:1px solid var(--card-border);border-radius:var(--radius);font-size:var(--font-base);font-family:inherit;background:var(--card);color:var(--text);margin-bottom:.75rem}.admin-table-wrap{overflow-x:auto;border:1px solid var(--card-border);border-radius:var(--radius)}.admin-table{width:100%;border-collapse:collapse;min-width:600px}.admin-table th{text-align:left;padding:.5rem .75rem;background:var(--bg);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--card-border)}.admin-table td{padding:.5rem .75rem;border-bottom:1px solid var(--card-border);font-size:var(--font-base)}.admin-table tr{cursor:pointer;transition:background .1s}.admin-table tr:hover{background:var(--bg)}.admin-table tr.active{background:#00c8960f}.admin-badge{padding:.12rem .45rem;border-radius:999px;font-size:.65rem;font-weight:700;text-transform:uppercase}.admin-badge.free{background:var(--card-border);color:var(--text-muted)}.admin-badge.trialing{background:#00c89626;color:var(--teal)}.admin-badge.premium_monthly,.admin-badge.premium_annual{background:#f6c90e26;color:#d97706}.admin-badge.expired{background:#e53e3e1a;color:var(--red)}.admin-detail{display:flex;flex-direction:column;gap:.15rem;margin-top:.5rem}.admin-detail h5{margin:.75rem 0 .25rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.admin-detail-row{display:flex;justify-content:space-between;padding:.3rem 0;font-size:.85rem;border-bottom:1px solid var(--card-border)}.admin-detail-row:last-child{border-bottom:none}.admin-tabs{display:flex;gap:.35rem;margin-bottom:1rem;flex-wrap:wrap}.admin-billing{margin-top:.5rem}.admin-billing-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.admin-billing-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1.25rem;text-align:center}.admin-billing-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.35rem}.admin-billing-value{font-size:1.5rem;font-weight:800;color:var(--text)}.admin-flags{display:flex;flex-direction:column}.admin-badge.open{background:#f6c90e26;color:#d97706}.admin-badge.resolved{background:#00c89626;color:var(--teal)}.admin-badge.premium{background:#f6c90e26;color:#d97706}.resolved-row{opacity:.5}.upcoming-card{display:flex;align-items:center;gap:.35rem;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);padding:.5rem}.up-card-body{flex:1;display:flex;align-items:center;gap:.6rem;cursor:pointer;min-width:0}.up-arrow{width:32px;height:32px;border-radius:var(--radius);border:1px solid var(--card-border);background:var(--card);color:var(--text-secondary);font-size:.88rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}.up-arrow:hover:not(:disabled){background:var(--bg);color:var(--text)}.up-arrow:disabled{opacity:.3;cursor:default}.plan-badge{font-size:.55rem;padding:.1rem .4rem;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-left:.35rem}.premium-plan{background:var(--teal);color:#fff}.trial-plan{background:#00c89633;color:var(--teal)}.free-plan{background:#ffffff1a;color:#fff6}.brand-sub{margin:1.5rem 0 0;font-size:.72rem;color:#ffffff59}.sidebar-brand-sub{margin:.5rem 0 0;font-size:.65rem;color:#ffffff40}.quick-add-label{margin:0 0 .25rem;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.text-size-preview{background:var(--bg);border-radius:var(--radius);padding:.85rem 1rem;text-align:center;color:var(--text-secondary);margin-bottom:.75rem;transition:font-size .15s}.text-size-slider{display:flex;align-items:center;gap:.65rem;padding:.25rem 0}.text-size-slider .size-a-sm{font-size:.75rem;color:var(--text-muted);font-weight:600;flex-shrink:0}.text-size-slider .size-a-lg{font-size:1.35rem;color:var(--text-muted);font-weight:600;flex-shrink:0}.slider-track{flex:1;position:relative;height:32px;display:flex;align-items:center;cursor:pointer}.slider-rail{width:100%;height:4px;background:var(--card-border);border-radius:999px;position:relative}.slider-fill{position:absolute;left:0;top:0;height:100%;background:var(--teal);border-radius:999px;transition:width .1s}.slider-ticks{position:absolute;top:0;left:0;right:0;height:100%;display:flex;justify-content:space-between;align-items:center;pointer-events:none}.slider-tick{width:6px;height:6px;border-radius:999px;background:var(--card-border)}.slider-tick.active{background:var(--teal)}.slider-thumb{position:absolute;top:50%;width:22px;height:22px;border-radius:999px;background:#fff;border:2px solid var(--card-border);box-shadow:0 1px 4px #0000001f;transform:translate(-50%,-50%);transition:left .1s}.slider-thumb:hover{border-color:var(--teal)}.debt-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);padding:var(--card-pad)}.debt-header{display:flex;justify-content:space-between;align-items:flex-start}.debt-details{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.78rem;color:var(--text-secondary);margin-top:.35rem}.debt-projection{margin-top:.65rem;padding-top:.65rem;border-top:1px solid var(--card-border)}.debt-projection-note{font-size:.7rem;color:var(--text-muted);font-style:italic;margin:0 0 .35rem}.debt-projection-row{display:flex;justify-content:space-between;padding:.2rem 0;font-size:.82rem}.debt-extra{margin-top:.5rem}.debt-extra label{font-size:.78rem;font-weight:600;color:var(--text-secondary);display:flex;flex-direction:column;gap:.2rem}.debt-extra-input{width:70px;padding:.2rem .4rem;border:1px solid var(--card-border);border-radius:6px;font-size:.82rem;font-family:inherit;background:var(--bg);color:var(--text);-moz-appearance:textfield}.debt-extra-input::-webkit-outer-spin-button,.debt-extra-input::-webkit-inner-spin-button{-webkit-appearance:none}.debt-extra-result{display:flex;flex-direction:column;gap:.15rem;font-size:.78rem;margin-top:.25rem}.skeleton{background:linear-gradient(90deg,var(--card-border) 25%,var(--bg) 50%,var(--card-border) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dual-charts{display:flex;flex-direction:column;gap:1.25rem}.chart-col{flex:1;min-width:0}.chart-label{margin:0 0 .35rem;font-size:.82rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.donut-wrapper{position:relative}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.donut-center-label{display:block;font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.donut-center-value{display:block;font-size:.95rem;font-weight:800;color:var(--text)}.bills-income-page{padding:1.25rem;max-width:700px;margin:0 auto}.bills-income-page h1{text-align:left;font-size:1.25rem;margin-bottom:.75rem}.bi-summary-bar{display:flex;justify-content:space-between;align-items:center;padding:.55rem .85rem;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);margin-bottom:1rem;font-size:var(--font-base)}.bi-tabs{display:flex;gap:.35rem;margin-bottom:1rem;border-bottom:1px solid var(--card-border);padding-bottom:0}.bi-tab{flex:1;padding:.65rem .85rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:color .12s,border-color .12s;font-family:inherit}.bi-tab:hover{color:var(--text)}.bi-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.bi-section{margin-bottom:1.25rem}.bi-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;gap:.5rem}.bi-section-head h2{margin:0;font-size:.95rem;font-weight:700}.savings-plus-btn,.savings-minus-btn{font-size:.75rem;padding:.3rem .6rem}@media(max-width:640px){.app{padding:1.15rem}.note-group{grid-column:span 1}.hero-balance{font-size:2.5rem}.quick-add-form{flex-wrap:wrap}.quick-desc{flex:1 1 100%}.quick-amount,.quick-cat{max-width:none;flex:1}.recurring-panel:not(.open) .recurring-section{display:none}.recurring-header .ghost-button{display:inline-flex}.cal-cell{min-height:60px;padding:.2rem}.cal-day-num{font-size:.68rem}.cal-bill-tag,.cal-exp-tag{font-size:.52rem}.cal-add-row{flex-wrap:wrap}.cal-add-row input,.cal-add-row select{flex:1 1 45%}.ad-banner .ad-placeholder,.ad-inline .ad-placeholder{height:50px}.lp-features{grid-template-columns:1fr}.lp-hero h1{font-size:1.35rem}.auth-name-row{flex-direction:column;gap:.75rem}.sidebar{display:flex;position:fixed;top:0;left:-230px;width:230px;height:100vh;z-index:45;transition:left .25s ease}.sidebar.open{left:0}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:44}.sidebar-open .shell-main{margin-left:0}}@media(min-width:641px){.dashboard-page{border-radius:20px;overflow:hidden;min-height:auto;box-shadow:0 8px 30px #00000014}.hero{border-radius:0}.stat-grid{grid-template-columns:repeat(4,1fr)}.stat-card{height:auto}.spending-layout{flex-direction:row}.spending-chart{flex:0 0 200px}.spending-legend{flex:1}.dual-charts,.history-charts{flex-direction:row}}@media(min-width:901px){#root{padding:0}.sidebar{display:flex;flex-direction:column;width:230px;background:var(--navy);color:#fff;padding:1.5rem 0 1rem;flex-shrink:0;height:100vh;position:fixed;top:0;left:0;z-index:45;overflow-y:auto;transition:left .25s ease}.sidebar-overlay{display:none!important}.shell-main{margin-left:230px;transition:margin-left .25s ease}.hamburger-btn{display:none}.sidebar-brand{font-size:1.25rem;font-weight:800;padding:0 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.brand-dot{width:10px;height:10px;border-radius:999px;background:var(--teal);display:inline-block;flex-shrink:0}.sidebar-nav{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;flex:1}.sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.6rem 1.25rem;color:#ffffff73;text-decoration:none;font-size:.88rem;font-weight:500;transition:background .12s,color .12s;position:relative}.sidebar-link:hover{background:#ffffff0d;color:#fffc}.sidebar-link.active{background:#ffffff14;color:#fff;font-weight:600}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--teal)}.sidebar-icon{font-size:1rem;width:1.25rem;text-align:center}.sidebar-bottom{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.25rem 0;margin-top:auto;border-top:1px solid rgba(255,255,255,.08)}.sidebar-logout{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:#ffffff59;font-size:.82rem;font-weight:500;cursor:pointer;padding:.4rem 0;transition:color .15s}.sidebar-logout:hover{color:#ffffffbf}.sidebar-logout .logout-icon{font-size:1rem}.bottom-tabs{display:none}.shell-main{padding-bottom:0}.dashboard-page,.calendar-page,.bills-income-page,.history-page,.manage-income-page{max-width:1024px;margin:0 auto;padding:1.5rem 2rem 2rem;border-radius:0;box-shadow:none;min-height:auto;overflow:visible}.hero{border-radius:var(--radius-lg);padding:1.75rem 2rem 2rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--navy) 0%,#1a2744 100%);box-shadow:0 4px 24px #0000001f}.stat-grid{padding:0;grid-template-columns:repeat(4,1fr)}.stat-card{height:auto;box-shadow:0 2px 8px #0000000f}.quick-add{padding:.75rem 0}.planner-section{padding:0}.dash-columns{display:flex;gap:1.5rem;padding:0 0 2rem}.dash-columns .planner-section{flex:3;min-width:0}.dash-chart-col{flex:2;min-width:0}.cal-cell{min-height:100px}.cal-month-label{font-size:1.35rem}.cal-day-num{font-size:.85rem}.bi-two-col{display:flex;gap:1.5rem}.bi-two-col>.bi-section{flex:1;min-width:0}.settings-page{max-width:900px;margin:0 auto;padding:1.5rem 2rem 2rem}.settings-two-col{flex-direction:row;gap:1.5rem}.settings-two-col>.settings-col{flex:1;min-width:0}.settings-section{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:0 2px 8px #0000000f}.s-mobile-logout{display:none}.lp-hero{padding:5rem 2rem 6rem}.lp-hero h1{font-size:2.75rem;letter-spacing:-.02em}.lp-hero-sub{font-size:1.15rem;max-width:600px;margin-left:auto;margin-right:auto;margin-bottom:2.5rem}.lp-hero-inner{max-width:800px}.lp-features{grid-template-columns:1fr 1fr;gap:1.25rem}.lp-feature{padding:2rem}}@media(min-width:1400px){.shell-main>*{max-width:1200px;margin-left:auto;margin-right:auto}.hero{max-width:1200px;margin-left:auto;margin-right:auto}.lp-features{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px){.auth-brand-panel{display:flex;align-items:center;justify-content:center;flex:1;background:var(--navy);padding:3rem}.auth-brand-content{max-width:380px}.auth-form-panel{flex:1}.lp-features{grid-template-columns:1fr 1fr}}:root,[data-theme=dark]{--navy: #0D1117;--navy-2: #161B22;--bg: #0D1117;--card: #161B22;--card-2: #1F2530;--card-border: #21262D;--card-border-2: #30363D;--text: #F0F6FC;--text-secondary: #B1BAC4;--text-muted: #8B95A1;--teal: #14B8A6;--teal-dim: rgba(20, 184, 166, .08);--orange: #F97316;--orange-hover: #FB8C3A;--red: #EF4444;--gold: #F59E0B;--accent: #14B8A6;--cta: #F97316;--cta-hover: #FB8C3A;--positive: #14B8A6;--negative: #EF4444;--radius: 12px;--radius-lg: 16px;--radius-pill: 999px}html{scroll-behavior:smooth}html,body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01";background:var(--bg);color:var(--text)}body{font-size:15px;line-height:1.6;letter-spacing:0}#root{padding:0;min-height:100vh;display:block}h1,h2,h3,h4,h5,h6{color:var(--text);letter-spacing:-.01em}.hero-label,.stat-label,.section-title,.quick-add-label,.admin-detail h5,.admin-billing-label,.admin-badge,.legend-label,.admin-table th,.bi-sub-label,.cal-weekday{letter-spacing:.02em!important}.app-shell{min-height:100vh;background:var(--bg);position:relative;display:block!important}.shell-main{padding:64px 0 24px;min-height:100vh;animation:pp-fade-in .15s ease-out both;box-sizing:border-box;max-width:1200px;margin:0 auto}@keyframes pp-fade-in{0%{opacity:0}to{opacity:1}}.pp-header{position:fixed;top:0;left:0;right:0;height:56px;z-index:100;background:var(--navy);border-bottom:1px solid var(--card-border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;padding-right:max(16px,env(safe-area-inset-right));padding-left:max(16px,env(safe-area-inset-left))}.pp-header-brand{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text)}.pp-header-brand-dot{width:10px;height:10px;border-radius:999px;background:var(--teal);flex-shrink:0}.pp-header-brand-name{font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.01em}.pp-header-btn{width:44px;height:44px;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,border-color .12s;padding:0}.pp-header-btn:hover,.pp-header-btn:focus-visible{background:var(--card);border-color:var(--card-border);outline:none}.pp-header-btn svg{width:22px;height:22px}.hamburger-btn{display:none!important}.pp-drawer-overlay{position:fixed;inset:0;background:#0000008c;z-index:110;opacity:0;pointer-events:none;transition:opacity .22s ease}.pp-drawer-overlay.open{opacity:1;pointer-events:auto}.pp-drawer{position:fixed;top:0;left:0;bottom:0;width:min(82vw,300px);background:var(--navy-2);border-right:1px solid var(--card-border);z-index:120;transform:translate(-105%);transition:transform .26s cubic-bezier(.32,.72,.26,1);display:flex;flex-direction:column;padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom));padding-left:max(20px,env(safe-area-inset-left));padding-right:20px}.pp-drawer.open{transform:translate(0)}.pp-drawer-brand{display:flex;align-items:center;gap:10px;padding:8px 0 24px;border-bottom:1px solid var(--card-border);margin-bottom:16px}.pp-drawer-brand-name{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.02em}.pp-drawer-close{margin-left:auto;width:36px;height:36px;border:none;background:transparent;color:var(--text-muted);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.pp-drawer-close:hover{background:var(--card);color:var(--text)}.pp-drawer-nav{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;flex:1}.pp-drawer-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:var(--text-secondary);text-decoration:none;font-size:15px;font-weight:500;transition:background .12s,color .12s}.pp-drawer-link:hover{background:var(--card);color:var(--text)}.pp-drawer-link.active{background:#14b8a614;color:var(--teal);font-weight:600}.pp-drawer-link svg{width:20px;height:20px;flex-shrink:0}.pp-drawer-footer{padding-top:16px;border-top:1px solid var(--card-border);margin-top:16px}.pp-drawer-status{display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:13px;color:var(--text-muted)}.pp-drawer-status .pp-status-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.pp-status-pill.premium{background:#14b8a626;color:var(--teal)}.pp-status-pill.trial{background:#f59e0b26;color:var(--gold)}.pp-status-pill.free{background:#8b95a126;color:var(--text-muted)}.pp-drawer-logout{margin-top:12px;width:100%;padding:12px;background:transparent;border:1px solid var(--card-border-2);border-radius:10px;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit}.pp-drawer-logout:hover{background:var(--card);border-color:var(--card-border-2)}.sidebar,.sidebar-overlay,.sidebar-bottom{display:none!important}.pp-page{width:100%;max-width:480px;margin:0 auto;padding:16px;padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.dashboard-page,.calendar-page,.bills-income-page,.history-page,.manage-income-page,.settings-page,.admin-page,.sub-page{width:100%!important;max-width:480px!important;margin:0 auto!important;padding:16px!important}.dashboard-page .stat-grid,.dashboard-page .quick-add,.dashboard-page .planner-section,.dashboard-page .dash-columns,.dashboard-page .upgrade-banner,.dashboard-page .dash-setup-banner,.dashboard-page .dash-variable-banner{padding-left:0!important;padding-right:0!important;margin-left:0!important;margin-right:0!important}.dashboard-page .dash-columns{gap:20px;padding-top:4px;padding-bottom:24px}.dashboard-page .planner-section{padding-top:0;padding-bottom:0}.pp-page-title{font-size:24px;font-weight:700;color:var(--text);margin:8px 0 20px;letter-spacing:-.02em;padding:0}.dashboard-page>h1,.calendar-page>h1,.bills-income-page>h1,.history-page>h1,.settings-page>h1,.sub-heading,.cal-month-label{font-size:24px!important;font-weight:700!important;letter-spacing:-.02em!important;color:var(--text)!important;margin:8px 0 20px!important}.dashboard-page .hero{background:radial-gradient(ellipse at top,rgba(20,184,166,.1) 0%,transparent 60%),var(--navy-2)!important;padding:32px 20px 36px!important;text-align:center!important;border-radius:var(--radius-lg)!important;margin-bottom:16px!important;border:1px solid var(--card-border)!important;overflow:hidden}.dashboard-page .hero-label{font-size:11px!important;text-transform:uppercase!important;letter-spacing:.02em!important;font-weight:600!important;color:var(--text-muted)!important;margin:0 0 12px!important}.dashboard-page .hero-balance{margin:0!important;font-size:clamp(44px,13vw,64px)!important;font-weight:800!important;color:var(--text)!important;letter-spacing:-.03em!important;line-height:1.05!important}.dashboard-page .hero-balance.healthy{text-shadow:0 0 40px rgba(20,184,166,.22)!important}.dashboard-page .hero-balance.warning{text-shadow:0 0 40px rgba(239,68,68,.28)!important}.dashboard-page .hero-sub{margin:12px 0 0!important;font-size:13px!important;color:var(--text-muted)!important;letter-spacing:0!important}.dashboard-page .hero-next-pill{display:inline-block;margin-top:16px!important;padding:8px 14px!important;background:#14b8a614!important;border:1px solid rgba(20,184,166,.22)!important;border-radius:999px!important;color:var(--text-secondary)!important;font-size:12px!important;font-weight:500}.dashboard-page .hero-next-pill strong{color:var(--teal)!important;font-weight:700}.stat-grid{display:grid!important;grid-template-columns:1fr 1fr!important;gap:10px!important;padding:0!important;margin:0 0 20px!important}.stat-card{background:var(--card)!important;border:1px solid var(--card-border)!important;border-radius:var(--radius-lg)!important;padding:16px!important;height:auto!important;min-height:84px!important;display:flex!important;flex-direction:column!important;gap:6px!important;transition:border-color .15s ease}.stat-card:hover{border-color:var(--card-border-2)}.stat-label{font-size:11px!important;font-weight:500!important;color:var(--text-muted)!important;text-transform:uppercase!important;letter-spacing:.02em!important}.stat-value{font-size:20px!important;font-weight:700!important;color:var(--text)!important;letter-spacing:-.01em!important}.stat-value.bills{color:var(--red)!important}.stat-value.teal{color:var(--teal)!important}.quick-add{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:20px!important;margin:0 0 20px!important}.quick-add-label{margin:0 0 4px!important;font-size:16px!important;font-weight:700!important;color:var(--text)!important;text-transform:none!important;letter-spacing:-.01em!important}.quick-add-sub{margin:0 0 16px;font-size:13px;color:var(--text-muted)}.quick-add-form{display:flex!important;flex-direction:column!important;gap:14px!important;align-items:stretch!important}.qa-field{display:flex;flex-direction:column;gap:6px}.qa-label{font-size:13px;font-weight:500;color:var(--text-muted)}.qa-input{width:100%;padding:14px 16px!important;height:auto!important;font-size:16px!important;background:var(--card-2)!important;border:1px solid var(--card-border)!important;border-radius:10px!important;color:var(--text)!important;font-family:inherit!important;max-width:none!important;transition:border-color .12s}.qa-input:focus{outline:none;border-color:var(--teal)!important}.qa-input.error{border-color:var(--red)!important}.qa-chips{display:flex;gap:8px;overflow-x:auto;padding:4px 0 8px;margin:0 -4px;scrollbar-width:none;-ms-overflow-style:none}.qa-chips::-webkit-scrollbar{display:none}.qa-chip{padding:10px 16px;border-radius:999px;background:var(--card-2);border:1px solid var(--card-border);color:var(--text-secondary);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .12s ease}.qa-chip:hover{border-color:var(--card-border-2);color:var(--text)}.qa-chip.active{background:#14b8a61f;border-color:var(--teal);color:var(--teal)}.qa-submit{width:100%;padding:14px 24px;background:var(--cta);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;min-height:48px;transition:background .15s}.qa-submit:hover{background:var(--cta-hover)}.qa-submit:disabled{opacity:.5;cursor:default}.qa-error{margin:0;font-size:12px;color:var(--red)}.qa-future-note{margin:4px 0 0;font-size:12px;color:var(--cta)}.pp-fab{position:fixed;right:20px;bottom:calc(84px + env(safe-area-inset-bottom));width:56px;height:56px;border-radius:999px;background:var(--cta);color:#fff;border:none;box-shadow:0 6px 24px #f9731659;cursor:pointer;z-index:90;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:400;transition:transform .15s ease,background .15s}.pp-fab:hover{background:var(--cta-hover);transform:translateY(-1px)}.pp-fab:active{transform:translateY(0)}.pp-sheet-overlay{position:fixed;inset:0;background:#0000008c;z-index:130;display:flex;align-items:flex-end;animation:pp-fade-in .16s ease-out}.pp-sheet{width:100%;max-width:560px;margin:0 auto;background:var(--card);border-top-left-radius:24px;border-top-right-radius:24px;padding:16px 20px max(24px,env(safe-area-inset-bottom));max-height:92vh;overflow-y:auto;animation:pp-sheet-up .26s cubic-bezier(.32,.72,.26,1)}@keyframes pp-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pp-sheet-handle{width:40px;height:4px;background:var(--card-border-2);border-radius:999px;margin:4px auto 14px}.pp-sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.pp-sheet-title{margin:0;font-size:18px;font-weight:700;color:var(--text)}.pp-sheet-close{width:32px;height:32px;border-radius:8px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.pp-sheet-close:hover{background:var(--card-2);color:var(--text)}.quick-add.is-inline-hidden{display:none}.bottom-tabs{position:fixed!important;bottom:0!important;left:0!important;right:0!important;height:68px!important;padding-bottom:env(safe-area-inset-bottom)!important;background:var(--navy)!important;border-top:1px solid var(--card-border)!important;display:flex!important;align-items:stretch!important;justify-content:space-around!important;z-index:40}.tab-item{flex:1;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:3px!important;padding:8px 4px!important;min-width:44px;min-height:56px;text-decoration:none!important;color:var(--text-muted)!important;font-size:12px!important;font-weight:500!important;position:relative;transition:color .12s;background:transparent;border:none}.tab-item:hover{color:var(--text-secondary)!important}.tab-item.active{color:var(--teal)!important}.tab-item svg{width:22px;height:22px}.tab-label{font-size:12px!important;letter-spacing:0!important}.tab-item.active:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:999px;background:var(--teal)}.recurring-card .pill,.recurring-card .ends-pill,.recurring-card .primary-pill,.pill,.entry-title .pill{white-space:nowrap!important;display:inline-block}.recurring-card .entry-title{display:flex;flex-wrap:wrap;align-items:center;gap:6px;row-gap:6px}.bill-card-actions{display:flex;gap:10px;align-items:center}.bill-icon-btn{min-width:44px;min-height:44px;width:44px;height:44px;border-radius:10px;border:1.5px solid #14B8A6!important;background:transparent!important;color:#14b8a6!important;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;transition:all .12s}.bill-icon-btn:hover{background:#14b8a61a!important;color:#14b8a6!important;border-color:#14b8a6!important}.bill-icon-btn.bill-icon-del{width:36px!important;min-width:36px!important;height:36px!important;min-height:36px!important;border:1px solid #30363D!important;background:transparent!important;color:var(--text-muted)!important;font-size:16px}.bill-icon-btn.bill-icon-del:hover{color:var(--red)!important;border-color:var(--red)!important;background:#ef444414!important}.ad-slot{display:none!important}@media(min-width:768px){.ad-slot{display:flex!important;justify-content:center;margin:16px auto;max-width:728px}.ad-placeholder{width:320px;height:50px;border:1px dashed var(--card-border-2);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:11px;letter-spacing:.02em;background:var(--card)}.ad-dims{display:none}}.settings-section{background:var(--card)!important;border:1px solid var(--card-border)!important;border-radius:var(--radius-lg)!important;padding:20px!important;margin-bottom:16px}.settings-section .section-title{font-size:17px!important;font-weight:700!important;margin:0 0 16px!important;letter-spacing:-.01em!important}.settings-section .pp-subheader{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;margin:20px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--card-border)}.settings-section .pp-subheader:first-of-type{margin-top:4px}.s-field-label{font-size:13px!important;color:var(--text-muted)!important;font-weight:500!important}.s-field input,.s-field input[type=date]{font-size:15px!important;color:var(--text)!important;font-weight:400!important}.primary-button{padding:14px 24px!important;height:auto!important;min-height:48px!important;background:var(--cta)!important;color:#fff!important;border:none!important;border-radius:12px!important;font-size:15px!important;font-weight:600!important;letter-spacing:0!important;cursor:pointer;font-family:inherit;transition:background .15s}.primary-button:hover{background:var(--cta-hover)!important}.ghost-button{padding:14px 24px!important;height:auto!important;min-height:48px!important;background:transparent!important;color:var(--text)!important;border:1px solid var(--card-border-2)!important;border-radius:12px!important;font-size:15px!important;font-weight:600!important;letter-spacing:0!important;cursor:pointer;font-family:inherit;transition:all .15s}.ghost-button:hover{border-color:var(--text-muted)!important}.delete-button{padding:14px 24px!important;min-height:48px!important;background:var(--red)!important;color:#fff!important;border:none!important;border-radius:12px!important;font-size:15px!important;font-weight:600!important;cursor:pointer;font-family:inherit}.upgrade-banner{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:12px!important;padding:14px 16px!important;background:linear-gradient(135deg,#f59e0b26,#f973161a)!important;border:1px solid rgba(245,158,11,.3)!important;border-radius:var(--radius-lg)!important;margin:0 0 16px!important}.upgrade-banner-text{color:#fff!important;font-size:14px!important;font-weight:600!important;line-height:1.4!important;letter-spacing:0!important}.upgrade-banner-text strong{color:#fff!important;font-weight:700!important}.upgrade-banner .primary-button{padding:8px 16px!important;min-height:36px!important;font-size:13px!important;height:auto!important;flex-shrink:0;margin-left:auto}.modal-form label{display:flex!important;flex-direction:column!important;gap:6px!important;font-size:13px!important;color:var(--text-muted)!important;font-weight:500!important;margin-bottom:12px}.modal-form input,.modal-form select,.modal-form textarea{padding:14px 16px!important;font-size:16px!important;background:var(--card-2)!important;border:1px solid var(--card-border)!important;border-radius:10px!important;color:var(--text)!important;font-family:inherit!important;height:auto!important;transition:border-color .12s}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{outline:none;border-color:var(--teal)!important}.pp-field-error,.inline-error{display:block;margin:6px 0 0!important;font-size:12px!important;color:var(--red)!important;font-weight:500;background:transparent!important;border:none!important;padding:0!important}.pp-field-error:before{content:"⚠ "}.bi-summary-bar{background:var(--card)!important;border:1px solid var(--card-border)!important;border-radius:var(--radius-lg)!important;padding:16px!important;margin:0 0 20px!important}.bi-section{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.bi-section-head h2{font-size:17px!important;font-weight:700!important;letter-spacing:-.01em!important}@media(min-width:768px){.dashboard-page,.calendar-page,.bills-income-page,.history-page,.manage-income-page,.settings-page,.admin-page,.sub-page{max-width:1100px!important;padding:32px 32px 48px!important;margin:0 auto!important}.dashboard-page .hero{padding:40px 24px 44px!important}.dashboard-page .hero-balance{font-size:clamp(52px,6vw,72px)!important}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))!important}}.history-date{white-space:nowrap!important}.history-edit-btn{height:28px;min-width:28px;padding:0 .4rem;font-size:.9rem;line-height:1;background:transparent;border:1px solid var(--card-border-2);color:var(--text-secondary);border-radius:8px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;transition:color .12s,border-color .12s,background .12s}.history-edit-btn:hover{color:var(--teal);border-color:var(--teal);background:#14b8a614}.cal-view-toggle{display:inline-flex;padding:4px;background:var(--card-2);border:1px solid var(--card-border);border-radius:999px;gap:2px}.cal-view-toggle button{padding:8px 16px;border-radius:999px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;min-width:64px;transition:all .12s}.cal-view-toggle button.active{background:var(--teal);color:#fff}.sb-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.sb-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.sb-title{margin:0;font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.01em}.sb-toggle{display:inline-flex;padding:3px;background:var(--card-2);border:1px solid var(--card-border);border-radius:999px;gap:2px}.sb-toggle button{padding:6px 12px;border-radius:999px;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .12s;white-space:nowrap}.sb-toggle button.active{background:var(--teal);color:#fff}.sb-donut-row{display:flex;align-items:center;gap:20px;margin-bottom:16px}.sb-donut{flex-shrink:0}.sb-total-block{display:flex;flex-direction:column;gap:4px}.sb-total-label{font-size:11px;text-transform:uppercase;letter-spacing:.02em;color:var(--text-muted);font-weight:600}.sb-total-value{font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.02em}.sb-top-list{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:10px}.sb-top-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px}.sb-top-name{display:flex;align-items:center;gap:8px;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-top-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.sb-top-amount{color:var(--text-secondary);font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0}.sb-view-all{display:inline-block;color:var(--teal);font-size:13px;font-weight:600;text-decoration:none;padding:8px 0 0}.sb-view-all:hover{text-decoration:underline}.sb-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:24px 0}.day-modal-form{display:flex;flex-direction:column;gap:14px}.day-modal-form .qa-submit{width:100%}.cal-savings-dot{display:inline-block;width:5px;height:5px;border-radius:999px;background:#00c9a7;margin-right:2px}.cal-savings-tag{font-size:.58rem;color:#00c9a7;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-view-toggle-row{display:flex!important;justify-content:center!important;margin:4px 0 16px!important}.sb-mini-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:16px 20px;margin-top:12px}.sb-mini-title{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.sb-mini-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.sb-mini-row{display:flex;align-items:center;justify-content:space-between;font-size:14px}.sb-mini-row-total{border-top:1px solid var(--card-border);padding-top:10px;margin-top:2px}.sb-mini-name{display:flex;align-items:center;gap:8px;color:var(--text)}.sb-mini-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.sb-mini-amount{color:var(--text-secondary);font-weight:600;font-variant-numeric:tabular-nums}.sb-mini-available{color:var(--teal)!important}@media(min-width:768px){.auth-split{display:flex!important;min-height:100vh!important;align-items:stretch!important}.auth-brand-panel,.auth-form-panel{flex:1 1 50%!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:48px!important}.auth-form-inner{width:100%!important;max-width:440px!important;margin:0 auto!important}.auth-form-inner h1{margin:0 0 16px!important}}img,video,iframe,canvas,svg{max-width:100%}.admin-table-wrap{overflow-x:auto!important}.admin-table{min-width:auto!important}.pp-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:200;max-width:420px;width:calc(100% - 32px);padding:14px 20px;background:#00c9a7;color:#fff;font-size:14px;font-weight:600;border-radius:14px;box-shadow:0 8px 30px #00c9a74d;text-align:center;animation:pp-toast-in .3s ease-out both;pointer-events:none}@keyframes pp-toast-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pp-celebration-overlay{position:fixed;inset:0;background:#000000b3;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:pp-fade-in .2s ease-out both}.pp-celebration-card{max-width:440px;width:100%;background:#161b22;border:1px solid #00C9A7;border-radius:20px;padding:40px 32px 32px;text-align:center}.pp-celebration-title{font-size:28px;font-weight:800;color:#f0f6fc;margin:0 0 12px;letter-spacing:-.02em}.pp-celebration-sub{font-size:15px;color:#b1bac4;margin:0 0 28px;line-height:1.5}.pp-celebration-btn{min-width:160px}.pp-tour-overlay{position:fixed;inset:0;background:#000000a6;z-index:300;animation:pp-fade-in .2s ease-out both}.pp-tour-spotlight{position:fixed;border-radius:12px;box-shadow:0 0 0 9999px #000000a6;z-index:301;pointer-events:none;transition:all .3s ease}.pp-tour-tooltip{position:fixed;z-index:302;max-width:340px;width:calc(100vw - 32px);background:#161b22;border:1px solid #21262D;border-radius:14px;padding:20px;box-shadow:0 16px 48px #00000080;animation:pp-fade-in .2s ease-out both}.pp-tour-tt-title{font-size:16px;font-weight:700;color:#f0f6fc;margin:0 0 8px}.pp-tour-tt-body{font-size:14px;color:#b1bac4;line-height:1.55;margin:0 0 16px}.pp-tour-tt-footer{display:flex;align-items:center;justify-content:space-between}.pp-tour-tt-count{font-size:12px;color:#6b7280}.pp-tour-tt-actions{display:flex;align-items:center;gap:12px}.pp-tour-skip{background:none;border:none;color:#8b95a1;font-size:13px;cursor:pointer;font-family:inherit;padding:4px 0}.pp-tour-skip:hover{color:#f0f6fc}.pp-tour-next{padding:8px 16px!important;min-height:36px!important;font-size:13px!important}.pp-tour-final{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;max-width:440px;width:calc(100vw - 48px)}.pp-tour-final-title{font-size:28px;font-weight:800;color:#f0f6fc;margin:0 0 12px;letter-spacing:-.02em}.pp-tour-final-body{font-size:15px;color:#b1bac4;margin:0 0 28px;line-height:1.5}.pp-tour-final-btn{min-width:160px}.hc-section-title{font-size:18px;font-weight:700;color:var(--text);margin:28px 0 14px}.hc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.hc-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:border-color .15s}.hc-card:hover{border-color:var(--card-border-2)}.hc-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.hc-card-summary{margin:0;font-size:13px;color:var(--text-muted)}.hc-card-detail{margin:10px 0 0;font-size:13px;color:var(--text-secondary);line-height:1.5}.hc-accordion{display:flex;flex-direction:column;gap:2px}.hc-acc-item{background:var(--card);border:1px solid var(--card-border);border-radius:10px;overflow:hidden}.hc-acc-item.open{border-color:var(--card-border-2)}.hc-acc-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:transparent;border:none;color:var(--text);font-size:14px;font-weight:600;text-align:left;cursor:pointer;font-family:inherit}.hc-acc-arrow{font-size:18px;color:var(--text-muted);flex-shrink:0;margin-left:12px}.hc-acc-body{padding:0 16px 14px;font-size:14px;color:var(--text-secondary);line-height:1.55}.pp-payment-row{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--card-2);border:1px solid var(--card-border);border-radius:10px}.pp-payment-fields{display:flex;gap:8px}.pp-payment-fields label{display:flex;flex-direction:column;gap:4px}@media(max-width:480px){.pp-payment-fields{flex-direction:column}}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.pp-top{position:fixed;top:0;left:0;right:0;height:64px;background:#0d1117;border-bottom:1px solid #21262D;z-index:100;padding-top:env(safe-area-inset-top)}.pp-top-inner{height:64px;max-width:1320px;margin:0 auto;padding:0 20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));display:flex;align-items:center;gap:16px}.pp-top-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);flex-shrink:0}.pp-top-brand-dot{width:10px;height:10px;border-radius:999px;background:var(--teal);flex-shrink:0}.pp-top-brand-name{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.pp-top-nav{display:none;align-items:center;gap:4px;flex:1;justify-content:center;min-width:0}.pp-top-link{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:background .12s,color .12s;white-space:nowrap}.pp-top-link svg{width:18px;height:18px;flex-shrink:0}.pp-top-link:hover{background:#161b22;color:var(--text)}.pp-top-link.active{background:#14b8a61f;color:var(--teal);font-weight:600}.pp-top-right{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}.pp-top-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.pp-top-badge.premium{background:#14b8a626;color:var(--teal);border:1px solid rgba(20,184,166,.3)}.pp-top-badge.trial{background:#f59e0b26;color:var(--gold);border:1px solid rgba(245,158,11,.3)}.pp-top-avatar{width:38px;height:38px;border-radius:999px;border:1px solid #21262D;background:#161b22;color:var(--text);font-size:13px;font-weight:700;letter-spacing:.02em;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit;transition:all .12s}.pp-top-avatar:hover{background:#1f2530;border-color:#30363d}.pp-top-avatar-premium{border-color:#f59e0b80}.pp-top-crown{position:absolute;bottom:-3px;right:-3px;font-size:12px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));pointer-events:none}.pp-top-avatar-wrap{position:relative}.pp-top-avatar-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#161b22;border:1px solid #21262D;border-radius:12px;box-shadow:0 16px 40px #00000073;padding:6px;z-index:120;animation:pp-fade-in .14s ease-out both}.pp-top-avatar-header{padding:10px 12px 12px;border-bottom:1px solid #21262D;margin-bottom:6px;display:flex;flex-direction:column;gap:2px}.pp-top-avatar-name{font-size:13px;font-weight:700;color:var(--text)}.pp-top-avatar-email{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.pp-top-avatar-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;background:transparent;border:none;width:100%;color:var(--text-secondary);font-size:13px;font-weight:500;text-align:left;text-decoration:none;cursor:pointer;font-family:inherit}.pp-top-avatar-item svg{width:16px;height:16px}.pp-top-avatar-item:hover{background:#1f2530;color:var(--text)}.pp-top-avatar-logout{color:#fca5a5}.pp-top-avatar-logout:hover{background:#ef44441a;color:#ef4444}.pp-top-hamburger{width:40px;height:40px;border-radius:10px;border:1px solid #21262D;background:#161b22;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:inherit;padding:0}.pp-top-hamburger svg{width:20px;height:20px}.pp-top-hamburger:hover{background:#1f2530}.pp-top-mobile-overlay{position:fixed;inset:64px 0 0;background:#0000008c;z-index:98;animation:pp-fade-in .16s ease-out both}.pp-top-mobile{position:fixed;top:64px;left:0;right:0;background:#0d1117;border-bottom:1px solid #21262D;max-height:0;overflow:hidden;transition:max-height .26s cubic-bezier(.32,.72,.26,1);z-index:99;padding-bottom:max(12px,env(safe-area-inset-bottom))}.pp-top-mobile.open{max-height:calc(100vh - 64px);overflow-y:auto}.pp-top-mobile ul{list-style:none;margin:0;padding:8px 12px 12px;display:flex;flex-direction:column;gap:2px}.pp-top-mobile-link{display:flex;align-items:center;gap:12px;padding:14px;border-radius:10px;color:var(--text-secondary);text-decoration:none;font-size:15px;font-weight:500;background:transparent;border:none;font-family:inherit;width:100%;text-align:left;cursor:pointer}.pp-top-mobile-link svg{width:20px;height:20px;flex-shrink:0}.pp-top-mobile-link:hover{background:#161b22;color:var(--text)}.pp-top-mobile-link.active{background:#14b8a61f;color:var(--teal);font-weight:600}.pp-top-mobile-logout{color:#fca5a5}@media(min-width:900px){.pp-top-nav{display:flex}.pp-top-hamburger,.pp-top-mobile,.pp-top-mobile-overlay{display:none}}@media(max-width:899px){.pp-top-badge{padding:3px 8px;font-size:10px}.pp-top-avatar{width:36px;height:36px;font-size:12px}}.modal-overlay{overflow-y:auto!important;padding:16px!important;-webkit-overflow-scrolling:touch}.modal-card{max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain}@media(max-width:767px){.modal-card{width:100%!important;max-width:420px!important;max-height:90vh!important}}
