/* ── Design tokens — Buzzy honey palette ──────────────── */
:root {
  --bg:          #FEF9F0;
  --surface:     #FFFCF5;
  --sidebar:     #1C1812;
  --sidebar2:    #251F16;
  --text:        #2D1F0E;
  --text2:       #6B5335;
  --text3:       #A88B65;
  --border:      rgba(180,120,40,0.10);
  --border2:     rgba(180,120,40,0.18);
  --accent:      #D97706;
  --accent-lt:   #F59E0B;
  --accent-bg:   rgba(217,119,6,0.08);
  --honey:       #FBBF24;
  --honey-bg:    rgba(251,191,36,0.10);
  --green:       #059669;
  --green-bg:    rgba(5,150,105,0.08);
  --red:         #DC2626;
  --red-bg:      rgba(220,38,38,0.07);
  --amber:       #92400E;
  --amber-bg:    rgba(146,64,14,0.09);
  --radius:      16px;
  --radius-sm:   10px;
  --shadow-sm:   0 1px 4px rgba(140,80,10,0.06), 0 1px 2px rgba(140,80,10,0.04);
  --shadow:      0 2px 10px rgba(140,80,10,0.08), 0 1px 3px rgba(140,80,10,0.04);
  --shadow-md:   0 8px 24px rgba(140,80,10,0.12), 0 2px 8px rgba(140,80,10,0.06);
}
html.dark {
  --bg:          #1A1410;
  --surface:     #241C14;
  --sidebar:     #120F0A;
  --sidebar2:    #1A1410;
  --text:        #F0E6D3;
  --text2:       #B89870;
  --text3:       #6B5230;
  --border:      rgba(255,200,100,0.07);
  --border2:     rgba(255,200,100,0.13);
  --accent:      #F59E0B;
  --accent-lt:   #FCD34D;
  --accent-bg:   rgba(245,158,11,0.13);
  --green:       #34D399;
  --green-bg:    rgba(52,211,153,0.10);
  --red:         #F87171;
  --red-bg:      rgba(248,113,113,0.10);
  --amber:       #FCD34D;
  --amber-bg:    rgba(252,211,77,0.11);
}

/* ── Skeleton loading ─────────────────────────────────── */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{border-radius:8px;background:linear-gradient(90deg,var(--border) 25%,rgba(180,120,40,0.08) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.5s infinite linear}
.skel-hero{height:160px;border-radius:var(--radius);margin-bottom:24px}
.skel-bar{height:80px;border-radius:var(--radius);margin-bottom:16px}
.skel-row{height:48px;margin-bottom:8px;border-radius:var(--radius-sm)}
.skel-chart{height:240px;border-radius:var(--radius);margin-bottom:16px}
.skel-wrap{animation:fade-in .2s ease}
@keyframes fade-in{from{opacity:0}to{opacity:1}}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:1100px){
  #main-content{padding:48px 32px 36px}
  .dash-hero{padding:24px 28px;gap:24px}
  .dash-hero-amount{font-size:42px}
  .dash-hs{padding:14px 16px}
  .dash-hs-val{font-size:18px}
  .checklist-sidebar{width:200px;padding:48px 14px 20px}
}
@media(max-width:960px){
  .checklist-sidebar{display:none}
  .dash-hero{flex-direction:column;align-items:stretch}
  .dash-hero-stats{flex-wrap:wrap}
  .budget-toolbar{flex-direction:column;align-items:flex-start}
}

/* ── FAQ ─────────────────────────────────────────────── */
.faq-item{padding:14px 0;border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:none}
.faq-q{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px}
.faq-a{font-size:13px;color:var(--text2);line-height:1.6}

/* ── Accessibility ───────────────────────────────────── */
.skip-link{position:absolute;top:-40px;left:0;padding:8px 16px;background:var(--accent);color:#fff;z-index:10000;border-radius:0 0 8px 0;font-size:13px;font-weight:600;transition:top .2s}
.skip-link:focus{top:0}
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.nav-item:focus-visible{outline:2px solid #FBBF24;outline-offset:-2px}

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:'SF Pro Text',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;font-size:14px;line-height:1.55;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}
button{font-family:inherit;font-size:inherit;cursor:pointer}
input,select{font-family:inherit}

/* ── Layout ─────────────────────────────────────────── */
#app{display:flex;height:100vh}
#sidebar{width:216px;flex-shrink:0;background:var(--sidebar);display:flex;flex-direction:column;-webkit-app-region:drag;border-right:1px solid rgba(255,200,80,0.07)}
#main-content{flex:1;overflow-y:auto;padding:48px 48px 40px;background:var(--bg)}

/* ── Titlebar drag strip ─────────────────────────────── */
#win-drag-bar{position:fixed;top:0;left:216px;right:0;height:38px;-webkit-app-region:drag;z-index:800;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.drag-dots{width:40px;height:4px;border-radius:2px;background:var(--border2);opacity:0.5;user-select:none}

/* ── Heatmap day modal ────────────────────────────────── */
.modal-heatmap-day{width:520px;max-width:96vw;display:flex;flex-direction:column;padding:0;overflow:hidden;max-height:80vh}
#heatmap-day-title{font-size:17px;font-weight:700;letter-spacing:-.3px}
#heatmap-day-total{font-size:12px;color:var(--text3);margin-top:3px}
#heatmap-day-list{overflow-y:auto;flex:1}
.hd-tx-row{display:grid;grid-template-columns:110px 1fr auto auto;gap:0 16px;padding:12px 24px;border-bottom:1px solid var(--border);align-items:center}
.hd-tx-row:last-child{border-bottom:none}
.hd-tx-row:hover{background:var(--bg)}
.hd-tx-date{font-size:12px;color:var(--text3);font-variant-numeric:tabular-nums;white-space:nowrap}
.hd-tx-desc{font-size:14px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hd-tx-cat{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;white-space:nowrap;flex-shrink:0;border:1px solid transparent}
.hd-tx-amt{font-size:14px;font-weight:600;color:var(--red);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}

/* ── Sidebar ─────────────────────────────────────────── */
.sidebar-top{padding:44px 18px 20px;border-bottom:1px solid rgba(255,200,80,0.07)}
.wordmark{font-size:16px;font-weight:800;color:#FCD34D;letter-spacing:-0.3px;display:flex;align-items:center;gap:10px;line-height:1.2}
.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:1px}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;background:transparent;border:none;color:rgba(255,255,255,0.40);font-size:13px;border-radius:var(--radius-sm);-webkit-app-region:no-drag;transition:background .14s,color .14s;text-align:left;letter-spacing:-0.1px;font-weight:500}
.nav-item:hover{background:rgba(255,200,80,0.07);color:rgba(255,255,255,0.70)}
.nav-item.active{background:linear-gradient(135deg,rgba(245,158,11,0.18),rgba(251,191,36,0.12));color:#FCD34D;font-weight:600;border-left:3px solid #FBBF24;padding-left:8px}
.nav-item svg{flex-shrink:0;opacity:.7}
.nav-item.active svg{opacity:1}
.sidebar-footer{padding:10px 8px 18px;border-top:1px solid rgba(255,200,80,0.07);display:flex;flex-direction:column;gap:3px}
.sidebar-btn{width:100%;padding:8px 11px;background:transparent;border:1px solid rgba(255,200,80,0.11);color:rgba(255,255,255,0.42);font-size:12px;border-radius:var(--radius-sm);cursor:pointer;-webkit-app-region:no-drag;transition:all .14s;text-align:left;letter-spacing:-0.1px}
.sidebar-btn:hover{background:rgba(255,200,80,0.07);color:rgba(255,255,255,0.78);border-color:rgba(255,200,80,0.20)}
.sidebar-btn.primary{background:linear-gradient(135deg,#D97706,#FBBF24);color:#fff;border-color:transparent;font-weight:700;text-align:center;box-shadow:0 2px 10px rgba(217,119,6,0.40);border-radius:99px}
.sidebar-btn.primary:hover{box-shadow:0 3px 14px rgba(245,158,11,0.50);transform:translateY(-1px)}
.sidebar-btn-link{border-color:transparent;color:rgba(255,200,80,0.28);font-size:11px;padding:4px 10px;text-align:center}
.sidebar-btn-link:hover{background:transparent;border-color:transparent;color:rgba(255,200,80,0.55)}
.sidebar-privacy{display:flex;align-items:center;gap:6px;padding:8px 10px 2px;color:rgba(255,200,80,0.25);font-size:10px;line-height:1.3;letter-spacing:0.02em}
.sidebar-privacy svg{flex-shrink:0;opacity:.5}
.sidebar-version{padding:0 10px 2px;color:rgba(255,200,80,0.18);font-size:10px;cursor:pointer}
.sidebar-version:hover{color:rgba(255,200,80,0.40)}

/* ── About modal ─────────────────────────────────────── */
.about-modal{max-width:380px;text-align:center;padding:0}
.about-header{padding:32px 24px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}
.about-title{font-size:22px;font-weight:800;letter-spacing:-0.5px;margin:0}
.about-version{font-size:13px;color:var(--text3);font-weight:500}
.about-body{padding:0 28px 20px}
.about-tagline{font-size:14px;color:var(--text2);margin:0 0 16px;font-weight:500}
.about-privacy-badge{display:flex;align-items:flex-start;gap:10px;background:var(--green-bg);border:1px solid rgba(5,150,105,0.15);border-radius:var(--radius-sm);padding:12px 14px;text-align:left}
.about-privacy-badge svg{flex-shrink:0;margin-top:1px;color:var(--green)}
.about-privacy-badge span{font-size:12.5px;line-height:1.5;color:var(--text2)}
.about-details{margin-top:14px;font-size:11.5px;color:var(--text3);line-height:1.6}
.about-footer{padding:14px 24px 20px;text-align:center}

/* ── Tabs ─────────────────────────────────────────────── */
.tab{display:none}
.tab.active{display:block;animation:tab-in .28s cubic-bezier(.22,1.1,.6,1)}
@keyframes tab-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.tab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.tab-header h1{font-size:24px;font-weight:800;letter-spacing:-0.8px;color:var(--text)}
.header-controls{display:flex;gap:10px;align-items:center}

/* ── Inputs ──────────────────────────────────────────── */
.select,select{padding:7px 28px 7px 11px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:13px;background:var(--surface);color:var(--text);outline:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23aaa'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;box-shadow:var(--shadow-sm)}
.select:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg),var(--shadow-sm)}
input[type=text],input[type=number],input[type=date]{padding:8px 12px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:14px;color:var(--text);background:var(--surface);outline:none;width:100%;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}
input[type=text]:focus,input[type=number]:focus,input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.search-input{padding:7px 11px 7px 32px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:13px;color:var(--text);background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat 10px center;outline:none;width:190px;transition:border-color .15s,width .22s,box-shadow .15s;box-shadow:var(--shadow-sm)}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);width:230px}
.search-input::placeholder{color:var(--text3)}

/* Small variant for selects inside panels */
.select-sm{font-size:12px;padding:4px 22px 4px 9px}
/* Full-width select inside a modal .field */
.field select{width:100%}

/* ── Buttons ─────────────────────────────────────────── */
.btn-primary{padding:9px 18px;background:linear-gradient(135deg,#D97706,#F59E0B);color:#fff;border:none;border-radius:99px;font-size:13px;font-weight:700;letter-spacing:-0.1px;transition:all .18s;white-space:nowrap;box-shadow:0 2px 10px rgba(217,119,6,0.30)}
.btn-primary:hover{box-shadow:0 4px 16px rgba(245,158,11,0.40);transform:translateY(-1px) scale(1.02)}
.btn-primary:active{transform:translateY(0) scale(.98)}
.btn-ghost{padding:8px 16px;background:var(--surface);color:var(--text2);border:1px solid var(--border2);border-radius:99px;font-size:13px;font-weight:500;transition:all .14s;box-shadow:var(--shadow-sm)}
.btn-ghost:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}
.btn-link{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;padding:0;letter-spacing:-0.1px;font-weight:500}
.btn-link:hover{color:var(--accent-lt)}
.btn-danger{padding:6px 12px;background:transparent;color:#B45309;border:1px solid rgba(180,83,9,0.22);border-radius:99px;font-size:13px;font-weight:600;transition:all .14s}
.btn-danger:hover{background:rgba(180,83,9,0.08);border-color:rgba(180,83,9,0.35)}
.icon-btn{background:none;border:none;padding:4px 6px;border-radius:6px;color:var(--text3);font-size:14px;transition:all .12s}
.icon-btn:hover{background:var(--bg);color:var(--text)}

/* ── Panels ──────────────────────────────────────────── */
.panel{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}
.heatmap-row{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.heatmap-cell{border-radius:12px;padding:14px 10px;text-align:center;transition:transform .18s,box-shadow .18s;cursor:pointer}
.heatmap-cell:hover{transform:scale(1.07);box-shadow:var(--shadow-md)}
.heatmap-day{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:6px}
.heatmap-val{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}
.panel-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:0.09em;color:var(--accent);margin-bottom:16px}
.panel-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.chart-wrap{position:relative;width:100%}
.h200{height:200px}.h160{height:160px}.h240{height:240px}
/* Full-width grid panel */
.grid-col-full{grid-column:1/-1}
/* Suppress bottom margin on panel title when inside a flex title row */
.panel-title-row .panel-title{margin-bottom:0}

/* ── Badge ───────────────────────────────────────────── */
.badge{font-size:11px;padding:2px 8px;background:var(--accent-bg);border-radius:99px;color:var(--accent);font-weight:700}

/* ── Value colours ───────────────────────────────────── */
.positive{color:var(--green)}.negative{color:var(--red)}.neutral{color:var(--amber)}

/* ── Dashboard ───────────────────────────────────────── */
#dash-net-worth-bar{margin-bottom:24px}
.dash-stats{margin-bottom:24px}
.dash-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}
/* ── New Dashboard ───────────────────────────────────── */
.db-score-row{display:flex;gap:20px;margin-bottom:20px}
.db-score-card{flex:0 0 200px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;align-items:center;box-shadow:var(--shadow-sm)}
.db-score-ring{position:relative;width:140px;height:140px;margin-bottom:12px}
.db-score-ring svg{transform:rotate(-90deg)}
.db-score-ring-bg{stroke:var(--border);fill:none;stroke-width:10}
.db-score-ring-fg{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1)}
.db-score-num{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:36px;font-weight:800;letter-spacing:-1.5px}
.db-score-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text3);margin-bottom:2px}
.db-score-sub{font-size:12px;color:var(--text3)}
.db-hero-panel{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-width:0}
.db-hero-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}
.db-hero-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text3);margin-bottom:6px}
.db-hero-amount{font-size:44px;font-weight:800;letter-spacing:-2px;line-height:1;font-variant-numeric:tabular-nums}
.db-hero-change{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;padding:3px 10px;border-radius:99px;margin-top:8px}
.db-hero-change.up{background:rgba(180,83,9,.15);color:#B45309}
.db-hero-change.down{background:rgba(251,191,36,.15);color:#D97706}
.db-hero-chart{flex:1;min-height:100px;margin-top:8px}
.db-hero-chart canvas{width:100%!important;height:100%!important}
.db-flow{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.db-flow-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text3);margin-bottom:14px}
.db-flow-bar{display:flex;height:32px;border-radius:8px;overflow:hidden;background:var(--border);margin-bottom:10px}
.db-flow-in{background:linear-gradient(90deg,#059669,#34d399);transition:width .8s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;min-width:0}
.db-flow-out{background:linear-gradient(90deg,#f87171,#DC2626);transition:width .8s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;min-width:0}
.db-flow-saved{background:linear-gradient(90deg,#D97706,#F59E0B);transition:width .8s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;min-width:0}
.db-flow-legend{display:flex;gap:20px;font-size:12px;color:var(--text2)}
.db-flow-legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
.db-flow-legend strong{font-weight:700;color:var(--text);margin-left:2px}
.db-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.db-treemap{display:flex;flex-wrap:wrap;gap:3px;padding:4px 0}
.db-tm-cell{border-radius:6px;padding:8px 10px;cursor:default;transition:opacity .15s;display:flex;flex-direction:column;justify-content:center;min-height:48px;overflow:hidden}
.db-tm-cell:hover{opacity:.85}
.db-tm-name{font-size:11px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.db-tm-amt{font-size:13px;font-weight:700;color:rgba(255,255,255,.9);font-variant-numeric:tabular-nums}
.db-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.db-badge{display:flex;align-items:center;gap:7px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:99px;font-size:12px;font-weight:500;color:var(--text2);box-shadow:var(--shadow-sm)}
.db-badge-icon{font-size:16px;line-height:1}
.db-badge strong{font-weight:700;color:var(--text)}
.db-pulse{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600}
.db-pulse-dot{width:8px;height:8px;border-radius:50%;animation:db-pulse-anim 2s ease infinite}
@keyframes db-pulse-anim{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
.flex-2{grid-column:span 2}

/* Hero financial summary */
.dash-hero{border-radius:var(--radius);padding:32px 36px;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:32px}
.dash-hero-pos{background:linear-gradient(135deg,#D97706 0%,#F59E0B 40%,#FBBF24 80%,#FCD34D 100%);box-shadow:0 6px 32px rgba(217,119,6,.30);border:none}
.dash-hero-neu{background:linear-gradient(135deg,#1C1812 0%,#251F16 50%,#2D2518 100%);box-shadow:0 6px 32px rgba(0,0,0,.25);border:1px solid rgba(255,200,80,0.08)}
.dash-hero-neg{background:linear-gradient(135deg,#1C1812 0%,#221A14 50%,#2A1E16 100%);box-shadow:0 6px 32px rgba(0,0,0,.25);border:1px solid rgba(200,120,80,0.12)}
.dash-hero-main{flex:1;min-width:0}
.dash-hero-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.11em;opacity:.72;margin-bottom:12px}
.dash-period-select{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 20px 3px 7px;border-radius:5px;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='rgba(255,255,255,0.5)'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center;outline:none;transition:border-color .15s}
.dash-period-select:hover{border-color:rgba(255,255,255,.4)}
.dash-period-select:focus{border-color:rgba(255,255,255,.5)}
.dash-period-select option{background:var(--sidebar);color:#fff}
.dash-hero-amount{font-size:56px;font-weight:800;letter-spacing:-3px;line-height:1;font-variant-numeric:tabular-nums}
.dash-hero-sublabel{font-size:14px;opacity:.82;margin-top:10px}
.dash-hero-rate-bar{margin-top:16px;height:4px;background:rgba(255,255,255,.2);border-radius:3px;width:220px;max-width:90%}
.dash-hero-rate-fill{height:100%;border-radius:2px;background:rgba(255,255,255,.80);transition:width .9s cubic-bezier(.4,0,.2,1)}
.dash-hero-rate-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.65;margin-top:6px}
.dash-hero-stats{display:flex;gap:0;flex-shrink:0;background:rgba(255,255,255,.10);border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.dash-hs{padding:20px 24px;border-right:1px solid rgba(255,255,255,.12);text-align:center}
.dash-hs:last-child{border-right:none}
.dash-hs-val{font-size:22px;font-weight:700;letter-spacing:-0.6px;font-variant-numeric:tabular-nums;line-height:1.2}
.dash-hs-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;opacity:.62;margin-top:5px}

/* Net worth */
.runway-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.runway-info{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.runway-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3)}
.runway-value{font-size:14px;font-variant-numeric:tabular-nums}
.runway-value strong{font-size:18px;font-weight:700}
.runway-track{height:6px;background:var(--border2);border-radius:3px;margin-bottom:8px;overflow:hidden}
.runway-fill{height:100%;border-radius:3px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.runway-sub{font-size:11px;color:var(--text3)}

/* Forecast panel */
.forecast-panel{margin-bottom:14px}
.forecast-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}
.forecast-main{display:flex;align-items:baseline;gap:8px}
.forecast-projected{font-size:26px;font-weight:800;letter-spacing:-0.5px;color:var(--text)}
.forecast-label{font-size:13px;color:var(--text3)}
.forecast-vs{font-size:13px;font-weight:600}
.forecast-bar-wrap{margin-top:4px}
.forecast-bar-track{height:5px;background:var(--border2);border-radius:3px;overflow:hidden}
.forecast-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}
.forecast-bar-label{font-size:11px;color:var(--text3);margin-top:6px}

/* Motivation panel */
.motivation-panel{margin-bottom:16px;padding:20px 24px;background:linear-gradient(135deg,var(--surface) 0%,rgba(251,191,36,0.04) 100%);border:1px solid rgba(251,191,36,0.15)}
.motivation-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0}
.motivation-row+.motivation-row{border-top:1px solid var(--border)}
.motivation-icon{font-size:22px;line-height:1;flex-shrink:0;margin-top:1px}
.motivation-msg{font-size:14px;line-height:1.6;color:var(--text2)}
.motivation-msg strong{color:var(--text);font-weight:700}

/* Recurring panel */
.recurring-panel{margin-bottom:14px}
.recurring-total{font-size:13px;color:var(--text3);font-weight:600}
.recurring-list{display:flex;flex-direction:column;gap:2px;margin-top:8px}
.recurring-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}
.recurring-item:last-child{border-bottom:none}
.recurring-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.recurring-info{flex:1;min-width:0}
.recurring-desc{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recurring-meta{font-size:11px;color:var(--text3)}
.recurring-amt{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap}
.nw-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.nw-empty{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 18px;margin-bottom:16px;font-size:12px;color:var(--text3)}
.nw-main{display:flex;align-items:center;gap:20px;margin-bottom:14px;flex-wrap:wrap}
.nw-hist-chart{flex-shrink:0;opacity:.9}
.nw-snapshot-btn{font-size:11px;color:var(--text3);background:none;border:1px solid var(--border2);border-radius:6px;padding:4px 10px;cursor:pointer;transition:all .12s;white-space:nowrap;margin-left:auto}
.nw-snapshot-btn:hover{border-color:var(--accent);color:var(--accent)}
.nw-add-btn{font-size:12px;white-space:nowrap;color:rgba(255,255,255,.6)!important}
.nw-add-btn:hover{color:rgba(255,255,255,.9)!important}
.nw-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3)}
.nw-value{font-size:38px;font-weight:800;letter-spacing:-1.8px;font-variant-numeric:tabular-nums}
.nw-breakdown{display:flex;gap:20px;font-size:12px;color:var(--text2);margin-bottom:14px}
.nw-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:5px}
.nw-item{display:flex;align-items:center}
.nw-accounts{display:flex;flex-wrap:wrap;gap:6px}
.nw-acc{display:flex;gap:10px;align-items:center;font-size:12px;padding:7px 14px;background:var(--bg);border-radius:8px;border:1px solid var(--border);justify-content:space-between;min-width:140px}

/* Account rows */
.account-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.account-row:last-child{border-bottom:none}
.acc-type-icon{width:32px;height:32px;border-radius:8px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;color:var(--text2)}
.acc-info{flex:1}
.acc-name{font-size:14px;font-weight:500;color:var(--text)}
.acc-notes{font-size:11px;color:var(--text3);font-weight:400}
.acc-type-label{font-size:11px;color:var(--text3);text-transform:capitalize}
.acc-balance{font-size:15px;font-weight:600;min-width:80px;text-align:right;letter-spacing:-0.4px;font-variant-numeric:tabular-nums}
.acc-actions{display:flex;gap:2px}

/* Insight cards */
.insight-card{display:flex;align-items:flex-start;gap:10px;padding:11px 0;border-bottom:1px solid var(--border)}
.insight-card:last-child{border-bottom:none}
.insight-badge{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.insight-badge.pos{background:var(--green-bg);color:var(--green)}
.insight-badge.neg{background:var(--red-bg);color:var(--red)}
.insight-badge.neu{background:var(--accent-bg);color:var(--accent)}
.insight-badge.warn{background:var(--amber-bg);color:var(--amber)}
.insight-card-body p{font-size:13.5px;color:var(--text2);line-height:1.6;margin:0}
.insight-card-body p strong{color:var(--text);font-weight:600}
.budget-alert-chip{display:block;font-size:12px;color:var(--text2);border-left:3px solid var(--border2);padding-left:8px;line-height:1.5}
.budget-alert-chip strong{font-weight:600;color:var(--text)}
.budget-alert-chip.over{color:#B45309}
.budget-alert-chip.over strong{color:var(--red)}
.budget-alert-chip.warn{color:var(--amber)}
.budget-alert-chip.warn strong{color:var(--amber)}

/* Empty state */
.dash-empty{text-align:center;padding:80px 24px}
.dash-empty .btn-primary{font-size:14px;padding:12px 30px;border-radius:10px}
.dash-empty .btn-ghost{font-size:13px;padding:10px 24px;border-radius:10px;display:inline-block}
.dash-empty-title{font-size:24px;font-weight:800;letter-spacing:-.6px;color:var(--text);margin-bottom:12px}
.dash-empty-sub{font-size:14px;color:var(--text3);margin-bottom:32px;line-height:1.65;max-width:340px;margin-left:auto;margin-right:auto}
.bva-empty{padding:48px 24px;text-align:center}
.bva-empty-title{font-size:17px;font-weight:700;color:var(--text2);margin-bottom:8px}
.bva-empty-sub{font-size:14px;color:var(--text3);line-height:1.6}

/* Stat card */
.stat-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px 22px;box-shadow:var(--shadow-sm)}
.stat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.09em;color:var(--text3);margin-bottom:8px}
.stat-value{font-size:26px;font-weight:700;letter-spacing:-1px;line-height:1.1;font-variant-numeric:tabular-nums}
.stat-sub{font-size:12px;color:var(--text3);margin-top:4px}

/* Budget tab secondary charts (week-by-week + income) */
.dash-charts-mt{margin-top:14px}

/* ── Budget KPI bar ───────────────────────────────────── */
.budget-kpi-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:linear-gradient(135deg,#D97706 0%,#F59E0B 40%,#FBBF24 80%,#FCD34D 100%);border:none;border-radius:var(--radius);overflow:hidden;margin-bottom:24px;box-shadow:0 6px 32px rgba(217,119,6,.30);color:#fff}
.budget-kpi{padding:24px 28px;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.18)}
.budget-kpi:last-child{border-right:none}
.budget-kpi-value{font-size:30px;font-weight:800;letter-spacing:-1.2px;color:#fff;font-variant-numeric:tabular-nums;line-height:1.05;margin-bottom:6px}
.budget-kpi-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.65)}
.budget-kpi-sub{font-size:12px;color:rgba(255,255,255,.55);margin-top:4px}
.kpi-ok{color:#fff}.kpi-warn{color:#fff}.kpi-over{color:rgba(255,255,255,.8)}

/* ── Data table ──────────────────────────────────────── */
.data-table{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}
.data-table-header{background:var(--bg);border-bottom:1px solid var(--border);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.09em;color:var(--text3)}
.bva-grid{display:grid;grid-template-columns:auto 1fr 140px 120px;align-items:center;padding:10px 20px;gap:0 8px}
.bva-grid-rec{grid-template-columns:1fr 160px 140px 140px 150px}
.data-row{border-bottom:1px solid var(--border);padding:14px 20px;transition:background .1s}
.data-row:last-child{border-bottom:none}
.data-row:nth-child(even){background:rgba(180,120,40,0.02)}
.data-row:hover{background:var(--bg)}
.bva-row-clickable{cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s}
.drag-handle{cursor:grab;color:var(--text3);font-size:16px;padding:4px 8px 4px 2px;opacity:.35;transition:opacity .15s;user-select:none;line-height:1;touch-action:none}
.drag-handle:hover{opacity:.7}
.drag-handle:active{cursor:grabbing;opacity:1}
.bva-row-clickable.dragging{opacity:0;pointer-events:none}
.drag-placeholder{border:2px dashed var(--accent);border-radius:var(--radius-sm);opacity:.35;background:var(--accent-bg)}
.bva-row-clickable:hover .bva-cat-name{color:var(--accent)}
.bva-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px 6px;background:var(--bg);border-bottom:1px solid var(--border)}
.bva-group-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--accent)}
.bva-group-summary{font-size:11px;font-weight:600;color:var(--text3);font-variant-numeric:tabular-nums}
.bva-grouped .bva-cat-name{padding-left:12px}
.data-table-footer{background:var(--bg);border-top:1px solid var(--border2);font-weight:600;font-size:14px;padding:12px 20px}
.tr{text-align:right}
.num{text-align:right;font-size:14px;font-variant-numeric:tabular-nums}
.num.over{color:#B45309}.num.under{color:#D97706}.num.neutral{color:var(--text3)}

/* Budget row cells */
.bva-cat-info{display:flex;flex-direction:column;gap:4px}
.bva-cat-name{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text)}
.cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sparkline-cell{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.sparkline-avg{font-size:10px;color:var(--text3);font-variant-numeric:tabular-nums}
.sparkline-empty{color:var(--text3)}

/* Budget bar */
.budget-bar-track{height:5px;background:var(--border2);border-radius:3px;position:relative;overflow:visible;max-width:200px}
.budget-bar-spent{position:absolute;left:0;top:0;height:100%;border-radius:3px;transition:width .3s}
.budget-bar-pct{position:absolute;right:0;top:-13px;font-size:10px;color:var(--text3);white-space:nowrap}

/* Inline budget input */
.inline-budget-wrap{display:flex;align-items:center;justify-content:flex-end;gap:2px}
.budget-prefix{color:var(--text3);font-size:12px}
.budget-suffix{color:var(--text3);font-size:10px;margin-left:2px}
.inline-budget{width:80px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;text-align:right;background:var(--surface);color:var(--text);cursor:pointer;font-variant-numeric:tabular-nums;transition:all .12s;font-weight:600}
.inline-budget:hover{border-color:var(--border2);background:var(--bg)}
.inline-budget:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 2px var(--accent-bg);outline:none}
.budget-total-note{font-size:10px;color:var(--text3);white-space:nowrap;margin-left:2px}
.rollover-chip{display:inline-block;font-size:10px;color:var(--green);font-weight:600;margin-top:2px}

/* Recommended */
.toggle-label{display:flex;align-items:center;cursor:pointer}
.toggle-label input{display:none}
.toggle-pill{font-size:12px;padding:6px 13px;border-radius:99px;border:1px solid var(--border2);background:var(--surface);color:var(--text3);transition:all .18s;user-select:none;font-weight:500}
.toggle-pill.toggle-state{font-size:0}
.toggle-pill.toggle-state::after{content:'Enable';font-size:12px}
.toggle-label input:checked + .toggle-pill.toggle-state::after{content:'Disable'}
.toggle-label input:checked + .toggle-pill{background:linear-gradient(135deg,rgba(217,119,6,0.12),rgba(251,191,36,0.12));color:var(--accent);border-color:rgba(217,119,6,0.30);font-weight:600}
.rec-col{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.rec-col-hdr{color:var(--accent);font-size:11px}
.rec-avg{font-size:12px;font-weight:600;color:var(--text2);font-variant-numeric:tabular-nums}
.rec-apply-btn{font-size:11px;padding:2px 8px;border-radius:99px;background:var(--accent-bg);color:var(--accent);border:1px solid rgba(217,119,6,0.22);white-space:nowrap;transition:background .1s}
.rec-apply-btn:hover{background:rgba(217,119,6,0.16)}
.rec-apply-all-btn{font-size:11px;padding:2px 9px;border-radius:5px;background:var(--accent-bg);color:var(--accent);border:1px solid rgba(217,119,6,0.22);margin-left:8px}
.rec-apply-all-btn:hover{background:rgba(217,119,6,0.16)}

/* ── Reconcile (Allocate) ─────────────────────────────── */
.recon-progress-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.recon-progress-track{flex:1;height:7px;background:var(--border2);border-radius:4px;overflow:hidden}
.recon-progress-fill{height:100%;background:linear-gradient(90deg,#D97706,#F59E0B,#FBBF24);border-radius:3px;transition:width .4s ease}
.recon-progress-label{font-size:12px;font-weight:500;color:var(--text3);white-space:nowrap;min-width:140px;text-align:right}

.recon-controls{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.bulk-action-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--accent-bg);border:1px solid var(--accent);border-radius:var(--radius);margin-bottom:10px;flex-wrap:wrap;animation:tab-in .18s ease}
.bulk-action-bar.hidden{display:none}
.bulk-count{font-size:13px;font-weight:600;color:var(--accent);white-space:nowrap;margin-right:4px}
.bulk-cat-select{flex:1;min-width:160px;max-width:220px}
.bulk-apply-btn{flex-shrink:0}
.recon-row-cb{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}
.recon-search-wrap{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;flex:1;min-width:160px;color:var(--text3)}
.recon-search-wrap:focus-within{border-color:var(--accent)}
.recon-search{background:none;border:none;outline:none;font-size:13px;color:var(--text);width:100%}
.recon-search::placeholder{color:var(--text3)}
.recon-filter-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2);white-space:nowrap;cursor:pointer;user-select:none}
.recon-filter-label input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}

.modal-wide{width:560px;max-width:95vw}
.cat-settings-list{max-height:480px;overflow-y:auto}
.cat-settings-empty{padding:32px;text-align:center;font-size:13px;color:var(--text3)}
.cat-settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;border-bottom:1px solid var(--border);transition:background .1s}
.cat-settings-row:last-child{border-bottom:none}
.cat-settings-row:hover{background:var(--bg)}
.cat-settings-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.cat-settings-info{display:flex;flex-direction:column;gap:3px;min-width:0}
.cat-settings-name{font-size:14px;font-weight:600;color:var(--text)}
.cat-settings-meta{font-size:11px;color:var(--text3)}
.cat-settings-actions{display:flex;gap:6px;flex-shrink:0}
.cat-settings-edit-btn{font-size:12px;padding:5px 12px}
.cat-settings-del-btn{font-size:12px;padding:5px 12px;background:none;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--red);cursor:pointer;font-weight:500;transition:all .12s}
.cat-settings-del-btn:hover{background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.2)}

/* ── Category transactions modal ─────────────────────────── */
.cat-tx-modal{width:min(580px,92vw);max-height:85vh;display:flex;flex-direction:column;padding:0;overflow:hidden}
.cat-tx-modal-header{padding:24px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.cat-tx-modal-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}
.cat-tx-modal-title{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:800;letter-spacing:-.5px;color:var(--text)}
.cat-tx-color-bar{width:4px;height:24px;border-radius:2px;flex-shrink:0}
.cat-tx-name{letter-spacing:-.4px}
.cat-tx-stats{display:flex;gap:20px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.cat-tx-stat{display:flex;flex-direction:column;gap:2px}
.cat-tx-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.cat-tx-stat-value{font-size:16px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.cat-tx-list{flex:1;overflow-y:auto}
.cat-tx-chart-wrap{height:160px;padding:0 24px 12px;border-bottom:1px solid var(--border);flex-shrink:0}
.cat-tx-chart-wrap canvas{width:100%!important;height:100%!important}
.cat-tx-list{flex:1;overflow-y:auto;min-height:0}
.cat-tx-empty{padding:48px 24px;text-align:center;color:var(--text3);font-size:14px}
.cat-tx-row{display:flex;align-items:center;gap:12px;padding:11px 24px;border-bottom:1px solid var(--border);transition:background .1s}
.cat-tx-row:last-child{border-bottom:none}
.cat-tx-row:hover{background:var(--bg)}
.cat-tx-left{flex:1;min-width:0}
.cat-tx-desc{font-size:13.5px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}
.cat-tx-date{font-size:11.5px;color:var(--text3);font-variant-numeric:tabular-nums;margin-top:2px}
.cat-tx-amount{font-size:14px;font-weight:600;color:var(--text);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}

/* ── Surplus hero panel ────────────────────────────────── */
.surplus-hero{background:linear-gradient(135deg,#D97706 0%,#F59E0B 40%,#FBBF24 80%,#FCD34D 100%);border-radius:var(--radius);padding:28px 32px;margin-bottom:20px;color:#fff;display:flex;flex-direction:column;gap:18px;box-shadow:0 6px 32px rgba(217,119,6,.30)}
.surplus-hero-top{display:flex;align-items:center;justify-content:space-between;gap:24px}
.surplus-hero-left{display:flex;flex-direction:column;gap:4px}
.surplus-hero-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;opacity:.75}
.surplus-hero-amount{font-size:46px;font-weight:800;letter-spacing:-2.2px;line-height:1;font-variant-numeric:tabular-nums}
.surplus-hero-cta{text-align:right}
.surplus-hero-sub{font-size:14px;opacity:.85}
.surplus-hero-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;border-top:1px solid rgba(255,255,255,.15);padding-top:14px}
.surplus-cat-card{background:rgba(255,255,255,.12);border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:8px;font-size:12px;color:#fff}
.surplus-cat-card-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.surplus-cat-card-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.surplus-cat-card-bar-wrap{width:48px;height:4px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden;flex-shrink:0}
.surplus-cat-card-bar-fill{height:100%;border-radius:2px}
.surplus-chip-amt{font-weight:700;white-space:nowrap;opacity:.95}
/* Last week arrow cell */
.lw-cell{display:flex;align-items:center;justify-content:flex-end;gap:6px;font-variant-numeric:tabular-nums}
.lw-arrow{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;flex-shrink:0}
.lw-arrow.under{background:rgba(251,191,36,.15);color:#FBBF24}
.lw-arrow.over{background:rgba(180,83,9,.15);color:#B45309}
.budget-adj-note{display:block;font-size:10px;color:var(--amber);font-weight:500;margin-top:2px}


.recon-table-wrap{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}
.recon-grid{display:grid;grid-template-columns:104px 1fr 96px 220px;align-items:center;gap:0 16px;padding:0 20px}
.recon-table-hdr{background:var(--bg);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);padding-top:10px;padding-bottom:10px}
.recon-list{overflow-y:auto;max-height:calc(100vh - 360px)}
.recon-row{border-bottom:1px solid var(--border);padding:11px 20px;display:grid;grid-template-columns:104px 1fr 96px 220px;align-items:center;gap:0 16px;transition:background .1s;position:relative}
.recon-row:last-child{border-bottom:none}
.recon-row:hover{background:var(--bg)}
.recon-row.selected{background:var(--accent-bg)}
.recon-row.unallocated .recon-date{color:var(--text)}
.recon-row.is-income{opacity:.7}
.recon-row.is-transfer{background:rgba(217,119,6,.04)}
.recon-row.is-transfer .recon-desc{color:var(--text2)}
.recon-row.is-transfer .recon-amount{color:var(--amber)}
.recon-date-cell{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text3);font-variant-numeric:tabular-nums;white-space:nowrap}
.recon-desc-cell{overflow:hidden}
.recon-date{font-size:12px;color:var(--text3);font-variant-numeric:tabular-nums;white-space:nowrap}
.recon-desc{font-size:14px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.recon-note{font-size:11px;color:var(--text3);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.recon-note-input{width:100%;font-size:11px;border:none;border-bottom:1px dashed var(--border2);background:transparent;color:var(--text2);outline:none;font-style:italic;padding:1px 0;margin-top:2px}
.recon-amount{font-size:14px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.recon-amount.debit{color:var(--red)}
.recon-amount.credit{color:var(--green)}

/* Read-only category pill */
.recon-cat-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:var(--bg);color:var(--text2);max-width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.recon-cat-pill .rcp-dot{width:7px;height:7px;border-radius:50%;background:var(--cc,var(--border2));flex-shrink:0}
.recon-cat-pill.unset{color:var(--text3);border-style:dashed;background:transparent;font-style:italic}
.recon-cat-pill.income-pill{color:var(--green);border-color:rgba(5,150,105,.25);background:var(--green-bg)}

/* Editable category select */
.cat-select-wrap{display:flex;align-items:center;gap:7px;position:relative}
.cat-select-wrap::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--cc,var(--border2));flex-shrink:0}
.recon-cat-select{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text);padding:5px 8px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}
.recon-cat-select:focus{outline:none;border-color:var(--accent)}
.recon-del-btn,.recon-note-btn,.recon-split-btn{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text3);font-size:12px;line-height:1;padding:4px 5px;border-radius:4px;opacity:0;transition:opacity .12s,color .12s;cursor:pointer}
.recon-del-btn{right:2px}
.recon-note-btn{right:22px}
.recon-split-btn{right:42px}
.recon-row:hover .recon-del-btn,.recon-row:hover .recon-note-btn,.recon-row:hover .recon-split-btn{opacity:.45}
.recon-del-btn:hover{opacity:1 !important;color:var(--red)}
.recon-note-btn:hover{opacity:1 !important;color:var(--accent)}
.recon-split-btn:hover{opacity:1 !important;color:var(--accent)}

.recon-empty{padding:56px 20px;text-align:center;color:var(--text3);font-size:14px}
.recon-empty strong{display:block;font-size:17px;color:var(--text2);margin-bottom:8px;font-weight:700}

/* ── Goals ───────────────────────────────────────────── */
.goals-hero{display:flex;margin-bottom:24px;border-radius:var(--radius);overflow:hidden;border:none;background:linear-gradient(135deg,#D97706 0%,#F59E0B 40%,#FBBF24 80%,#FCD34D 100%);box-shadow:0 6px 32px rgba(217,119,6,.30);color:#fff}
.goals-hero-stat{flex:1;padding:22px 24px;border-right:1px solid rgba(255,255,255,.18);text-align:center;min-width:0}
.goals-hero-stat:last-child{border-right:none}
.goals-hero-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.09em;color:rgba(255,255,255,.65);margin-bottom:8px;white-space:nowrap}
.goals-hero-value{font-size:28px;font-weight:800;letter-spacing:-1.2px;line-height:1;font-variant-numeric:tabular-nums;color:#fff}
/* ── Goals redesign ─────────────────────────────────────────────────────────── */
.goals-main{display:grid;grid-template-columns:1fr 340px;gap:14px;align-items:start}
.goal-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.goal-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:24px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow 0.18s,transform .18s}
.goal-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.goal-card-accent{position:absolute;top:0;left:0;right:0;height:5px;background:var(--gc,var(--accent));border-radius:var(--radius) var(--radius) 0 0}
.goal-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}
.goal-card-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.3}
.goal-card-edit{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:3px 8px;border-radius:var(--radius-sm);transition:all 0.12s}
.goal-card-edit:hover{background:var(--bg);color:var(--text)}
.goal-amounts{display:flex;align-items:baseline;gap:6px;margin-bottom:12px}
.goal-saved-val{font-size:28px;font-weight:800;letter-spacing:-1.2px;color:var(--text);font-variant-numeric:tabular-nums}
.goal-sep{font-size:13px;color:var(--text3)}
.goal-target-val{font-size:14px;font-weight:500;color:var(--text2);font-variant-numeric:tabular-nums}
.goal-track{height:7px;background:var(--border2);border-radius:4px;margin-bottom:14px;overflow:hidden}
.goal-fill{height:100%;border-radius:3px;background:var(--gc,var(--accent));transition:width 0.5s cubic-bezier(.4,0,.2,1)}
.goal-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text3)}
.goal-pct-badge{padding:2px 7px;border-radius:20px;font-weight:600;font-size:11px}
.goal-reached{color:var(--green);font-weight:500}
.goal-no-contrib{color:var(--text3);font-style:italic}
.goal-contrib{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:500;color:var(--text2)}
.goal-add-card{display:flex;align-items:center;justify-content:center;gap:8px;min-height:148px;border:2px dashed var(--border2);background:transparent;border-radius:var(--radius);color:var(--text3);font-size:14px;font-weight:500;cursor:pointer;width:100%;transition:all 0.18s}
.goal-add-card:hover{border-color:var(--accent);color:var(--accent);background:rgba(217,119,6,0.04);transform:translateY(-2px)}
.goal-add-card span{font-size:20px;line-height:1}
/* Sidebar panels */
.goals-sidebar{display:flex;flex-direction:column;gap:12px}
.goals-chart-bar{display:flex;align-items:center;gap:10px;margin-top:14px}
.goals-chart-toggle-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 14px;font-size:13px;color:var(--text2);cursor:pointer;transition:all 0.15s}
.goals-chart-toggle-btn:hover,.goals-chart-toggle-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.goals-chart-select{flex:1;max-width:260px}
.goals-chart-panel{margin-top:0}
.budget-settings-row{display:flex;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);width:fit-content;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.budget-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.budget-toolbar-left{display:flex;align-items:center;gap:8px}
.budget-toolbar-right{display:flex;align-items:center;gap:8px}
.budget-toolbar .select{padding:7px 28px 7px 11px;font-size:12px}
.budget-setting-item{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--text3);padding:8px 16px;border-right:1px solid var(--border)}
.budget-setting-item:last-child{border-right:none}
.budget-setting-item label{font-weight:600;white-space:nowrap;color:var(--text2);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.budget-setting-item select{background:transparent;border:none;box-shadow:none;font-size:12px;padding:0 20px 0 0;color:var(--text);font-weight:500;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23aaa'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center;cursor:pointer}
.budget-setting-toggle{padding:8px 12px}
.budget-tooltip-wrap{position:relative}
.budget-tooltip{display:none;position:absolute;bottom:calc(100% + 14px);left:50%;transform:translateX(-50%);width:280px;padding:14px 16px;background:var(--surface);color:var(--text);font-size:13px;line-height:1.6;border-radius:var(--radius);border:1px solid var(--border2);box-shadow:var(--shadow-md);pointer-events:none;z-index:200;text-transform:none;letter-spacing:normal;font-weight:400;white-space:normal;word-wrap:break-word}
.budget-tooltip::before{content:'';position:absolute;top:100%;left:50%;margin-left:-7px;border:7px solid transparent;border-top-color:var(--border2)}
.budget-tooltip::after{content:'';position:absolute;top:100%;left:50%;margin-left:-6px;border:6px solid transparent;border-top-color:var(--surface)}
.budget-tooltip-wrap:hover .budget-tooltip{display:block}
.goals-panel{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:24px;box-shadow:var(--shadow-sm)}
.goals-panel-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.09em;color:var(--text3);margin-bottom:16px}
/* Distribution */
.distrib-total-row{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.distrib-total-row label{font-size:13px;color:var(--text2);flex:1}
.distrib-mo{font-size:13px;color:var(--text3)}
.distrib-bar-wrap{height:9px;background:var(--border2);border-radius:5px;overflow:hidden;display:flex;margin-bottom:18px}
.distrib-bar-seg{height:100%;transition:width 0.3s}
.distrib-bar-unalloc{background:var(--border2)}
.distrib-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}
.distrib-row:last-of-type{border-bottom:none}
.distrib-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.distrib-label{flex:1;font-size:13px;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.distrib-inp{flex-shrink:0}
.distrib-pct{font-size:11px;color:var(--text3);min-width:32px;text-align:right}
.distrib-unalloc{display:flex;justify-content:space-between;padding:10px 0 0;font-size:12px;color:var(--text3);border-top:1px dashed var(--border);margin-top:6px}
.distrib-over{color:var(--red)}
/* Shared input wrap */
.goals-input-wrap{display:flex;align-items:center}
.goals-input-wrap span{padding:6px 8px;background:var(--bg);border:1px solid var(--border2);border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);font-size:13px;color:var(--text3)}
.goals-input-wrap input{border-radius:0 var(--radius-sm) var(--radius-sm) 0;width:80px;font-variant-numeric:tabular-nums;box-shadow:none}

/* ── Income breakdown (in Budget tab) ──────────────────── */
.income-total{font-size:28px;font-weight:800;letter-spacing:-1.2px;color:var(--green);margin-bottom:16px}
.income-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px;gap:10px}
.income-row-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text2)}
.income-row-amt{font-weight:600;color:var(--green);flex-shrink:0}
.panel-empty{font-size:12px;color:var(--text3);padding:6px 0}
/* Grid column helpers for dashboard layout */
.grid-col-1{grid-column:1}
.grid-col-2{grid-column:2}
/* Goals chart canvas wrapper */
.goals-chart-canvas-wrap{position:relative;height:280px}

/* ── Imports ─────────────────────────────────────────── */
.import-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px 20px;display:flex;align-items:center;gap:16px;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.import-icon{width:32px;height:32px;border-radius:8px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.import-icon-svg{width:14px;height:14px;color:var(--text3)}
.import-info{flex:1}
.import-filename{font-size:13px;font-weight:500;margin-bottom:3px}
.import-meta{font-size:11px;color:var(--text3);display:flex;gap:10px;flex-wrap:wrap}
.import-range{font-variant-numeric:tabular-nums}
.imports-empty{text-align:center;padding:48px;color:var(--text3);font-size:13px}

/* ── Manual transaction amount row ───────────────────── */
.amount-row{display:flex;gap:8px;align-items:center}
#manual-tx-type{width:120px}
.amount-input-wrap{display:flex;align-items:center;gap:4px;flex:1}
.amount-prefix{color:var(--text2)}
#manual-tx-amount{flex:1}
/* Recon header date cell */
.recon-hdr-date{display:flex;align-items:center;gap:8px}
#recon-select-all{cursor:pointer;accent-color:var(--accent)}
/* Categories settings modal: no padding so list goes edge-to-edge */
.modal-body-flush{padding:0}
/* Goal delete button positioning */
#goal-modal-delete{margin-right:auto}
/* Dashboard legend margin */
#dash-cat-legend{margin-top:12px}

/* ── Modal ────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.40);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.modal-overlay.hidden{display:none}
.modal{background:var(--surface);border-radius:20px;width:420px;max-width:94vw;box-shadow:0 24px 80px rgba(100,50,0,0.18),0 0 0 1px var(--border)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}
.modal-header h2{font-size:16px;font-weight:700;letter-spacing:-0.4px}
.modal-close{background:none;border:none;font-size:17px;color:var(--text3);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:7px;transition:all .12s}
.modal-close:hover{background:var(--bg);color:var(--text)}
.modal-body{padding:20px 24px}
.field{margin-bottom:18px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:.01em}
.field .hint{color:var(--text3);font-weight:400;font-size:11px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.color-picker{display:flex;flex-wrap:wrap;gap:7px}
.color-swatch{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .1s,border-color .1s}
.color-swatch:hover{transform:scale(1.15)}
.color-swatch.selected{border-color:var(--text)}
.learned-kw-wrap{display:flex;flex-wrap:wrap;gap:5px}
.learned-kw-tag{display:inline-flex;align-items:center;gap:3px;font-size:11px;padding:3px 8px 3px 9px;background:var(--green-bg);border:1px solid rgba(5,150,105,0.2);border-radius:99px;color:var(--green)}
.remove-learned-kw{background:none;border:none;color:rgba(5,150,105,0.4);font-size:13px;line-height:1;padding:0}
.remove-learned-kw:hover{color:var(--red)}

/* ── Toast ───────────────────────────────────────────── */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#2A1A08,#3D2810);color:#FCD34D;padding:11px 22px;border-radius:99px;font-size:13px;font-weight:600;z-index:2000;white-space:nowrap;box-shadow:0 8px 28px rgba(0,0,0,0.32);letter-spacing:-0.1px;border:1px solid rgba(255,200,80,0.20)}
.toast.hidden{display:none}
.toast-undo{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:99px;cursor:pointer;margin-left:8px;transition:background .12s}
.toast-undo:hover{background:rgba(255,255,255,.35)}
.undo-hint{display:none}

/* ── Scrollbars ──────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}

/* ── Global search ───────────────────────────────────── */
.global-search{position:fixed;top:0;left:216px;right:0;z-index:8000;background:rgba(0,0,0,.4);height:100vh;display:flex;flex-direction:column;align-items:center;padding-top:80px}
.global-search.hidden{display:none}
.global-search-bar{display:flex;align-items:center;gap:10px;width:min(560px,90%);background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-md)}
.global-search-bar svg{flex-shrink:0;color:var(--text3)}
.global-search-bar input{flex:1;border:none;background:none;font-size:15px;color:var(--text);outline:none}
.global-search-bar input::placeholder{color:var(--text3)}
.global-search-hint{font-size:10px;padding:2px 6px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text3);font-family:inherit}
.global-search-results{width:min(560px,90%);max-height:420px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-md)}
.gs-result{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.gs-result:hover{background:var(--bg)}
.gs-result:last-child{border-bottom:none}
.gs-result-left{flex:1;min-width:0}
.gs-result-desc{font-size:13.5px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gs-result-meta{font-size:11px;color:var(--text3);margin-top:2px}
.gs-result-amt{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}
.gs-result-amt.credit{color:var(--green)}
.gs-result-amt.debit{color:var(--text)}
.gs-empty{padding:24px;text-align:center;color:var(--text3);font-size:13px}
.gs-count{padding:8px 16px;font-size:11px;color:var(--text3);border-bottom:1px solid var(--border);background:var(--bg)}

/* ── Monthly report (CoinSpot-style) ─────────────────── */
.rpt-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px 0;margin-bottom:20px;box-shadow:var(--shadow-sm);overflow:hidden}
.rpt-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px}
.rpt-title-area{}
.rpt-month-label{font-size:13px;color:var(--text3);font-weight:500;margin-bottom:4px}
.rpt-hero-amount{font-size:42px;font-weight:800;letter-spacing:-1.5px;line-height:1.1;font-variant-numeric:tabular-nums}
.rpt-hero-change{display:inline-flex;align-items:center;gap:4px;font-size:14px;font-weight:700;margin-top:6px;padding:3px 10px;border-radius:99px}
.rpt-hero-change.up{background:rgba(180,83,9,.15);color:#B45309}
.rpt-hero-change.down{background:rgba(251,191,36,.15);color:#D97706}
.rpt-hero-change.flat{background:var(--bg);color:var(--text3)}
.rpt-period-tabs{display:flex;gap:2px;background:var(--bg);border-radius:8px;padding:3px}
.rpt-period-tab{padding:6px 14px;font-size:12px;font-weight:600;color:var(--text3);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .15s}
.rpt-period-tab:hover{color:var(--text)}
.rpt-period-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.rpt-chart-wrap{height:220px;margin:20px -32px 0;position:relative}
.rpt-chart-wrap canvas{width:100%!important;height:100%!important}
.rpt-stats{display:flex;gap:0;border:none;border-radius:var(--radius);overflow:hidden;margin-bottom:20px;background:linear-gradient(135deg,#D97706 0%,#F59E0B 40%,#FBBF24 80%,#FCD34D 100%);box-shadow:0 6px 32px rgba(217,119,6,.30);color:#fff}
.rpt-stat{flex:1;padding:16px 20px;border-right:1px solid rgba(255,255,255,.18);text-align:center}
.rpt-stat:last-child{border-right:none}
.rpt-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.65);margin-bottom:4px}
.rpt-stat-val{font-size:18px;font-weight:800;letter-spacing:-.4px;font-variant-numeric:tabular-nums;color:#fff}
.rpt-stat-sub{font-size:10px;color:var(--text3);margin-top:2px}
.rpt-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}
.rpt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm)}
.rpt-card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text3);margin-bottom:14px}
.rpt-cat-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}
.rpt-cat-row:last-child{border-bottom:none}
.rpt-cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.rpt-cat-name{flex:1;font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rpt-cat-bar{flex:0 0 80px;height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.rpt-cat-bar-fill{height:100%;border-radius:3px}
.rpt-cat-amt{font-size:13px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap}
.rpt-cat-pct{font-size:11px;color:var(--text3);width:36px;text-align:right}
.rpt-cat-clickable{cursor:pointer;transition:background .12s,padding .12s;border-radius:6px;margin:0 -8px;padding:7px 8px}
.rpt-cat-clickable:hover{background:var(--bg)}
.rpt-cat-active{font-weight:600}
.rpt-back-btn{font-size:12px;font-weight:500;color:var(--accent);cursor:pointer;margin-left:8px}
.rpt-back-btn:hover{text-decoration:underline}
.rpt-tx-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.rpt-tx-row:last-child{border-bottom:none}
.rpt-tx-left{flex:1;min-width:0}
.rpt-tx-desc{font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rpt-tx-date{font-size:11px;color:var(--text3)}
.rpt-tx-amt{font-size:13px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
@media print{
  html,body{overflow:visible!important;height:auto!important}
  html.dark{background:#fff!important;color:#000!important}
  #sidebar,#win-drag-bar,#ambient-bee,.checklist-sidebar,.toast,.modal-overlay{display:none!important}
  #app{display:block!important}
  #main-content{margin-left:0!important;padding:20px!important;overflow:visible!important}
  .tab{display:none!important}
  #tab-reports{display:block!important}
  .rpt-period-tabs{display:none!important}
  .dash-hero,.budget-kpi-bar,.panel{box-shadow:none!important;animation:none!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ── Getting started checklist ────────────────────────── */
/* ── Split transaction ────────────────────────────────── */
.split-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.split-cat{flex:1}
.split-amt-wrap{display:flex;align-items:center;gap:2px;width:100px}
.split-amt-wrap span{font-size:13px;color:var(--text3);font-weight:600}
.split-amt{width:80px;padding:6px 8px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:14px;font-weight:600;text-align:right;background:var(--surface);color:var(--text)}
.split-amt:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-bg)}
.split-row-del{width:28px;height:28px;border-radius:50%;background:none;border:1px solid var(--border2);color:var(--text3);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.split-row-del:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}

/* ── Right sidebar checklist ──────────────────────────── */
.checklist-sidebar{width:260px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;padding:52px 20px 24px;transition:width .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,padding .4s;overflow:hidden}
.checklist-sidebar.hidden{width:0;padding:0 0;opacity:0;border:none;pointer-events:none}
.checklist-sb-header{margin-bottom:12px}
.checklist-sb-title{font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.3px;margin-bottom:2px}
.checklist-sb-progress{font-size:24px;font-weight:800;color:var(--accent);letter-spacing:-.8px;margin-top:4px}
.checklist-sb-bar{height:4px;background:var(--border2);border-radius:2px;margin-bottom:20px;overflow:hidden}
.checklist-sb-bar-fill{height:100%;background:linear-gradient(90deg,#D97706,#FBBF24);border-radius:2px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.checklist-sb-items{flex:1;display:flex;flex-direction:column;gap:2px}
.checklist-sb-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:color .12s}
.checklist-sb-item:last-child{border-bottom:none}
.checklist-sb-item:hover .checklist-sb-label{color:var(--accent)}
.checklist-sb-item.done{opacity:.5;cursor:default}
.checklist-sb-item.done:hover .checklist-sb-label{color:var(--text3)}
.checklist-sb-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;margin-top:1px;transition:all .25s}
.checklist-sb-item.done .checklist-sb-check{background:var(--accent);border-color:var(--accent);color:#fff}
.checklist-sb-label{font-size:12.5px;font-weight:500;color:var(--text2);line-height:1.4;transition:color .12s}
.checklist-sb-item.done .checklist-sb-label{text-decoration:line-through;color:var(--text3)}
.checklist-sb-footer{margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}
.checklist-sb-dismiss{background:none;border:none;font-size:11px;color:var(--text3);cursor:pointer;padding:0;transition:color .12s}
.checklist-sb-dismiss:hover{color:var(--accent)}
.checklist-celebrate{text-align:center;padding:16px 8px;opacity:0;transform:scale(.8);transition:opacity .5s ease,transform .5s cubic-bezier(.22,1.1,.6,1)}
.checklist-celebrate.show{opacity:1;transform:scale(1)}
.checklist-celebrate-icon{font-size:36px;margin-bottom:6px;animation:celebrate-bounce .6s ease}
.checklist-celebrate-text{font-size:16px;font-weight:800;color:#D97706;margin-bottom:2px}
.checklist-celebrate-sub{font-size:11px;color:var(--text3)}
@keyframes celebrate-bounce{0%{transform:scale(0) rotate(-10deg)}50%{transform:scale(1.3) rotate(5deg)}100%{transform:scale(1) rotate(0)}}

/* ── Bank connection ─────────────────────────────────── */
.bank-btn{border:1px solid var(--border2);border-radius:10px;padding:10px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-family:inherit}
.bank-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(180,120,40,.12);border-color:var(--accent)}
.bank-btn:active{transform:translateY(0);box-shadow:none}
.bank-btn-logo{width:100%;overflow:hidden;flex-shrink:0}
.bank-btn-logo svg{width:100%;height:auto;display:block;border-radius:6px}
.bank-btn-name{display:none}

/* ── Settings ────────────────────────────────────────── */
.settings-grid{display:flex;flex-direction:column;gap:20px;max-width:100%}
.settings-section{padding:0;border:none;box-shadow:none;background:transparent;overflow:visible}
.settings-section .panel-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:0;padding:0 0 10px}
.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .12s}
.settings-row:last-child{border-bottom:none}
.settings-row:hover{background:var(--bg)}
.settings-label{font-size:13px;color:var(--text);font-weight:500;flex:1}
.settings-hint{font-size:11px;color:var(--text3);margin-top:4px;line-height:1.5;font-weight:400}
.settings-keywords{display:flex;flex-wrap:wrap;gap:6px}
.settings-kw-tag{font-size:12px;padding:5px 12px;background:linear-gradient(135deg,rgba(217,119,6,0.08),rgba(251,191,36,0.08));color:var(--accent);border:1px solid rgba(217,119,6,0.15);border-radius:99px;display:flex;align-items:center;gap:6px;font-weight:600;transition:all .15s}
.settings-kw-tag:hover{background:rgba(217,119,6,0.12);border-color:rgba(217,119,6,0.25)}
.settings-kw-del{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;padding:0;line-height:1;opacity:.5;transition:opacity .12s}
.settings-kw-del:hover{opacity:1}
.settings-section-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#D97706,#FBBF24);color:#fff;font-size:14px;margin-right:8px;flex-shrink:0}

/* ── Ambient bee ─────────────────────────────────────── */
#ambient-bee{position:fixed;z-index:8900;pointer-events:none;will-change:top,left,transform;opacity:0}
html.dark #ambient-bee{filter:drop-shadow(0 0 8px rgba(251,191,36,0.6)) drop-shadow(0 0 18px rgba(217,119,6,0.4)) drop-shadow(0 0 30px rgba(251,191,36,0.2))}
.ambient-bee-wrap{display:inline-block;transform-origin:center center}
@keyframes bee-head-look{
  0%  {transform:translateY(0px) rotate(0deg)}
  20% {transform:translateY(-2px) rotate(-2.5deg)}
  45% {transform:translateY(-1px) rotate(2deg)}
  65% {transform:translateY(-2.5px) rotate(-1.5deg)}
  85% {transform:translateY(-1px) rotate(1.5deg)}
  100%{transform:translateY(0px) rotate(0deg)}
}
.ambient-bee-wrap.bee-landed{animation:bee-head-look 3.4s ease-in-out infinite}

/* ── Product tour ────────────────────────────────────── */
.ob-hidden{display:none!important}
.ob-spot{position:fixed;background:rgba(18,10,4,.70);z-index:9000;pointer-events:all;transition:top .36s cubic-bezier(.4,0,.2,1),left .36s cubic-bezier(.4,0,.2,1),width .36s cubic-bezier(.4,0,.2,1),height .36s cubic-bezier(.4,0,.2,1)}
.ob-bee{position:fixed;z-index:9005;pointer-events:none;will-change:transform,top,left}
.ob-frame{position:fixed;z-index:9001;pointer-events:none;border:2px solid var(--accent);border-radius:10px;box-shadow:0 0 0 4px rgba(217,119,6,.18),0 0 28px rgba(217,119,6,.24);transition:top .38s cubic-bezier(.4,0,.2,1),left .38s cubic-bezier(.4,0,.2,1),width .38s cubic-bezier(.4,0,.2,1),height .38s cubic-bezier(.4,0,.2,1),opacity .25s ease;animation:ob-ring-pulse 2.5s ease infinite}
.ob-frame.ob-frame-hidden{opacity:0}
@keyframes ob-ring-pulse{0%,100%{box-shadow:0 0 0 4px rgba(217,119,6,.18),0 0 28px rgba(217,119,6,.22)}50%{box-shadow:0 0 0 7px rgba(217,119,6,.08),0 0 40px rgba(245,158,11,.14)}}
.ob-tooltip{position:fixed;z-index:9002;width:305px;background:var(--surface);border-radius:16px;padding:24px 24px 20px;box-shadow:0 24px 72px rgba(0,0,0,.28),0 0 0 1px var(--border);transition:top .38s cubic-bezier(.4,0,.2,1),left .38s cubic-bezier(.4,0,.2,1),transform .38s cubic-bezier(.4,0,.2,1),opacity .2s ease;-webkit-app-region:no-drag}
.ob-caret{position:absolute;width:11px;height:11px;background:var(--surface);transform:rotate(45deg)}
.ob-caret.ob-cl{left:-5px;top:50%;margin-top:-5px;box-shadow:-1px 1px 0 var(--border)}
.ob-caret.ob-cr{right:-5px;top:50%;margin-top:-5px;box-shadow:1px -1px 0 var(--border)}
.ob-caret.ob-ct{top:-5px;left:50%;margin-left:-5px;box-shadow:-1px -1px 0 var(--border)}
.ob-tip-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:8px;opacity:.85}
.ob-tip-title{font-size:17px;font-weight:700;letter-spacing:-.4px;color:var(--text);margin-bottom:8px;line-height:1.3}
.ob-tip-desc{font-size:13px;color:var(--text2);line-height:1.65;margin-bottom:20px}
.ob-tip-dots{display:flex;gap:5px;margin-bottom:16px}
.ob-dot{width:6px;height:6px;border-radius:99px;background:var(--border2);transition:all .3s cubic-bezier(.34,1.4,.64,1)}
.ob-dot.active{background:var(--accent);width:20px}
.ob-tip-footer{display:flex;align-items:center;justify-content:space-between}
.ob-tip-footer-btns{display:flex;gap:6px}
.ob-skip-btn{background:none;border:none;font-size:12px;color:var(--text3);cursor:pointer;padding:0;font-family:inherit;transition:color .12s;letter-spacing:-.1px}
.ob-skip-btn:hover{color:var(--text2)}
.ob-next-btn{padding:8px 20px;font-size:13px;font-weight:600;border-radius:9px;letter-spacing:-.1px}
.ob-prev-btn{padding:8px 14px;font-size:13px}

/* ── Dark mode extras ────────────────────────────────── */
html.dark .data-table-header{background:#1A1410}
html.dark .data-table-footer{background:#1A1410}
html.dark .stat-card{background:#241C14}
html.dark .panel{background:#241C14}
html.dark .goal-card{background:#241C14}
html.dark .checklist-sidebar{background:#241C14;border-color:rgba(255,200,80,0.07)}
html.dark .checklist-sb-check{border-color:rgba(255,200,80,0.2)}
html.dark .checklist-sb-label{color:rgba(255,255,255,.6)}
html.dark .settings-card{background:#241C14;border-color:rgba(255,200,80,0.07)}
html.dark .settings-row:hover{background:rgba(255,200,80,0.04)}
html.dark .modal{background:#241C14}
html.dark .modal-header{border-color:rgba(255,200,80,0.07)}
html.dark .budget-kpi-label{color:rgba(255,255,255,.7)}
html.dark .rpt-stat-label{color:rgba(255,255,255,.7)}
html.dark .goals-hero-label{color:rgba(255,255,255,.7)}
html.dark .panel-title{color:var(--accent-lt)}
html.dark .goals-panel{background:#241C14}
html.dark .recon-table-wrap{background:#241C14}
html.dark .recon-row:hover{background:#1A1410}
html.dark .recon-table-hdr{background:#1A1410}
html.dark .recon-cat-select{background:#1A1410}
html.dark .recon-search-wrap{background:#1A1410}
html.dark .nw-bar{background:#241C14}
html.dark .import-card{background:#241C14}
html.dark .btn-danger{color:#F87171;border-color:rgba(248,113,113,0.3)}
html.dark .btn-danger:hover{background:rgba(248,113,113,0.1)}

/* ── Premium animations ──────────────────────────────── */

/* Slide-up fade for list items */
@keyframes row-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Dashboard hero: subtle glow pulse when in profit */
@keyframes hero-glow{0%,100%{box-shadow:0 4px 24px rgba(217,119,6,.28)}50%{box-shadow:0 4px 40px rgba(251,191,36,.45),0 0 0 1px rgba(255,255,255,.06)}}
.dash-hero-pos{animation:hero-glow 3.5s ease-in-out infinite}

/* Amber hero glow for neutral state */
@keyframes hero-glow-amber{0%,100%{box-shadow:0 4px 24px rgba(217,119,6,.28)}50%{box-shadow:0 4px 40px rgba(245,158,11,.48),0 0 0 1px rgba(255,255,255,.06)}}
.dash-hero-neu{animation:hero-glow-amber 3.5s ease-in-out infinite}

/* KPI values pop up on render */
@keyframes val-pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.budget-kpi-value{animation:val-pop .3s cubic-bezier(.22,1.1,.6,1) both}
.budget-kpi:nth-child(1) .budget-kpi-value{animation-delay:.04s}
.budget-kpi:nth-child(2) .budget-kpi-value{animation-delay:.09s}
.budget-kpi:nth-child(3) .budget-kpi-value{animation-delay:.14s}
.budget-kpi:nth-child(4) .budget-kpi-value{animation-delay:.19s}

/* Budget table rows stagger in */
.data-row{animation:row-in .22s ease both}
.data-row:nth-child(1){animation-delay:.03s}
.data-row:nth-child(2){animation-delay:.06s}
.data-row:nth-child(3){animation-delay:.09s}
.data-row:nth-child(4){animation-delay:.12s}
.data-row:nth-child(5){animation-delay:.15s}
.data-row:nth-child(6){animation-delay:.18s}
.data-row:nth-child(7){animation-delay:.21s}
.data-row:nth-child(8){animation-delay:.24s}
.data-row:nth-child(9){animation-delay:.27s}
.data-row:nth-child(n+10){animation-delay:.29s}

/* Insight cards stagger in */
.insight-card{animation:row-in .28s ease both}
.insight-card:nth-child(1){animation-delay:.03s}
.insight-card:nth-child(2){animation-delay:.07s}
.insight-card:nth-child(3){animation-delay:.11s}
.insight-card:nth-child(4){animation-delay:.15s}
.insight-card:nth-child(5){animation-delay:.19s}
.insight-card:nth-child(6){animation-delay:.23s}

/* Heatmap cells stagger in */
.heatmap-cell{animation:row-in .32s ease both}
.heatmap-cell:nth-child(1){animation-delay:.04s}
.heatmap-cell:nth-child(2){animation-delay:.09s}
.heatmap-cell:nth-child(3){animation-delay:.14s}
.heatmap-cell:nth-child(4){animation-delay:.19s}
.heatmap-cell:nth-child(5){animation-delay:.24s}
.heatmap-cell:nth-child(6){animation-delay:.29s}
.heatmap-cell:nth-child(7){animation-delay:.34s}

/* Goal cards stagger in */
.goal-card{transition:box-shadow .2s ease,transform .2s ease;animation:row-in .3s ease both}
.goal-card:nth-child(1){animation-delay:.04s}
.goal-card:nth-child(2){animation-delay:.09s}
.goal-card:nth-child(3){animation-delay:.14s}
.goal-card:nth-child(4){animation-delay:.19s}
.goal-card:nth-child(n+5){animation-delay:.23s}

/* Goals hero stats pop */
.goals-hero-stat{animation:row-in .3s ease both}
.goals-hero-stat:nth-child(1){animation-delay:.05s}
.goals-hero-stat:nth-child(2){animation-delay:.10s}
.goals-hero-stat:nth-child(3){animation-delay:.15s}
.goals-hero-stat:nth-child(4){animation-delay:.20s}
.goals-hero-stat:nth-child(5){animation-delay:.25s}

/* Import cards stagger */
.import-card{animation:row-in .25s ease both;transition:box-shadow .15s ease,transform .15s ease}
.import-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}

/* Account rows stagger */
.account-row{animation:row-in .2s ease both}

/* Modal entry animation */
@keyframes modal-in{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-overlay:not(.hidden) .modal{animation:modal-in .2s cubic-bezier(.22,1.1,.6,1) both}

/* Toast slides up on show */
@keyframes toast-slide-in{from{opacity:0;transform:translateX(-50%) translateY(10px) scale(.97)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}
.toast:not(.hidden){animation:toast-slide-in .22s cubic-bezier(.22,1.1,.6,1) both}

/* Smooth bar transitions */
.budget-bar-spent{transition:width .65s cubic-bezier(.4,0,.2,1)!important}
.goal-fill{transition:width .7s cubic-bezier(.4,0,.2,1)!important}
.runway-fill{transition:width .65s cubic-bezier(.4,0,.2,1)!important}

/* ── Mobile responsive ──────────────────────────────── */
@media(max-width:768px){
  #app{flex-direction:column}
  #sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%!important;height:auto;z-index:100;flex-direction:row;padding:0;border-right:none;border-top:1px solid var(--border);-webkit-app-region:no-drag;overflow-x:auto;-webkit-overflow-scrolling:touch}
  #sidebar .sidebar-top{display:none}
  #sidebar .sidebar-footer{display:none}
  #sidebar .sidebar-nav{display:flex;flex-direction:row;gap:0;width:100%;padding:0}
  #sidebar .nav-item{font-size:10px;padding:8px 4px;flex:1;text-align:center;white-space:nowrap;border-left:none!important;border-bottom:2px solid transparent;justify-content:center}
  #sidebar .nav-item.active{border-bottom-color:var(--accent);border-left-color:transparent!important;background:none}
  #sidebar .nav-item svg{display:none}
  #win-drag-bar{display:none}
  #main-content{padding:16px 12px 72px}
  .tab-header{flex-direction:column;gap:8px;padding-bottom:12px}
  .header-controls{flex-wrap:wrap;gap:6px}
  .dash-hero{flex-direction:column;padding:20px 16px;gap:16px}
  .dash-hero-amount{font-size:32px}
  .dash-hero-stats{flex-wrap:wrap;gap:0}
  .dash-hs{padding:10px 12px;min-width:45%}
  .dash-hs-val{font-size:16px}
  .budget-kpi-bar{display:flex;flex-direction:column;gap:8px}
  .budget-kpi{padding:10px 14px}
  .budget-toolbar{flex-direction:column;align-items:stretch;gap:8px}
  .budget-toolbar-left,.budget-toolbar-right{flex-wrap:wrap;gap:6px}
  .bva-grid{grid-template-columns:24px 1fr 90px!important;font-size:13px}
  .sparkline-cell,.bva-grid>div:nth-child(4){display:none}
  .data-table-header.bva-grid>div:nth-child(4){display:none}
  .data-table-footer.bva-grid>div:nth-child(4){display:none}
  .data-row{padding:10px 12px}
  .settings-grid{gap:14px}
  .settings-card{padding:0}
  .settings-row{padding:12px 14px;flex-direction:column;align-items:flex-start;gap:8px}
  .modal{width:95vw;max-height:85vh;margin:8px}
  .goals-main{grid-template-columns:1fr!important}
  .goals-hero{flex-direction:column;gap:12px}
  .goals-hero-stat{padding:8px 12px}
  .goal-card{padding:16px 14px}
  .nw-bar{flex-direction:column;padding:16px 14px;gap:12px}
  #dash-donut-chart{width:120px!important;height:120px!important}
  .recon-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .recon-row{font-size:12px}
  .import-card{flex-direction:column;align-items:flex-start;gap:8px;padding:14px}
  .surplus-hero{padding:16px 14px}
  .checklist-sidebar{display:none}
  .global-search{left:0!important;right:0!important}
  .global-search-bar{width:95vw}
  .ob-tooltip{width:85vw;left:50%!important;transform:translateX(-50%)}
}
@media(max-width:480px){
  #main-content{padding:12px 8px 72px}
  .dash-hero-amount{font-size:28px}
  .bva-grid{grid-template-columns:20px 1fr 80px!important}
  .inline-budget{width:52px;font-size:13px}
  .modal{width:98vw}
  #sidebar .nav-item{font-size:9px;padding:6px 2px}
}

/* Net worth value pop */
.nw-value{animation:val-pop .4s cubic-bezier(.22,1.1,.6,1) both;animation-delay:.05s}

/* Sidebar nav items: smoother active transition */
.nav-item{transition:background .15s,color .15s,transform .1s}
.nav-item:active{transform:scale(.97)}

/* Button press micro-feedback */
.btn-primary:active{transform:scale(.96) translateY(0);transition:transform .08s,background .12s,box-shadow .08s;box-shadow:0 1px 3px rgba(217,119,6,0.22)}
.btn-ghost:active{transform:scale(.97);transition:transform .08s}
.sidebar-btn:active{transform:scale(.97)}

/* Tab heading slide in */
.tab-header h1{animation:val-pop .3s cubic-bezier(.22,1.1,.6,1) both}

/* Smooth color swatches */
.color-swatch{transition:transform .12s,box-shadow .12s}
.color-swatch:hover{transform:scale(1.18);box-shadow:0 2px 8px rgba(0,0,0,.18)}
.color-swatch.selected{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--text)}

/* Inline budget input hover glow */
.inline-budget:hover,.inline-budget:focus{box-shadow:0 0 0 2px var(--accent-bg)}

/* recon-progress smooth */
.recon-progress-fill{transition:width .5s cubic-bezier(.4,0,.2,1)}

/* Category legend stagger */
.cat-legend-item{animation:row-in .25s ease both;display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:13px}
.cat-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cat-legend-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text2)}
.cat-legend-val{font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
.cat-legend-pct{color:var(--text3);font-size:11px;min-width:30px;text-align:right}

/* Smooth nw-acc card */
/* Small account pills (overflow on net worth hero) */
.nw-acc-sm{font-size:12px;font-weight:600;color:rgba(255,255,255,.85);padding:5px 12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.08);border-radius:99px}
/* Manage accounts modal */
.ma-row{display:flex;align-items:center;gap:12px;padding:12px 24px;border-bottom:1px solid var(--border)}
.ma-row:last-child{border-bottom:none}
.ma-row:hover{background:var(--bg)}
.ma-info{flex:1;min-width:0}
.ma-name{font-size:13px;font-weight:600;color:var(--text)}
.ma-type{font-size:11px;color:var(--text3)}
.ma-balance-wrap{display:flex;align-items:center;gap:2px}
.ma-dollar{font-size:13px;color:var(--text3);font-weight:600}
.ma-balance-input{width:100px;padding:6px 8px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text);background:var(--surface);text-align:right;font-variant-numeric:tabular-nums}
.ma-balance-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-bg)}
.ma-del{width:28px;height:28px;border-radius:50%;background:none;border:1px solid var(--border2);color:var(--text3);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.ma-del:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}
.nw-acc{transition:box-shadow .15s,transform .15s;position:relative}
.nw-acc:hover{box-shadow:0 2px 10px rgba(120,60,10,.10);transform:translateY(-1px)}
.nw-acc-del{display:none;position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#D97706,#FBBF24);color:#fff;border:1px solid rgba(255,255,255,.3);font-size:11px;line-height:1;cursor:pointer;padding:0;box-shadow:0 2px 6px rgba(140,80,10,.25);transition:transform .15s}
.nw-acc-del:hover{transform:scale(1.15)}
.nw-acc:hover .nw-acc-del{display:flex;align-items:center;justify-content:center}

/* Recon row assigned flash */
@keyframes row-assigned{0%{background:rgba(5,150,105,.16)}100%{background:transparent}}
.recon-row.just-assigned{animation:row-assigned .8s ease forwards}
