@import"https://fonts.googleapis.com/css2?family=Sora:wght@600;700&family=Plus+Jakarta+Sans:wght@400;500;600&display=swap";:root{--bg: #f0faf6;--surface: #ffffff;--surface2: #f5fbf8;--border: #d1ece2;--text: #1a3329;--muted: #6b9b87;--income: #059669;--expense: #e11d48;--accent: #10b981;--accent2: #047857;--danger: #e11d48;--warning: #f59e0b;--font-clash: "Clash Grotesk", "Sora", sans-serif;--font-head: var(--font-clash);--font-body: "Plus Jakarta Sans", sans-serif;--radius: 14px;--shadow: 0 2px 12px rgba(16,185,129,.08);--sidebar-w: 240px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1.5px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto;transition:transform .3s}.sidebar-logo{padding:1.5rem;font-family:var(--font-head);font-size:20px;color:var(--accent2);border-bottom:1.5px solid var(--border);display:flex;align-items:center;gap:8px}.sidebar-nav{flex:1;padding:1rem 0}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;margin:2px 10px;border-radius:10px;cursor:pointer;text-decoration:none;color:var(--muted);font-size:14px;font-weight:500;transition:all .2s}.nav-item:hover{background:#f0fdf8;color:var(--accent)}.nav-item.active{background:var(--accent);color:#fff}.nav-item svg{width:18px;height:18px;flex-shrink:0}.sidebar-footer{padding:1rem;border-top:1.5px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;background:var(--surface2)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:var(--text)}.user-role{font-size:11px;color:var(--muted)}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh}.page-header{background:var(--surface);border-bottom:1.5px solid var(--border);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.page-title{font-family:var(--font-head);font-size:20px;color:var(--text)}.page-body{padding:2rem}.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.card-sm{padding:1.25rem 1.5rem}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:1.5rem}.summary-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);transition:transform .2s}.summary-card:hover{transform:translateY(-2px)}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}.summary-icon.income{background:#d1fae5}.summary-icon.expense{background:#ffe4e6}.summary-icon.balance{background:#dbeafe}.summary-icon.users{background:#ede9fe}.summary-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.summary-value{font-family:var(--font-head);font-size:24px}.summary-value.income{color:var(--income)}.summary-value.expense{color:var(--expense)}.summary-value.balance{color:#1d4ed8}.summary-value.users{color:#7c3aed}h2{font-family:var(--font-head);font-size:18px;color:var(--text);letter-spacing:-.3px}h3{font-family:var(--font-head);font-size:16px;color:var(--text)}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:9px;border:none;font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 12px #10b98140}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--surface2);border:1.5px solid var(--border);color:var(--text)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:#fff0f3;border:1.5px solid #fecdd3;color:var(--expense)}.btn-danger:hover{background:#ffe4e6}.btn-sm{padding:6px 12px;font-size:13px}.btn:disabled{opacity:.6;cursor:not-allowed}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}.form-input,.form-select{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:9px;background:var(--surface2);color:var(--text);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.form-input::placeholder{color:var(--muted)}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #10b9811f}.form-row{display:flex;gap:12px}.form-row>*{flex:1}.form-error{font-size:12px;color:var(--expense);margin-top:4px}.table-wrap{overflow-x:auto;border-radius:10px;border:1.5px solid var(--border)}table{width:100%;border-collapse:collapse}th{background:var(--surface2);text-align:left;padding:12px 16px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1.5px solid var(--border)}td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge-income{background:#d1fae5;color:#065f46}.badge-expense{background:#ffe4e6;color:#9f1239}.badge-admin{background:#ede9fe;color:#5b21b6}.badge-user{background:#dbeafe;color:#1e40af}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#ffe4e6;color:#9f1239}.auth-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:2.5rem;width:100%;max-width:420px;box-shadow:0 8px 32px #10b9811a}.auth-logo{font-family:var(--font-head);font-size:24px;color:var(--accent2);text-align:center;margin-bottom:1.5rem}.auth-title{font-family:var(--font-head);font-size:22px;text-align:center;margin-bottom:.5rem}.auth-sub{color:var(--muted);text-align:center;font-size:14px;margin-bottom:2rem}.auth-link{color:var(--accent);text-decoration:none;font-weight:600}.auth-link:hover{text-decoration:underline}.txn-item{display:flex;align-items:center;justify-content:space-between;background:var(--surface2);border:1.5px solid var(--border);border-radius:11px;padding:12px 16px;gap:12px;animation:fadeIn .25s ease;transition:box-shadow .2s}.txn-item:hover{box-shadow:0 3px 12px #10b9811a}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.txn-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.txn-emoji{width:40px;height:40px;background:#e6f7f1;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border:1.5px solid #c9eedd}.txn-desc{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-meta{font-size:12px;color:var(--muted);margin-top:2px}.txn-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.txn-amount{font-family:var(--font-head);font-size:16px}.txn-amount.income{color:var(--income)}.txn-amount.expense{color:var(--expense)}.breakdown-item{display:flex;align-items:center;gap:12px;margin-bottom:10px}.b-label{min-width:120px;font-size:13px;font-weight:500}.b-bar-wrap{flex:1;background:#e6f7f1;border-radius:9999px;height:10px;overflow:hidden}.b-bar{height:100%;border-radius:9999px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .5s}.b-amount{min-width:90px;text-align:right;font-size:13px;font-weight:600;color:var(--expense)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:2rem;box-shadow:0 20px 60px #00000026}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.modal-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:20px;line-height:1}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:1.5rem}.page-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s}.page-btn.active,.page-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:3rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.upload-area:hover,.upload-area.drag-over{border-color:var(--accent);background:#f0fdf8}.upload-icon{font-size:40px;margin-bottom:1rem}.upload-text{font-size:16px;font-weight:600;color:var(--text)}.upload-sub{font-size:13px;color:var(--muted);margin-top:4px}.chart-wrap{width:100%;height:280px}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted)}.empty-state-icon{font-size:48px;margin-bottom:1rem}.empty-state p{font-size:15px}.mobile-menu-btn{display:none}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-menu-btn{display:block}.summary-grid{grid-template-columns:1fr 1fr}.page-body{padding:1rem}.form-row{flex-direction:column}}@media (max-width: 480px){.summary-grid{grid-template-columns:1fr}}
