*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
/* Fix date input calendar icon visibility */
input[type=date]::-webkit-calendar-picker-indicator {
  opacity: 0.6;
  cursor: pointer;
  filter: none;
}
body.dark input[type=date]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(1.5);
  opacity: 0.8;
}
:root{
  --g:#00c896;--gd:#00a87e;--g2:#00e6ac;
  --r:#ff4757;--o:#ffa502;--pu:#7c4dff;--bl:#2979ff;
  --purple:#7c4dff;
  --bg:#f0f4f8;--card:#fff;--text:#1a1a2e;--muted:#8892a4;--border:#e8edf5;
  --sh:0 2px 16px rgba(0,0,0,.06);--sh2:0 8px 40px rgba(0,200,150,.18);
  --nav:#0f1923;
  --radius:16px;
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}

/* ── DARK MODE ── */
body.dark{
  --bg:#0f1923;--card:#1a2535;--text:#e8edf5;--muted:#6b7a8d;
  --border:#243044;--nav:#080e15;
  --sh:0 2px 16px rgba(0,0,0,.3);
}
body.dark .modal{background:#1a2535;color:#e8edf5}
body.dark .fg input,body.dark .fg select,body.dark .fg textarea{background:#243044;border-color:#2d3f55;color:#e8edf5}
body.dark .chk{background:#1e2f44;border-color:#2d3f55}
body.dark .sbox{background:#1a2535;color:#e8edf5}
body.dark .sinp,body.dark .srow input{background:#243044;border-color:#2d3f55;color:#e8edf5}
body.dark .sbtn2{opacity:.95}
body.dark .who{border-color:rgba(255,255,255,.05)}
body.dark .imp-stat-box,body.dark .import-preview{background:#243044}
body.dark .leaderboard-row,body.dark .er,body.dark .br,body.dark .sr,body.dark .mr{border-color:#243044}
body.dark .daybtn,body.dark .sqbtn,body.dark .export-btn,body.dark .ku-chip{background:#1e2f44;border-color:#2d3f55;color:#e8edf5}
body.dark .how-it-works{background:#1a2535}
body.dark .toggle-slider{background:#3d526b}
body.dark #inapp-notif{background:#e8edf5;color:#1a2535}
body.dark .chart-section-card{background:#1a2535;border-color:#243044}
body.dark .chart-section-card .chart-section-title{color:#6b7a8d}
body.dark .chart-legend-dot{}
.dark-toggle{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:1.1rem;padding:6px;border-radius:8px;transition:all .2s;line-height:1;min-height:34px;min-width:34px;display:flex;align-items:center;justify-content:center}
.dark-toggle:hover{background:rgba(255,255,255,.12)}

/* ── NAV ── */
nav.top-nav{background:var(--nav);color:#fff;padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:58px;position:sticky;top:var(--ribbon-h,0px);z-index:500;box-shadow:0 1px 0 rgba(255,255,255,.05)}
.brand{font-size:1.05rem;font-weight:900;display:flex;align-items:center;gap:8px;letter-spacing:-.3px;min-width:0;flex:1}
.brand-logo{width:34px;height:34px;border-radius:10px;flex-shrink:0;box-shadow:0 0 18px rgba(0,200,150,.22)}
.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--g);box-shadow:0 0 10px var(--g);flex-shrink:0}
.brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-group{font-size:.62rem;color:rgba(255,255,255,.5);font-weight:600;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.nav-r{display:flex;align-items:center;gap:6px;flex-shrink:0}
.sdot{width:8px;height:8px;border-radius:50%;background:#444;transition:all .4s;flex-shrink:0}
.sdot.ok{background:var(--g);box-shadow:0 0 8px var(--g)}.sdot.err{background:var(--r)}.sdot.busy{background:var(--o);animation:bl 1s infinite}
@keyframes bl{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes spin{to{transform:rotate(360deg)}}
#refresh-btn.spinning{animation:spin .6s linear infinite;pointer-events:none;opacity:.6}
.gpill{display:none!important}
.acct-item-badge{margin-left:auto;font-size:.65rem;font-weight:800;letter-spacing:1.5px;background:rgba(0,200,150,.15);color:var(--g);border-radius:6px;padding:2px 7px;border:1px solid rgba(0,200,150,.25)}
.nbtn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;border-radius:9px;padding:6px 10px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap;min-height:34px;min-width:34px;display:flex;align-items:center;justify-content:center}
.nbtn:hover,.nbtn:active{background:rgba(255,255,255,.22)}

/* ── TABS ── */
/* Desktop: show as top tab bar. Mobile: hide (bottom nav takes over) */
.tabs{background:var(--nav);border-bottom:1px solid rgba(255,255,255,.07);display:flex;overflow-x:auto;scrollbar-width:none;position:sticky;top:calc(var(--ribbon-h,0px) + 58px);z-index:400}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:12px 14px;font-size:.72rem;font-weight:700;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .18s;flex-shrink:0;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}
.tab:hover{color:rgba(255,255,255,.75)}.tab.on{color:var(--g);border-bottom-color:var(--g)}

/* ── BOTTOM NAV (mobile only) ── */
.bottom-nav{position:fixed!important;bottom:0!important;top:auto!important;left:0;right:0;z-index:300;background:var(--nav);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:stretch;height:60px;box-shadow:0 -4px 20px rgba(0,0,0,.25)}

@media(min-width:600px){
  .tabs{display:flex!important}
  .bottom-nav{display:none!important}
  .wrap{padding-bottom:24px}
  .fab{bottom:24px}
}
@media(max-width:599px){
  .tabs{display:none!important}
  .wrap{padding-bottom:80px}
}
/* Hide bottom nav and app content when setup is visible */
#setup:not([style*='display: none']):not([style*='display:none']) ~ .bottom-nav { display:none!important }
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-family:inherit;padding:6px 2px;transition:color .18s;position:relative}
.bnav-item.on{color:var(--g)}
.bnav-item.on .bnav-icon{transform:translateY(-2px)}
.bnav-icon{font-size:1.15rem;line-height:1;transition:transform .18s}
.bnav-label{font-size:.52rem;font-weight:700;letter-spacing:.1px;white-space:nowrap}
.bnav-more{position:relative}
/* More popup menu */
.more-menu{display:none;position:absolute;bottom:calc(100% + 8px);right:0;background:#1a2535;border:1px solid rgba(255,255,255,.12);border-radius:14px;min-width:170px;box-shadow:0 -8px 32px rgba(0,0,0,.4);z-index:400;overflow:hidden;padding:6px 0}
.more-menu.open{display:block}
.more-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:#e8edf5;font-family:inherit;font-size:.82rem;font-weight:600;padding:12px 16px;cursor:pointer;text-align:left;transition:background .15s}
.more-item:hover,.more-item:active{background:rgba(255,255,255,.08)}
.more-item.on{color:var(--g)}
#quick-add-panel{display:none!important}
/* wrap needs extra bottom padding for bottom nav */
.wrap{max-width:860px;margin:0 auto;padding:12px 12px 80px;position:relative;z-index:0;isolation:isolate}
.sec{display:none}.sec.on{display:block}

/* ── SYNC BANNER ── */
.sync-banner{display:none;align-items:center;gap:8px;padding:8px 16px;font-size:.75rem;font-weight:700;position:sticky;top:58px;z-index:90;border-bottom:1px solid transparent}
.sync-banner.show{display:flex}
.sync-banner.offline{background:#fff0f2;color:var(--r);border-color:#ffd0d5}
.sync-banner.saving{background:#fffbf0;color:#8a5c00;border-color:#ffe8a0}
.sync-banner.saved{background:#f0fdf7;color:var(--gd);border-color:#c8f5e6}
.sync-banner-dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ── SUMMARY CHIPS ── */
.summary-chips{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:12px;
}
.chip{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 11px;
  border-radius:14px;
  border:1.5px solid var(--border);
  background:var(--card);
  transition:transform .15s,box-shadow .15s;
  cursor:default;
  overflow:hidden;
  position:relative;
}
.chip:active{transform:scale(.97)}
.chip-icon{
  font-size:1.1rem;
  line-height:1;
  flex-shrink:0;
}
.chip-body{
  display:flex;
  flex-direction:column;
  gap:1px;
  min-width:0;
}
.chip-label{
  font-size:.58rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:var(--muted);
  white-space:nowrap;
}
.chip-val{
  font-size:.8rem;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  letter-spacing:-.3px;
}
.chip-neutral .chip-val{color:var(--text)}
.chip-owe{
  background:#fff5f5;
  border-color:#ffd6d9;
}
body.dark .chip-owe{background:rgba(255,71,87,.1);border-color:rgba(255,71,87,.2)}
.chip-owe .chip-val{color:var(--r)}
.chip-owed{
  background:#f0fdf7;
  border-color:#c8f5e6;
}
body.dark .chip-owed{background:rgba(0,200,150,.1);border-color:rgba(0,200,150,.2)}
.chip-owed .chip-val{color:var(--gd)}
@media(max-width:360px){
  .chip{padding:8px 9px;gap:6px}
  .chip-label{font-size:.52rem}
  .chip-val{font-size:.74rem}
}

/* ── HERO BALANCE ── */
.hero-bal{
  background:linear-gradient(145deg,#0d1e2e 0%,#0f2740 60%,#0a1e32 100%);
  border-radius:20px;
  padding:20px 18px 16px;
  margin-bottom:14px;
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  position:relative;
  overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.07);
}
.hero-bal::after{
  content:'';
  position:absolute;
  top:-60px;right:-60px;
  width:160px;height:160px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,150,.12) 0%,transparent 70%);
  pointer-events:none;
}
.hb-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:6px;
}
.hb-label{
  font-size:.6rem;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  opacity:.5;
}
.hb-pulse{
  width:8px;height:8px;border-radius:50%;
  background:var(--g);
  box-shadow:0 0 10px var(--g);
  animation:hb-glow 2s ease-in-out infinite;
}
@keyframes hb-glow{
  0%,100%{opacity:1;box-shadow:0 0 10px var(--g)}
  50%{opacity:.5;box-shadow:0 0 4px var(--g)}
}
.hb-amount{
  font-size:2.2rem;
  font-weight:900;
  letter-spacing:-1.5px;
  line-height:1.05;
  margin-bottom:5px;
}
.hb-sub{
  font-size:.73rem;
  opacity:.55;
  line-height:1.5;
}
.hb-updated{
  font-size:.6rem;
  opacity:.35;
  margin-top:4px;
  font-weight:600;
}
.hero-bal.owe .hb-amount{color:#ff6b7a}
.hero-bal.owe::after{
  background:radial-gradient(circle,rgba(255,71,87,.1) 0%,transparent 70%);
}
.hero-bal.owed .hb-amount{color:var(--g)}
.hero-bal.even .hb-amount{color:rgba(255,255,255,.9)}

/* ── QUICK SPLIT BUTTONS ── */
.split-quick{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.sqbtn{padding:6px 12px;border-radius:20px;border:1.5px solid var(--border);background:#fafbfc;font-size:.74rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .18s;color:var(--text)}
.sqbtn:hover{border-color:var(--g);color:var(--gd);background:#e6fdf5}
.sqbtn.active{border-color:var(--g);background:#e6fdf5;color:var(--gd)}

/* ── INSIGHTS ── */
.insight-row{display:flex;align-items:flex-start;gap:10px;padding:11px 0;border-bottom:1px solid var(--border)}
.insight-row:last-child{border-bottom:none}
.insight-icon{font-size:1.2rem;flex-shrink:0;width:28px;text-align:center}
.insight-text{flex:1;font-size:.8rem;line-height:1.6;color:var(--text)}
.insight-text b{font-weight:800}
.insight-text .sub{font-size:.7rem;color:var(--muted)}

/* ── UPI HELPER ── */
.upi-row{display:flex;align-items:center;gap:8px;padding:9px 12px;background:#f0fdf7;border:1px solid #c8f5e6;border-radius:10px;margin-top:7px;font-size:.76rem}
.upi-copy{background:var(--g);color:#fff;border:none;border-radius:7px;padding:5px 10px;font-size:.72rem;font-weight:800;cursor:pointer;font-family:inherit;white-space:nowrap}
.upi-copy:active{background:var(--gd)}

/* ── PARTIAL PAYMENT ── */
.partial-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}
.partial-row:last-child{border-bottom:none}
.partial-who{font-weight:700;font-size:.82rem;flex:1}
.partial-amt{font-size:.78rem;color:var(--muted)}

/* ── ACTIVITY FEED ── */
.af-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.af-row:last-child{border-bottom:none}
.af-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:900;flex-shrink:0;color:#fff}
.af-body{flex:1;min-width:0}
.af-text{font-size:.78rem;line-height:1.5;color:var(--text)}
.af-text b{font-weight:800}
.af-time{font-size:.65rem;color:var(--muted);margin-top:2px}
.af-icon{font-size:.8rem;flex-shrink:0;padding-top:2px}

/* ── UPI DEEP LINK BUTTONS ── */
.upi-apps{display:flex;gap:7px;margin-top:8px;flex-wrap:wrap}
.upi-app-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:20px;border:1.5px solid var(--border);background:#fafbfc;font-size:.74rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .18s;color:var(--text);text-decoration:none}
.upi-app-btn:hover{border-color:var(--g);background:#e6fdf5}

/* ── SUMMARY CARDS ── */
.summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
@media(max-width:400px){.summary{grid-template-columns:1fr 1fr;gap:8px}}
.sc{background:var(--card);border-radius:var(--radius);box-shadow:var(--sh);padding:14px 12px;text-align:center;border:1px solid var(--border);transition:transform .15s}
.sc:active{transform:scale(.98)}
.sc .v{font-size:1.2rem;font-weight:900;margin-bottom:3px;letter-spacing:-.5px}
.sc .l{font-size:.58rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-weight:700}
.sc.ow .v{color:var(--r)}.sc.od .v{color:var(--g)}
@media(max-width:400px){.sc:last-child{grid-column:span 2}}

/* ── CARDS ── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--sh);padding:16px;margin-bottom:14px;border:1px solid var(--border)}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cht{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted)}
.abtn{background:var(--g);color:#fff;border:none;border-radius:10px;padding:8px 14px;font-size:.76rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .2s;min-height:36px;display:inline-flex;align-items:center;gap:4px}
.abtn:active{transform:scale(.95);background:var(--gd)}
@media(max-width:640px){#sec-exp .exp-add-btn{display:none}}

/* ── NAV SETTINGS DROPDOWN ── */
.nav-settings-backdrop{
  display:none;position:fixed;inset:0;z-index:8500;
}
.nav-settings-backdrop.open{display:block}
.nav-settings-menu{
  display:none;
  position:fixed;
  top:54px;right:10px;
  z-index:8501;
  background:#1a2535;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  min-width:210px;
  box-shadow:0 12px 40px rgba(0,0,0,.45),0 2px 8px rgba(0,0,0,.2);
  overflow:hidden;
  padding:6px 0;
  animation:nsm-in .18s cubic-bezier(.34,1.3,.64,1);
  transform-origin:top right;
}
@keyframes nsm-in{
  from{opacity:0;transform:scale(.92) translateY(-6px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.nav-settings-menu.open{display:block}
.nav-settings-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;
  cursor:pointer;
  color:#e8edf5;
  font-size:.85rem;
  font-weight:600;
  font-family:inherit;
  transition:background .15s;
  user-select:none;
}
.nav-settings-item:hover,.nav-settings-item:active{
  background:rgba(255,255,255,.08);
}
.nav-si-icon{font-size:1rem;width:22px;text-align:center;flex-shrink:0;line-height:1}
.nav-si-label{flex:1}
.nav-si-badge{
  font-size:.6rem;font-weight:800;letter-spacing:.5px;
  padding:2px 7px;border-radius:8px;
  background:rgba(255,255,255,.12);color:rgba(255,255,255,.5);
  margin-left:auto;flex-shrink:0;
}
.nav-si-badge.on{
  background:rgba(0,200,150,.2);color:var(--g);
}
.nav-si-danger{color:#ff6b7a!important}
.nav-si-danger:hover{background:rgba(255,71,87,.1)!important}
.nav-settings-divider{
  height:1px;background:rgba(255,255,255,.08);margin:4px 0;
}
/* keep settings gear looking active when open */
.nav-settings-btn.active{
  background:rgba(255,255,255,.2);
  border-color:rgba(255,255,255,.3);
}

/* ── WHO BAR ── */
.who{
  background:linear-gradient(135deg,#0f1923 0%,#1a2535 100%);
  color:#fff;
  border-radius:20px;
  padding:14px 16px;
  margin-bottom:12px;
  display:flex;
  align-items:center;
  gap:13px;
  border:1px solid rgba(255,255,255,.08);
  flex-wrap:nowrap;
  overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.06);
  position:relative;
}
.who::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,200,150,.3),transparent);
}
.who-av{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--g),var(--gd));
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1rem;flex-shrink:0;color:#fff;
  box-shadow:0 0 0 3px rgba(0,200,150,.2),0 3px 12px rgba(0,200,150,.3);
  letter-spacing:-.5px;
}
.who-info{flex:1;min-width:0;overflow:hidden}
.wl{font-size:.56rem;opacity:.4;font-weight:700;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;margin-bottom:2px}
.wn{font-size:.95rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.3px;line-height:1.2}
.wu{font-size:.72rem;color:var(--g);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.3px;margin-top:2px}
.wg{
  font-size:.64rem;color:rgba(255,255,255,.4);font-weight:600;
  margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  display:flex;align-items:center;gap:5px;
}
.wg::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--g);opacity:.7;flex-shrink:0;animation:hb-glow 2s ease-in-out infinite}
.who-actions{
  display:flex;
  flex-direction:column;
  gap:5px;
  flex-shrink:0;
}
.wsw{
  flex-shrink:0;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
  border-radius:10px;
  padding:7px 13px;
  font-size:.72rem;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  transition:all .2s;
  white-space:nowrap;
  display:flex;align-items:center;gap:6px;
  width:100%;
  justify-content:center;
}
.wsw:hover,.wsw:active{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3)}
.wsw-share{
  background:rgba(0,200,150,.12);
  border-color:rgba(0,200,150,.25);
  color:var(--g);
}
.wsw-share:hover,.wsw-share:active{
  background:rgba(0,200,150,.22);
  border-color:rgba(0,200,150,.4);
}
.wsw-icon{font-size:.88rem;line-height:1}
.wsw-text{font-size:.72rem;font-weight:700}
.who-menu-wrap{position:static}

/* ── ACCOUNT BOTTOM SHEET ── */
.acct-sheet-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:8000;backdrop-filter:blur(2px)}
.acct-sheet-bg.open{display:block}
.acct-sheet{position:fixed;left:0;right:0;bottom:-100%;z-index:8001;background:var(--card);border-radius:20px 20px 0 0;padding:0 0 24px;transition:bottom .3s cubic-bezier(.4,0,.2,1);max-width:500px;margin:0 auto}
.acct-sheet.open{bottom:0}
body.dark .acct-sheet{background:#1a2535}
.acct-sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:12px auto 0}
.acct-sheet-user{display:flex;align-items:center;gap:12px;padding:16px 20px 12px}
.acct-sheet-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#00c896,#00a87e);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;color:#fff;flex-shrink:0}
.acct-sheet-name{font-size:.95rem;font-weight:800;color:var(--text)}
.acct-sheet-uname{font-size:.75rem;color:var(--g);font-weight:700;margin-top:2px}
.acct-sheet-items{padding:4px 12px 0}
.acct-item{display:flex;align-items:center;gap:14px;width:100%;background:none;border:none;color:var(--text);font-family:inherit;font-size:.88rem;font-weight:600;padding:14px 12px;border-radius:12px;cursor:pointer;text-align:left;transition:background .15s}
.acct-item:hover,.acct-item:active{background:var(--border)}
.acct-item-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}
.acct-divider{height:1px;background:var(--border);margin:4px 12px}
.acct-danger{color:var(--r)!important}

/* ── MORE BOTTOM SHEET ── */
.more-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:8000}
.more-backdrop.open{display:block}
.more-sheet{position:fixed;left:0;right:0;bottom:-100%;z-index:8001;background:var(--card);border-radius:20px 20px 0 0;padding:0 0 32px;transition:bottom .3s cubic-bezier(.4,0,.2,1);max-width:500px;margin:0 auto;box-shadow:0 -4px 32px rgba(0,0,0,.25);max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.more-sheet.open{bottom:0}
.more-sheet::before{content:'';display:block;width:40px;height:4px;border-radius:2px;background:var(--border);margin:12px auto 0}
body.dark .more-sheet{background:#1a2535}
.more-sheet-title{font-size:.7rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:14px 20px 8px;text-align:center}
.more-item{display:flex;align-items:center;gap:14px;width:100%;background:none;border:none;color:var(--text);font-family:inherit;font-size:.9rem;font-weight:600;padding:15px 20px;cursor:pointer;text-align:left;transition:background .15s}
.more-item:hover,.more-item:active{background:var(--border)}
.more-item-icon{font-size:1.2rem;width:28px;text-align:center;flex-shrink:0}
.more-item.on{color:var(--g)}
@media(max-width:420px){.who{flex-wrap:nowrap}.who-actions{gap:4px}.wsw{padding:6px 10px}.wsw-text{font-size:.66rem}}

/* ── GROUP TABS ── */
.group-tabs-wrap{margin-bottom:12px}
.group-name-label{
  font-size:.6rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1.2px;
  color:var(--muted);
  margin-bottom:8px;
  padding:0 2px;
  display:flex;
  align-items:center;
  gap:6px;
}
.group-name-label::before{
  content:'';
  display:inline-block;
  width:3px;height:10px;
  border-radius:2px;
  background:var(--g);
  flex-shrink:0;
}
/* Scroll container with fade-right overflow hint */
.group-tabs-scroll{
  position:relative;
}
.group-tabs-scroll::after{
  content:'';
  position:absolute;
  top:0;right:0;bottom:2px;
  width:40px;
  pointer-events:none;
  background:linear-gradient(to right,transparent,var(--bg));
  border-radius:0 20px 20px 0;
  transition:opacity .2s;
  z-index:2;
}
.group-tabs-scroll.at-end::after{opacity:0}
body.dark .group-tabs-scroll::after{background:linear-gradient(to right,transparent,#0f1923)}
.group-tabs{display:flex;gap:7px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;padding-right:6px}
.group-tabs::-webkit-scrollbar{display:none}
.gtab{padding:7px 15px;border-radius:20px;border:2px solid var(--border);background:var(--card);font-size:.76rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s;font-family:inherit;flex-shrink:0;min-height:36px;color:var(--text)}
.gtab.on{border-color:var(--g);background:#e6fdf5;color:var(--gd)}
.gtab:not(.on):hover{border-color:#c5cdd9;background:#f5f7fa}
.gtab-add{padding:7px 13px;border-radius:20px;border:2px dashed var(--border);background:transparent;font-size:.8rem;font-weight:700;cursor:pointer;color:var(--muted);font-family:inherit;transition:all .2s;flex-shrink:0;min-height:36px;display:inline-flex;align-items:center;justify-content:center}
.gtab-add:hover{border-color:var(--g);color:var(--g);background:#f0fdf7}
/* Pinned + New button in the label row — always visible, never scrolls away */
.gtab-add-fixed{padding:4px 10px;border-radius:10px;border:1.5px solid var(--g);background:#f0fdf7;color:var(--gd);font-size:.68rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;flex-shrink:0;line-height:1.4}
body.dark .gtab-add-fixed{background:rgba(0,200,150,.12);border-color:rgba(0,200,150,.35);color:var(--g)}
.gtab-add-fixed:hover{background:#d4f5e9;border-color:var(--gd)}
.gtab-wrap{position:relative;display:inline-flex;align-items:center;flex-shrink:0}
.gtab-del{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--r);color:#fff;border:2px solid #fff;font-size:.55rem;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1;padding:0;font-family:inherit;z-index:2;box-shadow:0 2px 6px rgba(255,71,87,.3)}
.gtab-wrap:hover .gtab-del{display:flex}

/* ── EXPENSE ROWS ── */
/* Vertical layout: top row (icon + text + amount) then action bar below */
.er{display:flex;flex-direction:column;padding:14px 0;border-bottom:1px solid var(--border);user-select:none;-webkit-user-select:none}
.er:last-child{border-bottom:none}
/* Top section holds icon, body text, and amount side-by-side */
.er-top{display:flex;align-items:flex-start;gap:12px;width:100%}
.ei{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.eb{flex:1;min-width:0}
.en{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;color:var(--text)}
/* Meta row: payer name · date · edited badge — always fully visible */
.em{font-size:.7rem;color:var(--muted);margin-top:3px;line-height:1.5;display:flex;align-items:center;flex-wrap:wrap;gap:3px}
.em-date{font-weight:600}
.em-sep{opacity:.4;margin:0 1px}
.etag{display:inline-block;background:#fff3e0;color:#e65100;border-radius:6px;padding:2px 7px;font-size:.62rem;font-weight:700;margin-top:4px;margin-right:3px}
.ea{text-align:right;flex-shrink:0;min-width:72px}
.et{font-weight:900;font-size:.92rem}
.es{font-size:.7rem;font-weight:700;margin-top:2px}.es.ow{color:var(--r)}.es.od{color:var(--g)}
/* Action bar lives BELOW split avatars — no overlap possible */
.ebtns{display:flex;align-items:center;gap:2px;margin-top:8px;padding-top:6px;border-top:none;flex-wrap:nowrap}
.ebtns-spacer{flex:1}
.edel,.eedit{background:none;border:none;color:#b8c4d0;cursor:pointer;font-size:.82rem;padding:5px 7px;transition:all .18s;min-height:32px;min-width:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.edel:hover{color:var(--r);background:#fff0f2}.eedit:hover{color:var(--bl);background:#f0f4ff}
.eactions{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.react-btn{background:#f5f6f8;border:1.5px solid transparent;border-radius:16px;padding:3px 9px;font-size:.82rem;cursor:pointer;transition:all .18s;font-family:inherit;min-height:28px;color:var(--text)}
.react-btn:active{transform:scale(.9)}.react-btn.active{background:#e6fdf5;border-color:var(--g)}
.react-count{font-size:.64rem;font-weight:800;margin-left:2px;vertical-align:middle}
.comments-wrap{margin-top:9px;border-top:1px dashed var(--border);padding-top:9px}
.comment-item{font-size:.72rem;color:var(--muted);padding:3px 0;line-height:1.5}
.comment-item b{color:var(--text);font-weight:700}
.comment-add{display:flex;gap:6px;margin-top:7px}
.comment-add input{flex:1;padding:8px 11px;border:1.5px solid var(--border);border-radius:9px;font-size:.76rem;outline:none;font-family:inherit;min-height:36px;background:#fafafa;transition:border .18s}
.comment-add input:focus{border-color:var(--g);background:#fff}
.comment-add button{padding:0 13px;border-radius:9px;border:none;background:var(--g);color:#fff;font-size:.8rem;font-weight:800;cursor:pointer;font-family:inherit;min-height:36px;min-width:38px;transition:background .18s}
.comment-add button:hover{background:var(--gd)}

/* ── BALANCES ── */
.br{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border)}.br:last-child{border-bottom:none}
.av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.84rem;flex-shrink:0;color:#fff}
.bn{font-weight:700;font-size:.88rem}.bd{font-size:.68rem;color:var(--muted);margin-top:2px}
.ba{font-weight:900;font-size:.95rem;flex-shrink:0}.ba.pos{color:var(--g)}.ba.neg{color:var(--r)}

/* ── SETTLE ── */
.sr{display:flex;align-items:center;gap:12px;padding:13px 14px;background:linear-gradient(135deg,#fffbf0,#fff9e6);border-radius:12px;border-left:3px solid var(--o);margin-bottom:9px;border:1px solid #ffe8a0;border-left:3px solid var(--o)}
.st{flex:1;font-size:.84rem;line-height:1.6}.st b{font-weight:800}.sam{color:var(--o);font-weight:900;font-size:.9rem}
.sbtn{background:var(--g);color:#fff;border:none;border-radius:9px;padding:8px 14px;font-size:.76rem;font-weight:800;cursor:pointer;font-family:inherit;flex-shrink:0;min-height:36px;transition:background .18s}
.sbtn:hover{background:var(--gd)}

/* ── MEMBERS ── */
.mr{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}.mr:last-child{border-bottom:none}
.mn{font-weight:700;font-size:.88rem;flex:1}
.mrm{background:none;border:none;color:#d0d5de;cursor:pointer;padding:4px;font-size:.88rem;min-height:32px;min-width:32px;border-radius:7px;transition:all .18s;display:flex;align-items:center;justify-content:center}
.mrm:hover{color:var(--r);background:#fff0f2}

/* ── STATS: full-width chart cards, stacked on mobile ── */
/* Each chart gets its own full-width card for breathing room */
.chart-section-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--sh);padding:18px 16px 14px;margin-bottom:14px;border:1px solid var(--border)}
.chart-section-title{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:1.1px;color:var(--muted);margin-bottom:4px}
.chart-section-value{font-size:1.3rem;font-weight:900;color:var(--text);margin-bottom:14px;letter-spacing:-.5px}
.chart-section-value span{font-size:.75rem;font-weight:600;color:var(--muted);margin-left:5px}
/* Canvas sizing — tall enough to be readable */
.chart-section-card canvas{display:block;width:100%!important;height:220px!important}
/* Custom legend pills */
.chart-legend{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.chart-legend-item{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:700;color:var(--text);padding:3px 8px;border-radius:20px;background:var(--bg);border:1px solid var(--border)}
.chart-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
/* Keep the old .chart-grid + .chart-box for any non-stats usage */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
@media(max-width:560px){.chart-grid{grid-template-columns:1fr}}
.chart-box{background:var(--card);border-radius:var(--radius);box-shadow:var(--sh);padding:16px;border:1px solid var(--border)}
.chart-title{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:12px}
.leaderboard-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border)}
.leaderboard-row:last-child{border-bottom:none}
.lb-rank{font-size:1.1rem;width:28px;text-align:center;flex-shrink:0}
.lb-bar-wrap{flex:1;min-width:0}
.lb-name{font-size:.8rem;font-weight:700;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-bar{height:6px;border-radius:3px;background:linear-gradient(90deg,var(--g),var(--g2));transition:width .7s cubic-bezier(.34,1.56,.64,1);min-width:4px}
.lb-amt{font-size:.82rem;font-weight:900;color:var(--g);flex-shrink:0}
.lb-badge{display:inline-block;padding:2px 7px;border-radius:10px;font-size:.58rem;font-weight:800;margin-left:5px}
.lb-badge.top{background:#fff3e0;color:#e65100}
.lb-badge.debt{background:#fce4ec;color:#c62828}
.lb-badge.settled{background:#e8f5e9;color:#2e7d32}

/* ── DAY FILTER ── */
.day-filter{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.day-filter::-webkit-scrollbar{display:none}
.daybtn{padding:6px 13px;border-radius:16px;border:1.5px solid var(--border);background:var(--card);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap;font-family:inherit;transition:all .18s;flex-shrink:0;min-height:32px;color:var(--text)}
.daybtn.on{border-color:var(--g);background:#e6fdf5;color:var(--gd)}
.daybtn:not(.on):hover{border-color:#c5cdd9}

/* ── EXPORT ── */
.export-btn{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg);border:1.5px solid var(--border);border-radius:12px;cursor:pointer;font-family:inherit;font-size:.84rem;font-weight:700;width:100%;margin-bottom:9px;transition:all .2s;text-align:left;min-height:54px;color:var(--text)}
.export-btn:hover{border-color:var(--g);background:#e6fdf5;color:var(--gd)}
.export-icon{font-size:1.35rem;flex-shrink:0;width:30px;text-align:center}

/* ── MODAL ── */
.overlay{display:none;position:fixed;inset:0;background:rgba(10,20,35,.7);z-index:9000;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.overlay.on{display:flex}
.modal{background:var(--card);border-radius:22px 22px 0 0;padding:16px 18px 28px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slide-up .28s cubic-bezier(.4,0,.2,1);position:relative}
@keyframes slide-up{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 14px}
.mh{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.mh h2{font-size:1rem;font-weight:900;letter-spacing:-.3px}
.mx{background:var(--bg);border:none;border-radius:50%;width:32px;height:32px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:inherit;transition:all .2s;flex-shrink:0}
.mx:hover{background:var(--border);color:var(--text)}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fg label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}
.fg input,.fg select,.fg textarea{padding:11px 13px;border:1.5px solid var(--border);border-radius:12px;font-size:.9rem;font-family:inherit;outline:none;background:#fafbfc;transition:border .18s;color:var(--text);width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g);background:#fff}
.divider{height:1px;background:var(--border);margin:6px 0}
.gap{height:8px}
.btn{display:flex;align-items:center;justify-content:center;width:100%;padding:13px;border-radius:14px;font-size:.9rem;font-weight:800;cursor:pointer;border:none;font-family:inherit;transition:all .2s;min-height:48px}
.btn-p{background:var(--g);color:#fff}.btn-p:hover{background:var(--gd)}
.btn-s{background:var(--bg);color:var(--text);border:1.5px solid var(--border)}.btn-s:hover{background:var(--border)}
.btn-r{background:#fff0f2;color:var(--r);border:1.5px solid #ffd6da}.btn-r:hover{background:#ffe0e4}
.modal-exp-scroll{overflow-y:auto;padding-right:2px}
.exp-modal-footer{padding-top:8px;border-top:1px solid var(--border);margin-top:4px}
.chk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px}
.chk-grid-compact{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:5px}
.chk{display:flex;align-items:center;gap:5px;padding:6px 8px;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;font-size:.72rem;font-weight:700;transition:all .18s;background:#fafbfc;user-select:none;min-height:44px;color:var(--text);overflow:hidden}
.chk.on{border-color:var(--g);background:#e6fdf5;color:var(--gd)}
.chk-av{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.52rem;font-weight:900;flex-shrink:0;color:#fff}
.chk-name{overflow:hidden;word-break:break-word;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* ── SETUP / LOGIN SCREEN ── */
#setup{display:none;min-height:100vh;align-items:center;justify-content:center;padding:20px;background:linear-gradient(160deg,#0f1923 0%,#0a2a1e 100%)}
.sbox{background:var(--card);border-radius:24px;padding:28px 22px 24px;width:100%;max-width:400px;box-shadow:0 24px 80px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.06);position:relative;overflow:hidden}
.sbox::before{content:'';position:absolute;top:-80px;right:-80px;width:200px;height:200px;background:radial-gradient(circle,rgba(0,200,150,.15) 0%,transparent 70%);pointer-events:none}
.slogo{font-size:2.2rem;text-align:center;margin-bottom:10px}
.setup-logo{display:block;width:min(260px,86vw);height:auto;margin:0 auto 12px;filter:drop-shadow(0 14px 34px rgba(0,200,150,.18))}
.sbox h1{font-size:1.4rem;font-weight:900;text-align:center;margin-bottom:4px;letter-spacing:-.5px}
.tagline{font-size:.78rem;color:var(--muted);text-align:center;margin-bottom:20px;line-height:1.6}
.sinp{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:12px;font-size:.9rem;font-family:inherit;margin-bottom:10px;outline:none;background:#fafbfc;transition:border .18s;display:block;color:var(--text)}
.sinp:focus{border-color:var(--g);background:#fff}
.sbtn2{width:100%;padding:14px;border-radius:14px;font-size:.9rem;font-weight:800;cursor:pointer;border:none;font-family:inherit;background:linear-gradient(135deg,var(--g),var(--gd));color:#fff;margin-bottom:10px;transition:all .2s;min-height:48px;display:flex;align-items:center;justify-content:center;gap:7px;box-shadow:0 4px 20px rgba(0,200,150,.3)}
.sbtn2:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,200,150,.4)}
.sbtn2:active{transform:scale(.98)}
.serr{color:var(--r);font-size:.78rem;margin-top:8px;font-weight:700;min-height:18px;line-height:1.4}
.sor{text-align:center;color:var(--muted);font-size:.74rem;font-weight:700;margin:12px 0;display:flex;align-items:center;gap:10px}
.sor::before,.sor::after{content:'';flex:1;height:1px;background:var(--border)}
.srow{display:flex;gap:8px}
.srow input{flex:1;padding:11px 13px;border:1.5px solid var(--border);border-radius:12px;font-size:.88rem;font-family:inherit;outline:none;background:#fafbfc;transition:border .18s;color:var(--text)}
.srow input:focus{border-color:var(--g);background:#fff}
.srow button{padding:11px 18px;border-radius:12px;border:none;background:var(--g);color:#fff;font-weight:800;font-size:.84rem;cursor:pointer;font-family:inherit;transition:background .18s;white-space:nowrap;min-height:44px}
.srow button:hover{background:var(--gd)}
.inv-banner{background:linear-gradient(135deg,#0f2740,#0a3d2b);border:1px solid rgba(0,200,150,.3);border-radius:16px;padding:16px;margin-bottom:16px;text-align:center;color:#fff}
.inv-banner h3{font-size:.9rem;font-weight:800;margin-bottom:6px}
.inv-banner p{font-size:.76rem;opacity:.7;margin-bottom:8px}
.inv-code{font-size:1.5rem;font-weight:900;letter-spacing:6px;color:var(--g);text-shadow:0 0 20px rgba(0,200,150,.4)}

/* ── FAB ── */
.fab{position:fixed;bottom:80px;right:16px;width:52px;height:52px;border-radius:50%;background:var(--g);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 20px rgba(0,200,150,.45);z-index:200;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:inherit;line-height:1}
.fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(0,200,150,.55)}
.fab:active{transform:scale(.95)}

/* ── TOAST ── */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:#1a2535;color:#fff;border-radius:20px;padding:10px 20px;font-size:.82rem;font-weight:700;z-index:10000;opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap;max-width:calc(100vw - 32px);text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── EMPTY STATES ── */
.empty{text-align:center;padding:40px 16px;color:var(--muted)}
.empty-emoji{font-size:2.4rem;display:block;margin-bottom:10px}
.ej{font-size:2.8rem;margin-bottom:10px}
.empty p{font-size:.84rem;line-height:1.7}
.empty b{color:var(--text)}
.empty-cta{display:inline-block;margin-top:12px;padding:10px 22px;border-radius:20px;border:none;background:var(--g);color:#fff;font-size:.8rem;font-weight:800;cursor:pointer;font-family:inherit;transition:opacity .2s}
.empty-cta:hover,.empty-cta:active{opacity:.85}

/* ── FOOTER ── */
.footer{text-align:center;font-size:.7rem;color:var(--muted);padding:20px 12px 8px;font-weight:600;line-height:1.8}
.footer b{color:var(--text)}

/* ── SHARE MODAL ── */
.share-link-box{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:11px 14px;font-size:.76rem;font-weight:700;word-break:break-all;margin-bottom:12px;cursor:pointer;color:var(--text);transition:background .18s}
.share-link-box:hover{background:var(--border)}
.code-box{background:linear-gradient(135deg,#0f1923,#1a2535);border-radius:14px;padding:16px;text-align:center;margin-bottom:12px;border:1px solid rgba(255,255,255,.08)}
.code-big{font-size:2rem;font-weight:900;letter-spacing:8px;color:var(--g);text-shadow:0 0 20px rgba(0,200,150,.3);margin:6px 0}
.code-sub{font-size:.65rem;color:rgba(255,255,255,.4);font-weight:700;text-transform:uppercase;letter-spacing:1px}

/* ── TOGGLE SWITCH ── */
.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;inset:0;border-radius:24px;background:#d1d5db;transition:.2s;cursor:pointer}
.toggle-slider:before{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 2px 4px rgba(0,0,0,.2)}
.toggle-switch input:checked + .toggle-slider{background:var(--g)}
.toggle-switch input:checked + .toggle-slider:before{transform:translateX(20px)}

/* ── FORGOT PIN ── */
.forgot-panel{background:#fffbf0;border:1.5px solid var(--o);border-radius:14px;padding:14px;margin-bottom:14px;font-size:.8rem;line-height:1.7;color:#7a5c00}
.forgot-panel b{font-weight:800;color:#5c4300}

/* ── PRICING / UPGRADE ── */
.ku-chip{display:inline-flex;align-items:center;gap:5px;background:#f0fdf7;border:1.5px solid var(--g);border-radius:20px;padding:5px 12px;font-size:.7rem;font-weight:800;color:var(--gd);cursor:pointer;transition:all .2s;font-family:inherit}
.ku-chip:hover{background:#e0faf3;transform:translateY(-1px)}
.ku-chip-pro{background:linear-gradient(135deg,#fff3cd,#fff8dc);border-color:#ffd700;color:#b8860b}
.ku-chip-pro:hover{background:linear-gradient(135deg,#ffe8a0,#fff3cd)}

/* ── RECURRING EXPENSES ── */
.rec-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.rec-row:last-child{border-bottom:none}
.rec-info{flex:1;min-width:0}
.rec-title{display:block;font-weight:700;font-size:.88rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-meta{display:block;font-size:.68rem;color:var(--muted);margin-top:3px;font-weight:600}
.rec-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.rec-amt{font-weight:900;font-size:.9rem;color:var(--text)}
.rec-del{background:#fff0f2;border:1.5px solid #ffd6da;color:var(--r);border-radius:20px;padding:5px 11px;font-size:.7rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .18s;white-space:nowrap}
.rec-del:hover{background:#ffe0e4}
.dash-empty{font-size:.78rem;color:var(--muted);padding:10px 0;font-style:italic}

/* ── DASHBOARD ── */
.dash-hero{background:linear-gradient(145deg,#0d1e2e,#0f2740);border-radius:18px;padding:20px 18px 16px;color:#fff;margin-bottom:14px;border:1px solid rgba(255,255,255,.07);text-align:center;position:relative;overflow:hidden}
.dash-hero::after{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,150,.15) 0%,transparent 70%);pointer-events:none}
.dash-av{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--gd));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.15rem;color:#fff;margin:0 auto 10px;box-shadow:0 0 0 4px rgba(0,200,150,.2)}
.dash-name{font-size:1.1rem;font-weight:900;margin-bottom:2px}
.dash-group{font-size:.72rem;opacity:.65;margin-bottom:10px}
.dash-bal{display:inline-block;padding:6px 16px;border-radius:20px;font-size:.82rem;font-weight:800;margin-top:4px}
.dash-bal.pos{background:rgba(0,200,150,.2);color:#00e8a8}
.dash-bal.neg{background:rgba(255,71,87,.2);color:#ff8a95}
.dash-bal.even{background:rgba(255,255,255,.15);color:rgba(255,255,255,.85)}
.dash-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}
.dash-card{background:var(--bg);border:1.5px solid var(--border);border-radius:13px;padding:12px 10px;text-align:center}
.dc-val{font-size:.9rem;font-weight:900;color:var(--text);margin-bottom:3px;word-break:break-all}
.dc-lbl{font-size:.6rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.dash-insight{background:#f0fdf7;border:1.5px solid var(--g);border-radius:10px;padding:10px 13px;font-size:.8rem;color:var(--gd);margin-bottom:14px;font-weight:600}
.dash-section-title{font-size:.67rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin:14px 0 8px;padding-top:10px;border-top:1px solid var(--border)}
.dash-section-title:first-of-type{border-top:none}
.dash-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:.82rem;color:var(--text)}
.dash-row:last-child{border-bottom:none}
.dash-empty{font-size:.78rem;color:var(--muted);padding:10px 0;font-style:italic}

/* ── IMPORT UI ── */
.import-drop{border:2.5px dashed var(--border);border-radius:14px;padding:28px 16px;text-align:center;cursor:pointer;transition:all .2s;background:#fafbfc;margin-bottom:14px}
.import-drop.drag,.import-drop.hover{border-color:var(--g);background:#f0fdf7}
.import-drop .ij,.import-drop .iej{font-size:2.2rem;margin-bottom:8px}
.import-drop p{font-size:.82rem;color:var(--muted);line-height:1.6}
.import-preview{background:#f5f7fa;border-radius:12px;padding:12px 14px;margin-bottom:12px;max-height:220px;overflow-y:auto;font-size:.74rem;line-height:1.8}
.imp-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}
.imp-row:last-child{border-bottom:none}
.imp-row .ir-chk{flex-shrink:0;width:18px;height:18px;accent-color:var(--g);cursor:pointer}
.imp-row .ir-desc{flex:1;font-weight:700;font-size:.76rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.imp-row .ir-meta{font-size:.66rem;color:var(--muted);flex-shrink:0}
.imp-row .ir-amt{font-weight:900;font-size:.78rem;color:var(--text);flex-shrink:0;min-width:58px;text-align:right}
.imp-warning,.imp-warn{background:#fffbf0;border:1.5px solid var(--o);border-radius:10px;padding:10px 13px;font-size:.74rem;color:#8a5c00;line-height:1.7;margin-bottom:12px}
.imp-warning b,.imp-warn b{font-weight:800}
.imp-stat{display:flex;gap:10px;margin-bottom:12px}
.imp-stat-box{flex:1;background:var(--bg);border-radius:10px;padding:10px;text-align:center}
.imp-stat-box .isv{font-size:1.1rem;font-weight:900;color:var(--g)}
.imp-stat-box .isl{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:700}

/* ── SECURITY BADGE ── */
.sec-badge{display:inline-flex;align-items:center;gap:5px;background:#e6fdf5;border:1px solid var(--g);border-radius:20px;padding:5px 12px;font-size:.67rem;font-weight:700;color:var(--gd);margin-bottom:14px}

/* ── HOW IT WORKS ── */
.how-it-works{background:#f4f6fb;border-radius:14px;padding:12px 14px;margin-bottom:16px;display:flex;flex-direction:column;gap:8px}
.hiw-step{display:flex;align-items:flex-start;gap:10px;font-size:.78rem;color:var(--text);line-height:1.5;font-weight:600}
.hiw-num{min-width:22px;height:22px;border-radius:50%;background:var(--g);color:#fff;font-size:.68rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* ── SPLIT LIVE PREVIEW ── */
#split-live-preview{display:none;background:#f0fdf7;border:1.5px solid #c8f5e6;border-radius:11px;padding:10px 12px;margin-top:8px}

/* ── DISABLED STATE ── */
.sbtn2:disabled,.btn:disabled{opacity:.6;cursor:not-allowed;transform:none !important;box-shadow:none !important}

/* ── ABOUT ── */
.about-hero{background:var(--nav);border-radius:16px;padding:22px;text-align:center;color:#fff;margin-bottom:14px}
.about-hero .emoji{font-size:2.8rem;margin-bottom:8px}
.about-hero h3{font-size:1.15rem;font-weight:900;margin-bottom:5px}
.about-hero p{font-size:.78rem;opacity:.65;line-height:1.7}
.about-dev{background:#f8f9fc;border-radius:13px;padding:14px;margin-bottom:12px;display:flex;align-items:center;gap:12px}
.about-version{text-align:center;font-size:.72rem;color:var(--muted);margin-top:8px}
.dev-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--gd));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.9rem;color:#fff;flex-shrink:0}
.dev-info .name{font-weight:800;font-size:.9rem}
.dev-info .role{font-size:.72rem;color:var(--muted);margin-top:2px}

/* ══════════════════════════════════════════════════════════
   DESKTOP POLISH  (≥ 600 px)
   Fixes: cramped tab bar, oversized who-bar, mobile-only
   more-sheet rendering on wide screens.
   ══════════════════════════════════════════════════════════ */
@media (min-width: 600px) {

  /* ── App shell ── */
  #app {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  }

  /* ── Top nav: taller, roomier ── */
  nav.top-nav {
    height: 64px;
    padding: 0 32px;
  }
  .brand-name { font-size: 1.15rem; }
  .brand-group { max-width: 220px; }
  .nav-r { gap: 10px; }
  .nbtn { font-size: .85rem; padding: 7px 14px; }

  /* ── Tab bar: bigger, spaced, pill-style active indicator ── */
  .tabs {
    top: 64px;
    padding: 0 24px;
    gap: 4px;
  }
  .tab {
    font-size: .84rem;
    padding: 16px 20px;
    letter-spacing: .2px;
    border-bottom-width: 3px;
  }
  .tab.on {
    background: rgba(0,200,150,.06);
  }
  .tab:hover {
    color: rgba(255,255,255,.9);
    background: rgba(255,255,255,.05);
  }

  /* ── sync banner offset for taller nav ── */
  .sync-banner { top: 64px; }

  /* ── Who bar: compact on desktop ── */
  .who {
    border-radius: 14px;
    padding: 10px 16px;
    margin-bottom: 10px;
  }
  .who-av { width: 38px; height: 38px; font-size: .85rem; }
  .wl { font-size: .52rem; }
  .wn { font-size: .88rem; }
  .wu { font-size: .68rem; }
  /* Actions row instead of column */
  .who-actions { flex-direction: row; gap: 8px; }
  .wsw { padding: 6px 14px; font-size: .74rem; width: auto; }

  /* ── More-sheet: dropdown instead of bottom sheet ── */
  .more-backdrop { display: none !important; }
  .more-sheet {
    position: fixed;
    bottom: auto !important;
    top: 132px;
    right: 20px;
    left: auto;
    border-radius: 16px !important;
    max-width: 240px;
    max-height: calc(100vh - 150px);
    overflow-y: auto;
    padding: 6px 0 12px !important;
    box-shadow: 0 12px 40px rgba(0,0,0,.35), 0 2px 8px rgba(0,0,0,.2);
    transition: opacity .18s ease, transform .18s ease !important;
    transform: scale(.94) translateY(-8px);
    opacity: 0;
    pointer-events: none;
  }
  .more-sheet.open {
    bottom: auto !important;
    transform: scale(1) translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .more-sheet::before { display: none; }

  /* ── Wrap ── */
  .wrap { padding: 16px 24px 32px; max-width: 900px; }

  /* ── Cards ── */
  .card { padding: 20px; }
}

@media (min-width: 900px) {
  .wrap { padding: 20px 32px 40px; }
}

/* ── DEMO MODE BANNER ── */
#demo-mode-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  /* Sit in normal document flow right below sync-banner, no sticky positioning
     that fights with the nav/tabs stack */
  position: relative;
  z-index: 96;
  background: linear-gradient(135deg, #ff6b35, #f7c59f);
  border-bottom: 2px solid #ff6b35;
  padding: 9px 16px;
  font-size: .78rem;
  font-weight: 800;
  color: #1a1a2e;
  box-shadow: 0 2px 8px rgba(255,107,53,.2);
}
body.dark #demo-mode-banner {
  background: linear-gradient(135deg, #c04a18, #8a3a0a);
  border-bottom-color: #c04a18;
  color: #f7e0d0;
}
#demo-mode-banner button {
  background: #1a1a2e;
  color: #fff;
  border: none;
  border-radius: 9px;
  padding: 6px 13px;
  font-size: .72rem;
  font-weight: 800;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  flex-shrink: 0;
  min-height: 32px;
}
body.dark #demo-mode-banner button {
  background: #f7e0d0;
  color: #1a1a2e;
}
/* Demo button pulse on landing screen */
#demo-btn {
  animation: demo-pulse 2.4s ease-in-out infinite;
}
@keyframes demo-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(255,107,53,0); }
  50%      { box-shadow: 0 0 0 8px rgba(255,107,53,.22); }
}
/* PIN shake on wrong entry */
@keyframes shake {
  0%,100% { transform: translateX(0); }
  20%     { transform: translateX(-6px); }
  40%     { transform: translateX(6px); }
  60%     { transform: translateX(-4px); }
  80%     { transform: translateX(4px); }
}
.shake { animation: shake 0.45s ease; }
/* Hide PWA install banner when already running as installed PWA */
@media (display-mode: standalone), (display-mode: fullscreen) {
  #pwa-install-banner { display: none !important; }
}

/* ──────────────────────────────── MY DASHBOARD ──────────────────────────────── */
.kd-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.kd-av {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  font-weight: 900;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.kd-header-info { flex: 1; min-width: 0; }
.kd-name { font-size: 1rem; font-weight: 900; color: var(--text); }
.kd-grp  { font-size: .72rem; color: var(--muted); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-streak {
  background: linear-gradient(135deg,#ff6b35,#f59e0b);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
  border-radius: 20px;
  padding: 4px 10px;
  flex-shrink: 0;
  white-space: nowrap;
}

.kd-bal-card {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
  margin-bottom: 14px;
  text-align: center;
  transition: border-color .3s;
}
.kd-bal-label {
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--muted);
  margin-bottom: 4px;
}
.kd-bal-amount {
  font-size: 1.9rem;
  font-weight: 900;
  letter-spacing: -.5px;
  line-height: 1.1;
  margin-bottom: 8px;
}
.kd-bal-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: center;
  margin-top: 6px;
}
.kd-chip {
  font-size: .64rem;
  font-weight: 700;
  border-radius: 20px;
  padding: 3px 9px;
  white-space: nowrap;
}
.kd-chip-owe  { background: #fff0f2; color: var(--r); }
.kd-chip-owed { background: #e6fdf5; color: var(--gd); }

.kd-stats-row {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 8px;
  margin-bottom: 14px;
}
.kd-stat-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 13px;
  padding: 10px 8px;
  text-align: center;
}
.kd-stat-val {
  font-size: .84rem;
  font-weight: 900;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.kd-stat-lbl {
  font-size: .62rem;
  font-weight: 700;
  color: var(--muted);
  margin-top: 2px;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.kd-section-title {
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .9px;
  color: var(--muted);
  margin: 16px 0 8px;
}

.kd-month-row {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(130px,1fr));
  gap: 8px;
  margin-bottom: 2px;
}
.kd-month-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 13px;
  padding: 12px 14px;
}
.kd-month-val {
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--text);
}
.kd-month-lbl {
  font-size: .65rem;
  color: var(--muted);
  font-weight: 700;
  margin-top: 2px;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.kd-mom {
  font-size: .66rem;
  font-weight: 800;
  margin-top: 4px;
}
.kd-budget-bar {
  height: 5px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
  margin-top: 8px;
}
.kd-budget-fill {
  height: 100%;
  border-radius: 4px;
  transition: width .5s;
}

.kd-cats {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 2px;
}
.kd-cat-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 9px 12px;
}
.kd-cat-icon { font-size: 1.1rem; width: 26px; text-align: center; flex-shrink: 0; }
.kd-cat-body { flex: 1; min-width: 0; }
.kd-cat-top {
  display: flex;
  justify-content: space-between;
  font-size: .78rem;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 5px;
}
.kd-cat-bar {
  height: 5px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.kd-cat-fill {
  height: 100%;
  background: var(--g);
  border-radius: 4px;
  transition: width .5s;
}

.kd-settle-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 2px;
}
.kd-settle-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 13px;
  border: 1.5px solid var(--border);
  background: var(--card);
}
.kd-settle-owe  { border-left: 3.5px solid var(--r); }
.kd-settle-owed { border-left: 3.5px solid var(--g); }
.kd-settle-av {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .72rem;
  font-weight: 900;
  color: #fff;
  flex-shrink: 0;
}
.kd-settle-info { flex: 1; min-width: 0; }
.kd-settle-name { font-size: .82rem; font-weight: 800; color: var(--text); }
.kd-settle-dir  { font-size: .66rem; color: var(--muted); font-weight: 700; }
.kd-settle-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.kd-settle-amt  { font-size: .86rem; font-weight: 900; }
.kd-settle-btn {
  font-size: .65rem;
  font-weight: 800;
  border: none;
  border-radius: 9px;
  padding: 4px 10px;
  cursor: pointer;
  font-family: inherit;
  background: #fff0f2;
  color: var(--r);
  min-height: 28px;
}
.kd-settle-btn-g { background: #e6fdf5; color: var(--gd); }

.kd-mem-bars {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 2px;
}
.kd-mem-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 8px 12px;
}
.kd-mem-me { border-color: var(--g); }
.kd-mem-bar-av {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .62rem;
  font-weight: 900;
  color: #fff;
  flex-shrink: 0;
}
.kd-mem-bar-body { flex: 1; min-width: 0; }
.kd-mem-bar-top {
  display: flex;
  justify-content: space-between;
  font-size: .76rem;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 5px;
}
.kd-mem-bar-track {
  height: 5px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.kd-mem-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width .5s;
}

.kd-actions {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 8px;
  margin-bottom: 4px;
}
.kd-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 12px 6px;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 13px;
  font-family: inherit;
  font-size: 1.2rem;
  cursor: pointer;
  color: var(--text);
  transition: background .15s, border-color .15s, transform .1s;
  -webkit-tap-highlight-color: transparent;
}
.kd-action-btn span {
  font-size: .63rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
}
.kd-action-btn:active { transform: scale(.96); background: var(--border); }
body.dark .kd-action-btn:active { background: #2a2a3e; }

/* ── Utility classes used in JS-generated markup ───────────────────────── */
@keyframes pulse-anim {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.7; transform:scale(1.04); }
}
.pulse { animation: pulse-anim 1.4s ease-in-out infinite; }

/* Mobile-admin tab active state */
.ma-tab-active {
  color: var(--g);
  border-bottom: 2px solid var(--g);
  font-weight: 700;
}

/* ══════════════════════════════════════════════════════════
   PERSONAL EXPENSE TRACKER
   ══════════════════════════════════════════════════════════ */
#pt-root { padding: 0 0 24px; }

/* Header */
.pt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  gap: 10px;
}
.pt-month-label {
  font-size: 1rem;
  font-weight: 900;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 7px;
}
.pt-month-sub { font-size: .65rem; color: var(--muted); font-weight: 700; text-transform: uppercase; letter-spacing: .6px; margin-top: 2px; }
.pt-now-badge { font-size: .58rem; background: var(--g); color: #fff; border-radius: 8px; padding: 2px 7px; font-weight: 800; letter-spacing: .3px; vertical-align: middle; }
.pt-month-nav {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-size: 1.15rem;
  font-weight: 700;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: all .18s;
  font-family: inherit;
}
.pt-month-nav:hover { border-color: var(--g); color: var(--g); background: #f0fdf7; }

/* Hero card */
.pt-hero {
  background: linear-gradient(145deg, #0d1e2e 0%, #0f2740 60%, #0a1e32 100%);
  border-radius: 20px;
  padding: 20px 18px 16px;
  color: #fff;
  margin-bottom: 14px;
  border: 1px solid rgba(255,255,255,.08);
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.07);
}
.pt-hero::after {
  content: '';
  position: absolute; top: -60px; right: -60px;
  width: 160px; height: 160px; border-radius: 50%;
  background: radial-gradient(circle, rgba(0,200,150,.12) 0%, transparent 70%);
  pointer-events: none;
}
.pt-hero-over::after { background: radial-gradient(circle, rgba(255,71,87,.15) 0%, transparent 70%); }
.pt-hero-warn::after { background: radial-gradient(circle, rgba(255,165,2,.12) 0%, transparent 70%); }
.pt-hero-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
}
.pt-hero-label { font-size: .6rem; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; opacity: .5; }
.pt-hero-edit {
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18);
  color: #fff; border-radius: 9px; padding: 4px 10px;
  font-size: .68rem; font-weight: 700; cursor: pointer; font-family: inherit;
  transition: all .18s;
}
.pt-hero-edit:hover { background: rgba(255,255,255,.2); }
.pt-hero-amt {
  font-size: 2.1rem; font-weight: 900; letter-spacing: -1.5px; line-height: 1.05;
  margin-bottom: 10px;
}
.pt-budget-row {
  display: flex; align-items: center; gap: 10px; margin-bottom: 14px;
}
.pt-budget-track {
  flex: 1; height: 5px; border-radius: 3px; background: rgba(255,255,255,.15); overflow: hidden;
}
.pt-budget-fill { height: 100%; border-radius: 3px; transition: width .5s; }
.pt-budget-label { font-size: .68rem; font-weight: 700; opacity: .7; white-space: nowrap; flex-shrink: 0; }
.pt-set-budget-hint {
  background: rgba(0,200,150,.15); border: 1px dashed rgba(0,200,150,.4);
  color: var(--g); border-radius: 10px; padding: 5px 14px; font-size: .74rem;
  font-weight: 700; cursor: pointer; font-family: inherit;
}
.pt-hero-stats {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 8px;
  border-top: 1px solid rgba(255,255,255,.1); padding-top: 12px;
}
.pt-hero-stat { text-align: center; }
.pt-hero-stat-val { display: block; font-size: .78rem; font-weight: 900; }
.pt-hero-stat-lbl { display: block; font-size: .58rem; opacity: .5; font-weight: 600; margin-top: 2px; text-transform: uppercase; letter-spacing: .4px; }

/* Quick actions */
.pt-actions {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 8px;
  margin-bottom: 16px;
}
.pt-action {
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  padding: 12px 6px;
  background: var(--card); border: 1.5px solid var(--border);
  border-radius: 14px; font-family: inherit; font-size: 1.25rem;
  cursor: pointer; color: var(--text);
  transition: background .15s, border-color .15s, transform .1s;
  -webkit-tap-highlight-color: transparent;
}
.pt-action span:last-child { font-size: .6rem; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); }
.pt-action:active { transform: scale(.95); background: var(--border); }

/* Section title */
.pt-section-title {
  font-size: .65rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; color: var(--muted); margin: 0 0 8px;
}

/* Category rows */
.pt-cats { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.pt-cat-row {
  display: flex; align-items: center; gap: 10px;
  background: var(--card); border: 1.5px solid var(--border);
  border-radius: 13px; padding: 10px 12px; cursor: pointer;
  transition: border-color .18s, transform .1s;
}
.pt-cat-row:hover { border-color: rgba(0,200,150,.4); }
.pt-cat-row:active { transform: scale(.98); }
.pt-cat-icon {
  width: 38px; height: 38px; border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
}
.pt-cat-body { flex: 1; min-width: 0; }
.pt-cat-top { display: flex; justify-content: space-between; font-size: .8rem; font-weight: 800; color: var(--text); margin-bottom: 5px; }
.pt-cat-bar { height: 4px; background: var(--border); border-radius: 3px; overflow: hidden; }
.pt-cat-fill { height: 100%; border-radius: 3px; transition: width .5s; }
.pt-cat-pct { font-size: .7rem; font-weight: 800; color: var(--muted); flex-shrink: 0; min-width: 32px; text-align: right; }

/* Entry list */
.pt-entries { display: flex; flex-direction: column; gap: 6px; }
.pt-entry {
  display: flex; align-items: center; gap: 10px;
  background: var(--card); border: 1.5px solid var(--border);
  border-radius: 12px; padding: 10px 12px;
  transition: border-color .15s;
}
.pt-entry:hover { border-color: rgba(0,200,150,.3); }
.pt-entry-icon {
  width: 36px; height: 36px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
}
.pt-entry-body { flex: 1; min-width: 0; }
.pt-entry-title { font-size: .84rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pt-entry-meta { font-size: .66rem; color: var(--muted); margin-top: 2px; font-weight: 600; }
.pt-entry-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.pt-entry-amt { font-size: .88rem; font-weight: 900; color: var(--text); }
.pt-entry-btns { display: flex; gap: 3px; }
.pt-entry-btns button {
  background: none; border: none; cursor: pointer; font-size: .78rem;
  padding: 3px 5px; border-radius: 6px; line-height: 1;
  transition: background .15s;
}
.pt-entry-btns button:hover { background: var(--border); }

/* Empty state */
.pt-empty {
  text-align: center; padding: 24px 12px;
  color: var(--muted); font-size: .82rem; line-height: 1.7;
}
.pt-empty-cta {
  background: var(--g); color: #fff; border: none;
  border-radius: 10px; padding: 6px 14px; font-size: .76rem;
  font-weight: 800; cursor: pointer; font-family: inherit; margin-left: 8px;
}

/* Chart modal specifics */
#pt-chart-donut, #pt-chart-trend {
  display: block; width: 100% !important; height: 200px !important;
}
.pt-chart-wrap { margin-bottom: 18px; }
.pt-chart-title { font-size: .65rem; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); margin-bottom: 8px; }

/* Budget form */
.pt-budget-cat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 8px; }
.pt-budget-cat-item { display: flex; flex-direction: column; gap: 3px; }
.pt-budget-cat-label { font-size: .65rem; font-weight: 700; color: var(--muted); }
.pt-budget-cat-input {
  padding: 8px 10px; border: 1.5px solid var(--border); border-radius: 10px;
  font-size: .84rem; font-family: inherit; background: #fafbfc;
  color: var(--text); outline: none; width: 100%;
}
.pt-budget-cat-input:focus { border-color: var(--g); background: #fff; }
body.dark .pt-budget-cat-input { background: #243044; border-color: #2d3f55; color: #e8edf5; }

/* Dark mode overrides */
body.dark .pt-cat-row,
body.dark .pt-entry { border-color: #243044; }
body.dark .pt-cat-row:hover { border-color: rgba(0,200,150,.35); }
body.dark .pt-action { border-color: #243044; background: #1a2535; }
body.dark .pt-month-nav { border-color: #243044; background: #1a2535; color: #e8edf5; }
