:root{--primary: #1D5E47;--teal: #2CC5A0;--teal-light: #E6F8F3;--masuk: #10B981;--masuk-pale: #D1FAE5;--keluar: #F43F5E;--keluar-pale: #FFE4E6;--bg: #F2F7F5;--card: #FFFFFF;--text: #1A1A2E;--muted: #94A3B8;--border: #E2EAE6;--green-mid: #2d6a4f;--green-pale: #d8f3dc;--green-light: #40916c;--radius: 14px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}.up-root{display:flex;flex-direction:column;min-height:100vh;max-width:480px;margin:0 auto;background:var(--bg)}.up-main{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:80px}.up-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;align-items:center;background:#fffffff7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.06);z-index:100;padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}.up-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;color:#b0bec5;transition:color .2s;padding:4px 0;-webkit-tap-highlight-color:transparent}.up-nav-btn svg{width:22px;height:22px;stroke-width:1.8}.up-nav-btn span{font-size:10px;font-weight:600}.up-nav-btn.active{color:var(--primary)}.up-nav-add{flex:0 0 64px}.up-nav-add-circle{width:52px;height:52px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #2cc5a066;margin-top:-20px}.up-nav-add-circle svg{width:26px;height:26px;color:#fff;stroke-width:2.5}.dash-root{padding:0 0 8px}.dash-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 0}.dash-brand{display:flex;align-items:center;gap:8px}.dash-brand-icon{font-size:22px}.dash-brand-name{font-size:18px;font-weight:800;color:var(--primary)}.dash-bell{font-size:20px;cursor:pointer}.dash-refresh-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--teal-light);color:var(--primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.dash-refresh-btn:active{transform:rotate(180deg);background:var(--teal);color:#fff}.saldo-card-new{background:linear-gradient(135deg,#1d5e47,#0f3d2e 60%,#1a4d3a);border-radius:24px;margin:16px;padding:24px 22px 20px;color:#fff;position:relative;overflow:hidden}.saldo-card-new:before{content:"";position:absolute;top:-30px;right:-30px;width:150px;height:150px;border-radius:50%;background:#ffffff0a}.sc-label{font-size:10px;font-weight:700;letter-spacing:1.5px;opacity:.6;margin-bottom:8px}.sc-value{font-size:clamp(24px,7vw,32px);font-weight:900;letter-spacing:-.5px;margin-bottom:20px}.sc-dots{display:flex;align-items:center;gap:5px}.sc-dots span{width:8px;height:8px;border-radius:50%;background:#ffffff59}.sc-dots-num{margin-left:auto;font-size:13px;font-weight:600;opacity:.7;letter-spacing:1px}.period-tabs{display:flex;gap:6px;padding:0 16px;margin-bottom:14px}.period-tab{padding:8px 18px;border-radius:20px;border:none;font-size:13px;font-weight:600;cursor:pointer;background:#fff;color:var(--muted);transition:all .2s;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 4px #0000000d}.period-tab.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #1d5e474d}.dash-stats{background:#fff;border-radius:20px;margin:0 16px 16px;padding:16px 20px;display:flex;align-items:center;box-shadow:0 2px 12px #0000000d}.dash-stat{flex:1;text-align:center}.ds-arrow{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;margin:0 auto 6px}.dash-stat.masuk .ds-arrow{background:var(--masuk-pale);color:var(--masuk)}.dash-stat.keluar .ds-arrow{background:var(--keluar-pale);color:var(--keluar)}.ds-label{font-size:11px;color:var(--muted);font-weight:600;margin-bottom:4px}.dash-stat.masuk .ds-value{font-size:16px;font-weight:800;color:var(--masuk)}.dash-stat.keluar .ds-value{font-size:16px;font-weight:800;color:var(--keluar)}.ds-divider{width:1px;background:var(--border);height:48px;margin:0 12px}.dash-chart-card{background:#fff;border-radius:20px;margin:0 16px 16px;padding:16px;box-shadow:0 2px 12px #0000000d}.dcc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.dcc-title{font-size:15px;font-weight:700}.dcc-legend{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:600}.dcc-dot-k{width:8px;height:8px;border-radius:50%;background:var(--keluar);display:inline-block}.dcc-dot-m{width:8px;height:8px;border-radius:50%;background:var(--masuk);display:inline-block;opacity:.4}.dcc-legend-txt{font-size:11px}.dcc-lbl-today{color:var(--primary);font-weight:800}.dcc-bars{display:flex;align-items:flex-end;gap:5px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.dcc-bars::-webkit-scrollbar{display:none}.dcc-col{flex:0 0 auto;min-width:28px;flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.dcc-bar-wrap{width:100%;display:flex;align-items:flex-end;gap:2px;height:60px}.dcc-bar-k{flex:1;border-radius:5px 5px 0 0;background:var(--keluar);transition:height .4s ease}.dcc-bar-m{flex:1;border-radius:5px 5px 0 0;background:#10b9814d;transition:height .4s ease}.dcc-col{cursor:pointer;-webkit-tap-highlight-color:transparent}.dcc-col-sel .dcc-bar-k{box-shadow:0 0 0 2px var(--keluar)}.dcc-col-sel .dcc-bar-m{box-shadow:0 0 0 2px var(--masuk)}.dcc-tip-bar{display:flex;align-items:center;gap:8px;background:#fff8f8;border:1px solid #FFE4E6;border-radius:10px;padding:8px 10px;margin-bottom:10px;font-size:12px}.dtb-lbl{font-weight:700;color:var(--text);min-width:60px;font-size:11px}.dtb-vals{flex:1;display:flex;gap:10px;flex-wrap:wrap}.dtb-m{font-weight:700;color:var(--masuk)}.dtb-k{font-weight:700;color:var(--keluar)}.dtb-empty{color:var(--muted);font-size:11px}.dtb-close{background:none;border:none;font-size:16px;color:var(--muted);cursor:pointer;padding:0;line-height:1;flex-shrink:0}.dcc-lbl{font-size:9px;color:var(--muted);font-weight:600}.dash-section{padding:0 16px}.ds-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ds-hd span:first-child{font-size:15px;font-weight:700}.ds-hd-link{font-size:12px;color:var(--teal);font-weight:600;cursor:pointer}.hist-root{padding:0 0 8px}.hist-header{padding:20px 16px 0}.hist-title{font-size:22px;font-weight:800}.hist-search-wrap{padding:14px 16px 0}.hist-search{display:flex;align-items:center;gap:10px;background:#fff;border-radius:16px;padding:10px 14px;box-shadow:0 2px 8px #0000000d}.hs-icon{width:18px;height:18px;color:var(--muted);flex-shrink:0}.hs-input{flex:1;border:none;outline:none;font-size:14px;color:var(--text);background:none}.hs-input::placeholder{color:var(--muted)}.hist-chips{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;scrollbar-width:none}.hist-chips::-webkit-scrollbar{display:none}.hchip{flex-shrink:0;padding:7px 16px;border-radius:20px;border:none;background:#fff;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 1px 4px #0000000d;-webkit-tap-highlight-color:transparent}.hchip.active{background:var(--primary);color:#fff}.hist-list{padding:0 16px}.hist-group{margin-bottom:20px}.hist-group-label{font-size:10px;font-weight:800;color:var(--muted);letter-spacing:1px;margin-bottom:8px}.add-root{padding:0 0 20px}.add-header{padding:20px 16px 0}.add-title{font-size:22px;font-weight:800}.add-toggle{display:flex;margin:14px 16px;background:#e8f0ed;border-radius:20px;padding:4px}.add-toggle-btn{flex:1;padding:12px;border-radius:16px;border:none;font-size:14px;font-weight:700;cursor:pointer;background:none;color:var(--muted);transition:all .2s;-webkit-tap-highlight-color:transparent}.add-toggle-btn.active-masuk{background:#fff;color:var(--masuk);box-shadow:0 2px 8px #0000001a}.add-toggle-btn.active-keluar{background:#fff;color:var(--keluar);box-shadow:0 2px 8px #0000001a}.add-card{background:#fff;border-radius:24px;margin:0 16px 16px;padding:20px;box-shadow:0 2px 16px #0000000f}.add-field{margin-bottom:20px}.add-field:last-child{margin-bottom:0}.add-field-label{font-size:10px;font-weight:800;color:var(--muted);letter-spacing:1px;margin-bottom:10px}.add-amt-wrap{display:flex;align-items:center;gap:10px;background:#f5f8f6;border-radius:14px;padding:14px 16px}.add-rp{font-size:18px;font-weight:800;color:var(--muted)}.add-amt-input{flex:1;border:none;outline:none;font-size:26px;font-weight:900;background:none;color:var(--text)}.add-amt-input::placeholder{color:#cbd5e1}.add-cat-scroll{display:grid;grid-auto-flow:column;grid-template-rows:repeat(3,auto);gap:8px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}.add-cat-scroll::-webkit-scrollbar{display:none}.add-cat-chip{flex-shrink:0;white-space:nowrap;padding:7px 13px;border-radius:20px;border:1.5px solid var(--border);background:#fff;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.add-cat-chip.active{font-weight:700}.add-date-wrap{display:flex;align-items:center;gap:12px;background:#f5f8f6;border-radius:14px;padding:14px 16px}.add-date-icon{font-size:18px}.add-date-input{flex:1;border:none;outline:none;font-size:15px;font-weight:600;background:none;color:var(--text)}.add-notes-input{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid var(--border);font-size:15px;outline:none;color:var(--text);background:#f5f8f6;transition:border-color .2s;-webkit-appearance:none}.add-notes-input:focus{border-color:var(--teal);background:#fff}.add-save-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:calc(100% - 32px);margin:0 16px;padding:18px;border-radius:20px;border:none;font-size:16px;font-weight:800;cursor:pointer;color:#fff;transition:all .2s;-webkit-tap-highlight-color:transparent}.add-save-btn.masuk{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 6px 20px #10b98159}.add-save-btn.keluar{background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 6px 20px #f43f5e59}.add-save-btn.disabled{background:#e2e8f0;color:#94a3b8;box-shadow:none}.add-save-btn:not(.disabled):active{transform:scale(.98)}.add-save-icon{font-size:18px}.add-reset-btn{display:block;margin:10px auto 0;background:none;border:none;font-size:13px;color:var(--muted);cursor:pointer;font-weight:600}.rep-root{padding:0 0 8px}.rep-header{display:flex;justify-content:space-between;align-items:center;padding:20px 16px 0;margin-bottom:14px}.rep-header-sub{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:1px;margin-bottom:4px}.rep-header-title{font-size:20px;font-weight:800}.rep-month-nav{display:flex;gap:8px}.rep-nav-btn{width:36px;height:36px;border-radius:50%;border:none;background:#fff;font-size:18px;cursor:pointer;color:var(--primary);box-shadow:0 2px 8px #00000014;display:grid;place-items:center;-webkit-tap-highlight-color:transparent}.rep-card{background:#fff;border-radius:20px;margin:0 16px 14px;padding:18px;box-shadow:0 2px 12px #0000000d}.rep-card-title{font-size:15px;font-weight:700;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}.rep-card-total{font-size:13px;color:var(--keluar);font-weight:700}.rep-donut-wrap{display:flex;align-items:center;gap:16px}.rep-donut-svg{width:130px;height:130px;flex-shrink:0}.rep-donut-legend{flex:1}.rep-legend-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.rep-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.rep-legend-label{flex:1;font-size:12px;font-weight:600;color:var(--text)}.rep-legend-pct{font-size:12px;font-weight:700;color:var(--muted)}.rep-week-bars{display:flex;align-items:flex-end;gap:12px;padding:4px 0 0}.rep-week-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.rep-week-bar-wrap{display:flex;align-items:flex-end;justify-content:center;width:100%}.rep-week-bar{width:100%;background:var(--teal);border-radius:8px 8px 0 0;transition:height .4s ease}.rep-week-lbl{font-size:10px;color:var(--muted);font-weight:700}.rep-summary-row{display:flex;gap:10px;padding:0 16px;margin-bottom:10px}.rep-sum-card{flex:1;background:#fff;border-radius:16px;padding:14px;box-shadow:0 2px 8px #0000000d}.rsc-label{font-size:11px;color:var(--muted);font-weight:600;margin-bottom:6px}.rep-sum-card.masuk .rsc-value{font-size:15px;font-weight:800;color:var(--masuk)}.rep-sum-card.keluar .rsc-value{font-size:15px;font-weight:800;color:var(--keluar)}.rep-net-card{margin:0 16px 14px;border-radius:16px;padding:14px 18px;display:flex;justify-content:space-between;align-items:center}.rep-net-card.pos{background:var(--masuk-pale)}.rep-net-card.neg{background:var(--keluar-pale)}.rnc-label{font-size:13px;color:var(--muted);font-weight:600}.rep-net-card.pos .rnc-value{font-size:17px;font-weight:800;color:#065f46}.rep-net-card.neg .rnc-value{font-size:17px;font-weight:800;color:#9f1239}.rep-cat-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.rep-cat-icon-wrap{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-size:18px;flex-shrink:0}.rep-cat-body{flex:1;min-width:0}.rep-cat-meta{display:flex;justify-content:space-between;margin-bottom:5px}.rep-cat-name{font-size:13px;font-weight:600}.rep-cat-amt{font-size:12px;font-weight:700;color:var(--keluar)}.rep-cat-track{height:5px;background:#f0f4f3;border-radius:3px;overflow:hidden}.rep-cat-fill{height:100%;border-radius:3px}.rep-cat-pct{font-size:12px;font-weight:700;color:var(--muted);flex-shrink:0}.prof-root{padding:0 0 20px}.prof-header{background:linear-gradient(135deg,#1d5e47,#0f3d2e);padding:40px 20px 30px;text-align:center;color:#fff}.prof-avatar{width:72px;height:72px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;margin:0 auto 12px;border:3px solid rgba(255,255,255,.3)}.prof-name{font-size:20px;font-weight:800;margin-bottom:4px}.prof-phone{font-size:13px;opacity:.7}.prof-stats{display:flex;align-items:center;background:#fff;border-radius:20px;margin:-20px 16px 16px;padding:20px;box-shadow:0 4px 20px #0000001a}.prof-stat{flex:1;text-align:center}.prof-stat-val{font-size:18px;font-weight:800;color:var(--text);margin-bottom:4px}.prof-stat-val.masuk{color:var(--masuk)}.prof-stat-val.keluar{color:var(--keluar)}.prof-stat-lbl{font-size:10px;color:var(--muted);font-weight:600}.prof-stat-div{width:1px;background:var(--border);height:36px;margin:0 8px}.prof-saldo-card{background:#fff;border-radius:20px;margin:0 16px 14px;padding:20px;text-align:center;box-shadow:0 2px 12px #0000000d}.psc-label{font-size:11px;color:var(--muted);font-weight:600;margin-bottom:8px}.psc-value{font-size:26px;font-weight:900;margin-bottom:8px}.psc-value.pos{color:var(--masuk)}.psc-value.neg{color:var(--keluar)}.psc-sub{font-size:12px;color:var(--muted)}.prof-info-card{background:#fff;border-radius:20px;margin:0 16px 14px;padding:4px 0;box-shadow:0 2px 12px #0000000d}.pic-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border)}.pic-row:last-child{border-bottom:none}.pic-icon{font-size:20px;flex-shrink:0}.pic-label{font-size:11px;color:var(--muted);font-weight:600;margin-bottom:2px}.pic-value{font-size:14px;font-weight:600}.prof-note{background:#fff;border-radius:20px;margin:0 16px;padding:18px;box-shadow:0 2px 12px #0000000d}.pn-title{font-size:14px;font-weight:700;margin-bottom:10px}.pn-body{font-size:13px;line-height:1.7;color:var(--muted)}.tx-row-new{display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;padding:12px 14px;margin-bottom:8px;box-shadow:0 1px 6px #0000000a;border:1.5px solid transparent;transition:border-color .2s}.tx-row-new.confirming{border-color:var(--keluar-pale);background:#fff8f8}.txn-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-size:20px;flex-shrink:0}.txn-body{flex:1;min-width:0}.txn-desc{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-meta{font-size:11px;color:var(--muted);margin-top:2px}.txn-amount{font-size:13px;font-weight:800;flex-shrink:0;white-space:nowrap}.txn-amount.masuk{color:var(--masuk)}.txn-amount.keluar{color:var(--keluar)}.txn-actions{display:flex;gap:2px;flex-shrink:0}.txn-btn{background:none;border:none;font-size:15px;cursor:pointer;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;-webkit-tap-highlight-color:transparent}.txn-btn.confirm-yes{background:var(--keluar);color:#fff;font-size:13px;font-weight:800}.txn-btn.confirm-no{background:#f1f3f5;color:var(--muted);font-size:13px;font-weight:800}.am-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:300;display:flex;align-items:flex-end;justify-content:center;animation:fadeBg .22s ease}.am-sheet{width:100%;max-width:480px;background:#fff;border-radius:28px 28px 0 0;padding:12px 20px 44px;max-height:93vh;overflow-y:auto;animation:slideUp .36s cubic-bezier(.32,.72,0,1)}.am-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 20px}.am-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.am-header-title{font-size:18px;font-weight:800;color:var(--text);margin-bottom:2px}.am-header-sub{font-size:11px;color:var(--muted)}.am-close-btn{width:38px;height:38px;border-radius:50%;border:none;background:var(--bg);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 4px #00000014}.am-close-btn:hover{background:#e2e8f0;color:var(--text)}.am-close-btn:active{transform:scale(.92)}.am-toggle{display:flex;background:var(--bg);border-radius:18px;padding:4px;gap:4px;margin-bottom:20px}.am-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:11px 8px;border-radius:14px;border:none;font-size:13px;font-weight:700;cursor:pointer;background:none;color:var(--muted);transition:all .2s;-webkit-tap-highlight-color:transparent}.am-active-masuk{background:#fff!important;color:var(--masuk)!important;box-shadow:0 2px 8px #0000001a}.am-active-keluar{background:#fff!important;color:var(--keluar)!important;box-shadow:0 2px 8px #0000001a}.am-amount-wrap{display:flex;align-items:center;gap:10px;background:var(--bg);border-radius:18px;padding:16px 18px;margin-bottom:20px}.am-rp{font-size:22px;font-weight:800;color:var(--muted)}.am-amount-input{flex:1;border:none;outline:none;font-size:30px;font-weight:900;background:none;color:var(--text);width:0}.am-amount-input::placeholder{color:#cbd5e1}.am-label{font-size:10px;font-weight:800;color:var(--muted);letter-spacing:1px;margin-bottom:10px}.am-date-wrap{display:flex;align-items:center;gap:10px;background:var(--bg);border-radius:14px;padding:13px 16px;margin-bottom:16px}.am-date-input{flex:1;border:none;outline:none;font-size:14px;font-weight:600;background:none;color:var(--text)}.am-notes-input{width:100%;padding:13px 16px;border-radius:14px;border:1.5px solid var(--border);font-size:14px;outline:none;color:var(--text);background:var(--bg);margin-bottom:20px;transition:border-color .2s;-webkit-appearance:none}.am-notes-input:focus{border-color:var(--teal);background:#fff}.am-save{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:17px;border-radius:20px;border:none;font-size:16px;font-weight:800;cursor:pointer;color:#fff;transition:all .2s;-webkit-tap-highlight-color:transparent}.am-save.pengeluaran{background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 6px 20px #f43f5e59}.am-save.pemasukan{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 6px 20px #10b98159}.am-save.disabled{background:var(--border);color:var(--muted);box-shadow:none;cursor:not-allowed}.am-save:not(.disabled):active{transform:scale(.98)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeBg .2s ease}.modal-sheet{width:100%;max-width:480px;background:#fff;border-radius:28px 28px 0 0;padding:12px 20px 40px;animation:slideUp .3s cubic-bezier(.32,.72,0,1);max-height:90vh;overflow-y:auto}.modal-pill{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}.modal-title{font-size:18px;font-weight:800;margin-bottom:20px}.modal-btns{display:flex;gap:10px;margin-top:20px}.modal-btn-cancel{flex:1;padding:15px;border-radius:16px;border:none;font-size:15px;font-weight:700;cursor:pointer;background:#f1f5f9;color:var(--muted)}.modal-btn-save{flex:2;padding:15px;border-radius:16px;border:none;font-size:15px;font-weight:700;cursor:pointer;color:#fff}.modal-btn-save.pengeluaran{background:var(--keluar)}.modal-btn-save.pemasukan{background:var(--masuk)}.modal-btn-save:disabled{background:var(--border)!important;color:#b0bec5;cursor:not-allowed}.empty-st{text-align:center;padding:32px 20px}.empty-msg{font-size:14px;color:var(--muted);font-weight:600;margin-bottom:6px}.empty-sub{font-size:12px;color:#cbd5e1}.up-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--muted);font-size:14px;font-weight:600}.up-spinner{width:36px;height:36px;border:3.5px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .75s linear infinite}.up-notfound{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px}.up-nf-emoji{font-size:64px;margin-bottom:16px}.up-nf-txt{font-size:16px;font-weight:700}.up-nf-sub{font-size:13px;color:#b0bec5;margin-top:8px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeBg{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.kp-root{min-height:100vh;background:#f2f7f5;padding:32px 16px 60px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a2e}.kp-container{max-width:720px;margin:0 auto}.kp-header{text-align:center;margin-bottom:40px}.kp-brand{display:inline-flex;align-items:center;gap:8px;background:#1d5e47;color:#fff;padding:8px 18px;border-radius:20px;font-size:14px;font-weight:700;margin-bottom:20px}.kp-brand-icon{font-size:18px}.kp-brand-name{font-size:14px}.kp-title{font-size:clamp(22px,5vw,30px);font-weight:900;color:#1d5e47;margin-bottom:8px;line-height:1.2}.kp-updated{font-size:13px;color:#94a3b8}.kp-body{display:flex;flex-direction:column;gap:16px}.kp-section{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 2px 12px #0000000d}.kp-section-header{display:flex;align-items:center;gap:14px;padding:18px 24px 0}.kp-section-num{width:32px;height:32px;border-radius:50%;background:#ebf8f4;color:#1d5e47;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0}.kp-section-title{font-size:16px;font-weight:800;color:#1a1a2e}.kp-section-body{padding:14px 24px 20px;display:flex;flex-direction:column;gap:10px}.kp-section-body p{font-size:14px;line-height:1.7;color:#374151}.kp-section-body ul{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.kp-section-body li{font-size:14px;line-height:1.6;color:#374151}.kp-list-no li{color:#e53e3e}.kp-list-no li::marker{content:"✗ "}.kp-note{font-size:13px!important;color:#6b7280!important;font-style:italic}.kp-highlight{display:flex;align-items:flex-start;gap:10px;background:#ebf8f4;border-radius:12px;padding:12px 16px;font-size:14px;line-height:1.6;color:#1d5e47;border:1px solid #2CC5A040}.kp-highlight-icon{font-size:18px;flex-shrink:0;margin-top:1px}.kp-contact{background:#fff;border-radius:20px;padding:20px 24px;box-shadow:0 2px 12px #0000000d;border-top:3px solid #2CC5A0}.kp-contact-title{font-size:16px;font-weight:800;color:#1a1a2e;margin-bottom:14px}.kp-contact-body{display:flex;flex-direction:column;gap:12px}.kp-contact-item{display:flex;align-items:center;gap:14px;padding:12px 16px;background:#f2f7f5;border-radius:14px;text-decoration:none;color:inherit;transition:background .15s}.kp-contact-item:hover{background:#ebf8f4}.kp-contact-icon{font-size:22px;flex-shrink:0}.kp-contact-label{font-size:11px;font-weight:700;color:#94a3b8;letter-spacing:.5px;margin-bottom:2px}.kp-contact-value{font-size:14px;font-weight:600;color:#1d5e47}.kp-footer{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:40px;font-size:13px;color:#94a3b8;font-weight:600}.adm-layout{display:flex;min-height:100vh;background:#f2f6f4;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.adm-sidebar{width:220px;min-height:100vh;background:#fff;border-right:1px solid #E2EAE6;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;flex-shrink:0}.adm-brand{display:flex;align-items:center;gap:10px;padding:24px 20px 20px;border-bottom:1px solid #F0F4F2}.adm-brand-icon{width:36px;height:36px;background:#1d5e47;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.adm-brand-name{font-size:15px;font-weight:800;color:#1a1a2e}.adm-nav{padding:16px 12px;flex:1}.adm-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600;color:#94a3b8;cursor:pointer;margin-bottom:4px;transition:all .15s}.adm-nav-active{background:#ebf8f4;color:#1d5e47!important;font-weight:700}.adm-nav-disabled{cursor:default}.adm-nav-item:not(.adm-nav-disabled):not(.adm-nav-active):hover{background:#f5f9f7;color:#1d5e47}.adm-sidebar-footer{padding:16px;border-top:1px solid #F0F4F2}.adm-footer-user{display:flex;align-items:center;gap:10px;margin-bottom:12px}.adm-footer-avatar{width:36px;height:36px;border-radius:50%;background:#1d5e47;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}.adm-footer-name{font-size:13px;font-weight:700;color:#1a1a2e}.adm-footer-role{font-size:10px;font-weight:600;color:#94a3b8;letter-spacing:.5px}.adm-sidebar-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px;border-radius:10px;border:1.5px solid #E2EAE6;background:none;color:#64748b;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.adm-sidebar-logout:hover{background:#fff0f0;border-color:#f43f5e;color:#f43f5e}.adm-main{flex:1;min-width:0;overflow-y:auto}.adm-topbar{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 0;margin-bottom:24px;gap:16px}.adm-page-title{font-size:22px;font-weight:800;color:#1a1a2e}.adm-topbar-right{display:flex;align-items:center;gap:10px}.adm-search-box{display:flex;align-items:center;gap:8px;background:#fff;border-radius:10px;border:1.5px solid #E2EAE6;padding:8px 12px;width:220px}.adm-search-input{border:none;outline:none;font-size:13px;color:#1a1a2e;background:none;width:100%}.adm-search-input::placeholder{color:#b0bec5}.adm-topbar-icon-btn{width:38px;height:38px;border-radius:10px;border:1.5px solid #E2EAE6;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.adm-topbar-icon-btn:hover{border-color:#1d5e47;color:#1d5e47}.adm-refresh-btn{display:flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;border:none;background:#1d5e47;color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s}.adm-refresh-btn:hover{background:#164d3a}.adm-content{padding:0 28px 40px}.adm-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.adm-stat-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 6px #0000000d}.adm-stat-icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}.adm-stat-value{font-size:28px;font-weight:900;color:#1a1a2e;margin-bottom:4px}.adm-stat-label{font-size:12px;font-weight:600;color:#94a3b8}.adm-section{background:#fff;border-radius:16px;box-shadow:0 1px 6px #0000000d;overflow:hidden}.adm-section-hd{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #F0F4F2}.adm-section-title{font-size:16px;font-weight:800;color:#1a1a2e}.adm-section-count{font-size:12px;color:#94a3b8;font-weight:600}.adm-table-wrap{overflow-x:auto}.adm-table{width:100%;border-collapse:collapse}.adm-table th{text-align:left;padding:12px 20px;font-size:11px;font-weight:700;color:#94a3b8;letter-spacing:.8px;border-bottom:1px solid #F0F4F2}.adm-table td{padding:14px 20px;font-size:13px;color:#1a1a2e;border-bottom:1px solid #F8FAF9}.adm-table tr:last-child td{border-bottom:none}.adm-table tbody tr:hover td{background:#fafcfb}.adm-user-cell{display:flex;align-items:center;gap:10px}.adm-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0}.adm-user-name{font-weight:600}.adm-phone{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:#64748b}.adm-tx-count{font-weight:700;color:#64748b}.adm-empty{text-align:center;padding:40px;color:#94a3b8}.adm-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}.adm-badge-active{background:#d1fae5;color:#065f46}.adm-badge-pending{background:#fef3c7;color:#92400e}.adm-badge-warn{background:#ffe4e6;color:#9f1239}.adm-link{display:inline-flex;align-items:center;gap:4px;color:#1d5e47;text-decoration:none;font-weight:700;font-size:13px;transition:color .15s}.adm-link:hover{color:#2cc5a0}.rep-export-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:10px;border:none;background:var(--primary);color:#fff;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}.rep-export-btn:hover{background:#164d3a}.rep-export-btn:active{transform:scale(.97)}.exp-year-row{display:flex;gap:8px;margin-bottom:4px}.exp-year-btn{flex:1;padding:10px;border-radius:12px;border:2px solid var(--border);background:#fff;font-size:15px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .15s}.exp-year-btn.active{border-color:var(--primary);color:var(--primary);background:#ebf8f4}.exp-month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.exp-month-btn{padding:10px 4px;border-radius:10px;border:1.5px solid var(--border);background:#fff;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s}.exp-month-btn.active{border-color:var(--primary);color:#fff;background:var(--primary)}.exp-preview{display:flex;align-items:center;gap:8px;background:#f2f7f5;border-radius:10px;padding:10px 14px;margin-top:16px;font-size:12px;font-weight:600;color:var(--primary)}.adm-aksi-wrap{display:flex;align-items:center;gap:8px}.adm-cek-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;background:#ebf8f4;color:#1d5e47;text-decoration:none;font-size:12px;font-weight:700;transition:all .15s;white-space:nowrap;border:1.5px solid transparent}.adm-cek-btn:hover{background:#1d5e47;color:#fff}.adm-del-btn{width:32px;height:32px;border-radius:8px;border:1.5px solid #E2EAE6;background:#fff;color:#94a3b8;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.adm-del-btn:hover{border-color:#f43f5e;color:#f43f5e;background:#fff0f0}.adm-confirm-wrap{display:flex;align-items:center;gap:5px}.adm-confirm-txt{font-size:12px;font-weight:700;color:#f43f5e;white-space:nowrap}.adm-confirm-yes{width:28px;height:28px;border-radius:6px;border:none;background:#f43f5e;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.adm-confirm-no{width:28px;height:28px;border-radius:6px;border:1.5px solid #E2EAE6;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer}.adm-pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid #F0F4F2}.adm-page-info{font-size:12px;color:#94a3b8;font-weight:600}.adm-page-btns{display:flex;gap:6px}.adm-page-btn{width:32px;height:32px;border-radius:8px;border:1.5px solid #E2EAE6;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.adm-page-btn:hover:not(:disabled){border-color:#1d5e47;color:#1d5e47}.adm-page-btn:disabled{opacity:.4;cursor:not-allowed}.adm-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px;color:#94a3b8;font-size:14px;font-weight:600}.adm-spinner{width:24px;height:24px;border:3px solid #E2EAE6;border-top-color:#1d5e47;border-radius:50%;animation:spin .75s linear infinite}@media (max-width: 768px){.adm-sidebar{width:60px}.adm-brand-name,.adm-nav-item span:last-child,.adm-footer-name,.adm-footer-role,.adm-sidebar-logout span{display:none}.adm-stats-grid{grid-template-columns:repeat(2,1fr)}.adm-topbar{padding:16px 16px 0}.adm-content{padding:0 16px 40px}.adm-search-box{width:160px}}.page{max-width:480px;margin:0 auto;padding:16px}.admin-header{background:#0f172a;color:#fff;padding:20px 16px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}.admin-header h1{font-size:18px}.logout-btn{background:#ffffff26;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px}.user-table{width:100%;border-collapse:collapse}.user-table th{text-align:left;padding:10px 12px;background:#f8fafc;font-size:12px;color:var(--muted);text-transform:uppercase}.user-table td{padding:12px;border-bottom:1px solid var(--border);font-size:14px}.user-table tr:hover td{background:#f8fafc}.user-table a{color:var(--green-mid);text-decoration:none;font-weight:600}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-active{background:var(--green-pale);color:var(--green-mid)}.badge-pending{background:#fff3cd;color:#856404}.card{background:var(--card);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:0 1px 4px #00000014}.stats{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.stat-box{flex:1;min-width:80px;text-align:center;background:var(--card);padding:12px 8px;border-radius:var(--radius);box-shadow:0 1px 4px #00000012}.stat-box .stat-num{font-size:22px;font-weight:700;color:var(--green-mid)}.stat-box .stat-label{font-size:11px;color:var(--muted);margin-top:2px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:360px}.login-card h2{text-align:center;margin-bottom:6px}.login-card p{text-align:center;color:var(--muted);font-size:13px;margin-bottom:24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-group input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;outline:none}.form-group input:focus{border-color:var(--green-mid)}.btn-primary{width:100%;padding:12px;background:var(--green-mid);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}.btn-primary:hover{background:var(--green-light)}.error-msg{color:#dc3545;font-size:13px;margin-top:8px;text-align:center}.loading,.not-found,.empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:15px}@media (max-width: 480px){.page{padding:12px}}
