:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bank-blue:#005baa;--bank-blue-2:#0076d6;--bank-blue-3:#00a4ff;--bank-orange:#f97316;--bank-green:#16a34a;--bank-red:#ef4444;--ink:#0f172a;--muted:#64748b;--line:#e2e8f0;--soft:#f8fafc;--card:#fff;--shadow:0 18px 50px #0f172a1f;background:#edf5ff;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#edf5ff;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.mobile-bank-bg{background:radial-gradient(circle at 10% 10%,#00a4ff40,#0000 28%),radial-gradient(circle at 90% 0,#f973162e,#0000 26%),linear-gradient(145deg,#eaf6ff 0%,#f8fbff 52%,#e3f1ff 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-phone-card{background:var(--card);border:1px solid #ffffffe6;border-radius:34px;width:min(420px,100%);overflow:hidden;box-shadow:0 28px 80px #00326433}.login-hero{color:#fff;background:linear-gradient(135deg,#005baafa,#0076d6f5 58%,#00a4fff2),radial-gradient(circle at 82% 18%,#ffffff47,#0000 26%);min-height:255px;padding:28px;position:relative;overflow:hidden}.login-hero:after{content:"";background:#ffffff29;border-radius:50% 50% 0 0;height:190px;position:absolute;inset:auto -80px -145px}.login-brand-row{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.login-brand-row strong{font-size:20px;display:block}.login-brand-row small{color:#ffffffd1;margin-top:2px;display:block}.login-hero h1{z-index:1;color:#fff;text-align:left;letter-spacing:-.04em;margin:42px 0 8px;font-size:clamp(28px,7vw,38px);line-height:1.08;position:relative}.login-hero p{z-index:1;color:#ffffffdb;max-width:310px;margin:0;line-height:1.55;position:relative}.hero-bubble{background:#ffffff2e;border-radius:999px;position:absolute}.hero-bubble.one{width:88px;height:88px;top:52px;right:32px}.hero-bubble.two{background:#f97316e6;width:32px;height:32px;top:118px;right:128px}.login-sheet{gap:11px;padding:26px 28px 30px;display:grid}.login-sheet h2{color:var(--ink);margin:0 0 6px}.login-shortcuts{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px;display:grid}.login-shortcuts span{text-align:center;color:var(--bank-blue);background:#f1f8ff;border-radius:16px;padding:10px 8px;font-size:12px;font-weight:800}.eyebrow{color:var(--bank-blue);text-transform:uppercase;letter-spacing:.14em;margin:0 0 6px;font-size:11px;font-weight:900}.eyebrow.blue{color:var(--bank-blue)}h1,h2,h3{color:var(--ink);margin:0}h2{letter-spacing:-.03em;font-size:26px}h3{letter-spacing:-.02em;font-size:20px}.center{text-align:center}.muted{color:var(--muted);margin:6px 0 0;line-height:1.55}.inline-note{color:var(--muted);margin-left:6px;font-weight:600}.form-stack{gap:11px;margin-top:18px;display:grid}.form-stack label,.form-grid label,.login-sheet label{color:#334155;font-size:13px;font-weight:900}input,select,textarea{width:100%;color:var(--ink);background:#f8fbff;border:1px solid #dbeafe;border-radius:16px;outline:none;padding:13px 14px;transition:all .2s}textarea{resize:vertical;min-height:90px}input:focus,select:focus,textarea:focus{border-color:var(--bank-blue-2);background:#fff;box-shadow:0 0 0 4px #0076d61f}input[type=color]{min-height:46px;padding:6px}.btn{color:var(--bank-blue);box-shadow:none;background:#eaf3ff;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-weight:900;transition:transform .15s,box-shadow .15s,background .15s;display:inline-flex}.btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px #005baa1f}.btn.primary,.bank-btn{color:#fff;background:linear-gradient(135deg, var(--bank-blue), var(--bank-blue-2) 58%, var(--bank-blue-3));box-shadow:0 14px 28px #005baa3d}.btn.ghost{color:#fff;background:#ffffff24;border:1px solid #ffffff2e}.btn.danger{color:#fff;background:linear-gradient(135deg,#dc2626,#ef4444)}.btn.full{width:100%}.btn.mini{border-radius:12px;padding:8px 10px;font-size:12px}.btn.icon{border-radius:14px;place-items:center;width:38px;height:38px;padding:0;font-size:24px;display:grid}button:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.demo-note{color:var(--muted);text-align:center;margin-top:12px;font-size:13px}.demo-note.left-note{text-align:left}.alert{border-radius:16px;margin:12px 0;padding:12px 14px}.alert.danger{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.app-shell.bank-shell{background:#edf5ff;grid-template-columns:280px 1fr;min-height:100vh;display:grid}.sidebar.bank-sidebar{background:linear-gradient(180deg, var(--bank-blue), #004077 72%, #06305c);color:#fff;flex-direction:column;height:100vh;padding:22px;display:flex;position:sticky;top:0;overflow:hidden}.sidebar.bank-sidebar:before{content:"";background:#ffffff1a;border-radius:999px;width:220px;height:220px;position:absolute;top:-68px;right:-110px}.sidebar-brand{z-index:1;align-items:center;gap:13px;margin-bottom:32px;display:flex;position:relative}.sidebar-brand strong{color:#fff;font-size:20px;display:block}.sidebar-brand small{color:#ffffffb8}.logo-badge{width:48px;height:48px;color:var(--bank-blue);background:linear-gradient(135deg,#fff,#dbeafe);border-radius:16px;place-items:center;font-size:24px;font-weight:1000;display:grid;box-shadow:0 12px 30px #00000029}.logo-badge.big{border-radius:18px;width:52px;height:52px}.sidebar nav{z-index:1;gap:9px;display:grid;position:relative}.sidebar nav button{color:#ffffffd1;text-align:left;background:0 0;border:1px solid #0000;border-radius:18px;align-items:center;gap:12px;width:100%;padding:14px;font-weight:900;display:flex}.sidebar nav button span{background:#ffffff1f;border-radius:12px;place-items:center;width:30px;height:30px;font-size:17px;display:inline-grid}.sidebar nav button.active,.sidebar nav button:hover{color:#fff;background:#ffffff29;border-color:#fff3}.sidebar nav button.active span{color:var(--bank-blue);background:#fff}.sidebar-footer{z-index:1;gap:12px;margin-top:auto;display:grid;position:relative}.user-chip{color:#fff;background:#ffffff21;border-radius:20px;grid-template-columns:36px 1fr;align-items:center;gap:4px 10px;padding:14px;display:grid}.user-chip span{background:#ffffff29;border-radius:12px;grid-row:span 2;place-items:center;width:36px;height:36px;display:grid}.user-chip strong{display:block}.user-chip small{color:#ffffffb3}.content.bank-content{min-width:0;padding:24px}.topbar.bank-topbar{justify-content:space-between;align-items:center;gap:18px;margin-bottom:18px;display:flex}.bank-topbar small{color:var(--muted);margin-top:2px;font-weight:700;display:block}.topbar-profile{width:48px;height:48px;color:var(--bank-blue);box-shadow:var(--shadow);background:#fff;border:none;border-radius:18px;font-weight:1000}.topbar-profile span{place-items:center;width:100%;height:100%;display:grid}.page-grid{gap:18px;display:grid}.bank-home{max-width:1280px}.balance-card{color:#fff;background:linear-gradient(135deg, #004a91, var(--bank-blue-2) 60%, #00a6ff), radial-gradient(circle at 84% 20%, #ffffff4d, transparent 28%);border-radius:28px;padding:24px;position:relative;overflow:hidden;box-shadow:0 22px 55px #005baa3d}.balance-card:before{content:"";background:#ffffff24;border-radius:999px;width:240px;height:240px;position:absolute;bottom:-130px;right:-90px}.balance-card:after{content:"";background:#f97316eb;border-radius:999px;width:76px;height:76px;position:absolute;top:28px;right:62px;box-shadow:-26px 14px #ffffff24}.balance-top,.balance-bottom{z-index:1;justify-content:space-between;align-items:flex-start;gap:18px;display:flex;position:relative}.balance-top span{color:#ffffffc7;font-weight:800;display:block}.balance-top strong{letter-spacing:-.05em;margin-top:8px;font-size:clamp(29px,5vw,48px);display:block}.chip-card{letter-spacing:.12em;background:#ffffff2b;border:1px solid #ffffff38;border-radius:14px;padding:10px 13px;font-weight:1000}.balance-bottom{align-items:center;margin-top:28px}.balance-bottom span{color:#fffc;font-size:13px;font-weight:800}.balance-bottom input{color:#fff;background:#ffffff29;border-color:#ffffff38;max-width:170px}.balance-bottom input::-webkit-calendar-picker-indicator{filter:invert()}.quick-menu-card{box-shadow:var(--shadow);background:#fff;border:1px solid #e2e8f0e6;border-radius:24px;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:16px;display:grid}.quick-item{color:var(--ink);justify-items:center;gap:8px;font-size:13px;font-weight:900;display:grid}.quick-item em{color:#fff;background:linear-gradient(135deg, var(--bank-blue), var(--bank-blue-3));border-radius:18px;place-items:center;width:52px;height:52px;font-size:24px;font-style:normal;display:grid;box-shadow:0 10px 22px #005baa2e}.quick-item:nth-child(2) em{background:linear-gradient(135deg,#f97316,#f59e0b)}.quick-item:nth-child(3) em{background:linear-gradient(135deg,#0f766e,#14b8a6)}.quick-item:nth-child(4) em{background:linear-gradient(135deg,#7c3aed,#a855f7)}.toolbar{box-shadow:var(--shadow);background:#fff;border:1px solid #e2e8f0e6;border-radius:24px;justify-content:space-between;align-items:center;gap:16px;padding:18px;display:flex}.toolbar input{max-width:220px}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.stat-card{background:#fff;border:1px solid #e2e8f0e6;border-radius:24px;justify-content:space-between;gap:12px;min-height:118px;padding:18px;display:flex;position:relative;overflow:hidden;box-shadow:0 14px 34px #0f172a14}.stat-card:before{content:"";background:#005baa1a;border-radius:50%;width:126px;height:126px;position:absolute;inset:auto -36px -60px auto}.stat-card.green:before{background:#16a34a1f}.stat-card.red:before{background:#ef44441f}.stat-card.purple:before{background:#7c3aed1f}.stat-card span{color:var(--muted);font-size:13px;font-weight:900}.stat-card strong{color:var(--ink);margin-top:12px;font-size:clamp(18px,2vw,24px);display:block}.stat-card em{z-index:1;width:44px;height:44px;color:var(--bank-blue);background:#edf7ff;border-radius:16px;place-items:center;font-size:24px;font-style:normal;display:grid;position:relative}.stat-card.green em{color:var(--bank-green);background:#ecfdf5}.stat-card.red em{color:var(--bank-red);background:#fef2f2}.stat-card.purple em{color:#7c3aed;background:#f5f3ff}.panel{box-shadow:var(--shadow);background:#fff;border:1px solid #e2e8f0e6;border-radius:24px;min-width:0;padding:20px}.bank-panel{background:#fff}.panel-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.two-columns{grid-template-columns:minmax(0,1.55fr) minmax(300px,.75fr);align-items:start;gap:18px;display:grid}.categories-page{margin-top:0}.legend{color:var(--muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;font-weight:800;display:flex}.dot{border-radius:50%;width:10px;height:10px;display:inline-block}.dot.income{background:var(--bank-green)}.dot.expense{background:var(--bank-orange)}.chart{width:100%;height:280px;display:block}.bar-income{fill:var(--bank-blue-2)}.bar-expense{fill:var(--bank-orange)}.chart-label{fill:var(--muted);font-size:11px}.empty{text-align:center;color:var(--muted);border:1px dashed #cbd5e1;border-radius:18px;padding:32px 16px}.empty.small{padding:18px}.loading{color:var(--muted)}.link-more{color:var(--bank-blue);font-size:13px;font-weight:900}.category-list{gap:12px;margin-top:14px;display:grid}.category-row{background:#f8fbff;border:1px solid #eff6ff;border-radius:18px;align-items:center;gap:12px;padding:12px;display:flex}.category-row strong,.category-row small{display:block}.category-row small{color:var(--muted);margin-top:3px}.category-icon,.category-row span:first-child{color:#fff;border-radius:15px;place-items:center;width:42px;height:42px;display:grid}.category-cards{gap:12px;margin-top:14px;display:grid}.category-card{background:#f8fbff;border:1px solid #eff6ff;border-radius:18px;grid-template-columns:48px 1fr auto auto;align-items:center;gap:12px;padding:13px;display:grid}.category-card>span{color:#fff;border-radius:14px;place-items:center;width:44px;height:44px;display:grid}.category-card small,td small{color:var(--muted);margin-top:4px;display:block}.table-wrap{margin-top:12px;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;text-align:left;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:12px;font-size:12px}td{vertical-align:top;border-bottom:1px solid #edf2f7;padding:14px 12px}.right{text-align:right}.amount{white-space:nowrap;font-weight:1000}.amount.income{color:var(--bank-green)}.amount.expense{color:var(--bank-orange)}.pill{color:var(--bank-blue);white-space:nowrap;background:#eef6ff;border:1px solid #dbeafe;border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-weight:900;display:inline-flex}.actions{flex-wrap:wrap;gap:8px;display:flex}.right-actions{justify-content:flex-end}.filter-panel{grid-template-columns:180px 180px 1fr auto;align-items:center;gap:12px;display:grid}.filter-inline{grid-template-columns:minmax(180px,260px) auto;align-items:center;gap:10px;display:grid}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172a85;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #e2e8f0e6;border-radius:28px;width:min(760px,100%);max-height:92vh;padding:22px;overflow:auto;box-shadow:0 28px 90px #0f172a47}.modal-head{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.form-grid{grid-template-columns:160px 1fr;align-items:center;gap:12px;display:grid}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.toast{z-index:80;color:#fff;background:linear-gradient(135deg,#047857,#16a34a);border-radius:18px;min-width:280px;max-width:420px;padding:15px 17px;position:fixed;bottom:22px;right:22px;box-shadow:0 18px 50px #0f172a38}.toast.error{background:linear-gradient(135deg,#b91c1c,#ef4444)}.toast strong,.toast span{display:block}.toast span{color:#fff;margin-top:4px}.badge{min-width:72px;color:var(--bank-blue);background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;justify-content:center;align-items:center;padding:7px 10px;font-size:12px;font-weight:1000;display:inline-flex}.badge.admin{color:var(--bank-blue);background:#e0f2fe;border-color:#bae6fd}.badge.user{color:var(--bank-green);background:#dcfce7;border-color:#bbf7d0}.badge.active{color:#15803d;background:#dcfce7;border-color:#bbf7d0}.badge.inactive{color:#b91c1c;background:#fee2e2;border-color:#fecaca}.bottom-nav{display:none}@media (width<=1100px){.app-shell.bank-shell{grid-template-columns:96px 1fr}.sidebar.bank-sidebar{padding:16px 12px}.sidebar-brand div{display:none}.sidebar nav button{justify-content:center;padding:12px 8px;font-size:0}.sidebar nav button span{font-size:20px}.sidebar-footer .user-chip{display:none}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.two-columns{grid-template-columns:1fr}}@media (width<=780px){body{background:#edf5ff}.app-shell.bank-shell{padding-bottom:92px;display:block}.sidebar.bank-sidebar{display:none}.content.bank-content{padding:16px}.topbar.bank-topbar{z-index:20;color:#fff;background:linear-gradient(135deg, var(--bank-blue), var(--bank-blue-2));border-radius:0 0 28px 28px;margin:-16px -16px 16px;padding:18px 16px 16px;position:sticky;top:0;box-shadow:0 18px 40px #005baa33}.bank-topbar h2,.bank-topbar .eyebrow{color:#fff}.bank-topbar small{color:#ffffffc7}.topbar-profile{color:#fff;box-shadow:none;background:#ffffff2e}.balance-card{border-radius:28px;margin-top:-4px}.balance-top,.balance-bottom,.toolbar,.panel-head{flex-direction:column;align-items:stretch}.balance-bottom input{max-width:100%}.quick-menu-card{grid-template-columns:repeat(4,1fr);gap:4px;padding:14px 8px}.quick-item{font-size:11px}.quick-item em{border-radius:16px;width:46px;height:46px;font-size:20px}.toolbar input{max-width:100%}.stats-grid,.filter-panel{grid-template-columns:1fr}.filter-inline{grid-template-columns:1fr;width:100%}.form-grid{grid-template-columns:1fr}.category-card{grid-template-columns:44px 1fr}.category-card .btn{width:100%}.bottom-nav{z-index:40;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;border:1px solid #e2e8f0e6;border-radius:24px;grid-template-columns:repeat(5,1fr);gap:4px;padding:8px;display:grid;position:fixed;bottom:12px;left:12px;right:12px;box-shadow:0 18px 55px #0f172a2e}.bottom-nav button{color:#64748b;background:0 0;border:none;border-radius:18px;justify-items:center;gap:3px;padding:8px 4px;font-weight:900;display:grid}.bottom-nav button span{font-size:20px}.bottom-nav button small{font-size:10px}.bottom-nav button.active{color:#fff;background:linear-gradient(135deg, var(--bank-blue), var(--bank-blue-2))}.toast{min-width:0;bottom:96px;left:14px;right:14px}}@media (width<=480px){.login-page{align-items:stretch;padding:0}.login-phone-card{border-radius:0;width:100%;min-height:100vh}.login-hero{border-radius:0 0 28px 28px;min-height:286px}.login-sheet{padding:24px 20px 28px}.balance-card{padding:20px}.balance-top strong{font-size:31px}.chip-card{display:none}.panel,.toolbar{border-radius:22px;padding:16px}.stat-card{min-height:104px}.modal-card{border-radius:24px;padding:18px}}.wallet-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.wallet-mini-card{color:#fff;background:linear-gradient(135deg,#005baa 0%,#0076d6 55%,#00a4ff 100%);border-radius:24px;justify-content:space-between;gap:14px;min-height:132px;padding:20px;display:flex;position:relative;overflow:hidden;box-shadow:0 18px 44px #005baa38}.wallet-mini-card.wife,.wallet-detail-card.istri{background:linear-gradient(135deg,#7c3aed 0%,#db2777 58%,#f97316 100%)}.wallet-mini-card:after,.wallet-detail-card:after{content:"";background:#ffffff2e;border-radius:50%;width:120px;height:120px;position:absolute;top:-30px;right:-30px}.wallet-mini-card span,.wallet-mini-card small,.wallet-detail-card small,.wallet-detail-card .muted{color:#ffffffd1}.wallet-mini-card strong{margin:10px 0 6px;font-size:clamp(21px,3vw,30px);display:block}.wallet-mini-card em{z-index:1;background:#ffffff2e;border-radius:16px;place-items:center;width:44px;height:44px;font-style:normal;font-weight:950;display:grid;position:relative}.wallet-page-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.wallet-detail-card{color:#fff;background:linear-gradient(135deg,#005baa 0%,#0076d6 60%,#00a4ff 100%);border-radius:28px;padding:24px;position:relative;overflow:hidden;box-shadow:0 20px 50px #0f172a29}.wallet-card-top{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.wallet-card-top>span{background:#ffffff2e;border-radius:18px;place-items:center;width:50px;height:50px;font-size:24px;display:grid}.wallet-detail-card h2{z-index:1;margin:22px 0 14px;font-size:clamp(26px,4vw,38px);position:relative}.wallet-meter{z-index:1;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:16px 0;display:grid;position:relative}.wallet-meter>div{background:#ffffff24;border-radius:16px;padding:12px}.wallet-meter span,.wallet-meter strong{display:block}.wallet-meter strong{color:#fff;margin-top:4px}.pill.wallet.suami{color:#075985;background:#e0f2fe;border-color:#bae6fd}.pill.wallet.istri{color:#9d174d;background:#fce7f3;border-color:#fbcfe8}.badge.suami{color:#075985;background:#e0f2fe;border-color:#bae6fd}.badge.istri{color:#9d174d;background:#fce7f3;border-color:#fbcfe8}@media (width<=760px){.wallet-summary-grid,.wallet-page-grid{grid-template-columns:1fr}.quick-menu-card{grid-template-columns:repeat(5,1fr)}}
