:root{
  --teal-50:#F0FDFA;--teal-100:#CCFBF1;--teal-200:#99F6E4;
  --teal-400:#2DD4BF;--teal-500:#14B8A6;--teal-600:#0D9488;
  --teal-700:#0F766E;--teal-800:#115E59;--teal-900:#134E4A;
  --slate-50:#F8FAFC;--slate-100:#F1F5F9;--slate-200:#E2E8F0;
  --slate-300:#CBD5E1;--slate-400:#94A3B8;--slate-500:#64748B;
  --slate-600:#475569;--slate-700:#334155;--slate-800:#1E293B;
  --slate-900:#0F172A;
  --gold:#F59E0B;--gold-light:#FEF3C7;
  --red:#EF4444;--green:#10B981;
  --font-display:'Sora',sans-serif;
  --font-body:'DM Sans',sans-serif;
  --radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.05);
  --shadow-lg:0 16px 48px rgba(0,0,0,.12),0 4px 16px rgba(0,0,0,.06);
  --shadow-teal:0 8px 32px rgba(13,148,136,.3);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
body{
  background:var(--slate-50);
  font-family:var(--font-body);
  color:var(--slate-800);
  -webkit-font-smoothing:antialiased;
  transition:background .3s,color .3s;
}
body.dark{
  background:var(--slate-900);
  color:var(--slate-100);
  --slate-50:#0F172A;--slate-100:#1E293B;--slate-200:#334155;
  --slate-300:#475569;--slate-400:#64748B;--slate-500:#94A3B8;
  --teal-50:#0D2420;--teal-100:#134E4A;
}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;}
input[type=number]{-moz-appearance:textfield;}
input[type=date]{color-scheme:light;}
body.dark input[type=date]{color-scheme:dark;}
::-webkit-scrollbar{width:0;}
details summary::-webkit-details-marker{display:none;}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:none}}
@keyframes scaleIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
@keyframes scaleInBounce{from{opacity:0;transform:scale(.7)}60%{transform:scale(1.06)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes loadBar{0%{width:0%;margin-left:0}50%{width:100%;margin-left:0}100%{width:0%;margin-left:100%}}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes glow{0%,100%{box-shadow:0 0 20px rgba(13,148,136,.3)}50%{box-shadow:0 0 44px rgba(13,148,136,.65)}}
@keyframes countUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes checkmark{from{stroke-dashoffset:30}to{stroke-dashoffset:0}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.anim-fadeUp{animation:fadeUp .4s cubic-bezier(.4,0,.2,1) both;}
.anim-fadeUp-1{animation:fadeUp .4s .08s cubic-bezier(.4,0,.2,1) both;}
.anim-fadeUp-2{animation:fadeUp .4s .16s cubic-bezier(.4,0,.2,1) both;}
.anim-fadeUp-3{animation:fadeUp .4s .24s cubic-bezier(.4,0,.2,1) both;}
.anim-fadeUp-4{animation:fadeUp .4s .32s cubic-bezier(.4,0,.2,1) both;}
.anim-scaleIn{animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1) both;}
.anim-scaleInBounce{animation:scaleInBounce .45s cubic-bezier(.34,1.56,.64,1) both;}
.anim-slideUp{animation:slideUp .32s cubic-bezier(.4,0,.2,1) both;}
.anim-slideRight{animation:slideInRight .35s cubic-bezier(.4,0,.2,1) both;}
.anim-slideLeft{animation:slideInLeft .35s cubic-bezier(.4,0,.2,1) both;}

/* ── Interactive states ── */
.pressable{transition:transform .12s cubic-bezier(.4,0,.2,1),box-shadow .12s;}
.pressable:active{transform:scale(.96);}
.pressable-sm:active{transform:scale(.94);}
.card-hover{transition:transform .2s,box-shadow .2s,border-color .2s;}
.card-hover:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}

/* ── Skeleton loading ── */
.skeleton{
  background:linear-gradient(90deg,var(--slate-100) 25%,var(--slate-50) 50%,var(--slate-100) 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s ease infinite;
  border-radius:8px;
}
body.dark .skeleton{
  background:linear-gradient(90deg,var(--slate-700) 25%,var(--slate-600) 50%,var(--slate-700) 75%);
  background-size:200% 100%;
}

/* ── Tab transition ── */
.tab-content{animation:tabSlideIn .3s cubic-bezier(.4,0,.2,1) both;}

/* ── will-change hints untuk elemen animasi berat ── */
.tab-content{will-change:opacity,transform;}
#splash .bar-inner{will-change:width,margin-left;}
.skeleton{will-change:background-position;}

/* ══ SESI B — UX Input Dipercepat ══ */
.qa-chip{
  padding:8px 14px;border-radius:100px;
  border:1.5px solid var(--slate-200);
  background:transparent;color:var(--slate-500);
  font-family:var(--font-display);font-weight:700;font-size:12px;
  cursor:pointer;white-space:nowrap;
  transition:all .18s cubic-bezier(.4,0,.2,1);
  -webkit-tap-highlight-color:transparent;
}
.qa-chip:active{transform:scale(.93);}
body.dark .qa-chip{border-color:var(--slate-600);color:var(--slate-400);}
.numpad-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:7px;margin-top:12px;
}
.numpad-key{
  padding:14px 4px;border-radius:14px;border:none;
  background:var(--slate-100);color:var(--slate-800);
  font-family:var(--font-display);font-size:20px;font-weight:700;
  cursor:pointer;transition:background .12s,transform .1s;
  -webkit-tap-highlight-color:transparent;user-select:none;
}
.numpad-key:active{transform:scale(.9);background:var(--teal-100);}
body.dark .numpad-key{background:var(--slate-700);color:var(--slate-100);}
body.dark .numpad-key:active{background:var(--teal-900);}
.numpad-key.del{background:#FEF2F2;color:#EF4444;}
body.dark .numpad-key.del{background:#3B1818;color:#F87171;}
.amount-display{
  font-family:var(--font-display);font-size:36px;font-weight:800;
  letter-spacing:-1.5px;text-align:center;padding:16px 0 8px;transition:color .2s;
}
.sparkline-wrap{display:flex;align-items:flex-end;gap:2px;height:28px;}
.spark-bar{flex:1;border-radius:3px 3px 0 0;min-height:3px;transition:height .4s ease;opacity:.75;}
.spark-bar.today{opacity:1;}
.cat-spark-wrap{display:flex;align-items:center;gap:2px;height:14px;flex-shrink:0;}
.cat-spark-seg{min-width:3px;border-radius:2px;transition:width .3s ease;}

/* ══ SESI G — UX/UI Polish ══ */

/* ── Dark mode: View Transition API (Chrome 111+) ── */
::view-transition-old(root){animation:220ms cubic-bezier(.4,0,.2,1) both dm-fade-out;}
::view-transition-new(root){animation:280ms cubic-bezier(.4,0,.2,1) both dm-fade-in;}
@keyframes dm-fade-out{from{opacity:1}to{opacity:0}}
@keyframes dm-fade-in{from{opacity:0}to{opacity:1}}

/* ── Dark mode toggle icon spring ── */
@keyframes dmIconFlip{0%{transform:scale(0) rotate(-90deg);opacity:0}60%{transform:scale(1.25) rotate(10deg)}100%{transform:scale(1) rotate(0deg);opacity:1}}
@keyframes dmGlowPulse{0%,100%{box-shadow:0 0 0 0 transparent}40%{box-shadow:0 0 0 8px rgba(13,148,136,.22)}}
.dm-icon-new{animation:dmIconFlip .38s cubic-bezier(.34,1.56,.64,1) both;}
.dm-glow{animation:dmGlowPulse .55s ease both;}

/* ── Swipe: hint animated arrow ── */
@keyframes swipeHintSlide{0%{transform:translateX(0);opacity:.9}40%{transform:translateX(-18px);opacity:1}60%{transform:translateX(-14px);opacity:1}100%{transform:translateX(0);opacity:.5}}
.swipe-hint-arrow{animation:swipeHintSlide 1.1s cubic-bezier(.4,0,.2,1) .5s 2 both;}

/* ── Swipe action buttons spring reveal ── */
@keyframes swipeReveal{from{transform:translateX(16px);opacity:0}to{transform:none;opacity:1}}
.swipe-btn-edit{animation:swipeReveal .22s .04s cubic-bezier(.34,1.56,.64,1) both;}
.swipe-btn-del{animation:swipeReveal .22s .00s cubic-bezier(.34,1.56,.64,1) both;}

/* ── Onboarding re-trigger badge ── */
@keyframes tourBadge{0%{transform:scale(0) rotate(-12deg)}65%{transform:scale(1.15) rotate(3deg)}100%{transform:scale(1) rotate(0)}}
.tour-badge{animation:tourBadge .4s cubic-bezier(.34,1.56,.64,1) both;}

/* ══ SESI E — Fitur Lanjutan ══ */
@keyframes badgePop{0%{transform:scale(0)}70%{transform:scale(1.25)}100%{transform:scale(1)}}
.notif-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:16px;height:16px;border-radius:99px;
  background:#EF4444;color:#fff;
  font-size:9px;font-weight:800;font-family:var(--font-display);
  display:flex;align-items:center;justify-content:center;
  padding:0 4px;border:2px solid var(--slate-50);
  animation:badgePop .3s cubic-bezier(.34,1.56,.64,1) both;
  pointer-events:none;
}
body.dark .notif-badge{border-color:var(--slate-900);}

/* ── Budget alert banner ── */
@keyframes alertSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.budget-alert-row{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:12px;
  margin-bottom:6px;cursor:pointer;
  transition:background .15s;
  animation:alertSlideIn .25s ease both;
}
.budget-alert-row:active{transform:scale(.99);}

/* ── Debt tracker ── */
.debt-card{
  border-radius:var(--radius-md);padding:14px;
  border:1.5px solid var(--slate-200);
  background:var(--slate-50);
  margin-bottom:8px;
  transition:border-color .2s,background .2s;
}
body.dark .debt-card{border-color:var(--slate-700);background:var(--slate-800);}
.debt-card.lunas{opacity:.65;}
.debt-type-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 9px;border-radius:99px;
  font-size:10px;font-weight:800;font-family:var(--font-display);
}

/* ── Auto-post toast ── */
@keyframes autoPostIn{from{opacity:0;transform:translateX(60px)}to{opacity:1;transform:none}}
.autopost-toast{
  position:fixed;bottom:90px;right:16px;
  background:linear-gradient(135deg,#10B981,#059669);
  color:#fff;border-radius:14px;
  padding:10px 14px;
  font-family:var(--font-display);font-size:12px;font-weight:700;
  box-shadow:0 6px 24px rgba(16,185,129,.4);
  z-index:9990;max-width:220px;
  animation:autoPostIn .35s cubic-bezier(.34,1.56,.64,1) both;
}

/* ── Hormati preferensi aksesibilitas user ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  .tab-content,.anim-fadeUp,.anim-fadeUp-1,.anim-fadeUp-2,.anim-fadeUp-3,.anim-fadeUp-4,
  .anim-scaleIn,.anim-scaleInBounce,.anim-slideUp,.anim-slideRight,.anim-slideLeft,
  .num-anim,.saved-badge{animation:none!important;}
}

/* ── Pill active indicator ── */
.pill-active{
  position:relative;overflow:hidden;
}
.pill-active::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  border-radius:inherit;
}

/* ── Number counter ── */
.num-anim{animation:countUp .4s cubic-bezier(.4,0,.2,1) both;}

/* ── Success checkmark ── */
.saved-badge{animation:scaleInBounce .4s cubic-bezier(.34,1.56,.64,1) both;}

/* ── Splash ── */
#splash{
  position:fixed;inset:0;
  background:var(--slate-900);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:99999;transition:opacity .5s;
}
#splash .logo{font-size:56px;animation:float 2s ease infinite;}
#splash h1{
  font-family:var(--font-display);font-size:28px;font-weight:700;
  color:#fff;margin:16px 0 6px;letter-spacing:-.5px;
}
#splash p{color:var(--slate-400);font-size:13px;}
#splash .bar{
  margin-top:40px;width:48px;height:2px;
  background:var(--slate-700);border-radius:2px;overflow:hidden;
}
#splash .bar-inner{
  height:100%;background:var(--teal-400);border-radius:2px;
  animation:loadBar 1.8s ease infinite;
}

/* ── Landing specific ── */
.landing-hero{
  min-height:100vh;
  background:var(--slate-900);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:80px 24px 60px;text-align:center;
}
.hero-glow{
  position:absolute;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(13,148,136,.25) 0%,transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-60%);
  pointer-events:none;
}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;
}
.pill-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(13,148,136,.15);border:1px solid rgba(13,148,136,.3);
  color:var(--teal-400);border-radius:100px;padding:6px 14px;
  font-size:12px;font-weight:600;font-family:var(--font-display);
  letter-spacing:.03em;margin-bottom:24px;
}
.pill-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--teal-400);animation:pulse 1.5s ease infinite;}

.stat-chip{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:100px;padding:8px 16px;
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:rgba(255,255,255,.7);
  font-family:var(--font-display);font-weight:500;
}

/* ── FAB (Floating Action Button) ── */
@keyframes fabPop{from{opacity:0;transform:scale(.5) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes fabIn{from{opacity:0;transform:translateY(8px) scale(.9)}to{opacity:1;transform:none}}
.fab-main{
  position:fixed;
  bottom:calc(68px + env(safe-area-inset-bottom));
  right:calc(50% - 224px);
  width:54px;height:54px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--teal-500),var(--teal-700));
  border:none;cursor:pointer;
  box-shadow:0 6px 24px rgba(13,148,136,.5),0 2px 8px rgba(0,0,0,.15);
  display:flex;align-items:center;justify-content:center;
  z-index:190;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;
  -webkit-tap-highlight-color:transparent;
}
.fab-main:active{transform:scale(.92)!important;}
.fab-main.open{background:linear-gradient(135deg,#475569,#334155);box-shadow:0 4px 16px rgba(0,0,0,.3);}
.fab-menu{
  position:fixed;
  bottom:calc(130px + env(safe-area-inset-bottom));
  right:calc(50% - 224px);
  display:flex;flex-direction:column;gap:10px;
  z-index:189;
  pointer-events:none;
}
.fab-menu.visible{pointer-events:all;}
.fab-item{
  display:flex;align-items:center;gap:10px;
  justify-content:flex-end;
  opacity:0;transform:translateY(8px) scale(.9);
  transition:opacity .2s,transform .2s;
}
.fab-menu.visible .fab-item:nth-child(1){animation:fabIn .2s .05s both;}
.fab-menu.visible .fab-item:nth-child(2){animation:fabIn .2s .0s both;}
.fab-item button{
  width:46px;height:46px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;box-shadow:0 4px 16px rgba(0,0,0,.2);
  -webkit-tap-highlight-color:transparent;
  transition:transform .15s;
}
.fab-item button:active{transform:scale(.9);}
.fab-item span.label{
  font-family:var(--font-display);font-size:12px;font-weight:700;
  background:var(--slate-800);color:#fff;
  padding:5px 12px;border-radius:100px;
  box-shadow:0 2px 10px rgba(0,0,0,.3);
  white-space:nowrap;
}
body.dark .fab-item span.label{background:#1E293B;}
.fab-backdrop{
  position:fixed;inset:0;z-index:188;
  background:rgba(0,0,0,.25);backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
  animation:fadeIn .15s both;
}
@media(max-width:480px){
  .fab-main,.fab-menu{right:16px;}
}

/* ── Health Score Ring ── */
.hs-ring{transform:rotate(-90deg);transform-origin:50% 50%;}
.hs-track{fill:none;stroke-linecap:round;}
.hs-fill{fill:none;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1);}

/* ══ SESI C — Polish: Onboarding · Empty States · Micro-interactions ══ */

/* ── Ripple Button ── */
@keyframes ripple{0%{transform:scale(0);opacity:.45}100%{transform:scale(4);opacity:0}}
.ripple-btn{position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;}
.ripple-btn .ripple-circle{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.38);
  pointer-events:none;transform:scale(0);
  animation:ripple .55s cubic-bezier(.4,0,.2,1) forwards;
}

/* ── Counter animation ── */
@keyframes numFlip{0%{opacity:0;transform:translateY(8px) scale(.92)}60%{transform:translateY(-2px) scale(1.04)}100%{opacity:1;transform:none}}
.num-flip{animation:numFlip .38s cubic-bezier(.34,1.56,.64,1) both;}

/* ── Checkmark SVG stroke animation ── */
@keyframes drawCheck{0%{stroke-dashoffset:40}100%{stroke-dashoffset:0}}
.check-draw{stroke-dasharray:40;animation:drawCheck .4s .05s cubic-bezier(.4,0,.2,1) forwards;}

/* ── Confetti burst ── */
@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0deg);opacity:1}100%{transform:translateY(180px) rotate(720deg);opacity:0}}
.confetti-piece{position:absolute;width:7px;height:7px;border-radius:2px;animation:confettiFall 1.1s ease-out forwards;}

/* ── Onboarding step emoji entrance ── */
@keyframes emojiBounce{0%{transform:scale(0) rotate(-15deg);opacity:0}60%{transform:scale(1.2) rotate(5deg);opacity:1}80%{transform:scale(.95) rotate(-3deg)}100%{transform:scale(1) rotate(0deg);opacity:1}}
.emoji-bounce{animation:emojiBounce .55s cubic-bezier(.34,1.56,.64,1) both;}

/* ── Onboarding step dot pulse ── */
@keyframes dotPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.35)}}

/* ── Stagger entrance for list items ── */
.stagger-item{opacity:0;animation:fadeUp .35s cubic-bezier(.4,0,.2,1) both;}
.stagger-item:nth-child(1){animation-delay:.04s}
.stagger-item:nth-child(2){animation-delay:.09s}
.stagger-item:nth-child(3){animation-delay:.14s}
.stagger-item:nth-child(4){animation-delay:.19s}
.stagger-item:nth-child(5){animation-delay:.24s}
.stagger-item:nth-child(6){animation-delay:.29s}
.stagger-item:nth-child(7){animation-delay:.34s}
.stagger-item:nth-child(8){animation-delay:.39s}

/* ── Empty state illustration pulse ── */
@keyframes illuFloat{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(1deg)}}
.illu-float{animation:illuFloat 3.5s ease-in-out infinite;}

/* ── Slide + fade tab transition ── */
@keyframes tabSlideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── Toast notification ── */
@keyframes toastIn{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translateX(-50%)}}
@keyframes toastOut{from{opacity:1;transform:translateX(-50%)}to{opacity:0;transform:translate(-50%,-8px)}}
.toast-enter{animation:toastIn .3s cubic-bezier(.34,1.56,.64,1) both;}
.toast-exit{animation:toastOut .25s ease both;}

/* ── Input focus ring glow ── */
.input-glow:focus{
  outline:none;
  box-shadow:0 0 0 3px var(--teal-400)22,0 0 0 1.5px var(--teal-500);
  border-color:var(--teal-500)!important;
  transition:box-shadow .2s,border-color .2s;
}

/* ── Chip selected pop ── */
@keyframes chipPop{0%{transform:scale(.9)}60%{transform:scale(1.07)}100%{transform:scale(1)}}
.chip-pop{animation:chipPop .25s cubic-bezier(.34,1.56,.64,1);}

/* ── Progress bar pulse (budget over) ── */
@keyframes progressPulse{0%,100%{opacity:1}50%{opacity:.6}}
.progress-danger{animation:progressPulse 1.2s ease infinite;}

/* ── FAB label fade ── */
@keyframes labelFade{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:none}}
.fab-label-enter{animation:labelFade .2s .05s both;}

/* ===== split from source: Kantong Pintar single-file ===== */
*{box-sizing:border-box;margin:0;padding:0;}
  body{font-family:'Segoe UI',Arial,sans-serif;color:#1E293B;font-size:12px;background:#fff;}
  .page{max-width:800px;margin:0 auto;padding:40px 48px;}
  /* Header */
  .header{display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid #0D9488;padding-bottom:16px;margin-bottom:24px;}
  .header-left{}
  .brand{font-size:22px;font-weight:800;color:#0D9488;letter-spacing:-0.5px;}
  .brand span{color:#1E293B;}
  .subtitle{color:#64748B;font-size:11px;margin-top:3px;}
  .export-info{text-align:right;color:#94A3B8;font-size:10px;line-height:1.6;}
  /* Summary cards */
  .summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px;}
  .box{padding:14px 16px;border-radius:10px;}
  .box-label{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#64748B;margin-bottom:4px;}
  .box-val{font-size:18px;font-weight:800;letter-spacing:-0.5px;}
  /* Section */
  .section{margin-bottom:28px;}
  .section-title{font-size:13px;font-weight:700;color:#1E293B;margin-bottom:10px;display:flex;align-items:center;gap:6px;}
  .section-title::before{content:'';display:inline-block;width:3px;height:14px;background:#0D9488;border-radius:2px;}
  /* Table */
  table{width:100%;border-collapse:collapse;}
  th{background:#0D9488;color:#fff;padding:8px 10px;text-align:left;font-size:11px;font-weight:600;}
  td{padding:7px 10px;border-bottom:1px solid #F1F5F9;font-size:11px;vertical-align:middle;}
  .num{text-align:right;font-weight:700;font-variant-numeric:tabular-nums;}
  .masuk{color:#10B981;}
  .keluar{color:#EF4444;}
  /* Footer */
  .footer{margin-top:32px;padding-top:16px;border-top:1px solid #E2E8F0;text-align:center;color:#94A3B8;font-size:10px;}
  /* Print-specific */
  @media print{
    body{font-size:11px;}
    .page{padding:20px 24px;}
    .no-print{display:none!important;}
    .section{page-break-inside:avoid;}
    table{page-break-inside:auto;}
    tr{page-break-inside:avoid;}
  }
  /* Print button \u2014 hides on print */
  .print-bar{background:#0D9488;color:#fff;padding:14px 48px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10;}
  .print-bar h2{font-size:14px;font-weight:700;flex:1;}
  .print-bar button{padding:8px 20px;border-radius:8px;border:none;cursor:pointer;font-weight:700;font-size:12px;}
  .btn-print{background:#fff;color:#0D9488;}
  .btn-close{background:rgba(255,255,255,.2);color:#fff;}