
/* ═══════════════ TOKENS ═══════════════ */
:root{
  --bg1:#0f0c29;--bg2:#302b63;--bg3:#24243e;
  --accent:#a78bfa;--accent2:#38bdf8;--accent3:#f472b6;
  --success:#34d399;--danger:#f87171;--warn:#fbbf24;
  --glass:rgba(255,255,255,.07);--glass-h:rgba(255,255,255,.11);--glass-b:rgba(255,255,255,.13);
  --shadow:0 8px 32px rgba(0,0,0,.35);
  --text:#f1f5f9;--muted:rgba(241,245,249,.5);
  --r:20px;--rs:12px;
  --tf:100ms;--tm:200ms;--ts:280ms;
  --spring:cubic-bezier(.34,1.56,.64,1);--out:cubic-bezier(.22,1,.36,1);--io:cubic-bezier(.4,0,.2,1);
  --pad:16px;--gap:10px;
  --fs-xs:11px;--fs-sm:12px;--fs-md:14px;--fs-lg:16px;
  --fs-hero:clamp(22px,5.8vw,28px);--fs-stat:clamp(20px,5.2vw,24px);
}
/* ═══════════════ RESET ═══════════════ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body,#app{border:0!important;outline:0!important;}
html,body{width:100%!important;max-width:100%!important;height:100%;overflow-x:hidden;margin:0!important;padding:0!important;border:0!important;}
body{
  font-family:'DM Sans',sans-serif;
  background:linear-gradient(135deg,var(--bg1) 0%,var(--bg2) 50%,var(--bg3) 100%) fixed;
  min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;color:var(--text);
  /* GPU-accelerated text rendering */
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
body::before,body::after{content:'';position:fixed;border-radius:50%;filter:blur(60px);pointer-events:none;z-index:0}
body::before{width:400px;height:400px;background:radial-gradient(circle,rgba(167,139,250,.28) 0%,transparent 70%);top:-100px;right:-80px;animation:orb1 9s ease-in-out infinite alternate}
body::after{width:320px;height:320px;background:radial-gradient(circle,rgba(56,189,248,.22) 0%,transparent 70%);bottom:90px;left:-70px;animation:orb2 11s ease-in-out infinite alternate}
@keyframes orb1{from{transform:translate(0,0)}to{transform:translate(35px,45px)}}
@keyframes orb2{from{transform:translate(0,0)}to{transform:translate(-25px,35px)}}
@media(prefers-reduced-motion:reduce){body::before,body::after{animation:none}}
#app{
  position:relative;z-index:1;
  width:100%;max-width:100%;
  height:100vh;height:100dvh;
  overflow-x:hidden;overflow-y:auto;
  overscroll-behavior:none;
  box-sizing:border-box;
  scroll-behavior:auto;
}
/* ═══════════════ TOP BAR ═══════════════ */
.top-bar{padding:clamp(14px,4vw,22px) var(--pad) 0;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Sora',sans-serif;font-size:24px;font-weight:700;background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}
.logo span{font-weight:300}
.top-right{display:flex;align-items:center;gap:10px}
.date-chip{font-size:11px;color:var(--muted);background:var(--glass);border:1px solid var(--glass-b);border-radius:99px;padding:4px 12px}
.health-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);transition:background var(--tm),box-shadow var(--tm);flex-shrink:0}
.health-dot.ok{background:var(--success);box-shadow:0 0 6px rgba(52,211,153,.6)}
.health-dot.err{background:var(--danger);box-shadow:0 0 6px rgba(248,113,113,.6)}
.health-dot.chk{background:var(--warn);animation:hpulse .9s ease-in-out infinite}
@keyframes hpulse{0%,100%{opacity:.35}50%{opacity:1}}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent3));display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-size:14px;font-weight:600;color:#fff;box-shadow:0 4px 15px rgba(167,139,250,.4);flex-shrink:0;transition:transform var(--tf) var(--spring)}
.avatar:active{transform:scale(.88)}
/* ═══════════════ PAGES ═══════════════ */
.page{display:none;padding:0 var(--pad) calc(76px + env(safe-area-inset-bottom,0px));width:100%;box-sizing:border-box;overflow-x:hidden}
.page.active{display:block}
/* GPU-accelerated page transitions */
.page.p-enter{display:block;animation:pIn var(--ts) var(--out) both;will-change:transform,opacity}
.page.p-leave{display:block;animation:pOut var(--tm) var(--io) both;pointer-events:none;will-change:transform,opacity}
@keyframes pIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}
@keyframes pOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-14px)}}
/* ═══════════════ PULL-TO-REFRESH ═══════════════ */
.ptr{display:flex;align-items:center;justify-content:center;gap:8px;height:0;overflow:hidden;font-size:12px;color:var(--muted);transition:height var(--tm) var(--out),color var(--tf);padding:0 20px}
.ptr.ready{color:var(--accent)}
.ptr-spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
/* ═══════════════ GREETING ═══════════════ */
.greeting{padding:clamp(12px,3.5vw,18px) 0 0}.greeting-sub{font-size:var(--fs-sm);color:var(--muted);margin-bottom:3px}.greeting-main{font-family:'Sora',sans-serif;font-size:clamp(17px,5vw,20px);font-weight:700}
/* ═══════════════ HERO CARD ═══════════════ */
.hero-card{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(167,139,250,.18) 0%,rgba(56,189,248,.12) 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(167,139,250,.28);border-radius:24px;padding:clamp(16px,4.5vw,22px) var(--pad) clamp(14px,4vw,18px);margin:clamp(12px,3.5vw,16px) 0 clamp(8px,2.5vw,12px);box-shadow:0 12px 40px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.12);box-sizing:border-box;width:100%}
.hero-card::before{content:'';position:absolute;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.18) 0%,transparent 70%);top:-70px;right:-50px;pointer-events:none}
.hero-label{font-size:var(--fs-xs);color:rgba(241,245,249,.55);letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px}
.hero-amount{font-family:'Sora',sans-serif;font-size:var(--fs-hero);font-weight:700;background:linear-gradient(90deg,#fff 20%,var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;margin-bottom:clamp(12px,4vw,18px);min-height:0}
.hero-row{display:flex;gap:var(--gap)}
.hero-mini{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--rs);padding:clamp(9px,2.8vw,12px) clamp(10px,3vw,14px);position:relative;overflow:hidden;transition:transform var(--tf) var(--spring),background var(--tf)}
.hero-mini:active{transform:scale(.95)}
.hero-mini::after{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,transparent 60%)}
.hm-label{font-size:var(--fs-xs);color:var(--muted);letter-spacing:.6px;text-transform:uppercase;margin-bottom:4px}
.hm-val{font-family:'Sora',sans-serif;font-size:clamp(11px,3.2vw,13px);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.hm-val.hutang{color:var(--danger)}.hm-val.piutang{color:var(--success)}
/* ═══════════════ STAT ROW ═══════════════ */
.stat-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--gap);margin:0 0 4px}
.stat-item{background:rgba(255,255,255,.08);border:1px solid var(--glass-b);border-radius:var(--rs);padding:clamp(10px,3vw,13px) clamp(6px,2.5vw,10px);text-align:center;transition:transform var(--tf) var(--spring)}
.stat-item:active{transform:scale(.94)}
.stat-label{font-size:var(--fs-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.stat-val{font-family:'Sora',sans-serif;font-size:var(--fs-stat);font-weight:700}
.stat-val.ca{color:var(--accent)}.stat-val.cp{color:var(--success)}.stat-val.ct{color:var(--accent2)}
.section-title{font-family:'Sora',sans-serif;font-size:var(--fs-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:clamp(14px,4vw,20px) 0 clamp(8px,3vw,12px);display:flex;align-items:center;justify-content:space-between}
.count-badge{font-size:11px;font-weight:600;background:rgba(167,139,250,.15);color:var(--accent);border:1px solid rgba(167,139,250,.25);border-radius:99px;padding:1px 9px;letter-spacing:0}
/* ═══════════════ SKELETON ═══════════════ */
.sk{background:linear-gradient(90deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.13) 40%,rgba(255,255,255,.05) 80%);background-size:300% 100%;animation:shim 1.6s ease-in-out infinite;border-radius:8px}
@keyframes shim{0%{background-position:200% 0}100%{background-position:-100% 0}}
.sk-hero{height:162px;border-radius:24px;margin:16px 0 12px}
.sk-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:4px}
.sk-stat{height:72px;border-radius:var(--rs)}
.sk-card{border-radius:var(--r);margin-bottom:12px}
.sk-card:nth-child(1){height:112px}.sk-card:nth-child(2){height:112px;opacity:.7}.sk-card:nth-child(3){height:112px;opacity:.45}
.sk-dh{height:160px;border-radius:24px;margin-bottom:14px}.sk-dgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.sk-dcell{height:80px;border-radius:var(--rs)}.sk-dbar{height:70px;border-radius:var(--rs);margin-bottom:14px}.sk-dtl{height:200px;border-radius:var(--r);margin-bottom:14px}
.glass-card{background:rgba(255,255,255,.08);border:1px solid var(--glass-b);border-radius:var(--r);box-shadow:var(--shadow);padding:20px;margin-bottom:16px;box-sizing:border-box;width:100%}
/* ═══════════════ DEBT CARD ═══════════════ */
.debt-card{background:rgba(255,255,255,.08);border:1px solid var(--glass-b);border-radius:var(--r);box-shadow:var(--shadow);padding:12px var(--pad) 11px var(--pad);margin-bottom:9px;cursor:pointer;position:relative;overflow:hidden;width:100%;box-sizing:border-box;transition:transform var(--tf) var(--spring),box-shadow var(--tf),background var(--tf),opacity var(--tm) var(--out);animation:cardIn var(--ts) var(--out) var(--delay,0ms) both}
.debt-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;border-radius:4px 0 0 4px;background:linear-gradient(180deg,var(--accent),var(--accent3))}
.debt-card.paid-c::before{background:linear-gradient(180deg,var(--success),#059669)}
.debt-card.over-c::before{background:linear-gradient(180deg,var(--warn),#f59e0b)}
.debt-card.od-c::before{background:linear-gradient(180deg,var(--danger),#b91c1c)}
.debt-card:active{transform:scale(.97);box-shadow:0 2px 10px rgba(0,0,0,.28);background:rgba(255,255,255,.12);transition:transform 60ms,background 60ms}
@media(hover:hover){.debt-card:hover{transform:translateY(-2px) scale(1.005);box-shadow:0 14px 40px rgba(0,0,0,.45);background:var(--glass-h)}}
.debt-card.l-exit{animation:lExit var(--tm) var(--io) forwards}
.debt-card.l-enter{animation:lEnter var(--ts) var(--out) var(--delay,0ms) both}
.debt-card.removing{opacity:.4;transform:scale(.97);pointer-events:none;transition:opacity var(--tm),transform var(--tm)}
@keyframes cardIn{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes lEnter{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes lExit{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}
.dc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px;gap:6px}
.debt-name{font-family:'Sora',sans-serif;font-size:clamp(13px,3.8vw,15px);font-weight:600;line-height:1.2;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.debt-badge{font-size:10px;font-weight:600;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}
.ba{background:rgba(167,139,250,.2);color:var(--accent);border:1px solid rgba(167,139,250,.3)}
.bp{background:rgba(52,211,153,.2);color:var(--success);border:1px solid rgba(52,211,153,.3)}
.bo{background:rgba(248,113,113,.2);color:var(--danger);border:1px solid rgba(248,113,113,.3)}
.bw{background:rgba(251,191,36,.18);color:var(--warn);border:1px solid rgba(251,191,36,.35)}
.dc-row{display:flex;justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:2px}
.dc-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.dc-val{font-family:'Sora',sans-serif;font-size:clamp(12px,3.4vw,13px);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dc-ov-row{display:flex;justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:2px}
.dc-ov-lbl{font-size:10px;color:var(--warn);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.dc-ov-val{font-family:'Sora',sans-serif;font-size:clamp(12px,3.4vw,13px);font-weight:700;color:var(--warn);white-space:nowrap}
.dc-meta{display:flex;align-items:center;gap:8px;margin-top:5px;min-width:0}
.dc-note{font-size:10px;color:var(--muted);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic;min-width:0}
.dc-due{font-size:10px;color:var(--muted);white-space:nowrap;flex-shrink:0}
.dc-due .ov{color:var(--danger)}.dc-due .ok{color:var(--accent2)}
.prog-wrap{margin-top:7px}.prog-label{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);margin-bottom:3px}
.prog-bg{background:rgba(255,255,255,.08);border-radius:99px;height:5px;overflow:hidden}
.prog-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width 1s var(--out)}
.prog-fill.done{background:linear-gradient(90deg,var(--success),#059669)}
.prog-fill.over{background:linear-gradient(90deg,var(--warn),#f59e0b)}
/* ═══════════════ SEARCH ═══════════════ */
.search-wrap{position:relative;margin:16px 0 14px;width:100%;box-sizing:border-box}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none;opacity:.5}
.search-input{width:100%;padding:clamp(10px,3vw,12px) 42px;background:rgba(255,255,255,.07);border:1px solid var(--glass-b);border-radius:var(--rs);color:var(--text);font-family:'DM Sans',sans-serif;font-size:var(--fs-md);outline:none;transition:border-color var(--tf),background var(--tf),box-shadow var(--tf)}
.search-input:focus{border-color:var(--accent);background:rgba(167,139,250,.09);box-shadow:0 0 0 3px rgba(167,139,250,.15)}
.search-input::placeholder{color:rgba(255,255,255,.28)}
.search-clear{position:absolute;right:14px;top:50%;transform:translateY(-50%) scale(0);background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:2px;line-height:1;opacity:0;transition:transform var(--tf) var(--spring),opacity var(--tf)}
.search-clear.vis{transform:translateY(-50%) scale(1);opacity:1}
/* ═══════════════ SWIPE CARD ═══════════════ */
.sw-wrap{
  position:relative;overflow:hidden;border-radius:var(--r);margin-bottom:10px;
  background:#201c4e;border:1px solid var(--glass-b);box-shadow:var(--shadow);
  width:100%;box-sizing:border-box;
  contain:layout style;
}
.sw-right{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:stretch;z-index:0;opacity:0;transition:opacity 80ms}
.sw-left{position:absolute;left:0;top:0;bottom:0;display:flex;align-items:stretch;z-index:0;opacity:0;transition:opacity 80ms}
.sw-wrap.revealed .sw-right,.sw-wrap.revealed .sw-left{opacity:1}
.sw-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;width:76px;border:none;cursor:pointer;font-size:11px;font-weight:600;font-family:'DM Sans',sans-serif;transition:filter var(--tf)}
.sw-btn:active{filter:brightness(1.2)}
.sw-btn.sw-del{background:#e05555;color:#fff;border-radius:0 var(--r) var(--r) 0}
.sw-btn.sw-edit{background:#27a882;color:#fff;border-radius:var(--r) 0 0 var(--r)}
.sw-btn.sw-arch{background:#7c5cbf;color:#fff;border-radius:0 var(--r) var(--r) 0}
.sw-btn .si{font-size:20px}
.tx-card{
  position:relative;z-index:1;
  background:#272254;border-radius:var(--r);padding:14px var(--pad);
  cursor:pointer;touch-action:pan-y;
  width:100%;box-sizing:border-box;
  transform:translateX(0);
  transition:background var(--tf);
  will-change:transform;
}
.tx-card.settling{transition:transform var(--tm) var(--spring)}
.tx-card:active{background:#2e2860;transition:background 60ms}.tx-card:hover{background:#2e2860}
.tx-card.removing{opacity:.4;pointer-events:none;transition:opacity var(--tm)}
.tc-top{display:flex;align-items:center;gap:clamp(10px,3vw,14px);margin-bottom:8px}
.tc-av{width:40px;height:40px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-size:14px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent3));box-shadow:0 4px 12px rgba(167,139,250,.35);color:#fff}
.tc-info{flex:1;min-width:0}
.tc-name{font-size:clamp(13px,4vw,15px);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-date{font-size:var(--fs-xs);color:var(--muted);margin-top:2px}
.tc-amt{font-family:'Sora',sans-serif;font-size:clamp(13px,4.2vw,16px);font-weight:700;color:var(--success);white-space:nowrap}
.tc-notes{font-size:11px;color:var(--muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px}
.tc-prog{display:flex;align-items:center;gap:10px}
.tc-pb{flex:1;background:rgba(255,255,255,.08);border-radius:99px;height:5px;overflow:hidden}
.tc-pf{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width 1s var(--out)}
.tc-pf.done{background:linear-gradient(90deg,var(--success),#059669)}
.tc-pct{font-size:11px;color:var(--muted);white-space:nowrap;font-family:'Sora',sans-serif}
.tc-ov-row{display:flex;justify-content:space-between;align-items:center;margin:4px 0 2px;padding:4px 8px;background:rgba(251,191,36,.1);border-radius:6px}
.tc-ov-lbl{font-size:10px;color:var(--warn);text-transform:uppercase;letter-spacing:.5px}
.tc-ov-val{font-family:'Sora',sans-serif;font-size:12px;font-weight:700;color:var(--warn)}
.tc-bot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:10px}
.tc-rl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px}
.tc-rv{font-family:'Sora',sans-serif;font-size:clamp(12px,3.8vw,14px);font-weight:600}
.tc-pill{font-size:10px;font-weight:600;padding:3px 9px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px;align-self:flex-end}
.fi-hint{font-size:11px;color:rgba(248,113,113,.45);margin-top:5px;padding-left:2px}
.swipe-hint{font-size:10px;color:var(--muted);margin-bottom:8px;margin-top:-4px;display:flex;align-items:center;justify-content:center;gap:10px;animation:hintPulse 2s ease-in-out 1s 2 both}
@keyframes hintPulse{0%,100%{opacity:.5}50%{opacity:1}}
/* ═══════════════ PAGINATION ═══════════════ */
.pagination{display:flex;align-items:center;justify-content:center;gap:10px;margin:16px 0 8px}
.page-btn{background:var(--glass);border:1px solid var(--glass-b);color:var(--text);border-radius:var(--rs);padding:9px 20px;font-family:'Sora',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:transform var(--tf) var(--spring),background var(--tf)}
.page-btn:active{transform:scale(.93)}.page-btn:disabled{opacity:.35;cursor:not-allowed}
.page-info{font-family:'Sora',sans-serif;font-size:12px;font-weight:600;color:var(--muted);min-width:60px;text-align:center}
/* ═══════════════ FAB ═══════════════ */
.fab{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0px) + 16px);right:max(20px, env(safe-area-inset-right,20px));width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;color:#fff;font-size:26px;box-shadow:0 8px 24px rgba(167,139,250,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--tf) var(--spring),box-shadow var(--tf),opacity var(--tm) var(--out);z-index:50;will-change:transform}
.fab:active{transform:scale(.88)}.fab.hidden{opacity:0;pointer-events:none;transform:scale(.7)}
@media(hover:hover){.fab:hover{transform:scale(1.1);box-shadow:0 12px 32px rgba(167,139,250,.65)}}
/* ═══════════════ BOTTOM NAV ═══════════════ */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;width:100%;background:rgba(15,12,41,.92);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-top:1px solid var(--glass-b);display:flex;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(10px,3vw,12px) 0 clamp(8px,2.5vw,10px);cursor:pointer;border:none;background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:var(--fs-xs);font-weight:500;gap:4px;position:relative;transition:color var(--tf)}
.nav-item.active{color:var(--accent)}.nav-icon{font-size:clamp(18px,5vw,20px);transition:transform var(--tf) var(--spring)}
.nav-item.active .nav-icon{transform:scale(1.22) translateY(-1px)}.nav-item:active .nav-icon{transform:scale(.88)}
.nav-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);position:absolute;bottom:6px;transform:scale(0);transition:transform var(--tf) var(--spring)}
.nav-item.active .nav-dot{transform:scale(1)}
/* ═══════════════ DETAIL PAGE ═══════════════ */
.back-btn{background:none;border:none;color:var(--accent);font-family:'DM Sans',sans-serif;font-size:14px;cursor:pointer;padding:0;display:flex;align-items:center;gap:6px;margin-bottom:16px;transition:opacity var(--tf),transform var(--tf) var(--spring)}
.back-btn:active{opacity:.6;transform:translateX(-4px)}
.det-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(167,139,250,.22) 0%,rgba(56,189,248,.12) 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(167,139,250,.3);border-radius:24px;padding:clamp(16px,4.5vw,24px) var(--pad) clamp(14px,4vw,20px);margin-bottom:14px;box-shadow:0 12px 40px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.10)}
.det-hero::before{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.15) 0%,transparent 70%);top:-60px;right:-40px;pointer-events:none}
.dh-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.dh-av{width:clamp(42px,11vw,52px);height:clamp(42px,11vw,52px);border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-size:clamp(14px,4.5vw,18px);font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent3));box-shadow:0 4px 16px rgba(167,139,250,.4);color:#fff}
.dh-info{flex:1;padding-left:14px}
.dh-name{font-family:'Sora',sans-serif;font-size:clamp(16px,5vw,20px);font-weight:700;line-height:1.2;margin-bottom:5px}
.dh-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.ring-wrap{position:relative;width:64px;height:64px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ring-svg{position:absolute;inset:0;width:64px;height:64px;transform:rotate(-90deg)}
.ring-track{fill:none;stroke:rgba(255,255,255,.1);stroke-width:5}
.ring-fill{fill:none;stroke-width:5;stroke-linecap:round;stroke-dasharray:188.5;stroke-dashoffset:188.5;transition:stroke-dashoffset 1.2s var(--out)}
.ring-fill.ar{stroke:url(#rg)}.ring-fill.pr{stroke:var(--success)}.ring-fill.or{stroke:var(--danger)}
.ring-pct{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Sora',sans-serif;font-size:11px;font-weight:700;line-height:1;text-align:center;white-space:nowrap;pointer-events:none;z-index:2}
.det-notes{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-left:3px solid var(--accent);border-radius:var(--rs);padding:12px 14px;margin-bottom:14px;font-size:13px;color:var(--muted);line-height:1.6;white-space:pre-wrap}
.det-notes strong{color:var(--text);font-size:11px;text-transform:uppercase;letter-spacing:.7px;display:block;margin-bottom:4px}
.bkd-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-bottom:12px}
.bkd-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--rs);padding:clamp(10px,3.5vw,14px);position:relative;overflow:hidden;transition:transform var(--tf) var(--spring)}
.bkd-item:active{transform:scale(.97)}
.bkd-item::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;border-radius:3px 0 0 3px}
.bi-po::before{background:linear-gradient(180deg,var(--accent2),#0ea5e9)}.bi-bu::before{background:linear-gradient(180deg,var(--accent3),#ec4899)}.bi-to::before{background:linear-gradient(180deg,var(--accent),var(--accent3))}.bi-si::before{background:linear-gradient(180deg,var(--warn),#f59e0b)}
/* ═══════════════ PENALTY CARD ═══════════════ */
.penalty-card-wrap{background:rgba(239,68,68,.09);border:1px solid rgba(239,68,68,.28);border-left:3px solid var(--danger);border-radius:var(--rs);padding:10px 14px;margin-bottom:10px}
.penalty-card-inner{display:flex;align-items:center;justify-content:space-between;gap:10px}
.penalty-card-left{}
.penalty-card-label{font-size:10px;color:#fca5a5;text-transform:uppercase;letter-spacing:.7px;font-weight:600;margin-bottom:2px}
.penalty-card-amount{font-family:'Sora',sans-serif;font-size:15px;font-weight:700;color:#fca5a5}
.penalty-card-right{font-size:10px;color:rgba(252,165,165,.6);text-align:right;line-height:1.4;flex-shrink:0}
/* ═══════════════ PENALTY BUTTON ═══════════════ */
.denda-btn{display:block;width:100%;padding:13px 16px;margin-bottom:10px;background:rgba(239,68,68,.12);border:1.5px solid rgba(239,68,68,.35);border-radius:var(--rs);color:#fca5a5;font-family:'Sora',sans-serif;font-size:14px;font-weight:600;text-align:center;cursor:pointer;transition:all var(--tf);letter-spacing:.2px}
.denda-btn:active{transform:scale(.97);background:rgba(239,68,68,.2)}
.bkd-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:5px}
.bkd-val{font-family:'Sora',sans-serif;font-size:clamp(12px,4vw,15px);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bkd-sub{font-size:10px;color:var(--muted);margin-top:2px}
.sb-wrap{background:rgba(255,255,255,.07);border:1px solid var(--glass-b);border-radius:var(--rs);padding:16px;margin-bottom:14px}
.sb-head{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:10px}
.sb-head span{font-family:'Sora',sans-serif;font-weight:600;color:var(--text)}
.sb-bg{background:rgba(255,255,255,.08);border-radius:99px;height:10px;overflow:hidden;position:relative}
.sb-int{position:absolute;right:0;top:0;height:100%;border-radius:0 99px 99px 0;background:linear-gradient(90deg,var(--accent3),#ec4899);transition:width 1s var(--out) .2s;will-change:width}
.sb-pri{height:100%;border-radius:99px 0 0 99px;background:linear-gradient(90deg,var(--accent2),#0ea5e9);transition:width 1s var(--out) .1s;will-change:width}
.sb-leg{display:flex;gap:14px;margin-top:10px}
.leg{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.leg::before{content:'';display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
.leg.lp::before{background:var(--accent2)}.leg.li::before{background:var(--accent3)}
.mp-wrap{background:rgba(255,255,255,.07);border:1px solid var(--glass-b);border-radius:var(--rs);padding:16px;margin-bottom:14px}
.mp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.mp-title{font-family:'Sora',sans-serif;font-size:14px;font-weight:600}
.mp-pct{font-family:'Sora',sans-serif;font-size:22px;font-weight:700;color:var(--accent)}.mp-pct.done{color:var(--success)}
.mp-bg{background:rgba(255,255,255,.08);border-radius:99px;height:12px;overflow:hidden}
.mp-track{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));background-size:200% 100%;animation:gshift 3s ease infinite;transition:width 1.2s var(--out) .3s;will-change:width;position:relative}
.mp-track::after{content:'';position:absolute;inset:0;border-radius:99px;background:linear-gradient(90deg,rgba(255,255,255,.15) 0%,transparent 50%)}
.mp-track.done{background:linear-gradient(90deg,var(--success),#059669);animation:none;background-size:auto}
@keyframes gshift{0%{background-position:0% 0}50%{background-position:100% 0}100%{background-position:0% 0}}
.mp-sub{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:8px}
.mp-sub span{font-family:'Sora',sans-serif;font-weight:600}
.pay-btn{width:100%;padding:clamp(13px,4vw,16px);background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:var(--rs);color:#fff;font-family:'Sora',sans-serif;font-size:clamp(14px,4.2vw,16px);font-weight:700;cursor:pointer;margin-bottom:14px;box-shadow:0 8px 24px rgba(167,139,250,.45);transition:transform var(--tf) var(--spring),box-shadow var(--tf);display:flex;align-items:center;justify-content:center;gap:10px}
.pay-btn:active{transform:scale(.97)}.pay-btn:disabled{opacity:.5;cursor:not-allowed}
@media(hover:hover){.pay-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.01);box-shadow:0 12px 32px rgba(167,139,250,.6)}}
.tl-wrap{padding:0}.tl-item{display:flex;position:relative}
.tl-left{display:flex;flex-direction:column;align-items:center;width:40px;flex-shrink:0}
.tl-dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;z-index:1;border:2px solid rgba(255,255,255,.15)}
.tl-dot.pd{background:rgba(52,211,153,.2);border-color:rgba(52,211,153,.4)}
.tl-dot.cur{background:rgba(167,139,250,.2);border-color:rgba(167,139,250,.5);animation:dotpulse 2s ease-in-out infinite}
@keyframes dotpulse{0%,100%{box-shadow:0 0 8px rgba(167,139,250,.4)}50%{box-shadow:0 0 18px rgba(167,139,250,.7)}}
.tl-line{width:2px;flex:1;min-height:16px;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.05));margin:3px 0}
.tl-line.last{background:transparent}
.tl-body{flex:1;padding:0 0 clamp(14px,4vw,20px) 10px}.tl-body.first{padding-top:4px}
.tl-meta{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3px}
.tl-title{font-size:var(--fs-md);font-weight:600}.tl-amount{font-family:'Sora',sans-serif;font-size:var(--fs-md);font-weight:700;color:var(--success)}
.tl-date{font-size:11px;color:var(--muted);margin-bottom:4px}
.tl-alloc{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.at{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:600;letter-spacing:.3px}
.at-i{background:rgba(244,114,182,.15);color:var(--accent3);border:1px solid rgba(244,114,182,.25)}
.at-p{background:rgba(56,189,248,.15);color:var(--accent2);border:1px solid rgba(56,189,248,.25)}
.tl-future{display:flex;position:relative;opacity:.4}
.tl-future .tl-dot{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);border-style:dashed}
/* ═══════════════ MODAL ═══════════════ */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);z-index:200;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--tm) var(--io)}
.modal-ov.open{opacity:1;pointer-events:all}
.modal-sheet{background:linear-gradient(180deg,rgba(48,43,99,.97) 0%,rgba(15,12,41,.99) 100%);border:1px solid var(--glass-b);border-radius:28px 28px 0 0;padding:clamp(20px,5vw,28px) clamp(16px,5vw,24px) clamp(28px,7vw,40px);width:100%;max-width:100%;transform:translateY(100%);transition:transform var(--ts) cubic-bezier(.25,.46,.45,.94);max-height:92vh;max-height:92dvh;overflow-y:auto;box-sizing:border-box;}
.modal-ov.open .modal-sheet{transform:translateY(0)}
.modal-handle{width:40px;height:4px;background:rgba(255,255,255,.2);border-radius:99px;margin:0 auto 24px}
.modal-title{font-family:'Sora',sans-serif;font-size:clamp(16px,4.5vw,18px);font-weight:600;margin-bottom:clamp(14px,4vw,20px)}
.edit-warn{background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25);border-radius:var(--rs);padding:10px 14px;font-size:12px;color:var(--warn);margin-bottom:16px;line-height:1.5}
/* ═══════════════ CONFIRM DIALOG ═══════════════ */
.confirm-ov{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity var(--tm) var(--io)}
.confirm-ov.open{opacity:1;pointer-events:all}
.confirm-box{background:linear-gradient(180deg,rgba(48,43,99,.98) 0%,rgba(15,12,41,1) 100%);border:1px solid var(--glass-b);border-radius:24px;padding:28px 24px;width:calc(100% - 32px);max-width:360px;transform:scale(.88) translateY(16px);transition:transform var(--ts) var(--spring);box-shadow:0 24px 60px rgba(0,0,0,.6)}
.confirm-ov.open .confirm-box{transform:scale(1) translateY(0)}
.confirm-icon{font-size:42px;text-align:center;margin-bottom:12px}
.confirm-title{font-family:'Sora',sans-serif;font-size:18px;font-weight:700;text-align:center;margin-bottom:8px}
.confirm-msg{font-size:14px;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:24px}
.confirm-name{font-weight:700;color:var(--text)}
.confirm-actions{display:flex;gap:10px}
.confirm-cancel{flex:1;padding:13px;background:rgba(255,255,255,.08);border:1px solid var(--glass-b);border-radius:var(--rs);color:var(--text);font-family:'Sora',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:transform var(--tf) var(--spring),background var(--tf)}
.confirm-cancel:active{transform:scale(.96)}
.confirm-ok{flex:1;padding:13px;background:rgba(248,113,113,.2);border:1px solid rgba(248,113,113,.35);border-radius:var(--rs);color:var(--danger);font-family:'Sora',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:transform var(--tf) var(--spring),background var(--tf),box-shadow var(--tf)}
.confirm-ok:active{transform:scale(.96)}.confirm-ok:disabled{opacity:.6;cursor:not-allowed}
@media(hover:hover){.confirm-ok:hover:not(:disabled){background:rgba(248,113,113,.3);box-shadow:0 4px 16px rgba(248,113,113,.3)}}
/* ═══════════════ FORMS ═══════════════ */
.fg{margin-bottom:14px}
.fl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;display:block}
.cw{position:relative}
.cp{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--muted);pointer-events:none;font-family:'DM Sans',sans-serif;font-weight:500}
.ci{width:100%;padding:clamp(11px,3vw,13px) 16px clamp(11px,3vw,13px) 44px;background:rgba(255,255,255,.07);border:1px solid var(--glass-b);border-radius:var(--rs);color:var(--text);font-family:'Sora',sans-serif;font-size:clamp(13px,4vw,15px);font-weight:600;letter-spacing:.3px;outline:none;transition:border-color var(--tf),background var(--tf),box-shadow var(--tf)}
.ci:focus{border-color:var(--accent);background:rgba(167,139,250,.09);box-shadow:0 0 0 3px rgba(167,139,250,.15)}
.ci::placeholder{color:rgba(255,255,255,.2);font-weight:400;font-family:'DM Sans',sans-serif;letter-spacing:0}
.fi{width:100%;background:rgba(255,255,255,.07);border:1px solid var(--glass-b);border-radius:var(--rs);color:var(--text);font-family:'DM Sans',sans-serif;font-size:var(--fs-md);padding:clamp(11px,3vw,13px) 16px;outline:none;transition:border-color var(--tf),background var(--tf),box-shadow var(--tf);resize:vertical;min-height:42px}
.fi:focus{border-color:var(--accent);background:rgba(167,139,250,.09);box-shadow:0 0 0 3px rgba(167,139,250,.15)}
.fi::placeholder{color:rgba(255,255,255,.25)}
textarea.fi{resize:vertical;min-height:80px;line-height:1.5}
.btn-p{width:100%;padding:clamp(13px,3.5vw,15px);background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:var(--rs);color:#fff;font-family:'Sora',sans-serif;font-size:var(--fs-md);font-weight:600;cursor:pointer;margin-top:8px;box-shadow:0 6px 20px rgba(167,139,250,.4);transition:transform var(--tf) var(--spring),box-shadow var(--tf),opacity var(--tf);display:flex;align-items:center;justify-content:center;gap:8px}
.btn-p:active{transform:scale(.96)}.btn-p:disabled{opacity:.6;cursor:not-allowed}
@media(hover:hover){.btn-p:hover:not(:disabled){transform:translateY(-1px) scale(1.01);box-shadow:0 10px 28px rgba(167,139,250,.55)}}
.btn-s{width:100%;padding:13px;background:rgba(255,255,255,.07);border:1px solid var(--glass-b);border-radius:var(--rs);color:var(--text);font-family:'Sora',sans-serif;font-size:14px;font-weight:500;cursor:pointer;margin-top:8px;transition:transform var(--tf) var(--spring),background var(--tf)}
.btn-s:active{transform:scale(.97)}
/* ═══════════════ TOAST ═══════════════ */
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-90px) scale(.9);background:rgba(22,18,56,.97);border:1px solid var(--glass-b);backdrop-filter:blur(20px);color:var(--text);padding:12px 24px;border-radius:99px;font-size:13px;font-weight:500;z-index:500;white-space:nowrap;transition:transform var(--ts) var(--spring),opacity var(--tm);opacity:0;max-width:90vw;text-overflow:ellipsis;overflow:hidden}
.toast.show{transform:translateX(-50%) translateY(0) scale(1);opacity:1}
.toast.s{border-color:rgba(52,211,153,.45);color:var(--success)}.toast.e{border-color:rgba(248,113,113,.45);color:var(--danger)}.toast.i{border-color:rgba(56,189,248,.45);color:var(--accent2)}
/* ═══════════════ OVERPAYMENT ═══════════════ */
.op-badge{background:rgba(251,191,36,.18);color:var(--warn);border:1px solid rgba(251,191,36,.35);font-size:10px;font-weight:700;padding:3px 9px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.ov-card{background:linear-gradient(135deg,rgba(251,191,36,.12),rgba(249,115,22,.08));border:1px solid rgba(251,191,36,.25);border-radius:var(--rs);padding:14px var(--pad);margin-bottom:12px;display:flex;align-items:center;gap:14px}
.ov-icon{font-size:28px;flex-shrink:0}
.ov-body{flex:1;min-width:0}
.ov-label{font-size:10px;color:var(--warn);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px;opacity:.8}
.ov-amount{font-family:'Sora',sans-serif;font-size:18px;font-weight:700;color:var(--warn)}
.ov-sub{font-size:11px;color:var(--muted);margin-top:1px}
.det-ov{background:linear-gradient(135deg,rgba(251,191,36,.12),rgba(249,115,22,.06));border:1px solid rgba(251,191,36,.28);border-left:3px solid var(--warn);border-radius:var(--rs);padding:14px 16px;margin-bottom:14px}
.det-ov-label{font-size:10px;color:var(--warn);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;font-weight:600}
.det-ov-amount{font-family:'Sora',sans-serif;font-size:20px;font-weight:700;color:var(--warn)}
.det-ov-note{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.4}
.loader{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.18);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.filter-tabs{display:flex;gap:8px;margin-bottom:14px}
.filter-tab{padding:8px 16px;border-radius:99px;border:1px solid var(--glass-b);background:var(--glass);font-family:'Sora',sans-serif;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all var(--tf) var(--spring);white-space:nowrap}
.filter-tab.active{background:rgba(167,139,250,.2);border-color:rgba(167,139,250,.4);color:var(--accent)}
.filter-tab:active{transform:scale(.95)}
.arch-badge{background:rgba(167,139,250,.15);color:var(--accent);border:1px solid rgba(167,139,250,.3);font-size:10px;font-weight:700;padding:3px 9px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.det-arch-banner{background:linear-gradient(135deg,rgba(167,139,250,.12),rgba(99,76,234,.06));border:1px solid rgba(167,139,250,.28);border-left:3px solid var(--accent);border-radius:var(--rs);padding:14px 16px;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.det-arch-icon{font-size:24px;flex-shrink:0}
.det-arch-body{flex:1}
.det-arch-label{font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px;font-weight:600}
.det-arch-note{font-size:12px;color:var(--muted);line-height:1.4}
.det-arch-btn{background:rgba(167,139,250,.18);border:1px solid rgba(167,139,250,.35);color:var(--accent);font-family:'Sora',sans-serif;font-size:12px;font-weight:700;padding:7px 14px;border-radius:var(--rs);cursor:pointer;white-space:nowrap;transition:background var(--tf),transform var(--tf) var(--spring)}
.det-arch-btn:active{transform:scale(.95)}
.arch-action-btn{width:100%;padding:14px;border:none;border-radius:var(--rs);font-family:'Sora',sans-serif;font-size:14px;font-weight:600;cursor:pointer;margin-bottom:14px;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform var(--tf) var(--spring)}
.arch-action-btn.do-archive{background:rgba(167,139,250,.15);border:1px solid rgba(167,139,250,.3);color:var(--accent)}
.arch-action-btn:active{transform:scale(.97)}
.confirm-ok.accent{background:rgba(167,139,250,.2);border-color:rgba(167,139,250,.35);color:var(--accent)}
.date-wrap{position:relative}
.date-wrap input[type=date]{
  color-scheme:dark;width:100%;
  -webkit-appearance:none;appearance:none;
  -moz-appearance:textfield;
  min-height:48px;max-height:48px;line-height:1.4;padding-top:12px;padding-bottom:12px;
  font-size:var(--fs-md);font-family:'DM Sans',sans-serif;
  overflow:hidden;
}
.date-wrap input[type=date][data-empty="true"]::-webkit-datetime-edit-text,
.date-wrap input[type=date][data-empty="true"]::-webkit-datetime-edit-month-field,
.date-wrap input[type=date][data-empty="true"]::-webkit-datetime-edit-day-field,
.date-wrap input[type=date][data-empty="true"]::-webkit-datetime-edit-year-field{color:transparent}
.date-wrap input[type=date]::-webkit-datetime-edit{display:flex;align-items:center;height:100%;padding:0}
.date-ph{position:absolute;inset:0;padding:0 16px;display:flex;align-items:center;font-size:14px;color:var(--muted);pointer-events:none;transition:opacity .15s}
.date-ph.hidden{opacity:0}
.lw{text-align:center;padding:40px;color:var(--muted);font-size:14px}
.empty{text-align:center;padding:48px 20px}.empty .ic{font-size:52px;opacity:.3;margin-bottom:12px}.empty p{color:var(--muted);font-size:14px;line-height:1.6}
.error-state{text-align:center;padding:40px 20px;background:rgba(248,113,113,.05);border:1px solid rgba(248,113,113,.15);border-radius:var(--r)}.error-state .ic{font-size:40px;margin-bottom:10px}.error-state p{color:var(--danger);font-size:14px;line-height:1.6;margin-bottom:14px}
.error-retry{background:rgba(248,113,113,.15);border:1px solid rgba(248,113,113,.3);color:var(--danger);font-family:'Sora',sans-serif;font-size:13px;font-weight:600;padding:10px 20px;border-radius:var(--rs);cursor:pointer;transition:background var(--tf)}
.error-retry:active{background:rgba(248,113,113,.25)}
.det-ph{text-align:center;padding:60px 20px;color:var(--muted)}.det-ph .ic{font-size:64px;margin-bottom:16px;opacity:.35}.det-ph p{font-size:14px;line-height:1.7}
footer{text-align:center;font-size:11px;color:var(--muted);padding:4px 0 8px;letter-spacing:.3px}
/* [UX] Offline banner — shown when navigator.onLine is false */
.offline-banner{position:fixed;top:0;left:0;right:0;z-index:600;background:rgba(248,113,113,.95);color:#fff;font-family:'Sora',sans-serif;font-size:13px;font-weight:600;text-align:center;padding:10px 16px;transform:translateY(-100%);transition:transform var(--tm) var(--spring)}
.offline-banner.show{transform:translateY(0)}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:99px}
/* ── 393px: iPhone 14/15, Pixel 6a ── */
@media(max-width:393px){:root{--pad:14px;--gap:9px;--fs-hero:clamp(19px,5.3vw,23px);--fs-stat:clamp(17px,4.8vw,21px)}}
/* ── 375px: iPhone SE 2/3, iPhone 12 mini ── */
@media(max-width:375px){:root{--pad:12px;--gap:8px;--r:16px;--rs:10px;--fs-hero:clamp(17px,5vw,21px);--fs-stat:clamp(15px,4.5vw,19px)}.hero-card{padding:13px var(--pad) 11px}.stat-val{font-size:16px}.modal-sheet{border-radius:20px 20px 0 0;padding:18px 14px 32px}.confirm-box{padding:22px 14px}}
/* ── 320px: iPhone SE 1st gen, small Android ── */
@media(max-width:320px){:root{--pad:10px;--gap:6px;--fs-hero:16px;--fs-stat:14px}.stat-row{gap:5px}.bkd-grid{grid-template-columns:1fr}.hero-card{padding:12px var(--pad) 10px}.hm-val{font-size:11px}}
/* ── ≥600px: Tablet / desktop — centered column layout ── */
@media(min-width:600px){
  #app{width:min(480px,100%);max-width:480px;margin:0 auto}
  .bottom-nav{width:min(480px,100%);max-width:480px;left:50%;right:auto;transform:translateX(-50%)}
  .modal-sheet{width:min(480px,100%);max-width:480px}
  .modal-ov{align-items:flex-end}
  .fab{right:calc(50% - 240px + 20px)}
  :root{--pad:20px;--gap:12px}
}

/* ═══════════════ OVERDUE BADGE (NAV) ═══════════════ */
.nav-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}
.nav-od-badge{position:absolute;top:-4px;right:-6px;min-width:15px;height:15px;padding:0 3px;background:var(--danger);border-radius:99px;font-family:'Sora',sans-serif;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none;transform:scale(0);transition:transform var(--tf) var(--spring);border:1.5px solid var(--bg1)}
.nav-od-badge.vis{transform:scale(1)}
/* ═══════════════ COPY LINK BTN ═══════════════ */
.copy-link-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px;background:rgba(56,189,248,.1);border:1px solid rgba(56,189,248,.25);border-radius:var(--rs);color:var(--accent2);font-family:'Sora',sans-serif;font-size:13px;font-weight:600;cursor:pointer;margin-bottom:12px;transition:background var(--tf),transform var(--tf) var(--spring)}
.copy-link-btn:active{transform:scale(.97);background:rgba(56,189,248,.18)}
/* topbar-salin: tombol Salin di top-bar, tampil saat halaman detail */
.topbar-salin{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:400;padding:0;cursor:pointer;transition:color var(--tf),opacity var(--tf);white-space:nowrap}
.topbar-salin:active{opacity:.4}
.topbar-salin svg{opacity:.6}
/* ═══════════════ UNDO TOAST ═══════════════ */
.toast-undo{display:flex;align-items:center;gap:10px;max-width:90vw}
.toast-undo-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:99px;color:#fff;font-family:'Sora',sans-serif;font-size:12px;font-weight:700;padding:4px 12px;cursor:pointer;flex-shrink:0;transition:background var(--tf)}
.toast-undo-btn:active{background:rgba(255,255,255,.3)}
/* ═══════════════ INST NOTES ═══════════════ */
.tl-note{font-size:11px;color:var(--accent2);margin-top:4px;padding:4px 8px;background:rgba(56,189,248,.08);border-left:2px solid rgba(56,189,248,.35);border-radius:0 4px 4px 0;line-height:1.4}
.fg-sm{margin-bottom:10px}
.fi-sm{width:100%;padding:8px 12px;background:rgba(255,255,255,.06);border:1px solid var(--glass-b);border-radius:var(--rs);color:var(--text);font-size:12px;font-family:'DM Sans',sans-serif;resize:none;outline:none;transition:border-color var(--tf)}
.fi-sm:focus{border-color:var(--accent)}
.fi-sm::placeholder{color:var(--muted)}
/* [UI] Penalty and note rows in payment timeline */
.tl-penalty{font-size:11px;color:#fca5a5;margin-top:4px;font-weight:500}
.tl-penalty span{font-weight:700;font-family:'Sora',sans-serif}
