@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0f1e;--bg2:#111827;--card:#1a2235;--card2:#1f2d45;--border:#2a3a56;--accent:#6366f1;--accent2:#818cf8;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--blue:#3b82f6;--text:#f1f5f9;--text2:#94a3b8;--text3:#64748b;--sidebar-w:240px;--radius:12px;--shadow:0 4px 24px #0006}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,sans-serif}#root{min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-body{flex:1;width:100%;max-width:1400px;padding:24px}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);padding:24px 20px}.sidebar-logo h1{color:var(--text);letter-spacing:-.3px;font-size:16px;font-weight:800}.sidebar-logo span{color:var(--accent2)}.sidebar-logo p{color:var(--text3);margin-top:2px;font-size:11px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-section{color:var(--text3);text-transform:uppercase;letter-spacing:1px;padding:8px 16px 4px;font-size:10px;font-weight:600}.nav-item{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:calc(100% - 16px);margin:2px 8px;padding:10px 20px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:var(--text);background:#6366f11a}.nav-item.active{color:var(--accent2);background:#6366f133}.nav-item svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.user-info{align-items:center;gap:10px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent), #8b5cf6);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.user-details p{font-size:12px;font-weight:600}.user-details span{color:var(--text3);font-size:11px}.logout-btn{width:100%;color:var(--red);cursor:pointer;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;margin-top:10px;padding:8px;font-size:12px;font-weight:500;transition:all .2s}.logout-btn:hover{background:#ef444433}.navbar{background:var(--bg2);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-title{color:var(--text);font-size:15px;font-weight:600}.navbar-right{align-items:center;gap:16px;display:flex}.notif-btn{cursor:pointer;color:var(--text2);background:0 0;border:none;border-radius:8px;padding:6px;transition:all .2s;position:relative}.notif-btn:hover{background:var(--card2);color:var(--text)}.notif-badge{background:var(--red);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:flex;position:absolute;top:2px;right:2px}.notif-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);width:340px;box-shadow:var(--shadow);z-index:200;position:absolute;top:48px;right:0}.notif-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-header h3{font-size:13px;font-weight:600}.notif-header button{color:var(--accent2);cursor:pointer;background:0 0;border:none;font-size:11px}.notif-list{max-height:320px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:12px 16px;transition:background .2s;display:flex}.notif-item:hover{background:var(--card2)}.notif-item.unread{background:#6366f10d}.notif-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.notif-dot.info{background:var(--blue)}.notif-dot.success{background:var(--green)}.notif-dot.error{background:var(--red)}.notif-dot.warning{background:var(--yellow)}.notif-text{color:var(--text2);font-size:12px;line-height:1.4}.notif-time{color:var(--text3);margin-top:3px;font-size:10px}.notif-empty{text-align:center;color:var(--text3);padding:24px;font-size:13px}.cards-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-2px)}.stat-card[style*=cursor\:pointer]:hover,.stat-card[style*="cursor: pointer"]:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0006}.stat-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:linear-gradient(90deg, var(--blue), #60a5fa)}.stat-card.green:before{background:linear-gradient(90deg, var(--green), #34d399)}.stat-card.yellow:before{background:linear-gradient(90deg, var(--yellow), #fbbf24)}.stat-card.red:before{background:linear-gradient(90deg, var(--red), #f87171)}.stat-card.purple:before{background:linear-gradient(90deg, var(--accent), var(--accent2))}.stat-card-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:14px;display:flex}.stat-card.blue .stat-card-icon{color:var(--blue);background:#3b82f626}.stat-card.green .stat-card-icon{color:var(--green);background:#10b98126}.stat-card.yellow .stat-card-icon{color:var(--yellow);background:#f59e0b26}.stat-card.red .stat-card-icon{color:var(--red);background:#ef444426}.stat-card.purple .stat-card-icon{color:var(--accent2);background:#6366f126}.stat-label{color:var(--text3);margin-bottom:6px;font-size:12px;font-weight:500}.stat-value{color:var(--text);font-size:26px;font-weight:800;line-height:1}.stat-sub{color:var(--text3);margin-top:6px;font-size:11px}.alert-bar{border-radius:10px;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.alert-bar.warning{color:var(--yellow);background:#f59e0b1a;border:1px solid #f59e0b4d}.alert-bar.danger{color:var(--red);background:#ef44441a;border:1px solid #ef44444d}.alert-bar.success{color:var(--green);background:#10b9811a;border:1px solid #10b9814d}.charts-grid{grid-template-columns:1fr 1.6fr;gap:16px;margin-bottom:24px;display:grid}.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-title{color:var(--text);margin-bottom:16px;font-size:14px;font-weight:600}.table-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.table-title{font-size:14px;font-weight:600}.table-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;background:var(--bg2);border-bottom:1px solid var(--border);padding:11px 16px;font-size:11px;font-weight:600}td{vertical-align:middle;border-bottom:1px solid #2a3a5680;padding:13px 16px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.table-empty{text-align:center;color:var(--text3);padding:48px;font-size:14px}.badge{border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-pending{color:var(--yellow);background:#f59e0b26;border:1px solid #f59e0b4d}.badge-approved{color:var(--green);background:#10b98126;border:1px solid #10b9814d}.badge-rejected{color:var(--red);background:#ef444426;border:1px solid #ef44444d}.badge-admin{color:var(--accent2);background:#6366f126;border:1px solid #6366f14d}.badge-user{color:var(--text2);border:1px solid var(--border);background:#94a3b81a}.badge-active{color:var(--green);background:#10b9811a;border:1px solid #10b98133}.badge-inactive{color:var(--red);background:#ef44441a;border:1px solid #ef444433}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent2)}.btn-green{color:var(--green);background:#10b98126;border:1px solid #10b9814d}.btn-green:hover:not(:disabled){background:#10b98140}.btn-red{color:var(--red);background:#ef444426;border:1px solid #ef44444d}.btn-red:hover:not(:disabled){background:#ef444440}.btn-ghost{color:var(--text2);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--card2);color:var(--text)}.btn-sm{padding:5px 10px;font-size:12px}.form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px}.form-title{margin-bottom:20px;font-size:16px;font-weight:700}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group.full{grid-column:1/-1}label{color:var(--text2);font-size:12px;font-weight:600}input,select,textarea{background:var(--bg2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:13px;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}input::placeholder{color:var(--text3)}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=date]{cursor:pointer}select option{background:var(--bg2)}textarea{resize:vertical;min-height:80px}.file-input-wrap{border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:8px;padding:20px;transition:border-color .2s}.file-input-wrap:hover{border-color:var(--accent)}.file-input-wrap input[type=file]{display:none}.file-label{color:var(--text3);font-size:13px}.file-label span{color:var(--accent2);cursor:pointer}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h2{font-size:20px;font-weight:700}.page-header p{color:var(--text3);margin-top:2px;font-size:13px}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-bar select,.filter-bar input{min-width:140px;padding:7px 12px;font-size:12px}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--card);border:1px solid var(--border);width:100%;max-width:480px;box-shadow:var(--shadow);border-radius:16px;padding:28px}.modal-title{margin-bottom:20px;font-size:16px;font-weight:700}.modal-footer{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f126,#0000 70%);width:500px;height:500px;position:absolute;top:-100px;right:-100px}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#10b98114,#0000 70%);width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.login-card{background:var(--card);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow);z-index:1;border-radius:20px;padding:40px;position:relative}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{font-size:22px;font-weight:800}.login-logo span{color:var(--accent2)}.login-logo p{color:var(--text3);margin-top:6px;font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.login-form input{width:100%}.login-btn{background:linear-gradient(135deg, var(--accent), #8b5cf6);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:8px;padding:12px;font-size:14px;font-weight:700;transition:opacity .2s}.login-btn:hover:not(:disabled){opacity:.9}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--red);background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;padding:10px 12px;font-size:13px}.demo-accounts{border-top:1px solid var(--border);margin-top:20px;padding-top:20px}.demo-accounts p{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:11px;font-weight:600}.demo-creds{flex-direction:column;gap:6px;display:flex}.demo-cred-btn{background:var(--bg2);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:8px;padding:9px 12px;transition:border-color .2s}.demo-cred-btn:hover{border-color:var(--accent)}.demo-cred-btn span{color:var(--accent2);margin-bottom:2px;font-size:11px;font-weight:600;display:block}.demo-cred-btn p{color:var(--text3);font-size:11px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.expense-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 30px #00000073}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.loader{justify-content:center;align-items:center;height:200px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pagination{justify-content:center;align-items:center;gap:8px;padding:16px;display:flex}.pagination button{border:1px solid var(--border);background:var(--card2);color:var(--text2);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{color:var(--text3);font-size:12px}.progress-wrap{background:var(--bg2);border-radius:6px;height:8px;margin-top:8px;overflow:hidden}.progress-bar{border-radius:6px;height:100%;transition:width .5s}.progress-bar.safe{background:linear-gradient(90deg, var(--green), #34d399)}.progress-bar.warn{background:linear-gradient(90deg, var(--yellow), #fbbf24)}.progress-bar.danger{background:linear-gradient(90deg, var(--red), #f87171)}@media (width<=768px){:root{--sidebar-w:0px}.sidebar{display:none}.main-content{margin-left:0}.charts-grid,.form-grid{grid-template-columns:1fr}}
