:root{--bg-base:#eef4fb;--bg-surface:#fff;--bg-surface-2:#dce9f7;--bg-overlay:#eef4fbf0;--text-primary:#1a1e2e;--text-secondary:#4d6070;--text-muted:#8fa3b8;--text-inverse:#fff;--accent:#0052a5;--accent-hover:#003d7a;--accent-muted:#0052a51a;--accent-muted-strong:#0052a52e;--gold:#1a6bb5;--gold-light:#2e86d4;--gold-muted:#1a6bb51f;--danger:#c0392b;--success:#1a7a4a;--danger-muted:#c0392b1a;--success-muted:#1a7a4a1a;--border:#0034691a;--border-strong:#00346933;--shadow-sm:0 1px 3px #0034690f,0 2px 8px #0034690a;--shadow-md:0 4px 16px #00346914,0 8px 24px #0034690d;--shadow-lg:0 8px 32px #0034691a,0 16px 48px #00346912;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--header-h:64px;--footer-h:68px}[data-theme=dark]{--bg-base:#0d1421;--bg-surface:#162032;--bg-surface-2:#1c2840;--bg-overlay:#0d1421f0;--text-primary:#e8e6f0;--text-secondary:#8892a8;--text-muted:#5a6580;--text-inverse:#0d1421;--accent:#2daaaa;--accent-hover:#3dc0c0;--accent-muted:#2daaaa1f;--accent-muted-strong:#2daaaa38;--gold:#e5b044;--gold-light:#f0c060;--gold-muted:#e5b04424;--danger:#f08080;--success:#4cc88a;--danger-muted:#f080801f;--success-muted:#4cc88a1f;--border:#e8e6f014;--border-strong:#e8e6f029;--shadow-sm:0 1px 3px #00000040,0 2px 8px #0003;--shadow-md:0 4px 16px #00000047,0 8px 24px #00000038;--shadow-lg:0 8px 32px #00000052,0 16px 48px #00000042}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{color:var(--text-primary);background-color:var(--bg-base);background-image:radial-gradient(ellipse at 15% 85%,var(--accent-muted)0px,transparent 55%),radial-gradient(ellipse at 85% 15%,var(--gold-muted)0px,transparent 55%);-webkit-font-smoothing:antialiased;background-attachment:fixed;min-height:100vh;font-family:Poppins,system-ui,sans-serif;font-size:14px;line-height:1.6;transition:background-color .3s,color .3s;overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-family:Poppins,sans-serif;line-height:1.25}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes spinCircle{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 var(--accent-muted-strong)}50%{box-shadow:0 0 0 12px #0000}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.anim-1{animation:.5s cubic-bezier(.22,1,.36,1) 50ms both fadeInUp}.anim-2{animation:.5s cubic-bezier(.22,1,.36,1) .12s both fadeInUp}.anim-3{animation:.5s cubic-bezier(.22,1,.36,1) .2s both fadeInUp}.anim-4{animation:.5s cubic-bezier(.22,1,.36,1) .28s both fadeInUp}.anim-5{animation:.5s cubic-bezier(.22,1,.36,1) .36s both fadeInUp}.tf-container{width:100%;max-width:520px;margin:0 auto;padding:0 18px}.app-content{padding-top:calc(var(--header-h) + 16px);padding-bottom:calc(var(--footer-h) + 24px);min-height:100vh}.app-content-nofooter{padding-top:calc(var(--header-h) + 16px);min-height:100vh;padding-bottom:32px}.preload-container{z-index:9999;background:var(--bg-base);flex-direction:column;justify-content:center;align-items:center;gap:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.preload-logo{object-fit:contain;width:80px;height:80px;animation:2s ease-in-out infinite float}.preload-spinner{border:3px solid var(--accent-muted);border-top-color:var(--accent);border-radius:50%;width:44px;height:44px;animation:.8s linear infinite spinCircle}.app-header{height:var(--header-h);z-index:100;background:linear-gradient(135deg,#003087 0%,#0052a5 60%,#1a6bb5 100%);border-bottom:none;align-items:center;padding:0 18px;transition:background .3s;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 24px #00308766,inset 0 1px #ffffff1a}.app-header:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff80 40%,#fffc 60%,#0000 100%);height:2px;position:absolute;top:0;left:0;right:0}.app-header-brand{flex:1;align-items:center;gap:12px;display:flex}.app-header-logo{object-fit:contain;border-radius:var(--radius-sm);filter:drop-shadow(0 2px 6px #00000040);width:40px;height:40px}.app-header-brand-text small{color:#ffffffa6;letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:500;display:block}.app-header-brand-text strong{color:#fff;text-shadow:0 1px 4px #0003;font-family:Poppins,sans-serif;font-size:15px;line-height:1.2;display:block}.app-header-actions{align-items:center;gap:8px;display:flex}.icon-btn{border-radius:var(--radius-sm);color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff24;border:1px solid #ffffff2e;justify-content:center;align-items:center;width:38px;height:38px;text-decoration:none;transition:background .2s,transform .15s;display:flex}.icon-btn:hover{background:#ffffff42;transform:scale(1.05)}.icon-btn svg{width:18px;height:18px}.notif-btn{position:relative}.notif-badge{color:#fff;pointer-events:none;background:#ff4757;border-radius:8px;justify-content:center;align-items:center;min-width:15px;height:15px;padding:0 3px;font-size:8px;font-weight:700;line-height:1;display:flex;position:absolute;top:5px;right:5px;box-shadow:0 0 0 2px #ffffff4d}.page-header{height:var(--header-h);z-index:100;background:linear-gradient(135deg,#003087 0%,#0052a5 60%,#1a6bb5 100%);border-bottom:none;align-items:center;gap:12px;padding:0 18px;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 24px #00308766,inset 0 1px #ffffff1a}.page-header:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff80 40%,#fffc 60%,#0000 100%);height:2px;position:absolute;top:0;left:0;right:0}.page-header-title{text-align:center;color:#fff;text-shadow:0 1px 4px #0003;flex:1;font-family:Poppins,sans-serif;font-size:18px}.back-btn{border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#ffffff24;border:1px solid #ffffff2e;justify-content:center;align-items:center;width:38px;height:38px;text-decoration:none;transition:background .2s;display:flex}.back-btn:hover{background:#ffffff42}.bottom-nav{height:calc(var(--footer-h) + env(safe-area-inset-bottom,0px));z-index:100;background:var(--bg-overlay);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{border-radius:var(--radius-md);color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 4px;font-size:10px;font-weight:600;text-decoration:none;transition:color .2s,background .2s;display:flex}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item svg{width:22px;height:22px}.bottom-nav-indicator{background:var(--accent);opacity:0;border-radius:50%;width:4px;height:4px;margin-top:2px;transition:opacity .2s}.bottom-nav-item.active .bottom-nav-indicator{opacity:1}[data-theme=dark] .app-header,[data-theme=dark] .page-header{background:linear-gradient(135deg,#0a1a3a 0%,#0d2050 60%,#122560 100%);box-shadow:0 4px 24px #00000080,inset 0 1px #ffffff0f}.login-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px 18px;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(at 20% 20%,#0052a547 0,#0000 60%),radial-gradient(at 80% 80%,#0030872e 0,#0000 55%);position:absolute;inset:0}[data-theme=dark] .login-page:before{background:radial-gradient(at 20% 30%,#2daaaa2e 0,#0000 60%),radial-gradient(at 80% 70%,#e5b0441a 0,#0000 55%)}.login-card{background:var(--bg-surface);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border);animation:.5s cubic-bezier(.22,1,.36,1) both scaleIn;position:relative;overflow:hidden}.login-card-header{text-align:center;background:linear-gradient(160deg,var(--accent-muted)0%,transparent 100%);border-bottom:1px solid var(--border);padding:40px 32px 28px}.login-school-logo{object-fit:contain;border-radius:var(--radius-md);background:var(--bg-surface);width:72px;height:72px;box-shadow:var(--shadow-md);margin:0 auto 16px;padding:8px}.login-card-header h1{color:var(--text-primary);margin-bottom:6px;font-size:20px}.login-card-header p{color:var(--text-secondary);font-size:13px;line-height:1.5}.login-card-body{padding:28px 32px 32px}.form-group{margin-bottom:20px}.form-label{color:var(--text-primary);letter-spacing:.02em;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-input-wrap{position:relative}.form-input-icon{color:var(--text-muted);pointer-events:none;display:flex;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.form-control{width:100%;height:48px;color:var(--text-primary);-webkit-text-fill-color:var(--text-primary);caret-color:var(--text-primary);background:var(--bg-surface-2);border:1.5px solid var(--border);border-radius:var(--radius-md);-webkit-appearance:none;outline:none;padding:0 16px 0 44px;font-family:Poppins,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s,background .2s}.form-control::placeholder{color:var(--text-muted);-webkit-text-fill-color:var(--text-muted)}.form-control:focus{border-color:var(--accent);background:var(--bg-surface);box-shadow:0 0 0 3px var(--accent-muted);color:var(--text-primary);-webkit-text-fill-color:var(--text-primary)}.form-control:-webkit-autofill{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:0 0 0 100px var(--bg-surface)inset;caret-color:var(--text-primary);transition:background-color 5000s ease-in-out}.form-control:-webkit-autofill:hover{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:0 0 0 100px var(--bg-surface)inset;caret-color:var(--text-primary);transition:background-color 5000s ease-in-out}.form-control:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:0 0 0 100px var(--bg-surface)inset;caret-color:var(--text-primary);transition:background-color 5000s ease-in-out}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-md);letter-spacing:.03em;cursor:pointer;border:none;width:100%;height:50px;font-family:Poppins,sans-serif;font-size:15px;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s;position:relative;overflow:hidden}.btn-primary:after{content:"";opacity:0;background:linear-gradient(90deg,#0000,#ffffff1f,#0000) 0 0/200% 100%;transition:opacity .3s;position:absolute;inset:0}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:hover:after{opacity:1;animation:1.2s linear infinite shimmer}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-surface-2);height:44px;color:var(--text-primary);border:1.5px solid var(--border-strong);border-radius:var(--radius-md);cursor:pointer;padding:0 20px;font-family:Poppins,sans-serif;font-size:14px;font-weight:600;transition:background .2s,transform .15s}.btn-secondary:hover{background:var(--border);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;height:44px;padding:0 20px;font-family:Poppins,sans-serif;font-size:14px;font-weight:600;transition:opacity .2s,transform .15s}.btn-danger:hover{opacity:.88;transform:translateY(-1px)}.alert-error{background:var(--danger-muted);border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);align-items:flex-start;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:13px;font-weight:500;animation:.3s fadeInUp;display:flex}.alert-error svg{flex-shrink:0;margin-top:1px}.dashboard-welcome{align-items:center;gap:10px;margin-bottom:28px;padding-top:4px;display:flex}.dashboard-welcome h2{color:var(--text-primary);font-size:16px;font-weight:700;line-height:1.3}.dashboard-welcome-emoji{object-fit:contain;width:20px;height:20px}.tagihan-banner{border-radius:var(--radius-xl);color:#fff;background:linear-gradient(135deg,#c0392b 0%,#e74c3c 55%,#a93226 100%);margin-bottom:16px;padding:24px 20px 16px;animation:.4s cubic-bezier(.22,1,.36,1) both fadeInUp;position:relative;overflow:hidden;box-shadow:0 8px 28px #c0392b59,0 2px 8px #c0392b33}[data-theme=dark] .tagihan-banner{background:linear-gradient(135deg,#7b241c 0%,#c0392b 55%,#641e16 100%);box-shadow:0 8px 28px #0006}.tagihan-banner.lunas{background:linear-gradient(135deg,#1a7a4a 0%,#27ae60 55%,#1e8449 100%);box-shadow:0 8px 28px #27ae6059,0 2px 8px #27ae6033}[data-theme=dark] .tagihan-banner.lunas{background:linear-gradient(135deg,#145a32 0%,#1e8449 55%,#0e6124 100%);box-shadow:0 8px 28px #0006}.tagihan-banner-decor-1{pointer-events:none;background:#ffffff12;border-radius:50%;width:160px;height:160px;position:absolute;top:-40px;right:-40px}.tagihan-banner-decor-2{pointer-events:none;background:#ffffff0a;border-radius:50%;width:120px;height:120px;position:absolute;bottom:-50px;right:60px}.tagihan-banner-label{letter-spacing:.08em;text-transform:uppercase;opacity:.75;margin-bottom:4px;font-size:11px;font-weight:600}.tagihan-banner-amount{letter-spacing:-.02em;margin-bottom:4px;font-family:Poppins,sans-serif;font-size:26px;font-weight:700}.tagihan-banner-period{opacity:.65;margin-bottom:16px;font-size:12px}.tagihan-banner-footer{justify-content:space-between;align-items:center;display:flex}.tagihan-badge{letter-spacing:.03em;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-size:11px;font-weight:700;display:inline-flex}.tagihan-badge.lunas{color:#fff;background:#fff3}.tagihan-badge.belum{color:#fff;background:#0000002e}.tagihan-banner-link{color:#fffc;opacity:.9;font-size:12px;font-weight:600}.tagihan-empty-card{border-radius:var(--radius-xl);background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;align-items:center;gap:8px;margin-bottom:16px;padding:28px 20px;display:flex}.tagihan-empty-icon{background:var(--success-muted);width:48px;height:48px;color:var(--success);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.tagihan-empty-icon svg{width:22px;height:22px}.tagihan-empty-text{color:var(--text-primary);font-size:15px;font-weight:700}.tagihan-empty-sub{color:var(--text-muted);font-size:13px}.saldo-banner{border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--accent)0%,var(--accent-hover)50%,#0a4a4a 100%);color:#fff;box-shadow:var(--shadow-lg);margin-bottom:28px;padding:28px 24px;position:relative;overflow:hidden}[data-theme=dark] .saldo-banner{background:linear-gradient(135deg,#1a4a4a 0%,var(--accent)50%,#0d3a3a 100%)}.saldo-banner:before{content:"";background:#ffffff0f;border-radius:50%;width:160px;height:160px;position:absolute;top:-40px;right:-40px}.saldo-banner:after{content:"";background:#ffffff0a;border-radius:50%;width:120px;height:120px;position:absolute;bottom:-50px;right:60px}.saldo-banner-label{letter-spacing:.08em;text-transform:uppercase;opacity:.75;margin-bottom:4px;font-size:12px;font-weight:600}.saldo-banner-sublabel{opacity:.6;margin-bottom:16px;font-size:12px;line-height:1.4}.saldo-banner-amount{letter-spacing:-.02em;margin-bottom:20px;font-family:Poppins,sans-serif;font-size:32px;font-weight:400;position:relative}.saldo-banner-link{color:#fff;background:#ffffff2e;border:1px solid #ffffff40;border-radius:100px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex;position:relative}.saldo-banner-link:hover{color:#fff;background:#ffffff47}.saldo-banner-decor{opacity:.12;width:80px;position:absolute;bottom:20px;right:20px}.section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.view-more{color:var(--accent);letter-spacing:.02em;font-size:11px;font-weight:600;text-decoration:none;transition:opacity .2s}.view-more:hover{opacity:.75;color:var(--accent)}.anim-3,.anim-4{margin-bottom:28px}.menu-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:0;display:grid}.menu-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;align-items:center;gap:8px;padding:14px 6px 12px;text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.menu-item:hover{box-shadow:var(--shadow-md);border-color:var(--accent-muted-strong);transform:translateY(-3px)}.menu-item-icon{border-radius:var(--radius-md);background:var(--accent-muted);justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s;display:flex}.menu-item:hover .menu-item-icon{background:var(--accent-muted-strong)}.menu-item-icon img{object-fit:contain;width:22px;height:22px}.menu-item-label{color:var(--text-secondary);text-align:center;letter-spacing:.01em;font-size:10px;font-weight:600;line-height:1.3}.announcement-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);cursor:pointer;margin-bottom:10px;transition:transform .22s,box-shadow .22s;overflow:hidden}.announcement-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.announcement-card:active{transform:translateY(0)}.announcement-card-banner{background:linear-gradient(120deg,var(--accent)0%,#1a6bb5 100%);padding:14px 16px 12px;position:relative;overflow:hidden}.announcement-card-banner:before{content:"";pointer-events:none;background:#ffffff14;border-radius:50%;width:80px;height:80px;position:absolute;top:-24px;right:-24px}.announcement-card-banner:after{content:"";pointer-events:none;background:#ffffff0d;border-radius:50%;width:60px;height:60px;position:absolute;bottom:-30px;right:40px}.announcement-card-tag{color:#ffffffe6;letter-spacing:.08em;text-transform:uppercase;background:#ffffff2e;border:1px solid #ffffff38;border-radius:20px;align-items:center;gap:4px;margin-bottom:8px;padding:2px 9px;font-size:9px;font-weight:700;display:inline-flex}.announcement-card-tag svg{width:9px;height:9px}.announcement-title{color:#fff;z-index:1;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;line-height:1.4;position:relative;overflow:hidden}.announcement-card-body{padding:12px 16px 0}.announcement-body{color:var(--text-secondary);margin-bottom:0;font-size:12px;line-height:1.6}.announcement-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:8px;padding:10px 16px 12px;display:flex}.announcement-footer-date{color:var(--text-muted);align-items:center;gap:5px;font-size:10px;font-weight:500;display:flex}.announcement-footer-date svg{flex-shrink:0}.announcement-read-btn{color:var(--accent);letter-spacing:.02em;align-items:center;gap:4px;font-size:11px;font-weight:700;transition:gap .2s;display:inline-flex}.announcement-card:hover .announcement-read-btn{gap:7px}.bill-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:24px;animation:.4s cubic-bezier(.22,1,.36,1) both fadeInUp}.bill-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.bill-amount{color:var(--text-primary);font-family:Poppins,sans-serif;font-size:26px}.bill-period{color:var(--text-muted);margin-top:4px;font-size:12px}.badge-status{letter-spacing:.04em;text-transform:uppercase;border-radius:100px;align-items:center;gap:5px;padding:5px 12px;font-size:11px;font-weight:700;display:inline-flex}.badge-status.paid{background:var(--success-muted);color:var(--success)}.badge-status.unpaid{background:var(--danger-muted);color:var(--danger)}.bill-divider{background:var(--border);height:1px;margin:16px 0}.bill-detail-label{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:700}.bill-detail-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.bill-detail-item:last-child{border-bottom:none}.bill-detail-name{color:var(--text-secondary);font-size:13px;font-weight:500}.bill-detail-amount{color:var(--text-primary);font-size:13px;font-weight:700}.btn-edit-bill{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:5px;padding:5px 12px;font-family:Poppins,sans-serif;font-size:11px;font-weight:600;transition:opacity .2s,transform .15s;display:inline-flex}.btn-edit-bill:hover{opacity:.82;transform:scale(1.03)}.btn-edit-blue{background:var(--accent-muted);color:var(--accent)}.btn-edit-red{background:var(--danger-muted);color:var(--danger)}.tx-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 0;animation:.4s cubic-bezier(.22,1,.36,1) both fadeInUp;display:flex}.tx-item:last-child{border-bottom:none}.tx-dot{background:var(--danger);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:5px}.tx-info{flex:1}.tx-date{color:var(--text-primary);margin-bottom:4px;font-size:13px;font-weight:600}.tx-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.tx-amount-col{text-align:right}.tx-total{color:var(--accent);margin-bottom:4px;font-family:Poppins,sans-serif;font-size:16px}.tx-breakdown{color:var(--text-muted);margin-top:2px;font-size:11px}.profile-hero{text-align:center;padding:32px 0 24px}.profile-avatar{object-fit:cover;border:3px solid var(--accent-muted-strong);width:88px;height:88px;box-shadow:0 0 0 6px var(--accent-muted);border-radius:50%;margin:0 auto 16px;animation:3s ease-in-out infinite pulse-glow}.profile-name{color:var(--text-primary);margin-bottom:4px;font-family:Poppins,sans-serif;font-size:22px}.profile-class{color:var(--text-secondary);margin-bottom:8px;font-size:13px}.profile-nis{background:var(--accent-muted);color:var(--accent);letter-spacing:.04em;border-radius:100px;padding:4px 14px;font-size:12px;font-weight:700;display:inline-block}.profile-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px;display:grid}.profile-stat-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);padding:14px 10px}.profile-stat-amount{color:var(--text-primary);word-break:break-all;margin-bottom:4px;font-family:Poppins,sans-serif;font-size:14px}.profile-stat-label{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;font-size:10px;font-weight:600}.profile-stat-item.incoming .profile-stat-amount{color:var(--success)}.profile-stat-item.outgoing .profile-stat-amount{color:var(--danger)}.profile-stat-item.balance .profile-stat-amount{color:var(--accent)}.profile-menu{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.profile-menu-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:14px;padding:16px 20px;text-decoration:none;transition:background .2s;display:flex}.profile-menu-item:last-child{border-bottom:none}.profile-menu-item:hover{background:var(--accent-muted)}.profile-menu-icon{border-radius:var(--radius-md);background:var(--accent);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.profile-menu-icon.danger-icon{background:var(--danger)}.profile-menu-label{color:var(--text-primary);flex:1;font-size:14px;font-weight:600}.profile-menu-chevron{color:var(--text-muted)}.modal-sidebar .modal-dialog{max-width:300px;height:100%;margin:0}.modal-sidebar .modal-content{background:var(--bg-surface);border:none;border-radius:0;height:100%}.sidebar-header{border-bottom:1px solid var(--border);background:linear-gradient(160deg,var(--accent-muted)0%,transparent 100%);align-items:center;gap:14px;padding:32px 20px 20px;display:flex}.sidebar-school-logo{object-fit:contain;border-radius:var(--radius-sm);width:44px;height:44px}.sidebar-school-name{color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.3}.sidebar-body{padding:20px}.sidebar-user{border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:20px;padding:14px 0 18px;display:flex}.sidebar-avatar{object-fit:cover;border-radius:50%;width:44px;height:44px}.sidebar-user-name{color:var(--text-primary);font-size:14px;font-weight:700}.sidebar-user-label{color:var(--text-muted);font-size:11px}.sidebar-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;font-size:10px;font-weight:800}.theme-toggle-row{justify-content:space-between;align-items:center;padding:12px 0;display:flex}.theme-toggle-label{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.toggle-switch{width:48px;height:26px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--bg-surface-2);border:1.5px solid var(--border-strong);cursor:pointer;border-radius:100px;transition:background .25s,border-color .25s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-muted);border-radius:50%;width:18px;height:18px;transition:transform .25s cubic-bezier(.22,1,.36,1),background .25s;position:absolute;top:50%;left:3px;transform:translateY(-50%)}.toggle-switch input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translate(22px,-50%)}.sidebar-nav-item{border-radius:var(--radius-md);background:var(--accent-muted);border:1px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;text-align:left;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s,transform .15s;display:flex}.sidebar-nav-item:hover{background:var(--accent-muted-strong);transform:translate(2px)}.sidebar-nav-icon{border-radius:var(--radius-sm);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebar-nav-icon svg{width:16px;height:16px}.sidebar-nav-arrow{width:14px;height:14px;color:var(--text-muted);flex-shrink:0;margin-left:auto}.panduan-hero{background:linear-gradient(135deg,var(--accent)0%,var(--accent-hover)100%);border-radius:var(--radius-xl);color:#fff;align-items:center;gap:16px;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 6px 20px #0052a54d}.panduan-hero-icon{border-radius:var(--radius-md);background:#ffffff2e;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.panduan-hero-icon svg{width:26px;height:26px}.panduan-hero-title{margin-bottom:4px;font-family:Poppins,sans-serif;font-size:18px}.panduan-hero-sub{opacity:.75;font-size:12px;line-height:1.5}.panduan-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:10px;transition:box-shadow .2s;overflow:hidden}.panduan-card.open{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.panduan-card-head{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:14px 16px;display:flex}.panduan-card-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.panduan-card-icon svg{width:18px;height:18px}.panduan-card-title{color:var(--text-primary);flex:1;font-size:14px;font-weight:700}.panduan-card-body{border-top:1px solid var(--border);padding:0 16px 16px}.panduan-steps{flex-direction:column;gap:10px;padding:12px 0 0;list-style:none;display:flex}.panduan-step-item{align-items:flex-start;gap:10px;display:flex}.panduan-step-num{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;min-width:22px;height:22px;margin-top:1px;font-size:11px;font-weight:800;display:flex}.panduan-step-text{color:var(--text-secondary);font-size:13px;line-height:1.55}.panduan-footer-note{background:var(--bg-surface-2);border-radius:var(--radius-md);color:var(--text-muted);align-items:center;gap:8px;margin:16px 0 8px;padding:12px 16px;font-size:12px;line-height:1.5;display:flex}.panduan-footer-note svg{color:var(--accent);flex-shrink:0}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 24px;display:flex}.empty-state img{opacity:.55;filter:grayscale(.3);width:120px}.empty-state h3{color:var(--text-primary);font-size:18px}.empty-state p{color:var(--text-muted);max-width:240px;font-size:13px;line-height:1.5}.modal-content{background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);padding:8px;border-radius:var(--radius-xl)!important}.modal-title{color:var(--text-primary);font-family:Poppins,sans-serif}.modal-body{color:var(--text-secondary);font-size:14px}.version-text{color:var(--text-muted);text-align:center;letter-spacing:.03em;margin-top:20px;font-size:11px}.text-accent{color:var(--accent)}.text-gold{color:var(--gold)}.text-muted-var{color:var(--text-muted)}.bg-surface{background:var(--bg-surface)}.list-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.btn{font-family:Poppins,sans-serif}.card{background:var(--bg-surface);border-color:var(--border);border-radius:var(--radius-lg);color:var(--text-primary)}.card-title{color:var(--text-primary);font-family:Poppins,sans-serif}.card-text{color:var(--text-secondary)}.pocket-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.pocket-item:last-child{border-bottom:none}.pocket-label{color:var(--text-primary);font-size:13px;font-weight:600}.pocket-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.pocket-amount{font-family:Poppins,sans-serif;font-size:15px;font-weight:400}.pocket-amount.credit{color:var(--success)}.pocket-amount.debit{color:var(--danger)}
@font-face{font-family:Poppins;font-style:normal;font-weight:300;font-display:swap;src:url(../media/7e832ad540183e91-s.a2f18b1a.woff2)format("woff2");unicode-range:U+900-97F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+20F0,U+25CC,U+A830-A839,U+A8E0-A8FF,U+11B00-11B09}@font-face{font-family:Poppins;font-style:normal;font-weight:300;font-display:swap;src:url(../media/2094fb60fd9c8287-s.3ed55436.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Poppins;font-style:normal;font-weight:300;font-display:swap;src:url(../media/c875c6f5d3e977ac-s.p.80fc2c9e.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Poppins;font-style:normal;font-weight:400;font-display:swap;src:url(../media/41e95f694c5c4549-s.666bad7d.woff2)format("woff2");unicode-range:U+900-97F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+20F0,U+25CC,U+A830-A839,U+A8E0-A8FF,U+11B00-11B09}@font-face{font-family:Poppins;font-style:normal;font-weight:400;font-display:swap;src:url(../media/6c55a692938ebbbc-s.0a77efb4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Poppins;font-style:normal;font-weight:400;font-display:swap;src:url(../media/a218039a3287bcfd-s.p.4a23d71b.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Poppins;font-style:normal;font-weight:500;font-display:swap;src:url(../media/bdc7e24a509eb931-s.43b0b13e.woff2)format("woff2");unicode-range:U+900-97F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+20F0,U+25CC,U+A830-A839,U+A8E0-A8FF,U+11B00-11B09}@font-face{font-family:Poppins;font-style:normal;font-weight:500;font-display:swap;src:url(../media/0da9c7f357bd9d4d-s.b2288445.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Poppins;font-style:normal;font-weight:500;font-display:swap;src:url(../media/8e6fa89aa22d24ec-s.p.3aec397d.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Poppins;font-style:normal;font-weight:600;font-display:swap;src:url(../media/0a7740363b4d4863-s.95e4158a.woff2)format("woff2");unicode-range:U+900-97F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+20F0,U+25CC,U+A830-A839,U+A8E0-A8FF,U+11B00-11B09}@font-face{font-family:Poppins;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5f9d24ebef5d5292-s.bd593fbe.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Poppins;font-style:normal;font-weight:600;font-display:swap;src:url(../media/e2334d715941921e-s.p.d82a9aff.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Poppins;font-style:normal;font-weight:700;font-display:swap;src:url(../media/b53057dbf91a7acf-s.c55744ae.woff2)format("woff2");unicode-range:U+900-97F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+20F0,U+25CC,U+A830-A839,U+A8E0-A8FF,U+11B00-11B09}@font-face{font-family:Poppins;font-style:normal;font-weight:700;font-display:swap;src:url(../media/798ea22d9983e047-s.b460e02c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Poppins;font-style:normal;font-weight:700;font-display:swap;src:url(../media/47fe1b7cd6e6ed85-s.p.855a563b.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Poppins;font-style:normal;font-weight:800;font-display:swap;src:url(../media/99ce71e74c11bc20-s.1db2973a.woff2)format("woff2");unicode-range:U+900-97F,U+1CD0-1CF9,U+200C-200D,U+20A8,U+20B9,U+20F0,U+25CC,U+A830-A839,U+A8E0-A8FF,U+11B00-11B09}@font-face{font-family:Poppins;font-style:normal;font-weight:800;font-display:swap;src:url(../media/8cf1ea7b03cdeb83-s.da3cbacd.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Poppins;font-style:normal;font-weight:800;font-display:swap;src:url(../media/829ba4228c966254-s.p.a61bc753.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Poppins Fallback;src:local(Arial);ascent-override:93.62%;descent-override:31.21%;line-gap-override:8.92%;size-adjust:112.16%}.poppins_20e82910-module__4lWQ2G__className{font-family:Poppins,Poppins Fallback;font-style:normal}.poppins_20e82910-module__4lWQ2G__variable{--font-poppins:"Poppins","Poppins Fallback"}
