@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  /* Navy & Teal palette from mockup */
  --navy:#1B2A3D;--navy-light:#243447;--navy-dark:#131F2E;
  --teal:#0EA58A;--teal-bright:#12C4A4;--teal-12:rgba(14,165,138,0.1);--teal-bg:#E8F8F4;
  --bg:#F0F2F5;--surface:#FFFFFF;
  --ink:#1A1D21;--ink-2:#4A5568;--ink-3:#8896A6;
  --line:#E2E8F0;--line-2:#EDF2F7;
  --red:#DC3545;--red-12:#FEE2E5;
  --amber:#D4850A;--amber-12:#FFF3CD;
  --green:#0EA58A;--green-12:#E8F8F4;

  --sans:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --mono:ui-monospace,"SF Mono","Roboto Mono",Menlo,Consolas,monospace;

  /* Legacy aliases so other pages don't break */
  --paper:#F0F2F5;--paper-2:#E2E8F0;
  --jade:#0EA58A;--jade-bright:#12C4A4;--jade-12:rgba(14,165,138,0.1);
  --brass:#D4850A;--brass-12:#FFF3CD;
  --cinnabar:#DC3545;--cinnabar-12:#FEE2E5;
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5;min-height:100vh}
.mono{font-family:var(--mono)}
.material-symbols-rounded{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;display:inline-block;vertical-align:middle;line-height:1;width:24px;height:24px;overflow:hidden}
.on .material-symbols-rounded{font-variation-settings:'FILL' 1,'wght' 500,'GRAD' 0,'opsz' 24}
.hidden{display:none!important}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
button{font-family:var(--sans);cursor:pointer}
input,select{font-family:var(--sans)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:2.5px solid var(--teal);outline-offset:2px}

/* ========== LOGIN ========== */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}
.loginbox{width:100%;max-width:400px;background:var(--surface);border-radius:20px;overflow:hidden;box-shadow:0 20px 60px rgba(27,42,61,0.12)}
.loginhero{background:linear-gradient(155deg,var(--navy),var(--navy-dark));padding:32px 28px 28px;text-align:center;color:#fff}
.loginhero .mk{width:56px;height:56px;border-radius:16px;background:rgba(14,165,138,.2);border:1px solid rgba(14,165,138,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.loginhero h2{font-size:20px;font-weight:800;letter-spacing:-.02em}
.loginhero p{font-size:12.5px;color:rgba(255,255,255,.65);margin-top:4px}
.loginform{padding:28px 24px}
.loginform label{display:block;font-size:12px;font-weight:600;color:var(--ink-2);margin:0 0 6px}
.loginform .fg{margin-bottom:16px;position:relative}
.loginform input{width:100%;height:48px;border:1.5px solid var(--line);border-radius:12px;background:var(--bg);padding:0 16px;font-size:15px;color:var(--ink);transition:all 0.2s}
.loginform input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px var(--teal-12)}
.loginbtn{width:100%;height:50px;border:none;border-radius:12px;background:var(--navy);color:#fff;font-size:15px;font-weight:700;box-shadow:0 4px 14px rgba(27,42,61,.25);margin-top:4px;transition:all 0.2s}
.loginbtn:hover{background:var(--navy-light);transform:translateY(-1px)}
.loginerr{color:var(--red);font-size:12.5px;text-align:center;margin-top:12px;font-weight:600;min-height:18px}
.logincredit{text-align:center;font-size:11px;color:var(--ink-3);padding:0 0 22px}

/* ========== TOPBAR (Dark Navy) ========== */
.topbar{background:var(--navy);padding:0;position:sticky;top:0;z-index:50}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;max-width:1200px;margin:0 auto;padding-left:24px;padding-right:24px}
.brand{display:flex;align-items:center;gap:12px}
.mark{width:40px;height:40px;border-radius:12px;background:rgba(14,165,138,.2);border:1px solid rgba(14,165,138,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand-name{font-size:16px;font-weight:800;letter-spacing:-.01em;color:#fff;line-height:1.1}
.brand-sub{font-size:11px;color:rgba(255,255,255,.5);font-weight:500;margin-top:2px}
.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-user{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-size:13px;font-weight:600}
.topbar-avatar{width:36px;height:36px;border-radius:50%;background:var(--navy-light);border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}

/* ========== NAVIGATION BAR ========== */
.navbar{background:var(--navy-light);border-top:1px solid rgba(255,255,255,.06)}
.navbar-inner{display:flex;align-items:center;gap:0;max-width:1200px;margin:0 auto;padding:0 24px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.navbar-inner::-webkit-scrollbar{display:none}
.navbar a{font-size:13.5px;font-weight:600;color:rgba(255,255,255,.55);text-decoration:none;padding:14px 20px;position:relative;white-space:nowrap;transition:color 0.2s;display:inline-flex;align-items:center;gap:6px}
.navbar a:hover{color:rgba(255,255,255,.85)}
.navbar a.on{color:#fff}
.navbar a.on::after{content:"";position:absolute;bottom:0;left:20px;right:20px;height:3px;background:var(--teal);border-radius:3px 3px 0 0}
.logout{font-size:12.5px;font-weight:600;color:rgba(255,255,255,.55);background:none;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:7px 16px;margin-left:auto;transition:all 0.2s}
.logout:hover{background:rgba(255,255,255,.08);color:#fff}

/* ========== CONTENT AREA ========== */
.content{padding:28px 0 50px}
.page-title{font-size:26px;font-weight:800;letter-spacing:-.03em;color:var(--ink);margin-bottom:24px}
.rule{display:none}

/* ========== COMMON COMPONENTS ========== */
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
h1{font-size:26px;font-weight:800;letter-spacing:-.03em;line-height:1.1}
.lede{font-size:13px;color:var(--ink-2);margin-top:9px;font-weight:500}
.lede .n{font-family:var(--mono);font-weight:600;color:var(--ink);font-size:12.5px}
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:20px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--navy);color:#fff;border:none;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:700;box-shadow:0 2px 8px rgba(27,42,61,.15);transition:all 0.2s}
.btn:hover{background:var(--navy-light);transform:translateY(-1px);box-shadow:0 4px 14px rgba(27,42,61,.25)}
.btn.ghost{background:var(--surface);color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:var(--bg)}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:5px 12px;border-radius:8px}
.chip::before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}
.chip.aktif{background:var(--green-12);color:var(--green)}
.chip.nunggak{background:var(--amber-12);color:var(--amber)}
.chip.lunas{background:var(--line-2);color:var(--ink-2)}
.card{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;box-shadow:0 1px 3px rgba(0,0,0,0.04),0 4px 12px rgba(0,0,0,0.02);transition:box-shadow 0.2s}
.card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.06)}
.loading{padding:60px 0;text-align:center;color:var(--ink-3);font-size:13px}
.seclabel{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:6px 0 8px}

/* ========== LEDGER / TABLE ========== */
.ledger{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.04),0 4px 12px rgba(0,0,0,0.02)}
.lrow{display:grid;align-items:center;gap:14px;padding:14px 22px;position:relative;border-bottom:1px solid var(--line-2);transition:background 0.15s}
.lrow:last-child{border-bottom:none}
.lrow:hover{background:var(--bg)}
.lhead{display:grid;align-items:center;gap:14px;padding:12px 22px;background:var(--navy);border-bottom:1px solid rgba(255,255,255,.1)}
.lhead span{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.r{text-align:right;justify-self:end}
.who{display:flex;align-items:center;gap:12px;min-width:0}
.av{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;background:linear-gradient(150deg,var(--teal),#087A66)}
.av.b{background:linear-gradient(150deg,var(--amber),#A06800)}
.nm{font-size:14px;font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub{font-size:11.5px;color:var(--ink-3);font-weight:500;margin-top:1px}
.mny{font-family:var(--mono);font-size:13.5px;font-weight:500}
.mny.j{color:var(--green);font-weight:600}.mny.c{color:var(--red);font-weight:600}.mny.z{color:var(--ink-3)}

/* ========== FORMS ========== */
.formcard{max-width:600px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.field input,.field select{width:100%;height:48px;border:1.5px solid var(--line);border-radius:12px;background:var(--bg);padding:0 16px;font-size:15px;color:var(--ink);transition:all 0.2s}
.field input:focus,.field select:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px var(--teal-12)}
.field input.mono{font-family:var(--mono)}
.field input:disabled{background:var(--line-2);color:var(--ink-3);border-color:var(--line);cursor:not-allowed;opacity:1}
.field input.isi{background:#fff;border-color:var(--teal);border-width:1.5px}
.field input.isi:focus{box-shadow:0 0 0 3px var(--teal-12)}
.field label .tag{font-size:9px;font-weight:700;padding:2px 6px;border-radius:5px;margin-left:6px;vertical-align:middle}
.field label .tag.lock{background:var(--line-2);color:var(--ink-3)}
.field label .tag.edit{background:var(--green-12);color:var(--green)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.method{display:flex;gap:10px}
.mbtn{flex:1;height:48px;border-radius:10px;font-size:13.5px;font-weight:700;border:1.5px solid var(--line);background:var(--surface);color:var(--ink-2);transition:all 0.2s}
.mbtn.on{background:var(--navy);border-color:var(--navy);color:#fff}
.save{width:100%;height:50px;border:none;border-radius:12px;background:var(--navy);color:#fff;font-size:15px;font-weight:700;box-shadow:0 4px 14px rgba(27,42,61,.2);margin-top:6px;transition:all 0.2s}
.save:hover{background:var(--navy-light)}

/* ========== DASHBOARD: Balance Cards ========== */
.dash-balances{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px rgba(0,0,0,0.04),0 4px 12px rgba(0,0,0,0.02)}
.dash-balances-title{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:20px}
.bal-row{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--line-2)}
.bal-row:last-child{border-bottom:none}
.bal-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bal-icon.kas{background:var(--teal-12);color:var(--teal)}
.bal-icon.lpd{background:rgba(27,42,61,.08);color:var(--navy)}
.bal-info{flex:1;min-width:0}
.bal-label{font-size:13px;font-weight:600;color:var(--ink-3)}
.bal-value{font-family:var(--mono);font-size:28px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-top:2px}
.bal-spark{width:180px;height:50px;flex-shrink:0}
.bal-period{font-size:11px;color:var(--ink-3);font-weight:500;text-align:right;min-width:80px}

/* ========== DASHBOARD: Grid Layout ========== */
.dash-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:24px;align-items:start}

/* ========== DASHBOARD: Transactions Table ========== */
.tx-card{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.04),0 4px 12px rgba(0,0,0,0.02)}
.tx-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line-2)}
.tx-header h3{font-size:16px;font-weight:800;color:var(--ink)}
.tx-header a{font-size:13px;font-weight:600;color:var(--teal);text-decoration:none}
.tx-header a:hover{text-decoration:underline}
.tx-thead{display:grid;grid-template-columns:44px 1.2fr 0.7fr 0.8fr 1fr;gap:10px;padding:10px 22px;background:var(--navy);align-items:center}
.tx-thead span{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.tx-row{display:grid;grid-template-columns:44px 1.2fr 0.7fr 0.8fr 1fr;gap:10px;padding:14px 22px;border-bottom:1px solid var(--line-2);align-items:center;transition:background 0.15s}
.tx-row:last-child{border-bottom:none}
.tx-row:hover{background:var(--bg)}
.tx-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.tx-icon.masuk{background:var(--teal-12);color:var(--teal)}
.tx-icon.keluar{background:var(--red-12);color:var(--red)}
.tx-icon.netral{background:var(--line-2);color:var(--ink-3)}
.tx-title{font-size:13.5px;font-weight:700;color:var(--ink)}
.tx-sub{font-size:11px;color:var(--ink-3);font-weight:500;margin-top:1px}
.tx-date{font-size:12.5px;color:var(--ink-2);font-weight:500}
.tx-cat{font-size:12px;color:var(--ink-3);font-weight:500}
.tx-amount{font-family:var(--mono);font-size:13px;font-weight:700;text-align:right}
.tx-amount.in{color:var(--green)}
.tx-amount.out{color:var(--red)}

/* ========== DASHBOARD: Quick Actions ========== */
.qa-title{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:16px}
.qa-list{display:flex;flex-direction:column;gap:10px}
.qa-btn{display:flex;align-items:center;gap:14px;background:var(--navy);color:#fff;border:none;border-radius:14px;padding:14px 20px;font-size:14px;font-weight:700;width:100%;text-align:left;transition:all 0.2s;box-shadow:0 2px 8px rgba(27,42,61,.15)}
.qa-btn:hover{background:var(--navy-light);transform:translateY(-1px);box-shadow:0 4px 16px rgba(27,42,61,.25)}
.qa-btn:active{transform:scale(0.98)}
.qa-icon{width:40px;height:40px;border-radius:12px;background:rgba(14,165,138,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--teal-bright)}

/* ========== DASHBOARD: Arus Kas (Cash Flow) ========== */
.kr{display:flex;justify-content:space-between;padding:10px 20px;font-size:13px;align-items:center}
.kr .k{color:var(--ink-2)}.kr .v{font-family:var(--mono)}
.kr.hd{background:var(--navy);padding:10px 20px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.kr.hd .v{color:rgba(255,255,255,.9)}
.kr.hd .v.in{color:var(--teal-bright)}.kr.hd .v.out{color:#FF8A80}
.kr.sub{padding-left:32px;color:var(--ink-2);font-size:12.5px}
.kr.sisa{background:var(--teal-12);padding:14px 20px}.kr.sisa .k{color:var(--teal);font-weight:700}.kr.sisa .v{color:var(--teal);font-size:18px;font-weight:800}

/* ========== DASHBOARD: Stats ========== */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.stat{background:var(--surface);border:1px solid var(--line-2);border-radius:14px;padding:16px 18px;box-shadow:0 1px 3px rgba(0,0,0,0.03);transition:all 0.2s}
.stat:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,0.06)}
.stat .sl{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.stat .sv{font-family:var(--mono);font-size:16px;font-weight:700;margin-top:4px}
.stat .sv.warn{color:var(--amber);font-family:var(--sans);font-weight:800}

/* Old acts - keep for backward compat */
.acts{display:flex;flex-direction:column;gap:10px}
.act{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--surface);border:1.5px solid var(--line);border-radius:12px;padding:12px 20px;font-size:14px;font-weight:700;color:var(--ink-2);width:100%;text-align:center;transition:all 0.2s}
.act:hover{background:var(--bg);color:var(--ink)}
.act.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.act.primary:hover{background:var(--navy-light)}

/* Old grid/bal compat */
.bal2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.balc{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:20px 22px;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.balc.kas{border-left:4px solid var(--teal)}.balc.lpd{border-left:4px solid var(--navy)}
.balc .bl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.balc .bv{font-family:var(--mono);font-size:24px;font-weight:700;margin-top:8px;color:var(--ink)}
.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;align-items:start}

/* ========== BOTTOM NAV (Mobile) ========== */
.mlogout{display:none;font-size:12.5px;font-weight:600;color:rgba(255,255,255,.6);background:none;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:7px 16px}
.botnav{display:none;height:64px;align-items:center}
.botnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;color:var(--ink-3);text-decoration:none;font-size:10px;font-weight:600;min-width:0;transition:color 0.2s}
.botnav a .ic{display:flex;align-items:center;justify-content:center;width:48px;height:26px;border-radius:12px;transition:all 0.2s;color:var(--ink-3)}
.botnav a .ic svg,.botnav a .ic .material-symbols-rounded{width:20px;height:20px;font-size:20px}
.botnav a span.lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.botnav a.on{color:var(--teal);font-weight:700}
.botnav a.on .ic{background:var(--teal-12);color:var(--teal)}

/* ========== MODAL ========== */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{transform:scale(0.95) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

.modal{position:fixed;inset:0;background:rgba(27,42,61,.5);display:flex;align-items:center;justify-content:center;padding:20px;z-index:50;animation:fadeIn 0.2s ease-out forwards;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.modalbox{width:100%;max-width:460px;background:var(--surface);border-radius:20px;padding:24px;max-height:90vh;overflow:auto;animation:popIn 0.3s cubic-bezier(0.16,1,0.3,1) forwards}
.modalbox h3{font-size:18px;font-weight:800;margin-bottom:16px}

/* ========== FAB Speed Dial ========== */
.fab-container{position:fixed;right:16px;bottom:24px;z-index:45;display:flex;flex-direction:column;align-items:flex-end;gap:0}
.fab-btn{width:52px;height:52px;border-radius:16px;background:var(--teal);color:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(14,165,138,.35);cursor:pointer;transition:all 0.3s cubic-bezier(0.16,1,0.3,1);flex-shrink:0}
.fab-btn:hover{background:var(--teal-bright);transform:translateY(-2px)}
.fab-btn:active{transform:scale(0.92)}
.fab-btn .fab-icon{font-size:24px;color:#fff;transition:transform 0.35s cubic-bezier(0.16,1,0.3,1);display:block;line-height:1}
.fab-btn.open .fab-icon{transform:rotate(45deg)}
.fab-btn.open{background:var(--navy);box-shadow:0 6px 20px rgba(15,23,42,.35)}

/* Speed Dial Items */
.fab-menu{display:flex;flex-direction:column;align-items:flex-end;gap:10px;margin-bottom:12px;pointer-events:none;overflow:hidden}
.fab-menu-item{display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(20px) scale(0.85);transition:opacity 0.25s ease, transform 0.25s cubic-bezier(0.16,1,0.3,1);pointer-events:none}
.fab-menu-item:nth-child(1){transition-delay:0ms}
.fab-menu-item:nth-child(2){transition-delay:0ms}
.fab-menu-item:nth-child(3){transition-delay:0ms}
.fab-menu-item:nth-child(4){transition-delay:0ms}
.fab-menu-item:nth-child(5){transition-delay:0ms}
.fab-menu.open .fab-menu-item{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.fab-menu.open .fab-menu-item:nth-child(5){transition-delay:30ms}
.fab-menu.open .fab-menu-item:nth-child(4){transition-delay:60ms}
.fab-menu.open .fab-menu-item:nth-child(3){transition-delay:90ms}
.fab-menu.open .fab-menu-item:nth-child(2){transition-delay:120ms}
.fab-menu.open .fab-menu-item:nth-child(1){transition-delay:150ms}
.fab-menu-label{background:var(--surface);color:var(--ink);font-size:12px;font-weight:700;padding:6px 12px;border-radius:10px;white-space:nowrap;box-shadow:0 3px 12px rgba(0,0,0,0.12);border:1px solid var(--line-2);user-select:none}
.fab-menu-btn{width:44px;height:44px;border-radius:14px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.15);transition:all 0.2s;flex-shrink:0}
.fab-menu-btn:active{transform:scale(0.90)}
.fab-menu-btn.c1{background:#0f172a}
.fab-menu-btn.c2{background:#2563eb}
.fab-menu-btn.c3{background:#7c3aed}
.fab-menu-btn.c4{background:#d97706}
.fab-menu-btn.c5{background:#dc2626}
.fab-menu-btn .material-symbols-rounded{font-size:20px;color:#fff}

/* FAB overlay backdrop */
.fab-overlay{display:none;position:fixed;inset:0;z-index:44;background:rgba(0,0,0,0)}
.fab-overlay.show{display:block}

/* Active press states */
.btn:active,.act:active,.blnbtn:active,.mbtn:active,.loginbtn:active{transform:scale(0.97)}
.lrow:active{background:var(--bg)!important}

/* ========== SEARCH ========== */
.acsearch{position:relative}
.acsearch input{width:100%;height:48px;border:1.5px solid var(--line);border-radius:12px;background:var(--bg);padding:0 16px;font-size:15px;color:var(--ink)}
.acsearch input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px var(--teal-12)}
.acsearch.picked input{background:var(--teal-12);border-color:var(--teal);font-weight:600;color:var(--navy)}
.aclist{position:absolute;top:52px;left:0;right:0;max-height:200px;overflow-y:auto;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 30px -10px rgba(27,42,61,.2);z-index:10}
.aclist.hidden{display:none}
.acitem{padding:12px 16px;font-size:14px;cursor:pointer;border-bottom:1px solid var(--line-2);display:flex;justify-content:space-between;align-items:center}
.acitem:last-child{border-bottom:none}
.acitem:hover,.acitem.hl{background:var(--teal-12)}
.acitem .id{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.acempty{padding:14px;text-align:center;color:var(--ink-3);font-size:13px}

/* ========== GRID BULAN ========== */
.blnyear{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.blngrid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.blnbtn{height:44px;border:1.5px solid var(--line);border-radius:12px;background:var(--surface);font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;position:relative;transition:all 0.2s}
.blnbtn.on{background:var(--navy);border-color:var(--navy);color:#fff}
.blnbtn.paid{background:var(--teal-12);border-color:var(--teal);color:var(--teal)}
.blnbtn.paid::after{content:"✓";position:absolute;top:2px;right:5px;font-size:9px}
.blnbtn.hapus{background:var(--red-12);border-color:var(--red);color:var(--red)}
.blnbtn.hapus::after{content:"✕";position:absolute;top:2px;right:5px;font-size:9px}
.blnlegend{display:flex;gap:14px;flex-wrap:wrap;margin-top:9px;font-size:11px;color:var(--ink-2)}
.blnlegend span{display:flex;align-items:center;gap:5px}
.blnlegend i{width:11px;height:11px;border-radius:3px;display:inline-block}

/* ========== TOAST ========== */
.toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:14px 22px;border-radius:14px;font-size:13.5px;font-weight:600;box-shadow:0 14px 34px -8px rgba(27,42,61,.4);z-index:100;opacity:0;transition:opacity .3s,transform .3s;max-width:88%;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--red)}
.rchip{font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:10px;border:1.5px solid var(--teal);background:var(--teal-12);color:var(--teal);cursor:pointer}
.rchip:hover{background:var(--teal);color:#fff}
.nunggakbox{padding:12px 16px;border-radius:12px;font-size:12.5px;font-weight:600;margin-bottom:14px}
.nunggakbox.warn{background:var(--amber-12);color:var(--amber)}
.nunggakbox.ok{background:var(--green-12);color:var(--green)}

/* ========== PAGINATION ========== */
.pgbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg);border-top:1px solid var(--line-2);border-radius:0 0 16px 16px}
.pgbar span{font-size:12px;color:var(--ink-2);font-weight:600}
.pgbtn{display:flex;gap:6px}
.pgbtn button{height:34px;min-width:34px;padding:0 10px;border:1.5px solid var(--line);border-radius:8px;background:var(--surface);font-size:12px;font-weight:700;color:var(--ink-2);cursor:pointer}
.pgbtn button.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.pgbtn button:disabled{opacity:.35;cursor:default}

/* ========== RESPONSIVE ========== */
@media (max-width:760px){
  h1{font-size:22px}
  .page-title{font-size:22px}
  .grid2,.bal2,.dash-grid{grid-template-columns:1fr}
  .navbar{display:none}
  .dlogout{display:none!important}
  .mlogout{display:inline-flex}
  .topbar-inner{padding:10px 14px}
  .brand-sub{display:none}
  .brand-name{font-size:13px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mark{width:32px;height:32px;border-radius:10px}
  .topbar-avatar{width:32px;height:32px;font-size:11px}
  .mlogout{padding:5px 10px}
  .wrap{padding:0 14px}
  .content{padding:16px 0 100px}
  .lhead,.tx-thead{display:none}
  .lrow{grid-template-columns:1fr!important;gap:7px}
  .lrow .r{justify-self:start;text-align:left}
  .celllab::before{content:attr(data-l) "  ";color:var(--ink-3);font-weight:600;font-size:11px}
  .tx-row{grid-template-columns:36px 1fr auto;gap:10px}
  .tx-row .tx-date,.tx-row .tx-cat{display:none}
  .bal-spark{display:none}
  .bal-period{display:none}
  .bal-value{font-size:22px}
  .bal-icon{width:40px;height:40px;border-radius:12px}
  .botnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:40;background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--line-2);box-shadow:0 -4px 16px rgba(0,0,0,0.06);padding-bottom:env(safe-area-inset-bottom)}
  .modal{align-items:flex-end;padding:0}
  .modalbox{max-width:100%;border-radius:20px 20px 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom));max-height:85vh;animation:slideUp 0.35s cubic-bezier(0.16,1,0.3,1) forwards}
  .stats{grid-template-columns:1fr}
  .qa-list{flex-direction:row;flex-wrap:wrap}
  .qa-btn{flex:1;min-width:140px;flex-direction:column;text-align:center;padding:16px 12px;gap:10px}
  .fab-container{bottom:calc(68px + env(safe-area-inset-bottom));right:14px}
}

/* ========== PRINT ========== */
@media print{
  .topbar,.navbar,.nav,.logout,.botnav,.fab-container,.btn,button,.acts,.seclabel,form,.no-print,.qa-list{display:none!important}
  body{background:#fff!important;color:#000!important}
  .card,.ledger,.tx-card,.dash-balances{border:none!important;box-shadow:none!important}
  .kr.hd{background:#eee!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .kr.sisa{background:#ddd!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .kr.sisa .k,.kr.sisa .v{color:#000!important}
}
