@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";
:root{--bg-primary:#f4f8ff;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#eff5ff;--bg-glass:#fffffff5;--bg-input:#fff;--border-color:#d6e3ff;--border-color-hover:#b6ccff;--text-primary:#0b1f44;--text-secondary:#26447b;--text-muted:#4b6394;--accent-green:#0c7a43;--accent-green-dim:#eaf8f1;--accent-green-glow:#0c7a4338;--accent-red:#b42318;--accent-red-dim:#fff2f0;--accent-red-glow:#b4231833;--accent-blue:#0f4ec9;--accent-blue-dim:#e8f0ff;--accent-blue-glow:#0f4ec947;--accent-purple:#3349b9;--accent-purple-dim:#eef1ff;--accent-yellow:#8a5a00;--accent-yellow-dim:#fff5db;--gradient-primary:linear-gradient(135deg, #0f4ec9 0%, #2f6bde 100%);--gradient-income:linear-gradient(135deg, #11864b 0%, #0c6f3e 100%);--gradient-expense:linear-gradient(135deg, #c53a2a 0%, #a4271b 100%);--sidebar-width:260px;--radius:12px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 2px 10px #0f285a14;--shadow-md:0 8px 24px #0f285a1f;--shadow-lg:0 16px 40px #0f285a29;--shadow-glow-green:0 0 20px #0c7a432e;--shadow-glow-red:0 0 20px #b4231824;--shadow-glow-blue:0 0 20px #0f4ec92e}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;overflow-x:hidden}:focus-visible{outline-offset:2px;outline:3px solid #1f63e2}.login-page{background:linear-gradient(#f7faff 0%,#ecf3ff 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(at 30% 20%,#4d8eff14 0%,#0000 50%),radial-gradient(at 70% 80%,#a855f70f 0%,#0000 50%),radial-gradient(#00d68f0a 0%,#0000 50%);width:200%;height:200%;animation:15s ease-in-out infinite alternate bgPulse;position:absolute;top:-50%;left:-50%}@keyframes bgPulse{0%{transform:translate(0)rotate(0)}to{transform:translate(-5%,3%)rotate(2deg)}}.login-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:48px 40px;animation:.6s ease-out slideUp;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{background:var(--gradient-primary);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;font-size:28px;display:inline-flex;box-shadow:0 8px 24px #4d8eff4d}.login-logo h1{color:var(--accent-blue);font-size:24px;font-weight:700}.login-logo p{color:var(--text-secondary);margin-top:8px;font-size:14px}.login-form{flex-direction:column;gap:16px;display:flex}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:var(--text-secondary);font-size:13px;font-weight:500}.input-group input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);outline:none;padding:14px 16px;font-family:Plus Jakarta Sans,sans-serif;font-size:15px;transition:all .3s}.input-group input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-dim)}.input-group input::placeholder{color:var(--text-muted)}.btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-top:8px;padding:14px 24px;font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:600;transition:all .3s;position:relative;overflow:hidden}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4d8eff4d}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{background:var(--accent-red-dim);border-radius:var(--radius);color:var(--accent-red);border:1px solid #ff4d6a4d;padding:12px 16px;font-size:13px;animation:.4s ease-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.login-footer{text-align:center;color:var(--text-muted);margin-top:24px;font-size:13px}.dashboard-layout{min-height:100vh;display:flex;position:relative;overflow-x:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:101;flex-direction:column;height:100vh;padding:24px 16px;transition:transform .3s;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:24px;padding:0 8px 24px;display:flex}.sidebar-brand-icon{background:var(--gradient-primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.sidebar-brand h2{color:var(--accent-blue);font-size:16px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.sidebar-link{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 14px;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.sidebar-link:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-blue-dim);color:#0a3ca6;border:1px solid #bcd0ff}.sidebar-link-icon{text-align:center;width:24px;font-size:18px}.sidebar-user{border-top:1px solid var(--border-color);align-items:center;gap:12px;margin-top:auto;padding:16px 14px;display:flex}.sidebar-user-avatar{background:var(--gradient-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-phone{color:var(--text-muted);font-size:11px}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:32px}.page-header{margin-bottom:32px}.page-header h1{margin-bottom:4px;font-size:28px;font-weight:700}.page-header p{color:var(--text-secondary);font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:all .3s;position:relative;overflow:hidden}.stat-card:before{content:"";opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card.income:before{background:var(--gradient-income)}.stat-card.expense:before{background:var(--gradient-expense)}.stat-card.balance:before{background:var(--gradient-primary)}.stat-card.transactions:before{background:linear-gradient(135deg, var(--accent-yellow) 0%, #f59e0b 100%)}.stat-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.stat-card-label{color:var(--text-secondary);font-size:13px;font-weight:500}.stat-card-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.stat-card.income .stat-card-icon{background:var(--accent-green-dim)}.stat-card.expense .stat-card-icon{background:var(--accent-red-dim)}.stat-card.balance .stat-card-icon{background:var(--accent-blue-dim)}.stat-card.transactions .stat-card-icon{background:var(--accent-yellow-dim)}.stat-card-value{margin-bottom:4px;font-size:26px;font-weight:700}.stat-card.income .stat-card-value{color:var(--accent-green)}.stat-card.expense .stat-card-value{color:var(--accent-red)}.stat-card.balance .stat-card-value{color:var(--accent-blue)}.stat-card.transactions .stat-card-value{color:var(--accent-yellow)}.stat-card-sub{color:var(--text-muted);font-size:12px}.charts-grid{grid-template-columns:2fr 1fr;gap:20px;margin-bottom:32px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;padding:24px;overflow:hidden}.chart-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:20px;display:flex}.chart-card-title{font-size:16px;font-weight:600}.chart-card-subtitle{color:var(--text-muted);font-size:12px}.chart-container{width:100%;max-width:100%;height:280px;position:relative}.table-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.table-header{border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:20px 24px;display:flex}.table-title{font-size:16px;font-weight:600}.table-filters{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:8px 14px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:500;transition:all .2s}.filter-btn:hover{border-color:var(--border-color-hover);color:var(--text-primary)}.filter-btn.active{background:var(--accent-blue-dim);border-color:var(--accent-blue);color:var(--accent-blue)}.search-input{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;outline:none;width:180px;padding:8px 14px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;transition:all .3s}.search-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-dim)}.search-input::placeholder{color:var(--text-muted)}.transactions-table{border-collapse:collapse;width:100%}.transactions-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);padding:12px 24px;font-size:11px;font-weight:600}.transactions-table td{border-bottom:1px solid var(--border-color);padding:14px 24px;font-size:13px}.transactions-table tr:last-child td{border-bottom:none}.transactions-table tr{transition:background .2s}.transactions-table tr:hover{background:var(--bg-card-hover)}.tx-type-badge{border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.tx-type-badge.income{background:var(--accent-green-dim);color:var(--accent-green)}.tx-type-badge.expense{background:var(--accent-red-dim);color:var(--accent-red)}.tx-amount{font-variant-numeric:tabular-nums;font-weight:600}.tx-amount.income{color:var(--accent-green)}.tx-amount.expense{color:var(--accent-red)}.tx-category{color:var(--text-secondary);align-items:center;gap:6px;display:flex}.tx-delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;padding:6px 10px;font-size:13px;transition:all .2s}.tx-delete-btn:hover{background:var(--accent-red-dim);color:var(--accent-red);border-color:#ff4d6a4d}.table-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.table-footer-info{color:var(--text-muted);font-size:12px}.pagination{gap:4px;display:flex}.pagination-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:6px 12px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;transition:all .2s}.pagination-btn:hover{border-color:var(--border-color-hover);color:var(--text-primary)}.pagination-btn.active{background:var(--accent-blue-dim);border-color:var(--accent-blue);color:var(--accent-blue)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.month-picker{align-items:center;gap:8px;display:flex}.month-picker-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:8px 12px;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;transition:all .2s}.month-picker-btn:hover{border-color:var(--border-color-hover);color:var(--text-primary)}.month-picker-label{color:var(--text-primary);text-align:center;min-width:140px;font-size:14px;font-weight:600}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:300px;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:13px}.empty-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:48px}.empty-state-text{text-align:center;font-size:14px}.empty-state-sub{color:var(--text-muted);margin-top:8px;font-size:12px}.category-list{flex-direction:column;gap:8px;display:flex}.category-item{background:var(--bg-input);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:12px 16px;transition:background .2s;display:flex}.category-item:hover{background:var(--bg-card-hover)}.category-item-left{align-items:center;gap:10px;display:flex}.category-item-icon{font-size:18px}.category-item-name{font-size:13px;font-weight:500}.category-item-amount{font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.category-item-bar{background:var(--border-color);border-radius:2px;width:100%;height:4px;margin-top:8px;overflow:hidden}.category-item-bar-fill{border-radius:2px;height:100%;transition:width .6s}.category-item-bar-fill.income{background:var(--accent-green)}.category-item-bar-fill.expense{background:var(--accent-red)}.recent-tx-list{flex-direction:column;display:flex}.recent-tx-item{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.recent-tx-item:last-child{border-bottom:none}.recent-tx-left{align-items:center;gap:12px;display:flex}.recent-tx-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.recent-tx-icon.income{background:var(--accent-green-dim)}.recent-tx-icon.expense{background:var(--accent-red-dim)}.recent-tx-desc{font-size:13px;font-weight:500}.recent-tx-date{color:var(--text-muted);margin-top:2px;font-size:11px}.recent-tx-amount{font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.recent-tx-amount.income{color:var(--accent-green)}.recent-tx-amount.expense{color:var(--accent-red)}.mobile-header{border-bottom:1px solid var(--border-color);z-index:100;background:#fff;justify-content:space-between;align-items:center;width:100%;padding:16px 20px;display:none;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #0000000d}.mobile-menu-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;font-size:24px;transition:background .2s;display:flex}.mobile-menu-btn:hover{background:var(--bg-card-hover)}.mobile-menu-btn:active{background:var(--border-color)}.sidebar-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;animation:.2s ease-out fadeIn;display:none;position:fixed;inset:0}@media (max-width:768px){.sidebar{width:280px;box-shadow:var(--shadow-lg);transform:translate(-100%)!important}.sidebar.open{transform:translate(0)!important}.sidebar-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;animation:.2s ease-out fadeIn;display:none;position:fixed;inset:0}.sidebar-overlay.show{display:block}.mobile-header{display:flex!important}.main-content{width:100%;padding:20px 16px;margin-left:0!important;padding-top:80px!important}.charts-grid{gap:16px;grid-template-columns:1fr!important}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-card-value{font-size:20px}.page-header h1{font-size:22px}.page-header{margin-bottom:20px}.chart-card{width:100%;overflow:hidden;padding:16px!important}.chart-container{max-width:100%;width:100%!important;height:250px!important}.chart-card-title{font-size:14px}.chart-card-subtitle{font-size:11px}.transactions-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.transactions-table thead{display:none}.transactions-table tbody{display:block}.transactions-table tr{border:1px solid var(--border-color);background:var(--bg-card);border-radius:8px;margin-bottom:8px;padding:10px;display:block}.transactions-table td{text-align:left;border:none;padding:4px 0;display:block}.transactions-table td:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;margin-bottom:2px;font-size:10px;font-weight:600;display:block}.table-header{flex-direction:column;align-items:stretch;padding:16px}.table-filters{justify-content:flex-start;width:100%}.search-input{width:100%}.table-footer{flex-direction:column;align-items:stretch;gap:12px}.pagination{justify-content:center}.month-picker{justify-content:center;width:100%}.month-picker-label{min-width:120px}.category-item{padding:12px}.category-item-icon{font-size:16px}.category-item-name,.category-item-amount{font-size:12px}.card{padding:16px}div[style*="position: fixed"][style*="backgroundColor: rgba(0,0,0,0.5)"]>div{margin:16px;max-width:calc(100% - 32px)!important}.admin-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.admin-table thead{display:none}.admin-table tbody{display:block}.admin-table tr{border:1px solid var(--border-color);background:var(--bg-card);border-radius:8px;margin-bottom:16px;padding:12px;display:block}.admin-table td{text-align:left;border:none;padding:8px 0;display:block}.admin-table td:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.admin-table td:first-child{padding-top:0}.admin-table td:last-child{padding-bottom:0}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.login-card{margin:16px;padding:32px 24px}.stat-card-value,.page-header h1{font-size:18px}.page-header p{font-size:13px}.chart-container{height:200px!important}.chart-card{padding:12px!important}.chart-card-title{font-size:13px}.chart-card-subtitle{font-size:10px}.transactions-table tr{margin-bottom:6px!important;padding:8px!important}.transactions-table td{font-size:12px;padding:3px 0!important}.transactions-table td:before{margin-bottom:1px!important;font-size:9px!important}.table-filters{flex-direction:column}.filter-btn{text-align:center;width:100%}.saving-actions{flex-direction:column!important;width:100%!important}.saving-actions button{justify-content:center;width:100%!important}.month-picker-btn{padding:6px 10px;font-size:13px}.month-picker-label{min-width:100px;font-size:13px}.main-content{padding:80px 12px 16px!important}.chart-card,.stat-card,.table-card,.card{padding:12px!important}.page-header{margin-bottom:16px}.category-item{padding:10px}.category-item-icon{font-size:14px}.category-item-name,.category-item-amount{font-size:11px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s ease-out fadeIn}.animate-slide-up{animation:.5s ease-out slideInUp}.stagger-1{animation-delay:50ms;animation-fill-mode:both}.stagger-2{animation-delay:.1s;animation-fill-mode:both}.stagger-3{animation-delay:.15s;animation-fill-mode:both}.stagger-4{animation-delay:.2s;animation-fill-mode:both}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);padding:12px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border-color);padding:12px}.admin-table tr:hover{background:var(--bg-card-hover)}.btn-secondary{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);cursor:pointer;padding:8px 16px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:600;transition:all .2s}.btn-secondary:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}@media (max-width:768px){.admin-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.admin-table thead{display:none}.admin-table tbody{display:block}.admin-table tr{border:1px solid var(--border-color);background:var(--bg-card);border-radius:8px;margin-bottom:16px;padding:12px;display:block}.admin-table td{text-align:left;border:none;padding:8px 0;display:block}.admin-table td:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.admin-table td:first-child{padding-top:0}.admin-table td:last-child{padding-bottom:0}}
