/* ── app.css ──────────────────────────────────────────────────────────────────
 * Tidl — Irregular Income Manager
 * All application styles in one file.
 *
 * Structure:
 *   1. Reset + CSS custom properties (design tokens)
 *   2. App shell (layout, header, tab bar, scroll)
 *   3. Auth screen
 *   4. Screens + cards + hero
 *   5. Form elements (fields, pills, submit buttons)
 *   6. Feature-specific (tax, smoothing, volunteer, EI, expenses, mileage)
 *   7. Modals (pricing, onboarding, PWA)
 *   8. Utilities (skeleton, delete button)
 *
 * Design tokens are in :root — change a colour or font once here,
 * it propagates everywhere. Never hardcode colour values in components.
 * ─────────────────────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --cream:#f5f0e8; --cream-dark:#ede6d6; --cream-mid:#f0ead8;
  --ink:#1a1710; --ink-mid:#3d3928; --ink-muted:#7a7460; --ink-faint:#b8b09a;
  --forest:#2d4a3e; --forest-light:#3d6b5a; --forest-pale:#e8f0ec;
  --amber:#c4720a; --amber-light:#fdf3e0;
  --red:#b84040; --red-light:#fdf0f0;
  --gold:#c4a832; --gold-light:#fdf8e0;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',sans-serif; --mono:'DM Mono',monospace;
  --safe-top:env(safe-area-inset-top,0px); --safe-bot:env(safe-area-inset-bottom,0px);
}
html,body{height:100%;background:var(--cream);color:var(--ink);font-family:var(--sans);overflow:hidden}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.6}

.app{position:fixed;inset:0;display:flex;flex-direction:column;z-index:1}

/* ── AUTH SCREEN ── */
.auth-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:32px;text-align:center}
.auth-logo{font-family:var(--serif);font-size:48px;font-weight:900;font-style:italic;color:var(--forest);margin-bottom:8px}
.auth-tagline{font-size:14px;color:var(--ink-muted);margin-bottom:40px;line-height:1.5}
.auth-form{width:100%;max-width:340px}
.auth-field{margin-bottom:12px}
.auth-input{width:100%;padding:13px 16px;border:1.5px solid var(--cream-dark);border-radius:12px;font-size:16px;font-family:var(--sans);background:white;color:var(--ink);outline:none;transition:border-color .15s}
.auth-input:focus{border-color:var(--forest)}
.auth-btn{width:100%;padding:14px;background:var(--forest);color:white;border:none;border-radius:12px;font-family:var(--serif);font-size:18px;font-weight:700;font-style:italic;cursor:pointer;margin-top:4px;transition:background .15s}
.auth-btn:active{background:var(--forest-light)}
.auth-switch{margin-top:16px;font-size:13px;color:var(--ink-muted);cursor:pointer}
.auth-switch span{color:var(--forest);font-weight:500;text-decoration:underline}
.auth-error{font-size:12px;color:var(--red);margin-top:8px;font-family:var(--mono)}
.tip-card{background:white;border:1px solid var(--cream-dark);border-radius:14px;padding:16px 18px;margin-top:28px;max-width:340px;text-align:left;box-shadow:0 1px 3px rgba(26,23,16,.06);position:relative}
.tip-label{font-family:var(--mono);font-size:9px;color:var(--forest);text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.tip-label::before{content:'◆';font-size:7px}
.tip-text{font-size:13px;color:var(--ink-mid);line-height:1.6}
.tip-text strong{color:var(--ink);font-weight:600}
.tip-nav{display:flex;justify-content:space-between;align-items:center;margin-top:10px}
.tip-dots{display:flex;gap:4px}
.tip-dot{width:5px;height:5px;border-radius:50%;background:var(--cream-dark);transition:background .2s}
.tip-dot.active{background:var(--forest)}
.tip-next{font-family:var(--mono);font-size:9px;color:var(--forest);cursor:pointer;text-decoration:underline;letter-spacing:.04em}

/* ── HEADER ── */
.header{flex-shrink:0;background:var(--cream);border-bottom:1px solid var(--cream-dark);padding:calc(var(--safe-top) + 12px) 20px 12px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--forest);letter-spacing:-.02em;display:flex;align-items:baseline;gap:3px}
.logo-dot{width:6px;height:6px;border-radius:50%;background:var(--amber);margin-bottom:3px;flex-shrink:0;animation:breathe 3s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}
.logo-sub{font-family:var(--mono);font-size:9px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;margin-left:4px}
.header-right{display:flex;align-items:center;gap:12px}
.header-date{font-family:var(--mono);font-size:10px;color:var(--ink-muted);display:none}
@media(min-width:480px){.header-date{display:block}}
.plan-badge{font-family:var(--mono);font-size:9px;padding:3px 8px;border-radius:20px;cursor:pointer}
.plan-free{background:var(--cream-dark);color:var(--ink-muted)}
.plan-pro{background:var(--gold-light);color:var(--gold)}
.plan-biz{background:#eff6ff;color:#1e40af}
.signout-btn{font-family:var(--mono);font-size:9px;color:var(--ink-muted);background:none;border:1px solid var(--cream-dark);border-radius:8px;cursor:pointer;padding:6px 10px;min-height:36px;min-width:44px;-webkit-tap-highlight-color:transparent;transition:all .15s}
.signout-btn:hover{background:var(--cream-dark);color:var(--ink)}

/* ── TAB BAR — restructured with overflow scroll ── */
.tab-bar{flex-shrink:0;background:var(--cream);border-bottom:1px solid var(--cream-dark);display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tab-bar::-webkit-scrollbar{display:none}
.tab{flex-shrink:0;min-width:60px;padding:10px 8px 8px;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;-webkit-tap-highlight-color:transparent}
.tab.active{border-bottom-color:var(--forest)}
.tab-icon{font-size:17px}
.tab-label{font-family:var(--mono);font-size:8px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;transition:color .2s;white-space:nowrap}
.tab.active .tab-label{color:var(--forest)}

/* ── SCROLL ── */
.scroll{flex:1;overflow-y:scroll;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{width:10px}
.scroll::-webkit-scrollbar-track{background:var(--cream-dark);border-radius:5px}
.scroll::-webkit-scrollbar-thumb{background:var(--ink-muted);border-radius:5px}
.scroll::-webkit-scrollbar-thumb:hover{background:var(--ink-mid)}
.auth-screen{overflow-y:auto}
.auth-screen::-webkit-scrollbar{width:5px}
.auth-screen::-webkit-scrollbar-track{background:var(--cream)}
.auth-screen::-webkit-scrollbar-thumb{background:var(--ink-faint);border-radius:3px}

/* ── SCREENS ── */
.screen{display:none;padding:20px 16px calc(var(--safe-bot) + 24px);max-width:560px;margin:0 auto}
.screen.active{display:block}

/* ── LABELS ── */
.section-label{font-family:var(--mono);font-size:9px;font-weight:500;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.section-label::after{content:'';flex:1;height:1px;background:var(--cream-dark)}

/* ── CARDS ── */
.card{background:white;border:1px solid var(--cream-dark);border-radius:14px;overflow:hidden;margin-bottom:12px;box-shadow:0 1px 3px rgba(26,23,16,.06)}
.card-head{padding:12px 16px;border-bottom:1px solid var(--cream-dark);display:flex;align-items:center;justify-content:space-between}
.card-title{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--ink)}
.cbadge{font-family:var(--mono);font-size:9px;padding:3px 8px;border-radius:20px;font-weight:500}
.cb-forest{background:var(--forest-pale);color:var(--forest)}
.cb-amber{background:var(--amber-light);color:var(--amber)}
.cb-red{background:var(--red-light);color:var(--red)}
.cb-gold{background:var(--gold-light);color:var(--gold)}

/* ── HERO ── */
.hero-card{background:var(--forest);border-radius:18px;padding:24px 20px 20px;margin-bottom:16px;position:relative;overflow:hidden}
.hero-card::before{content:'';position:absolute;top:-40px;right:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.04)}
.hero-card::after{content:'';position:absolute;bottom:-20px;left:-20px;width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,.03)}
.hero-label{font-family:var(--mono);font-size:9px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}
.hero-amount{font-family:var(--serif);font-size:52px;font-weight:900;font-style:italic;color:white;line-height:1;letter-spacing:-.02em;margin-bottom:4px}
.hero-sub{font-size:12px;color:rgba(255,255,255,.6);margin-bottom:20px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;position:relative;z-index:1}
.hero-stat-label{font-family:var(--mono);font-size:8px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.hero-stat-val{font-family:var(--serif);font-size:18px;font-weight:700;color:white;letter-spacing:-.02em}
.hero-stat-sub{font-size:10px;color:rgba(255,255,255,.5)}

/* ── BUFFER ── */
.buffer-wrap{padding:14px 16px}
.buffer-labels{display:flex;justify-content:space-between;margin-bottom:6px}
.buffer-label{color:var(--ink-muted);font-family:var(--mono);font-size:9px}
.buffer-val{color:var(--ink);font-weight:500;font-family:var(--mono);font-size:11px}
.buffer-track{height:8px;background:var(--cream-dark);border-radius:4px;overflow:hidden;margin-bottom:8px}
.buffer-fill{height:100%;border-radius:4px;transition:width .6s ease;background:var(--forest)}
.buffer-fill.warn{background:var(--amber)}
.buffer-fill.danger{background:var(--red)}
.buffer-note{font-size:11px;color:var(--ink-muted)}

/* ── INCOME ITEMS ── */
.income-item{padding:11px 16px;border-bottom:1px solid var(--cream-dark);display:flex;align-items:center;gap:12px}
.income-item:last-child{border-bottom:none}
.income-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.income-info{flex:1;min-width:0}
.income-source{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.income-meta{font-size:10px;color:var(--ink-muted);margin-top:1px;font-family:var(--mono)}
.income-amount{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--forest);white-space:nowrap}
.income-type-badge{font-family:var(--mono);font-size:8px;padding:2px 6px;border-radius:4px;margin-left:4px}
.t4{background:#e8f0ec;color:var(--forest)}
.inv{background:var(--amber-light);color:var(--amber)}
.side{background:#f0ecf8;color:#6b4c9e}

/* ── LOG FORM ── */
.log-form{padding:16px}
.field{margin-bottom:14px}
.field-label{font-family:var(--mono);font-size:9px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px;display:block}
.field input,.field select{width:100%;background:var(--cream);border:1.5px solid var(--cream-dark);border-radius:10px;padding:11px 14px;font-size:15px;font-family:var(--sans);color:var(--ink);outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none}
.field input:focus,.field select:focus{border-color:var(--forest);background:white}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.amount-wrap{position:relative}
.amount-prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-family:var(--serif);font-size:18px;color:var(--ink-muted);pointer-events:none}
.amount-wrap input{padding-left:28px;font-family:var(--serif);font-size:22px;font-weight:700}
.type-pills{display:flex;gap:8px}
.type-pill{flex:1;padding:10px 8px;border-radius:10px;text-align:center;font-family:var(--mono);font-size:10px;cursor:pointer;border:1.5px solid var(--cream-dark);background:var(--cream);color:var(--ink-muted);transition:all .15s;-webkit-tap-highlight-color:transparent}
.type-pill.active{border-color:var(--forest);background:var(--forest-pale);color:var(--forest);font-weight:500}
.submit-btn{width:100%;background:var(--forest);color:white;border:none;padding:15px;border-radius:12px;font-family:var(--serif);font-size:17px;font-weight:700;font-style:italic;cursor:pointer;margin-top:4px;transition:background .15s;-webkit-tap-highlight-color:transparent}
.submit-btn:active{background:var(--forest-light)}
.submit-btn:disabled{background:var(--ink-faint);cursor:not-allowed}
.success-flash{display:none;text-align:center;padding:20px}
.success-flash-icon{font-size:36px;margin-bottom:8px}
.success-flash-text{font-family:var(--serif);font-size:18px;font-weight:700;font-style:italic;color:var(--forest)}

/* ── TAX ── */
.tax-province-row{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--cream-dark);overflow-x:auto}
.prov-chip{flex-shrink:0;padding:5px 12px;border-radius:20px;font-family:var(--mono);font-size:10px;cursor:pointer;border:1px solid var(--cream-dark);background:var(--cream);color:var(--ink-muted);transition:all .15s;-webkit-tap-highlight-color:transparent}
.prov-chip.active{background:var(--forest);color:white;border-color:var(--forest)}
.tax-breakdown{padding:14px 16px}
.tax-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--cream-dark)}
.tax-row:last-child{border-bottom:none}
.tax-name{font-size:12px;color:var(--ink-mid)}
.tax-rate{font-family:var(--mono);font-size:10px;color:var(--ink-muted)}
.tax-amount{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--red)}
.tax-total-row{padding:14px 16px;border-top:2px solid var(--cream-dark);display:flex;justify-content:space-between;align-items:center}
.tax-total-label{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--ink)}
.tax-total-amount{font-family:var(--serif);font-size:24px;font-weight:900;font-style:italic;color:var(--red)}
.tax-note{padding:10px 16px;font-size:10px;color:var(--ink-faint);font-family:var(--mono);line-height:1.5}

/* ── CHART ── */
.chart-wrap{padding:16px}
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:120px;margin-bottom:8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar{width:100%;border-radius:5px 5px 0 0;transition:height .5s ease;min-height:3px}
.bar.t4-bar{background:var(--forest)}
.bar.inv-bar{background:var(--amber)}
.bar.side-bar{background:#9b79c8}
.bar-label{font-family:var(--mono);font-size:8px;color:var(--ink-faint);text-align:center}
.chart-legend{display:flex;gap:14px;justify-content:center;margin-top:8px}
.leg{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--ink-muted)}
.leg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* ── SMOOTH ── */
.smooth-stat{padding:12px 16px;border-bottom:1px solid var(--cream-dark);display:flex;justify-content:space-between;align-items:center}
.smooth-stat:last-child{border-bottom:none}
.smooth-label{font-size:12px;color:var(--ink-mid)}
.smooth-val{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--ink)}
.smooth-sub{font-family:var(--mono);font-size:9px;color:var(--ink-faint);margin-top:1px}
.alert-bar{background:var(--amber-light);border-left:3px solid var(--amber);padding:10px 14px;margin:12px 0;border-radius:0 8px 8px 0}
.alert-bar-text{font-size:12px;color:var(--amber);font-weight:500}
.alert-bar-sub{font-size:10px;color:var(--ink-muted);margin-top:2px}

/* ── SOURCES ── */
.source-row{padding:10px 16px;border-bottom:1px solid var(--cream-dark);display:flex;align-items:center;gap:12px}
.source-row:last-child{border-bottom:none}
.source-bar-wrap{flex:1}
.source-name{font-size:12px;font-weight:500;color:var(--ink);margin-bottom:4px}
.source-track{height:5px;background:var(--cream-dark);border-radius:3px;overflow:hidden}
.source-fill{height:100%;border-radius:3px;background:var(--forest)}
.source-amount{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--forest);white-space:nowrap}
.source-pct{font-family:var(--mono);font-size:9px;color:var(--ink-faint);text-align:right}

/* ── PRICING MODAL ── */
.pricing-overlay{display:none;position:fixed;inset:0;background:rgba(26,23,16,.7);z-index:9999;align-items:flex-end;justify-content:center;overflow-y:auto}
.pricing-overlay.show{display:flex}
.pricing-sheet{background:var(--cream);border-radius:24px 24px 0 0;width:100%;max-width:560px;padding:28px 20px calc(var(--safe-bot)+28px);max-height:95vh;overflow-y:auto}
.pricing-header{text-align:center;margin-bottom:20px}
.pricing-title{font-family:var(--serif);font-size:28px;font-weight:900;font-style:italic;color:var(--forest);margin-bottom:4px}
.pricing-sub{font-size:13px;color:var(--ink-muted);line-height:1.5}
.pricing-toggle{display:flex;align-items:center;justify-content:center;gap:10px;margin:16px 0}
.pricing-toggle-label{font-family:var(--mono);font-size:10px;color:var(--ink-muted)}
.pricing-toggle-label.active{color:var(--forest);font-weight:500}
.pricing-save{background:var(--forest-pale);color:var(--forest);font-family:var(--mono);font-size:9px;padding:2px 8px;border-radius:20px;margin-left:4px}
.pricing-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.pricing-card{background:white;border:1.5px solid var(--cream-dark);border-radius:16px;padding:18px 16px;transition:border-color .2s}
.pricing-card.featured{border-color:var(--forest);box-shadow:0 2px 12px rgba(45,74,62,.15)}
.pricing-card.featured-biz{border-color:#1e40af;box-shadow:0 2px 12px rgba(30,64,175,.12)}
.pricing-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.pricing-card-name{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--ink)}
.pricing-card-badge{font-family:var(--mono);font-size:9px;padding:3px 8px;border-radius:20px}
.pricing-card-price{margin-bottom:12px}
.pricing-card-amount{font-family:var(--serif);font-size:32px;font-weight:900;font-style:italic;color:var(--forest)}
.pricing-card-amount.biz-price{color:#1e40af}
.pricing-card-period{font-size:12px;color:var(--ink-muted);font-family:var(--sans)}
.pricing-card-annual{font-family:var(--mono);font-size:9px;color:var(--ink-faint);display:block;margin-top:2px}
.pricing-features{list-style:none;margin-bottom:16px}
.pricing-features li{display:flex;align-items:flex-start;gap:8px;padding:4px 0;font-size:12px;color:var(--ink-mid);line-height:1.4}
.pricing-features li .check{color:var(--forest);font-weight:700;font-size:13px;flex-shrink:0}
.pricing-features li .check.biz{color:#1e40af}
.pricing-features li .dash{color:var(--ink-faint);flex-shrink:0}
.pricing-cta{width:100%;padding:13px;border:none;border-radius:12px;font-family:var(--serif);font-size:16px;font-weight:700;font-style:italic;cursor:pointer;transition:all .15s}
.pricing-cta-free{background:var(--cream-dark);color:var(--ink-muted)}
.pricing-cta-pro{background:var(--forest);color:white}
.pricing-cta-biz{background:#1e40af;color:white}
.pricing-dismiss{width:100%;background:none;border:none;color:var(--ink-faint);font-size:12px;cursor:pointer;padding:10px;margin-top:8px}
.pro-gate{padding:24px 16px;text-align:center}
.pro-gate-icon{font-size:32px;margin-bottom:12px}
.pro-gate-title{font-family:var(--serif);font-size:20px;font-weight:700;font-style:italic;color:var(--ink);margin-bottom:8px}
.pro-gate-sub{font-size:13px;color:var(--ink-muted);margin-bottom:20px;line-height:1.5}
.pro-upgrade-btn{display:inline-block;background:var(--gold);color:white;border:none;padding:13px 28px;border-radius:12px;font-family:var(--serif);font-size:16px;font-weight:700;font-style:italic;cursor:pointer;transition:background .15s}

/* ── EXPORT ── */
.export-btn{width:100%;background:white;color:var(--forest);border:1.5px solid var(--forest);padding:13px;border-radius:12px;font-family:var(--serif);font-size:16px;font-weight:700;font-style:italic;cursor:pointer;margin-bottom:10px;transition:all .15s}
.export-btn:active{background:var(--forest-pale)}

/* ── LOADING ── */
.loading-overlay{display:none;position:fixed;inset:0;background:var(--cream);z-index:999;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.loading-overlay.show{display:flex}
.loading-logo{font-family:var(--serif);font-size:36px;font-weight:900;font-style:italic;color:var(--forest)}
.loading-sub{font-family:var(--mono);font-size:11px;color:var(--ink-faint);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── ONBOARDING MODAL ── */
.onboard-overlay{display:none;position:fixed;inset:0;background:rgba(26,23,16,.7);z-index:9998;align-items:flex-end;justify-content:center}
.onboard-overlay.show{display:flex}
.onboard-sheet{background:var(--cream);border-radius:24px 24px 0 0;width:100%;max-width:480px;padding:32px 24px calc(var(--safe-bot) + 32px);max-height:90vh;overflow-y:auto}
.onboard-step{display:none}.onboard-step.active{display:block}
.onboard-progress{display:flex;gap:6px;margin-bottom:24px;justify-content:center}
.onboard-dot{width:8px;height:8px;border-radius:50%;background:var(--cream-dark);transition:background .3s}
.onboard-dot.active{background:var(--forest)}
.onboard-icon{font-size:40px;text-align:center;margin-bottom:12px}
.onboard-title{font-family:var(--serif);font-size:26px;font-weight:900;font-style:italic;color:var(--forest);text-align:center;margin-bottom:8px}
.onboard-sub{font-size:13px;color:var(--ink-muted);text-align:center;line-height:1.6;margin-bottom:24px}
.onboard-options{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.onboard-option{padding:14px 10px;border-radius:12px;border:1.5px solid var(--cream-dark);background:white;text-align:center;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.onboard-option.active{border-color:var(--forest);background:var(--forest-pale)}
.onboard-option-icon{font-size:22px;margin-bottom:6px}
.onboard-option-label{font-size:12px;font-weight:500;color:var(--ink)}
.onboard-option-sub{font-size:10px;color:var(--ink-muted);margin-top:2px;font-family:var(--mono)}
.onboard-next{width:100%;background:var(--forest);color:white;border:none;padding:15px;border-radius:12px;font-family:var(--serif);font-size:17px;font-weight:700;font-style:italic;cursor:pointer;transition:background .15s}
.onboard-skip{width:100%;background:none;border:none;color:var(--ink-faint);font-size:12px;cursor:pointer;padding:10px;margin-top:4px}

/* ── PWA INSTALL PROMPT ── */
.pwa-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--forest);color:white;padding:12px 16px calc(var(--safe-bot) + 12px);z-index:9990;flex-direction:row;align-items:center;gap:12px}
.pwa-bar.show{display:flex}
.pwa-bar-text{flex:1;font-size:12px;line-height:1.4}
.pwa-bar-title{font-family:var(--serif);font-size:14px;font-weight:700;font-style:italic}
.pwa-bar-sub{font-size:10px;color:rgba(255,255,255,.7);font-family:var(--mono)}
.pwa-install-btn{background:white;color:var(--forest);border:none;padding:8px 16px;border-radius:8px;font-family:var(--mono);font-size:11px;font-weight:500;cursor:pointer;flex-shrink:0}
.pwa-dismiss{background:none;border:none;color:rgba(255,255,255,.5);font-size:18px;cursor:pointer;padding:4px;flex-shrink:0}

/* ── RECURRING BADGE ── */
.recurring-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:8px;padding:2px 7px;border-radius:20px;background:#f0ecf8;color:#6b4c9e;margin-left:6px}

/* ── EXPENSE TAB ── */
.exp-cat-tag{display:inline-block;font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:4px;background:var(--amber-light);color:var(--amber);margin-top:2px}

/* ── VOLUNTEER ── */
.vol-org-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding: 14px 16px; }
.vol-org-chip { padding: 10px 12px; border-radius: 10px; border: 1.5px solid var(--cream-dark); background: var(--cream); font-size: 12px; font-weight: 500; color: var(--ink-mid); cursor: pointer; text-align: center; transition: all .15s; -webkit-tap-highlight-color: transparent; }
.vol-org-chip.active { border-color: var(--forest); background: var(--forest-pale); color: var(--forest); }
.vol-org-chip.other { grid-column: span 2; font-style: italic; color: var(--ink-muted); }
.vol-hero { background: linear-gradient(135deg, #2d4a3e 0%, #1a3028 100%); border-radius: 18px; padding: 22px 20px 18px; margin-bottom: 16px; position: relative; overflow: hidden; }
.vol-hero::before { content: ''; position: absolute; top: -30px; right: -20px; width: 120px; height: 120px; border-radius: 50%; background: rgba(255,255,255,.05); }
.vol-stat-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-top: 16px; }
.vol-stat { background: rgba(255,255,255,.08); border-radius: 10px; padding: 10px 12px; }
.vol-stat-label { font-family: var(--mono); font-size: 8px; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 4px; }
.vol-stat-val { font-family: var(--serif); font-size: 20px; font-weight: 700; color: white; letter-spacing: -.02em; }
.vol-stat-sub { font-size: 10px; color: rgba(255,255,255,.5); margin-top: 2px; }
.vol-item { padding: 11px 16px; border-bottom: 1px solid var(--cream-dark); display: flex; align-items: center; gap: 12px; }
.vol-item:last-child { border-bottom: none; }
.vol-item-icon { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.vol-item-info { flex: 1; min-width: 0; }
.vol-item-title { font-size: 13px; font-weight: 500; color: var(--ink); }
.vol-item-meta { font-size: 10px; color: var(--ink-muted); margin-top: 1px; font-family: var(--mono); }
.vol-item-val { text-align: right; }
.vol-item-hours { font-family: var(--serif); font-size: 16px; font-weight: 700; color: var(--forest); }
.vol-item-expense { font-size: 11px; color: var(--amber); font-family: var(--mono); margin-top: 2px; }
.exp-type-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.exp-type-pill { padding: 6px 10px; border-radius: 8px; font-family: var(--mono); font-size: 10px; cursor: pointer; border: 1.5px solid var(--cream-dark); background: var(--cream); color: var(--ink-muted); transition: all .15s; -webkit-tap-highlight-color: transparent; }
.exp-type-pill.active { border-color: var(--amber); background: var(--amber-light); color: var(--amber); }
.vol-badge { display: inline-block; font-family: var(--mono); font-size: 9px; padding: 3px 8px; border-radius: 20px; background: var(--forest-pale); color: var(--forest); border: 1px solid rgba(45,74,62,.2); }

/* ── EI CALCULATOR ── */
.ei-hero { background: linear-gradient(135deg, #1a3028 0%, #0f1f19 100%); border-radius: 18px; padding: 22px 20px 20px; margin-bottom: 16px; position: relative; overflow: hidden; }
.ei-hero::before { content:''; position:absolute; top:-30px; right:-20px; width:120px; height:120px; border-radius:50%; background:rgba(255,255,255,.04); }
.ei-status { display:inline-flex; align-items:center; gap:6px; padding:4px 12px; border-radius:20px; font-family:var(--mono); font-size:10px; font-weight:500; margin-bottom:12px; }
.ei-status.qualified { background:rgba(34,197,94,.2); color:#22c55e; }
.ei-status.close { background:rgba(245,158,11,.2); color:#f59e0b; }
.ei-status.not-yet { background:rgba(239,68,68,.15); color:#ef4444; }
.ei-status.self-emp { background:rgba(59,130,246,.15); color:#3b82f6; }
.ei-progress-wrap { margin:14px 0 8px; }
.ei-progress-label { display:flex; justify-content:space-between; font-family:var(--mono); font-size:9px; color:rgba(255,255,255,.5); margin-bottom:6px; }
.ei-progress-track { height:10px; background:rgba(255,255,255,.1); border-radius:5px; overflow:hidden; }
.ei-progress-fill { height:100%; border-radius:5px; transition:width .6s ease; }
.ei-stat-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:16px; }
.ei-stat { background:rgba(255,255,255,.07); border-radius:10px; padding:10px 12px; }
.ei-stat-label { font-family:var(--mono); font-size:8px; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.08em; margin-bottom:3px; }
.ei-stat-val { font-family:var(--serif); font-size:20px; font-weight:700; color:white; letter-spacing:-.02em; }
.ei-stat-sub { font-size:10px; color:rgba(255,255,255,.45); margin-top:2px; }
.ei-region-select { width:100%; background:var(--cream); border:1.5px solid var(--cream-dark); border-radius:10px; padding:11px 14px; font-size:14px; font-family:var(--sans); color:var(--ink); outline:none; -webkit-appearance:none; appearance:none; margin-bottom:4px; }
.ei-region-select:focus { border-color:var(--forest); }
.ei-type-pills { display:flex; gap:8px; margin-bottom:4px; }
.ei-type-pill { flex:1; padding:10px 8px; border-radius:10px; text-align:center; font-family:var(--mono); font-size:10px; cursor:pointer; border:1.5px solid var(--cream-dark); background:var(--cream); color:var(--ink-muted); transition:all .15s; -webkit-tap-highlight-color:transparent; }
.ei-type-pill.active { border-color:var(--forest); background:var(--forest-pale); color:var(--forest); font-weight:500; }
.ei-info-box { background:var(--blue-light,#eff6ff); border:1px solid rgba(59,130,246,.2); border-radius:10px; padding:12px 14px; margin:10px 0; font-size:12px; color:#1e40af; line-height:1.6; }
.ei-warning-box { background:var(--amber-light); border:1px solid rgba(245,158,11,.2); border-radius:10px; padding:12px 14px; margin:10px 0; font-size:12px; color:var(--amber); line-height:1.6; }

/* ── UNEXPECTED EXPENSES ── */
.exp-section { margin-top: 16px; border-top: 1px solid var(--cream-dark); }
.exp-toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; cursor: pointer; -webkit-tap-highlight-color: transparent; }
.exp-toggle-label { font-family: var(--mono); font-size: 10px; color: var(--ink-muted); text-transform: uppercase; letter-spacing: .08em; display: flex; align-items: center; gap: 8px; }
.exp-toggle-label::before { content: '⚡'; font-size: 13px; }
.exp-toggle-arrow { font-size: 11px; color: var(--ink-faint); transition: transform .2s; }
.exp-toggle-arrow.open { transform: rotate(180deg); }
.exp-body { display: none; padding: 0 16px 16px; }
.exp-body.open { display: block; }
.exp-unexpected-toggle { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--cream-dark); margin-bottom: 12px; }
.exp-unexpected-label { font-size: 13px; color: var(--ink-mid); }
.exp-unexpected-sub { font-size: 10px; color: var(--ink-faint); font-family: var(--mono); margin-top: 2px; }
.toggle-switch { position: relative; width: 40px; height: 22px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider { position: absolute; inset: 0; background: var(--cream-dark); border-radius: 11px; cursor: pointer; transition: background .2s; }
.toggle-slider::before { content: ''; position: absolute; width: 16px; height: 16px; left: 3px; top: 3px; background: white; border-radius: 50%; transition: transform .2s; box-shadow: 0 1px 3px rgba(0,0,0,.2); }
.toggle-switch input:checked + .toggle-slider { background: var(--forest); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(18px); }
.cat-drill { margin-bottom: 10px; }
.cat-level { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 6px; }
.cat-chip { padding: 5px 10px; border-radius: 8px; font-size: 11px; font-family: var(--mono); cursor: pointer; border: 1px solid var(--cream-dark); background: var(--cream); color: var(--ink-muted); transition: all .15s; white-space: nowrap; -webkit-tap-highlight-color: transparent; }
.cat-chip.active { border-color: var(--amber); background: var(--amber-light); color: var(--amber); }
.cat-add-btn { width: 22px; height: 22px; border-radius: 50%; border: 1.5px dashed var(--ink-faint); background: none; color: var(--ink-faint); font-size: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .15s; }
.cat-add-btn:hover { border-color: var(--forest); color: var(--forest); }
.cat-path { font-family: var(--mono); font-size: 9px; color: var(--ink-faint); margin-bottom: 8px; min-height: 14px; }
.remind-row { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-top: 1px solid var(--cream-dark); margin-top: 8px; }
.remind-label { font-size: 12px; color: var(--ink-mid); flex: 1; }
.remind-date-input { font-family: var(--mono); font-size: 11px; color: var(--forest); border: 1px solid var(--cream-dark); background: var(--cream); cursor: pointer; padding: 4px 8px; border-radius: 6px; }
.exp-alert { background: var(--amber-light); border: 1px solid rgba(245,158,11,.25); border-left: 3px solid var(--amber); border-radius: 8px; padding: 12px 14px; margin-bottom: 12px; }
.exp-alert-title { font-size: 13px; font-weight: 600; color: var(--amber); margin-bottom: 3px; font-family: var(--display); }
.exp-alert-sub { font-size: 11px; color: var(--ink-muted); line-height: 1.5; }
.exp-summary-item { display: flex; justify-content: space-between; align-items: center; padding: 7px 0; border-bottom: 1px solid var(--cream-dark); font-size: 12px; }
.exp-summary-item:last-child { border-bottom: none; }

/* ── SKELETON ── */
.sk{background:linear-gradient(90deg,var(--cream-dark) 25%,var(--cream) 50%,var(--cream-dark) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;height:12px;margin-bottom:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── DELETE BUTTON ── */
.delete-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--cream-dark);background:var(--cream);color:var(--ink-faint);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;-webkit-tap-highlight-color:transparent;margin-left:8px}
.delete-btn:hover,.delete-btn:active{background:var(--red-light);border-color:var(--red);color:var(--red)}
