:root{--blu-cyan:#00AEEF;--blu-cyan-hover:#0095CC;--blu-cyan-light:#E0F6FF;--blu-navy:#001E36;--blu-navy-mid:#003055;--blu-bg:#F4F7FA;--white:#FFFFFF;--text-dark:#0F1923;--text-mid:#4A5568;--text-muted:#94A3B8;--green:#10B981;--green-light:#D1FAE5;--red:#F43F5E;--red-light:#FFE4E6;--amber:#F59E0B;--amber-light:#FEF3C7;--radius-sm:12px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--shadow-sm:0 2px 8px rgba(0,0,0,0.04);--shadow-md:0 8px 24px rgba(0,0,0,0.06);--shadow-lg:0 16px 48px rgba(0,0,0,0.1);--shadow-cyan:0 8px 24px rgba(0,174,239,0.25)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body,html{height:100%}body{font-family:DM Sans,sans-serif;background:var(--blu-bg);color:var(--text-dark);-webkit-font-smoothing:antialiased}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--blu-navy);padding:20px;position:relative;overflow:hidden}.auth-bg-circle{position:absolute;border-radius:50%;pointer-events:none}.auth-bg-circle-1{width:600px;height:600px;background:radial-gradient(circle,rgba(0,174,239,.15) 0,transparent 70%);top:-200px;right:-150px}.auth-bg-circle-2{width:400px;height:400px;background:radial-gradient(circle,rgba(0,174,239,.08) 0,transparent 70%);bottom:-150px;left:-100px}.auth-card{background:var(--white);border-radius:var(--radius-xl);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:slideUpFade .5s ease-out}@keyframes slideUpFade{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.auth-locd{text-align:center;margin-bottom:32px}.auth-logo .wordmark{font-family:Sora,sans-serif;font-size:2rem;font-weight:800;color:var(--blu-navy);letter-spacing:-.5px}.auth-logo .wordmark span{color:var(--blu-cyan)}.auth-logo .tagline{font-size:.85rem;color:var(--text-muted);margin-top:4px;font-weight:500}.auth-tab-row{display:flex;background:var(--blu-bg);border-radius:var(--radius-sm);padding:4px;margin-bottom:24px}.auth-tab{flex:1 1;padding:10px;border:none;background:transparent;border-radius:10px;font-family:DM Sans,sans-serif;font-weight:600;font-size:.9rem;color:var(--text-muted);cursor:pointer;transition:all .2s}.auth-tab.active{background:var(--white);color:var(--blu-navy);box-shadow:var(--shadow-sm)}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--blu-navy);margin-bottom:6px;letter-spacing:.3px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border-radius:var(--radius-sm);border:1.5px solid #e2e8f0;font-family:DM Sans,sans-serif;font-size:.95rem;color:var(--text-dark);background:#F8FAFC;outline:none;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus,.form-group select:focus{border-color:var(--blu-cyan);background:var(--white);box-shadow:0 0 0 3px rgba(0,174,239,.12)}.input-prefix-wrap{position:relative;display:flex;align-items:center}.input-prefix-wrap .prefix{position:absolute;left:14px;font-weight:600;color:var(--text-muted);font-size:.95rem;pointer-events:none}.input-prefix-wrap input{padding-left:40px;font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;border-radius:50px;font-family:DM Sans,sans-serif;font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:all .2s;width:100%;text-decoration:none;letter-spacing:.1px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--blu-cyan);color:var(--white);box-shadow:var(--shadow-cyan)}.btn-primary:hover:not(:disabled){background:var(--blu-cyan-hover);transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,174,239,.35)}.btn-navy{background:var(--blu-navy);color:var(--white)}.btn-navy:hover:not(:disabled){background:var(--blu-navy-mid);transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--text-muted);width:auto;padding:10px 16px}.btn-ghost:hover{background:var(--blu-bg);color:var(--blu-navy)}.btn-outline{background:transparent;color:var(--blu-cyan);border:1.5px solid var(--blu-cyan)}.btn-outline:hover{background:var(--blu-cyan-light)}.btn-danger{background:var(--red-light);color:var(--red);box-shadow:none}.btn-danger:hover{background:#fecdd3;transform:translateY(-1px)}.btn-sm{padding:8px 16px;font-size:.85rem}.btn-icon{height:40px;padding:0;border-radius:50%;flex-shrink:0;width:40px}.google-btn{width:100%;min-height:50px;padding:0 20px;display:flex;align-items:center;justify-content:center;gap:12px;border-radius:12px;border:1px solid #e2e8f0;background:var(--blu-navy,#001E36);color:#ffffff;font-weight:600;font-size:1rem;cursor:pointer;box-shadow:0 2px 4px rgba(0,0,0,.05);transition:all .2s ease}.top-header-mobile{display:none}@media (max-width:768px){.top-header-mobile{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff;border-bottom:1px solid #e2e8f0;margin-bottom:16px;border-radius:12px}.user-profile-mobile{display:flex;align-items:center;gap:12px}.mobile-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:1px solid #e2e8f0}.mobile-user-info{display:flex;flex-direction:column}.mobile-name{font-weight:700;font-size:.95rem;color:var(--blu-navy,#001E36)}.mobile-role{font-size:.75rem;color:#64748b;text-transform:capitalize}.mobile-logout-btn{display:flex;align-items:center;gap:6px;background:transparent;border:none;color:#F43F5E;font-weight:600;font-size:.85rem;padding:6px 12px;border-radius:8px;background:rgba(244,63,94,.1)}}.top-header{background:var(--white);padding:14px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 0 rgba(0,0,0,.06);position:-webkit-sticky;position:sticky;top:0;z-index:50}.logo{font-family:Sora,sans-serif;font-weight:800;font-size:1.4rem;color:var(--blu-navy);letter-spacing:-.5px}.logo span{color:var(--blu-cyan)}.header-right{gap:12px}.header-right,.realtime-badge{display:flex;align-items:center}.realtime-badge{gap:6px;background:var(--green-light);color:var(--green);padding:6px 12px;border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:.2px}.realtime-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.user-avatar-wrap{display:flex;align-items:center;gap:10px;cursor:pointer}.user-info-mini{text-align:right}.user-name{font-size:.85rem;font-weight:700;color:var(--blu-navy);line-height:1}.user-role-badge{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:50px;margin-top:3px;display:inline-block}.role-admin{background:#EDE9FE;color:#7C3AED}.role-bendahara{background:#FEF3C7;color:#B45309}.role-anggota{color:var(--blu-cyan-hover)}.avatar-img,.role-anggota{background:var(--blu-cyan-light)}.avatar-img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--blu-cyan)}.app-body{padding-bottom:90px}.app-container{max-width:100%;padding:20px 16px}.tab-content{display:none;animation:fadeSlideUp .35s ease}.tab-content.active{display:block}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--white);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.04)}.card,.hero-card{margin-bottom:16px}.hero-card{background:linear-gradient(135deg,var(--blu-navy) 0,var(--blu-navy-mid) 100%);border-radius:var(--radius-xl);padding:28px 24px;color:white;position:relative;overflow:hidden;box-shadow:0 16px 40px rgba(0,30,54,.25)}.hero-card:before{top:-80px;right:-80px;width:240px;height:240px;background:rgba(0,174,239,.18);filter:blur(40px)}.hero-card:after,.hero-card:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.hero-card:after{bottom:-60px;left:-40px;width:180px;height:180px;background:rgba(0,174,239,.08);filter:blur(30px)}.hero-label{font-size:.8rem;color:rgba(255,255,255,.6);font-weight:600;letter-spacing:.5px;margin-bottom:8px;display:flex;align-items:center;gap:8px}.hero-amount{font-family:Sora,sans-serif;font-size:2.4rem;font-weight:800;letter-spacing:-1px;margin-bottom:24px;transition:all .3s;position:relative;z-index:1}.hero-amount.masked{letter-spacing:4px;color:rgba(255,255,255,.4)}.hero-quick-stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;position:relative;z-index:1}.hero-stat-pill{background:rgba(255,255,255,.1);border-radius:14px;padding:12px 14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.hero-stat-pill .label{font-size:.72rem;color:rgba(255,255,255,.6);font-weight:600;margin-bottom:4px}.hero-stat-pill .value{font-family:Sora,sans-serif;font-size:1rem;font-weight:700;color:white}.hero-stat-pill .value.in{color:#4ADE80}.hero-stat-pill .value.out{color:#FB7185}.eye-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:0;line-height:1;opacity:.7;transition:opacity .2s}.eye-btn:hover{opacity:1}.section-title{font-family:Sora,sans-serif;font-size:.95rem;font-weight:700;color:var(--blu-navy);margin:24px 0 12px 4px;letter-spacing:-.2px}.summary-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;margin-bottom:16px}.summary-card{text-align:center;padding:20px 12px;display:flex;flex-direction:column;align-items:center}.summary-card .icon-wrap{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:10px}.icon-wrap.in{background:var(--green-light)}.icon-wrap.out{background:var(--red-light)}.icon-wrap.kas{background:var(--amber-light)}.summary-card .slabel{font-size:.75rem;color:var(--text-muted);font-weight:600;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.summary-card .svalue{font-family:Sora,sans-serif;font-size:1.05rem;font-weight:700;color:var(--blu-navy)}.ledger-item{display:flex;justify-content:space-between;align-items:center;padding:14px 4px;border-bottom:1px solid #f1f5f9;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.ledger-item:last-child{border-bottom:none}.ledger-item:active,.ledger-item:hover{background:#F8FAFC;padding-left:12px;padding-right:12px;margin:0 -8px}.ledger-left{gap:12px}.ledger-icon,.ledger-left{display:flex;align-items:center}.ledger-icon{width:38px;height:38px;border-radius:12px;justify-content:center;font-size:1rem;flex-shrink:0}.ledger-icon.jenis-pemasukan{background:var(--green-light)}.ledger-icon.jenis-pengeluaran{background:var(--red-light)}.ledger-icon.jenis-kas{background:var(--amber-light)}.ledger-info .ledger-title{font-weight:600;font-size:.9rem;color:var(--text-dark);line-height:1.2}.ledger-info .ledger-sub{font-size:.75rem;color:var(--text-muted);margin-top:2px}.ledger-right{text-align:right;flex-shrink:0}.ledger-amount{font-family:Sora,sans-serif;font-weight:700;font-size:.92rem}.ledger-amount.positive{color:var(--green)}.ledger-amount.negative{color:var(--red)}.ledger-amount.neutral{color:var(--amber)}.ledger-date{font-size:.72rem;color:var(--text-muted);margin-top:2px}.search-filter-row{margin-bottom:14px}.search-bar,.search-filter-row{display:flex;gap:10px;align-items:center}.search-bar{background:var(--white);border-radius:var(--radius-md);padding:11px 16px;flex:1 1;border:1.5px solid #e2e8f0;box-shadow:var(--shadow-sm)}.search-bar input{border:none;background:transparent;outline:none;width:100%;font-family:DM Sans,sans-serif;font-size:.9rem;color:var(--blu-navy)}.search-bar input::placeholder{color:var(--text-muted)}.btn-filter{background:var(--white);border:1.5px solid #e2e8f0;border-radius:var(--radius-md);width:46px;height:46px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--blu-navy);box-shadow:var(--shadow-sm);transition:all .2s;flex-shrink:0}.btn-filter:hover{border-color:var(--blu-cyan);color:var(--blu-cyan)}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;background:var(--white);display:flex;justify-content:space-around;padding:10px 0 calc(10px + env(safe-area-inset-bottom));box-shadow:0 -1px 0 rgba(0,0,0,.06),0 -8px 32px rgba(0,0,0,.04);z-index:50;border-radius:20px 20px 0 0}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-muted);cursor:pointer;transition:all .2s;padding:8px 20px;border-radius:14px}.nav-icon{font-size:1.3rem;transition:transform .2s}.nav-label{font-size:.7rem;font-weight:700;letter-spacing:.3px}.nav-item.active{color:var(--blu-cyan)}.nav-item.active .nav-icon{transform:translateY(-2px)}.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,15,30,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);align-items:flex-end;justify-content:center;z-index:1000}.modal-backdrop.open{display:flex}.modal-sheet{background:var(--white);width:100%;max-width:560px;border-radius:28px 28px 0 0;padding:28px 20px calc(28px + env(safe-area-inset-bottom));animation:sheetUp .3s cubic-bezier(.34,1.56,.64,1);max-height:95vh;overflow-y:auto}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-family:Sora,sans-serif;font-size:1.2rem;font-weight:700;color:var(--blu-navy)}.close-btn{background:#F1F5F9;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);font-size:1rem;transition:all .2s}.close-btn:hover{background:#E2E8F0;color:var(--text-dark)}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1 1}.mt-1{margin-top:8px}.mt-2{margin-top:12px}.mt-3{margin-top:20px}.receipt-box{background:#F8FAFC;border:1.5px dashed #cbd5e1;border-radius:var(--radius-md);padding:20px}.receipt-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;font-size:.88rem}.receipt-row:last-child{margin-bottom:0}.receipt-row .rlabel{color:var(--text-muted);font-weight:600;min-width:90px}.receipt-row .rvalue{font-weight:600;color:var(--blu-navy);text-align:right}.receipt-divider{border:none;border-top:1.5px dashed #cbd5e1;margin:12px 0}.detail-amount-wrap{text-align:center;padding:24px 16px;border-radius:var(--radius-md);margin-bottom:16px}.detail-amount-wrap.in{background:var(--green-light)}.detail-amount-wrap.out{background:var(--red-light)}.detail-amount-wrap.kas{background:var(--amber-light)}.detail-emoji{font-size:2.5rem;margin-bottom:8px}.detail-amount{font-family:Sora,sans-serif;font-size:2rem;font-weight:800;letter-spacing:-1px}.detail-amount.in{color:var(--green)}.detail-amount.out{color:var(--red)}.detail-amount.kas{color:var(--amber)}.chart-toggle{display:flex;background:#F1F5F9;border-radius:50px;padding:4px;width:-moz-fit-content;width:fit-content;margin:0 auto 20px}.chart-toggle button{padding:8px 22px;border:none;background:transparent;border-radius:50px;font-family:DM Sans,sans-serif;font-weight:700;font-size:.82rem;color:var(--text-muted);cursor:pointer;transition:all .2s}.chart-toggle button.active{background:var(--white);color:var(--blu-cyan);box-shadow:var(--shadow-sm)}.budget-item{padding:14px 0;border-bottom:1px solid #f1f5f9}.budget-item:last-child{border-bottom:none}.budget-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.budget-kategori{font-weight:600;font-size:.9rem;color:var(--text-dark)}.budget-numbers{font-size:.8rem;color:var(--text-muted);font-weight:500}.budget-bar-track{height:8px;background:#EFF2F5;border-radius:50px;overflow:hidden}.budget-bar-fill{height:100%;border-radius:50px;transition:width .8s ease}.budget-bar-fill.safe{background:var(--green)}.budget-bar-fill.warn{background:var(--amber)}.budget-bar-fill.danger{background:var(--red)}.budget-pct{font-size:.75rem;font-weight:700;margin-top:4px}.budget-pct.safe{color:var(--green)}.budget-pct.warn{color:var(--amber)}.budget-pct.danger{color:var(--red)}.kas-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.kas-card{background:var(--white);border-radius:var(--radius-md);padding:16px;text-align:center;border:1px solid rgba(0,0,0,.04);box-shadow:var(--shadow-sm);transition:transform .2s}.kas-card:hover{transform:translateY(-2px)}.kas-avatar{width:48px;height:48px;border-radius:50%;margin:0 auto 10px;border:2px solid var(--blu-cyan-light);object-fit:cover}.kas-nama{font-weight:700;font-size:.88rem;color:var(--blu-navy);margin-bottom:4px}.kas-total{font-family:Sora,sans-serif;font-weight:700;font-size:.92rem;color:var(--green)}.cs-container{position:fixed!important;bottom:85px!important;right:20px!important;z-index:99999!important;display:flex;flex-direction:column-reverse;align-items:flex-end;gap:12px;pointer-events:none}@media (min-width:769px){.cs-container{bottom:25px!important;right:30px!important}}.cs-item,.cs-main-btn,.cs-menu{pointer-events:auto!important;cursor:pointer}.cs-main-btn{background-color:#1a4074;color:#81a0b9;transition:all .3s ease}.cs-main-btn,.cs-menu-content{pointer-events:auto;padding:12px 24px;border-radius:50px;border:none;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 15px rgba(0,0,0,.2);cursor:pointer}.cs-menu-content{background-color:#6299afe2;color:#449126;transition:all}.cs-menu-content.hidden{display:none;opacity:0;transform:translateY(10px)}.cs-main-btn:hover{transform:translateY(-3px) scale(1.02)}.cs-text{font-size:.85rem;font-weight:600;white-space:nowrap}.cs-menu{margin-bottom:12px;background:rgba(134,160,191,.6);border-radius:12px;box-shadow:0 10px 25px rgba(0,0,0,.15);padding:8px;display:flex;flex-direction:column;gap:4px;opacity:0;visibility:hidden;transform:translateY(10px);transition:all .3s ease;min-width:150px;border:2px solid #e2e8f0}.cs-menu.open{opacity:1;visibility:visible;transform:translateY(0)}.cs-item{text-decoration:none;color:#06202d;font-size:.85rem;padding:10px 16px;border-radius:16px;transition:background .5s}.cs-item:hover{background:#187ba2;color:#75a7ac;transform:scale(1.03)}.cs-item.wa{background:rgba(16,202,13,.3)}.cs-item.email{background:rgba(18,75,206,.3)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px}.empty-state p{font-weight:600;font-size:.9rem}@media (min-width:768px){.app-body{padding-bottom:0;display:flex}.top-header{top:0;right:0;z-index:100}.sidebar,.top-header{position:fixed;left:0}.sidebar{top:64px;bottom:0;width:240px;background:var(--white);border-right:1px solid #edf2f7;display:flex;flex-direction:column;padding:20px 16px;gap:4px;overflow-y:auto}.bottom-nav{display:none}.sidebar .nav-item{flex-direction:row;width:100%;border-radius:var(--radius-md);padding:13px 16px;justify-content:flex-start;gap:12px}.sidebar .nav-item.active{background:var(--blu-bg)}.sidebar .nav-item .nav-icon{transform:none!important}.sidebar .nav-item .nav-label{font-size:.9rem}.app-container{margin-left:240px;margin-top:64px;max-width:960px;padding:28px 32px}.modal-backdrop{align-items:center}.modal-sheet{border-radius:var(--radius-xl);width:90%;max-width:480px;margin:0 auto}.cs-container{bottom:32px;right:32px}.kas-grid,.summary-grid{grid-template-columns:repeat(3,1fr)}}.text-green{color:var(--green)!important}.text-red{color:var(--red)!important}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.font-bold{font-weight:700}.hidden{display:none!important}.chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:50px;font-size:.75rem;font-weight:700;letter-spacing:.3px}.chip-green{background:var(--green-light);color:var(--green)}.chip-red{background:var(--red-light);color:var(--red)}.chip-amber{background:var(--amber-light);color:var(--amber)}.chip-blue{background:var(--blu-cyan-light);color:var(--blu-cyan-hover)}.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}