*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0c0e14;--bg2:#111318;--bg3:#161820;
  --card:#1a1d27;--card2:#1f2235;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
  --text:#eef0f8;--text2:rgba(238,240,248,0.65);--text3:rgba(238,240,248,0.35);
  --green:#00e5a0;--green-bg:rgba(0,229,160,0.1);
  --red:#ff5c7a;--red-bg:rgba(255,92,122,0.1);
  --blue:#4d9fff;--blue-bg:rgba(77,159,255,0.1);
  --yellow:#ffd166;--yellow-bg:rgba(255,209,102,0.1);
  --purple:#a78bfa;--purple-bg:rgba(167,139,250,0.1);
  --accent:#4d9fff;--radius:12px;--sidebar:240px;
  --shadow:0 8px 32px rgba(0,0,0,0.4);
}
:root[data-theme="light"]{
  --bg:#f5f7fb;--bg2:#ffffff;--bg3:#eef1f7;
  --card:#ffffff;--card2:#f0f3fa;
  --border:rgba(16,20,30,0.08);--border2:rgba(16,20,30,0.16);
  --text:#0e1220;--text2:rgba(14,18,32,0.65);--text3:rgba(14,18,32,0.45);
  --green:#00a878;--green-bg:rgba(0,168,120,0.12);
  --red:#e23a5b;--red-bg:rgba(226,58,91,0.1);
  --blue:#2d7fe8;--blue-bg:rgba(45,127,232,0.1);
  --yellow:#d99d2b;--yellow-bg:rgba(217,157,43,0.12);
  --purple:#7c5cf2;--purple-bg:rgba(124,92,242,0.1);
  --accent:#2d7fe8;--shadow:0 8px 32px rgba(16,20,30,0.12);
}
html{scroll-behavior:smooth}
body{font-family:'Sora',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;transition:background 0.2s,color 0.2s}
button{font-family:inherit}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* AUTH */
#auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);
  background-image:radial-gradient(ellipse at 20% 50%,rgba(77,159,255,0.07) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 20%,rgba(0,229,160,0.05) 0%,transparent 50%)}
.auth-box{width:100%;max-width:420px;padding:48px 40px;background:var(--card);border:1px solid var(--border);border-radius:24px;text-align:center}
.auth-logo{font-size:32px;font-weight:700;letter-spacing:-1px;margin-bottom:8px}
.auth-logo span{color:var(--green)}
.auth-tagline{font-size:13px;color:var(--text2);margin-bottom:40px;font-weight:300}
.google-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 24px;
  background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);font-size:14px;font-weight:500;
  color:var(--text);cursor:pointer;transition:all 0.2s}
.google-btn:hover{background:var(--bg3);border-color:var(--accent);box-shadow:0 0 20px rgba(77,159,255,0.1)}
.google-btn svg{width:20px;height:20px;flex-shrink:0}
.auth-note{font-size:11px;color:var(--text3);margin-top:20px;line-height:1.6}

/* APP */
#app{display:none;min-height:100vh}
.layout{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--sidebar);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-logo{padding:24px 20px 20px;font-size:20px;font-weight:700;letter-spacing:-0.5px;border-bottom:1px solid var(--border)}
.sidebar-logo span{color:var(--green)}
.sidebar-user{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:600;flex-shrink:0;overflow:hidden;color:#fff}
.user-avatar img{width:100%;height:100%;object-fit:cover}
.user-meta{min-width:0;flex:1}
.user-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-email{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav{padding:16px 12px;flex:1}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  font-size:13px;font-weight:400;color:var(--text2);cursor:pointer;transition:all 0.15s;margin-bottom:2px;
  border:1px solid transparent;background:none;width:100%;text-align:left}
.nav-item:hover{background:var(--card);color:var(--text)}
.nav-item[aria-current="page"]{background:var(--blue-bg);color:var(--blue);border-color:rgba(77,159,255,0.15);font-weight:500}
.nav-item svg{width:16px;height:16px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.8}
.nav-section{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);padding:12px 12px 6px;margin-top:8px}
.sidebar-bottom{padding:16px 12px;border-top:1px solid var(--border)}
.logout-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  font-size:13px;color:var(--text3);cursor:pointer;transition:all 0.2s;width:100%;background:none;border:none}
.logout-btn:hover{color:var(--red);background:var(--red-bg)}
.logout-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}

/* MAIN */
.main{flex:1;overflow-x:hidden;min-width:0}
.page{display:none;padding:32px;animation:fadeIn 0.25s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.page-header{margin-bottom:28px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-title{font-size:22px;font-weight:700;letter-spacing:-0.5px}
.page-sub{font-size:13px;color:var(--text2);margin-top:4px;font-weight:300}
.header-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;
  font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all 0.15s;text-decoration:none;white-space:nowrap}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 0 20px rgba(77,159,255,0.25)}
.btn-ghost{background:var(--card);color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover:not(:disabled){border-color:var(--border2);color:var(--text)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(255,92,122,0.2)}
.btn-danger:hover:not(:disabled){background:rgba(255,92,122,0.2)}
.btn-sm{padding:7px 14px;font-size:12px}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.card-sm{padding:16px}

/* SUMMARY */
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:28px}
.summary-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden}
.summary-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.summary-card.income::before{background:var(--green)}
.summary-card.expense::before{background:var(--red)}
.summary-card.balance::before{background:var(--blue)}
.summary-card.savings::before{background:var(--yellow)}
.summary-card.transfer::before{background:var(--purple)}
.sc-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text3);margin-bottom:8px}
.sc-val{font-size:24px;font-weight:700;letter-spacing:-0.5px;font-family:'JetBrains Mono',monospace}
.sc-val.income{color:var(--green)}
.sc-val.expense{color:var(--red)}
.sc-val.balance{color:var(--blue)}
.sc-val.savings{color:var(--yellow)}
.sc-val.transfer{color:var(--purple)}
.sc-change{font-size:11px;color:var(--text3);margin-top:6px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.chart-title{font-size:14px;font-weight:600}
.chart-wrap{position:relative;height:220px}

/* FILTER TABS */
.filter-tabs{display:flex;gap:4px;background:var(--bg2);padding:4px;border-radius:10px;border:1px solid var(--border)}
.ftab{padding:6px 14px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text2);
  transition:all 0.15s;border:none;background:none}
.ftab[aria-pressed="true"]{background:var(--card2);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,0.15)}

/* TRANSACTIONS TABLE */
.tx-table{width:100%;border-collapse:collapse}
.tx-table th{text-align:left;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text3);
  padding:10px 12px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:1}
.tx-table td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}
.tx-table tr:last-child td{border-bottom:none}
.tx-table tr:hover td{background:rgba(127,127,127,0.04)}
.tx-cat-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:500}
.tx-cat-badge.transfer-badge{background:var(--blue-bg);color:var(--blue)}
.tx-amount{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:500}
.tx-amount.inc{color:var(--green)}
.tx-amount.exp{color:var(--red)}
.tx-amount.tr{color:var(--blue)}
.tx-extras{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.tx-extras .chip{display:inline-flex;align-items:center;gap:4px;padding:1px 8px;border-radius:6px;font-size:10px;font-weight:500;line-height:1.5}
.tx-note{font-size:12px;color:var(--text3);max-width:220px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-date{font-size:11px;color:var(--text3);font-family:'JetBrains Mono',monospace;white-space:nowrap}
.tx-actions{display:flex;gap:6px;justify-content:flex-end}
@media(hover:hover){.tx-actions{opacity:0;transition:opacity 0.15s}.tx-table tr:hover .tx-actions,.tx-table tr:focus-within .tx-actions{opacity:1}}
.icon-btn{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;
  border:none;cursor:pointer;transition:all 0.15s;background:var(--bg2);color:var(--text2)}
.icon-btn.edit:hover{background:var(--blue-bg);color:var(--blue)}
.icon-btn.del:hover{background:var(--red-bg);color:var(--red)}
.icon-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:11px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase;color:var(--text3)}
.form-input,.form-select,.form-textarea{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:11px 14px;
  font-size:13px;font-family:'Sora',sans-serif;color:var(--text);outline:none;width:100%;transition:border-color 0.15s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text3)}
.form-select option{background:var(--bg2);color:var(--text)}
.form-textarea{min-height:80px;resize:vertical}
.form-hint{font-size:11px;color:var(--text3)}
.checkbox-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;cursor:pointer}
.checkbox-row input{accent-color:var(--accent)}
.type-toggle{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:0;background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.type-opt{padding:11px;text-align:center;cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);
  transition:all 0.15s;border:none;background:none}
.type-opt[aria-pressed="true"].inc{background:var(--green-bg);color:var(--green)}
.type-opt[aria-pressed="true"].exp{background:var(--red-bg);color:var(--red)}
.type-opt[aria-pressed="true"].tx{background:var(--blue-bg);color:var(--blue)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center;
  z-index:1000;padding:20px;backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity 0.2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--card);border:1px solid var(--border2);border-radius:20px;padding:28px;width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;transform:translateY(16px);transition:transform 0.2s;box-shadow:var(--shadow)}
.modal-overlay.open .modal{transform:none}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.modal-title{font-size:16px;font-weight:700;letter-spacing:-0.3px}
.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--bg2);color:var(--text2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:16px;transition:all 0.15s}
.modal-close:hover{background:var(--red-bg);color:var(--red)}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}
.confirm-msg{font-size:14px;color:var(--text2);line-height:1.5}

/* CATEGORIES */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:20px}
.cat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;
  display:flex;align-items:center;gap:12px;transition:border-color 0.15s}
.cat-card:hover{border-color:var(--border2)}
.cat-emoji{font-size:22px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border-radius:10px;flex-shrink:0}
.cat-info{flex:1;min-width:0}
.cat-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-type{font-size:11px;color:var(--text3);margin-top:2px;text-transform:capitalize}
.cat-actions{display:flex;gap:4px;flex-shrink:0}

/* REPORTS */
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
.top-cats{margin-top:20px}
.top-cat-item{display:flex;align-items:center;gap:12px;padding:12px 6px;border-bottom:1px solid var(--border);transition:background 0.15s;border-radius:6px;margin:0 -6px}
.top-cat-item:last-child{border-bottom:none}
.top-cat-item.clickable{cursor:pointer}
.top-cat-item.clickable:hover{background:rgba(127,127,127,0.06)}
.tc-name{font-size:13px;color:var(--text2);min-width:130px;max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-bar-wrap{flex:1;height:6px;background:var(--bg2);border-radius:3px;overflow:hidden}
.tc-bar{height:100%;border-radius:3px;transition:width 0.5s ease}
.tc-pct{font-size:11px;color:var(--text3);font-family:'JetBrains Mono',monospace;width:40px;text-align:right;flex-shrink:0}
.tc-amt{font-size:12px;font-family:'JetBrains Mono',monospace;color:var(--text2);width:100px;text-align:right;flex-shrink:0}

/* BUDGETS */
.budget-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;margin-top:20px}
.budget-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.budget-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.budget-cat{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.budget-emoji{font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border-radius:9px;flex-shrink:0}
.budget-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.budget-sub{font-size:11px;color:var(--text3)}
.budget-bar{height:8px;background:var(--bg2);border-radius:4px;overflow:hidden;margin:10px 0 8px}
.budget-bar-fill{height:100%;border-radius:4px;transition:width 0.4s ease}
.budget-bar-fill.ok{background:var(--green)}
.budget-bar-fill.warn{background:var(--yellow)}
.budget-bar-fill.over{background:var(--red)}
.budget-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);font-family:'JetBrains Mono',monospace}
.budget-stats .over{color:var(--red)}

/* RECURRING */
.rec-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.rec-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px}
.rec-main{flex:1;min-width:0}
.rec-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-sub{font-size:11px;color:var(--text3);margin-top:2px}

/* EMPTY */
.empty{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-icon{font-size:40px;margin-bottom:12px}
.empty-text{font-size:14px;margin-bottom:20px}

/* SEARCH */
.tx-controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}
.search-wrap{position:relative;flex:1;min-width:200px}
.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;stroke:var(--text3);fill:none;stroke-width:2;pointer-events:none}
.search-input{padding-left:36px!important}

/* TOAST */
#toast{position:fixed;bottom:24px;right:24px;z-index:9999;background:var(--card2);border:1px solid var(--border2);
  padding:12px 20px;border-radius:12px;font-size:13px;transform:translateY(20px);opacity:0;
  transition:all 0.25s;pointer-events:none;box-shadow:var(--shadow);max-width:420px;
  display:flex;align-items:center;gap:12px}
#toast.show{transform:none;opacity:1;pointer-events:auto}
#toast.success{border-color:rgba(0,229,160,0.3);color:var(--green)}
#toast.error{border-color:rgba(255,92,122,0.3);color:var(--red)}
#toast.info{border-color:var(--border2);color:var(--text)}
#toast .undo-btn{background:transparent;border:1px solid currentColor;color:inherit;
  padding:4px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;
  font-family:inherit;transition:background 0.15s}
#toast .undo-btn:hover{background:rgba(127,127,127,0.15)}

/* LOADING */
#loading{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;
  z-index:9999;flex-direction:column;gap:16px}
.spinner{width:36px;height:36px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* MOBILE */
.mob-header{display:none;padding:16px 20px;background:var(--bg2);border-bottom:1px solid var(--border);
  align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.mob-menu-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:4px}
.mob-menu-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:99;backdrop-filter:blur(2px)}

/* LOAD MORE */
.load-more{display:flex;justify-content:center;padding:20px}

/* SETTINGS */
.setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--border)}
.setting-row:last-child{border-bottom:none}
.setting-label{font-size:13px;font-weight:500}
.setting-desc{font-size:11px;color:var(--text3);margin-top:2px}
.setting-control{flex-shrink:0;min-width:160px}

/* COLOR PICKER */
.color-picker{display:flex;gap:8px;flex-wrap:wrap}
.color-opt{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform 0.15s}
.color-opt:hover{transform:scale(1.1)}
.color-opt[aria-pressed="true"]{border-color:#fff;box-shadow:0 0 0 1px var(--accent)}

/* KBD */
kbd{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text2)}

/* PERIOD BAR (Reports) */
.period-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.period-step{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text2);
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.15s}
.period-step:hover:not(:disabled){border-color:var(--border2);color:var(--text);background:var(--card2)}
.period-step:disabled{opacity:0.35;cursor:not-allowed}
.period-step svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}
.period-label{font-size:13px;color:var(--text2);font-weight:500;margin-top:8px}
.period-custom{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}
.period-custom .form-input{width:auto}
.period-custom-sep{font-size:12px;color:var(--text3)}

/* PERSON CHIP PICKER (share editor) */
.person-chips{display:flex;gap:6px;flex-wrap:wrap;min-height:32px}
.person-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 8px 5px 10px;border-radius:8px;font-size:12px;font-weight:500}
.person-chip-x{background:transparent;border:none;color:inherit;cursor:pointer;padding:0;margin-left:2px;font-size:12px;opacity:0.6;line-height:1}
.person-chip-x:hover{opacity:1}
.person-add-row{display:flex;gap:8px;align-items:center;margin-top:8px}
.person-add-row select{flex:1;max-width:280px}
.equal-toggle{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12px;color:var(--text2)}
.equal-toggle input{accent-color:var(--accent)}
.shares-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.share-row{display:grid;grid-template-columns:1fr 100px auto;align-items:center;gap:8px;padding:6px 10px;background:var(--bg2);border-radius:8px}
.share-name{font-size:13px}
.share-pct{padding:6px 10px;font-size:13px;text-align:right}
.share-suffix{color:var(--text3);font-size:13px}
.share-sum{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 10px;font-size:12px;color:var(--text2)}
.share-sum.bad{color:var(--red)}
.share-sum.ok{color:var(--green)}

/* EMOJI HINT */
.emoji-hint{font-size:10px;color:var(--text3);margin-top:4px;font-family:'JetBrains Mono',monospace}

/* BREAKDOWN CARDS (Reports — by Person / by Account) */
.breakdown-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.bd-card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.bd-card[open]{border-color:var(--border2)}
.bd-summary{display:grid;grid-template-columns:auto 1fr auto auto auto;align-items:center;gap:12px;
  padding:12px 14px;cursor:pointer;list-style:none;user-select:none}
.bd-summary::-webkit-details-marker{display:none}
.bd-summary:hover{background:rgba(127,127,127,0.04)}
.bd-emoji{font-size:18px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}
.bd-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bd-total{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:var(--text)}
.bd-pct{font-size:11px;color:var(--text3);font-family:'JetBrains Mono',monospace;min-width:36px;text-align:right}
.bd-chev{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;color:var(--text3);transition:transform 0.2s}
.bd-card[open] .bd-chev{transform:rotate(180deg)}
.bd-body{padding:0 14px 14px;border-top:1px solid var(--border)}
.bd-cat-row{display:grid;grid-template-columns:140px 1fr 36px 90px;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.bd-cat-row:last-child{border-bottom:none}
.bd-cat-name{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bd-cat-bar{height:6px;background:var(--bg2);border-radius:3px;overflow:hidden}
.bd-cat-fill{height:100%;border-radius:3px}
.bd-cat-pct{font-size:11px;color:var(--text3);font-family:'JetBrains Mono',monospace;text-align:right}
.bd-cat-amt{font-size:12px;font-family:'JetBrains Mono',monospace;color:var(--text2);text-align:right}

@media(max-width:600px){
  .bd-summary{grid-template-columns:auto 1fr auto auto}
  .bd-pct{display:none}
  .bd-cat-row{grid-template-columns:1fr 1fr 30px 80px}
  .bd-cat-name{min-width:0}
}

/* ACCOUNT FLOW (Reports) — table for native column alignment */
.flow-table{width:100%;border-collapse:collapse;margin-top:6px}
.flow-table th{text-align:left;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:1px;padding:8px 12px;border-bottom:1px solid var(--border)}
.flow-table th.num{text-align:right}
.flow-table td{padding:10px 12px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}
.flow-table tr:last-child td{border-bottom:none}
.flow-table .num{font-family:'JetBrains Mono',monospace;font-size:12px;text-align:right;white-space:nowrap}
.flow-table .in{color:var(--green)}
.flow-table .out{color:var(--red)}
.flow-table .net{font-weight:600}
.flow-table .net.pos{color:var(--green)}
.flow-table .net.neg{color:var(--red)}
.flow-table .net.zero{color:var(--text3)}
.flow-table .acc{display:flex;align-items:center;gap:10px;min-width:0}
.flow-table .acc-emoji{font-size:16px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}
.flow-table tr.clickable{cursor:pointer;transition:background 0.15s}
.flow-table tr.clickable:hover td{background:rgba(127,127,127,0.06)}
@media(max-width:600px){
  .flow-table th,.flow-table td{padding:8px 6px}
  .flow-table th:nth-child(3),.flow-table td:nth-child(3){display:none}
}

/* "Show all" toggle for top categories */
.top-cats-more{display:flex;justify-content:center;padding-top:14px;margin-top:6px;border-top:1px solid var(--border)}

@media(max-width:900px){
  .sidebar{position:fixed;left:-100%;top:0;bottom:0;z-index:100;transition:left 0.25s;width:260px}
  .sidebar.open{left:0}
  .sidebar-overlay.open{display:block}
  .mob-header{display:flex}
  .page{padding:20px 16px}
  .summary-grid{grid-template-columns:1fr 1fr}
  .grid-2,.report-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .form-group.full{grid-column:1}
}
@media(max-width:500px){
  .summary-grid{grid-template-columns:1fr 1fr}
  .sc-val{font-size:18px}
  .tx-table th:nth-child(2),.tx-table td:nth-child(2){display:none}
}
