:root{
  --bg:#f5f2ec;
  --line:#d8d2c7;
  --green:#163b2d;
  --green-2:#1f523a;
  --green-3:#2c694b;
  --green-soft:#244e3c;
  --mint:#53c6a0;
  --orange:#eea16c;
  --text:#243128;
  --muted:#7f827b;
  --white:#ffffff;
}
*{box-sizing:border-box}
body.app-body{margin:0;background:var(--bg);font-family:'Plus Jakarta Sans',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);padding-bottom:84px}
.dashboard-shell{width:min(430px,100%);margin:0 auto;background:var(--bg);min-height:100dvh}
.top-green{background:linear-gradient(180deg,#14392c 0%, #173f30 56%, #173f30 100%);padding:6px 8px 14px}
.app-topbar{display:flex;align-items:center;justify-content:space-between;padding:8px 8px 14px;border-bottom:1px solid rgba(255,255,255,.08)}
.app-identity{display:flex;align-items:center;gap:10px;min-width:0}
.home-badge{width:34px;height:34px;border-radius:999px;background:#2a6b4a;display:grid;place-items:center;font-size:17px;box-shadow:inset 0 0 0 2px rgba(255,255,255,.08)}
.identity-text{min-width:0}
.identity-title{margin:0;color:#fff;font-size:13px;font-weight:800;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:245px}
.identity-sub{margin-top:2px;color:#9cc0ac;font-size:11px}
.bell-btn{width:36px;height:36px;border-radius:12px;background:#2b6a4b;display:grid;place-items:center;color:#fff;text-decoration:none;font-size:18px}
.hero-balance{margin-top:10px;background:linear-gradient(180deg,#255f44 0%, #235740 100%);border-radius:22px;padding:16px 18px 18px;color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.hero-balance small{display:block;color:#abccbb;font-size:11px;margin-bottom:6px}
.hero-balance h1{margin:0 0 14px;font-size:20px;line-height:1.05;letter-spacing:-.02em}
.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat-box{background:#173f30;border-radius:14px;padding:10px 12px;min-height:74px}
.stat-box .dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:middle}.dot.income{background:#51d89f}.dot.expense{background:#f5a777}
.stat-box .label{color:#b1c9ba;font-size:11px}.stat-box .value{display:block;margin-top:8px;color:#fff;font-size:14px;font-weight:800}
.month-switch{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:10px;padding:10px 16px 6px}
.month-btn{width:34px;height:34px;border-radius:11px;border:1px solid #d7d1c7;background:#fbfaf7;display:grid;place-items:center;color:#6f726b;text-decoration:none;font-size:16px;box-shadow:0 1px 0 rgba(0,0,0,.03)}
.month-label{text-align:center;font-size:14px;font-weight:800;color:#2f322d}
.card-block{background:#fbfaf8;border:1px solid var(--line);border-radius:18px;margin:10px 16px;padding:14px 14px 16px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.card-head{font-size:10px;font-weight:800;color:#8a8d84;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.quick-item{text-decoration:none;color:#4f544e;text-align:center}
.quick-icon{width:52px;height:52px;border-radius:16px;margin:0 auto 9px;display:grid;place-items:center;font-size:23px}
.quick-icon.plus{background:#eef0fb;color:#7081c4}.quick-icon.chart{background:#e7f6ef;color:#47aa86}.quick-icon.export{background:#fff0ea;color:#e0855a}.quick-icon.list{background:#f0eff5;color:#81818f}
.quick-item span{display:block;font-size:11px}
.category-wrap{display:grid;grid-template-columns:124px 1fr;gap:10px;align-items:center}
.donut{width:108px;height:108px;border-radius:50%;background:conic-gradient(#d77647 0 96%, #89b774 96% 99%, #c9c1ae 99% 100%);display:grid;place-items:center;margin:0 auto;position:relative}
.donut::before{content:"";width:74px;height:74px;border-radius:50%;background:#fff;box-shadow:inset 0 0 0 1px #efe8de;position:absolute}
.donut-inner{position:relative;text-align:center;z-index:1}
.donut-inner small{display:block;font-size:9px;color:#868981}.donut-inner b{font-size:16px;color:#353731}
.legend-list{display:grid;gap:7px}
.legend-item{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:6px;font-size:12px;color:#62655e}.lg-dot{width:8px;height:8px;border-radius:50%}.lg-1{background:#d77647}.lg-2{background:#9ec47c}.lg-3{background:#dfb34b}
.legend-item b{color:#343630;font-weight:700}.legend-item em{font-style:normal;color:#646760;font-size:11px}
.tab-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.premium-cap{font-size:10px;color:#9b9a90;font-weight:700}
.tab-switch{background:#efebe5;border-radius:12px;padding:4px;display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:16px}.tab-switch span{height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#8a877f}.tab-switch .active{background:#184635;color:#fff}
.empty-box{text-align:center;padding:16px 8px 4px;color:#8d8d84;font-size:12px;line-height:1.5}
.action-wide{display:flex;margin-top:16px}.action-wide a{width:100%;height:40px;border-radius:12px;background:#184635;color:#fff;text-decoration:none;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.tx-list{display:grid;gap:0}
.tx-item{display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:10px;align-items:center;padding:11px 0;border-bottom:1px solid #e7e0d5}.tx-item:last-child{border-bottom:none;padding-bottom:0}
.tx-pin{width:28px;height:28px;border-radius:9px;background:#fdeeea;display:grid;place-items:center;font-size:14px}
.tx-main{min-width:0}.tx-main b{display:block;font-size:13px;color:#30332e;line-height:1.25}.tx-meta{font-size:10.5px;color:#8b8c84;line-height:1.45}.tx-tag{display:inline-block;padding:1px 6px;border-radius:8px;background:#edf4e8;color:#4c7a4a;font-size:10px;margin-left:4px}.tx-amount{font-size:13px;font-weight:800;white-space:nowrap}.tx-amount.expense{color:#c95f32}.tx-amount.income{color:#27805a}
.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:min(430px,100%);background:#fbfaf7;border-top:1px solid #ddd6cb;display:grid;grid-template-columns:repeat(5,1fr);padding:8px 8px max(10px, env(safe-area-inset-bottom));z-index:60}
.nav-item{text-decoration:none;color:#9a9b94;display:flex;flex-direction:column;align-items:center;gap:5px;font-size:18px;font-weight:700}.nav-item span{font-size:10.5px;font-weight:600}.nav-item.active{color:#1d3d31}.nav-item.active span{color:#1d3d31}.nav-item.center-plus{font-size:21px}
@media (max-width:360px){.category-wrap{grid-template-columns:1fr}.legend-list{margin-top:8px}.identity-title{max-width:190px}.hero-balance h1{font-size:18px}}
.tab-switch a{height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#8a877f;text-decoration:none}.tab-switch a.active{background:#184635;color:#fff}.mini-totals{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}.mini-totals span{background:#f3f0ea;border-radius:12px;padding:10px;font-size:11px;color:#797c74}.mini-totals b{display:block;color:#243128;font-size:12px;margin-top:3px}.small-list{display:grid;gap:8px;margin-top:10px}.small-list div{border-bottom:1px solid #ebe4d9;padding:8px 0}.small-list b{display:block;font-size:13px}.small-list span{font-size:11px;color:#82857d}.mobile-form-page{width:min(430px,100%);margin:0 auto;padding:14px 16px 96px;background:#f5f2ec;min-height:100dvh}.simple-header{display:flex;align-items:center;gap:12px;margin:4px 0 14px}.simple-header a{width:34px;height:34px;border:1px solid #d8d2c7;background:#fff;border-radius:11px;display:grid;place-items:center;text-decoration:none;color:#4e554d}.simple-header h1{font-size:18px;margin:0;color:#1d3d31}.form-panel{background:#fbfaf8;border:1px solid #d8d2c7;border-radius:18px;padding:16px}.form-stack{display:grid;gap:10px}.form-stack label{font-size:12px;font-weight:800;color:#6e716a}.form-stack input,.form-stack select,.form-stack textarea{width:100%;min-height:44px;border:1px solid #ded8cc;border-radius:12px;background:#fff;padding:11px 12px;font:inherit}.form-stack button,.primary-wide{height:42px;border:0;border-radius:12px;background:#184635;color:#fff;font-weight:800;font-size:13px;text-decoration:none;display:flex;align-items:center;justify-content:center}.list-card{background:#fbfaf8;border:1px solid #d8d2c7;border-radius:18px;margin:10px 0;padding:14px}.list-card h3{font-size:14px;margin:0 0 5px}.list-card p{font-size:12px;margin:0;color:#797c74;line-height:1.5}.list-actions{margin-top:10px;display:flex;justify-content:flex-end}.delete-mini{font-size:12px;color:#c95f32;text-decoration:none;font-weight:800}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.report-tile{background:#fbfaf8;border:1px solid #d8d2c7;border-radius:18px;padding:14px}.report-tile small{font-size:10px;text-transform:uppercase;color:#8a8d84;font-weight:800}.report-tile b{display:block;margin-top:7px;font-size:16px;color:#1d3d31}


/* v21 persistent app header */
.top-green.app-persistent-header{width:min(430px,100%);margin:0 auto;padding-bottom:14px}
.mobile-form-page,.mobile-shell{padding-top:10px!important}
.page-header,.simple-header{margin-top:4px!important}
body.app-body{padding-top:0!important}


/* v22: remote Next CSS bridge + exact reference color alignment */
:root{
  --cb-ref-green:#1E3A2F;
  --cb-ref-card:#245B42;
  --cb-ref-deep:#173B2E;
  --cb-ref-bg:#F4F1EA;
  --cb-ref-line:#DCD5CA;
}
body.app-body{
  background:var(--cb-ref-bg)!important;
  font-family:"Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif!important;
}
.dashboard-shell,.mobile-form-page{background:var(--cb-ref-bg)!important}
.top-green{background:#1E3A2F!important}
.hero-balance{background:#245B42!important}
.stat-box{background:#173B2E!important}
.card-block,.list-card,.form-panel,.report-tile{background:#fffdfa!important;border-color:var(--cb-ref-line)!important}
.bottom-nav{background:#fffdfa!important;border-color:var(--cb-ref-line)!important}
.app-topbar{border-bottom-color:rgba(255,255,255,.08)!important}
button,.primary-wide,.action-wide a,.form-stack button{font-weight:700!important}


/* v23 exact reference icons */
.bell-btn svg{width:19px;height:19px;display:block}
.quick-icon svg{width:24px;height:24px;display:block}
.quick-icon.plus{background:#EEF0FF!important}
.quick-icon.chart{background:#EBF9F4!important}
.quick-icon.export{background:#FFF0EB!important}
.quick-icon.list{background:#F5F6FA!important}
.bottom-nav .nav-item{gap:4px!important;font-size:0!important;position:relative}
.bottom-nav .nav-item svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;display:block;margin-bottom:1px}
.bottom-nav .nav-item:first-child svg{fill:currentColor;stroke:none}
.bottom-nav .nav-item span{font-size:10.5px!important;line-height:1!important}
.bottom-nav .nav-item i{width:4px;height:4px;border-radius:999px;background:currentColor;display:block;margin-top:2px}
.home-badge{font-size:16px!important}
.bell-btn{color:#B6D0C3!important}


/* v24 single-page dashboard */
.single-dashboard .dash-panel{display:none}
.single-dashboard .dash-panel.active{display:block}
.single-dashboard button.quick-item{
  border:0;background:transparent;padding:0;font:inherit;cursor:pointer;
}
.single-dashboard .bottom-nav .nav-item i{display:none}
.single-dashboard .bottom-nav .nav-item.active i{display:block}
.filter-pills{display:flex;gap:7px;overflow:auto;padding:0 0 14px;margin-top:-2px}
.filter-pills button{border:1px solid #d8d2c7;background:#fff;border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700;color:#4a514b;white-space:nowrap}
.filter-pills button.active{background:#173b2e;color:#fff;border-color:#173b2e}
.month-heading{font-size:15px;color:#173b2e;margin:4px 0 10px;border-bottom:1px solid #d8d2c7;padding-bottom:10px}
.tx-right{text-align:right}
.tx-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:6px}
.tx-actions a{font-size:12px;text-decoration:none;background:#eef3ff;color:#4575d6;border-radius:7px;padding:4px 8px}
.tx-actions a.danger{background:#fff0f0;color:#d05d5d}
.profile-panel{text-align:center}
.profile-avatar{width:64px;height:64px;border-radius:22px;background:#eef6ee;display:grid;place-items:center;margin:4px auto 10px;font-size:28px}
.profile-panel h2{margin:0;font-size:18px;color:#173b2e}
.profile-panel p{margin:5px 0;color:#7f827b;font-size:13px}
.profile-meta{display:inline-flex;margin-top:10px;padding:6px 10px;border-radius:999px;background:#eef6ee;color:#173b2e;font-size:12px;font-weight:800}
.compact-form{margin-bottom:14px}
.compact-form input,.compact-form select{min-height:42px!important}
.tab-switch button{height:34px;border-radius:10px;border:0;background:transparent;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#8a877f}
.tab-switch button.active{background:#184635;color:#fff}


/* v25 polished single page forms */
.single-dashboard .dash-panel[data-panel="catat"] .card-block{
  margin-top:14px;
  padding:16px 16px 18px;
}
.single-dashboard .form-stack{
  display:grid!important;
  gap:11px!important;
}
.single-dashboard .form-stack label{
  font-size:12px!important;
  font-weight:800!important;
  color:#6f716b!important;
  line-height:1.2!important;
  margin:0!important;
}
.single-dashboard .form-stack input:not([type="radio"]),
.single-dashboard .form-stack select,
.single-dashboard .form-stack textarea{
  width:100%!important;
  min-height:46px!important;
  border:1px solid #ded6ca!important;
  border-radius:14px!important;
  background:#fff!important;
  padding:12px 14px!important;
  font-size:15px!important;
  color:#1f2f26!important;
  outline:none!important;
  box-shadow:none!important;
  appearance:auto!important;
}
.single-dashboard .form-stack textarea{
  min-height:96px!important;
  resize:vertical!important;
}
.single-dashboard .form-stack input:focus,
.single-dashboard .form-stack select:focus,
.single-dashboard .form-stack textarea:focus{
  border-color:#255f44!important;
  box-shadow:0 0 0 3px rgba(37,95,68,.10)!important;
}
.type-toggle{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:10px!important;
  margin:0 0 2px!important;
}
.type-chip{
  margin:0!important;
  display:block!important;
  cursor:pointer!important;
}
.type-chip input{
  position:absolute!important;
  opacity:0!important;
  width:1px!important;
  height:1px!important;
  pointer-events:none!important;
}
.type-chip span{
  height:46px!important;
  border-radius:14px!important;
  border:1px solid #ded6ca!important;
  background:#fff!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  color:#596057!important;
  font-size:13px!important;
  font-weight:800!important;
}
.type-chip span i{
  width:8px!important;
  height:8px!important;
  border-radius:50%!important;
  display:block!important;
}
.expense-chip span i{background:#f0997b!important}
.income-chip span i{background:#5dcaa5!important}
.type-chip input:checked + span{
  background:#184635!important;
  color:#fff!important;
  border-color:#184635!important;
  box-shadow:0 8px 18px rgba(24,70,53,.14)!important;
}
.single-dashboard .form-stack button{
  height:48px!important;
  border-radius:14px!important;
  border:0!important;
  background:#184635!important;
  color:#fff!important;
  font-size:14px!important;
  font-weight:800!important;
  margin-top:2px!important;
}
.single-dashboard .compact-form input,
.single-dashboard .compact-form select{
  min-height:44px!important;
}
.profile-panel{
  padding:22px 16px!important;
}
.profile-avatar{
  width:62px!important;
  height:62px!important;
  border-radius:22px!important;
  background:#ecf6ef!important;
  color:#143b2d!important;
  font-size:28px!important;
}
.profile-panel h2{
  font-size:18px!important;
  letter-spacing:-.02em!important;
  margin-top:8px!important;
}
.profile-panel p{
  font-size:13px!important;
  color:#7a7d76!important;
}
.profile-actions{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:9px!important;
  margin-top:14px!important;
}
.profile-actions a{
  min-height:42px!important;
  border-radius:13px!important;
  background:#184635!important;
  color:#fff!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-decoration:none!important;
  font-size:13px!important;
  font-weight:800!important;
}
.profile-actions a.logout-profile{
  background:#fff!important;
  color:#b4483a!important;
  border:1px solid #eadbd5!important;
}
.member-profile-list{
  display:grid!important;
  gap:10px!important;
}
.member-profile-row{
  display:flex!important;
  align-items:center!important;
  gap:11px!important;
  padding:10px!important;
  border-radius:14px!important;
  background:#f5f2ec!important;
}
.member-profile-row>span{
  width:36px!important;
  height:36px!important;
  border-radius:13px!important;
  background:#184635!important;
  color:#fff!important;
  display:grid!important;
  place-items:center!important;
  font-weight:800!important;
}
.member-profile-row b{
  display:block!important;
  font-size:13px!important;
  color:#203328!important;
}
.member-profile-row small{
  display:block!important;
  color:#85877f!important;
  font-size:11px!important;
  margin-top:2px!important;
}


/* v26 responsive category card */
.category-wrap{
  display:grid!important;
  grid-template-columns:minmax(104px,132px) minmax(0,1fr)!important;
  align-items:center!important;
  gap:12px!important;
  width:100%!important;
  overflow:hidden!important;
}
.donut{
  width:clamp(94px,28vw,122px)!important;
  height:clamp(94px,28vw,122px)!important;
  min-width:0!important;
}
.donut::before{
  width:68%!important;
  height:68%!important;
}
.donut-inner{
  max-width:76%!important;
  overflow:hidden!important;
}
.donut-inner small{
  font-size:9px!important;
  line-height:1.1!important;
}
.donut-inner b{
  display:block!important;
  font-size:clamp(12px,3.4vw,16px)!important;
  line-height:1.1!important;
  white-space:nowrap!important;
}
.legend-list{
  min-width:0!important;
  overflow:hidden!important;
}
.legend-item{
  display:grid!important;
  grid-template-columns:10px minmax(0,1fr) auto!important;
  gap:7px!important;
  align-items:center!important;
  width:100%!important;
  min-width:0!important;
}
.legend-item b{
  min-width:0!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  font-size:11.5px!important;
}
.legend-item em{
  min-width:0!important;
  white-space:nowrap!important;
  font-size:10.5px!important;
}
@media (max-width:390px){
  .card-block{margin-left:10px!important;margin-right:10px!important;padding-left:12px!important;padding-right:12px!important}
  .category-wrap{
    grid-template-columns:112px minmax(0,1fr)!important;
    gap:8px!important;
  }
  .donut{width:104px!important;height:104px!important}
  .legend-item{
    grid-template-columns:9px minmax(0,1fr)!important;
    row-gap:2px!important;
  }
  .legend-item em{
    grid-column:2!important;
    font-size:10px!important;
  }
}
@media (max-width:340px){
  .category-wrap{
    grid-template-columns:1fr!important;
    justify-items:center!important;
  }
  .legend-list{
    width:100%!important;
    margin-top:6px!important;
  }
  .legend-item{
    grid-template-columns:9px minmax(0,1fr) auto!important;
  }
  .legend-item em{
    grid-column:auto!important;
  }
}


/* v27 smaller category card */
.category-wrap{
  grid-template-columns:88px minmax(0,1fr)!important;
  gap:8px!important;
}
.donut{
  width:82px!important;
  height:82px!important;
}
.donut::before{
  width:62%!important;
  height:62%!important;
}
.donut-inner small{
  font-size:8px!important;
}
.donut-inner b{
  font-size:11px!important;
  letter-spacing:-.02em!important;
}
.legend-item{
  grid-template-columns:8px minmax(0,1fr)!important;
  gap:5px!important;
  margin-bottom:5px!important;
}
.legend-item b{
  font-size:10.5px!important;
}
.legend-item em{
  grid-column:2!important;
  font-size:9.5px!important;
  line-height:1.15!important;
  color:#6d716a!important;
}
.lg-dot{
  width:7px!important;
  height:7px!important;
}
@media (max-width:390px){
  .category-wrap{
    grid-template-columns:82px minmax(0,1fr)!important;
    gap:7px!important;
  }
  .donut{
    width:78px!important;
    height:78px!important;
  }
  .donut-inner b{
    font-size:10.5px!important;
  }
  .legend-item b{
    font-size:10px!important;
  }
  .legend-item em{
    font-size:9px!important;
  }
}
@media (max-width:340px){
  .category-wrap{
    grid-template-columns:76px minmax(0,1fr)!important;
    gap:6px!important;
    justify-items:stretch!important;
  }
  .donut{
    width:72px!important;
    height:72px!important;
  }
  .legend-list{
    margin-top:0!important;
  }
  .legend-item{
    grid-template-columns:7px minmax(0,1fr)!important;
  }
}

/* v28 workspace isolation UI */
.form-note.left{display:block;text-align:left;margin:6px 0 0;color:#7a7d76;font-size:12px;line-height:1.45}
.profile-actions a:first-child{background:#184635!important;color:#fff!important}


/* v29 category text + history filters */
.donut{
  width:72px!important;
  height:72px!important;
}
.donut::before{
  width:46px!important;
  height:46px!important;
}
.donut-inner{
  width:42px!important;
  max-width:42px!important;
  margin:0 auto!important;
  line-height:1.05!important;
}
.donut-inner small{
  display:block!important;
  font-size:7px!important;
  line-height:1.05!important;
  margin-bottom:1px!important;
}
.donut-inner b{
  display:block!important;
  font-size:11px!important;
  line-height:1.05!important;
  white-space:normal!important;
  word-break:break-word!important;
  overflow-wrap:anywhere!important;
  letter-spacing:-.02em!important;
}
.category-wrap{
  grid-template-columns:72px minmax(0,1fr)!important;
  gap:8px!important;
}
.legend-list{
  display:grid!important;
  gap:6px!important;
}
.legend-item{
  grid-template-columns:8px minmax(0,1fr)!important;
  gap:5px!important;
}
.legend-item b{
  font-size:10px!important;
  line-height:1.15!important;
}
.legend-item em{
  grid-column:2!important;
  font-size:9px!important;
  line-height:1.15!important;
  white-space:normal!important;
}
.filter-pills{
  flex-wrap:nowrap!important;
  overflow-x:auto!important;
  -webkit-overflow-scrolling:touch!important;
  padding-bottom:10px!important;
}
.filter-pills::-webkit-scrollbar{display:none}
.filter-pills button{
  flex:0 0 auto!important;
}
@media (max-width:390px){
  .category-wrap{
    grid-template-columns:68px minmax(0,1fr)!important;
    gap:7px!important;
  }
  .donut{
    width:66px!important;
    height:66px!important;
  }
  .donut::before{
    width:42px!important;
    height:42px!important;
  }
  .donut-inner{
    width:38px!important;
    max-width:38px!important;
  }
  .donut-inner small{font-size:6.5px!important}
  .donut-inner b{font-size:10px!important}
}
@media (max-width:340px){
  .category-wrap{
    grid-template-columns:64px minmax(0,1fr)!important;
  }
  .donut{
    width:62px!important;
    height:62px!important;
  }
  .donut::before{
    width:39px!important;
    height:39px!important;
  }
  .donut-inner{
    width:34px!important;
    max-width:34px!important;
  }
  .donut-inner b{font-size:9px!important}
}


/* v30 unified flash/alert UI */
.cb-alert-stack{
  width:100%;
  display:grid;
  gap:10px;
  margin:10px 0 12px;
}
.dashboard-shell>.cb-alert-stack,
.mobile-form-page>.cb-alert-stack,
.mobile-shell>.cb-alert-stack{
  padding:0 16px;
}
.auth-card .cb-alert-stack,
.owner-shell .cb-alert-stack,
.checkout-page .cb-alert-stack{
  padding:0;
}
.cb-alert{
  width:100%;
  min-height:48px;
  border-radius:16px;
  border:1px solid transparent;
  padding:11px 40px 11px 12px;
  display:grid;
  grid-template-columns:26px minmax(0,1fr);
  gap:10px;
  align-items:flex-start;
  position:relative;
  box-shadow:0 10px 24px rgba(23,40,31,.08);
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
.cb-alert-icon{
  width:26px;
  height:26px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-size:14px;
  line-height:1;
  font-weight:900;
  color:#fff;
}
.cb-alert-body{
  min-width:0;
  font-size:12.5px;
  line-height:1.42;
  color:#243128;
}
.cb-alert-body strong{
  display:block;
  font-size:12px;
  line-height:1.15;
  margin-bottom:2px;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.cb-alert-close{
  position:absolute;
  top:8px;
  right:8px;
  width:26px;
  height:26px;
  border:0;
  border-radius:9px;
  background:rgba(255,255,255,.65);
  color:inherit;
  cursor:pointer;
  font-size:18px;
  line-height:1;
  display:grid;
  place-items:center;
}
.cb-alert-success{
  background:#eef8f2;
  border-color:#ccebd8;
  color:#11623f;
}
.cb-alert-success .cb-alert-icon{background:#1f8a57}
.cb-alert-success .cb-alert-body strong{color:#11623f}

.cb-alert-error{
  background:#fff1ef;
  border-color:#ffd3cc;
  color:#b63224;
}
.cb-alert-error .cb-alert-icon{background:#d34a38}
.cb-alert-error .cb-alert-body strong{color:#b63224}

.cb-alert-warning{
  background:#fff7e8;
  border-color:#f3ddaf;
  color:#94600f;
}
.cb-alert-warning .cb-alert-icon{background:#d69221}
.cb-alert-warning .cb-alert-body strong{color:#94600f}

.cb-alert-info{
  background:#eef5ff;
  border-color:#cddffd;
  color:#265fa8;
}
.cb-alert-info .cb-alert-icon{background:#3b78d8}
.cb-alert-info .cb-alert-body strong{color:#265fa8}

/* backward compatibility for old .alert output */
.alert{
  border-radius:16px!important;
  padding:12px 14px!important;
  margin:10px 16px!important;
  font-size:13px!important;
  line-height:1.45!important;
  box-shadow:0 10px 24px rgba(23,40,31,.08)!important;
}
.alert.success{
  background:#eef8f2!important;
  border:1px solid #ccebd8!important;
  color:#11623f!important;
}
.alert.error{
  background:#fff1ef!important;
  border:1px solid #ffd3cc!important;
  color:#b63224!important;
}
@media (max-width:360px){
  .cb-alert{
    border-radius:14px;
    padding-right:36px;
  }
  .cb-alert-body{
    font-size:12px;
  }
}


/* v31 month navigation, wallet, category, button polish */
.month-switch .month-btn{
  transition:transform .14s ease, box-shadow .14s ease, background .14s ease;
}
.month-switch .month-btn:active{
  transform:scale(.94);
}
.wallet-overview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:-2px 16px 10px;
}
.wallet-card{
  background:#fffdfa;
  border:1px solid #dcd5ca;
  border-radius:17px;
  padding:12px;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}
.wallet-card span{
  display:block;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#888b84;
  font-weight:900;
}
.wallet-card b{
  display:block;
  margin-top:5px;
  font-size:16px;
  color:#173b2e;
  line-height:1.1;
}
.wallet-card small{
  display:block;
  margin-top:6px;
  font-size:9.5px;
  line-height:1.35;
  color:#7d8179;
}
.wallet-toggle{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.wallet-toggle label{
  margin:0!important;
  display:block;
  cursor:pointer;
}
.wallet-toggle input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.wallet-toggle span{
  height:44px;
  border:1px solid #ded6ca;
  border-radius:14px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:900;
  color:#596057;
}
.wallet-toggle input:checked + span{
  background:#184635;
  color:#fff;
  border-color:#184635;
  box-shadow:0 8px 18px rgba(24,70,53,.14);
}
.pretty-action-btn,
.action-wide button,
.action-wide a{
  width:100%!important;
  min-height:46px!important;
  border:0!important;
  border-radius:15px!important;
  background:linear-gradient(180deg,#255f44 0%,#184635 100%)!important;
  color:#fff!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:9px!important;
  font-size:13px!important;
  font-weight:900!important;
  text-decoration:none!important;
  box-shadow:0 10px 22px rgba(24,70,53,.18)!important;
}
.pretty-action-btn span{
  width:22px;
  height:22px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  display:grid;
  place-items:center;
  font-size:16px;
  line-height:1;
}
.pretty-submit{
  height:48px!important;
  border-radius:15px!important;
  border:0!important;
  background:linear-gradient(180deg,#255f44 0%,#184635 100%)!important;
  color:#fff!important;
  font-size:14px!important;
  font-weight:900!important;
  box-shadow:0 10px 22px rgba(24,70,53,.16)!important;
}
.category-chip-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.category-chip-list span{
  padding:8px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  border:1px solid #ded6ca;
  background:#fff;
  color:#596057;
}
.category-chip-list span.expense{
  background:#fff0eb;
  border-color:#f3d1c4;
  color:#b45a35;
}
.category-chip-list span.income{
  background:#eaf8f1;
  border-color:#c6ead9;
  color:#247b55;
}
.wallet-tag{
  display:inline-flex;
  margin-left:4px;
  padding:2px 6px;
  border-radius:999px;
  background:#edf1ef;
  color:#405449;
  font-size:10px;
  font-weight:800;
}
@media (max-width:360px){
  .wallet-overview{
    grid-template-columns:1fr;
  }
}


/* v32 global balance + month filter */
.balance-scope-note{
  margin:0 16px 8px;
  padding:9px 11px;
  border-radius:13px;
  background:#eef6ef;
  color:#456051;
  font-size:11px;
  line-height:1.4;
  border:1px solid #d8eadb;
}
.balance-scope-note a{
  color:#184635;
  font-weight:900;
  text-decoration:none;
}
.hero-balance small{
  text-transform:none!important;
}


/* v33 wallet transfer */
.wallet-overview{
  grid-template-columns:1fr 1fr!important;
}
.wallet-transfer-shortcut{
  grid-column:1 / -1;
  min-height:42px;
  border:0;
  border-radius:14px;
  background:linear-gradient(180deg,#255f44 0%,#184635 100%);
  color:#fff;
  font-size:13px;
  font-weight:900;
  box-shadow:0 10px 22px rgba(24,70,53,.16);
}
.quick-icon.wallet{
  background:#e9f6ef;
  color:#1e6f53;
}
.quick-icon.wallet svg{
  width:24px;
  height:24px;
  display:block;
}
.wallet-balance-list{
  display:grid;
  gap:10px;
}
.wallet-balance-list div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  border:1px solid #ded6ca;
  background:#fff;
  border-radius:15px;
  padding:12px;
}
.wallet-balance-list span{
  font-size:12px;
  font-weight:900;
  color:#6f746c;
}
.wallet-balance-list b{
  font-size:14px;
  color:#173b2e;
}
@media (max-width:360px){
  .wallet-overview{
    grid-template-columns:1fr!important;
  }
}


/* v34 reference UI polish */
.dashboard-shell{
  background:#f4f1ea!important;
}
.top-green{
  padding:6px 8px 14px!important;
}
.hero-balance{
  margin-top:8px!important;
  padding:14px 16px 15px!important;
  border-radius:18px!important;
}
.hero-balance h1{
  font-size:21px!important;
  margin-bottom:12px!important;
}
.stat-box{
  min-height:58px!important;
  border-radius:12px!important;
  padding:9px 10px!important;
}
.stat-box .value{
  margin-top:5px!important;
  font-size:13px!important;
}
.hero-wallet-mini{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:9px;
}
.hero-wallet-mini button{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(16,50,38,.72);
  color:#fff;
  border-radius:12px;
  min-height:42px;
  padding:7px 9px;
  text-align:left;
  cursor:pointer;
}
.hero-wallet-mini span{
  display:block;
  font-size:9px;
  color:#a8c9b8;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
}
.hero-wallet-mini b{
  display:block;
  margin-top:3px;
  font-size:13px;
  line-height:1.1;
}
.wallet-overview{
  display:none!important;
}
.month-switch{
  padding-top:9px!important;
}
.balance-scope-note{
  margin:0 16px 8px!important;
  padding:8px 10px!important;
  font-size:10.5px!important;
  border-radius:12px!important;
}
.quick-grid{
  grid-template-columns:repeat(4,1fr)!important;
  gap:10px!important;
}
.quick-icon{
  width:44px!important;
  height:44px!important;
  border-radius:14px!important;
  margin-bottom:8px!important;
}
.quick-icon svg{
  width:21px!important;
  height:21px!important;
}
.quick-item span{
  font-size:10.5px!important;
  font-weight:700!important;
}
.card-block{
  margin:10px 16px!important;
  padding:13px 13px 15px!important;
  border-radius:17px!important;
}
.category-wrap{
  grid-template-columns:78px minmax(0,1fr)!important;
  gap:9px!important;
}
.donut{
  width:72px!important;
  height:72px!important;
}
.donut::before{
  width:48px!important;
  height:48px!important;
}
.donut-inner{
  width:42px!important;
  max-width:42px!important;
}
.donut-inner small{
  font-size:7px!important;
}
.donut-inner b{
  font-size:10px!important;
  white-space:normal!important;
  overflow-wrap:anywhere!important;
  line-height:1.05!important;
}
.legend-item b{
  font-size:10.5px!important;
}
.legend-item em{
  font-size:9.2px!important;
}
.mini-wallet-link{
  width:100%;
  min-height:36px;
  margin:0 0 10px;
  border:1px solid #d8eadb;
  border-radius:12px;
  background:#eef6ef;
  color:#184635;
  font-size:12px;
  font-weight:900;
}
.pretty-action-btn,
.action-wide button,
.action-wide a,
.pretty-submit,
.wallet-transfer-shortcut{
  min-height:42px!important;
  border-radius:13px!important;
  box-shadow:none!important;
  background:#184635!important;
  font-size:13px!important;
}
.panel-title-mini{
  margin:-5px 0 12px;
  font-size:17px;
  color:#173b2e;
  letter-spacing:-.02em;
}
.wallet-balance-list div{
  padding:10px!important;
  border-radius:13px!important;
}
.wallet-balance-list b{
  font-size:13px!important;
}
.bottom-nav{
  height:66px!important;
}
@media (max-width:360px){
  .hero-wallet-mini{
    grid-template-columns:1fr 1fr;
  }
  .hero-wallet-mini b{
    font-size:11.5px;
  }
  .category-wrap{
    grid-template-columns:68px minmax(0,1fr)!important;
  }
  .donut{
    width:64px!important;
    height:64px!important;
  }
  .donut::before{
    width:42px!important;
    height:42px!important;
  }
}


/* v35 production activity + cleanup */
.identity-sub{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.balance-scope-note{
  display:none!important;
}
.activity-strip{
  display:grid;
  gap:8px;
  margin:10px 16px 8px;
}
.activity-pill{
  width:100%;
  border:1px solid #d8eadb;
  background:#eef6ef;
  color:#315544;
  border-radius:14px;
  padding:9px 11px;
  text-align:left;
  font-size:11px;
  line-height:1.35;
  cursor:pointer;
}
.activity-pill span{
  font-weight:900;
  color:#184635;
}
.activity-log-list{
  display:grid;
  gap:9px;
}
.activity-log-item{
  width:100%;
  border:1px solid #ded6ca;
  background:#fff;
  border-radius:15px;
  padding:11px;
  text-align:left;
  cursor:pointer;
}
.activity-log-item span{
  display:block;
  color:#184635;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
}
.activity-log-item b{
  display:block;
  margin-top:4px;
  font-size:13px;
  color:#253229;
}
.activity-log-item small{
  display:block;
  margin-top:4px;
  font-size:11px;
  color:#7b8178;
}


/* v36 popup edit, ajax actions, category button, pwa polish */
.field-with-action{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.field-with-action label{
  margin:0!important;
}
.field-with-action button{
  border:1px solid #d8eadb;
  background:#eef6ef;
  color:#184635;
  border-radius:999px;
  padding:7px 10px;
  font-size:11px;
  font-weight:900;
}
.cb-modal{
  position:fixed;
  inset:0;
  z-index:3000;
  display:none;
  align-items:flex-end;
  justify-content:center;
}
.cb-modal.open{
  display:flex;
}
.cb-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(17,24,20,.48);
}
.cb-modal-card{
  position:relative;
  z-index:1;
  width:min(430px,100%);
  max-height:88dvh;
  overflow:auto;
  background:#fbfaf8;
  border-radius:24px 24px 0 0;
  padding:18px 16px 22px;
  border:1px solid #ded6ca;
  box-shadow:0 -20px 48px rgba(0,0,0,.18);
}
.cb-modal-close{
  position:absolute;
  top:10px;
  right:10px;
  width:32px;
  height:32px;
  border:0;
  border-radius:12px;
  background:#eef1ec;
  color:#314236;
  font-size:20px;
}
.tx-edit-btn{
  border:0;
  background:transparent;
  color:#184635;
  font-size:11px;
  font-weight:900;
  padding:0;
}
.cb-floating-toast{
  margin:10px 16px!important;
}
button:disabled{
  opacity:.65;
}
@media (min-width:431px){
  .cb-modal{
    align-items:center;
  }
  .cb-modal-card{
    border-radius:24px;
  }
}


/* v37 menu fix + larger category chart */
.bottom-nav .nav-item{
  cursor:pointer!important;
  touch-action:manipulation!important;
}
.quick-item,
[data-tab-target]{
  cursor:pointer!important;
}
.card-block .category-wrap{
  grid-template-columns:128px minmax(0,1fr)!important;
  gap:14px!important;
  align-items:center!important;
}
.card-block .donut{
  width:118px!important;
  height:118px!important;
}
.card-block .donut::before{
  width:78px!important;
  height:78px!important;
}
.card-block .donut-inner{
  width:70px!important;
  max-width:70px!important;
}
.card-block .donut-inner small{
  font-size:10px!important;
  line-height:1.1!important;
  margin-bottom:3px!important;
}
.card-block .donut-inner b{
  font-size:15px!important;
  line-height:1.06!important;
  letter-spacing:-.04em!important;
  white-space:normal!important;
}
.card-block .legend-list{
  gap:9px!important;
}
.card-block .legend-item{
  grid-template-columns:10px minmax(0,1fr)!important;
  column-gap:7px!important;
  row-gap:2px!important;
}
.card-block .legend-item b{
  font-size:13px!important;
  line-height:1.18!important;
}
.card-block .legend-item em{
  font-size:11.5px!important;
  line-height:1.2!important;
  color:#6d716a!important;
}
.card-block .lg-dot{
  width:9px!important;
  height:9px!important;
}
@media (max-width:390px){
  .card-block .category-wrap{
    grid-template-columns:112px minmax(0,1fr)!important;
    gap:11px!important;
  }
  .card-block .donut{
    width:104px!important;
    height:104px!important;
  }
  .card-block .donut::before{
    width:68px!important;
    height:68px!important;
  }
  .card-block .donut-inner{
    width:60px!important;
    max-width:60px!important;
  }
  .card-block .donut-inner b{
    font-size:13px!important;
  }
  .card-block .legend-item b{
    font-size:12px!important;
  }
  .card-block .legend-item em{
    font-size:10.5px!important;
  }
}


/* v39 bottom sheet savings debts + popup alerts */
.cb-alert-stack{
  position:fixed!important;
  left:50%!important;
  bottom:18px!important;
  transform:translateX(-50%)!important;
  z-index:4000!important;
  width:min(398px,calc(100% - 32px))!important;
  padding:0!important;
  pointer-events:none!important;
}
.cb-alert{
  pointer-events:auto!important;
  margin:0!important;
  animation:sheetUp .22s ease-out!important;
}
.cb-modal.open .cb-modal-card{
  animation:sheetUp .22s ease-out;
}
@keyframes sheetUp{
  from{transform:translateY(24px);opacity:.4}
  to{transform:translateY(0);opacity:1}
}
.action-sheet .cb-modal-card{
  padding:28px 20px 26px!important;
}
.sheet-head{
  text-align:center;
  margin-bottom:22px;
}
.sheet-icon{
  width:42px;
  height:42px;
  border-radius:15px;
  margin:0 auto 10px;
  display:grid;
  place-items:center;
  background:#fff6d7;
}
.sheet-head h3{
  margin:0 0 8px;
  color:#173b2e;
  font-size:22px;
  line-height:1.1;
}
.sheet-head b{
  display:block;
  color:#173b2e;
  font-size:30px;
  line-height:1;
}
.sheet-action{
  width:100%;
  min-height:66px;
  border:0;
  border-radius:15px;
  margin-bottom:14px;
  padding:0 18px;
  display:flex;
  align-items:center;
  gap:10px;
  text-align:left;
  font-size:20px;
  font-weight:900;
}
.sheet-action.green{background:#d4f4df;color:#176238}
.sheet-action.orange{background:#ffddce;color:#9a4b2b}
.sheet-action.neutral{background:#f3f2ef;color:#173b2e}
.sheet-action.red{background:#ffe1e6;color:#a63844}
.sheet-cancel{
  width:100%;
  height:46px;
  border:0;
  background:transparent;
  color:#8b8b86;
  font-size:18px;
}
.active-finance-list{
  display:grid;
  gap:10px;
  margin-bottom:12px;
}
.finance-row{
  width:100%;
  border:1px solid #ded6ca;
  background:#fffdfa;
  border-radius:16px;
  padding:12px;
  display:flex;
  gap:11px;
  align-items:center;
  text-align:left;
}
.finance-row>span{
  width:38px;
  height:38px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:#eef6ef;
  flex:0 0 38px;
}
.finance-row b{
  display:block;
  font-size:14px;
  color:#173b2e;
}
.finance-row small{
  display:block;
  margin-top:3px;
  font-size:11px;
  color:#7f827b;
}
.mini-add-btn{
  border:0;
  border-radius:999px;
  background:#184635;
  color:#fff;
  height:32px;
  padding:0 12px;
  font-size:12px;
  font-weight:900;
}
.cb-modal-card select,
.cb-modal-card input,
.cb-modal-card textarea{
  font-size:16px!important;
}


/* v49 global popup close fix */
.cb-modal{
  pointer-events:auto!important;
}
.cb-modal-backdrop,
.cb-modal-close,
[data-close-modal],
.cb-alert-close,
[data-alert-close]{
  cursor:pointer!important;
  touch-action:manipulation!important;
}
.cb-modal-backdrop{
  z-index:0!important;
}
.cb-modal-card{
  z-index:2!important;
}
.cb-modal-close{
  z-index:4!important;
}
.cb-alert-close{
  position:relative!important;
  z-index:3!important;
  pointer-events:auto!important;
}
.cb-alert{
  pointer-events:auto!important;
}


/* v51 orange access accent */
:root{
  --orange-accent:#f2a56c;
  --orange-soft:#fff1e8;
  --orange-line:#f3c7a6;
}
.home-badge,
.auth-logo,
.logo{
  background:linear-gradient(150deg,#f2a56c 0%,#d9783d 48%,#173f30 100%)!important;
}
.bell-btn,
.quick-icon,
.nav-item.active,
.app-nav .nav-item.active{
  box-shadow:0 0 0 2px rgba(242,165,108,.16)!important;
}
.card-head:before{
  content:'';
  display:inline-block;
  width:7px;
  height:7px;
  border-radius:999px;
  background:var(--orange-accent);
  margin-right:7px;
  vertical-align:1px;
}
.cb-access-note{
  margin:10px 16px;
  border:1px solid var(--orange-line);
  background:linear-gradient(180deg,#fff8f2 0%,#fff1e8 100%);
  border-radius:18px;
  padding:12px 13px;
  color:#5f3a22;
  font-size:12px;
  line-height:1.48;
}
.cb-access-note b{
  display:block;
  color:#173f30;
  font-size:13px;
  margin-bottom:3px;
}
.cb-orange-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  height:26px;
  border-radius:999px;
  background:#fff1e8;
  border:1px solid #f3c7a6;
  color:#8d4e25;
  padding:0 9px;
  font-size:10px;
  font-weight:900;
}
.btn-primary,
.auth-submit,
.btn.green,
.btn.primary{
  box-shadow:0 0 0 2px rgba(242,165,108,.10)!important;
}
.cb-modal-card:before{
  content:'';
  display:block;
  height:4px;
  margin:-16px -16px 12px;
  border-radius:18px 18px 0 0;
  background:linear-gradient(90deg,#f2a56c,#173f30);
}


/* v52 limit topup dana */
.cb-access-note.is-locked{
  border-color:#eaa16c!important;
  background:linear-gradient(180deg,#fff3e7 0%,#ffe7d1 100%)!important;
}
.cb-limit-warning{
  margin:0 0 12px;
  border:1px solid #f3c7a6;
  background:#fff1e8;
  border-radius:16px;
  padding:13px;
  color:#5f3a22;
  font-size:12px;
  line-height:1.5;
}
.cb-limit-warning b{
  display:block;
  color:#173f30;
  font-size:14px;
  margin-bottom:4px;
}
.cb-limit-warning p{
  margin:0 0 10px;
}
.cb-limit-warning a{
  height:38px;
  border-radius:12px;
  background:#173f30;
  color:#fff;
  display:grid;
  place-items:center;
  text-decoration:none;
  font-weight:800;
  font-size:12px;
}
.js-dashboard-form.is-disabled{
  opacity:.55;
}


/* v54 saving goal progress */
.finance-row.saving-goal-row{
  align-items:flex-start;
}
.finance-row .saving-progress{
  display:block;
  height:8px;
  border-radius:999px;
  background:#e8e1d6;
  margin-top:7px;
  overflow:hidden;
  border:1px solid rgba(216,210,199,.75);
}
.finance-row .saving-progress i{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#f2a56c 0%,#2a6b4a 100%);
}
.finance-row .saving-progress-label{
  display:block;
  margin-top:4px;
  font-style:normal;
  font-size:10px;
  line-height:1.2;
  color:#8d4e25;
  font-weight:900;
}


/* v55 saving debt inner tab fix */
.finance-inner-tabs [data-finance-tab]{
  cursor:pointer;
}
.finance-tab-panel,
.finance-action{
  display:none!important;
}
.finance-tab-panel.active,
.finance-action.active{
  display:block!important;
}
.finance-action{
  margin-top:10px;
}


/* v56 hero transfer button */
.hero-transfer-wrap{
  margin:-8px 8px 10px;
}
.hero-transfer-btn{
  width:100%;
  border:1px solid #cfe6d7;
  background:linear-gradient(180deg,#eef8ef 0%,#e7f4e9 100%);
  color:#173f30;
  min-height:42px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-size:12px;
  font-weight:900;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.hero-transfer-btn span{
  width:24px;
  height:24px;
  border-radius:999px;
  background:#fff;
  display:grid;
  place-items:center;
  color:#173f30;
  font-size:14px;
}
.hero-transfer-btn b{
  font-size:12px;
}


/* v57 transfer button inside balance card */
.hero-balance .hero-transfer-btn.in-balance{
  width:100%;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(14,48,35,.74);
  color:#fff;
  min-height:40px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin-top:10px;
  font-size:12px;
  font-weight:900;
  box-shadow:none;
}
.hero-balance .hero-transfer-btn.in-balance span{
  width:24px;
  height:24px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:14px;
}
.hero-balance .hero-transfer-btn.in-balance b{
  font-size:12px;
}


/* v58 sharing 5 users */
.member-limit-note{
  margin:8px 0 0;
  font-size:11px;
  color:#7b8178;
}


/* v60 detailed recap dashboard */
.recap-legend{
  display:flex;
  gap:12px;
  align-items:center;
  margin:4px 0 12px;
  font-size:11px;
  color:#647066;
  font-weight:800;
}
.recap-legend span{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.recap-legend i{
  width:9px;
  height:9px;
  border-radius:999px;
  display:inline-block;
}
.income-dot{background:#2a6b4a}
.expense-dot{background:#f2a56c}
.year-chart{
  height:142px;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:6px;
  align-items:end;
  padding:12px 6px 4px;
  background:#f7f3ea;
  border:1px solid #e5ded3;
  border-radius:18px;
}
.month-bar{
  height:100%;
  min-width:0;
  display:grid;
  grid-template-rows:1fr auto;
  gap:6px;
  align-items:end;
}
.bar-pair{
  height:100%;
  display:flex;
  align-items:end;
  justify-content:center;
  gap:2px;
}
.bar-pair i{
  width:7px;
  min-height:4px;
  border-radius:999px 999px 4px 4px;
  display:block;
}
.income-bar{background:#2a6b4a}
.expense-bar{background:#f2a56c}
.month-bar small{
  font-size:9px;
  color:#6f746c;
  text-align:center;
  white-space:nowrap;
}
.people-expense-list,
.top-expense-list{
  display:grid;
  gap:9px;
}
.person-expense-row,
.top-expense-row{
  display:flex;
  align-items:center;
  gap:10px;
  background:#fbfaf6;
  border:1px solid #e5ded3;
  border-radius:15px;
  padding:11px;
}
.person-expense-row div{
  flex:1;
  min-width:0;
}
.person-expense-row b,
.top-expense-row b{
  display:block;
  font-size:13px;
  color:#173f30;
}
.person-expense-row small,
.top-expense-row small{
  display:block;
  margin-top:2px;
  color:#7a8077;
  font-size:11px;
}
.person-expense-row span{
  color:#8d4e25;
  background:#fff1e8;
  border:1px solid #f3c7a6;
  border-radius:999px;
  padding:4px 8px;
  font-size:11px;
  font-weight:900;
}
.compare-box{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.compare-box div{
  background:#fbfaf6;
  border:1px solid #e5ded3;
  border-radius:16px;
  padding:12px;
}
.compare-box small{
  display:block;
  color:#7a8077;
  font-size:10px;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.06em;
}
.compare-box b{
  display:block;
  margin-top:5px;
  color:#173f30;
  font-size:15px;
}
.compare-box em{
  display:block;
  margin-top:4px;
  font-style:normal;
  color:#8d4e25;
  font-size:11px;
  font-weight:800;
}
.top-expense-row span{
  width:26px;
  height:26px;
  border-radius:10px;
  background:#173f30;
  color:#fff;
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:900;
  flex:0 0 26px;
}
.top-expense-row i{
  font-style:normal;
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  background:#fff1e8;
  border-radius:10px;
  flex:0 0 28px;
}
.top-expense-row div{
  flex:1;
  min-width:0;
}
.top-expense-row strong{
  font-size:12px;
  color:#173f30;
  white-space:nowrap;
}
@media(max-width:360px){
  .year-chart{gap:3px;padding-left:4px;padding-right:4px}
  .bar-pair i{width:5px}
  .compare-box{grid-template-columns:1fr}
}


/* v61 category donut sticky balance */
.top-green{
  position:sticky!important;
  top:0!important;
  z-index:50!important;
  box-shadow:0 8px 22px rgba(20,57,44,.12);
}
.dashboard-shell{
  overflow:visible!important;
}
.category-card-polished{
  border-radius:22px!important;
  padding:18px!important;
}
.category-card-polished .card-head{
  text-transform:uppercase;
  letter-spacing:.10em;
  font-size:12px!important;
  color:#85877f!important;
  font-weight:900!important;
  margin-bottom:16px!important;
}
.category-chart-v61{
  display:grid;
  grid-template-columns:165px 1fr;
  gap:20px;
  align-items:center;
}
.category-donut-v61{
  width:160px;
  height:160px;
  border-radius:999px;
  display:grid;
  place-items:center;
  position:relative;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.03);
}
.category-donut-inner-v61{
  width:86px;
  height:86px;
  border-radius:999px;
  background:#fffdfa;
  display:grid;
  place-items:center;
  align-content:center;
  text-align:center;
}
.category-donut-inner-v61 small{
  display:block;
  font-size:13px;
  color:#8a8a84;
  font-weight:800;
  line-height:1;
}
.category-donut-inner-v61 b{
  display:block;
  margin-top:8px;
  color:#173f30;
  font-size:17px;
  line-height:1.05;
  letter-spacing:-.04em;
}
.category-legend-v61{
  display:grid;
  gap:12px;
}
.category-legend-row-v61{
  display:grid;
  grid-template-columns:18px minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
}
.category-legend-row-v61 span{
  width:14px;
  height:14px;
  border-radius:5px;
  display:block;
}
.category-legend-row-v61 b{
  color:#173f30;
  font-size:15px;
  line-height:1.2;
  font-weight:700;
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.category-legend-row-v61 em{
  color:#173f30;
  font-size:14px;
  font-weight:900;
  font-style:normal;
  white-space:nowrap;
}
@media(max-width:430px){
  .category-chart-v61{
    grid-template-columns:120px 1fr;
    gap:14px;
  }
  .category-donut-v61{
    width:118px;
    height:118px;
  }
  .category-donut-inner-v61{
    width:64px;
    height:64px;
  }
  .category-donut-inner-v61 small{
    font-size:11px;
  }
  .category-donut-inner-v61 b{
    font-size:14px;
  }
  .category-legend-v61{
    gap:10px;
  }
  .category-legend-row-v61{
    grid-template-columns:15px minmax(0,1fr);
    gap:8px;
  }
  .category-legend-row-v61 em{
    grid-column:2;
    font-size:12px;
  }
  .category-legend-row-v61 b{
    font-size:13px;
  }
}


/* v62 clean activity notifications */
.activity-strip{
  margin-top:8px;
}
.activity-pill span{
  font-weight:900;
}


/* v63 grouped member activity */
.grouped-activity-pill{
  display:grid!important;
  grid-template-columns:auto 1fr;
  gap:2px 7px;
  align-items:center;
  text-align:left;
  line-height:1.25;
}
.grouped-activity-pill span{
  grid-row:1 / span 2;
  align-self:center;
  max-width:92px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.grouped-activity-pill b{
  font-size:11px;
  font-weight:850;
  color:#173f30;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.grouped-activity-pill small{
  display:block;
  font-size:10px;
  color:#7a8077;
  font-weight:800;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}


/* v64 category layout match first reference */
.category-card-v64{
  padding:18px 20px 20px!important;
}
.category-chart-v64{
  display:grid;
  grid-template-columns:152px minmax(0,1fr);
  gap:28px;
  align-items:center;
  min-width:0;
}
.category-donut-v64{
  width:148px;
  height:148px;
  border-radius:50%;
  background:conic-gradient(#d77647 0 96%, #89b774 96% 99%, #dfb34b 99% 100%);
  display:grid;
  place-items:center;
  position:relative;
  margin:0 auto;
}
.category-donut-v64::before{
  content:"";
  position:absolute;
  width:98px;
  height:98px;
  border-radius:50%;
  background:#fff;
  box-shadow:inset 0 0 0 1px #ece4d7;
}
.category-donut-inner-v64{
  position:relative;
  z-index:1;
  text-align:center;
  display:grid;
  gap:2px;
}
.category-donut-inner-v64 small{
  display:block;
  font-size:13px;
  line-height:1.15;
  color:#8e8c84;
  font-weight:600;
}
.category-donut-inner-v64 b{
  display:block;
  font-size:22px;
  line-height:1.05;
  letter-spacing:-0.03em;
  color:#173f30;
  font-weight:900;
}
.category-legend-v64{
  display:grid;
  gap:16px;
  min-width:0;
}
.category-legend-row-v64{
  display:grid;
  grid-template-columns:18px minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  min-width:0;
}
.category-swatch-v64{
  display:block;
  width:16px;
  height:16px;
  border-radius:4px;
}
.category-legend-row-v64 b{
  min-width:0;
  font-size:16px;
  line-height:1.2;
  color:#173f30;
  font-weight:500;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.category-legend-row-v64 em{
  font-style:normal;
  white-space:nowrap;
  font-size:16px;
  line-height:1.2;
  color:#173f30;
  font-weight:800;
}
@media (max-width:480px){
  .category-card-v64{padding:16px!important;}
  .category-chart-v64{grid-template-columns:122px minmax(0,1fr);gap:14px;}
  .category-donut-v64{width:116px;height:116px;}
  .category-donut-v64::before{width:74px;height:74px;}
  .category-donut-inner-v64 small{font-size:11px;}
  .category-donut-inner-v64 b{font-size:15px;}
  .category-legend-v64{gap:10px;}
  .category-legend-row-v64{grid-template-columns:14px minmax(0,1fr) auto;gap:8px;}
  .category-swatch-v64{width:12px;height:12px;border-radius:3px;}
  .category-legend-row-v64 b{font-size:12px;}
  .category-legend-row-v64 em{font-size:12px;}
}
@media (max-width:380px){
  .category-chart-v64{grid-template-columns:108px minmax(0,1fr);gap:10px;}
  .category-donut-v64{width:102px;height:102px;}
  .category-donut-v64::before{width:66px;height:66px;}
  .category-donut-inner-v64 small{font-size:10px;}
  .category-donut-inner-v64 b{font-size:14px;}
  .category-legend-row-v64{grid-template-columns:12px minmax(0,1fr) auto;gap:7px;}
  .category-swatch-v64{width:10px;height:10px;}
  .category-legend-row-v64 b{font-size:11px;}
  .category-legend-row-v64 em{font-size:11px;}
}


/* v65 wider mobile layout */
/* Membuat tampilan mobile terasa lebih lebar tanpa mengubah ke mode desktop. */
.app-body,
.single-dashboard{
  background:#f4f1ea!important;
}
.dashboard-shell,
.mobile-shell,
.app-shell{
  width:min(100%, 520px)!important;
  max-width:520px!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.dashboard-shell{
  padding-left:6px!important;
  padding-right:6px!important;
}
.card-block,
.wallet-overview,
.activity-strip,
.cb-access-note,
.month-switch,
.hero-transfer-wrap{
  margin-left:6px!important;
  margin-right:6px!important;
}
.top-green{
  margin-left:0!important;
  margin-right:0!important;
}
.category-card-v64{
  padding-left:20px!important;
  padding-right:20px!important;
}
@media (min-width:431px) and (max-width:640px){
  .dashboard-shell,
  .mobile-shell,
  .app-shell{
    max-width:560px!important;
  }
  .dashboard-shell{
    padding-left:8px!important;
    padding-right:8px!important;
  }
  .card-block,
  .wallet-overview,
  .activity-strip,
  .cb-access-note,
  .month-switch{
    margin-left:8px!important;
    margin-right:8px!important;
  }
  .category-chart-v64{
    grid-template-columns:142px minmax(0,1fr)!important;
    gap:20px!important;
  }
  .category-donut-v64{
    width:138px!important;
    height:138px!important;
  }
  .category-donut-v64::before{
    width:88px!important;
    height:88px!important;
  }
  .category-donut-inner-v64 b{
    font-size:18px!important;
  }
  .category-legend-row-v64 b,
  .category-legend-row-v64 em{
    font-size:14px!important;
  }
}
@media (max-width:430px){
  .dashboard-shell{
    padding-left:4px!important;
    padding-right:4px!important;
  }
  .card-block,
  .wallet-overview,
  .activity-strip,
  .cb-access-note,
  .month-switch{
    margin-left:4px!important;
    margin-right:4px!important;
  }
  .category-card-v64{
    padding-left:14px!important;
    padding-right:14px!important;
  }
  .category-chart-v64{
    grid-template-columns:116px minmax(0,1fr)!important;
    gap:12px!important;
  }
}
@media (max-width:380px){
  .category-chart-v64{
    grid-template-columns:104px minmax(0,1fr)!important;
    gap:8px!important;
  }
  .category-legend-row-v64 b,
  .category-legend-row-v64 em{
    font-size:10.5px!important;
  }
}


/* v66 mobile compact nav category fix */
/* Batalkan efek terlalu lebar dari v65 agar menu bawah tidak tertabrak scroll. */
.dashboard-shell,
.mobile-shell,
.app-shell{
  width:100%!important;
  max-width:430px!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.dashboard-shell{
  padding-left:0!important;
  padding-right:0!important;
  padding-bottom:92px!important;
}
.card-block,
.wallet-overview,
.activity-strip,
.cb-access-note,
.month-switch{
  margin-left:12px!important;
  margin-right:12px!important;
}
.top-green{
  margin-left:0!important;
  margin-right:0!important;
  border-radius:0 0 0 0!important;
}

/* Pastikan bottom nav selalu aman, tidak ketabrak konten scroll. */
.app-nav,
.bottom-nav{
  position:fixed!important;
  left:50%!important;
  right:auto!important;
  bottom:0!important;
  transform:translateX(-50%)!important;
  width:100%!important;
  max-width:430px!important;
  z-index:999!important;
  background:#fffdfa!important;
  border-top:1px solid #ded6ca!important;
  padding-bottom:calc(8px + env(safe-area-inset-bottom))!important;
}
.app-body{
  padding-bottom:92px!important;
}

/* Kategori: dibuat lebih compact seperti saran user */
.category-card-v64{
  padding:13px 14px 14px!important;
}
.category-card-v64 .card-head{
  font-size:10px!important;
  letter-spacing:.08em!important;
  margin-bottom:10px!important;
}
.category-chart-v64{
  grid-template-columns:104px minmax(0,1fr)!important;
  gap:10px!important;
  align-items:center!important;
}
.category-donut-v64{
  width:100px!important;
  height:100px!important;
}
.category-donut-v64::before{
  width:64px!important;
  height:64px!important;
}
.category-donut-inner-v64 small{
  font-size:10px!important;
  line-height:1!important;
}
.category-donut-inner-v64 b{
  font-size:15px!important;
  line-height:1.05!important;
}
.category-legend-v64{
  gap:8px!important;
}
.category-legend-row-v64{
  grid-template-columns:12px minmax(0,1fr) auto!important;
  gap:7px!important;
}
.category-swatch-v64{
  width:11px!important;
  height:11px!important;
  border-radius:3px!important;
}
.category-legend-row-v64 b{
  font-size:12px!important;
  line-height:1.15!important;
  max-width:96px!important;
}
.category-legend-row-v64 em{
  font-size:12px!important;
  line-height:1.15!important;
  font-weight:900!important;
}
@media(max-width:380px){
  .card-block,
  .wallet-overview,
  .activity-strip,
  .cb-access-note,
  .month-switch{
    margin-left:9px!important;
    margin-right:9px!important;
  }
  .category-card-v64{
    padding:12px!important;
  }
  .category-chart-v64{
    grid-template-columns:96px minmax(0,1fr)!important;
    gap:8px!important;
  }
  .category-donut-v64{
    width:92px!important;
    height:92px!important;
  }
  .category-donut-v64::before{
    width:58px!important;
    height:58px!important;
  }
  .category-donut-inner-v64 b{
    font-size:13px!important;
  }
  .category-legend-row-v64 b,
  .category-legend-row-v64 em{
    font-size:10.5px!important;
  }
  .category-legend-row-v64 b{
    max-width:76px!important;
  }
}


/* v67 category total smaller */
/* Perkecil tulisan Total + nominal di tengah donut sekitar 3x dari ukuran sebelumnya. */
.category-donut-inner-v64 small{
  font-size:7px!important;
  line-height:1!important;
  font-weight:700!important;
}
.category-donut-inner-v64 b{
  font-size:8px!important;
  line-height:1!important;
  letter-spacing:-.02em!important;
  font-weight:900!important;
  margin-top:1px!important;
}
@media(max-width:430px){
  .category-donut-inner-v64 small{
    font-size:6.5px!important;
  }
  .category-donut-inner-v64 b{
    font-size:7.5px!important;
  }
}
@media(max-width:380px){
  .category-donut-inner-v64 small{
    font-size:6px!important;
  }
  .category-donut-inner-v64 b{
    font-size:7px!important;
  }
}


/* v68 short rupiah category */
.category-donut-inner-v64 b{
  white-space:nowrap!important;
}
.category-legend-row-v64 em{
  white-space:nowrap!important;
}


/* v69 sticky balance only */
/* Yang sticky hanya kotak Saldo Global + Pemasukan + Pengeluaran. Cash/Rekening dan Pindah Saldo tidak ikut sticky. */
.top-green{
  position:relative!important;
  top:auto!important;
  z-index:10!important;
  box-shadow:none!important;
}
.balance-sticky-wrap{
  position:sticky!important;
  top:0!important;
  z-index:80!important;
  margin:0!important;
  padding:0 12px 8px!important;
  background:#f4f1ea!important;
}
.balance-sticky-wrap .hero-balance.sticky-balance-only{
  margin:0!important;
  border-radius:18px!important;
  box-shadow:0 8px 22px rgba(20,57,44,.14)!important;
}
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-row{
  margin-bottom:0!important;
}
.balance-sticky-wrap .hero-balance.sticky-balance-only + .hero-wallet-mini,
.balance-sticky-wrap .hero-transfer-btn{
  display:none!important;
}
.wallet-overview{
  position:relative!important;
  z-index:1!important;
}
@media(max-width:430px){
  .balance-sticky-wrap{
    padding-left:9px!important;
    padding-right:9px!important;
  }
}


/* v70 restore wallet non sticky */
/* Cash/Rekening dan tombol Pindah Saldo tetap tampil, tetapi tidak sticky saat scroll. */
.wallet-overview.wallet-overview-normal{
  display:grid!important;
  position:relative!important;
  top:auto!important;
  z-index:1!important;
  margin-top:8px!important;
  margin-bottom:10px!important;
}
.wallet-overview.wallet-overview-normal .wallet-transfer-shortcut{
  display:block!important;
  position:relative!important;
}
.balance-sticky-wrap .hero-wallet-mini,
.balance-sticky-wrap .hero-transfer-btn{
  display:none!important;
}


/* v71 restore wallet insert fix */
.wallet-overview.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:10px!important;
  position:relative!important;
  top:auto!important;
  z-index:1!important;
  margin:8px 12px 10px!important;
}
.wallet-overview.wallet-overview-normal .wallet-transfer-shortcut{
  display:block!important;
  grid-column:1 / -1!important;
  width:100%!important;
  position:relative!important;
  top:auto!important;
  z-index:1!important;
}
.wallet-overview.wallet-overview-normal .wallet-card{
  display:block!important;
}
@media(max-width:380px){
  .wallet-overview.wallet-overview-normal{
    margin-left:9px!important;
    margin-right:9px!important;
    gap:8px!important;
  }
}


/* v72 wallet clean orange */
/* Hilangkan kesan putih polos pada Cash/Rekening dan tombol Pindah Saldo. */
.wallet-overview.wallet-overview-normal{
  gap:9px!important;
}
.wallet-overview.wallet-overview-normal .wallet-card{
  position:relative!important;
  overflow:hidden!important;
  border:1px solid #f3c7a6!important;
  background:linear-gradient(180deg,#fff7ef 0%,#fff1e8 100%)!important;
  box-shadow:0 1px 0 rgba(0,0,0,.03)!important;
}
.wallet-overview.wallet-overview-normal .wallet-card::before{
  content:"";
  position:absolute;
  width:58px;
  height:58px;
  border-radius:999px;
  background:rgba(242,165,108,.22);
  right:-20px;
  top:-24px;
}
.wallet-overview.wallet-overview-normal .wallet-card::after{
  content:"";
  position:absolute;
  width:8px;
  height:34px;
  border-radius:999px;
  background:#f2a56c;
  left:0;
  top:14px;
}
.wallet-overview.wallet-overview-normal .wallet-card span{
  position:relative;
  z-index:1;
  color:#8d4e25!important;
  font-weight:900!important;
}
.wallet-overview.wallet-overview-normal .wallet-card b{
  position:relative;
  z-index:1;
  color:#173f30!important;
}
.wallet-overview.wallet-overview-normal .wallet-transfer-shortcut{
  border:1px solid #f3c7a6!important;
  background:linear-gradient(180deg,#f2a56c 0%,#dd8144 100%)!important;
  color:#fff!important;
  border-radius:14px!important;
  min-height:42px!important;
  font-weight:900!important;
  box-shadow:0 1px 0 rgba(0,0,0,.04)!important;
}
.wallet-overview.wallet-overview-normal small{
  display:none!important;
}


/* v73 unified header balance */
/* Header Keuangan Keluarga dan Saldo Global dibuat menyatu dalam satu kotak warna. */
.header-balance-unified{
  position:sticky!important;
  top:0!important;
  z-index:90!important;
  margin:0 0 8px!important;
  padding:0 10px 10px!important;
  background:linear-gradient(180deg,#1f6b4a 0%,#287a55 58%,#f4f1ea 58%,#f4f1ea 100%)!important;
  border-radius:0 0 26px 26px!important;
  box-shadow:0 10px 22px rgba(20,57,44,.14)!important;
}
.header-balance-unified .top-green{
  position:relative!important;
  top:auto!important;
  z-index:1!important;
  margin:0!important;
  padding:12px 4px 8px!important;
  background:transparent!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.header-balance-unified .app-topbar{
  padding-left:2px!important;
  padding-right:2px!important;
}
.header-balance-unified .balance-sticky-wrap{
  position:relative!important;
  top:auto!important;
  z-index:2!important;
  margin:0!important;
  padding:0!important;
  background:transparent!important;
}
.header-balance-unified .hero-balance.sticky-balance-only{
  margin:0!important;
  border-radius:20px!important;
  background:linear-gradient(180deg,#ffffff 0%,#fff8f0 100%)!important;
  border:1px solid rgba(242,165,108,.42)!important;
  box-shadow:0 8px 20px rgba(18,55,42,.12)!important;
}
.header-balance-unified .identity-card{
  background:rgba(255,255,255,.14)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  box-shadow:none!important;
}
.header-balance-unified .identity-title,
.header-balance-unified .identity-sub{
  color:#fff!important;
}
.header-balance-unified .bell-btn{
  background:rgba(255,255,255,.16)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.2)!important;
}
.wallet-overview.wallet-overview-normal{
  margin-top:8px!important;
}
@media(max-width:430px){
  .header-balance-unified{
    padding-left:9px!important;
    padding-right:9px!important;
    border-radius:0 0 22px 22px!important;
  }
  .header-balance-unified .top-green{
    padding-top:10px!important;
    padding-bottom:7px!important;
  }
  .header-balance-unified .hero-balance.sticky-balance-only{
    border-radius:18px!important;
  }
}


/* v74 profile reset delete member */
.profile-shell-v74{
  padding-bottom:96px!important;
}
.member-row-v74{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
  padding:14px!important;
  border:1px solid #eadfd0!important;
  border-radius:18px!important;
  background:linear-gradient(180deg,#fffdfa 0%,#fff7ef 100%)!important;
}
.member-main-v74{
  display:grid;
  gap:3px;
  min-width:0;
}
.member-main-v74 b{
  color:#173f30!important;
  font-size:14px!important;
}
.member-main-v74 span{
  width:max-content;
  color:#8d4e25!important;
  background:#fff0e4!important;
  border:1px solid #f3c7a6!important;
  border-radius:999px!important;
  padding:3px 8px!important;
  font-size:10px!important;
  font-weight:900!important;
}
.member-main-v74 small{
  color:#6f746c!important;
  font-size:11px!important;
}
.member-main-v74 em{
  color:#8d4e25!important;
  font-size:11px!important;
  font-style:normal!important;
  font-weight:800!important;
}
.member-actions-v74{
  display:grid!important;
  grid-template-columns:1fr;
  gap:8px!important;
}
.member-actions-v74 form{
  margin:0!important;
}
.btn-reset-v74,
.btn-delete-v74{
  width:100%!important;
  border:0!important;
  border-radius:14px!important;
  min-height:40px!important;
  font-weight:900!important;
  font-size:12px!important;
}
.btn-reset-v74{
  color:#fff!important;
  background:linear-gradient(180deg,#f2a56c 0%,#dd8144 100%)!important;
}
.btn-delete-v74{
  color:#9c2d20!important;
  background:#fff0ed!important;
  border:1px solid #f1b5ad!important;
}
@media(min-width:420px){
  .member-row-v74{
    grid-template-columns:minmax(0,1fr) 150px!important;
    align-items:center!important;
  }
}


/* v75 green unified balance */
/* Kotak Keuangan Keluarga + Saldo Global tetap menyatu, tapi warna saldo dikembalikan hijau seperti awal. */
.header-balance-unified{
  background:linear-gradient(180deg,#1b6f4b 0%,#1b6f4b 100%)!important;
  border-radius:0 0 26px 26px!important;
  padding-bottom:12px!important;
}
.header-balance-unified .hero-balance.sticky-balance-only{
  background:linear-gradient(180deg,#246f4c 0%,#215f43 100%)!important;
  border:1px solid rgba(255,255,255,.08)!important;
  box-shadow:0 8px 20px rgba(8,42,28,.22)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only small{
  color:rgba(255,255,255,.72)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only h1{
  color:#fff!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .stat-box{
  background:#173f30!important;
  border:1px solid rgba(255,255,255,.05)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .stat-box .label{
  color:rgba(255,255,255,.68)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .stat-box .value{
  color:#fff!important;
}
.header-balance-unified .identity-card{
  background:transparent!important;
  border:0!important;
}
.header-balance-unified .bell-btn{
  background:rgba(255,255,255,.12)!important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)!important;
}
@media(max-width:430px){
  .header-balance-unified{
    border-radius:0 0 24px 24px!important;
  }
}


/* v76 fix invite member layout */
.invite-page-v76{
  min-height:100dvh!important;
  background:#f4f1ea!important;
  overflow-x:hidden!important;
}
.invite-page-v76 .app-persistent-header,
.invite-page-v76 > .top-green{
  display:none!important;
}
.invite-shell-v76{
  width:min(430px,100%)!important;
  max-width:430px!important;
  min-height:calc(100dvh - 86px)!important;
  margin:0 auto!important;
  padding:16px 12px 104px!important;
  display:block!important;
  background:#f4f1ea!important;
}
.invite-shell-v76 .page-header{
  display:grid!important;
  grid-template-columns:42px 1fr 42px!important;
  align-items:center!important;
  gap:8px!important;
  margin:0 0 14px!important;
  padding:0!important;
  width:100%!important;
}
.invite-shell-v76 .page-header a{
  width:38px!important;
  height:38px!important;
  border-radius:14px!important;
  background:#fffdfa!important;
  border:1px solid #e2d8c9!important;
  display:grid!important;
  place-items:center!important;
  color:#173f30!important;
  box-shadow:0 1px 0 rgba(0,0,0,.03)!important;
}
.invite-shell-v76 .page-header h1{
  margin:0!important;
  text-align:center!important;
  font-size:20px!important;
  line-height:1.15!important;
  color:#173f30!important;
  letter-spacing:-.03em!important;
}
.invite-shell-v76 .form-card{
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  padding:16px!important;
  border-radius:22px!important;
  background:#fffdfa!important;
  border:1px solid #e2d8c9!important;
  box-shadow:0 14px 36px rgba(67,20,7,.08)!important;
}
.invite-shell-v76 .form-note{
  font-size:12px!important;
  line-height:1.55!important;
  margin:0 0 8px!important;
  color:#6f746c!important;
}
.invite-shell-v76 .form-stack{
  gap:9px!important;
}
.invite-shell-v76 label{
  font-size:12px!important;
  font-weight:900!important;
  color:#173f30!important;
  margin-top:3px!important;
}
.invite-shell-v76 input,
.invite-shell-v76 select{
  width:100%!important;
  min-height:44px!important;
  border-radius:15px!important;
  border:1px solid #e2d8c9!important;
  background:#fff!important;
  color:#173f30!important;
  padding:0 13px!important;
  box-shadow:none!important;
}
.invite-shell-v76 .btn-primary.full{
  min-height:46px!important;
  border-radius:15px!important;
  margin-top:6px!important;
  background:#174b34!important;
  color:#fff!important;
}
.invite-page-v76 .bottom-nav{
  position:fixed!important;
  left:50%!important;
  right:auto!important;
  bottom:0!important;
  transform:translateX(-50%)!important;
  width:100%!important;
  max-width:430px!important;
  z-index:999!important;
}
@media(min-width:431px){
  .invite-shell-v76{
    padding-top:22px!important;
  }
}


/* v77 light unified balance wallet */
/* Saldo Global, Pemasukan, Pengeluaran dibuat light/oranye agar menyatu dengan Cash/Rekening. */
.header-balance-unified{
  background:linear-gradient(180deg,#1d6f4c 0%,#257a55 48%,#f4f1ea 48%,#f4f1ea 100%)!important;
  box-shadow:0 8px 20px rgba(20,57,44,.10)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only{
  position:relative!important;
  overflow:hidden!important;
  background:linear-gradient(180deg,#fff8ef 0%,#fff0e4 100%)!important;
  border:1px solid #f3c7a6!important;
  color:#173f30!important;
  box-shadow:0 8px 18px rgba(67,20,7,.10)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only::before{
  content:"";
  position:absolute;
  width:92px;
  height:92px;
  border-radius:999px;
  right:-34px;
  top:-42px;
  background:rgba(242,165,108,.22);
}
.header-balance-unified .hero-balance.sticky-balance-only::after{
  content:"";
  position:absolute;
  width:9px;
  height:56px;
  border-radius:999px;
  left:0;
  top:22px;
  background:#f2a56c;
}
.header-balance-unified .hero-balance.sticky-balance-only small,
.header-balance-unified .hero-balance.sticky-balance-only h1,
.header-balance-unified .hero-balance.sticky-balance-only .stat-row{
  position:relative!important;
  z-index:1!important;
}
.header-balance-unified .hero-balance.sticky-balance-only small{
  color:#8d4e25!important;
  font-weight:800!important;
}
.header-balance-unified .hero-balance.sticky-balance-only h1{
  color:#173f30!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .stat-box{
  background:linear-gradient(180deg,#fffdfa 0%,#fff7ef 100%)!important;
  border:1px solid #f3c7a6!important;
  box-shadow:0 1px 0 rgba(0,0,0,.03)!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .stat-box .label{
  color:#8d4e25!important;
  font-weight:800!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .stat-box .value{
  color:#173f30!important;
  font-weight:900!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .dot.income{
  background:#51d89f!important;
}
.header-balance-unified .hero-balance.sticky-balance-only .dot.expense{
  background:#f2a56c!important;
}

/* Cash/Rekening dibuat satu bahasa visual dengan kartu saldo. */
.wallet-overview.wallet-overview-normal .wallet-card{
  background:linear-gradient(180deg,#fff8ef 0%,#fff0e4 100%)!important;
  border:1px solid #f3c7a6!important;
}
.wallet-overview.wallet-overview-normal .wallet-card span{
  color:#8d4e25!important;
}
.wallet-overview.wallet-overview-normal .wallet-card b{
  color:#173f30!important;
}
.wallet-overview.wallet-overview-normal .wallet-transfer-shortcut{
  background:linear-gradient(180deg,#fff8ef 0%,#fff0e4 100%)!important;
  color:#173f30!important;
  border:1px solid #f3c7a6!important;
}


/* v78 dashboard profile member actions */
.member-profile-row-v78{
  align-items:flex-start!important;
  gap:10px!important;
  padding:12px!important;
  border:1px solid #eadfd0!important;
  border-radius:16px!important;
  background:linear-gradient(180deg,#fffdfa 0%,#fff7ef 100%)!important;
}
.member-profile-info-v78{
  display:grid!important;
  gap:4px!important;
  min-width:0!important;
}
.member-profile-info-v78 em{
  color:#8d4e25!important;
  font-size:11px!important;
  font-style:normal!important;
  font-weight:800!important;
}
.member-profile-actions-v78{
  display:grid!important;
  grid-template-columns:1fr;
  gap:7px!important;
  margin-top:7px!important;
}
.member-profile-actions-v78 form{
  margin:0!important;
}
.btn-reset-v78,
.btn-delete-v78{
  width:100%!important;
  min-height:36px!important;
  border-radius:13px!important;
  font-size:11px!important;
  font-weight:900!important;
  border:0!important;
}
.btn-reset-v78{
  background:linear-gradient(180deg,#f2a56c 0%,#dd8144 100%)!important;
  color:#fff!important;
}
.btn-delete-v78{
  background:#fff0ed!important;
  color:#9c2d20!important;
  border:1px solid #f1b5ad!important;
}


/* v79 fix profile after reset delete */
/* Halaman /app/profile tidak lagi membawa header dashboard besar di kiri atas setelah reset/hapus anggota. */
.profile-page-v79{
  min-height:100dvh!important;
  background:#f4f1ea!important;
  overflow-x:hidden!important;
  padding-bottom:96px!important;
}
.profile-page-v79 .app-persistent-header,
.profile-page-v79 > .top-green{
  display:none!important;
}
.profile-shell-v79{
  width:min(430px,100%)!important;
  max-width:430px!important;
  margin:0 auto!important;
  padding:16px 12px 104px!important;
  display:block!important;
  min-height:calc(100dvh - 86px)!important;
  background:#f4f1ea!important;
}
.profile-shell-v79 .page-header{
  display:grid!important;
  grid-template-columns:42px 1fr 42px!important;
  align-items:center!important;
  gap:8px!important;
  margin:0 0 14px!important;
  padding:0!important;
}
.profile-shell-v79 .page-header a{
  width:38px!important;
  height:38px!important;
  border-radius:14px!important;
  background:#fffdfa!important;
  border:1px solid #e2d8c9!important;
  display:grid!important;
  place-items:center!important;
  color:#173f30!important;
}
.profile-shell-v79 .page-header h1{
  margin:0!important;
  text-align:center!important;
  font-size:20px!important;
  line-height:1.15!important;
  color:#173f30!important;
  letter-spacing:-.03em!important;
}
.profile-shell-v79 .profile-card,
.profile-shell-v79 .members-card{
  width:100%!important;
  max-width:none!important;
  margin:0 0 12px!important;
  padding:16px!important;
  border-radius:22px!important;
  background:#fffdfa!important;
  border:1px solid #e2d8c9!important;
  box-shadow:0 14px 36px rgba(67,20,7,.08)!important;
}
.profile-shell-v79 .logout-btn{
  width:100%!important;
  max-width:none!important;
  margin:12px 0 0!important;
  border-radius:16px!important;
}
.profile-shell-v79 .cb-alert-stack{
  position:relative!important;
  inset:auto!important;
  width:100%!important;
  max-width:none!important;
  margin:0 0 12px!important;
  transform:none!important;
  z-index:10!important;
}
.profile-page-v79 .bottom-nav{
  position:fixed!important;
  left:50%!important;
  right:auto!important;
  bottom:0!important;
  transform:translateX(-50%)!important;
  width:100%!important;
  max-width:430px!important;
  z-index:999!important;
}
.profile-shell-v79 .member-row-v74{
  grid-template-columns:1fr!important;
}
@media(min-width:420px){
  .profile-shell-v79 .member-row-v74{
    grid-template-columns:minmax(0,1fr) 150px!important;
    align-items:center!important;
  }
}


/* v80 profile route to dashboard */
/* /app/profile tidak dipakai sebagai halaman mandiri. Semua profil kembali ke dashboard#profil. */


/* v81 fix saving goal progress */
/* Progress goal tabungan memakai target rupiah yang sudah dinormalisasi, bukan angka target yang terpotong. */
.saving-progress-label{
  font-weight:900!important;
}


/* v82 use category icons */
.tx-pin,
.top-expense-row i{
  font-family:Apple Color Emoji, Segoe UI Emoji, Noto Color Emoji, sans-serif!important;
}


/* v83 profile change password */
.profile-password-btn-v83{
  width:100%!important;
  min-height:42px!important;
  border:0!important;
  border-radius:15px!important;
  background:linear-gradient(180deg,#fff8ef 0%,#fff0e4 100%)!important;
  color:#173f30!important;
  border:1px solid #f3c7a6!important;
  font-weight:900!important;
  font-size:12px!important;
  cursor:pointer!important;
}
.profile-actions .profile-password-btn-v83{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-decoration:none!important;
}
#passwordModal .cb-modal-card{
  max-width:390px!important;
}
#passwordModal input[type="password"]{
  letter-spacing:.08em;
}


/* v84 strict pwa install popup */
.pwa-install-open-v84 body{
  overflow:hidden!important;
}
.pwa-install-overlay-v84{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
  align-items:flex-end;
  justify-content:center;
  background:rgba(16,36,27,.52);
  padding:18px 12px calc(18px + env(safe-area-inset-bottom));
}
.pwa-install-overlay-v84.show{
  display:flex;
}
.pwa-install-card-v84{
  width:min(430px,100%);
  background:linear-gradient(180deg,#fffdfa 0%,#fff3e8 100%);
  border:1px solid #f3c7a6;
  border-radius:26px;
  padding:22px 18px 18px;
  box-shadow:0 26px 70px rgba(16,36,27,.28);
  color:#173f30;
  position:relative;
  text-align:center;
}
.pwa-install-close-v84{
  position:absolute;
  top:12px;
  right:12px;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid #f3c7a6;
  background:#fff;
  color:#8d4e25;
  font-size:22px;
  line-height:1;
  font-weight:900;
}
.pwa-install-icon-v84{
  width:58px;
  height:58px;
  border-radius:20px;
  display:grid;
  place-items:center;
  margin:0 auto 12px;
  background:#fff0e4;
  border:1px solid #f3c7a6;
  font-size:30px;
}
.pwa-install-card-v84 h2{
  margin:0 0 8px;
  font-size:22px;
  letter-spacing:-.04em;
}
.pwa-install-card-v84 p{
  margin:0 auto 12px;
  color:#657363;
  font-size:14px;
  line-height:1.55;
  max-width:330px;
}
.pwa-install-note-v84{
  background:#fff;
  border:1px dashed #f3c7a6;
  border-radius:16px;
  padding:11px 12px;
  color:#8d4e25;
  font-size:12px;
  line-height:1.45;
  margin-bottom:12px;
}
.pwa-install-main-v84,
.pwa-install-later-v84{
  width:100%;
  min-height:46px;
  border:0;
  border-radius:16px;
  font-weight:900;
}
.pwa-install-main-v84{
  background:#173f30;
  color:#fff;
}
.pwa-install-main-v84:disabled{
  opacity:.72;
}
.pwa-install-later-v84{
  margin-top:9px;
  background:transparent;
  color:#8d4e25;
}
.pwa-force-install-v84{
  position:fixed;
  right:14px;
  bottom:calc(88px + env(safe-area-inset-bottom));
  z-index:500;
  width:46px;
  height:46px;
  border:0;
  border-radius:18px;
  background:#173f30;
  color:#fff;
  box-shadow:0 10px 28px rgba(16,36,27,.22);
  font-size:21px;
}
@media(display-mode:standalone){
  .pwa-force-install-v84{display:none!important;}
}


/* v85 pwa installed browser guard */
.pwa-installed-guard-open-v85 body{
  overflow:hidden!important;
}
.pwa-open-installed-guard-v85{
  position:fixed;
  inset:0;
  z-index:100000;
  background:rgba(16,36,27,.64);
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:18px 12px calc(18px + env(safe-area-inset-bottom));
}
.pwa-open-installed-card-v85{
  width:min(430px,100%);
  background:linear-gradient(180deg,#fffdfa 0%,#fff3e8 100%);
  border:1px solid #f3c7a6;
  border-radius:26px;
  padding:22px 18px 18px;
  box-shadow:0 26px 70px rgba(16,36,27,.30);
  color:#173f30;
  text-align:center;
}
.pwa-open-installed-icon-v85{
  width:58px;
  height:58px;
  border-radius:20px;
  display:grid;
  place-items:center;
  margin:0 auto 12px;
  background:#fff0e4;
  border:1px solid #f3c7a6;
  font-size:30px;
}
.pwa-open-installed-card-v85 h2{
  margin:0 0 8px;
  font-size:22px;
  letter-spacing:-.04em;
}
.pwa-open-installed-card-v85 p{
  margin:0 auto 14px;
  color:#657363;
  font-size:14px;
  line-height:1.55;
  max-width:330px;
}
.pwa-open-installed-card-v85 button{
  width:100%;
  min-height:46px;
  border:0;
  border-radius:16px;
  font-weight:900;
  margin-top:9px;
}
.pwa-open-installed-card-v85 [data-pwa-show-install-v85]{
  background:#173f30;
  color:#fff;
}
.pwa-open-installed-card-v85 [data-pwa-continue-browser-v85]{
  background:transparent;
  color:#8d4e25;
}


/* v86 profile compact buttons password modal fix */
.member-profile-row-v78{
  display:grid!important;
  grid-template-columns:34px minmax(0,1fr)!important;
  gap:9px!important;
  padding:10px 11px!important;
}
.member-profile-row-v78 > span{
  width:34px!important;
  height:34px!important;
  min-width:34px!important;
  border-radius:12px!important;
  font-size:13px!important;
}
.member-profile-info-v78{
  gap:2px!important;
}
.member-profile-info-v78 b{
  font-size:13px!important;
  line-height:1.2!important;
}
.member-profile-info-v78 small,
.member-profile-info-v78 em{
  font-size:10px!important;
  line-height:1.25!important;
}
.member-profile-actions-v78{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:6px!important;
  margin-top:6px!important;
}
.member-profile-actions-v78 form{
  width:auto!important;
  flex:0 0 auto!important;
}
.btn-reset-v78,
.btn-delete-v78{
  width:auto!important;
  min-width:0!important;
  min-height:27px!important;
  height:27px!important;
  padding:0 9px!important;
  border-radius:999px!important;
  font-size:9.5px!important;
  line-height:1!important;
  white-space:nowrap!important;
}
.profile-password-btn-v86,
.profile-password-btn-v83{
  min-height:34px!important;
  height:34px!important;
  border-radius:13px!important;
  font-size:11px!important;
  padding:0 12px!important;
}
#passwordModal.open{
  display:flex!important;
  z-index:100001!important;
}
#passwordModal .cb-modal-card{
  width:min(390px,calc(100% - 22px))!important;
}


/* v87 android webapk intent open */
/* Intent target package: org.chromium.webapk.acb677a0b40a0cd5c_V2 */
.pwa-open-installed-card-v85 [data-open-webapk-v87] {
  background:#173f30!important;
  color:#fff!important;
}


/* v88 login session redirect fix */


/* v89 mobile only pwa guard */
@media (hover:hover) and (pointer:fine) {
  .pwa-install-overlay-v84,
  .pwa-open-installed-guard-v85,
  .pwa-force-install-v84{
    display:none!important;
  }
  html.pwa-install-open-v84 body,
  html.pwa-installed-guard-open-v85 body{
    overflow:auto!important;
  }
}


/* v90 remove free 50 text */


/* v91 transaction detail history */
.tx-actions{
  gap:8px!important;
}
.tx-detail-btn-v91{
  border:0;
  background:transparent;
  color:#8d4e25;
  font-size:11px;
  font-weight:900;
  padding:0;
}
.transaction-detail-card-v91{
  padding-bottom:18px!important;
}
.tx-detail-head-v91{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  border-radius:18px;
  background:linear-gradient(180deg,#fff8ef 0%,#fff0e4 100%);
  border:1px solid #f3c7a6;
  margin-bottom:12px;
}
.tx-detail-head-v91 > span{
  width:44px;
  height:44px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#fffdfa;
  border:1px solid #f3c7a6;
  font-size:24px;
}
.tx-detail-head-v91 h3{
  margin:0 0 4px;
  font-size:17px;
  line-height:1.2;
  color:#173f30;
}
.tx-detail-head-v91 b{
  font-size:14px;
  color:#173f30;
}
.tx-detail-head-v91 b.expense{color:#b64227}
.tx-detail-head-v91 b.income{color:#14804f}
.tx-detail-grid-v91{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
}
.tx-detail-grid-v91 div,
.tx-detail-note-v91{
  background:#fffdfa;
  border:1px solid #eadfd0;
  border-radius:15px;
  padding:10px 11px;
}
.tx-detail-grid-v91 small,
.tx-detail-note-v91 small{
  display:block;
  color:#8d4e25;
  font-size:10px;
  font-weight:900;
  margin-bottom:4px;
}
.tx-detail-grid-v91 b{
  display:block;
  color:#173f30;
  font-size:12px;
  line-height:1.35;
}
.tx-detail-note-v91{
  margin-top:9px;
}
.tx-detail-note-v91 p{
  margin:0;
  color:#4d5a50;
  font-size:12px;
  line-height:1.45;
}
.tx-detail-actions-v91{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
  margin-top:12px;
}
.tx-detail-actions-v91 button{
  min-height:42px;
  border:0;
  border-radius:15px;
  font-size:12px;
  font-weight:900;
}
.tx-detail-edit-v91{
  background:#173f30;
  color:#fff;
}
.tx-detail-close-v91{
  background:#fff0e4;
  color:#8d4e25;
  border:1px solid #f3c7a6!important;
}


/* v92 remove all pricing quota landing */


/* v93 organization workspace 10 users */
.account-choice{
  grid-template-columns:1fr!important;
}
@media(min-width:390px){
  .account-choice{
    grid-template-columns:1fr!important;
  }
}


/* v94 referral system */
.referral-card-v94 .card-head{margin-bottom:10px}
.referral-hero-v94{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:13px;border-radius:18px;background:linear-gradient(180deg,#fff8ef 0%,#fff0e4 100%);
  border:1px solid #f3c7a6;margin-bottom:12px;
}
.referral-hero-v94 small{display:block;color:#8d4e25;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}
.referral-hero-v94 b{display:block;color:#e86f0b;font-size:28px;font-weight:900;letter-spacing:-.04em;margin-top:2px}
.referral-hero-v94 p{margin:4px 0 0;color:#657363;font-size:12px;line-height:1.45}
.referral-hero-v94 > span{width:48px;height:48px;border-radius:18px;display:grid;place-items:center;background:#fffdfa;border:1px solid #f3c7a6;font-size:25px;flex:0 0 48px}
.referral-label-v94{display:block;font-size:11px;font-weight:900;color:#173f30;margin:0 0 6px}
.referral-link-v94{display:flex;gap:7px}
.referral-link-v94 input{min-width:0;flex:1;height:38px;border:1px solid #eadfd0;border-radius:13px;background:#fffdfa;color:#173f30;font-size:11px;padding:0 10px}
.referral-link-v94 button,.referral-share-btn-v94,.referral-withdraw-v94{border:0;border-radius:13px;font-weight:900;font-size:11px}
.referral-link-v94 button{width:58px;background:#173f30;color:#fff}
.referral-share-btn-v94{width:100%;height:38px;margin-top:8px;background:#fff0e4;color:#8d4e25;border:1px solid #f3c7a6}
.referral-stats-v94{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px;margin-top:10px}
.referral-stats-v94 div{background:#fffdfa;border:1px solid #eadfd0;border-radius:14px;padding:9px}
.referral-stats-v94 small{display:block;color:#8d4e25;font-size:9px;font-weight:900}
.referral-stats-v94 b{display:block;color:#173f30;font-size:12px;margin-top:3px}
.referral-withdraw-v94{display:grid;place-items:center;height:40px;margin-top:10px;background:#173f30;color:#fff;text-decoration:none}
.referral-empty-v94{margin-top:10px;border-radius:14px;background:#f6f1e9;color:#657363;font-size:11px;font-weight:800;padding:10px;text-align:center}
.referral-list-v94{display:grid;gap:6px;margin-top:10px}
.referral-list-v94 div{display:flex;align-items:center;justify-content:space-between;gap:8px;background:#fffdfa;border:1px solid #eadfd0;border-radius:13px;padding:8px}
.referral-list-v94 span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;color:#173f30}
.referral-list-v94 b{font-size:10px;color:#8d4e25;white-space:nowrap}
.referral-register-note-v94{margin-bottom:12px!important}


/* v95 referral copy share fix */
.referral-link-v94 button,
.referral-share-btn-v94{
  cursor:pointer!important;
  touch-action:manipulation!important;
  position:relative!important;
  z-index:2!important;
}
.referral-link-v94 input{
  pointer-events:auto!important;
}


/* v96 green premium ui refresh */
:root{
  --cb-green-deep:#006b43;
  --cb-green:#008f5a;
  --cb-green-soft:#eaf7f1;
  --cb-mint:#f4fbf8;
  --cb-card:#ffffff;
  --cb-ink:#061426;
  --cb-muted:#6c7784;
  --cb-line:#e7eee9;
  --cb-orange:#ff6b1a;
  --cb-red:#ff342e;
  --cb-purple:#7a35e8;
}
body.app-body,
.single-dashboard{
  background:linear-gradient(180deg,#eef8f3 0%,#f7fbf8 42%,#ffffff 100%)!important;
  color:var(--cb-ink)!important;
}
.app-body .top-green,
.single-dashboard .top-green,
.header-unified-green,
.app-persistent-header{
  background:
    radial-gradient(circle at 64% -10%,rgba(255,255,255,.16),transparent 34%),
    radial-gradient(circle at 105% 70%,rgba(0,176,106,.35),transparent 42%),
    linear-gradient(155deg,#005f3c 0%,#007a4d 48%,#009b62 100%)!important;
  border-radius:0 0 32px 32px!important;
  color:#fff!important;
  box-shadow:0 14px 36px rgba(0,107,67,.18)!important;
}
.app-topbar .bell-btn,
.app-topbar .search-btn,
.bell-btn{
  background:#fff!important;
  color:#006b43!important;
  border:1px solid rgba(255,255,255,.75)!important;
  box-shadow:0 8px 18px rgba(0,74,43,.14)!important;
}
.hero-balance,
.header-balance-unified .hero-balance,
.hero-balance.sticky-balance-only{
  background:#fff!important;
  color:var(--cb-ink)!important;
  border:1px solid rgba(0,107,67,.08)!important;
  border-radius:24px!important;
  box-shadow:0 14px 36px rgba(0,55,34,.10)!important;
}
.hero-balance small,
.hero-balance .label,
.hero-balance .stat-box .label{
  color:var(--cb-muted)!important;
}
.hero-balance h1,
.hero-balance .value{
  color:var(--cb-ink)!important;
}
.hero-balance .status-pill,
.status-pill,
.hero-balance .health-pill{
  background:#dff5e9!important;
  color:#007a4d!important;
  border-radius:999px!important;
  font-weight:900!important;
}
.stat-row,
.wallet-overview{
  gap:10px!important;
}
.stat-box,
.wallet-card,
.summary-card,
.card-block,
.quick-card,
.recap-card,
.budget-card,
.target-card,
.category-card,
.insight-card,
.cashflow-card{
  background:#fff!important;
  border:1px solid var(--cb-line)!important;
  border-radius:20px!important;
  box-shadow:0 10px 28px rgba(0,55,34,.07)!important;
}
.stat-box{
  background:linear-gradient(180deg,#fff 0%,#fbfefd 100%)!important;
}
.wallet-card{
  background:#fff!important;
}
.wallet-transfer-shortcut,
.wallet-transfer-btn,
button[data-wallet-transfer],
.transfer-button,
.profile-actions a,
.profile-actions button,
.referral-share-btn-v94{
  background:linear-gradient(180deg,#ecf8f2 0%,#e2f3eb 100%)!important;
  color:#007a4d!important;
  border:1px solid #d8eee4!important;
  border-radius:15px!important;
  font-weight:900!important;
}
.pretty-submit,
.btn-primary,
.auth-submit,
.referral-withdraw-v94{
  background:linear-gradient(135deg,#007a4d 0%,#009b62 100%)!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 10px 24px rgba(0,122,77,.22)!important;
}
.bottom-nav{
  background:rgba(255,255,255,.94)!important;
  border:1px solid rgba(0,107,67,.08)!important;
  box-shadow:0 -10px 30px rgba(0,55,34,.10)!important;
  backdrop-filter:blur(18px)!important;
}
.bottom-nav .nav-item.active,
.bottom-nav .active,
.bottom-nav .active-trigger{
  color:#007a4d!important;
}
.bottom-nav .plus-btn,
.nav-plus,
.bottom-nav [data-tab-target="catat"]{
  background:linear-gradient(135deg,#007a4d 0%,#009b62 100%)!important;
  color:#fff!important;
  box-shadow:0 12px 26px rgba(0,122,77,.25)!important;
}
.tx-item,
.member-profile-row-v78,
.referral-list-v94 div{
  background:#fff!important;
  border:1px solid var(--cb-line)!important;
  border-radius:18px!important;
}
.tx-amount.income,
.income,
.text-income{
  color:#007a4d!important;
}
.tx-amount.expense,
.expense,
.text-expense,
.danger{
  color:#ff342e!important;
}
.quick-item i,
.menu-icon,
.category-icon{
  background:#ecf8f2!important;
  color:#007a4d!important;
}
.referral-card-v94{
  background:#fff!important;
  border:1px solid var(--cb-line)!important;
}
.referral-hero-v94{
  background:linear-gradient(145deg,#eaf7f1 0%,#fff 100%)!important;
  border:1px solid #d8eee4!important;
}
.referral-hero-v94 b{
  color:#007a4d!important;
}
.referral-link-v94 input{
  border:1px solid #d8eee4!important;
  background:#f8fffb!important;
}
.referral-link-v94 button{
  background:#007a4d!important;
  color:#fff!important;
  cursor:pointer!important;
  pointer-events:auto!important;
}
.referral-share-btn-v94{
  cursor:pointer!important;
  pointer-events:auto!important;
}
.referral-link-v94,
.referral-card-v94{
  position:relative!important;
  z-index:5!important;
}
.auth-premium-body,
.auth-premium-shell,
.page{
  background:linear-gradient(180deg,#eef8f3 0%,#f8fbf9 52%,#ffffff 100%)!important;
}
.auth-top,
.page .top{
  background:
    radial-gradient(circle at 70% -10%,rgba(255,255,255,.16),transparent 35%),
    linear-gradient(155deg,#005f3c 0%,#007a4d 52%,#009b62 100%)!important;
  border-radius:0 0 30px 30px!important;
}
.auth-card,
.card,
.referral-section-v94 .referral-card-v94{
  background:#fff!important;
  border:1px solid var(--cb-line)!important;
  box-shadow:0 12px 30px rgba(0,55,34,.08)!important;
}


/* v97 exact green reference ui */
:root{
  --v97-bg:#f3f8f5;
  --v97-bg2:#eef6f2;
  --v97-card:#ffffff;
  --v97-ink:#071321;
  --v97-muted:#667381;
  --v97-line:#e6eeea;
  --v97-green-dark:#00613f;
  --v97-green:#008a57;
  --v97-green2:#00a86a;
  --v97-mint:#edf8f2;
  --v97-mint2:#e7f4ed;
  --v97-red:#ff3b30;
  --v97-orange:#ff6b1a;
  --v97-purple:#7c3df2;
  --v97-blue:#2677f2;
  --v97-shadow:0 12px 32px rgba(0,50,31,.08);
}
html,body{
  background:var(--v97-bg)!important;
}
body.app-body,
.single-dashboard{
  background:
    linear-gradient(180deg,#edf7f2 0%,#f7fbf9 46%,#ffffff 100%)!important;
  color:var(--v97-ink)!important;
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;
}
.dashboard-shell{
  width:min(480px,100%)!important;
  max-width:480px!important;
  margin:0 auto!important;
  background:transparent!important;
  padding-bottom:112px!important;
  overflow:hidden!important;
}
.header-balance-unified{
  position:relative!important;
  margin:0!important;
  padding:0 18px 0!important;
  background:
    radial-gradient(circle at 64% -12%,rgba(255,255,255,.16) 0,rgba(255,255,255,.11) 18%,transparent 40%),
    radial-gradient(circle at 113% 62%,rgba(22,185,116,.42),transparent 34%),
    linear-gradient(150deg,#00583a 0%,#007a4d 48%,#009e63 100%)!important;
  border-radius:0 0 34px 34px!important;
  color:#fff!important;
  min-height:252px!important;
}
.header-balance-unified:after{
  content:""!important;
  position:absolute!important;
  left:-18px!important;right:-18px!important;bottom:-1px!important;
  height:44px!important;
  background:#f7fbf9!important;
  clip-path:ellipse(70% 100% at 50% 100%)!important;
  z-index:0!important;
}
.top-green-v97,
.top-green{
  background:transparent!important;
  box-shadow:none!important;
  border-radius:0!important;
  padding:19px 0 0!important;
  position:relative!important;
  z-index:2!important;
}
.app-topbar-v97,
.app-topbar{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:12px!important;
  padding:0!important;
}
.app-identity-v97 .identity-text{
  display:block!important;
}
.identity-hello-v97{
  display:block!important;
  color:rgba(255,255,255,.94)!important;
  font-size:15px!important;
  font-weight:700!important;
  margin-bottom:5px!important;
}
.identity-title{
  margin:0!important;
  color:#fff!important;
  font-size:25px!important;
  line-height:1.05!important;
  font-weight:900!important;
  letter-spacing:-.045em!important;
}
.identity-sub{
  color:rgba(255,255,255,.88)!important;
  font-size:13px!important;
  font-weight:700!important;
  margin-top:8px!important;
}
.home-badge{display:none!important}
.top-actions-v97{
  display:flex!important;
  gap:10px!important;
  align-items:center!important;
}
.search-btn-v97,
.bell-btn{
  width:46px!important;
  height:46px!important;
  border-radius:16px!important;
  border:0!important;
  background:#fff!important;
  color:#00613f!important;
  display:grid!important;
  place-items:center!important;
  box-shadow:0 10px 23px rgba(0,54,35,.16)!important;
  position:relative!important;
}
.search-btn-v97 svg,
.bell-btn svg{
  width:22px!important;height:22px!important;
}
.bell-btn i{
  position:absolute!important;
  right:6px!important;top:6px!important;
  width:9px!important;height:9px!important;border-radius:99px!important;
  background:#ff4b2f!important;border:2px solid #fff!important;
}
.balance-sticky-wrap{
  position:relative!important;
  z-index:3!important;
  margin-top:24px!important;
  padding:0!important;
  background:transparent!important;
}
.hero-balance-v97,
.hero-balance.sticky-balance-only{
  position:relative!important;
  overflow:hidden!important;
  background:#fff!important;
  border:1px solid rgba(0,67,42,.08)!important;
  border-radius:21px!important;
  padding:19px 16px 16px!important;
  box-shadow:0 16px 40px rgba(0,50,31,.14)!important;
  color:var(--v97-ink)!important;
}
.hero-balance-v97 small{
  color:#0d1a2a!important;
  font-size:13px!important;
  font-weight:900!important;
  display:flex!important;
  align-items:center!important;
  gap:6px!important;
  position:relative!important;
  z-index:2!important;
}
.eye-v97{
  font-size:14px!important;
  color:#0d1a2a!important;
}
.hero-balance-v97 h1{
  font-size:34px!important;
  line-height:1!important;
  margin:10px 0 10px!important;
  color:var(--v97-ink)!important;
  letter-spacing:-.06em!important;
  position:relative!important;
  z-index:2!important;
}
.balance-health-v97{
  display:flex!important;
  gap:12px!important;
  align-items:center!important;
  margin-bottom:15px!important;
  position:relative!important;
  z-index:2!important;
}
.balance-health-v97 b{
  display:inline-flex!important;
  min-height:23px!important;
  align-items:center!important;
  padding:0 16px!important;
  border-radius:999px!important;
  color:#007a4d!important;
  background:#dff5e8!important;
  font-size:12px!important;
  font-weight:900!important;
}
.balance-health-v97 span{
  color:#77808c!important;
  font-size:12px!important;
  font-weight:700!important;
}
.wallet-illustration-v97{
  position:absolute!important;
  right:18px!important;
  top:6px!important;
  width:130px!important;
  height:112px!important;
  border-radius:999px!important;
  background:radial-gradient(circle,#e6f8ef 0%,#eaf8f2 52%,transparent 68%)!important;
  z-index:1!important;
}
.wallet-body-v97{
  position:absolute!important;
  right:24px!important;
  top:39px!important;
  width:70px!important;
  height:55px!important;
  border-radius:15px 18px 18px 15px!important;
  background:linear-gradient(135deg,#087247 0%,#0e9a62 100%)!important;
  box-shadow:0 12px 18px rgba(0,90,55,.22)!important;
}
.wallet-body-v97:before{
  content:""!important;
  position:absolute!important;
  left:9px!important;right:8px!important;top:-14px!important;
  height:24px!important;
  border-radius:12px!important;
  background:linear-gradient(135deg,#0d704a,#0bb36f)!important;
  transform:rotate(-7deg)!important;
  border:2px solid rgba(255,255,255,.28)!important;
}
.wallet-body-v97:after{
  content:""!important;
  position:absolute!important;
  right:9px!important;top:25px!important;
  width:11px!important;height:11px!important;border-radius:99px!important;
  background:#f7bd35!important;
  box-shadow:0 0 0 3px rgba(247,189,53,.20)!important;
}
.coin-v97{
  position:absolute!important;
  display:grid!important;place-items:center!important;
  width:24px!important;height:24px!important;border-radius:99px!important;
  color:#a66a00!important;
  background:linear-gradient(135deg,#ffe17a,#f5a90a)!important;
  border:2px solid #ffd66a!important;
  font-size:8px!important;font-weight:900!important;
  box-shadow:0 6px 12px rgba(164,106,0,.17)!important;
}
.coin-a-v97{right:74px!important;top:25px!important}
.coin-b-v97{right:51px!important;top:15px!important}
.leaf-v97{
  position:absolute!important;
  width:30px!important;height:16px!important;border-radius:100% 0 100% 0!important;
  background:#4cbf77!important;
  transform:rotate(-35deg)!important;
  right:6px!important;
}
.leaf-a-v97{top:34px!important}
.leaf-b-v97{top:56px!important;right:0!important;background:#78ca8c!important}

.stat-row-v97,
.hero-balance .stat-row{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  position:relative!important;
  z-index:2!important;
}
.stat-box{
  min-height:78px!important;
  padding:12px 10px!important;
  border-radius:14px!important;
  background:#fff!important;
  border:1px solid var(--v97-line)!important;
  box-shadow:none!important;
}
.stat-box .label,
.stat-box .value{
  display:block!important;
  text-align:left!important;
}
.stat-box .label{
  color:#0d1a2a!important;
  font-size:10px!important;
  font-weight:800!important;
  margin-top:3px!important;
}
.stat-box .value{
  color:#0d1a2a!important;
  font-size:12px!important;
  font-weight:900!important;
  margin-top:3px!important;
  line-height:1.25!important;
}
.stat-icon-v97{
  width:32px!important;
  height:32px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:10px!important;
  font-size:18px!important;
  font-weight:900!important;
  margin-bottom:3px!important;
}
.stat-income-v97 .stat-icon-v97{background:#e7f8ee!important;color:#00a25f!important}
.stat-expense-v97 .stat-icon-v97{background:#fff0ec!important;color:#ff3b30!important}
.wallet-cash-v97 .stat-icon-v97{background:#e8f6f3!important;color:#008d7a!important}
.wallet-bank-v97 .stat-icon-v97{background:#f1e9ff!important;color:#7c3df2!important}
.transfer-inside-v97{
  width:100%!important;
  height:42px!important;
  border:0!important;
  margin-top:12px!important;
  border-radius:13px!important;
  background:linear-gradient(180deg,#eef8f3,#e6f4ed)!important;
  color:#007a4d!important;
  font-size:14px!important;
  font-weight:900!important;
}
.wallet-overview-normal{
  display:none!important;
}

.card-block{
  background:#fff!important;
  border:1px solid var(--v97-line)!important;
  border-radius:17px!important;
  box-shadow:var(--v97-shadow)!important;
  padding:15px!important;
  margin:12px 18px!important;
}
.card-head,
.tab-top .card-head{
  color:#0d1a2a!important;
  font-size:14px!important;
  font-weight:900!important;
  margin-bottom:12px!important;
}
.month-switch{
  background:#fff!important;
  border:1px solid var(--v97-line)!important;
  border-radius:17px!important;
  margin:14px 18px 12px!important;
  box-shadow:var(--v97-shadow)!important;
}
.month-btn{
  background:#eef8f3!important;
  color:#007a4d!important;
  border-radius:12px!important;
}
.quick-grid{
  display:grid!important;
  grid-template-columns:repeat(6,1fr)!important;
  gap:9px!important;
}
.quick-item{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  min-height:auto!important;
}
.quick-icon{
  width:45px!important;
  height:45px!important;
  margin:0 auto 8px!important;
  border-radius:14px!important;
  display:grid!important;
  place-items:center!important;
  background:#edf8f3!important;
  color:#007a4d!important;
  box-shadow:none!important;
}
.quick-icon svg{
  width:24px!important;
  height:24px!important;
}
.quick-item span{
  color:#0d1a2a!important;
  font-size:11px!important;
  font-weight:800!important;
}
.quick-icon.plus{background:#e6f7ed!important}
.quick-icon.chart{background:#edf4ff!important}
.quick-icon.export{background:#fff0ec!important}
.quick-icon.list{background:#f0f2f5!important}
.quick-icon.target-v97{background:#f2eaff!important;color:#7c3df2!important;font-size:25px!important}
.quick-icon.debt-v97{background:#e7f8f4!important;color:#008d7a!important;font-size:22px!important}

.recap-grid,
.summary-grid,
.wallet-grid{
  gap:10px!important;
}
.recap-grid > *,
.summary-grid > *,
.finance-row,
.top-expense-row,
.tx-item,
.member-profile-row-v78,
.referral-list-v94 div{
  background:#fff!important;
  border:1px solid var(--v97-line)!important;
  border-radius:15px!important;
  box-shadow:none!important;
}
.tx-item{
  padding:12px 10px!important;
}
.tx-pin{
  background:#fff0ec!important;
  color:#ff6b1a!important;
  border-radius:13px!important;
}
.tx-amount.income{color:#007a4d!important}
.tx-amount.expense{color:#ff3b30!important}
.wallet-tag,.tx-tag{
  border:0!important;
  background:#eef8f3!important;
  color:#007a4d!important;
  border-radius:999px!important;
  font-weight:800!important;
}
.filter-pills button,
.history-filter button,
[data-filter]{
  border-radius:999px!important;
  border:1px solid var(--v97-line)!important;
  background:#fff!important;
  color:#667381!important;
}
.filter-pills button.active,
.history-filter button.active,
[data-filter].active{
  background:#007a4d!important;
  color:#fff!important;
}
.pretty-submit,
.btn-primary,
.auth-submit,
.referral-withdraw-v94{
  background:linear-gradient(135deg,#006b43 0%,#009b62 100%)!important;
  color:#fff!important;
  border:0!important;
  border-radius:15px!important;
  box-shadow:0 12px 24px rgba(0,122,77,.22)!important;
}
.profile-actions a,
.profile-actions button,
.referral-share-btn-v94,
.referral-link-v94 button,
.wallet-transfer-shortcut{
  border-radius:13px!important;
  background:linear-gradient(180deg,#eef8f3,#e6f4ed)!important;
  border:1px solid #dcefe6!important;
  color:#007a4d!important;
  font-weight:900!important;
}
.referral-link-v94 button{
  background:#007a4d!important;
  color:#fff!important;
}
.bottom-nav{
  left:50%!important;
  transform:translateX(-50%)!important;
  width:min(450px,calc(100% - 24px))!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.96)!important;
  border:1px solid rgba(0,79,50,.08)!important;
  box-shadow:0 -12px 34px rgba(0,50,31,.13)!important;
  backdrop-filter:blur(16px)!important;
  padding:9px 10px calc(9px + env(safe-area-inset-bottom))!important;
}
.bottom-nav .nav-item{
  color:#667381!important;
  font-size:10px!important;
  font-weight:800!important;
}
.bottom-nav .nav-item.active,
.bottom-nav .nav-item.active-trigger{
  color:#007a4d!important;
}
.bottom-nav .nav-item svg{
  width:22px!important;
  height:22px!important;
}
.bottom-nav .nav-plus,
.bottom-nav .plus-btn,
.bottom-nav [data-tab-target="catat"].nav-item{
  width:58px!important;
  height:58px!important;
  border-radius:999px!important;
  background:linear-gradient(135deg,#006b43 0%,#009b62 100%)!important;
  color:#fff!important;
  box-shadow:0 13px 28px rgba(0,122,77,.28)!important;
}
.auth-top,
.page .top{
  background:
    radial-gradient(circle at 68% -12%,rgba(255,255,255,.15),transparent 38%),
    linear-gradient(150deg,#00583a 0%,#007a4d 48%,#009e63 100%)!important;
}
.auth-card,
.card,
.referral-section-v94 .referral-card-v94{
  background:#fff!important;
  border:1px solid var(--v97-line)!important;
  border-radius:18px!important;
  box-shadow:var(--v97-shadow)!important;
}
@media(max-width:430px){
  .header-balance-unified{padding-left:14px!important;padding-right:14px!important}
  .card-block{margin-left:14px!important;margin-right:14px!important}
  .quick-grid{gap:6px!important}
  .quick-icon{width:40px!important;height:40px!important;border-radius:13px!important}
  .quick-item span{font-size:10px!important}
}


/* v98 referral min 10 data */
.referral-stats-v98{
  grid-template-columns:1fr 1fr!important;
}
.referral-note-v98{
  margin-top:10px;
  padding:10px 11px;
  border-radius:14px;
  background:#eef8f3;
  border:1px solid #dcefe6;
  color:#007a4d;
  font-size:11px;
  font-weight:800;
  line-height:1.45;
}


/* v99 sticky balance bottom sheet compact */
/* Sticky hanya saldo, pemasukan, pengeluaran. Cash/Rekening dan Pindah Saldo kembali non-sticky. */
.header-balance-unified{
  min-height:214px!important;
  padding-bottom:10px!important;
}
.balance-sticky-wrap{
  position:sticky!important;
  top:0!important;
  z-index:80!important;
  margin-top:16px!important;
  padding:0!important;
}
.hero-balance-v97,
.hero-balance.sticky-balance-only{
  padding:14px 14px 13px!important;
  border-radius:18px!important;
  transition:none!important;
  transform:none!important;
  will-change:auto!important;
}
.hero-balance-v97 h1{
  font-size:28px!important;
  margin:7px 0 8px!important;
  letter-spacing:-.055em!important;
}
.hero-balance-v97 small{
  font-size:12px!important;
}
.balance-health-v97{
  margin-bottom:10px!important;
}
.balance-health-v97 b{
  min-height:20px!important;
  padding:0 11px!important;
  font-size:10px!important;
}
.balance-health-v97 span{
  font-size:11px!important;
}
.wallet-illustration-v97{
  display:none!important;
}
.hero-balance-v97 .wallet-stat-v97,
.hero-balance-v97 .transfer-inside-v97{
  display:none!important;
}
.stat-row-v97,
.hero-balance .stat-row{
  grid-template-columns:1fr 1fr!important;
  gap:7px!important;
}
.stat-box{
  min-height:58px!important;
  padding:9px 10px!important;
  border-radius:13px!important;
}
.stat-icon-v97{
  display:none!important;
}
.stat-box .label{
  font-size:10px!important;
  margin-top:0!important;
}
.stat-box .value{
  font-size:11.5px!important;
  margin-top:4px!important;
}
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  margin:12px 18px 0!important;
  padding:0!important;
  position:relative!important;
  z-index:5!important;
}
.wallet-overview-normal .wallet-card{
  min-height:62px!important;
  padding:12px!important;
  border-radius:16px!important;
}
.wallet-overview-normal .wallet-card span{
  font-size:11px!important;
  color:#667381!important;
  font-weight:800!important;
}
.wallet-overview-normal .wallet-card b{
  font-size:14px!important;
  color:#071321!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
  height:40px!important;
  min-height:40px!important;
  padding:0!important;
  border-radius:14px!important;
  font-size:13px!important;
  background:linear-gradient(180deg,#eef8f3,#e6f4ed)!important;
  color:#007a4d!important;
}

/* UI lebih compact supaya tidak terlihat besar */
.dashboard-shell{
  padding-bottom:96px!important;
}
.card-block{
  margin:10px 14px!important;
  padding:12px!important;
  border-radius:16px!important;
}
.card-head{
  font-size:13px!important;
  margin-bottom:9px!important;
}
.month-switch{
  margin:10px 14px!important;
  min-height:38px!important;
}
.quick-grid{
  gap:5px!important;
}
.quick-icon{
  width:38px!important;
  height:38px!important;
  border-radius:12px!important;
  margin-bottom:5px!important;
}
.quick-icon svg{
  width:21px!important;
  height:21px!important;
}
.quick-item span{
  font-size:9.5px!important;
}
.tx-item{
  padding:9px!important;
  border-radius:14px!important;
}
.tx-pin{
  width:34px!important;
  height:34px!important;
  border-radius:12px!important;
  font-size:17px!important;
}
.tx-main b{
  font-size:12px!important;
}
.tx-meta{
  font-size:9.5px!important;
}
.tx-amount{
  font-size:12px!important;
}
.wallet-tag,.tx-tag{
  font-size:8.5px!important;
  padding:3px 7px!important;
}
.member-profile-row-v78{
  padding:8px 9px!important;
}
.referral-hero-v94{
  padding:10px!important;
  border-radius:15px!important;
}
.referral-hero-v94 b{
  font-size:22px!important;
}
.referral-stats-v94 div{
  padding:8px!important;
}

/* Semua form tambah/edit/detail menjadi bottom sheet muncul dari bawah */
.cb-modal{
  align-items:flex-end!important;
  justify-content:center!important;
  padding:0 10px calc(10px + env(safe-area-inset-bottom))!important;
  background:rgba(6,20,18,.42)!important;
}
.cb-modal .cb-modal-card{
  width:min(430px,100%)!important;
  max-height:86dvh!important;
  overflow:auto!important;
  border-radius:22px 22px 18px 18px!important;
  padding:14px!important;
  transform:translateY(110%)!important;
  opacity:.98!important;
  transition:transform .26s cubic-bezier(.22,.9,.24,1), opacity .2s ease!important;
  box-shadow:0 -18px 42px rgba(0,45,28,.22)!important;
}
.cb-modal.open .cb-modal-card{
  transform:translateY(0)!important;
  opacity:1!important;
}
.cb-modal .cb-modal-backdrop{
  position:absolute!important;
  inset:0!important;
}
.cb-modal-close{
  width:30px!important;
  height:30px!important;
  border-radius:12px!important;
  font-size:19px!important;
}
.cb-modal .card-head,
.cb-modal h3,
.cb-modal .sheet-head h3{
  font-size:15px!important;
  margin-bottom:10px!important;
}
.form-stack{
  gap:8px!important;
}
.form-stack label{
  font-size:11px!important;
  margin-bottom:2px!important;
}
.form-stack input,
.form-stack select,
.form-stack textarea,
.compact-form input,
.compact-form select,
.compact-form textarea{
  min-height:38px!important;
  height:38px!important;
  border-radius:13px!important;
  padding:0 11px!important;
  font-size:13px!important;
}
.form-stack textarea,
.compact-form textarea{
  min-height:72px!important;
  height:72px!important;
  padding-top:9px!important;
}
.type-toggle,
.wallet-toggle{
  gap:7px!important;
}
.type-chip span,
.wallet-toggle span{
  min-height:36px!important;
  border-radius:13px!important;
  font-size:11px!important;
  padding:0 9px!important;
}
.pretty-submit{
  min-height:40px!important;
  height:40px!important;
  border-radius:14px!important;
  font-size:12px!important;
}
.sheet-head{
  padding:10px!important;
}
.sheet-icon{
  width:38px!important;
  height:38px!important;
  border-radius:14px!important;
}
.sheet-action{
  min-height:40px!important;
  height:40px!important;
  border-radius:14px!important;
  font-size:12px!important;
}
.tx-detail-head-v91{
  padding:10px!important;
  border-radius:15px!important;
}
.tx-detail-head-v91 > span{
  width:38px!important;
  height:38px!important;
  border-radius:14px!important;
}
.tx-detail-grid-v91{
  gap:7px!important;
}
.tx-detail-grid-v91 div,
.tx-detail-note-v91{
  padding:8px!important;
  border-radius:13px!important;
}
.tx-detail-actions-v91 button{
  min-height:38px!important;
  height:38px!important;
  border-radius:13px!important;
  font-size:11px!important;
}

/* Bottom nav lebih kecil */
.bottom-nav{
  width:min(430px,calc(100% - 20px))!important;
  border-radius:22px!important;
  padding:7px 8px calc(7px + env(safe-area-inset-bottom))!important;
}
.bottom-nav .nav-item{
  font-size:9.5px!important;
}
.bottom-nav .nav-item svg{
  width:20px!important;
  height:20px!important;
}
.bottom-nav .nav-plus,
.bottom-nav .plus-btn,
.bottom-nav [data-tab-target="catat"].nav-item{
  width:52px!important;
  height:52px!important;
}
@media(max-width:430px){
  .wallet-overview-normal{
    margin-left:14px!important;
    margin-right:14px!important;
  }
  .hero-balance-v97 h1{
    font-size:26px!important;
  }
  .stat-box .value{
    font-size:11px!important;
  }
}


/* v100 reference scroll button fix */
/* Hilangkan efek geser: header + saldo ringkas dibuat fixed stabil, bukan sticky yang ikut naik-turun. */
.header-balance-unified{
  position:fixed!important;
  top:0!important;
  left:50%!important;
  transform:translateX(-50%)!important;
  width:min(480px,100%)!important;
  z-index:90!important;
  min-height:208px!important;
  height:208px!important;
  padding:0 14px 10px!important;
  border-radius:0 0 28px 28px!important;
  overflow:visible!important;
  will-change:auto!important;
}
.header-balance-unified:after{
  height:34px!important;
}
.top-green,
.top-green-v97{
  height:92px!important;
  padding-top:16px!important;
}
.app-topbar,
.app-topbar-v97{
  height:78px!important;
}
.balance-sticky-wrap{
  position:absolute!important;
  left:14px!important;
  right:14px!important;
  top:92px!important;
  margin:0!important;
  z-index:92!important;
  transform:none!important;
  will-change:auto!important;
}
.hero-balance-v97,
.hero-balance.sticky-balance-only{
  height:116px!important;
  min-height:116px!important;
  padding:12px 12px 11px!important;
  border-radius:18px!important;
  transform:none!important;
  transition:none!important;
  animation:none!important;
}
.hero-balance-v97 h1{
  font-size:24px!important;
  margin:6px 0 7px!important;
}
.hero-balance-v97 small{
  font-size:11px!important;
}
.balance-health-v97{
  display:none!important;
}
.hero-balance-v97 .stat-row,
.stat-row-v97{
  grid-template-columns:1fr 1fr!important;
  gap:7px!important;
}
.hero-balance-v97 .stat-box{
  min-height:46px!important;
  height:46px!important;
  padding:7px 9px!important;
  border-radius:12px!important;
  background:#fff!important;
}
.hero-balance-v97 .stat-box .label{
  font-size:9.5px!important;
}
.hero-balance-v97 .stat-box .value{
  font-size:10.5px!important;
  margin-top:2px!important;
}
.dashboard-shell{
  padding-top:222px!important;
  background:linear-gradient(180deg,#f6fbf8 0%,#fff 100%)!important;
}
.wallet-overview-normal{
  margin-top:8px!important;
}

/* Tombol Catat di quick menu jangan lingkaran hijau solid; samakan pastel icon dengan item lain. */
.quick-item[data-tab-target="catat"]{
  background:transparent!important;
  box-shadow:none!important;
}
.quick-item[data-tab-target="catat"] .quick-icon,
.quick-icon.plus{
  background:#eaf7f1!important;
  color:#007a4d!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:14px!important;
}
.quick-item[data-tab-target="catat"] .quick-icon svg,
.quick-icon.plus svg{
  stroke:#007a4d!important;
}
.quick-item[data-tab-target="catat"] span{
  color:#071321!important;
}

/* Floating plus bottom tetap hijau seperti referensi, tetapi icon quick Catat tidak. */
.bottom-nav [data-tab-target="catat"].nav-item,
.bottom-nav .nav-plus,
.bottom-nav .plus-btn{
  background:linear-gradient(135deg,#006b43 0%,#008f5a 100%)!important;
  color:#fff!important;
}

/* Orange area dibuat putih/pastel seperti referensi: kartu tetap white card, orange hanya icon/progress teks kecil. */
.card-block,
.stat-box,
.wallet-card,
.tx-item,
.top-expense-row,
.finance-row,
.referral-card-v94,
.referral-hero-v94,
.referral-list-v94 div,
.member-profile-row-v78,
.category-card,
.budget-card,
.target-card{
  background:#fff!important;
}
.quick-icon.export,
.quick-icon.budget,
.quick-item[data-tab-target="kategori"] .quick-icon,
.stat-expense-v97 .stat-icon-v97,
.tx-pin,
.referral-section-v94 .referral-card-v94{
  background:#fff!important;
  border:1px solid #eef1ee!important;
}
.quick-icon.export svg,
.quick-item[data-tab-target="kategori"] svg{
  stroke:#ff6b1a!important;
}
.expense-chip span,
.type-chip.expense-chip span{
  background:#fff!important;
  border:1px solid #eef1ee!important;
  color:#ff3b30!important;
}
.pwa-install-overlay-v84 .pwa-install-card-v84,
.pwa-open-installed-card-v85,
.cb-modal .cb-modal-card{
  background:#fff!important;
}

/* Tombol dalam kartu yang sebelumnya oranye/cream diubah ke white/mint soft. */
.referral-share-btn-v94,
.profile-actions a,
.profile-actions button,
.wallet-transfer-shortcut,
.tx-detail-close-v91,
.sheet-action.neutral,
.btn-secondary,
.mini-add-btn{
  background:linear-gradient(180deg,#ffffff 0%,#f3faf6 100%)!important;
  color:#007a4d!important;
  border:1px solid #dcefe6!important;
}

/* Modal/bottom sheet tetap slide-up tapi lebih ringan dan tidak terlihat terlalu besar. */
.cb-modal .cb-modal-card{
  width:min(420px,calc(100% - 18px))!important;
  max-height:82dvh!important;
  padding:12px!important;
  border-radius:20px 20px 16px 16px!important;
}
.form-stack input,
.form-stack select,
.form-stack textarea,
.compact-form input,
.compact-form select,
.compact-form textarea{
  min-height:36px!important;
  height:36px!important;
  font-size:12px!important;
}
.pretty-submit,
.sheet-action,
.tx-detail-actions-v91 button{
  height:38px!important;
  min-height:38px!important;
}
@media(max-width:430px){
  .header-balance-unified{
    width:100%!important;
    left:0!important;
    transform:none!important;
  }
  .dashboard-shell{
    padding-top:218px!important;
  }
}


/* v101 optional pwa install prompt */
.pwa-force-install-v84,
.pwa-open-installed-guard-v85,
.pwa-install-overlay-v84{
  display:none!important;
}
html.pwa-install-open-v101 body{
  overflow:hidden!important;
}
.pwa-install-overlay-v101{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
  align-items:flex-end;
  justify-content:center;
  background:rgba(6,20,18,.36);
  padding:12px 12px calc(12px + env(safe-area-inset-bottom));
}
.pwa-install-overlay-v101.show{
  display:flex;
}
.pwa-install-card-v101{
  width:min(420px,100%);
  background:#fff;
  border:1px solid #dcefe6;
  border-radius:22px;
  padding:16px 14px 14px;
  box-shadow:0 -18px 44px rgba(0,50,31,.20);
  color:#071321;
  text-align:center;
  position:relative;
}
.pwa-install-close-v101{
  position:absolute;
  top:10px;
  right:10px;
  width:30px;
  height:30px;
  border-radius:12px;
  border:1px solid #e6eeea;
  background:#fff;
  color:#667381;
  font-size:18px;
  font-weight:900;
}
.pwa-install-icon-v101{
  width:48px;
  height:48px;
  margin:2px auto 10px;
  border-radius:17px;
  display:grid;
  place-items:center;
  background:#eaf7f1;
  color:#007a4d;
  font-size:25px;
}
.pwa-install-card-v101 h2{
  margin:0 0 6px;
  font-size:18px;
  letter-spacing:-.035em;
}
.pwa-install-card-v101 p{
  margin:0 auto 10px;
  color:#667381;
  font-size:12px;
  line-height:1.45;
  max-width:320px;
}
.pwa-install-note-v101{
  border-radius:14px;
  background:#f3faf6;
  border:1px solid #dcefe6;
  color:#007a4d;
  padding:9px 10px;
  font-size:11px;
  line-height:1.4;
  margin-bottom:10px;
}
.pwa-install-main-v101,
.pwa-install-hide-v101{
  width:100%;
  min-height:40px;
  border-radius:14px;
  font-size:12px;
  font-weight:900;
}
.pwa-install-main-v101{
  border:0;
  background:linear-gradient(135deg,#006b43 0%,#009b62 100%);
  color:#fff;
}
.pwa-install-main-v101:disabled{
  opacity:.7;
}
.pwa-install-hide-v101{
  margin-top:8px;
  border:1px solid #dcefe6;
  background:#fff;
  color:#667381;
}


/* v102 force white balance card */
/* Override paling akhir: bagian Saldo Global wajib putih seperti referensi. */
.header-balance-unified .hero-balance,
.header-balance-unified .hero-balance-v97,
.header-balance-unified .hero-balance.sticky-balance-only,
.hero-balance-v97,
.hero-balance.sticky-balance-only,
.balance-sticky-wrap .hero-balance{
  background:#ffffff!important;
  background-color:#ffffff!important;
  background-image:none!important;
  color:#071321!important;
  border:1px solid rgba(0,79,50,.08)!important;
  box-shadow:0 16px 40px rgba(0,50,31,.12)!important;
}
.header-balance-unified .hero-balance *,
.hero-balance-v97 *,
.hero-balance.sticky-balance-only *{
  color:inherit;
}
.hero-balance-v97 small,
.hero-balance.sticky-balance-only small,
.hero-balance-v97 .label,
.hero-balance.sticky-balance-only .label{
  color:#071321!important;
}
.hero-balance-v97 h1,
.hero-balance.sticky-balance-only h1{
  color:#071321!important;
}
.hero-balance-v97 .stat-box,
.hero-balance.sticky-balance-only .stat-box,
.hero-balance-v97 .stat-row .stat-box,
.hero-balance.sticky-balance-only .stat-row .stat-box{
  background:#ffffff!important;
  background-color:#ffffff!important;
  background-image:none!important;
  border:1px solid #e6eeea!important;
  color:#071321!important;
}
.hero-balance-v97 .stat-box .label,
.hero-balance.sticky-balance-only .stat-box .label{
  color:#071321!important;
}
.hero-balance-v97 .stat-box .value,
.hero-balance.sticky-balance-only .stat-box .value{
  color:#071321!important;
}
.hero-balance-v97 .stat-income-v97 .value,
.hero-balance-v97 .stat-income-v97 .label{
  color:#071321!important;
}
.hero-balance-v97 .stat-expense-v97 .value,
.hero-balance-v97 .stat-expense-v97 .label{
  color:#071321!important;
}
.balance-health-v97 b{
  background:#dff5e8!important;
  color:#007a4d!important;
}
.balance-health-v97 span{
  color:#667381!important;
}
.wallet-illustration-v97{
  background:radial-gradient(circle,#e6f8ef 0%,#eefaf4 55%,transparent 70%)!important;
}
.header-balance-unified{
  background:
    radial-gradient(circle at 64% -12%,rgba(255,255,255,.16) 0,rgba(255,255,255,.11) 18%,transparent 40%),
    radial-gradient(circle at 113% 62%,rgba(22,185,116,.42),transparent 34%),
    linear-gradient(150deg,#00583a 0%,#007a4d 48%,#009e63 100%)!important;
}

/* Jika saldo card fixed compact, tetap putih dan tidak transparan saat scroll. */
.balance-sticky-wrap{
  background:transparent!important;
}
.balance-sticky-wrap:before,
.balance-sticky-wrap:after,
.hero-balance-v97:before,
.hero-balance-v97:after{
  background:transparent!important;
}

/* Wallet card di bawah tetap putih juga. */
.wallet-overview-normal .wallet-card,
.wallet-overview-normal .wallet-transfer-shortcut{
  background:#ffffff!important;
  background-color:#ffffff!important;
  background-image:none!important;
  border:1px solid #e6eeea!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  color:#007a4d!important;
}


/* v103 align balance wallet column */
/* Satu ukuran kolom: Saldo Global, Cash/Rekening, Pindah Saldo, dan card lain harus lurus. */
:root{
  --v103-page-max:480px;
  --v103-gutter:14px;
  --v103-content-width:calc(100% - (var(--v103-gutter) * 2));
}
.dashboard-shell{
  width:min(var(--v103-page-max),100%)!important;
  max-width:var(--v103-page-max)!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.header-balance-unified{
  width:min(var(--v103-page-max),100%)!important;
  max-width:var(--v103-page-max)!important;
  left:50%!important;
  right:auto!important;
  transform:translateX(-50%)!important;
  padding-left:0!important;
  padding-right:0!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  width:var(--v103-content-width)!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.balance-sticky-wrap{
  left:var(--v103-gutter)!important;
  right:var(--v103-gutter)!important;
  width:auto!important;
  max-width:none!important;
  margin-left:0!important;
  margin-right:0!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .sticky-balance-only{
  width:100%!important;
  max-width:none!important;
  box-sizing:border-box!important;
  margin-left:0!important;
  margin-right:0!important;
}
.wallet-overview-normal,
.card-block,
.month-switch,
.activity-strip{
  width:var(--v103-content-width)!important;
  max-width:none!important;
  margin-left:auto!important;
  margin-right:auto!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  padding:0!important;
}
.wallet-overview-normal .wallet-card,
.wallet-overview-normal .wallet-transfer-shortcut{
  width:100%!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
}
@media(max-width:430px){
  :root{
    --v103-gutter:14px;
  }
  .header-balance-unified{
    left:0!important;
    transform:none!important;
    width:100%!important;
    max-width:100%!important;
  }
}
@media(min-width:431px){
  :root{
    --v103-gutter:18px;
  }
}


/* v104 absolute center balance wallet */
/* Override paling akhir: Saldo Global, Cash/Rekening, dan seluruh card memakai garis kiri-kanan absolut yang sama. */
:root{
  --v104-page-width:min(480px, 100vw);
  --v104-gutter:14px;
}
html,body{
  overflow-x:hidden!important;
}
.dashboard-shell{
  position:relative!important;
  width:var(--v104-page-width)!important;
  max-width:480px!important;
  margin:0 auto!important;
  padding-left:0!important;
  padding-right:0!important;
  box-sizing:border-box!important;
}
.header-balance-unified{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  width:var(--v104-page-width)!important;
  max-width:480px!important;
  margin-left:auto!important;
  margin-right:auto!important;
  transform:none!important;
  padding-left:0!important;
  padding-right:0!important;
  box-sizing:border-box!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  width:auto!important;
  margin-left:var(--v104-gutter)!important;
  margin-right:var(--v104-gutter)!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap{
  position:absolute!important;
  top:92px!important;
  left:var(--v104-gutter)!important;
  right:var(--v104-gutter)!important;
  width:auto!important;
  margin:0!important;
  padding:0!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .sticky-balance-only{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  margin:0!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.wallet-overview-normal,
.month-switch,
.activity-strip,
.card-block{
  width:auto!important;
  max-width:none!important;
  margin-left:var(--v104-gutter)!important;
  margin-right:var(--v104-gutter)!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal{
  padding:0!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
  gap:8px!important;
}
.wallet-overview-normal .wallet-card,
.wallet-overview-normal .wallet-transfer-shortcut{
  width:100%!important;
  max-width:100%!important;
  margin:0!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
}
@media(max-width:360px){
  :root{--v104-gutter:12px;}
}
@media(min-width:481px){
  .header-balance-unified{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
  }
}


/* v105 force same x axis balance wallet */
/*
  Fix final: jangan pakai centering variable untuk kartu fixed.
  Semua blok utama dipaksa mulai dan selesai di X-axis yang sama:
  left 20px, right 20px pada mobile.
*/
:root{
  --v105-x:20px;
}
@media(max-width:390px){
  :root{--v105-x:18px;}
}
html,body{
  width:100%!important;
  max-width:100%!important;
  overflow-x:hidden!important;
}
.dashboard-shell{
  width:100%!important;
  max-width:480px!important;
  margin:0 auto!important;
  padding-left:0!important;
  padding-right:0!important;
  box-sizing:border-box!important;
  overflow:visible!important;
}
.header-balance-unified{
  position:fixed!important;
  top:0!important;
  left:50%!important;
  right:auto!important;
  transform:translateX(-50%)!important;
  width:100%!important;
  max-width:480px!important;
  margin:0!important;
  padding-left:0!important;
  padding-right:0!important;
  box-sizing:border-box!important;
  overflow:visible!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  width:auto!important;
  margin-left:var(--v105-x)!important;
  margin-right:var(--v105-x)!important;
  padding-left:0!important;
  padding-right:0!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap{
  position:absolute!important;
  top:92px!important;
  left:var(--v105-x)!important;
  right:var(--v105-x)!important;
  width:auto!important;
  max-width:none!important;
  margin:0!important;
  padding:0!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .sticky-balance-only{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  margin:0!important;
  padding-left:14px!important;
  padding-right:14px!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.wallet-overview-normal,
.month-switch,
.activity-strip,
.card-block{
  width:auto!important;
  max-width:none!important;
  margin-left:var(--v105-x)!important;
  margin-right:var(--v105-x)!important;
  padding-left:0!important;
  padding-right:0!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.card-block{
  padding:12px!important;
}
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
  gap:10px!important;
}
.wallet-overview-normal .wallet-card,
.wallet-overview-normal .wallet-transfer-shortcut{
  width:100%!important;
  max-width:100%!important;
  margin:0!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
}
@media(min-width:481px){
  .header-balance-unified{
    width:480px!important;
  }
  .dashboard-shell{
    width:480px!important;
  }
}


/* v106 final tidy aligned balance and wallet */
:root{
  --v106-max:480px;
  --v106-gutter:20px;
}
@media(max-width:390px){
  :root{ --v106-gutter:18px; }
}
html,body{
  overflow-x:hidden!important;
}
.dashboard-shell{
  position:relative!important;
  width:100%!important;
  max-width:var(--v106-max)!important;
  margin:0 auto!important;
  padding-top:286px!important;
  padding-left:0!important;
  padding-right:0!important;
  background:linear-gradient(180deg,#f5fbf7 0%,#ffffff 100%)!important;
  box-sizing:border-box!important;
}
.header-balance-unified{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  width:100%!important;
  max-width:var(--v106-max)!important;
  margin:0 auto!important;
  transform:none!important;
  padding:0!important;
  height:auto!important;
  min-height:0!important;
  border-radius:0!important;
  overflow:visible!important;
  z-index:120!important;
}
.header-balance-unified::after{ display:none!important; }
@media(min-width:481px){
  .header-balance-unified{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    width:480px!important;
  }
}
.header-balance-unified .top-green,
.header-balance-unified .top-green-v97{
  height:172px!important;
  min-height:172px!important;
  margin:0!important;
  padding:0!important;
  border-radius:0 0 34px 34px!important;
  overflow:hidden!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  width:auto!important;
  height:auto!important;
  margin-left:var(--v106-gutter)!important;
  margin-right:var(--v106-gutter)!important;
  padding-top:18px!important;
  padding-bottom:0!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap{
  position:absolute!important;
  top:98px!important;
  left:var(--v106-gutter)!important;
  right:var(--v106-gutter)!important;
  width:auto!important;
  margin:0!important;
  padding:0!important;
  box-sizing:border-box!important;
  transform:none!important;
  z-index:121!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only,
.balance-sticky-wrap .sticky-balance-only{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  margin:0!important;
  padding:18px 20px 18px!important;
  border-radius:26px!important;
  box-shadow:0 12px 28px rgba(16,60,42,.12)!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap .hero-balance-v97 h1,
.balance-sticky-wrap .hero-balance.sticky-balance-only h1{
  font-size:31px!important;
  line-height:1.08!important;
  margin:0 0 14px!important;
}
.balance-sticky-wrap .hero-balance-v97 small,
.balance-sticky-wrap .hero-balance.sticky-balance-only small{
  margin-bottom:8px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-row,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:10px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box{
  min-height:84px!important;
  padding:14px 14px 12px!important;
  border-radius:18px!important;
}
.balance-sticky-wrap .hero-balance-v97 .wallet-stat-v97,
.balance-sticky-wrap .hero-balance-v97 .transfer-inside-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only .wallet-stat-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only .transfer-inside-v97,
.balance-sticky-wrap .hero-transfer-btn,
.balance-sticky-wrap .wallet-transfer-shortcut{
  display:none!important;
}
.wallet-overview-normal,
.month-switch,
.activity-strip,
.card-block{
  width:calc(100% - (var(--v106-gutter) * 2))!important;
  max-width:none!important;
  margin-left:auto!important;
  margin-right:auto!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
  padding:0!important;
  margin-top:16px!important;
}
.wallet-overview-normal .wallet-card,
.wallet-overview-normal .wallet-transfer-shortcut{
  width:100%!important;
  max-width:100%!important;
  margin:0!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
}
.month-switch{
  margin-top:14px!important;
}
@media(max-width:390px){
  .dashboard-shell{ padding-top:278px!important; }
  .header-balance-unified .top-green,
  .header-balance-unified .top-green-v97{ height:166px!important; min-height:166px!important; }
  .balance-sticky-wrap{ top:94px!important; }
  .balance-sticky-wrap .hero-balance,
  .balance-sticky-wrap .hero-balance-v97,
  .balance-sticky-wrap .hero-balance.sticky-balance-only,
  .balance-sticky-wrap .sticky-balance-only{ padding:16px 18px 16px!important; }
  .balance-sticky-wrap .hero-balance-v97 h1,
  .balance-sticky-wrap .hero-balance.sticky-balance-only h1{ font-size:29px!important; }
}


/* v107 balance card no cut align */
/*
  Fix dari screenshot:
  - Kartu Saldo Global tidak boleh kepotong.
  - Pemasukan/Pengeluaran harus terlihat penuh.
  - Cash/Rekening sejajar dengan kartu Saldo.
  - Header hijau tidak menyisakan jarak kosong besar.
*/
:root{
  --v107-max:480px;
  --v107-x:24px;
}
@media(max-width:390px){
  :root{ --v107-x:22px; }
}
html,body{
  overflow-x:hidden!important;
}
.dashboard-shell{
  width:100%!important;
  max-width:var(--v107-max)!important;
  margin:0 auto!important;
  padding-left:0!important;
  padding-right:0!important;
  padding-top:302px!important;
  box-sizing:border-box!important;
  background:linear-gradient(180deg,#f5fbf7 0%,#fff 100%)!important;
}
.header-balance-unified{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  width:100%!important;
  max-width:var(--v107-max)!important;
  margin:0 auto!important;
  transform:none!important;
  height:292px!important;
  min-height:292px!important;
  padding:0!important;
  border-radius:0 0 34px 34px!important;
  overflow:visible!important;
  z-index:120!important;
  box-sizing:border-box!important;
}
@media(min-width:481px){
  .header-balance-unified{
    left:50%!important;
    right:auto!important;
    transform:translateX(-50%)!important;
    width:480px!important;
  }
}
.header-balance-unified::after{
  display:none!important;
}
.header-balance-unified .top-green,
.header-balance-unified .top-green-v97{
  height:166px!important;
  min-height:166px!important;
  margin:0!important;
  padding:0!important;
  border-radius:0 0 34px 34px!important;
  overflow:hidden!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  width:auto!important;
  margin-left:var(--v107-x)!important;
  margin-right:var(--v107-x)!important;
  padding-top:18px!important;
  height:auto!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap{
  position:absolute!important;
  top:112px!important;
  left:var(--v107-x)!important;
  right:var(--v107-x)!important;
  width:auto!important;
  height:auto!important;
  margin:0!important;
  padding:0!important;
  z-index:130!important;
  transform:none!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only,
.balance-sticky-wrap .sticky-balance-only{
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  min-height:190px!important;
  margin:0!important;
  padding:18px 20px 18px!important;
  overflow:visible!important;
  border-radius:24px!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap .hero-balance-v97 small,
.balance-sticky-wrap .hero-balance.sticky-balance-only small{
  display:flex!important;
  margin:0 0 10px!important;
  font-size:13px!important;
  line-height:1.1!important;
}
.balance-sticky-wrap .hero-balance-v97 h1,
.balance-sticky-wrap .hero-balance.sticky-balance-only h1{
  font-size:34px!important;
  line-height:1.05!important;
  margin:0 0 18px!important;
  letter-spacing:-.055em!important;
}
.balance-sticky-wrap .balance-health-v97{
  display:none!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-row,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:10px!important;
  margin:0!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box{
  display:block!important;
  height:70px!important;
  min-height:70px!important;
  padding:13px 14px!important;
  border-radius:17px!important;
  overflow:visible!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box .label,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box .label{
  display:block!important;
  font-size:12px!important;
  line-height:1.1!important;
  margin:0 0 8px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box .value,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box .value{
  display:block!important;
  font-size:17px!important;
  line-height:1.15!important;
  margin:0!important;
}
.balance-sticky-wrap .hero-balance-v97 .wallet-stat-v97,
.balance-sticky-wrap .hero-balance-v97 .transfer-inside-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only .wallet-stat-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only .transfer-inside-v97,
.balance-sticky-wrap .hero-transfer-btn,
.balance-sticky-wrap .wallet-transfer-shortcut{
  display:none!important;
}
.wallet-overview-normal,
.month-switch,
.activity-strip,
.card-block{
  width:auto!important;
  max-width:none!important;
  margin-left:var(--v107-x)!important;
  margin-right:var(--v107-x)!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
  padding:0!important;
  margin-top:12px!important;
}
.wallet-overview-normal .wallet-card{
  height:84px!important;
  min-height:84px!important;
  padding:16px 15px!important;
  box-sizing:border-box!important;
  border-radius:18px!important;
  overflow:hidden!important;
}
.wallet-overview-normal .wallet-card span{
  font-size:13px!important;
  line-height:1.1!important;
  margin-bottom:8px!important;
}
.wallet-overview-normal .wallet-card b{
  font-size:22px!important;
  line-height:1.1!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
  width:100%!important;
  height:48px!important;
  min-height:48px!important;
  margin:0!important;
  border-radius:17px!important;
}
.month-switch{
  margin-top:14px!important;
}
@media(max-width:390px){
  .dashboard-shell{
    padding-top:292px!important;
  }
  .header-balance-unified{
    height:282px!important;
    min-height:282px!important;
  }
  .header-balance-unified .top-green,
  .header-balance-unified .top-green-v97{
    height:158px!important;
    min-height:158px!important;
  }
  .balance-sticky-wrap{
    top:104px!important;
  }
  .balance-sticky-wrap .hero-balance,
  .balance-sticky-wrap .hero-balance-v97,
  .balance-sticky-wrap .hero-balance.sticky-balance-only,
  .balance-sticky-wrap .sticky-balance-only{
    min-height:184px!important;
    padding:16px 18px 16px!important;
  }
  .balance-sticky-wrap .hero-balance-v97 h1,
  .balance-sticky-wrap .hero-balance.sticky-balance-only h1{
    font-size:31px!important;
  }
  .balance-sticky-wrap .hero-balance-v97 .stat-box,
  .balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box{
    height:68px!important;
    min-height:68px!important;
    padding:12px!important;
  }
  .balance-sticky-wrap .hero-balance-v97 .stat-box .value,
  .balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box .value{
    font-size:15.5px!important;
  }
  .wallet-overview-normal .wallet-card b{
    font-size:20px!important;
  }
}


/* v108 remove green gap balance wallet */
/*
  Fix screenshot: area hijau kosong di bawah kartu saldo dibuang.
  Header hijau berhenti tepat setelah kartu Saldo Global, lalu Cash/Rekening langsung naik.
*/
:root{
  --v108-x:24px;
  --v108-header-h:500px;
  --v108-card-top:178px;
  --v108-card-h:248px;
}
@media(max-width:390px){
  :root{
    --v108-x:22px;
    --v108-header-h:486px;
    --v108-card-top:168px;
    --v108-card-h:240px;
  }
}
.dashboard-shell{
  padding-top:calc(var(--v108-header-h) + 18px)!important;
}
.header-balance-unified{
  height:var(--v108-header-h)!important;
  min-height:var(--v108-header-h)!important;
  max-height:var(--v108-header-h)!important;
  border-radius:0 0 34px 34px!important;
  overflow:visible!important;
}
.header-balance-unified .top-green,
.header-balance-unified .top-green-v97{
  height:100%!important;
  min-height:100%!important;
  border-radius:0 0 34px 34px!important;
  background:transparent!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  margin-left:var(--v108-x)!important;
  margin-right:var(--v108-x)!important;
  padding-top:18px!important;
}
.balance-sticky-wrap{
  top:var(--v108-card-top)!important;
  left:var(--v108-x)!important;
  right:var(--v108-x)!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only,
.balance-sticky-wrap .sticky-balance-only{
  min-height:var(--v108-card-h)!important;
  height:var(--v108-card-h)!important;
  padding:20px 22px 20px!important;
  border-radius:26px!important;
  overflow:visible!important;
}
.balance-sticky-wrap .hero-balance-v97 h1,
.balance-sticky-wrap .hero-balance.sticky-balance-only h1{
  font-size:34px!important;
  margin:0 0 20px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-row,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-row{
  gap:12px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box{
  height:76px!important;
  min-height:76px!important;
  padding:14px 16px!important;
}
.wallet-overview-normal{
  margin-top:0!important;
}
.wallet-overview-normal,
.month-switch,
.activity-strip,
.card-block{
  margin-left:var(--v108-x)!important;
  margin-right:var(--v108-x)!important;
}
@media(max-width:390px){
  .dashboard-shell{
    padding-top:calc(var(--v108-header-h) + 16px)!important;
  }
  .balance-sticky-wrap .hero-balance,
  .balance-sticky-wrap .hero-balance-v97,
  .balance-sticky-wrap .hero-balance.sticky-balance-only,
  .balance-sticky-wrap .sticky-balance-only{
    padding:18px 20px 18px!important;
  }
  .balance-sticky-wrap .hero-balance-v97 h1,
  .balance-sticky-wrap .hero-balance.sticky-balance-only h1{
    font-size:31px!important;
  }
}


/* v109 restore dashboard initial position */
/*
  Revert posisi dashboard atas:
  - Header tidak fixed lagi.
  - Saldo tidak sticky/fixed lagi.
  - Cash/Rekening/Pindah Saldo kembali mengikuti flow normal.
  - Menghapus efek area hijau kosong dan geser-geser dari v100-v108.
*/
.dashboard-shell{
  position:relative!important;
  width:min(430px,100%)!important;
  max-width:430px!important;
  margin:0 auto!important;
  padding-top:0!important;
  padding-left:0!important;
  padding-right:0!important;
  background:linear-gradient(180deg,#f5fbf7 0%,#ffffff 100%)!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
}
.header-balance-unified{
  position:relative!important;
  top:auto!important;
  left:auto!important;
  right:auto!important;
  transform:none!important;
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  margin:0!important;
  padding:0 14px 14px!important;
  border-radius:0 0 28px 28px!important;
  overflow:visible!important;
  z-index:1!important;
  box-sizing:border-box!important;
}
.header-balance-unified::after{
  display:none!important;
}
.header-balance-unified .top-green,
.header-balance-unified .top-green-v97{
  position:relative!important;
  height:auto!important;
  min-height:0!important;
  margin:0 -14px!important;
  padding:18px 14px 18px!important;
  border-radius:0 0 28px 28px!important;
  overflow:visible!important;
  background:
    radial-gradient(circle at 64% -12%,rgba(255,255,255,.16) 0,rgba(255,255,255,.11) 18%,transparent 40%),
    radial-gradient(circle at 113% 62%,rgba(22,185,116,.42),transparent 34%),
    linear-gradient(150deg,#00583a 0%,#007a4d 48%,#009e63 100%)!important;
}
.header-balance-unified .app-topbar,
.header-balance-unified .app-topbar-v97{
  width:auto!important;
  height:auto!important;
  margin:0!important;
  padding:0!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap{
  position:relative!important;
  top:auto!important;
  left:auto!important;
  right:auto!important;
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  margin:14px 0 0!important;
  padding:0!important;
  z-index:2!important;
  transform:none!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap .hero-balance,
.balance-sticky-wrap .hero-balance-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only,
.balance-sticky-wrap .sticky-balance-only{
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  min-height:0!important;
  margin:0!important;
  padding:14px!important;
  border-radius:18px!important;
  box-sizing:border-box!important;
  overflow:visible!important;
  box-shadow:0 12px 28px rgba(0,50,31,.10)!important;
  background:#fff!important;
}
.balance-sticky-wrap .wallet-illustration-v97{
  display:none!important;
}
.balance-sticky-wrap .balance-health-v97{
  display:flex!important;
  margin-bottom:10px!important;
}
.balance-sticky-wrap .hero-balance-v97 h1,
.balance-sticky-wrap .hero-balance.sticky-balance-only h1{
  font-size:27px!important;
  line-height:1.05!important;
  margin:6px 0 9px!important;
}
.balance-sticky-wrap .hero-balance-v97 small,
.balance-sticky-wrap .hero-balance.sticky-balance-only small{
  font-size:12px!important;
  margin:0 0 4px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-row,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
  margin:0!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box{
  height:auto!important;
  min-height:58px!important;
  padding:9px 10px!important;
  border-radius:13px!important;
  background:#fff!important;
  border:1px solid #e6eeea!important;
  box-sizing:border-box!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-icon-v97{
  display:none!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box .label,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box .label{
  font-size:10px!important;
  line-height:1.2!important;
  margin:0 0 4px!important;
}
.balance-sticky-wrap .hero-balance-v97 .stat-box .value,
.balance-sticky-wrap .hero-balance.sticky-balance-only .stat-box .value{
  font-size:11.5px!important;
  line-height:1.2!important;
  margin:0!important;
}
.balance-sticky-wrap .hero-balance-v97 .wallet-stat-v97,
.balance-sticky-wrap .hero-balance-v97 .transfer-inside-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only .wallet-stat-v97,
.balance-sticky-wrap .hero-balance.sticky-balance-only .transfer-inside-v97{
  display:none!important;
}
.wallet-overview-normal,
.month-switch,
.activity-strip,
.card-block{
  width:auto!important;
  max-width:none!important;
  margin-left:14px!important;
  margin-right:14px!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
  padding:0!important;
  margin-top:12px!important;
}
.wallet-overview-normal .wallet-card{
  height:auto!important;
  min-height:62px!important;
  padding:12px!important;
  border-radius:16px!important;
  background:#fff!important;
  border:1px solid #e6eeea!important;
  box-sizing:border-box!important;
}
.wallet-overview-normal .wallet-card span{
  font-size:11px!important;
  margin-bottom:4px!important;
}
.wallet-overview-normal .wallet-card b{
  font-size:14px!important;
  line-height:1.2!important;
}
.wallet-overview-normal .wallet-transfer-shortcut{
  grid-column:1 / -1!important;
  width:100%!important;
  height:40px!important;
  min-height:40px!important;
  margin:0!important;
  border-radius:14px!important;
  box-sizing:border-box!important;
}
.month-switch{
  margin-top:12px!important;
}
@media(max-width:430px){
  .dashboard-shell{
    width:100%!important;
    max-width:100%!important;
  }
  .header-balance-unified{
    padding-left:14px!important;
    padding-right:14px!important;
  }
}


/* v110 remove green background behind catat nav */
/* Samakan tombol Catat bawah dengan item nav lain, tanpa lingkaran hijau. */
.bottom-nav .nav-plus,
.bottom-nav .plus-btn,
.bottom-nav [data-tab-target="catat"].nav-item{
  width:auto!important;
  height:auto!important;
  min-width:0!important;
  min-height:0!important;
  border-radius:0!important;
  background:transparent!important;
  background-image:none!important;
  box-shadow:none!important;
  color:#667381!important;
  padding:0!important;
}
.bottom-nav [data-tab-target="catat"].nav-item.active,
.bottom-nav [data-tab-target="catat"].nav-item.active-trigger{
  color:#007a4d!important;
}
.bottom-nav [data-tab-target="catat"].nav-item svg,
.bottom-nav .nav-plus svg,
.bottom-nav .plus-btn svg{
  width:22px!important;
  height:22px!important;
  stroke:currentColor!important;
  fill:none!important;
}


/* v113 white neon palette from SaaS template */
:root{
  --neo-bg:#f7f8fb;
  --neo-card:#ffffff;
  --neo-ink:#111827;
  --neo-muted:#6b7280;
  --neo-line:rgba(17,24,39,.075);
  --neo-purple:#b26cff;
  --neo-cyan:#00d8ff;
  --neo-yellow:#ffbf00;
  --neo-blue:#758bff;
  --neo-pink:#ff5d8f;
  --neo-orange:#ff8a00;
  --neo-teal:#00d6bd;
  --neo-green:#009b62;
  --neo-shadow:0 16px 34px rgba(15,23,42,.075);
}
body.app-body,
.single-dashboard,
.dashboard-shell{
  background:
    radial-gradient(circle at 12% 8%, rgba(178,108,255,.09), transparent 26%),
    radial-gradient(circle at 88% 18%, rgba(0,216,255,.10), transparent 26%),
    linear-gradient(180deg,#fbfcff 0%,#f6f9fb 44%,#ffffff 100%)!important;
}
.card-block,
.month-switch,
.wallet-card,
.stat-box,
.tx-item,
.member-profile-row-v78,
.referral-card-v94,
.auth-card,
.card{
  background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(255,255,255,.91))!important;
  border:1px solid var(--neo-line)!important;
  box-shadow:var(--neo-shadow)!important;
}
.card-head{
  color:var(--neo-ink)!important;
  letter-spacing:.025em!important;
}
.header-balance-unified .top-green,
.header-balance-unified .top-green-v97,
.auth-top,
.page .top{
  background:
    radial-gradient(circle at 14% 12%,rgba(178,108,255,.14),transparent 32%),
    radial-gradient(circle at 88% 20%,rgba(0,216,255,.17),transparent 32%),
    linear-gradient(150deg,#004b37 0%,#007a4d 52%,#00a86a 100%)!important;
}
.hero-balance,
.hero-balance-v97,
.hero-balance.sticky-balance-only{
  background:
    radial-gradient(circle at 96% 0%,rgba(178,108,255,.10),transparent 28%),
    linear-gradient(180deg,#ffffff 0%,#fbfffd 100%)!important;
  border:1px solid rgba(0,216,189,.13)!important;
  box-shadow:0 18px 38px rgba(15,23,42,.10)!important;
}
.hero-balance:before,
.hero-balance-v97:before{
  content:""!important;
  position:absolute!important;
  left:0!important;
  top:28px!important;
  width:6px!important;
  height:54px!important;
  border-radius:0 12px 12px 0!important;
  background:linear-gradient(180deg,var(--neo-orange),var(--neo-pink))!important;
}
.hero-balance .stat-box:nth-child(1) .label:before,
.stat-income-v97 .label:before{
  content:"";
  display:inline-block;
  width:8px;height:8px;margin-right:7px;border-radius:999px;
  background:var(--neo-teal);
}
.hero-balance .stat-box:nth-child(2) .label:before,
.stat-expense-v97 .label:before{
  content:"";
  display:inline-block;
  width:8px;height:8px;margin-right:7px;border-radius:999px;
  background:var(--neo-pink);
}
.quick-grid{gap:8px!important}
.quick-item{background:transparent!important;border:0!important;box-shadow:none!important}
.quick-icon{
  background:#fff!important;
  border:1px solid rgba(17,24,39,.06)!important;
  box-shadow:0 10px 22px rgba(15,23,42,.06)!important;
}
.quick-item:nth-child(1) .quick-icon{color:var(--neo-green)!important;background:linear-gradient(180deg,rgba(0,214,189,.12),#fff)!important}
.quick-item:nth-child(2) .quick-icon{color:var(--neo-cyan)!important;background:linear-gradient(180deg,rgba(0,216,255,.12),#fff)!important}
.quick-item:nth-child(3) .quick-icon{color:var(--neo-orange)!important;background:linear-gradient(180deg,rgba(255,138,0,.13),#fff)!important}
.quick-item:nth-child(4) .quick-icon{color:var(--neo-blue)!important;background:linear-gradient(180deg,rgba(117,139,255,.13),#fff)!important}
.quick-item:nth-child(5) .quick-icon{color:var(--neo-purple)!important;background:linear-gradient(180deg,rgba(178,108,255,.14),#fff)!important}
.quick-item:nth-child(6) .quick-icon{color:var(--neo-yellow)!important;background:linear-gradient(180deg,rgba(255,191,0,.14),#fff)!important}
.quick-icon svg{stroke:currentColor!important}
.quick-item span{color:var(--neo-ink)!important}
.bottom-nav{
  background:rgba(255,255,255,.94)!important;
  border:1px solid rgba(17,24,39,.08)!important;
  box-shadow:0 -16px 36px rgba(15,23,42,.10)!important;
}
.bottom-nav .nav-item{color:#6b7280!important}
.bottom-nav .nav-item.active,
.bottom-nav .nav-item.active-trigger{color:var(--neo-green)!important}
.bottom-nav [data-tab-target="catat"].nav-item,
.bottom-nav .nav-plus,
.bottom-nav .plus-btn{
  background:transparent!important;
  background-image:none!important;
  color:#6b7280!important;
  box-shadow:none!important;
  border-radius:0!important;
}
.referral-hero-v94{
  background:
    radial-gradient(circle at 10% 0%,rgba(178,108,255,.13),transparent 34%),
    radial-gradient(circle at 90% 0%,rgba(0,216,255,.14),transparent 34%),
    linear-gradient(180deg,#fff,#fbfffd)!important;
  border:1px solid rgba(0,216,189,.14)!important;
}
.referral-hero-v94 b{color:var(--neo-purple)!important}
.referral-link-v94 button,
.referral-withdraw-v94,
.pretty-submit,
.btn-primary,
.auth-submit{
  background:linear-gradient(135deg,var(--neo-green),var(--neo-teal))!important;
  color:#fff!important;
}
.referral-share-btn-v94,
.wallet-transfer-shortcut,
.btn-secondary,
.profile-actions a,
.profile-actions button{
  background:linear-gradient(180deg,#fff 0%,#f7fffd 100%)!important;
  color:var(--neo-green)!important;
  border:1px solid rgba(0,214,189,.16)!important;
}
.tx-amount.expense{color:#ff5d3d!important}
.tx-amount.income{color:var(--neo-green)!important}


/* v114 upgrade popup wa */
.upgrade-card-v114{
  text-align:center!important;
  background:
    radial-gradient(circle at 20% 0%,rgba(178,108,255,.13),transparent 36%),
    radial-gradient(circle at 92% 0%,rgba(0,216,255,.13),transparent 34%),
    linear-gradient(180deg,#fff,#fbfffd)!important;
}
.upgrade-icon-v114{
  width:54px;
  height:54px;
  margin:2px auto 10px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(180deg,rgba(178,108,255,.16),rgba(0,216,255,.10));
  font-size:27px;
}
.upgrade-card-v114 h3{
  margin:0 0 8px!important;
  font-size:20px!important;
  color:#111827!important;
  letter-spacing:-.035em!important;
}
.upgrade-card-v114 p{
  margin:0 auto 12px!important;
  max-width:330px;
  color:#667381!important;
  font-size:12.5px!important;
  line-height:1.55!important;
}
.upgrade-benefits-v114{
  display:grid;
  gap:7px;
  margin:10px 0 12px;
}
.upgrade-benefits-v114 span{
  display:block;
  padding:9px 10px;
  border-radius:14px;
  background:#f7fffd;
  border:1px solid rgba(0,214,189,.16);
  color:#007a4d;
  font-size:11.5px;
  font-weight:850;
}
.upgrade-wa-v114,
.upgrade-later-v114{
  width:100%;
  min-height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  font-size:12.5px;
  font-weight:900;
  text-decoration:none;
}
.upgrade-wa-v114{
  background:linear-gradient(135deg,#009b62,#00d6bd);
  color:#fff!important;
  border:0;
  box-shadow:0 12px 26px rgba(0,155,98,.20);
}
.upgrade-later-v114{
  margin-top:8px;
  border:1px solid rgba(17,24,39,.08);
  background:#fff;
  color:#667381;
}


/* v117 upgrade request only after wa */


/* v120 white wallet ornaments and compact forms */
.wallet-overview,
.wallet-overview-normal,
.hero-wallet-mini{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.wallet-card,
.hero-wallet-mini .wallet-card,
.wallet-card-v97{
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 10px 22px rgba(15,23,42,.055)!important;
  color:#111827!important;
}
.wallet-card:before,
.wallet-card:after,
.hero-wallet-mini:before,
.hero-wallet-mini:after,
.wallet-overview:before,
.wallet-overview:after,
.wallet-overview-normal:before,
.wallet-overview-normal:after{
  display:none!important;
  content:none!important;
}
.wallet-card span,
.wallet-card small,
.wallet-transfer-shortcut small{
  color:#667381!important;
}
.wallet-card b{
  color:#111827!important;
}
.wallet-transfer-shortcut,
.hero-transfer-btn,
.wallet-transfer-shortcut-v97{
  background:#ffffff!important;
  background-image:none!important;
  color:#111827!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 10px 22px rgba(15,23,42,.055)!important;
}
.wallet-transfer-shortcut svg,
.hero-transfer-btn svg{
  stroke:#111827!important;
}
:root{
  --neo-orange:#ffffff!important;
}
.auth-form,
.form-stack,
.pretty-form,
.owner-form,
.cb-form,
.modal-form,
.profile-form{
  gap:8px!important;
}
.auth-form .field,
.form-stack .field,
.pretty-form .field,
.cb-form .field,
.modal-form .field{
  margin-bottom:8px!important;
}
.auth-form label,
.form-stack label,
.pretty-form label,
.owner-form label,
.cb-form label,
.modal-form label{
  margin-bottom:4px!important;
  font-size:11px!important;
  font-weight:850!important;
  color:#38443f!important;
}
input,
select,
textarea,
.field-control,
.auth-form input,
.auth-form select,
.auth-form textarea,
.form-stack input,
.form-stack select,
.form-stack textarea,
.pretty-form input,
.pretty-form select,
.pretty-form textarea,
.owner-form input,
.owner-form select,
.owner-form textarea,
.cb-form input,
.cb-form select,
.cb-form textarea,
.modal-form input,
.modal-form select,
.modal-form textarea{
  min-height:40px!important;
  border-radius:12px!important;
  border:1px solid rgba(17,24,39,.09)!important;
  background:#fff!important;
  box-shadow:none!important;
  font-size:13px!important;
}
textarea{
  min-height:72px!important;
  padding-top:10px!important;
}
.field-control{
  padding:0!important;
}
.field-control input{
  border:0!important;
}
.field-icon{
  width:34px!important;
  font-size:14px!important;
}
.pass-toggle{
  height:30px!important;
  min-height:30px!important;
  padding:0 10px!important;
  border-radius:10px!important;
  font-size:11px!important;
}
.pretty-submit,
.auth-submit,
.btn-primary,
.form-stack button,
.owner-form button{
  min-height:40px!important;
  border-radius:12px!important;
  font-size:12.5px!important;
  box-shadow:none!important;
}
.cb-modal-card,
.modal-card,
.bottom-sheet,
.auth-card,
.owner-card{
  border-radius:18px!important;
}
.cb-modal-card{
  padding:14px!important;
}


/* v121 force referral visible in profile */
.dash-panel[data-panel="profil"] .referral-card-v94{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  margin-top:12px!important;
}
.profile-referral-jump-v121{
  background:#ffffff!important;
  color:#007a4d!important;
  border:1px solid rgba(0,122,77,.16)!important;
}
.referral-setup-warning-v121{
  margin:0 0 10px!important;
  padding:10px 12px!important;
  border-radius:14px!important;
  background:#fff8e6!important;
  border:1px solid rgba(255,191,0,.35)!important;
  color:#7a5200!important;
  font-size:12px!important;
  line-height:1.45!important;
  font-weight:800!important;
}
.referral-card-v94 input{
  min-height:40px!important;
}


/* v122 referral profile data view */
.referral-card-old-v122{
  display:none!important;
}
.referral-profile-data-v122{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  margin-top:12px!important;
  background:#ffffff!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 14px 30px rgba(15,23,42,.06)!important;
}
.referral-profile-head-v122{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:12px;
}
.referral-profile-head-v122 small{
  display:block;
  color:#007a4d;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.referral-profile-head-v122 h3{
  margin:4px 0 4px;
  font-size:18px;
  color:#111827;
  letter-spacing:-.04em;
}
.referral-profile-head-v122 p{
  margin:0;
  color:#667381;
  font-size:12px;
  line-height:1.45;
}
.referral-profile-head-v122 span{
  width:44px;
  height:44px;
  flex:0 0 44px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:#f5fbf8;
  border:1px solid rgba(0,122,77,.09);
  font-size:23px;
}
.referral-info-grid-v122,
.referral-status-v122{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:10px 0;
}
.referral-info-grid-v122 div,
.referral-status-v122 div{
  background:#fbfdfc;
  border:1px solid rgba(17,24,39,.065);
  border-radius:14px;
  padding:10px;
}
.referral-info-grid-v122 small,
.referral-status-v122 small{
  display:block;
  color:#667381;
  font-size:10px;
  font-weight:850;
  margin-bottom:4px;
}
.referral-info-grid-v122 b,
.referral-status-v122 b{
  display:block;
  color:#111827;
  font-size:14px;
  line-height:1.15;
}
.referral-label-v122{
  display:block;
  margin:12px 0 6px;
  color:#38443f;
  font-size:11px;
  font-weight:900;
}
.referral-link-v122{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
}
.referral-link-v122 input{
  width:100%;
  min-width:0;
  min-height:40px!important;
  border-radius:12px!important;
  border:1px solid rgba(17,24,39,.08)!important;
  padding:0 10px!important;
  background:#fff!important;
  font-size:11.5px!important;
}
.referral-link-v122 button,
.referral-actions-v122 button,
.referral-actions-v122 a{
  min-height:40px;
  border-radius:12px;
  border:0;
  padding:0 12px;
  display:grid;
  place-items:center;
  text-decoration:none;
  font-size:12px;
  font-weight:900;
}
.referral-link-v122 button,
.referral-actions-v122 button{
  background:#007a4d;
  color:#fff;
}
.referral-actions-v122{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin:8px 0 10px;
}
.referral-actions-v122 a{
  background:#f5fbf8;
  color:#007a4d;
  border:1px solid rgba(0,122,77,.12);
}
.referral-actions-v122 span{
  min-height:40px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:#f7f8fb;
  color:#667381;
  border:1px solid rgba(17,24,39,.06);
  font-size:12px;
  font-weight:850;
}
.referral-latest-v122,
.referral-empty-v122,
.referral-rules-v122{
  margin-top:10px;
  border-radius:14px;
  background:#fbfdfc;
  border:1px solid rgba(17,24,39,.065);
  padding:10px;
}
.referral-latest-v122 > b,
.referral-rules-v122 > b{
  display:block;
  margin-bottom:8px;
  font-size:12px;
  color:#111827;
}
.referral-latest-v122 div{
  display:flex;
  justify-content:space-between;
  gap:8px;
  padding:7px 0;
  border-top:1px solid rgba(17,24,39,.055);
  font-size:11.5px;
}
.referral-latest-v122 span{
  color:#111827;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.referral-latest-v122 em{
  color:#667381;
  font-style:normal;
  white-space:nowrap;
}
.referral-empty-v122{
  color:#667381;
  font-size:12px;
  line-height:1.45;
}
.referral-rules-v122 ul{
  margin:0;
  padding-left:17px;
  color:#667381;
  font-size:11.5px;
  line-height:1.55;
}
.referral-rules-v122 li{
  margin:3px 0;
}
@media(max-width:370px){
  .referral-info-grid-v122,
  .referral-status-v122,
  .referral-actions-v122{
    grid-template-columns:1fr;
  }
}


/* v124 referral inside profile top - tampil langsung di kartu profil */
.profile-referral-inline-v124{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  width:100%!important;
  margin:12px 0!important;
  padding:12px!important;
  border-radius:18px!important;
  background:#ffffff!important;
  border:1px solid rgba(0,122,77,.14)!important;
  box-shadow:0 12px 28px rgba(15,23,42,.065)!important;
  text-align:left!important;
}
.profile-referral-title-v124{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  margin-bottom:10px!important;
}
.profile-referral-title-v124 > span{
  width:42px!important;
  height:42px!important;
  border-radius:15px!important;
  display:grid!important;
  place-items:center!important;
  background:#f5fbf8!important;
  border:1px solid rgba(0,122,77,.12)!important;
  font-size:22px!important;
  flex:0 0 42px!important;
}
.profile-referral-title-v124 b{
  display:block!important;
  color:#111827!important;
  font-size:15px!important;
  line-height:1.15!important;
}
.profile-referral-title-v124 small,
.profile-referral-info-v124 small,
.profile-referral-actions-v124 em{
  display:block!important;
  color:#667381!important;
  font-size:11.5px!important;
  line-height:1.45!important;
  font-style:normal!important;
}
.profile-referral-link-v124{
  display:grid!important;
  grid-template-columns:1fr auto!important;
  gap:8px!important;
  margin:8px 0!important;
}
.profile-referral-link-v124 input{
  min-width:0!important;
  width:100%!important;
  min-height:39px!important;
  border-radius:12px!important;
  border:1px solid rgba(17,24,39,.08)!important;
  background:#fff!important;
  color:#111827!important;
  padding:0 10px!important;
  font-size:11.5px!important;
}
.profile-referral-link-v124 button,
.profile-referral-actions-v124 button,
.profile-referral-actions-v124 a{
  min-height:39px!important;
  border-radius:12px!important;
  border:0!important;
  padding:0 12px!important;
  display:grid!important;
  place-items:center!important;
  background:#007a4d!important;
  color:#fff!important;
  text-decoration:none!important;
  font-size:12px!important;
  font-weight:900!important;
}
.profile-referral-stats-v124{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:7px!important;
  margin:8px 0!important;
}
.profile-referral-stats-v124 div{
  border-radius:13px!important;
  background:#fbfdfc!important;
  border:1px solid rgba(17,24,39,.06)!important;
  padding:8px!important;
}
.profile-referral-stats-v124 small{
  display:block!important;
  color:#667381!important;
  font-size:9.5px!important;
  margin-bottom:3px!important;
}
.profile-referral-stats-v124 b{
  display:block!important;
  color:#111827!important;
  font-size:12px!important;
  line-height:1.2!important;
}
.profile-referral-actions-v124{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  align-items:center!important;
  margin:8px 0!important;
}
.profile-referral-actions-v124 em{
  min-height:39px!important;
  border-radius:12px!important;
  display:grid!important;
  place-items:center!important;
  padding:0 9px!important;
  background:#f7f8fb!important;
  border:1px solid rgba(17,24,39,.06)!important;
  text-align:center!important;
}
.profile-referral-info-v124{
  padding:9px!important;
  border-radius:13px!important;
  background:#f5fbf8!important;
  border:1px solid rgba(0,122,77,.1)!important;
}
.profile-referral-info-v124 b{
  display:block!important;
  margin-bottom:4px!important;
  color:#007a4d!important;
  font-size:12px!important;
}
.profile-referral-history-v124{
  margin-top:8px!important;
  border-radius:13px!important;
  background:#fbfdfc!important;
  border:1px solid rgba(17,24,39,.06)!important;
  padding:9px!important;
}
.profile-referral-history-v124 > b{
  display:block!important;
  margin-bottom:6px!important;
  font-size:12px!important;
}
.profile-referral-history-v124 div{
  display:flex!important;
  justify-content:space-between!important;
  gap:8px!important;
  padding:5px 0!important;
  border-top:1px solid rgba(17,24,39,.055)!important;
}
.profile-referral-history-v124 span{
  color:#111827!important;
  font-size:11.5px!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.profile-referral-history-v124 small{
  color:#667381!important;
  font-size:11px!important;
  white-space:nowrap!important;
}
@media(max-width:370px){
  .profile-referral-stats-v124,
  .profile-referral-actions-v124{
    grid-template-columns:1fr!important;
  }
}


/* v126 profile actions wallet white home clean */
/* Tombol profil dibuat berjejer dan tombol Referal Saya dihapus dari view. */
.profile-actions{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:7px!important;
  margin-top:12px!important;
}
.profile-actions a,
.profile-actions button{
  width:100%!important;
  min-width:0!important;
  min-height:38px!important;
  border-radius:12px!important;
  padding:0 8px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  line-height:1.15!important;
  font-size:11px!important;
  font-weight:850!important;
  text-decoration:none!important;
  white-space:normal!important;
  border:1px solid rgba(17,24,39,.08)!important;
  background:#ffffff!important;
  color:#143b2d!important;
  box-shadow:0 8px 18px rgba(15,23,42,.045)!important;
}
.profile-actions .profile-password-btn-v83,
.profile-actions .profile-password-btn-v86{
  background:#ffffff!important;
  color:#143b2d!important;
}
.profile-actions a.logout-profile{
  background:#fff!important;
  color:#b4483a!important;
  border:1px solid rgba(180,72,58,.18)!important;
}
.profile-referral-jump-v121{
  display:none!important;
}

/* Dompet/cash/rekening dibuat putih bersih. */
.wallet-overview,
.wallet-overview-normal,
.hero-wallet-mini,
.stat-row-v97{
  background:transparent!important;
  background-image:none!important;
}
.wallet-card,
.wallet-stat-v97,
.wallet-cash-v97,
.wallet-bank-v97,
.hero-wallet-mini .wallet-card,
.stat-row-v97 .wallet-stat-v97{
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(17,24,39,.075)!important;
  color:#111827!important;
  box-shadow:0 10px 22px rgba(15,23,42,.055)!important;
}
.wallet-card:before,
.wallet-card:after,
.wallet-stat-v97:before,
.wallet-stat-v97:after,
.wallet-cash-v97:before,
.wallet-cash-v97:after,
.wallet-bank-v97:before,
.wallet-bank-v97:after{
  display:none!important;
  content:none!important;
}
.wallet-card span,
.wallet-card small,
.wallet-stat-v97 .label,
.wallet-cash-v97 .label,
.wallet-bank-v97 .label{
  color:#667381!important;
}
.wallet-card b,
.wallet-stat-v97 .value,
.wallet-cash-v97 .value,
.wallet-bank-v97 .value{
  color:#111827!important;
}
.wallet-stat-v97 .stat-icon-v97,
.wallet-cash-v97 .stat-icon-v97,
.wallet-bank-v97 .stat-icon-v97{
  background:#f7f8fb!important;
  color:#111827!important;
  border:1px solid rgba(17,24,39,.06)!important;
}
.wallet-transfer-shortcut,
.transfer-inside-v97,
.hero-transfer-btn,
.wallet-transfer-shortcut-v97{
  background:#ffffff!important;
  background-image:none!important;
  color:#111827!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 10px 22px rgba(15,23,42,.055)!important;
}
.wallet-transfer-shortcut:before,
.wallet-transfer-shortcut:after,
.transfer-inside-v97:before,
.transfer-inside-v97:after{
  display:none!important;
  content:none!important;
}

/* Pastikan card transaksi bulan ini tidak muncul di beranda jika sisa cache lama masih ada. */
.dash-panel[data-panel="beranda"] .card-block:has(.card-head){
  /* harmless; actual removal done in view */
}

@media(max-width:360px){
  .profile-actions{
    gap:6px!important;
  }
  .profile-actions a,
  .profile-actions button{
    font-size:10px!important;
    padding:0 5px!important;
  }
}


/* v127 easy privacy language landing auth */
.auth-privacy-note-v127{
  margin:0 0 13px!important;
  padding:11px 12px!important;
  border-radius:16px!important;
  background:#f5fbf8!important;
  border:1px solid rgba(0,122,77,.14)!important;
  color:#456051!important;
  font-size:11.5px!important;
  line-height:1.55!important;
}
.auth-privacy-note-v127 b{
  display:block!important;
  color:#173f30!important;
  margin-bottom:3px!important;
}
.landing-privacy-v127 .story-item{
  background:#ffffff!important;
}
.landing-privacy-v127 .story-item b{
  color:#173f30!important;
}


/* v128 category icon picker and category grid transaction */
.category-icon-picker-v128{
  display:grid!important;
  grid-template-columns:repeat(6,1fr)!important;
  gap:7px!important;
}
.category-icon-picker-v128 label{
  margin:0!important;
  cursor:pointer!important;
}
.category-icon-picker-v128 input{
  position:absolute!important;
  opacity:0!important;
  pointer-events:none!important;
}
.category-icon-picker-v128 span{
  height:38px!important;
  border-radius:13px!important;
  display:grid!important;
  place-items:center!important;
  background:#fff!important;
  border:1px solid rgba(17,24,39,.08)!important;
  font-size:19px!important;
  box-shadow:0 6px 14px rgba(15,23,42,.035)!important;
}
.category-icon-picker-v128 input:checked + span{
  border-color:#007a4d!important;
  background:#f5fbf8!important;
  box-shadow:0 0 0 3px rgba(0,122,77,.08)!important;
}
.category-grid-select-v128{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:8px!important;
}
.category-grid-item-v128{
  margin:0!important;
  cursor:pointer!important;
}
.category-grid-item-v128 input{
  position:absolute!important;
  opacity:0!important;
  pointer-events:none!important;
}
.category-grid-item-v128 span{
  min-height:72px!important;
  border-radius:16px!important;
  padding:9px 7px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:5px!important;
  text-align:center!important;
  background:#fff!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 8px 18px rgba(15,23,42,.045)!important;
}
.category-grid-item-v128 i{
  font-style:normal!important;
  font-size:22px!important;
  line-height:1!important;
}
.category-grid-item-v128 b{
  display:block!important;
  width:100%!important;
  color:#111827!important;
  font-size:10.5px!important;
  line-height:1.2!important;
  font-weight:850!important;
  white-space:normal!important;
  overflow:hidden!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
}
.category-grid-item-v128 input:checked + span{
  border-color:#007a4d!important;
  background:#f5fbf8!important;
  box-shadow:0 0 0 3px rgba(0,122,77,.08),0 8px 18px rgba(15,23,42,.045)!important;
}
.category-grid-item-v128.income input:checked + span{
  border-color:#007a4d!important;
}
.category-grid-item-v128.expense input:checked + span{
  border-color:#b4483a!important;
  background:#fff8f6!important;
  box-shadow:0 0 0 3px rgba(180,72,58,.07),0 8px 18px rgba(15,23,42,.045)!important;
}
.edit-category-grid-v128{
  max-height:240px!important;
  overflow:auto!important;
  padding-right:2px!important;
}
.form-stack select,
.js-dashboard-form select{
  min-height:42px!important;
  border-radius:12px!important;
  border:1px solid rgba(17,24,39,.09)!important;
  background:#fff!important;
  padding:0 12px!important;
  color:#111827!important;
  font-size:13px!important;
}
@media(max-width:370px){
  .category-grid-select-v128{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .category-icon-picker-v128{
    grid-template-columns:repeat(5,1fr)!important;
  }
}


/* v129 compact white balance home */
.single-dashboard .dash-top,
.dash-top,
.dashboard-header-v97,
.hero-header-v97{
  background:#ffffff!important;
  background-image:none!important;
  border-radius:0 0 18px 18px!important;
  color:#111827!important;
  padding:12px 12px 10px!important;
  box-shadow:0 8px 20px rgba(15,23,42,.045)!important;
}
.dash-greeting,
.dash-greeting h1,
.dash-greeting h2,
.dash-top h1,
.dash-top h2,
.dashboard-header-v97 h1,
.hero-header-v97 h1{
  color:#111827!important;
}
.dash-greeting small,
.dash-greeting p,
.dash-top p,
.dashboard-header-v97 p,
.hero-header-v97 p{
  color:#667381!important;
}
.header-action,
.header-icon,
.dash-top .icon-btn,
.dashboard-header-v97 .icon-btn,
.hero-header-v97 .icon-btn{
  background:#f7f8fb!important;
  color:#111827!important;
  border:1px solid rgba(17,24,39,.07)!important;
  box-shadow:none!important;
}
.balance-card,
.balance-card-v97,
.hero-balance-v97,
.global-balance-card,
.single-dashboard .balance-card{
  margin:8px 0 0!important;
  padding:12px 14px!important;
  border-radius:18px!important;
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 10px 24px rgba(15,23,42,.06)!important;
  color:#111827!important;
}
.balance-card:before,
.balance-card:after,
.balance-card-v97:before,
.balance-card-v97:after,
.hero-balance-v97:before,
.hero-balance-v97:after,
.global-balance-card:before,
.global-balance-card:after{
  display:none!important;
  content:none!important;
}
.balance-card small,
.balance-card-v97 small,
.hero-balance-v97 small,
.global-balance-card small{
  color:#7a4b18!important;
  font-size:11px!important;
}
.balance-card h1,
.balance-card-v97 h1,
.hero-balance-v97 h1,
.global-balance-card h1{
  font-size:25px!important;
  line-height:1.05!important;
  margin:5px 0 8px!important;
  letter-spacing:-.055em!important;
  color:#082f2d!important;
}
.balance-health-v97{
  min-height:24px!important;
  gap:7px!important;
  margin:4px 0 8px!important;
}
.balance-health-v97 b{
  min-height:23px!important;
  padding:0 10px!important;
  border-radius:999px!important;
  font-size:10px!important;
  background:#eafaf1!important;
  color:#087a4d!important;
}
.balance-health-v97 span{
  font-size:10.5px!important;
  color:#667381!important;
}
.stat-row,
.stat-row-v97{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  margin-top:8px!important;
}
.stat-box,
.stat-income-v97,
.stat-expense-v97{
  min-height:58px!important;
  padding:9px 10px!important;
  border-radius:14px!important;
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:none!important;
}
.stat-box .label,
.stat-income-v97 .label,
.stat-expense-v97 .label{
  font-size:9.5px!important;
  color:#667381!important;
  letter-spacing:.04em!important;
}
.stat-box .value,
.stat-income-v97 .value,
.stat-expense-v97 .value{
  font-size:12px!important;
  line-height:1.15!important;
  margin-top:3px!important;
  color:#111827!important;
}
.stat-icon-v97{
  width:8px!important;
  height:8px!important;
  min-width:8px!important;
  border-radius:999px!important;
  font-size:0!important;
  padding:0!important;
  margin-bottom:4px!important;
}
.wallet-overview,
.wallet-overview-normal{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  margin:8px 12px 8px!important;
}
.wallet-card{
  min-height:56px!important;
  padding:10px 12px!important;
  border-radius:15px!important;
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 8px 18px rgba(15,23,42,.045)!important;
}
.wallet-card span{
  font-size:10px!important;
  color:#7a4b18!important;
}
.wallet-card b{
  margin-top:4px!important;
  font-size:14px!important;
  color:#082f2d!important;
}
.wallet-transfer-shortcut,
.transfer-inside-v97{
  grid-column:1 / -1!important;
  min-height:42px!important;
  border-radius:14px!important;
  padding:0 10px!important;
  margin:0!important;
  background:#ffffff!important;
  background-image:none!important;
  color:#082f2d!important;
  border:1px solid rgba(17,24,39,.075)!important;
  box-shadow:0 8px 18px rgba(15,23,42,.045)!important;
  font-size:13px!important;
}
.transfer-inside-v97{
  margin-top:8px!important;
}
@media(max-width:390px){
  .single-dashboard .dash-top,
  .dash-top,
  .dashboard-header-v97,
  .hero-header-v97{
    padding:10px 10px 8px!important;
  }
  .balance-card h1,
  .balance-card-v97 h1,
  .hero-balance-v97 h1,
  .global-balance-card h1{
    font-size:23px!important;
  }
  .wallet-overview,
  .wallet-overview-normal{
    margin-left:10px!important;
    margin-right:10px!important;
  }
}


/* v130 fixed saldo global on scroll */
.dash-panel[data-panel="beranda"].active .balance-card,
.dash-panel[data-panel="beranda"].active .balance-card-v97,
.dash-panel[data-panel="beranda"].active .hero-balance-v97,
.dash-panel[data-panel="beranda"].active .global-balance-card,
.dash-panel[data-panel="beranda"].active .single-dashboard .balance-card{
  position:sticky!important;
  top:8px!important;
  z-index:80!important;
  margin-top:6px!important;
  margin-bottom:8px!important;
  border-radius:16px!important;
  background:#ffffff!important;
  box-shadow:0 12px 26px rgba(15,23,42,.12)!important;
  border:1px solid rgba(17,24,39,.08)!important;
}

/* Saat sticky, ukuran saldo global dibuat lebih ringkas. */
.dash-panel[data-panel="beranda"].active .balance-card h1,
.dash-panel[data-panel="beranda"].active .balance-card-v97 h1,
.dash-panel[data-panel="beranda"].active .hero-balance-v97 h1,
.dash-panel[data-panel="beranda"].active .global-balance-card h1{
  font-size:22px!important;
  line-height:1.05!important;
  margin:4px 0 6px!important;
}

.dash-panel[data-panel="beranda"].active .balance-card small,
.dash-panel[data-panel="beranda"].active .balance-card-v97 small,
.dash-panel[data-panel="beranda"].active .hero-balance-v97 small,
.dash-panel[data-panel="beranda"].active .global-balance-card small{
  font-size:10px!important;
}

.dash-panel[data-panel="beranda"].active .balance-health-v97{
  margin:2px 0 6px!important;
}

.dash-panel[data-panel="beranda"].active .balance-health-v97 b{
  min-height:20px!important;
  padding:0 8px!important;
  font-size:9px!important;
}

.dash-panel[data-panel="beranda"].active .balance-health-v97 span{
  font-size:9.5px!important;
}

.dash-panel[data-panel="beranda"].active .stat-row-v97,
.dash-panel[data-panel="beranda"].active .stat-row{
  gap:6px!important;
  margin-top:6px!important;
}

.dash-panel[data-panel="beranda"].active .stat-box,
.dash-panel[data-panel="beranda"].active .stat-income-v97,
.dash-panel[data-panel="beranda"].active .stat-expense-v97{
  min-height:50px!important;
  padding:7px 8px!important;
  border-radius:12px!important;
}

.dash-panel[data-panel="beranda"].active .stat-box .label,
.dash-panel[data-panel="beranda"].active .stat-income-v97 .label,
.dash-panel[data-panel="beranda"].active .stat-expense-v97 .label{
  font-size:9px!important;
}

.dash-panel[data-panel="beranda"].active .stat-box .value,
.dash-panel[data-panel="beranda"].active .stat-income-v97 .value,
.dash-panel[data-panel="beranda"].active .stat-expense-v97 .value{
  font-size:11px!important;
}

/* Beri ruang aman agar sticky card tidak menabrak header/top bar di mobile. */
@media(max-width:430px){
  .dash-panel[data-panel="beranda"].active .balance-card,
  .dash-panel[data-panel="beranda"].active .balance-card-v97,
  .dash-panel[data-panel="beranda"].active .hero-balance-v97,
  .dash-panel[data-panel="beranda"].active .global-balance-card{
    top:6px!important;
  }
}


/* v131 strict white compact sticky balance */
/* Override paling akhir: paksa area saldo jadi putih, kecil, dan sticky. */
body .single-dashboard,
body .mobile-shell,
body .dash-shell{
  background:#f7f8fb!important;
}

body .dash-panel[data-panel="beranda"].active{
  padding-top:0!important;
}

/* Wrapper hijau/oranye di atas dibuat putih total */
body .dash-panel[data-panel="beranda"].active .hero-shell,
body .dash-panel[data-panel="beranda"].active .hero-card,
body .dash-panel[data-panel="beranda"].active .balance-shell,
body .dash-panel[data-panel="beranda"].active .balance-card-wrap,
body .dash-panel[data-panel="beranda"].active .balance-card,
body .dash-panel[data-panel="beranda"].active .balance-card-v97,
body .dash-panel[data-panel="beranda"].active .hero-balance-v97,
body .dash-panel[data-panel="beranda"].active .global-balance-card{
  background:#ffffff!important;
  background-image:none!important;
  color:#0f172a!important;
}

/* Card Saldo Global fixed/sticky */
body .dash-panel[data-panel="beranda"].active .balance-card,
body .dash-panel[data-panel="beranda"].active .balance-card-v97,
body .dash-panel[data-panel="beranda"].active .hero-balance-v97,
body .dash-panel[data-panel="beranda"].active .global-balance-card{
  position:-webkit-sticky!important;
  position:sticky!important;
  top:0!important;
  z-index:999!important;
  margin:0 8px 8px!important;
  padding:9px 10px!important;
  border-radius:15px!important;
  border:1px solid rgba(15,23,42,.07)!important;
  box-shadow:0 8px 20px rgba(15,23,42,.10)!important;
  overflow:hidden!important;
}

/* Hilangkan dekorasi warna besar */
body .dash-panel[data-panel="beranda"].active .balance-card:before,
body .dash-panel[data-panel="beranda"].active .balance-card:after,
body .dash-panel[data-panel="beranda"].active .balance-card-v97:before,
body .dash-panel[data-panel="beranda"].active .balance-card-v97:after,
body .dash-panel[data-panel="beranda"].active .hero-balance-v97:before,
body .dash-panel[data-panel="beranda"].active .hero-balance-v97:after,
body .dash-panel[data-panel="beranda"].active .global-balance-card:before,
body .dash-panel[data-panel="beranda"].active .global-balance-card:after{
  display:none!important;
  content:none!important;
}

/* Teks saldo dibuat kecil */
body .dash-panel[data-panel="beranda"].active .balance-card small,
body .dash-panel[data-panel="beranda"].active .balance-card-v97 small,
body .dash-panel[data-panel="beranda"].active .hero-balance-v97 small,
body .dash-panel[data-panel="beranda"].active .global-balance-card small{
  font-size:9px!important;
  line-height:1.1!important;
  color:#6b7280!important;
}

body .dash-panel[data-panel="beranda"].active .balance-card h1,
body .dash-panel[data-panel="beranda"].active .balance-card-v97 h1,
body .dash-panel[data-panel="beranda"].active .hero-balance-v97 h1,
body .dash-panel[data-panel="beranda"].active .global-balance-card h1{
  font-size:20px!important;
  line-height:1!important;
  margin:3px 0 5px!important;
  letter-spacing:-.05em!important;
  color:#082f2d!important;
}

/* Badge Sehat jangan melebar */
body .dash-panel[data-panel="beranda"].active .balance-health-v97{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:6px!important;
  min-height:18px!important;
  margin:0 0 6px!important;
}
body .dash-panel[data-panel="beranda"].active .balance-health-v97 b,
body .dash-panel[data-panel="beranda"].active .health-badge,
body .dash-panel[data-panel="beranda"].active .badge,
body .dash-panel[data-panel="beranda"].active .status-badge{
  width:auto!important;
  min-width:0!important;
  max-width:max-content!important;
  min-height:18px!important;
  height:18px!important;
  padding:0 8px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:9px!important;
  line-height:1!important;
  background:#eafaf1!important;
  color:#087a4d!important;
  border:0!important;
  box-shadow:none!important;
  flex:0 0 auto!important;
}
body .dash-panel[data-panel="beranda"].active .balance-health-v97 span{
  font-size:9px!important;
  line-height:1.15!important;
  color:#6b7280!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

/* Badge/card Pemasukan Pengeluaran lebih kecil */
body .dash-panel[data-panel="beranda"].active .stat-row,
body .dash-panel[data-panel="beranda"].active .stat-row-v97{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:6px!important;
  margin-top:5px!important;
}
body .dash-panel[data-panel="beranda"].active .stat-box,
body .dash-panel[data-panel="beranda"].active .stat-income-v97,
body .dash-panel[data-panel="beranda"].active .stat-expense-v97{
  min-height:44px!important;
  padding:6px 8px!important;
  border-radius:12px!important;
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(15,23,42,.07)!important;
  box-shadow:none!important;
}
body .dash-panel[data-panel="beranda"].active .stat-box .label,
body .dash-panel[data-panel="beranda"].active .stat-income-v97 .label,
body .dash-panel[data-panel="beranda"].active .stat-expense-v97 .label{
  font-size:8.5px!important;
  line-height:1.1!important;
  color:#6b7280!important;
}
body .dash-panel[data-panel="beranda"].active .stat-box .value,
body .dash-panel[data-panel="beranda"].active .stat-income-v97 .value,
body .dash-panel[data-panel="beranda"].active .stat-expense-v97 .value{
  margin-top:2px!important;
  font-size:10.5px!important;
  line-height:1.15!important;
  color:#111827!important;
}
body .dash-panel[data-panel="beranda"].active .stat-icon-v97{
  width:7px!important;
  height:7px!important;
  min-width:7px!important;
  max-width:7px!important;
  min-height:7px!important;
  max-height:7px!important;
  padding:0!important;
  margin:0 0 3px!important;
  border-radius:999px!important;
  font-size:0!important;
  line-height:0!important;
}

/* Cash/Rekening dan Pindah Saldo dipaksa putih dan diperkecil */
body .wallet-overview,
body .wallet-overview-normal{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:7px!important;
  margin:6px 8px 7px!important;
}
body .wallet-card{
  min-height:48px!important;
  padding:8px 10px!important;
  border-radius:13px!important;
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(15,23,42,.07)!important;
  box-shadow:0 6px 14px rgba(15,23,42,.045)!important;
}
body .wallet-card:before,
body .wallet-card:after{
  display:none!important;
  content:none!important;
}
body .wallet-card span{
  font-size:9px!important;
  line-height:1.1!important;
  color:#6b7280!important;
  letter-spacing:.06em!important;
}
body .wallet-card b{
  margin-top:3px!important;
  font-size:12.5px!important;
  line-height:1.05!important;
  color:#082f2d!important;
}
body .wallet-transfer-shortcut,
body .transfer-inside-v97{
  grid-column:1 / -1!important;
  min-height:36px!important;
  height:36px!important;
  padding:0 10px!important;
  border-radius:12px!important;
  margin:0!important;
  background:#ffffff!important;
  background-image:none!important;
  border:1px solid rgba(15,23,42,.07)!important;
  color:#082f2d!important;
  box-shadow:0 6px 14px rgba(15,23,42,.045)!important;
  font-size:12px!important;
  font-weight:900!important;
}
body .wallet-transfer-shortcut:before,
body .wallet-transfer-shortcut:after,
body .transfer-inside-v97:before,
body .transfer-inside-v97:after{
  display:none!important;
  content:none!important;
}

/* Workspace switcher v151: satu email bisa punya banyak ruang keuangan terpisah */
.workspace-switch-btn-v151{
  position:relative;
}
.workspace-switch-btn-v151 svg{
  width:20px;
  height:20px;
}
.workspace-switch-btn-v151:after{
  content:"";
  position:absolute;
  right:7px;
  top:7px;
  width:7px;
  height:7px;
  border-radius:999px;
  background:#f1b56d;
  border:2px solid rgba(23,63,48,.95);
}
.workspace-switch-card-v151{
  max-height:min(86dvh,720px);
  overflow:auto;
  padding:18px!important;
}
.workspace-switch-head-v151{
  display:flex;
  gap:14px;
  align-items:flex-start;
  justify-content:space-between;
  padding:2px 4px 14px;
  border-bottom:1px solid #e5ded3;
  margin-bottom:14px;
}
.workspace-switch-head-v151 small{
  display:block;
  color:#7c8278;
  font-size:11px;
  margin-bottom:4px;
}
.workspace-switch-head-v151 h3{
  margin:0;
  color:#173f30;
  font-size:20px;
  line-height:1.15;
}
.workspace-switch-head-v151 p{
  margin:7px 0 0;
  color:#6f746c;
  font-size:12px;
  line-height:1.45;
}
.workspace-switch-head-v151>span{
  width:44px;
  height:44px;
  border-radius:16px;
  background:#eef6ef;
  display:grid;
  place-items:center;
  font-size:22px;
  flex:0 0 44px;
}
.workspace-option-list-v151{
  display:grid;
  gap:8px;
  margin-bottom:16px;
}
.workspace-option-list-v151 form{
  margin:0;
}
.workspace-option-v151{
  width:100%;
  min-height:62px;
  border:1px solid #ded6ca;
  background:#fffdfa;
  border-radius:16px;
  padding:10px;
  display:grid;
  grid-template-columns:42px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  text-align:left;
  color:#243128;
}
.workspace-option-v151>span{
  width:42px;
  height:42px;
  border-radius:14px;
  background:#f2f4ee;
  display:grid;
  place-items:center;
  font-size:21px;
}
.workspace-option-v151 b{
  display:block;
  color:#173f30;
  font-size:14px;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.workspace-option-v151 small{
  display:block;
  margin-top:3px;
  color:#7c8278;
  font-size:11px;
}
.workspace-option-v151 em{
  font-style:normal;
  color:#7c8278;
  font-size:11px;
  font-weight:700;
  padding:6px 9px;
  border-radius:999px;
  background:#f3f1ec;
}
.workspace-option-v151.active{
  border-color:#173f30;
  background:#eef6ef;
  box-shadow:inset 0 0 0 1px rgba(23,63,48,.08);
}
.workspace-option-v151.active em{
  background:#173f30;
  color:#fff;
}
.workspace-option-v151:disabled{
  opacity:1;
}
.workspace-create-box-v151{
  background:#f7f4ed;
  border:1px solid #e0d8cb;
  border-radius:18px;
  padding:14px;
}
.workspace-create-box-v151 .form-stack{
  margin:0;
}
.workspace-create-box-v151 input,
.workspace-create-box-v151 select{
  background:#fffdfa!important;
}
.workspace-note-v151{
  margin:10px 2px 0;
  color:#74786f;
  font-size:11px;
  line-height:1.45;
}


/* v152 footer setting + manage ruang */
.bottom-nav-v152,
.bottom-nav{
  grid-template-columns:repeat(6,1fr)!important;
  padding-left:4px!important;
  padding-right:4px!important;
}
.bottom-nav-v152 .nav-item,
.bottom-nav .nav-item{
  gap:3px!important;
}
.bottom-nav-v152 .nav-item svg,
.bottom-nav .nav-item svg{
  width:20px!important;
  height:20px!important;
}
.bottom-nav-v152 .nav-item span,
.bottom-nav .nav-item span{
  font-size:9.2px!important;
  letter-spacing:-.03em!important;
}
.nav-setting-v152 svg{
  stroke-width:1.7!important;
}
.profile-panel-clean-v152{
  text-align:center;
}
.profile-summary-clean-v152{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin:14px 0 10px;
  text-align:left;
}
.profile-summary-clean-v152>div{
  border:1px solid #e5ded3;
  background:#fffdfa;
  border-radius:16px;
  padding:11px;
}
.profile-summary-clean-v152 small{
  display:block;
  color:#7c8278;
  font-size:11px;
}
.profile-summary-clean-v152 b{
  display:block;
  color:#173f30;
  font-size:13px;
  margin-top:3px;
  line-height:1.2;
}
.profile-note-clean-v152,
.setting-note-v152{
  border-radius:14px;
  background:#eef6ef;
  color:#315746;
  font-size:12px;
  line-height:1.5;
  padding:10px 12px;
  text-align:left;
  margin:10px 0;
}
.profile-actions-clean-v152{
  grid-template-columns:1fr;
}
.profile-actions-clean-v152 button,
.profile-actions-clean-v152 a{
  width:100%;
}
.setting-panel-v152{
  padding:16px!important;
}
.setting-head-v152{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.setting-head-v152 small{
  display:block;
  color:#7c8278;
  font-size:11px;
  margin-bottom:3px;
}
.setting-head-v152 h2{
  margin:0;
  color:#173f30;
  font-size:22px;
  line-height:1.1;
  letter-spacing:-.04em;
}
.setting-head-v152 p{
  margin:7px 0 0;
  color:#6f746c;
  font-size:12px;
  line-height:1.45;
}
.setting-head-v152>span{
  width:44px;
  height:44px;
  border-radius:16px;
  background:#eef6ef;
  display:grid;
  place-items:center;
  font-size:22px;
  flex:0 0 44px;
}
.setting-tab-top-v152{
  align-items:flex-start!important;
  gap:12px!important;
}
.setting-tab-top-v152 small{
  display:block;
  margin-top:5px;
  color:#7c8278;
  font-size:11px;
  line-height:1.4;
}
.workspace-current-v152{
  display:flex;
  gap:11px;
  align-items:center;
  border:1px solid #d8d2c7;
  background:linear-gradient(180deg,#fffdfa 0%,#f8f5ee 100%);
  border-radius:18px;
  padding:12px;
  margin:12px 0;
}
.workspace-current-v152>span{
  width:44px;
  height:44px;
  border-radius:16px;
  background:#173f30;
  color:#fff;
  display:grid;
  place-items:center;
  font-size:22px;
  flex:0 0 44px;
}
.workspace-current-v152 small,
.workspace-current-v152 em{
  display:block;
  color:#7c8278;
  font-size:11px;
  font-style:normal;
}
.workspace-current-v152 b{
  display:block;
  color:#173f30;
  font-size:15px;
  line-height:1.2;
  margin:2px 0;
}
.workspace-option-list-setting-v152{
  margin-top:10px;
}
.workspace-create-setting-v152{
  margin-top:12px;
  border-top:1px solid #e5ded3;
  padding-top:14px;
}
.mini-add-link-v152{
  height:32px;
  padding:0 12px;
  border-radius:999px;
  background:#184635;
  color:#fff!important;
  display:grid;
  place-items:center;
  text-decoration:none!important;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
}
.setting-referral-card-v152 .profile-referral-inline-v124{
  margin:0!important;
  box-shadow:none!important;
}
.setting-security-actions-v152{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
}
.setting-security-actions-v152 button,
.setting-security-actions-v152 a{
  min-height:42px;
  border-radius:13px!important;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none!important;
}
@media(max-width:370px){
  .bottom-nav-v152 .nav-item span,
  .bottom-nav .nav-item span{
    font-size:8.6px!important;
  }
  .bottom-nav-v152 .nav-item svg,
  .bottom-nav .nav-item svg{
    width:19px!important;
    height:19px!important;
  }
  .profile-summary-clean-v152,
  .setting-security-actions-v152{
    grid-template-columns:1fr;
  }
}


/* v153 - manage ruang: jenis disembunyikan, switch hanya untuk pindah */
.workspace-manage-list-v153{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.workspace-manage-item-v153{
  border:1px solid #ded6ca;
  background:#fffdfa;
  border-radius:16px;
  padding:12px;
  display:grid;
  gap:10px;
}
.workspace-manage-title-v153{
  display:flex;
  align-items:center;
  gap:10px;
}
.workspace-manage-title-v153>span{
  width:38px;
  height:38px;
  border-radius:14px;
  background:#eef6ef;
  display:grid;
  place-items:center;
  flex:0 0 38px;
}
.workspace-manage-title-v153 b{
  display:block;
  font-size:14px;
  color:#173b2e;
  letter-spacing:-.02em;
}
.workspace-manage-title-v153 small{
  display:block;
  margin-top:3px;
  font-size:11px;
  color:#7f827b;
}
.workspace-inline-form-v153{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
}
.workspace-inline-form-v153 input{
  min-height:40px;
  border:1px solid #ded8cc;
  border-radius:12px;
  background:#fff;
  padding:9px 11px;
  font:inherit;
  font-size:13px;
}
.workspace-inline-form-v153 button,
.workspace-delete-btn-v153{
  min-height:40px;
  border:0;
  border-radius:12px;
  padding:0 12px;
  font-size:12px;
  font-weight:800;
}
.workspace-inline-form-v153 button{
  background:#184635;
  color:#fff;
}
.workspace-delete-btn-v153{
  width:100%;
  background:#ffe6e6;
  color:#b13b44;
}
.workspace-delete-btn-v153.disabled{
  background:#f2eee8;
  color:#99948d;
}
.workspace-create-setting-v152 select,
.workspace-switch-modal-v151 .workspace-create-box-v151{
  display:none!important;
}
.workspace-switch-modal-v151 .workspace-option-list-v151{
  margin-top:10px;
}


/* v154 - darker magenta-green header, no translucent divider */
.top-green,
.top-green-v97{
  background:
    radial-gradient(circle at 14% 0%, rgba(126,34,206,.24) 0%, rgba(126,34,206,0) 34%),
    linear-gradient(180deg,#171022 0%, #221126 42%, #111f19 100%)!important;
}
.header-balance-unified .top-green,
.header-balance-unified .top-green-v97{
  border-bottom:0!important;
}
.app-topbar,
.app-topbar-v97{
  border-bottom:0!important;
  box-shadow:none!important;
}
.app-identity,
.app-identity-v97,
.identity-text{
  border-bottom:0!important;
  box-shadow:none!important;
}
.identity-sub{
  border-bottom:0!important;
}
.top-actions-v97 .workspace-switch-btn-v151,
.top-actions-v97 .bell-btn{
  background:rgba(28,16,36,.74)!important;
  border:1px solid rgba(255,255,255,.06)!important;
  box-shadow:0 8px 20px rgba(0,0,0,.18)!important;
}


/* v155 - ruang utama + anggota pindah ke profil */
.workspace-primary-form-v155{
  margin:0;
}
.workspace-primary-btn-v155{
  width:100%;
  min-height:40px;
  border:0;
  border-radius:12px;
  background:#eef6ef;
  color:#173b2e;
  font-size:12px;
  font-weight:800;
}
.workspace-primary-btn-v155.active{
  background:#184635;
  color:#fff;
}
.profile-member-card-v155{
  text-align:left;
}
.profile-member-card-v155 .member-profile-list{
  margin-top:12px;
}


/* v156 - migrasi data antar ruang */
.workspace-migrate-form-v156{
  border:1px dashed #d9d1c6;
  background:#fffaf4;
  border-radius:14px;
  padding:10px;
  display:grid;
  gap:7px;
}
.workspace-migrate-form-v156 label{
  font-size:11px;
  color:#6f746c;
  font-weight:800;
}
.workspace-migrate-row-v156{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
}
.workspace-migrate-row-v156 select{
  min-height:40px;
  border:1px solid #ded8cc;
  border-radius:12px;
  background:#fff;
  padding:9px 10px;
  font:inherit;
  font-size:13px;
}
.workspace-migrate-row-v156 button{
  min-height:40px;
  border:0;
  border-radius:12px;
  background:#7a3b8f;
  color:#fff;
  padding:0 12px;
  font-size:12px;
  font-weight:800;
}
.workspace-migrate-form-v156 small{
  display:block;
  color:#8a8179;
  font-size:10.5px;
  line-height:1.4;
}


/* v162 - top switch + notif icon tanpa background, notif jadi popup */
.top-actions-v97{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
}
.top-actions-v97 .workspace-switch-btn-v151,
.top-actions-v97 .bell-btn{
  width:auto!important;
  min-width:unset!important;
  height:36px!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  border-radius:0!important;
  display:grid!important;
  place-items:center!important;
}
.top-actions-v97 .workspace-switch-btn-v151 svg,
.top-actions-v97 .bell-btn svg{
  width:22px!important;
  height:22px!important;
  stroke:#c8ffe0!important;
  color:#c8ffe0!important;
}
.top-actions-v97 .workspace-switch-btn-v151:hover svg,
.top-actions-v97 .bell-btn:hover svg,
.top-actions-v97 .workspace-switch-btn-v151:focus-visible svg,
.top-actions-v97 .bell-btn:focus-visible svg{
  stroke:#ffffff!important;
  color:#ffffff!important;
}
.top-actions-v97 .bell-btn i{
  right:0!important;
  top:1px!important;
  width:7px!important;
  height:7px!important;
  background:#ffd87a!important;
  box-shadow:0 0 0 2px rgba(22,59,45,.65)!important;
}
.activity-modal-v162 .cb-modal-card{
  width:min(430px, calc(100% - 24px))!important;
}
.activity-card-v162{
  max-height:min(78vh, 680px)!important;
  overflow:hidden!important;
  display:grid!important;
  grid-template-rows:auto 1fr!important;
}
.activity-modal-head-v162{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:12px!important;
  margin-bottom:10px!important;
  padding-right:24px!important;
}
.activity-modal-head-v162 small{
  display:block!important;
  color:#809385!important;
  font-size:11px!important;
  font-weight:800!important;
  text-transform:uppercase!important;
  letter-spacing:.08em!important;
  margin-bottom:5px!important;
}
.activity-modal-head-v162 h3{
  margin:0!important;
  color:#173f30!important;
  font-size:20px!important;
  letter-spacing:-.03em!important;
}
.activity-modal-head-v162 p{
  margin:6px 0 0!important;
  color:#718072!important;
  font-size:12px!important;
  line-height:1.45!important;
}
.activity-modal-head-v162>span{
  width:42px!important;
  height:42px!important;
  border-radius:14px!important;
  background:#ecf8f0!important;
  display:grid!important;
  place-items:center!important;
  font-size:20px!important;
}
.activity-modal-list-v162{
  display:grid!important;
  gap:10px!important;
  overflow:auto!important;
  padding-right:2px!important;
}
.activity-modal-item-v162{
  width:100%!important;
  border:1px solid #e0d8cc!important;
  background:#fffdfa!important;
  border-radius:16px!important;
  padding:12px!important;
  display:grid!important;
  grid-template-columns:auto 1fr auto!important;
  gap:10px!important;
  align-items:flex-start!important;
  text-align:left!important;
}
.activity-modal-item-v162 span{
  width:34px!important;
  height:34px!important;
  border-radius:12px!important;
  background:#edf6ef!important;
  display:grid!important;
  place-items:center!important;
  font-size:0!important;
  position:relative!important;
}
.activity-modal-item-v162 span:before{
  content:"🔔"!important;
  font-size:17px!important;
}
.activity-modal-item-v162 b{
  display:block!important;
  color:#173f30!important;
  font-size:13px!important;
  margin-bottom:4px!important;
}
.activity-modal-item-v162 small{
  display:block!important;
  color:#758277!important;
  font-size:11px!important;
  line-height:1.45!important;
}
.activity-modal-item-v162 em{
  color:#8b8a84!important;
  font-size:10px!important;
  font-style:normal!important;
  font-weight:800!important;
  white-space:nowrap!important;
}


/* v164 - saldo global sticky sendiri + status sehat dihilangkan */
.header-balance-unified{
  position:relative!important;
  top:auto!important;
  z-index:10!important;
  margin:0 0 8px!important;
  padding:0 10px 0!important;
  background:transparent!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.header-balance-unified .top-green{
  border-radius:0 0 26px 26px!important;
  box-shadow:0 10px 22px rgba(20,57,44,.14)!important;
}
.balance-sticky-wrap{
  position:sticky!important;
  top:8px!important;
  z-index:96!important;
  margin:-8px 0 10px!important;
  padding:0 12px 8px!important;
  background:transparent!important;
}
.balance-sticky-wrap .hero-balance.sticky-balance-only{
  margin:0!important;
  border-radius:18px!important;
  box-shadow:0 10px 24px rgba(20,57,44,.18)!important;
}
.hero-balance-v97{
  padding:12px 14px 14px!important;
}
.hero-balance-v97 small{
  margin-bottom:4px!important;
}
.hero-balance-v97 h1{
  margin:0 0 10px!important;
}
.balance-health-v97{
  display:none!important;
}
.hero-balance-v97 .stat-row{
  gap:9px!important;
}
.hero-balance-v97 .stat-box{
  min-height:68px!important;
}
@media (min-width:768px){
  .balance-sticky-wrap{
    top:12px!important;
    max-width:720px!important;
    margin:-8px auto 12px!important;
    padding:0 12px 8px!important;
  }
}


/* v165 - efek loading smooth saat pindah menu, popup, dan submit */
.app-loading-overlay-v165{
  position:fixed!important;
  inset:0!important;
  z-index:9999!important;
  display:grid!important;
  place-items:center!important;
  padding:20px!important;
  background:rgba(7,38,27,.18)!important;
  backdrop-filter:blur(8px)!important;
  -webkit-backdrop-filter:blur(8px)!important;
  opacity:0!important;
  pointer-events:none!important;
  transition:opacity .18s ease!important;
}
.app-loading-overlay-v165.show{
  opacity:1!important;
  pointer-events:auto!important;
}
.app-loading-card-v165{
  width:min(260px, calc(100% - 34px))!important;
  border-radius:24px!important;
  padding:20px 18px!important;
  background:linear-gradient(180deg,#ffffff 0%,#fff8ef 100%)!important;
  border:1px solid rgba(242,165,108,.36)!important;
  box-shadow:0 24px 60px rgba(10,46,34,.26)!important;
  display:grid!important;
  justify-items:center!important;
  text-align:center!important;
  transform:translateY(8px) scale(.97)!important;
  transition:transform .2s ease!important;
}
.app-loading-overlay-v165.show .app-loading-card-v165{
  transform:translateY(0) scale(1)!important;
}
.app-loading-wallet-v165{
  width:58px!important;
  height:58px!important;
  border-radius:20px!important;
  display:grid!important;
  place-items:center!important;
  color:#087a4c!important;
  background:radial-gradient(circle at 30% 20%,#dffbe9 0%,#c4f2d7 48%,#effbf3 100%)!important;
  box-shadow:inset 0 0 0 1px rgba(8,122,76,.08), 0 10px 20px rgba(8,122,76,.16)!important;
  margin-bottom:10px!important;
  animation:walletPulseV165 .78s ease-in-out infinite alternate!important;
}
.app-loading-wallet-v165 svg{
  width:42px!important;
  height:42px!important;
}
.app-loading-card-v165 b{
  color:#173f30!important;
  font-size:16px!important;
  font-weight:900!important;
  letter-spacing:-.02em!important;
}
.app-loading-card-v165 small{
  margin-top:5px!important;
  color:#6f7c70!important;
  font-size:12px!important;
  font-weight:700!important;
  line-height:1.4!important;
}
@keyframes walletPulseV165{
  from{transform:translateY(0) scale(1)}
  to{transform:translateY(-4px) scale(1.04)}
}
.dash-panel{
  transition:opacity .16s ease, transform .16s ease!important;
}
body.panel-loading-v165 .dash-panel.active{
  opacity:.35!important;
  transform:translateY(6px)!important;
}
.cb-modal.open .cb-modal-card{
  animation:modalPopV165 .2s ease both!important;
}
@keyframes modalPopV165{
  from{opacity:.6;transform:translateY(10px) scale(.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@media (prefers-reduced-motion: reduce){
  .app-loading-card-v165,
  .app-loading-wallet-v165,
  .dash-panel,
  .cb-modal.open .cb-modal-card{
    animation:none!important;
    transition:none!important;
  }
}


/* v166 - Saldo Global benar-benar fixed setelah header discroll */
:root{
  --saldo-v166-height:164px;
}
.balance-sticky-wrap{
  position:sticky!important;
  top:0!important;
  z-index:120!important;
}
body.saldo-fixed-v166 .balance-sticky-wrap{
  position:fixed!important;
  top:0!important;
  left:50%!important;
  transform:translateX(-50%)!important;
  width:min(430px,100%)!important;
  z-index:999!important;
  margin:0!important;
  padding:8px 12px 8px!important;
  background:linear-gradient(180deg,rgba(244,241,234,.98),rgba(244,241,234,.88))!important;
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
  box-shadow:0 10px 26px rgba(20,57,44,.12)!important;
}
body.saldo-fixed-v166 .wallet-overview.wallet-overview-normal{
  margin-top:calc(var(--saldo-v166-height) + 10px)!important;
}
body.saldo-fixed-v166 .balance-sticky-wrap .hero-balance.sticky-balance-only{
  box-shadow:0 14px 30px rgba(20,57,44,.22)!important;
}
body.saldo-fixed-v166 .balance-sticky-wrap .wallet-illustration-v97{
  opacity:.82!important;
}
@media(max-width:430px){
  body.saldo-fixed-v166 .balance-sticky-wrap{
    padding-left:9px!important;
    padding-right:9px!important;
  }
}


/* v167 - tiap fitur profil & setting dibungkus warna berbeda agar lebih mudah dibaca */
.dash-panel[data-panel="profil"] .card-block,
.dash-panel[data-panel="setting"] .card-block{
  border-width:1px!important;
  box-shadow:0 8px 18px rgba(19,57,44,.05)!important;
}

.dash-panel[data-panel="profil"] .profile-panel.profile-panel-clean-v152{
  background:linear-gradient(180deg,#eff8f1 0%, #fbfffc 100%)!important;
  border:1px solid #cfe7d5!important;
}
.dash-panel[data-panel="profil"] .profile-panel.profile-panel-clean-v152 .profile-avatar{
  background:#d9f0df!important;
  box-shadow:inset 0 0 0 1px rgba(23,63,48,.08)!important;
}
.dash-panel[data-panel="profil"] .profile-member-card-v155{
  background:linear-gradient(180deg,#f7f0fb 0%, #fffdfd 100%)!important;
  border:1px solid #e7d8f4!important;
}
.dash-panel[data-panel="profil"] .profile-member-card-v155 .member-profile-row{
  background:rgba(255,255,255,.72)!important;
  border:1px solid #eadff3!important;
}

.dash-panel[data-panel="setting"] .setting-panel-v152{
  background:linear-gradient(180deg,#eef8ff 0%, #fbfeff 100%)!important;
  border:1px solid #d8eaf5!important;
}
.dash-panel[data-panel="setting"] .setting-head-v152 > span{
  background:#d9eef8!important;
  box-shadow:inset 0 0 0 1px rgba(19,57,44,.06)!important;
}

.dash-panel[data-panel="setting"] .setting-workspace-card-v152{
  background:linear-gradient(180deg,#fff8ee 0%, #fffdf8 100%)!important;
  border:1px solid #eed9bb!important;
}
.dash-panel[data-panel="setting"] .setting-workspace-card-v152 .setting-workspace-active-v152,
.dash-panel[data-panel="setting"] .setting-workspace-card-v152 .setting-form-v152,
.dash-panel[data-panel="setting"] .setting-workspace-card-v152 .setting-workspace-item-v152{
  background:rgba(255,255,255,.72)!important;
  border-color:#ead8be!important;
}

.dash-panel[data-panel="setting"] .setting-referral-card-v152{
  background:linear-gradient(180deg,#edf9f3 0%, #fbfffd 100%)!important;
  border:1px solid #cfe8d9!important;
}
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .referral-box-v152,
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .referral-note-v152,
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .referral-history-v152{
  background:rgba(255,255,255,.74)!important;
  border-color:#d6e9db!important;
}

.dash-panel[data-panel="setting"] .setting-security-card-v152{
  background:linear-gradient(180deg,#f7f3ff 0%, #fffefe 100%)!important;
  border:1px solid #e2d7f3!important;
}
.dash-panel[data-panel="setting"] .setting-security-card-v152 .setting-security-actions-v152{
  padding-top:4px!important;
}
.dash-panel[data-panel="setting"] .setting-security-card-v152 .profile-password-btn-v86{
  background:#fff7ee!important;
  border:1px solid #efd7b5!important;
  color:#75522f!important;
}
.dash-panel[data-panel="setting"] .setting-security-card-v152 .logout-profile{
  color:#4f48d5!important;
}

.dash-panel[data-panel="profil"] .card-head,
.dash-panel[data-panel="setting"] .card-head{
  color:#173f30!important;
}
.dash-panel[data-panel="profil"] .setting-note-v152,
.dash-panel[data-panel="setting"] .setting-note-v152{
  background:rgba(255,255,255,.62)!important;
  border-color:rgba(23,63,48,.08)!important;
}

.dash-panel[data-panel="profil"] .card-block > .tab-top,
.dash-panel[data-panel="setting"] .card-block > .tab-top{
  margin-bottom:10px!important;
}

@media (prefers-color-scheme: dark){
  .dash-panel[data-panel="profil"] .card-block,
  .dash-panel[data-panel="setting"] .card-block{
    color:inherit!important;
  }
}


/* v168 - warna profil/setting lebih pekat, tidak terlalu transparan */
.dash-panel[data-panel="profil"] .profile-panel.profile-panel-clean-v152{
  background:linear-gradient(180deg,#d7f0df 0%, #eaf8ee 100%)!important;
  border:1px solid #9fd0ad!important;
  box-shadow:0 10px 22px rgba(23,63,48,.10)!important;
}
.dash-panel[data-panel="profil"] .profile-panel.profile-panel-clean-v152 .profile-summary-clean-v152 > div{
  background:#ffffff!important;
  border:1px solid #b5dabf!important;
}
.dash-panel[data-panel="profil"] .profile-panel.profile-panel-clean-v152 .profile-note-clean-v152{
  background:#c8ead2!important;
  border:1px solid #9fd0ad!important;
  color:#173f30!important;
}
.dash-panel[data-panel="profil"] .profile-member-card-v155{
  background:linear-gradient(180deg,#ead9f7 0%, #f4eafc 100%)!important;
  border:1px solid #c8a6e4!important;
  box-shadow:0 10px 22px rgba(72,35,110,.11)!important;
}
.dash-panel[data-panel="profil"] .profile-member-card-v155 .member-profile-row{
  background:#ffffff!important;
  border:1px solid #d1b6e9!important;
}
.dash-panel[data-panel="profil"] .profile-member-card-v155 .setting-note-v152{
  background:#dec8f0!important;
  border:1px solid #c8a6e4!important;
  color:#41205d!important;
}

.dash-panel[data-panel="setting"] .setting-panel-v152{
  background:linear-gradient(180deg,#d6ecf8 0%, #e8f5fb 100%)!important;
  border:1px solid #9bc9df!important;
  box-shadow:0 10px 22px rgba(16,80,111,.10)!important;
}
.dash-panel[data-panel="setting"] .setting-head-v152 > span{
  background:#b9deef!important;
  border:1px solid #8fc4dd!important;
}

.dash-panel[data-panel="setting"] .setting-workspace-card-v152{
  background:linear-gradient(180deg,#f7dfbd 0%, #fff0d6 100%)!important;
  border:1px solid #e1ad68!important;
  box-shadow:0 10px 22px rgba(140,83,25,.12)!important;
}
.dash-panel[data-panel="setting"] .workspace-current-v152,
.dash-panel[data-panel="setting"] .workspace-create-box-v151,
.dash-panel[data-panel="setting"] .workspace-manage-item-v153{
  background:#fffaf2!important;
  border:1px solid #dda75d!important;
  box-shadow:0 3px 10px rgba(140,83,25,.06)!important;
}
.dash-panel[data-panel="setting"] .workspace-migrate-form-v156{
  background:#f6e3ef!important;
  border:1px solid #d99aca!important;
}
.dash-panel[data-panel="setting"] .workspace-inline-form-v153 input{
  background:#ffffff!important;
}
.dash-panel[data-panel="setting"] .workspace-primary-btn-v155.active{
  background:#4f826d!important;
  color:#ffffff!important;
}

.dash-panel[data-panel="setting"] .setting-referral-card-v152{
  background:linear-gradient(180deg,#d3f1df 0%, #e9faef 100%)!important;
  border:1px solid #95d2aa!important;
  box-shadow:0 10px 22px rgba(23,100,60,.11)!important;
}
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .profile-referral-link-v124,
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .profile-referral-stats-v124 > div,
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .profile-referral-info-v124,
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .profile-referral-history-v124{
  background:#ffffff!important;
  border:1px solid #a7d9b7!important;
}
.dash-panel[data-panel="setting"] .setting-referral-card-v152 .profile-referral-actions-v124 em{
  background:#e0f4e7!important;
  border:1px solid #a7d9b7!important;
  color:#173f30!important;
}

.dash-panel[data-panel="setting"] .setting-security-card-v152{
  background:linear-gradient(180deg,#e3d4f7 0%, #f1e8fb 100%)!important;
  border:1px solid #b996e4!important;
  box-shadow:0 10px 22px rgba(72,35,110,.11)!important;
}
.dash-panel[data-panel="setting"] .setting-security-card-v152 .profile-password-btn-v86{
  background:#fff0da!important;
  border:1px solid #e0aa63!important;
  color:#6b4218!important;
}
.dash-panel[data-panel="setting"] .setting-security-card-v152 .logout-profile{
  background:#ffffff!important;
  border:1px solid #c6aceb!important;
  border-radius:14px!important;
  min-height:42px!important;
  display:grid!important;
  place-items:center!important;
  text-decoration:none!important;
  font-weight:900!important;
}

.dash-panel[data-panel="profil"] .card-head,
.dash-panel[data-panel="setting"] .card-head{
  color:#14392c!important;
  font-weight:900!important;
}
.dash-panel[data-panel="profil"] .card-block small,
.dash-panel[data-panel="setting"] .card-block small{
  color:#4f5f55!important;
}


/* v169 - hilangkan popup/info sukses error gagal */
.cb-alert-stack,
.cb-alert,
.cb-floating-toast,
.flash-message,
.toast,
.toast-success,
.toast-error,
.alert-success,
.alert-error,
.alert-danger{
  display:none!important;
}
