.auth-logo{font-size:52px;font-weight:700;letter-spacing:-2px;margin-bottom:6px;text-align:center}
.auth-logo span{color:var(--green)}
.auth-tag{font-size:14px;color:var(--muted);margin-bottom:36px;text-align:center}
.auth-card{background:var(--surface);border:1px solid rgba(14,165,233,0.15);border-radius:var(--radius);padding:24px;width:100%;max-width:360px;box-shadow:var(--shadow-lg)}
.auth-tabs{display:flex;gap:2px;background:var(--surface2);border-radius:var(--radius-sm);padding:3px;margin-bottom:20px}
.auth-tab{flex:1;padding:9px;border-radius:6px;font-size:13px;cursor:pointer;color:var(--muted);text-align:center;transition:all 0.15s}
.auth-tab.active{background:#fff;color:var(--text);font-weight:500}
.auth-divider{display:flex;align-items:center;gap:12px;margin-top:14px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0.08em}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-google-btn{width:100%;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;margin-top:14px;padding:10px 14px;border:1px solid rgba(148,163,184,0.28);border-radius:18px;background:rgba(255,255,255,0.92);color:var(--text);font:inherit;font-size:15px;font-weight:600;cursor:pointer;transition:border-color 0.15s ease,transform 0.15s ease,box-shadow 0.15s ease;background-clip:padding-box}
.auth-google-btn:hover{border-color:rgba(14,165,233,0.32);box-shadow:0 10px 24px rgba(15,23,42,0.06)}
.auth-google-btn:active{transform:translateY(1px)}
.auth-google-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(14,165,233,0.18)}
.auth-google-btn:disabled{opacity:0.55;cursor:not-allowed;transform:none;box-shadow:none}
.auth-google-btn-icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(255,255,255,0.96);border:1px solid rgba(148,163,184,0.18);box-shadow:0 4px 10px rgba(15,23,42,0.06)}
.auth-google-btn-icon svg{width:18px;height:18px;display:block}
.auth-google-btn span:last-child{grid-column:2;justify-self:center;text-align:center}
.auth-google-legal{margin-top:8px;font-size:11px;line-height:1.5;color:var(--muted);text-align:center}
.auth-google-legal a{color:var(--green);text-decoration:underline}
.auth-msg{font-size:13px;text-align:center;margin-top:12px;min-height:18px}
.auth-msg.err{color:var(--red)}
.auth-msg.ok{color:var(--green);background:rgba(14,165,233,0.08);border:1px solid rgba(14,165,233,0.22);border-radius:var(--radius-sm);padding:12px 14px;margin-top:16px;line-height:1.5}
.onboard{position:fixed;inset:0;z-index:150;display:flex;flex-direction:column}
.onboard.hidden{display:none}
.ob-hd{padding:20px 20px 0;display:flex;align-items:center;justify-content:space-between}
.ob-logo{font-size:20px;font-weight:700;letter-spacing:-0.5px}
.ob-logo span{color:var(--green)}
.dev-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;background:var(--green-light);border:1px solid rgba(14,165,233,0.22);color:var(--green)!important;font-size:10px;font-weight:800;letter-spacing:0.08em}
.ob-step{font-size:13px;color:var(--muted)}
.ob-prog{height:3px;background:var(--surface2);margin:16px 20px 0}
.ob-bar{height:100%;background:var(--green);border-radius:2px;transition:width 0.4s ease}
.ob-body{flex:1;overflow-y:auto;padding:24px 20px}
.ob-hero{margin-bottom:18px;padding:18px;border:1px solid rgba(14,165,233,0.18);border-radius:22px;background:linear-gradient(135deg,rgba(14,165,233,0.12),rgba(255,255,255,0) 54%),var(--surface);box-shadow:var(--shadow-sm)}
.ob-kicker{display:inline-flex;align-items:center;margin-bottom:10px;padding:4px 9px;border-radius:999px;background:var(--surface2);color:var(--green);font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase}
.ob-title{font-size:28px;font-weight:750;letter-spacing:-0.8px;margin-bottom:6px;line-height:1.12}
.ob-title span{color:var(--green)}
.ob-sub{font-size:14px;color:var(--muted);margin-bottom:0;line-height:1.5}
.ob-ft{padding:16px 20px max(20px,env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--surface)}
.ob-ft .btn-full[data-state="loading"]{opacity:0.88}
.ob-ft .btn-full[data-state="success"]{background:#16A34A}
.ob-ft .btn-full[data-state="success"]:disabled{opacity:1}
.ob-skip-btn{width:100%;margin-top:10px;padding:12px 14px;border:1px solid rgba(148,163,184,0.24);border-radius:16px;background:rgba(148,163,184,0.08);color:var(--muted);font:inherit;font-size:14px;font-weight:600;cursor:pointer}
.ob-skip-btn:active{opacity:0.85}
.ob-skip-btn:focus-visible{outline:2px solid rgba(14,165,233,0.28);outline-offset:2px}
.ob-status-message{margin:0 0 14px;padding:12px 14px;border-radius:16px;font-size:13px;line-height:1.5;border:1px solid rgba(14,165,233,0.18);background:rgba(14,165,233,0.08);color:var(--text)}
.ob-status-message.is-info{border-color:rgba(14,165,233,0.18);background:rgba(14,165,233,0.08)}
.ob-status-message.is-error{border-color:rgba(239,68,68,0.2);background:rgba(239,68,68,0.08)}
.ob-section-card{position:relative;margin-top:14px;padding:16px;border:1px solid var(--border);border-radius:22px;background:var(--surface);box-shadow:var(--shadow-sm);overflow:hidden}
.ob-section-card::before{content:'';position:absolute;left:0;right:0;top:0;height:3px;background:var(--green)}
.ob-section-card.expense::before{background:var(--red)}
.ob-section-card.savings::before{background:var(--amber)}
.ob-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.ob-section-eyebrow{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);margin-bottom:5px}
.ob-section-card.expense .ob-section-eyebrow{color:var(--red)}
.ob-section-card.savings .ob-section-eyebrow{color:var(--amber)}
.ob-section-title{margin:0;color:var(--text);font-size:18px;font-weight:700;letter-spacing:-0.35px}
.ob-section-copy{max-width:520px;margin:5px 0 0;color:var(--muted);font-size:12px;line-height:1.45}
.ob-insight{display:grid;grid-template-columns:1fr;gap:10px;min-width:148px;padding:12px;border-radius:16px;background:var(--green-light);border:1px solid rgba(14,165,233,0.2)}
.ob-insight.expense{background:rgba(244,63,94,0.07);border-color:rgba(244,63,94,0.18)}
.ob-insight.savings{background:rgba(245,158,11,0.08);border-color:rgba(245,158,11,0.2)}
.ob-insight-label{font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:2px}
.ob-insight-value{font-size:18px;font-weight:800;color:var(--value-positive);white-space:nowrap}
.ob-insight.expense .ob-insight-value{color:var(--red)}
.ob-insight.savings .ob-insight-value{color:var(--amber)}
.ob-insight-value.small{font-size:13px}
.ob-list{border-radius:16px;border:1px solid var(--border);background:linear-gradient(180deg,rgba(128,128,128,0.035),rgba(128,128,128,0));padding:0 12px}
.irow{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.irow:last-of-type{border-bottom:none}
.ob-money-row{align-items:flex-start}
.iico{font-size:22px;width:36px;height:36px;border-radius:12px;background:var(--surface2);display:flex;align-items:center;justify-content:center;text-align:center;flex-shrink:0}
.iinfo{flex:1;min-width:0}
.ihead{display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap}
.iname{flex:1 1 180px;min-width:0;font-size:13px;font-weight:500;line-height:1.3;white-space:normal;word-break:normal;overflow-wrap:break-word}
.ob-inline-trigger{padding:0;border:none;background:transparent;color:var(--text);font:inherit;font-size:13px;font-weight:500;line-height:1.3;text-align:left;cursor:text;word-break:break-word}
.ob-inline-trigger{display:block;width:100%;white-space:normal;word-break:normal;overflow-wrap:break-word}
.ob-inline-input{padding:10px 12px;font-size:14px}
.ob-row-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.ob-row-help{margin-top:5px;font-size:11px;color:var(--muted);line-height:1.35}
.irow .ch-edit{margin-top:-2px}
.irow .ch-edit.danger{color:var(--red);border-color:rgba(244,63,94,0.25)}
.iinput{width:112px;padding:11px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;font-weight:700;text-align:right;outline:none;font-family:inherit}
.iinput:focus{border-color:var(--green)}
.isuf{font-size:12px;color:var(--muted);flex-shrink:0}
.calc-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-top:16px}
.ob-calc-box{border-radius:22px;background:linear-gradient(180deg,rgba(14,165,233,0.08),rgba(14,165,233,0.02)),var(--surface)}
.calc-hd{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:14px}
.crow{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:8px}
.crow:last-child{margin-bottom:0}
.crow.tot{border-top:1px solid var(--border);padding-top:12px;margin-top:4px;font-size:15px;font-weight:600}
.cv{font-weight:600}
.cv.g{color:var(--value-positive)}
.cv.r{color:var(--red)}
.cv.savings{color:var(--amber)}
.ob-calc-note{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--muted);line-height:1.45}
.ob-daily-preview .ob-calc-note{margin-top:0;margin-bottom:12px;padding:0;border-top:none}
.ob-calc-note--prorata{margin-top:8px}
.ob-calc-note.is-positive{color:var(--value-positive)}
.ob-calc-note.is-negative{color:var(--red)}
.daily-result{margin-top:14px;padding:16px;background:var(--green-light);border-radius:18px;border:1px solid rgba(14,165,233,0.3);text-align:center}
.daily-result-lbl{font-size:11px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.08em}
.daily-result-val{font-size:38px;font-weight:700;color:var(--value-positive)}
.daily-result-sub{font-size:11px;color:var(--muted);margin-top:4px}
.add-line{display:flex;align-items:center;gap:8px;padding:12px 0;color:var(--green);font-size:13px;cursor:pointer;border-top:1px solid var(--border)}
.ob-add-line{width:100%;border-right:none;border-left:none;border-bottom:none;background:transparent;font-family:inherit;font-weight:700}
.cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-btn{width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:16px;color:var(--text);display:flex;align-items:center;justify-content:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;width:100%;box-sizing:border-box}
.cal-dow{font-size:10px;color:var(--muted);text-align:center;padding:4px 0;text-transform:uppercase}
.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;position:relative;border:1px solid transparent;overflow:hidden;min-width:0}
.cal-day:active{opacity:0.7}
.cal-day.today{border-color:var(--green)}
.cal-day.today .cal-num{color:var(--green);font-weight:600}
.cal-day.selected{background:transparent;border-color:var(--green);border-width:2px}
.cal-day.selected .cal-num{color:var(--green)!important;font-weight:700}
.cal-day.selected .cal-dot{background:var(--green)!important}
.cal-day.has-data .cal-dot{width:4px;height:4px;border-radius:50%;position:absolute;bottom:2px}
.cal-day.pos-day .cal-dot{background:var(--value-positive)}
.cal-day.neg-day .cal-dot{background:var(--red)}
.cal-day.empty{opacity:0.15;pointer-events:none}
.cal-num{font-size:13px;line-height:1;font-weight:500}
.cal-mini{font-size:12px;font-weight:600;line-height:1;max-width:100%;overflow:hidden;text-overflow:clip;margin-top:3px}
.cal-mini.is-positive{color:var(--value-positive)}
.cal-mini.is-negative{color:var(--red)}
.cal-mini.is-zero{color:var(--value-positive)}
.day-detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-top:10px}
.bars{display:flex;align-items:flex-end;gap:2px;height:80px;margin:8px 0}
.bar-w{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;height:100%}
.bar-inner{width:100%;display:flex;align-items:flex-end;height:70px}
.bar-seg{width:100%;border-radius:2px 2px 0 0}
.bar-lbl{font-size:8px;color:var(--muted)}
.stats-donut-card{padding:14px 16px}
.stats-category-detail-head{margin-top:12px;margin-bottom:6px}
.stats-donut-wrap{display:flex;align-items:center;gap:14px}
.stats-donut{width:78px;height:78px;border-radius:50%;flex-shrink:0;position:relative;background:var(--surface2)}
.stats-donut::after{content:'';position:absolute;inset:14px;border-radius:50%;background:var(--surface);border:1px solid var(--border)}
.stats-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1;text-align:center}
.stats-donut-value{font-size:12px;font-weight:700}
.stats-donut-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em}
.stats-donut-legend{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
.stats-donut-item{display:flex;align-items:center;gap:8px;font-size:12px}
.stats-donut-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.stats-donut-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stats-donut-share{font-weight:600;white-space:nowrap}
.stats-cat-meta{display:flex;align-items:center;gap:8px;margin-top:3px;font-size:11px;color:var(--muted)}
.stats-cat-pct{font-weight:600;color:var(--text)}
.stats-compare-explainer{padding:14px 16px;font-size:12px;color:var(--muted);line-height:1.55}
.stats-compare-explainer strong{color:var(--text);font-weight:600}
.stats-compare-note{font-size:11px;color:var(--muted);line-height:1.4}
.stats-meta-note{margin-bottom:6px;padding:10px 12px;border-radius:12px;font-size:12px;line-height:1.45;border:1px solid var(--border)}
.stats-meta-note.live{background:var(--green-light);color:var(--green);border-color:rgba(14,165,233,0.28)}
.stats-meta-note.archive{background:var(--surface2);color:var(--text)}
.stats-meta-time{margin-bottom:10px;font-size:11px;color:var(--muted)}
.stats-month-nav{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:10px;margin-bottom:12px}
.stats-month-label{text-align:center;font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stats-month-btn[disabled]{opacity:0.45;cursor:not-allowed}
.legal-disclaimer{margin:8px auto 0;padding:8px 10px;border-radius:14px;border:1px solid rgba(148,163,184,0.2);background:rgba(148,163,184,0.08);color:var(--muted);font-size:10.5px;line-height:1.4;text-align:center}
.legal-disclaimer--compact{margin-top:0;margin-bottom:8px}
.legal-disclaimer--onboarding{margin-top:14px;padding:12px 14px;border-radius:16px}
.stats-chart-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.stats-chart-copy{min-width:0}
.stats-chart-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.stats-chart-title{font-size:13px;font-weight:500}
.premium-title{position:relative;display:block;width:100%;padding-right:132px}
.premium-badge{
  display:inline-flex;
  align-items:center;
  gap:0;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(14,165,233,0.10);
  color:#0284c7;
  border:1px solid rgba(14,165,233,0.18);
  font-size:0;
  font-weight:700;
  line-height:1;
  white-space:nowrap;
  vertical-align:middle;
}
.premium-badge::after{content:'⭐ Premium';font-size:11px;line-height:1}
.premium-title>.premium-badge{
  position:absolute;
  top:0;
  right:0;
}
.kpi-lbl.premium-title{padding-right:122px}
.kpi-lbl .premium-badge{max-width:100%;font-size:10px;padding:3px 6px;letter-spacing:0;white-space:nowrap}
.today-premium-projection{margin-bottom:10px;padding:12px 15px;border:1px solid rgba(14,165,233,0.22);background:linear-gradient(180deg,rgba(14,165,233,0.08),rgba(16,185,129,0.04)),var(--surface)}
.today-premium-projection[data-action]{cursor:pointer}
.today-premium-projection[data-action]:active{transform:translateY(1px)}
.today-premium-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}
.today-premium-main{font-size:13px;font-weight:600;line-height:1.4;color:var(--text)}
.today-premium-sub{margin-top:5px;font-size:11px;line-height:1.45;color:var(--muted)}
.today-premium-meta{margin-top:8px;font-size:11px;color:var(--green);font-weight:700}
.today-premium-projection.is-negative{border-color:rgba(244,63,94,0.22);background:linear-gradient(180deg,rgba(244,63,94,0.07),rgba(14,165,233,0.03)),var(--surface)}
.today-premium-projection.is-negative .today-premium-meta{color:var(--red)}
.today-premium-projection.is-neutral .today-premium-meta{color:var(--muted)}
.stats-chart-sub{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.4}
.stats-mini-tabs{display:flex;gap:4px;flex-shrink:0;background:var(--surface2);border-radius:999px;padding:3px}
.stats-mini-tab{padding:6px 10px;border-radius:999px;font-size:11px;color:var(--muted);cursor:pointer;white-space:nowrap}
.stats-mini-tab.active{background:var(--surface);color:var(--text);font-weight:600}
.stats-toggle{position:relative;display:inline-flex;align-items:center;gap:8px;padding:7px 11px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:11px;cursor:pointer;font-family:inherit}
.stats-toggle strong{font-size:10px;letter-spacing:0.04em}
.stats-toggle.active{border-color:rgba(14,165,233,0.3);background:var(--green-light);color:var(--green)}
.stats-toggle .premium-badge{position:absolute;top:50%;right:8px;transform:translateY(-50%)}
.stats-chart-wrap{width:100%;overflow:hidden}
.stats-chart-svg{display:block;width:100%;height:auto}
.stats-chart-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.stats-chart-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.stats-chart-swatch{width:10px;height:10px;border-radius:50%}
.stats-chart-empty{padding:28px 0;text-align:center;color:var(--muted);font-size:13px}
.today-activation-card{position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:14px;padding:16px 18px;border-color:rgba(14,165,233,0.22);background:linear-gradient(180deg,rgba(14,165,233,0.08),rgba(14,165,233,0.04))}
.today-activation-copy{min-width:0;flex:1}
.today-activation-title{font-size:14px;font-weight:600;color:var(--text)}
.today-activation-text{margin-top:4px;font-size:12px;line-height:1.45;color:var(--muted)}
.today-activation-cta{flex-shrink:0;white-space:nowrap}
.today-activation-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border:none;border-radius:999px;background:transparent;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;font-family:inherit}
.today-activation-close:active{background:var(--surface2)}
.stats-period-cats{display:flex;flex-direction:column;gap:14px}
.stats-period-cats-grid{display:grid;grid-template-columns:minmax(0,1fr) 112px;gap:14px;align-items:center}
.stats-cat-list{display:flex;flex-direction:column;gap:10px}
.stats-cat-row{display:flex;align-items:center;gap:10px}
.stats-cat-bar-wrap{height:8px;background:var(--surface2);border-radius:999px;overflow:hidden;margin-top:6px}
.stats-cat-bar{height:100%;border-radius:999px}
.stats-cat-amt{font-size:12px;font-weight:600;white-space:nowrap}
#st-cats .tx-row{cursor:pointer}
#st-cats .tx-row:active{opacity:0.7}
.cat-det-month{font-size:13px;font-weight:400;color:var(--muted)}
.cat-det-total{font-size:13px;color:var(--muted);margin-bottom:16px}
.cat-det-list{display:flex;flex-direction:column;gap:10px}
.cat-det-day{background:var(--surface2);border-radius:10px;padding:10px 12px}
.cat-det-day-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.cat-det-day-lbl{font-size:13px;font-weight:600}
.cat-det-day-tot{font-size:13px;font-weight:700;color:var(--red)}
.cat-det-item{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:12px;border-top:1px solid var(--border)}
.cat-det-desc{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cat-det-amt{font-weight:600;color:var(--red);white-space:nowrap;margin-left:10px}
@media (max-width:560px){
  .legal-disclaimer{font-size:10px;padding:6px 9px;line-height:1.35}
.stats-period-cats-grid{grid-template-columns:1fr}
  .stats-chart-head{flex-direction:column;align-items:stretch}
  .stats-chart-actions{justify-content:flex-start}
  .stats-mini-tabs{align-self:flex-start}
  .stats-month-nav{grid-template-columns:40px minmax(0,1fr) 40px;gap:8px}
  .stats-month-label{font-size:13px}
  .premium-title{padding-right:128px}
  .premium-badge{padding:4px 7px}
  .premium-badge::after{font-size:10px}
  .kpi-lbl .premium-badge{padding:3px 5px}
  .kpi-lbl .premium-badge::after{font-size:9px}
  .premium-title>.premium-badge,
  .stats-toggle .premium-badge{
    width:24px;
    min-width:24px;
    justify-content:center;
    overflow:hidden;
    text-indent:-9999px;
    padding:4px 0;
    gap:0;
  }
  .premium-title>.premium-badge::after,
  .stats-toggle .premium-badge::after{
    content:'⭐';
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    text-indent:0;
    font-size:12px;
    line-height:1;
  }
  .stats-toggle{padding-right:11px}
  .today-premium-head{align-items:stretch;flex-direction:column}
  .today-premium-main{font-size:13px}
}
.premium-badge{
  gap:0;
  font-size:0;
}
.premium-badge::after{
  content:'⭐ Premium';
  font-size:11px;
  line-height:1;
}
@media (max-width:560px){
  .premium-title{padding-right:128px}
  .premium-badge{padding:4px 7px}
  .premium-badge::after{font-size:10px}
  .kpi-lbl .premium-badge{padding:3px 5px}
  .kpi-lbl .premium-badge::after{font-size:9px}
  .premium-title>.premium-badge,
  .stats-toggle .premium-badge{
    width:auto;
    min-width:0;
    overflow:visible;
    text-indent:0;
    padding:4px 7px;
    gap:0;
  }
  .premium-title>.premium-badge::after,
  .stats-toggle .premium-badge::after{
    content:'⭐ Premium';
    position:static;
    inset:auto;
    display:inline;
    text-indent:0;
    font-size:10px;
    line-height:1;
  }
  .stats-toggle{padding-right:11px}
}
.charge-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border)}
.charge-row:last-child{border-bottom:none}
.charge-row.is-terminated{opacity:0.58}
.ch-info{flex:1;min-width:0}
.ch-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ch-name{font-size:13px;white-space:normal;word-break:normal;overflow-wrap:break-word}
.ch-date{font-size:11px;color:var(--muted);margin-top:1px}
.charge-status-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:10px;font-weight:600;letter-spacing:0.02em;text-transform:uppercase}
.ch-amounts{display:flex;flex-direction:column;align-items:flex-end;gap:2px;min-width:0}
.ch-amt{font-size:14px;font-weight:600;margin-right:8px;white-space:nowrap}
.ch-amt.inc{color:var(--value-positive)}
.ch-amt.exp{color:var(--red)}
.ch-amt.savings{color:var(--amber)}
.ch-edit{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted)}
.ch-edit.danger{color:var(--red);border-color:rgba(244,63,94,0.25)}
.amount-secondary{margin-top:2px;font-size:11px;color:var(--muted);line-height:1.4;white-space:nowrap}
.srow{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}
.srow:last-child{border-bottom:none}
.settings-stack-row{padding:14px 0;border-bottom:1px solid var(--border)}
.sinfo{flex:1}
.sname{font-size:14px}
.sdesc{font-size:11px;color:var(--muted);margin-top:2px}
.sval{font-size:15px;font-weight:600;color:var(--value-positive);margin-right:10px}
.value-positive{color:var(--value-positive)!important}
.value-negative{color:var(--red)!important}
.sbtn{padding:7px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;cursor:pointer;font-size:12px;color:var(--text);font-family:inherit}
.sbtn:active{background:var(--surface2)}
.sbtn[disabled]{opacity:0.72;cursor:default}
.sbtn.danger{color:var(--red);border-color:rgba(226,75,74,0.3)}
.settings-inline-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.settings-input-row{display:flex;align-items:center;gap:10px;margin-top:12px}
.settings-inline-input{max-width:180px}
.settings-inline-note{font-size:11px;color:var(--muted);margin-top:8px;line-height:1.45}
.settings-first-month-card{padding:14px 0;border-bottom:1px solid var(--border)}
.settings-first-month-card.hidden{display:none}
.settings-first-month-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.settings-first-month-current{font-size:12px;color:var(--text);font-weight:600}
.settings-profile-card{display:flex;align-items:center;gap:14px;padding:16px!important;margin-bottom:20px!important}
.settings-profile-avatar{width:46px;height:46px;border-radius:50%;background:var(--green);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}
.settings-profile-info{flex:1;min-width:0}
.settings-profile-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.settings-profile-email{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.settings-profile-actions{display:flex;gap:8px;flex-shrink:0}
.settings-section-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.07em;margin:20px 0 6px 4px}
.settings-section-title:first-of-type{margin-top:0}
.settings-danger-zone{margin-top:4px;padding:16px;border:1px solid rgba(226,75,74,0.16);border-radius:18px;background:linear-gradient(180deg,rgba(226,75,74,0.05),rgba(255,255,255,0))}
.settings-danger-zone-head{font-size:13px;font-weight:700;color:var(--text);letter-spacing:0.02em}
.settings-danger-zone-text{margin-top:6px;font-size:12px;line-height:1.55;color:var(--muted)}
.settings-danger-zone-btn{margin-top:14px;color:#b42318;border-color:rgba(226,75,74,0.24);background:rgba(226,75,74,0.08)}
.settings-danger-zone-btn:active{background:rgba(226,75,74,0.12)}
.sum-subtle{font-size:11px;color:var(--muted);line-height:1.5;margin-top:6px}
.budget-calc-summary{margin-top:12px}
.budget-calc-details{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.budget-calc-details .crow{margin-bottom:0}
.budget-calc-result{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.month-end-minimum-card{margin-top:14px;padding:16px}
.month-end-minimum-title{font-size:14px;font-weight:600;color:var(--text)}
.month-end-minimum-help{font-size:12px;color:var(--muted);line-height:1.5;margin-top:6px}
.month-end-minimum-list{margin-top:12px}
.month-end-minimum-input-row{display:flex;align-items:center;gap:10px;margin-top:12px}
.month-end-minimum-suffix{font-size:12px;color:var(--muted);white-space:nowrap}
.ob-start-card{margin-top:14px;padding:16px;border-radius:22px}
.ob-start-options{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.ob-start-option{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text);font:inherit;font-size:13px;font-weight:600;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:6px}
.ob-start-option.active{border-color:rgba(14,165,233,0.32);background:var(--green-light);color:var(--green)}
.ob-start-option-title{display:block;font-size:13px;font-weight:700;color:inherit}
.ob-start-option-text{display:block;font-size:11px;font-weight:400;line-height:1.45;color:var(--muted)}
.ob-start-option.active .ob-start-option-text{color:var(--text)}
.today-start-date-note{margin-top:12px;padding:12px 14px;font-size:12px;line-height:1.5;color:var(--muted);border-color:rgba(14,165,233,0.18);background:rgba(14,165,233,0.05)}
.today-setup-reminder{margin-bottom:12px;padding:14px 15px;border-radius:18px;border:1px solid rgba(14,165,233,0.16);background:linear-gradient(180deg,rgba(240,249,255,0.96),rgba(255,255,255,0.98))}
.today-setup-reminder-title{font-size:14px;font-weight:700;color:var(--text)}
.today-setup-reminder-text{margin-top:6px;font-size:12px;line-height:1.55;color:var(--muted)}
.today-setup-reminder-btn{margin-top:12px}
.today-empty-state{margin-bottom:12px;padding:16px 15px;border-radius:20px;border:1px dashed rgba(148,163,184,0.32);background:rgba(255,255,255,0.72)}
.today-empty-state-title{font-size:15px;font-weight:700;color:var(--text)}
.today-empty-state-text{margin-top:6px;font-size:12px;line-height:1.55;color:var(--muted)}
.today-reset-forecast{font-size:17px;line-height:1.25;white-space:normal}
.today-reset-forecast-sub{font-size:11px;line-height:1.4;color:var(--muted)}
.onboarding-amount-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.onboarding-amount-main{display:flex;align-items:center;gap:8px}
.onboarding-amount-secondary{display:inline-flex;align-self:flex-end;max-width:190px;padding:4px 8px;border-radius:999px;background:rgba(128,128,128,0.07);color:var(--muted);font-size:11px;line-height:1.35;text-align:right;white-space:normal}
.settings-category-toolbar{display:flex;align-items:center;gap:10px;margin-top:12px}
.settings-categories-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.settings-category-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}
.settings-category-row.inactive{opacity:0.72}
.settings-category-main{display:flex;align-items:flex-start;gap:10px;min-width:0;flex:1}
.settings-category-icon{width:34px;height:34px;border-radius:10px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.category-icon-button{border:1px solid var(--border);cursor:pointer;font-family:inherit}
.settings-category-copy{min-width:0;flex:1}
.settings-category-name{font-size:13px;font-weight:600;color:var(--text)}
.settings-category-meta{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.4}
.settings-category-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.category-emoji-input{max-width:72px;text-align:center;font-size:18px}
.category-modal-card{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:520px;border:1px solid var(--border);box-shadow:var(--shadow-lg)}
.category-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 0}
.category-modal-title{font-size:15px;font-weight:600;color:var(--text)}
.category-modal-sub{margin-top:4px;font-size:12px;color:var(--muted);line-height:1.45}
.category-modal-close{border:none;background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit}
.category-modal-body{padding:18px}
.category-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.category-emoji-picker{position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px;box-shadow:var(--shadow-lg)}
.category-emoji-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}
.category-emoji-btn{height:42px;border-radius:12px;border:1px solid var(--border);background:var(--surface2);cursor:pointer;font-size:22px;font-family:inherit}
.switch{position:relative;display:inline-flex;width:48px;height:28px;cursor:pointer}
.switch input{opacity:0;width:0;height:0}
.switch-slider{position:absolute;inset:0;border-radius:999px;background:var(--surface2);border:1px solid var(--border);transition:all .2s ease}
.switch-slider::before{content:'';position:absolute;width:20px;height:20px;left:3px;top:3px;border-radius:50%;background:var(--surface);box-shadow:var(--shadow-sm);transition:transform .2s ease}
.switch input:checked + .switch-slider{background:var(--green-light);border-color:rgba(14,165,233,0.28)}
.switch input:checked + .switch-slider::before{transform:translateX(20px);background:var(--green)}
.income-modal{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:950;display:none;align-items:flex-end;justify-content:center;padding:16px}
.income-modal-card{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-lg);overflow:hidden}
.income-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px}
.income-modal-title{font-size:15px;font-weight:600;color:var(--text)}
.income-modal-sub{margin-top:4px;font-size:12px;color:var(--muted)}
.income-modal-close{border:none;background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit}
.income-modal-body{padding:0 18px 18px}
.income-modal-question{font-size:14px;font-weight:500;color:var(--text);margin-bottom:14px}
.income-modal-helper{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:14px}
.income-modal-actions{display:flex;justify-content:flex-end;gap:10px}
.notif-prefs-modal{position:fixed;inset:0;background:rgba(15,23,42,0.56);z-index:960;display:none;align-items:flex-end;justify-content:center;padding:16px}
.notif-prefs-modal.is-open{display:flex}
.notif-prefs-modal-card{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden;max-height:92vh;overflow-y:auto}
.notif-prefs-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px}
.notif-prefs-modal-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-0.02em}
.notif-prefs-modal-sub{margin-top:4px;font-size:12px;color:var(--muted)}
.notif-prefs-modal-close{border:none;background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit}
.notif-prefs-modal-body{padding:0 18px 18px}
.notif-prefs-master{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:4px}
.notif-prefs-master-label{font-size:14px;font-weight:600;color:var(--text)}
.notif-pref-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid rgba(148,163,184,0.10)}
.notif-pref-row:last-child{border-bottom:none}
.notif-pref-info{flex:1;min-width:0}
.notif-pref-icon{font-size:15px;margin-right:6px}
.notif-pref-name{font-size:13px;font-weight:500;color:var(--text)}
.notif-pref-desc{font-size:11px;color:var(--muted);line-height:1.4;margin-top:2px}
.notif-prefs-modal-actions{margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.delete-account-modal{position:fixed;inset:0;background:rgba(15,23,42,0.56);z-index:960;display:none;align-items:flex-end;justify-content:center;padding:16px}
.delete-account-modal.is-open{display:flex}
.delete-account-modal-card{width:100%;max-width:460px;background:var(--surface);border:1px solid rgba(226,75,74,0.18);border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden}
.delete-account-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px}
.delete-account-modal-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-0.02em}
.delete-account-modal-close{border:none;background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit}
.delete-account-modal-body{padding:0 18px 18px}
.delete-account-modal-text{font-size:13px;line-height:1.55;color:var(--text);margin-bottom:16px}
.delete-account-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.delete-account-confirm-btn{background:#d94b46;border-color:#d94b46;min-width:210px}
.delete-account-confirm-btn[disabled]{opacity:0.58;background:#d94b46;border-color:#d94b46;color:#fff}
.changelog-modal{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:940;display:none;align-items:flex-end;justify-content:center;padding:16px}
.changelog-modal-card{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden}
.changelog-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px}
.changelog-modal-kicker{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--green);margin-bottom:6px}
.changelog-modal-version{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase}
.changelog-modal-title{margin-top:6px;font-size:18px;line-height:1.3;color:var(--text)}
.changelog-modal-close{border:none;background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit}
.changelog-modal-body{padding:0 18px 18px}
.changelog-modal-list{margin:0;padding-left:18px;color:var(--text)}
.changelog-modal-list li{font-size:13px;line-height:1.6}
.changelog-modal-list li+li{margin-top:6px}
.changelog-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.changelog-modal-close:hover{color:var(--text)}
.changelog-modal-entries{display:none;padding:4px 0}
.changelog-modal-card.history{max-height:86vh;display:flex;flex-direction:column}
.changelog-modal-card.history .changelog-modal-head{border-bottom:1px solid var(--border);padding-bottom:16px}
.changelog-modal-card.history .changelog-modal-body{flex:1;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch}
.changelog-modal-entries .changelog-entry+.changelog-entry{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.changelog-modal-entries .changelog-entry-title{color:var(--text);font-size:16px}
.changelog-modal-entries .changelog-entry-version{color:var(--muted);background:rgba(128,128,128,0.08);border:none}
.changelog-modal-entries .changelog-entry-list{color:var(--muted)}
.changelog-modal-entries .changelog-entry-list li{font-size:13px}
.changelog-modal-entries .changelog-entry-badge{color:var(--green);background:rgba(16,185,129,0.08);border-color:rgba(16,185,129,0.14)}
@media(min-width:641px){
  .changelog-modal.history{align-items:center;padding:20px}
  .changelog-modal-card.history{border-radius:24px}
}
@media(max-width:640px){
  .ob-hd{padding:16px 16px 0}
  .ob-prog{margin:14px 16px 0}
  .ob-body{padding:18px 16px}
  .ob-hero{padding:16px;border-radius:20px}
  .ob-title{font-size:25px}
  .ob-section-card{padding:14px;border-radius:20px}
  .ob-section-head{flex-direction:column}
  .ob-insight{width:100%;box-sizing:border-box;grid-template-columns:1fr 1fr}
  .ob-list{padding:0 10px}
  .irow{align-items:flex-start;flex-wrap:wrap}
  .iinfo{min-width:calc(100% - 46px);width:calc(100% - 46px)}
  .ihead{width:100%}
  .ob-row-actions{width:100%;justify-content:flex-start}
  .ob-inline-input{width:100%}
  .onboarding-amount-wrap{width:calc(100% - 46px);margin-left:46px;align-items:stretch}
  .onboarding-amount-main{width:100%}
  .iinput{width:100%;margin-left:0}
  .isuf{margin-left:auto}
  .onboarding-amount-secondary{align-self:flex-start;max-width:none;text-align:left}
  .settings-inline-actions{align-items:flex-end}
  .settings-first-month-actions{align-items:stretch;flex-direction:column}
  .settings-input-row{align-items:stretch;flex-direction:column}
  .settings-inline-input{max-width:none}
  .settings-danger-zone{padding:15px}
  .budget-calc-result{align-items:flex-start;flex-direction:column}
  .month-end-minimum-input-row{align-items:stretch;flex-direction:column}
  .settings-category-toolbar{align-items:stretch;flex-direction:column}
  .settings-category-row{flex-direction:column}
  .settings-category-actions{justify-content:flex-start}
  .category-modal-actions{flex-direction:column}
  .category-emoji-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .income-modal{padding:0}
  .income-modal-card{max-width:none;border-radius:20px 20px 0 0}
  .delete-account-modal{padding:0}
  .delete-account-modal-card{max-width:none;border-radius:22px 22px 0 0}
  .notif-prefs-modal{padding:0}
  .notif-prefs-modal-card{max-width:none;border-radius:22px 22px 0 0}
  .delete-account-modal-actions{flex-direction:column}
  .delete-account-confirm-btn{min-width:0}
  .changelog-modal{padding:0}
  .changelog-modal-card{max-width:none;border-radius:20px 20px 0 0}
  .changelog-modal-card.history{max-height:88vh;border-radius:20px 20px 0 0}
  .changelog-modal-actions{flex-direction:column}
  .today-activation-card{align-items:flex-start;flex-direction:column;padding-right:46px}
  .today-activation-cta{width:100%}
}
