*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#222638;--border:#2e3348;--text:#e8eaf0;--text-muted:#7c82a0;--accent:#4f8ef7;--accent-dim:#4f8ef71f;--green:#34d399;--green-dim:#34d3991f;--red:#f87171;--red-dim:#f871711f;--yellow:#fbbf24;--yellow-dim:#fbbf241f;--radius:10px;--radius-sm:6px;--shadow:0 4px 24px #0000004d;--font:"Plus Jakarta Sans",sans-serif;--mono:"JetBrains Mono",monospace}body{background:#0f1117;background:var(--bg);color:#e8eaf0;color:var(--text);font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:14px;line-height:1.6}.layout,body{min-height:100vh}.layout,.sidebar{display:flex}.sidebar{background:#1a1d27;background:var(--surface);border-right:1px solid #2e3348;border-right:1px solid var(--border);flex-direction:column;height:100vh;position:fixed;width:240px;z-index:100}.main{flex:1 1;margin-left:240px;min-height:100vh;padding:32px}.sidebar-logo{border-bottom:1px solid #2e3348;border-bottom:1px solid var(--border);color:#4f8ef7;color:var(--accent);font-size:18px;font-weight:700;letter-spacing:-.3px;padding:24px 20px 16px}.sidebar-logo span{color:#7c82a0;color:var(--text-muted);display:block;font-size:12px;font-weight:400;margin-top:2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:16px 12px}.nav-item{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#7c82a0;color:var(--text-muted);cursor:pointer;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:14px;font-weight:500;gap:10px;padding:10px 12px;text-align:left;text-decoration:none;transition:all .15s;width:100%}.nav-item:hover{background:#222638;background:var(--surface2);color:#e8eaf0;color:var(--text)}.nav-item.active{background:#4f8ef71f;background:var(--accent-dim);color:#4f8ef7;color:var(--accent)}.nav-item .icon{flex-shrink:0;height:18px;width:18px}.sidebar-bottom{border-top:1px solid #2e3348;border-top:1px solid var(--border);padding:16px 12px}.user-info{font-size:13px;padding:8px 12px}.user-info .name{font-weight:600}.user-info .role{color:#7c82a0;color:var(--text-muted);font-size:12px}.badge-pending{background:#fbbf241f;background:var(--yellow-dim);border-radius:10px;color:#fbbf24;color:var(--yellow);font-size:11px;font-weight:600;margin-left:auto;padding:1px 7px}.card{background:#1a1d27;background:var(--surface);border:1px solid #2e3348;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:24px}.card-sm{padding:16px}.stat-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{background:#1a1d27;background:var(--surface);border:1px solid #2e3348;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow:hidden;padding:20px;position:relative}.stat-card:before{content:"";height:3px;left:0;position:absolute;right:0;top:0}.stat-card.income:before{background:#34d399;background:var(--green)}.stat-card.expense:before{background:#f87171;background:var(--red)}.stat-card.balance:before{background:#4f8ef7;background:var(--accent)}.stat-card.pending:before{background:#fbbf24;background:var(--yellow)}.stat-label{color:#7c82a0;color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.stat-value{font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:26px;font-weight:700;line-height:1.2;margin-top:6px}.stat-value.income{color:#34d399;color:var(--green)}.stat-value.expense{color:#f87171;color:var(--red)}.stat-value.balance{color:#4f8ef7;color:var(--accent)}.stat-value.pending{color:#fbbf24;color:var(--yellow)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{color:#7c82a0;color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}td,th{border-bottom:1px solid #2e3348;border-bottom:1px solid var(--border)}td{font-size:13px;padding:12px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:#222638;background:var(--surface2)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:3px 9px}.badge.income{background:#34d3991f;background:var(--green-dim);color:#34d399;color:var(--green)}.badge.expense{background:#f871711f;background:var(--red-dim);color:#f87171;color:var(--red)}.badge.approved{background:#34d3991f;background:var(--green-dim);color:#34d399;color:var(--green)}.badge.pending{background:#fbbf241f;background:var(--yellow-dim);color:#fbbf24;color:var(--yellow)}.badge.rejected{background:#f871711f;background:var(--red-dim);color:#f87171;color:var(--red)}.badge.admin{background:#4f8ef71f;background:var(--accent-dim);color:#4f8ef7;color:var(--accent)}.badge.user{background:#222638;background:var(--surface2);color:#7c82a0;color:var(--text-muted)}.badge.active{background:#34d3991f;background:var(--green-dim);color:#34d399;color:var(--green)}.badge.inactive{background:#f871711f;background:var(--red-dim);color:#f87171;color:var(--red)}.form-group{display:flex;flex-direction:column;gap:6px}.label{color:#7c82a0;color:var(--text-muted);font-size:13px;font-weight:500}.input,.select,.textarea{background:#222638;background:var(--surface2);border:1px solid #2e3348;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#e8eaf0;color:var(--text);font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:14px;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}.input:focus,.select:focus,.textarea:focus{border-color:#4f8ef7;border-color:var(--accent)}.select option{background:#222638;background:var(--surface2)}.textarea{min-height:80px;resize:vertical}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid-3{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.btn{align-items:center;border:none;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:13px;font-weight:600;gap:6px;justify-content:center;padding:9px 16px;text-decoration:none;transition:all .15s}.btn-primary{background:#4f8ef7;background:var(--accent);color:#fff}.btn-primary:hover{opacity:.88}.btn-secondary{background:#222638;background:var(--surface2);border:1px solid #2e3348;border:1px solid var(--border);color:#e8eaf0;color:var(--text)}.btn-secondary:hover{border-color:#4f8ef7;border-color:var(--accent);color:#4f8ef7;color:var(--accent)}.btn-success{background:#34d3991f;background:var(--green-dim);color:#34d399;color:var(--green)}.btn-success:hover{background:#34d399;background:var(--green);color:#000}.btn-danger{background:#f871711f;background:var(--red-dim);color:#f87171;color:var(--red)}.btn-danger:hover{background:#f87171;background:var(--red);color:#fff}.btn-sm{font-size:12px;padding:5px 10px}.btn:disabled{cursor:not-allowed;opacity:.5}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.3px}.page-title span{color:#7c82a0;color:var(--text-muted);font-size:14px;font-weight:400;margin-left:8px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.modal{background:#1a1d27;background:var(--surface);border:1px solid #2e3348;border:1px solid var(--border);border-radius:14px;box-shadow:0 4px 24px #0000004d;box-shadow:var(--shadow);max-height:90vh;max-width:480px;overflow-y:auto;padding:28px;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:18px;font-weight:700}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.alert{border-radius:6px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px;padding:12px 16px}.alert-error{background:#f871711f;background:var(--red-dim);border:1px solid #f8717133;color:#f87171;color:var(--red)}.alert-success{background:#34d3991f;background:var(--green-dim);border:1px solid #34d39933;color:#34d399;color:var(--green)}.filters{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.filter-input{width:auto}.amount{font-family:JetBrains Mono,monospace;font-family:var(--mono);font-weight:500}.amount.income{color:#34d399;color:var(--green)}.amount.expense{color:#f87171;color:var(--red)}.login-page{align-items:center;background:#0f1117;background:var(--bg);display:flex;justify-content:center;min-height:100vh}.login-box{background:#1a1d27;background:var(--surface);border:1px solid #2e3348;border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 24px #0000004d;box-shadow:var(--shadow);max-width:400px;padding:40px;width:100%}.login-logo{color:#4f8ef7;color:var(--accent);font-size:24px;font-weight:700;margin-bottom:8px}.login-subtitle{font-size:14px;margin-bottom:32px}.empty,.login-subtitle{color:#7c82a0;color:var(--text-muted)}.empty{padding:48px;text-align:center}.empty-icon{font-size:40px;margin-bottom:12px}.loading{align-items:center;display:flex;justify-content:center;padding:48px}.spinner{animation:spin .7s linear infinite;border:2px solid #2e3348;border-top-color:#4f8ef7;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:28px;width:28px}@keyframes spin{to{transform:rotate(1turn)}}.pagination{align-items:center;display:flex;gap:6px;justify-content:flex-end;margin-top:16px}.page-info{color:#7c82a0;color:var(--text-muted);font-size:13px;margin:0 8px}.chart-section{margin-bottom:24px}.section-title{font-size:15px;font-weight:600;margin-bottom:16px}.bottom-nav{background:#1a1d27;background:var(--surface);border-top:1px solid #2e3348;border-top:1px solid var(--border);bottom:0;display:none;left:0;padding:6px 0 env(safe-area-inset-bottom,6px);position:fixed;right:0;z-index:200}.bottom-nav-items{align-items:center;display:flex;justify-content:space-around}.bottom-nav-item{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#7c82a0;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:10px;font-weight:600;gap:3px;min-width:56px;padding:6px 12px;position:relative;text-decoration:none;transition:color .15s}.bottom-nav-item .bnav-icon{font-size:20px;line-height:1}.bottom-nav-item.active{color:#4f8ef7;color:var(--accent)}.bottom-nav-badge{background:#fbbf24;background:var(--yellow);border-radius:10px;color:#000;font-size:9px;font-weight:700;padding:1px 5px;position:absolute;right:8px;top:4px}.mobile-menu-overlay{align-items:flex-end;background:#00000080;display:none;inset:0;position:fixed;z-index:300}.mobile-menu-overlay.open{display:flex}.mobile-menu-sheet{background:#1a1d27;background:var(--surface);border-radius:20px 20px 0 0;border-top:1px solid #2e3348;border-top:1px solid var(--border);padding:20px 16px calc(env(safe-area-inset-bottom, 0px) + 20px);width:100%}.mobile-menu-handle{background:#2e3348;background:var(--border);border-radius:2px;height:4px;margin:0 auto 20px;width:36px}.mobile-menu-item{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius);color:#7c82a0;color:var(--text-muted);cursor:pointer;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:15px;font-weight:500;gap:12px;padding:14px 12px;text-decoration:none;transition:all .15s;width:100%}.mobile-menu-item.active,.mobile-menu-item:hover{background:#222638;background:var(--surface2);color:#e8eaf0;color:var(--text)}.mobile-menu-item .icon{font-size:18px;text-align:center;width:24px}.mobile-menu-user{background:#222638;background:var(--surface2);border-radius:10px;border-radius:var(--radius);margin-bottom:12px;padding:12px}.mobile-menu-user .name{font-size:15px;font-weight:600}.mobile-menu-user .role{color:#7c82a0;color:var(--text-muted);font-size:12px}@media (max-width:768px){.sidebar{display:none}.bottom-nav{display:block}.main{margin-left:0;padding:16px 16px calc(80px + env(safe-area-inset-bottom, 0px))}.page-title{font-size:18px}.page-header,.stat-grid{margin-bottom:16px}.stat-grid{gap:10px;grid-template-columns:1fr 1fr}.stat-card{padding:14px}.stat-value{font-size:18px}.form-grid,.form-grid-3{grid-template-columns:1fr}.filters{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding-bottom:4px}.filters::-webkit-scrollbar{display:none}.filter-input{flex-shrink:0;min-width:130px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:600px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;max-height:92vh;padding:24px 20px calc(env(safe-area-inset-bottom, 0px) + 20px)}.login-box{border:none;border-radius:0;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:32px 24px}.cat-grid,.report-grid{grid-template-columns:1fr!important}.input,.select,.textarea{font-size:16px;padding:11px 14px}.btn{padding:11px 16px}.btn-sm{font-size:12px;padding:7px 12px}}@media (max-width:400px){.stat-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:15px}.main{padding:12px 12px calc(80px + env(safe-area-inset-bottom, 0px))}}
/*# sourceMappingURL=main.02d9a88e.css.map*/