/* THE VAULT v3 — vault.css */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{height:100%;scroll-behavior:smooth;}
:root{
  --bg:#040c12;--bg2:#070f16;--panel:#080f18;--panel2:#0c1520;
  --teal:#00ffc8;--teal-dim:rgba(0,255,200,0.1);--teal-glow:rgba(0,255,200,0.25);
  --green:#3ddc84;--green-dim:rgba(61,220,132,0.12);
  --red:#ff5555;--red-dim:rgba(255,85,85,0.12);
  --amber:#ffb703;--amber-dim:rgba(255,183,3,0.12);
  --violet:#9d7fff;--violet-dim:rgba(157,127,255,0.12);
  --border:rgba(0,255,200,0.1);--text:#cde0d8;--muted:#4a6870;
  --radius:10px;--sidebar-w:220px;
  --font-brand:'Cinzel',serif;--font-body:'Inter',sans-serif;--font-mono:'Share Tech Mono',monospace;
}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:0.9rem;min-height:100vh;display:flex;overflow-x:hidden;}

/* Skip link */
.skip-link{position:absolute;top:-100px;left:1rem;background:var(--teal);color:#000;padding:0.5rem 1rem;border-radius:5px;font-weight:700;z-index:9999;transition:top .2s;}
.skip-link:focus{top:1rem;}

/* Focus styles — visible for keyboard nav */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:4px;}
button:focus-visible,a:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--teal);outline-offset:3px;}

/* Background */
.bg-wrap{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.bg-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:0.12;animation:orb-drift 20s ease-in-out infinite alternate;}
.orb-1{width:600px;height:600px;background:#00ffc8;top:-150px;left:-150px;}
.orb-2{width:500px;height:500px;background:#0033ff;bottom:-100px;right:-100px;animation-duration:26s;}
@keyframes orb-drift{from{transform:translate(0,0);}to{transform:translate(30px,-25px);}}
.bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,255,200,0.015) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,200,0.015) 1px,transparent 1px);background-size:36px 36px;}

/* Sidebar */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);z-index:200;background:rgba(4,10,16,0.97);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.25rem 0;transition:transform .3s ease;backdrop-filter:blur(12px);}
.sidebar-brand{display:flex;align-items:center;gap:0.6rem;padding:0 1.2rem 1.2rem;border-bottom:1px solid var(--border);margin-bottom:0.75rem;}
.brand-icon{font-size:1.3rem;color:var(--teal);filter:drop-shadow(0 0 8px rgba(0,255,200,0.5));}
.brand-name{font-family:var(--font-brand);font-size:1.1rem;font-weight:700;color:var(--teal);letter-spacing:0.05em;}
.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:0.15rem;padding:0 0.6rem;}
.nav-item{display:flex;align-items:center;gap:0.6rem;padding:0.6rem 0.75rem;border-radius:8px;font-size:0.82rem;font-weight:500;letter-spacing:0.03em;color:var(--muted);background:transparent;border:none;cursor:pointer;transition:all .2s;text-align:left;width:100%;}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,0.04);}
.nav-item.active{color:var(--teal);background:var(--teal-dim);}
.nav-icon{font-size:0.9rem;width:18px;text-align:center;}
.sidebar-footer{padding:1rem 1.2rem 0;border-top:1px solid var(--border);margin-top:auto;}
.back-link{font-family:var(--font-mono);font-size:0.65rem;letter-spacing:0.1em;color:var(--muted);text-decoration:none;transition:color .2s;}
.back-link:hover{color:var(--teal);}

/* Main */
.main-wrap{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1;}

/* Topbar */
.topbar{position:sticky;top:0;z-index:100;background:rgba(4,10,16,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0.75rem 1.5rem;display:flex;align-items:center;gap:0.75rem;flex-wrap:wrap;}
.menu-toggle{display:none;background:none;border:none;color:var(--teal);font-size:1.2rem;cursor:pointer;padding:0.25rem;}
.topbar-title{font-family:var(--font-brand);font-size:1rem;font-weight:600;color:var(--teal);letter-spacing:0.08em;margin-right:auto;}
.topbar-controls{display:flex;align-items:center;gap:0.5rem;flex-wrap:wrap;}
.month-controls{display:flex;align-items:center;gap:0.4rem;}
.month-nav{background:none;border:1px solid var(--border);color:var(--teal);width:26px;height:26px;border-radius:5px;cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.month-nav:hover,.month-nav:focus-visible{background:var(--teal-dim);}
.month-label{font-family:var(--font-mono);font-size:0.72rem;letter-spacing:0.08em;color:var(--text);min-width:110px;text-align:center;}
.filter-btn{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;background:transparent;border:1px solid var(--border);color:var(--muted);padding:0.3rem 0.7rem;border-radius:5px;cursor:pointer;transition:all .2s;}
.filter-btn.active,.filter-btn:hover,.filter-btn:focus-visible{background:var(--teal-dim);border-color:rgba(0,255,200,0.4);color:var(--teal);}
.acct-filter-sel{font-family:var(--font-mono);font-size:0.65rem;background:var(--panel);border:1px solid var(--border);color:var(--teal);padding:0.3rem 0.6rem;border-radius:6px;cursor:pointer;outline:none;}
.export-btn{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;background:rgba(61,220,132,0.08);border:1px solid rgba(61,220,132,0.3);color:var(--green);padding:0.3rem 0.8rem;border-radius:5px;cursor:pointer;transition:all .2s;}
.export-btn:hover,.export-btn:focus-visible{background:var(--green-dim);}
.import-btn{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;border:1px solid rgba(157,127,255,0.3);color:var(--violet);background:rgba(157,127,255,0.08);padding:0.3rem 0.8rem;border-radius:5px;cursor:pointer;transition:all .2s;}
.import-btn:hover,.import-btn:focus-visible{background:var(--violet-dim);}
.import-pdf-btn{background:rgba(255,183,3,0.08);border-color:rgba(255,183,3,0.3);color:var(--amber);}
.import-pdf-btn:hover,.import-pdf-btn:focus-visible{background:var(--amber-dim);}
.template-btn{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;background:rgba(0,255,200,0.06);border:1px solid rgba(0,255,200,0.2);color:rgba(0,255,200,0.55);padding:0.3rem 0.8rem;border-radius:5px;cursor:pointer;transition:all .2s;}
.template-btn:hover,.template-btn:focus-visible{background:var(--teal-dim);color:var(--teal);}

/* Views */
.view{display:none;padding:1.5rem;flex-direction:column;gap:1.25rem;}
.view.active{display:flex;}
.view-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.75rem;}
.view-title{font-family:var(--font-brand);font-size:1.3rem;font-weight:600;color:var(--teal);letter-spacing:0.06em;}

/* Summary cards */
.summary-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:0.85rem;}
.acct-sum-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:0.9rem 1rem;display:flex;align-items:center;gap:0.75rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;}
.acct-sum-card:hover,.acct-sum-card:focus-visible{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3);}
.acct-sum-icon{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
.acct-sum-label{font-family:var(--font-mono);font-size:0.55rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);margin-bottom:0.15rem;}
.acct-sum-bal{font-family:var(--font-mono);font-size:1rem;font-weight:700;}

/* Cards */
.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.card-title{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--teal);opacity:0.8;}
.card-link{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.08em;color:var(--muted);background:none;border:none;cursor:pointer;transition:color .2s;}
.card-link:hover,.card-link:focus-visible{color:var(--teal);}
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.25rem;}
.chart-card canvas{width:100%!important;}

/* Recent transactions mini */
.tx-mini-list{display:flex;flex-direction:column;gap:0.5rem;max-height:260px;overflow-y:auto;}
.tx-mini{display:flex;align-items:center;gap:0.6rem;padding:0.5rem;border-radius:7px;background:rgba(255,255,255,0.02);}
.tx-mini-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.tx-mini-desc{flex:1;font-size:0.83rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tx-mini-amt{font-family:var(--font-mono);font-size:0.8rem;font-weight:600;flex-shrink:0;}
.tx-mini-date{font-family:var(--font-mono);font-size:0.6rem;color:var(--muted);flex-shrink:0;}

/* Pie */
.pie-wrap{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;}
.pie-legend{display:flex;flex-direction:column;gap:0.45rem;flex:1;min-width:140px;}
.pie-legend-item{display:flex;align-items:center;gap:0.5rem;font-size:0.8rem;}
.pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.pie-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pie-pct{font-family:var(--font-mono);font-size:0.72rem;color:var(--muted);}

/* Top merchants */
.merchant-item{display:flex;align-items:center;gap:0.75rem;padding:0.5rem 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.merchant-rank{font-family:var(--font-mono);font-size:0.65rem;color:var(--muted);width:18px;text-align:center;flex-shrink:0;}
.merchant-name{flex:1;font-size:0.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.merchant-bar-wrap{width:80px;height:5px;background:rgba(255,255,255,0.07);border-radius:3px;overflow:hidden;}
.merchant-bar{height:100%;border-radius:3px;background:var(--red);}
.merchant-amt{font-family:var(--font-mono);font-size:0.75rem;color:var(--red);min-width:64px;text-align:right;}

/* Budget mini */
.budget-mini{display:flex;flex-direction:column;gap:0.7rem;}
.budget-mini-item{display:grid;grid-template-columns:120px 1fr 80px;align-items:center;gap:0.75rem;}
.bmi-name{font-size:0.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bmi-track{height:6px;background:rgba(255,255,255,0.07);border-radius:3px;overflow:hidden;}
.bmi-fill{height:100%;border-radius:3px;transition:width .5s ease;}
.bmi-pct{font-family:var(--font-mono);font-size:0.65rem;color:var(--muted);text-align:right;}

/* Transactions */
.filter-row{display:flex;gap:0.5rem;flex-wrap:wrap;align-items:center;}
.mini-sel{font-family:var(--font-mono);font-size:0.65rem;letter-spacing:0.05em;background:var(--panel);border:1px solid var(--border);color:var(--muted);padding:0.35rem 0.6rem;border-radius:6px;cursor:pointer;outline:none;transition:all .2s;}
.mini-sel:focus-visible{border-color:rgba(0,255,200,0.4);color:var(--text);}
.search-input{font-family:var(--font-body);font-size:0.82rem;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:0.35rem 0.75rem;border-radius:6px;outline:none;flex:1;min-width:150px;transition:all .2s;}
.search-input:focus-visible{border-color:rgba(0,255,200,0.4);}
.search-input::placeholder{color:var(--muted);}
.tx-count{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.1em;color:var(--muted);}
.tx-list{display:flex;flex-direction:column;gap:0.5rem;}
.tx-item{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:0.85rem 1rem;display:flex;align-items:center;gap:0.85rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;}
.tx-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;}
.tx-item.income{border-color:rgba(61,220,132,0.12);}
.tx-item.expense{border-color:rgba(255,85,85,0.12);}
.tx-item.transfer{border-color:rgba(157,127,255,0.12);}
.tx-item.income::before{background:var(--green);}
.tx-item.expense::before{background:var(--red);}
.tx-item.transfer::before{background:var(--violet);}
.tx-item:hover,.tx-item:focus-visible{transform:translateX(3px);box-shadow:0 4px 20px rgba(0,0,0,0.3);}
.tx-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.income .tx-dot{background:var(--green);box-shadow:0 0 5px var(--green);}
.expense .tx-dot{background:var(--red);box-shadow:0 0 5px var(--red);}
.transfer .tx-dot{background:var(--violet);box-shadow:0 0 5px var(--violet);}
.tx-body{flex:1;min-width:0;}
.tx-desc{font-size:0.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tx-sub{font-family:var(--font-mono);font-size:0.6rem;color:var(--muted);margin-top:0.15rem;display:flex;gap:0.5rem;flex-wrap:wrap;}
.tx-cat{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.07);padding:0.05rem 0.35rem;border-radius:3px;}
.tx-amount{font-family:var(--font-mono);font-size:0.9rem;font-weight:700;flex-shrink:0;min-width:80px;text-align:right;}
.income .tx-amount{color:var(--green);}
.expense .tx-amount{color:var(--red);}
.transfer .tx-amount{color:var(--violet);}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:0.4rem;padding:1rem 0;flex-wrap:wrap;}
.page-btn{font-family:var(--font-mono);font-size:0.65rem;background:var(--panel);border:1px solid var(--border);color:var(--muted);width:32px;height:32px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.page-btn:hover,.page-btn:focus-visible{background:var(--teal-dim);border-color:rgba(0,255,200,0.4);color:var(--teal);}
.page-btn.active{background:var(--teal-dim);border-color:rgba(0,255,200,0.4);color:var(--teal);font-weight:700;}
.page-btn:disabled{opacity:0.3;cursor:not-allowed;}
.page-info{font-family:var(--font-mono);font-size:0.62rem;color:var(--muted);padding:0 0.5rem;}

/* Accounts */
.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}
.acct-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;}
.acct-card:hover,.acct-card:focus-visible{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3);}
.acct-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.85rem;}
.acct-name{font-family:var(--font-brand);font-size:1rem;font-weight:600;}
.acct-type{font-family:var(--font-mono);font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,0.04);padding:0.2rem 0.5rem;border-radius:4px;}
.acct-owner{font-family:var(--font-mono);font-size:0.62rem;color:var(--muted);margin-bottom:0.75rem;}
.acct-balance{font-family:var(--font-mono);font-size:1.4rem;font-weight:700;margin-bottom:0.75rem;}
.acct-stats{display:flex;gap:1rem;}
.acct-stat{display:flex;flex-direction:column;gap:0.15rem;}
.acct-stat-label{font-family:var(--font-mono);font-size:0.55rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);}
.acct-stat-val{font-family:var(--font-mono);font-size:0.8rem;font-weight:600;}
.household-row{display:flex;gap:1.5rem;flex-wrap:wrap;padding:0.5rem 0;}
.household-stat{display:flex;flex-direction:column;gap:0.2rem;}
.household-label{font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);}
.household-val{font-family:var(--font-mono);font-size:1.3rem;font-weight:700;}
.household-divider{width:1px;background:var(--border);align-self:stretch;}

/* Budget cards */
.budget-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;}
.budget-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;cursor:pointer;transition:all .2s;}
.budget-card:hover,.budget-card:focus-visible{border-color:rgba(0,255,200,0.3);transform:translateY(-2px);}
.bc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.75rem;}
.bc-name{font-weight:600;font-size:0.92rem;}
.bc-limit{font-family:var(--font-mono);font-size:0.7rem;color:var(--muted);}
.bc-track{height:8px;background:rgba(255,255,255,0.07);border-radius:4px;overflow:hidden;margin-bottom:0.5rem;}
.bc-fill{height:100%;border-radius:4px;transition:width .5s ease;}
.bc-foot{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:0.65rem;color:var(--muted);margin-bottom:0.85rem;}
.bc-tx-list{display:flex;flex-direction:column;gap:0.3rem;border-top:1px solid rgba(255,255,255,0.06);padding-top:0.75rem;}
.bc-tx-row{display:flex;align-items:center;gap:0.5rem;font-size:0.75rem;}
.bc-tx-date{font-family:var(--font-mono);font-size:0.6rem;color:var(--muted);min-width:70px;}
.bc-tx-desc{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted);}
.bc-tx-amt{font-family:var(--font-mono);font-size:0.72rem;color:var(--red);flex-shrink:0;}

/* Saving pots */
.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;}
.goal-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;transition:all .2s;}
.goal-card:hover{transform:translateY(-1px);}
.gc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.3rem;}
.gc-name{font-family:var(--font-brand);font-size:1rem;font-weight:600;}
.gc-date{font-family:var(--font-mono);font-size:0.62rem;color:var(--muted);margin-bottom:0.75rem;}
.gc-track{height:10px;background:rgba(255,255,255,0.07);border-radius:5px;overflow:hidden;margin-bottom:0.5rem;}
.gc-fill{height:100%;border-radius:5px;transition:width .5s ease;}
.gc-foot{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:0.68rem;margin-bottom:0.85rem;}
.gc-saved{color:var(--teal);}
.gc-target{color:var(--muted);}
.gc-pct{font-weight:700;}
.gc-actions{display:flex;gap:0.5rem;}
.gc-btn{flex:1;font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.08em;text-transform:uppercase;border:1px solid;border-radius:6px;cursor:pointer;padding:0.4rem;transition:all .2s;text-align:center;}
.gc-btn-add{background:var(--green-dim);border-color:rgba(61,220,132,0.35);color:var(--green);}
.gc-btn-add:hover,.gc-btn-add:focus-visible{background:rgba(61,220,132,0.2);}
.gc-btn-withdraw{background:var(--red-dim);border-color:rgba(255,85,85,0.35);color:var(--red);}
.gc-btn-withdraw:hover,.gc-btn-withdraw:focus-visible{background:rgba(255,85,85,0.2);}
.gc-btn-edit{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.1);color:var(--muted);}
.gc-btn-edit:hover,.gc-btn-edit:focus-visible{color:var(--text);}

/* Bills */
.bills-list,.bills-mini{display:flex;flex-direction:column;gap:0.6rem;}
.bill-item{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:0.85rem 1rem;display:flex;align-items:center;gap:0.85rem;cursor:pointer;transition:all .2s;}
.bill-item:hover,.bill-item:focus-visible{border-color:rgba(0,255,200,0.3);}
.bill-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.bill-body{flex:1;min-width:0;}
.bill-name{font-size:0.88rem;font-weight:500;}
.bill-meta{font-family:var(--font-mono);font-size:0.6rem;color:var(--muted);margin-top:0.15rem;}
.bill-amt{font-family:var(--font-mono);font-size:0.92rem;font-weight:700;color:var(--red);flex-shrink:0;}
.bill-due{font-family:var(--font-mono);font-size:0.65rem;flex-shrink:0;padding:0.2rem 0.5rem;border-radius:4px;}
.bill-due.soon{background:rgba(255,183,3,0.15);color:var(--amber);}
.bill-due.overdue{background:var(--red-dim);color:var(--red);}
.bill-due.ok{background:var(--green-dim);color:var(--green);}
.bill-paid-btn{font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.08em;text-transform:uppercase;border:1px solid;border-radius:5px;cursor:pointer;padding:0.2rem 0.45rem;transition:all .2s;flex-shrink:0;}
.bill-paid-btn.unpaid{background:rgba(255,255,255,0.03);border-color:rgba(255,255,255,0.1);color:var(--muted);}
.bill-paid-btn.unpaid:hover,.bill-paid-btn.unpaid:focus-visible{border-color:rgba(61,220,132,0.4);color:var(--green);}
.bill-paid-btn.paid{background:var(--green-dim);border-color:rgba(61,220,132,0.4);color:var(--green);}

/* Buttons */
.btn-primary{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;background:var(--teal-dim);border:1px solid rgba(0,255,200,0.4);color:var(--teal);padding:0.6rem 1.2rem;border-radius:7px;cursor:pointer;transition:all .2s;}
.btn-primary:hover,.btn-primary:focus-visible{background:rgba(0,255,200,0.2);box-shadow:0 0 14px var(--teal-glow);}
.btn-danger{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;background:var(--red-dim);border:1px solid rgba(255,85,85,0.35);color:var(--red);padding:0.6rem 1.2rem;border-radius:7px;cursor:pointer;transition:all .2s;}
.btn-danger:hover,.btn-danger:focus-visible{background:rgba(255,85,85,0.2);}
.btn-secondary{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.12);color:var(--muted);padding:0.6rem 1.2rem;border-radius:7px;cursor:pointer;transition:all .2s;}
.btn-secondary:hover,.btn-secondary:focus-visible{background:rgba(255,255,255,0.09);color:var(--text);}
.btn-primary.hidden,.btn-danger.hidden{display:none;}

/* Modals */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,5,10,0.88);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1rem;}
.modal-overlay.hidden{display:none;}
.modal{background:var(--panel);border:1px solid rgba(0,255,200,0.2);border-radius:14px;width:100%;max-width:480px;padding:1.75rem;position:relative;box-shadow:0 0 60px rgba(0,255,200,0.07);animation:modal-in .2s ease-out;}
.modal-sm{max-width:360px;}
@keyframes modal-in{from{opacity:0;transform:scale(.96) translateY(8px);}to{opacity:1;transform:none;}}
.modal::before{content:'';display:block;height:2px;background:linear-gradient(90deg,transparent,rgba(0,255,200,0.4),transparent);margin-bottom:1.25rem;border-radius:2px;}
.modal-x{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:var(--muted);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:0.8rem;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.modal-x:hover,.modal-x:focus-visible{background:var(--red-dim);color:var(--red);}
.modal-title{font-family:var(--font-brand);font-size:1.1rem;color:var(--text);margin-bottom:1.25rem;}
.modal-body{display:flex;flex-direction:column;gap:0.85rem;}
.modal-footer{display:flex;gap:0.6rem;margin-top:1.25rem;}
.pdf-modal{background:var(--panel);border:1px solid rgba(255,183,3,0.3);border-radius:14px;width:100%;max-width:520px;padding:1.75rem;position:relative;box-shadow:0 0 60px rgba(255,183,3,0.07);animation:modal-in .2s ease-out;}
.pdf-modal::before{content:'';display:block;height:2px;background:linear-gradient(90deg,transparent,rgba(255,183,3,0.4),transparent);margin-bottom:1.25rem;border-radius:2px;}
.pdf-status{font-family:var(--font-mono);font-size:0.75rem;letter-spacing:0.06em;color:var(--muted);margin:0.75rem 0;min-height:1.5rem;line-height:1.6;}
.pdf-status.success{color:var(--green);}
.pdf-status.error{color:var(--red);}
.pdf-status.loading{color:var(--amber);}
.pdf-select-row{display:flex;gap:0.75rem;align-items:center;margin-bottom:0.5rem;}
.pdf-select-all{font-family:var(--font-mono);font-size:0.62rem;color:var(--muted);background:none;border:none;cursor:pointer;letter-spacing:0.06em;text-decoration:underline;}
.pdf-select-all:hover,.pdf-select-all:focus-visible{color:var(--teal);}
.pdf-preview{max-height:240px;overflow-y:auto;margin:0.75rem 0;display:flex;flex-direction:column;gap:0.35rem;}
.pdf-tx-row{display:flex;align-items:center;gap:0.6rem;padding:0.45rem 0.6rem;background:rgba(255,255,255,0.02);border-radius:6px;font-size:0.8rem;}
.pdf-tx-row input[type=checkbox]{accent-color:var(--teal);flex-shrink:0;}
.pdf-tx-date{font-family:var(--font-mono);font-size:0.65rem;color:var(--muted);flex-shrink:0;min-width:72px;}
.pdf-tx-desc{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pdf-tx-amt{font-family:var(--font-mono);font-size:0.75rem;font-weight:600;flex-shrink:0;min-width:70px;text-align:right;}
.pdf-tx-type select{font-family:var(--font-mono);font-size:0.6rem;background:var(--panel2);border:1px solid var(--border);color:var(--muted);border-radius:4px;padding:0.15rem 0.3rem;}

/* Type tabs */
.type-tabs{display:flex;gap:0.4rem;}
.type-tab{flex:1;font-family:var(--font-mono);font-size:0.65rem;letter-spacing:0.08em;text-transform:uppercase;background:transparent;border:1px solid rgba(255,255,255,0.08);color:var(--muted);padding:0.45rem;border-radius:6px;cursor:pointer;transition:all .2s;}
.type-tab:hover,.type-tab:focus-visible{color:var(--text);}
.type-tab.active[data-type="income"]{background:var(--green-dim);border-color:rgba(61,220,132,0.4);color:var(--green);}
.type-tab.active[data-type="expense"]{background:var(--red-dim);border-color:rgba(255,85,85,0.4);color:var(--red);}
.type-tab.active[data-type="transfer"]{background:var(--violet-dim);border-color:rgba(157,127,255,0.4);color:var(--violet);}
.type-tab.active[data-type="asset"]{background:var(--green-dim);border-color:rgba(61,220,132,0.4);color:var(--green);}
.type-tab.active[data-type="liability"]{background:var(--red-dim);border-color:rgba(255,85,85,0.4);color:var(--red);}

/* Fields */
.field-row{display:flex;flex-direction:column;gap:0.85rem;}
.field-row.two-col{flex-direction:row;gap:0.75rem;}
.field-row.two-col .field{flex:1;}
.field{display:flex;flex-direction:column;gap:0.35rem;}
.field label{font-family:var(--font-mono);font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);}
.field-input{background:rgba(0,255,200,0.03);border:1px solid var(--border);border-radius:7px;padding:0.65rem 0.85rem;color:var(--text);font-family:var(--font-body);font-size:0.88rem;outline:none;width:100%;transition:all .2s;color-scheme:dark;}
.field-input::placeholder{color:var(--muted);}
.field-input:focus,.field-input:focus-visible{border-color:rgba(0,255,200,0.4);box-shadow:0 0 0 3px rgba(0,255,200,0.06);}
.field-input.error{border-color:rgba(255,85,85,0.5);}
.color-input{height:40px;padding:0.25rem;cursor:pointer;}
.amount-wrap{position:relative;}
.cur-sign{position:absolute;left:0.85rem;top:50%;transform:translateY(-50%);font-family:var(--font-mono);color:var(--muted);font-size:0.85rem;pointer-events:none;}
.amount-input{padding-left:1.75rem;font-family:var(--font-mono);}
.req{color:var(--red);margin-left:2px;}
.field-error{font-family:var(--font-mono);font-size:0.62rem;color:var(--red);min-height:1rem;letter-spacing:0.05em;}
.pot-fund-info{font-family:var(--font-mono);font-size:0.72rem;color:var(--muted);line-height:1.6;}

/* Empty state */
.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted);font-style:italic;font-size:0.9rem;}

/* Sidebar overlay for mobile */
.sidebar-overlay{display:none;position:fixed;inset:0;z-index:199;background:rgba(0,0,0,0.6);backdrop-filter:blur(2px);}
.sidebar-overlay.active{display:block;}
/* Keep menu toggle always visible and fixed on mobile */
@media(max-width:700px){
  .menu-toggle{position:fixed;top:0.75rem;left:0.85rem;z-index:300;background:rgba(4,10,16,0.95);border:1px solid var(--border);border-radius:6px;padding:0.3rem 0.6rem;font-size:1rem;line-height:1;min-width:32px;text-align:center;}
}
@media(max-width:900px){.summary-cards{grid-template-columns:repeat(2,1fr);}
  .accounts-grid,.budget-grid,.goals-grid{grid-template-columns:1fr;}
}
@media(max-width:700px){
  :root{--sidebar-w:0px;}
  .sidebar{transform:translateX(-220px);width:220px;}
  .sidebar.open{transform:translateX(0);}
  .main-wrap{margin-left:0;}
  .menu-toggle{display:block;}
  .topbar{padding-left:3.5rem;}
  .summary-cards{grid-template-columns:1fr 1fr;}
  .field-row.two-col{flex-direction:column;}
  .topbar-controls{gap:0.35rem;}
  .view{padding:1rem;}
}
@media(max-width:480px){
  .summary-cards{grid-template-columns:1fr;}
  .topbar{flex-wrap:wrap;}
}
/* ============================================================
   LOCAL STORAGE DISCLAIMER BANNER
============================================================ */

.local-disclaimer {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: rgba(255, 215, 0, 0.04);
  border: 1px solid rgba(255, 215, 0, 0.18);
  border-left: 3px solid rgba(255, 215, 0, 0.5);
  border-radius: 6px;
  padding: 0.65rem 1.1rem;
  margin: 0.75rem 1.5rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: rgba(255, 215, 0, 0.65);
  line-height: 1.5;
}

/* Vault: fits inside the main-wrap, full width minus sidebar */
.main-wrap .local-disclaimer {
  margin: 0.75rem 1.5rem 0;
}

/* Codex: sits between the split screen and footer */
.codex-disclaimer {
  max-width: 900px;
  margin: 0.5rem auto;
  justify-content: center;
  text-align: center;
  border-left: 1px solid rgba(255, 215, 0, 0.18);
  border-bottom: 1px solid rgba(255, 215, 0, 0.18);
  border-radius: 0 0 6px 6px;
  border-top: none;
}

.disclaimer-icon {
  font-size: 0.85rem;
  flex-shrink: 0;
  opacity: 0.8;
}

.disclaimer-text {
  flex: 1;
}

@media (max-width: 600px) {
  .local-disclaimer {
    margin: 0.5rem 0.75rem;
    font-size: 0.65rem;
  }
}
