/* =====================================================
   KEUANGAN NATIVAN — style.css v4
===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  --primary:      #2563eb;
  --primary-dark: #1d4ed8;
  --primary-soft: #e8f0ff;
  --secondary:    #4f46e5;
  --success:      #22c55e;
  --success-dark: #16a34a;
  --danger:       #ef4444;
  --warning:      #f59e0b;
  --text:         #1f2937;
  --muted:        #6b7280;
  --card:         #ffffff;
  --border:       #e5e7eb;
  --radius:       16px;
  --radius-lg:    24px;
  --shadow-sm:    0 2px 8px rgba(0,0,0,.06);
  --shadow-md:    0 8px 24px rgba(0,0,0,.10);
  --shadow-lg:    0 20px 40px rgba(37,99,235,.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

body {
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  background:linear-gradient(160deg,#eef2ff 0%,#f8fafc 60%,#f0fdf4 100%);
  color:var(--text);min-height:100vh;padding-bottom:100px;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:680px}

/* ── Login ── */
#loginScreen {
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:linear-gradient(135deg,#1e40af,#4f46e5,#7c3aed);
  z-index:10000;display:flex;align-items:center;justify-content:center;
}
.login-box {
  width:90%;max-width:340px;
  background:rgba(255,255,255,.12);backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.25);border-radius:28px;
  padding:36px 28px;text-align:center;
  box-shadow:0 25px 60px rgba(0,0,0,.3);
}
.login-logo{font-size:3rem;margin-bottom:8px}
.login-box h3{color:white;font-weight:800;font-size:1.4rem;margin-bottom:6px}
.login-box p{color:rgba(255,255,255,.7);font-size:.85rem;margin-bottom:24px}
.login-input {
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);
  border-radius:14px;padding:12px 16px;color:white;font-size:1rem;
  width:100%;margin-bottom:12px;font-family:inherit;
  letter-spacing:2px;transition:.2s;
}
.login-input::placeholder{color:rgba(255,255,255,.5);letter-spacing:0}
.login-input:focus{outline:none;border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.2)}
.btn-login {
  width:100%;padding:13px;background:white;color:#2563eb;
  font-weight:700;font-size:1rem;border:none;border-radius:14px;
  cursor:pointer;transition:.2s;font-family:inherit;
}
.btn-login:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.2)}
#loginError{color:#fca5a5;margin-top:10px;font-size:.85rem;font-weight:600}

/* ── Splash ── */
#splashScreen {
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:linear-gradient(135deg,#1e40af,#4f46e5,#7c3aed);
  z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
#splashScreen.active{opacity:1;pointer-events:auto}
.splash-content{text-align:center;width:80%;max-width:300px;animation:fadeUp .4s ease both}
.splash-logo{font-size:4rem;margin-bottom:12px;animation:pulse 1.8s ease infinite}
.splash-title{color:white;font-weight:800;font-size:1.5rem;margin-bottom:6px}
.splash-subtitle{color:rgba(255,255,255,.75);font-size:.85rem;margin-bottom:24px;min-height:20px;transition:.3s}
.splash-progress-wrap{width:100%;height:8px;background:rgba(255,255,255,.2);border-radius:99px;overflow:hidden;margin-bottom:10px}
.splash-progress-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,#60a5fa,#a78bfa,#34d399);
  background-size:200% 100%;border-radius:99px;
  transition:width .45s cubic-bezier(.4,0,.2,1);
  animation:shimmer 1.5s linear infinite;
}
.splash-pct{color:rgba(255,255,255,.6);font-size:.8rem;font-weight:700}

/* ── Loading Overlay ── */
#loadingOverlay {
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(255,255,255,.55);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:9999;
}
.spinner{
  border:4px solid #e5e7eb;border-top:4px solid var(--primary);
  border-radius:50%;width:44px;height:44px;animation:spin .7s linear infinite;
}
#overlayToast{
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.8);
  background:#15803d;color:white;padding:18px 28px;border-radius:16px;
  opacity:0;transition:.3s;font-weight:700;font-size:1rem;
  box-shadow:0 16px 40px rgba(0,0,0,.2);z-index:10001;pointer-events:none;
}
#overlayToast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* ── Custom Alert Modal ── */
.alert-backdrop {
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,.45);backdrop-filter:blur(6px);
  z-index:8000;opacity:0;pointer-events:none;transition:.25s;
}
.alert-backdrop.show{opacity:1;pointer-events:auto}
.alert-modal {
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-46%) scale(.9);
  background:white;border-radius:24px;padding:28px 24px 20px;
  z-index:8001;width:88%;max-width:360px;text-align:center;
  box-shadow:0 30px 60px rgba(0,0,0,.18);
  opacity:0;pointer-events:none;
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
}
.alert-modal.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.alert-icon-wrap{font-size:3rem;margin-bottom:12px;animation:bounceIn .4s ease}
.alert-title{font-size:1.1rem;font-weight:800;color:var(--text);margin-bottom:8px}
.alert-message{font-size:.88rem;color:var(--muted);line-height:1.5;margin-bottom:20px}
.alert-actions{display:flex;gap:10px;justify-content:center}
.alert-btn {
  flex:1;padding:11px 16px;border:none;border-radius:12px;
  font-weight:700;font-size:.88rem;cursor:pointer;font-family:inherit;transition:.15s;
}
.alert-btn:hover{transform:translateY(-1px)}
.alert-btn.primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:white}
.alert-btn.secondary{background:#f3f4f6;color:var(--text)}
.alert-btn.danger{background:#fee2e2;color:#b91c1c}
.alert-btn.success{background:#dcfce7;color:#15803d}

/* ── Toast Container ── */
#toastContainer{
  position:fixed;top:16px;left:50%;transform:translateX(-50%);
  z-index:9999;display:flex;flex-direction:column;align-items:center;
  gap:8px;width:calc(100% - 32px);max-width:380px;pointer-events:none;
}

/* Base toast — glassmorphism */
.toast{
  width:100%;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px) saturate(1.8);
  -webkit-backdrop-filter:blur(20px) saturate(1.8);
  border-radius:18px;
  padding:0;
  display:flex;align-items:stretch;
  box-shadow:
    0 8px 32px rgba(0,0,0,.12),
    0 2px 8px rgba(0,0,0,.08),
    0 0 0 1px rgba(255,255,255,.8) inset;
  opacity:0;
  transform:translateY(-24px) scale(.9);
  transition:transform .42s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
  pointer-events:auto;overflow:hidden;position:relative;
}
.toast.show{opacity:1;transform:translateY(0) scale(1)}
.toast.hiding{
  opacity:0;transform:translateY(-16px) scale(.94);
  transition:transform .28s cubic-bezier(.4,0,.2,1), opacity .22s ease;
}

/* Left accent bar */
.toast::before{
  content:"";width:4px;flex-shrink:0;
  background:var(--toast-accent,#e5e7eb);
  border-radius:18px 0 0 18px;
  display:block;
}

/* Bottom progress drain */
.toast::after{
  content:"";position:absolute;left:0;bottom:0;height:2.5px;
  width:100%;background:var(--toast-accent,#e5e7eb);opacity:.5;
  animation:toast-drain var(--toast-dur,4s) linear forwards;
  transform-origin:left;
}
@keyframes toast-drain{from{transform:scaleX(1)}to{transform:scaleX(0)}}

.toast-inner{display:flex;align-items:center;gap:12px;padding:13px 14px 13px 12px;flex:1;min-width:0}

.toast-icon-box{
  width:38px;height:38px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  background:var(--toast-icon-bg,#f3f4f6);
  box-shadow:0 2px 8px var(--toast-icon-shadow,rgba(0,0,0,.08));
}
.toast-body{flex:1;min-width:0}
.toast-title{font-size:.84rem;font-weight:700;color:var(--text);line-height:1.3}
.toast-sub{font-size:.74rem;color:var(--muted);margin-top:2px;display:none}
.toast-close{
  width:26px;height:26px;border:none;
  background:rgba(0,0,0,.06);border-radius:8px;cursor:pointer;
  font-size:.72rem;color:var(--muted);display:flex;align-items:center;
  justify-content:center;flex-shrink:0;padding:0;transition:.15s;
  margin-right:2px;
}
.toast-close:hover{background:rgba(0,0,0,.12)}

/* Colour variants */
.toast.t-success{
  --toast-accent:#22c55e;
  --toast-icon-bg:#dcfce7;
  --toast-icon-shadow:rgba(34,197,94,.2);
  background:rgba(240,253,244,.9);
}
.toast.t-success .toast-title{color:#15803d}

.toast.t-error{
  --toast-accent:#ef4444;
  --toast-icon-bg:#fee2e2;
  --toast-icon-shadow:rgba(239,68,68,.2);
  background:rgba(254,242,242,.9);
}
.toast.t-error .toast-title{color:#b91c1c}

.toast.t-warning{
  --toast-accent:#f59e0b;
  --toast-icon-bg:#fef3c7;
  --toast-icon-shadow:rgba(245,158,11,.2);
  background:rgba(255,251,235,.9);
}
.toast.t-warning .toast-title{color:#92400e}

.toast.t-info{
  --toast-accent:#3b82f6;
  --toast-icon-bg:#dbeafe;
  --toast-icon-shadow:rgba(59,130,246,.2);
  background:rgba(239,246,255,.9);
}
.toast.t-info .toast-title{color:#1e40af}



/* ── Success Notification (transaksi berhasil) ── */
.success-notif{
  position:fixed;top:16px;left:50%;
  transform:translateX(-50%) translateY(-130px);
  background:white;border-radius:22px;
  padding:14px 16px 10px;
  display:flex;align-items:flex-start;gap:12px;
  box-shadow:0 20px 50px rgba(0,0,0,.16),0 0 0 1px rgba(0,0,0,.05);
  z-index:10002;width:calc(100% - 32px);max-width:360px;
  opacity:0;transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;
  overflow:hidden;
}
.success-notif.sn-show{transform:translateX(-50%) translateY(0);opacity:1}
.success-notif.sn-hide{transform:translateX(-50%) translateY(-130px);opacity:0;transition:transform .3s ease,opacity .25s ease}
.sn-left{flex-shrink:0}
.sn-icon-ring{
  width:46px;height:46px;border-radius:15px;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;box-shadow:0 6px 16px rgba(34,197,94,.35);
  animation:iconPop .5s cubic-bezier(.34,1.56,.64,1) both;
}
.sn-body{flex:1;min-width:0;padding-top:2px}
.sn-label{font-size:.7rem;font-weight:800;color:#16a34a;text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px}
.sn-detail{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sn-amount{font-size:1rem;font-weight:800;color:#15803d;margin-top:1px}
.sn-close{position:absolute;top:10px;right:10px;width:24px;height:24px;border:none;background:#f3f4f6;border-radius:8px;cursor:pointer;font-size:.75rem;color:var(--muted);display:flex;align-items:center;justify-content:center;padding:0}
.sn-progress-track{position:absolute;left:0;bottom:0;width:100%;height:3px;background:#f0f0f0}
.sn-progress-fill{height:100%;background:linear-gradient(90deg,#22c55e,#86efac);animation:snDrain 4s linear forwards}

@keyframes snDrain{from{width:100%}to{width:0%}}
@keyframes iconPop{from{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0deg)}}

/* ── Balance ── */
.balance {
  background:linear-gradient(135deg,#2563eb 0%,#4f46e5 60%,#7c3aed 100%);
  border-radius:28px;padding:28px 24px;text-align:center;color:white;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
  margin-top:16px;margin-bottom:14px;
}
.balance::before{content:"";position:absolute;width:250px;height:250px;background:rgba(255,255,255,.08);border-radius:50%;top:-100px;right:-80px;pointer-events:none}
.balance::after{content:"";position:absolute;width:180px;height:180px;background:rgba(255,255,255,.06);border-radius:50%;bottom:-70px;left:-50px;pointer-events:none}
.balance-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;opacity:.75;margin-bottom:6px;position:relative;z-index:1}
.balance-amount{font-size:clamp(1.4rem,6vw,2.2rem);font-weight:800;letter-spacing:-.5px;position:relative;z-index:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-balances{display:flex;gap:8px;margin-top:18px;position:relative;z-index:2}
.sub-balance{flex:1;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);border-radius:14px;padding:10px 8px;font-size:.65rem;cursor:pointer;transition:.2s;font-weight:600;position:relative;z-index:2;-webkit-tap-highlight-color:transparent}
.sub-balance:hover{transform:translateY(-2px);background:rgba(255,255,255,.25)}
.sub-balance:active{transform:scale(.95);background:rgba(255,255,255,.3)}
.sub-balance span{display:block;font-size:.78rem;font-weight:700;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Detail Saldo Bottom Sheet ── */
.detail-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);z-index:2000;opacity:0;pointer-events:none;transition:.25s}
.detail-backdrop.show{opacity:1;pointer-events:auto}
.detail-sheet{position:fixed;bottom:-100%;left:0;width:100%;max-height:75vh;background:white;border-radius:24px 24px 0 0;z-index:2001;transition:bottom .35s cubic-bezier(.4,0,.2,1);padding:0 0 32px;overflow:hidden;display:flex;flex-direction:column}
.detail-sheet.show{bottom:0}
.detail-sheet-header{padding:16px 20px 12px;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.detail-sheet-title{font-weight:800;font-size:1rem;color:var(--text)}
.detail-sheet-close{width:32px;height:32px;border:none;background:#f3f4f6;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.detail-sheet-handle{width:40px;height:5px;background:#e5e7eb;border-radius:5px;margin:12px auto 0;flex-shrink:0}
.detail-sheet-body{overflow-y:auto;padding:16px 20px;flex:1}
.detail-wallet-group{margin-bottom:20px}
.detail-wallet-label{font-size:.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.detail-wallet-label::after{content:"";flex:1;height:1px;background:#f0f0f0}
.detail-person-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fafafa;border-radius:12px;margin-bottom:8px;border:1px solid #f0f0f0}
.detail-person-info{display:flex;align-items:center;gap:10px}
.detail-person-avatar{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}
.detail-person-name{font-size:.82rem;font-weight:600;color:var(--text)}
.detail-person-sub{font-size:.72rem;color:var(--muted)}
.detail-person-amount{font-size:.9rem;font-weight:800}
.detail-person-amount.positive{color:var(--success-dark)}
.detail-person-amount.negative{color:var(--danger)}
.detail-total-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--primary-soft);border-radius:12px;margin-top:4px}
.detail-total-label{font-size:.8rem;font-weight:700;color:var(--primary)}
.detail-total-amount{font-size:1rem;font-weight:800;color:var(--primary)}

/* ── Summary Cards ── */
.summary-card{background:var(--card);border-radius:var(--radius);padding:16px 14px;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:.2s}
.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.summary-card h6{font-size:.75rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.summary-card h3{font-size:1.1rem;font-weight:800;color:var(--text)}
.summary-card h3.income{color:var(--success-dark)}
.summary-card h3.expense{color:var(--danger)}

/* ── Notif Banner ── */
.notif-banner{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:var(--radius);padding:14px 16px;color:white;margin-bottom:14px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px rgba(245,158,11,.25);cursor:pointer;transition:.2s}
.notif-banner:hover{transform:translateY(-1px)}
.notif-banner-icon{font-size:1.5rem}
.notif-banner-text{flex:1}
.notif-banner-text strong{display:block;font-size:.9rem;font-weight:700}
.notif-banner-text span{font-size:.78rem;opacity:.9}
.notif-banner button{background:white;color:#d97706;border:none;border-radius:8px;padding:6px 12px;font-weight:700;font-size:.8rem;cursor:pointer;font-family:inherit}

/* ── Budget Card ── */
.budget-card{background:linear-gradient(135deg,#16a34a,#15803d);border-radius:var(--radius-lg);padding:20px;color:white;box-shadow:0 12px 30px rgba(22,163,74,.3);margin-bottom:16px;position:relative;overflow:hidden}
.budget-card::after{content:"";position:absolute;width:200px;height:200px;background:rgba(255,255,255,.06);border-radius:50%;right:-80px;top:-80px}
.budget-period{font-size:.72rem;opacity:.8;margin-bottom:4px;font-weight:600}
.budget-card h6{font-size:.8rem;font-weight:600;opacity:.85;margin-bottom:4px}
.budget-card h4{font-size:1.4rem;font-weight:800}
.budget-progress{height:10px;background:rgba(255,255,255,.2);border-radius:10px;margin:12px 0 6px}
.budget-bar{height:100%;border-radius:10px;width:0%;background:#4ade80;transition:width .5s cubic-bezier(.4,0,.2,1)}
.budget-warning{font-size:.8rem;font-weight:700;margin-bottom:10px}
.warning80{color:#fde047}.warning90{color:#fb923c}.warning100{color:#fca5a5}
.budget-input{display:flex;gap:8px;margin-top:12px}
.budget-input input{flex:1;border-radius:10px;border:none;padding:8px 12px;font-size:.9rem;font-family:inherit;background:rgba(255,255,255,.9)}
.budget-input input:focus{outline:none}
.budget-input button{border:none;background:white;color:#16a34a;font-weight:700;border-radius:10px;padding:8px 16px;cursor:pointer;font-family:inherit;transition:.15s}
.budget-input button:hover{background:#f0fdf4}
.budget-input button:disabled{opacity:.5;cursor:not-allowed}
.budget-card small{opacity:.75;font-size:.72rem}

/* ── Modal ── */
.modal-ios{position:fixed;bottom:-100%;left:0;width:100%;background:white;border-radius:24px 24px 0 0;box-shadow:0 -8px 30px rgba(0,0,0,.15);padding:20px;transition:bottom .38s cubic-bezier(.4,0,.2,1);z-index:1000;max-height:90vh;overflow-y:auto}
.modal-ios.show{bottom:0}
.modal-backdrop-ios{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:.25s;z-index:999}
.modal-backdrop-ios.show{opacity:1;pointer-events:auto}
.modal-handle{width:40px;height:5px;background:#d1d5db;border-radius:5px;margin:0 auto 14px}

/* ── Modal Tabs ── */
.modal-tabs{display:flex;gap:8px;margin-bottom:20px;background:#f3f4f6;border-radius:14px;padding:4px}
.modal-tab{flex:1;padding:9px;border:none;border-radius:11px;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--muted);background:transparent;cursor:pointer;transition:.2s}
.modal-tab.active{background:white;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.1)}

/* ── Transfer Panel ── */
.transfer-info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:12px 14px;font-size:.83rem;color:#1e40af;margin-bottom:20px;line-height:1.5}
.transfer-arrow{text-align:center;font-size:1.5rem;color:var(--primary);margin:8px 0;font-weight:700}
.btn-transfer{background:linear-gradient(135deg,#0ea5e9,#2563eb)!important}

/* ── Form Elements ── */
.form-control,.form-select{border-radius:12px;border:1px solid var(--border);font-size:.9rem;font-family:inherit;padding:10px 12px;transition:.2s;background:#fafafa}
.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);background:white;outline:none}
.form-label{font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:5px;display:block}
.btn-blue{background:linear-gradient(135deg,var(--primary),var(--secondary));border:none;color:white;font-weight:700;border-radius:14px;padding:12px;transition:.2s;font-size:.95rem;cursor:pointer;font-family:inherit;width:100%}
.btn-blue:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(37,99,235,.35)}
.btn-blue:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* ── FAB ── */
.fab-add{position:fixed;bottom:24px;right:20px;width:62px;height:62px;border:none;border-radius:20px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:white;font-size:28px;box-shadow:0 12px 28px rgba(37,99,235,.4);cursor:pointer;transition:.2s;z-index:999;display:flex;align-items:center;justify-content:center}
.fab-add:hover{transform:scale(1.08) translateY(-2px)}
.fab-add:active{transform:scale(.96)}

/* ── Riwayat ── */
.riwayat-title{font-weight:800;text-align:center;margin:28px 0 12px;font-size:1.15rem;color:var(--primary)}
.filter-export{display:flex;gap:10px;align-items:center;background:white;border-radius:14px;padding:10px 12px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
#filter{flex:1;border:none;background:#f3f4f6;border-radius:10px;padding:8px 12px;font-size:.9rem;font-family:inherit;transition:.2s}
#filter:focus{outline:none;background:white;box-shadow:0 0 0 2px var(--primary-soft)}
.btn-export{background:var(--success);border:none;color:white;padding:8px 14px;border-radius:10px;font-size:.82rem;cursor:pointer;font-weight:700;font-family:inherit;transition:.15s;white-space:nowrap}
.btn-export:hover{background:var(--success-dark);transform:translateY(-1px)}
.tanggal-filter{background:white;border-radius:12px;padding:10px 12px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.tanggal-filter .d-flex input{border-radius:10px;border:1px solid var(--border);font-size:.82rem;padding:7px 10px;font-family:inherit;background:#f9fafb;flex:1}
.tanggal-filter button{border:none;background:var(--primary);color:white;padding:7px 14px;border-radius:10px;cursor:pointer;font-family:inherit;font-weight:600}

/* ── Transaction Cards ── */
.riwayat-container{margin-top:14px}
.trx-card{background:white;border-radius:18px;padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:.25s;animation:fadeUp .3s ease both}
.trx-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.trx-card.transfer-card{border-left:4px solid #0ea5e9}
.trx-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px dashed #f0f0f0;padding-bottom:8px;margin-bottom:8px}
.trx-header h6{font-size:.82rem;font-weight:800;color:var(--primary);letter-spacing:.5px}
.trx-date{font-size:.72rem;color:var(--muted);white-space:nowrap;margin-left:8px}
.trx-detail{font-size:.8rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.trx-detail-meta{color:var(--muted);font-size:.77rem}
.trx-badge{font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:20px;display:inline-block;margin-right:6px}
.trx-badge.pendapatan{background:#dcfce7;color:#15803d}
.trx-badge.pengeluaran{background:#fee2e2;color:#b91c1c}
.trx-badge.transfer{background:#e0f2fe;color:#0369a1}
.trx-nominal{font-weight:800;font-size:.95rem}
.trx-nominal.pendapatan{color:var(--success-dark)}
.trx-nominal.pengeluaran{color:var(--danger)}
.trx-nominal.transfer{color:#0369a1}
.trx-deskripsi{font-size:.75rem;color:var(--muted);font-style:italic;display:block;margin-top:2px}

/* ── Debug Panel ── */
#debugPanel{display:none;background:#1e293b;color:#f1f5f9;border-radius:12px;padding:12px;font-size:.72rem;font-family:monospace;margin-top:12px;word-break:break-all}
#debugPanel.show{display:block}

/* ── Success Notification ── */
.success-notif{
  position:fixed;top:16px;left:50%;transform:translateX(-50%) translateY(-120px);
  background:white;border-radius:20px;padding:14px 18px;
  display:flex;align-items:center;gap:14px;
  box-shadow:0 16px 40px rgba(0,0,0,.15),0 0 0 1px rgba(0,0,0,.04);
  z-index:10002;min-width:280px;max-width:340px;
  transition:transform .45s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;
  opacity:0;
}
.success-notif.show{transform:translateX(-50%) translateY(0);opacity:1}
.success-notif.hide{transform:translateX(-50%) translateY(-120px);opacity:0;transition:transform .3s ease,opacity .25s ease}
.sn-icon-wrap{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;flex-shrink:0;animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1)}
.sn-icon{font-size:1.3rem}
.sn-body{flex:1;min-width:0}
.sn-label{font-size:.7rem;font-weight:700;color:var(--success-dark);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}
.sn-kategori{font-size:.92rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sn-nominal{font-size:.82rem;font-weight:700;color:var(--muted)}
.sn-nominal span{color:var(--success-dark);font-weight:800}
.sn-progress{height:3px;background:#f0fdf4;border-radius:2px;margin-top:10px;overflow:hidden;position:relative;z-index:0}
.sn-progress-bar{height:100%;background:linear-gradient(90deg,#22c55e,#86efac);border-radius:2px;width:100%;transform-origin:left;animation:sn-drain var(--sn-dur,3s) linear forwards}
@keyframes sn-drain{from{transform:scaleX(1)}to{transform:scaleX(0)}}
@keyframes scaleIn{from{transform:scale(.3)}to{transform:scale(1)}}

/* ── Animations ── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes shimmer{0%{background-position:200% center}100%{background-position:-200% center}}
@keyframes bounceIn{0%{transform:scale(.3)}50%{transform:scale(1.15)}100%{transform:scale(1)}}

/* ── Responsive ── */
@media(max-width:500px){
  .filter-export{flex-wrap:wrap}
  .btn-export{width:100%}
  .trx-header{flex-direction:column}
  .trx-date{margin-left:0;margin-top:2px}
  .balance-amount{font-size:1.8rem}
}
