*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#f5f4ef;--card:#fff;--border:#e8e7e2;--dark:#1a1a1a;--text:#374151;--muted:#9ca3af;--green:#2d8a4e;--green-bg:#dcfce7;--red:#ef4444;--gold:#e5a73b;--blue:#3b82f6;--purple:#8b5cf6;--amber:#d97706;--sb-w:240px}
html{font-size:14px}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--green);text-decoration:none}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}

/* === APP === */
.app{display:flex;min-height:100vh}
.main{flex:1;margin-left:var(--sb-w);min-width:0}
.content{padding:24px 32px}

/* === SIDEBAR === */
.sidebar{width:var(--sb-w);background:var(--card);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:100;transition:transform .3s}
.sb-logo{padding:24px 24px 20px;border-bottom:1px solid var(--border)}
.logo-text{font-size:22px;font-weight:800;color:var(--dark)}
.logo-text span{color:var(--green)}
.sb-nav{flex:1;padding:16px 12px;overflow-y:auto}
.sb-label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:1.5px;padding:0 12px;margin-bottom:8px}
.sb-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;color:#6b7280;transition:all .2s;margin-bottom:2px;text-decoration:none;position:relative}
.sb-link i{width:18px;text-align:center;font-size:14px}
.sb-link:hover{background:#f9fafb;color:var(--dark)}
.sb-link.active{background:var(--dark);color:#fff;font-weight:600}
.sb-dot{width:6px;height:6px;background:var(--green);border-radius:50%;position:absolute;right:14px}
.sb-bottom{border-top:1px solid var(--border);padding:12px}
.sb-notif{position:relative}
.sb-badge{position:absolute;right:12px;background:var(--red);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center}
.sb-user{display:flex;align-items:center;gap:10px;padding:12px 14px;margin-top:4px}
.sb-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--green),#166534);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}
.sb-user-info{flex:1;min-width:0}
.sb-user-info strong{display:block;font-size:13px;font-weight:600;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-info small{font-size:11px;color:var(--muted)}
.sb-logout{color:var(--muted);transition:color .2s}
.sb-logout:hover{color:var(--red)}

/* === HEADER === */
.hdr{padding:20px 32px 12px;position:sticky;top:0;z-index:50;background:var(--bg)}
.hdr-left{display:flex;align-items:center;gap:12px}
.hdr-menu{display:none;background:none;border:none;font-size:20px;color:var(--text);cursor:pointer}
.hdr-date{font-size:10px;font-weight:600;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}
.hdr-greeting{font-size:22px;font-weight:800;color:var(--dark);margin-top:2px}
.hdr-greeting em{font-style:italic;color:var(--green);font-weight:700}

/* === CARDS === */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;transition:box-shadow .2s}
.card:hover{box-shadow:0 2px 12px rgba(0,0,0,.04)}
.card-hd{display:flex;align-items:center;gap:8px;padding:16px 20px;border-bottom:1px solid var(--border)}
.card-dark{background:linear-gradient(135deg,#1a3a2a 0%,#2d5a3d 50%,#1a3a2a 100%);border-radius:16px;color:#fff}

/* === ALERT === */
.alert{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;font-size:13px;margin-bottom:16px;animation:slideIn .3s}
.alert-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.alert-x{margin-left:auto;background:none;border:none;font-size:18px;color:inherit;cursor:pointer;opacity:.6}
@keyframes slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* === BUTTONS === */
.btn-green{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--green);color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-green:hover{background:#246d3e;box-shadow:0 4px 12px rgba(45,138,78,.25);color:#fff}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:transparent;color:#6b7280;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-outline:hover{border-color:var(--green);color:var(--green)}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-block{width:100%;justify-content:center;padding:12px;font-size:14px}
.act-btns{display:flex;gap:2px}
.act-btn{width:30px;height:30px;border:none;background:#f9fafb;border-radius:8px;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}
.act-btn:hover{background:#eff6ff;color:var(--blue)}
.act-del:hover{background:#fef2f2;color:var(--red)}

/* === DASHBOARD TOP === */
.dash-top{display:grid;grid-template-columns:280px 1fr 260px;gap:20px;margin-bottom:20px}
.gauge-card{padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}
.gauge-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);text-align:center}
.gauge-pct{display:block;font-size:32px;font-weight:800;color:#fff}
.gauge-sub{display:block;font-size:9px;letter-spacing:1px;color:rgba(255,255,255,.5);text-transform:uppercase;margin-top:2px}
.gauge-legend{display:flex;gap:16px;margin-top:12px;font-size:11px;color:rgba(255,255,255,.7)}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px}
.dot-gold{background:var(--gold)}
.dot-gray{background:rgba(255,255,255,.25)}
.dot-green{background:var(--green)}

/* Balance Card */
.balance-card{padding:20px 24px;display:flex;flex-direction:column;justify-content:center}
.bal-label{font-size:9px;letter-spacing:1.5px;color:rgba(255,255,255,.5);font-weight:600;margin-bottom:2px}
.bal-amount{font-size:26px;font-weight:800;margin-bottom:4px}
.bal-breakdown{display:flex;gap:10px;margin-bottom:10px}
.bal-cur{font-size:11px;color:rgba(255,255,255,.6);background:rgba(255,255,255,.08);padding:2px 8px;border-radius:6px;font-weight:500}
.bal-stats{display:flex;gap:8px;margin-bottom:12px}
.bal-stat{flex:1;background:rgba(255,255,255,.08);border-radius:8px;padding:8px 10px}
.bal-stat small{display:block;font-size:9px;color:rgba(255,255,255,.5);margin-bottom:1px}
.bal-stat strong{font-size:13px;font-weight:700}
.bal-stat em{display:block;font-size:10px;color:rgba(255,255,255,.45);font-style:normal;margin-top:1px}
.bal-btn{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600;transition:all .2s;text-decoration:none;align-self:flex-start}
.bal-btn:hover{background:#246d3e;color:#fff}

/* Quick Actions */
.qa-card{padding:20px}
.qa-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.qa-hdr strong{font-size:14px;font-weight:700;color:var(--dark)}
.qa-hdr small{font-size:11px;color:var(--muted)}
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.qa-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border:1px solid var(--border);border-radius:12px;text-decoration:none;transition:all .2s;text-align:center}
.qa-btn:hover{border-color:var(--green);background:#f0fdf4}
.qa-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}
.qi-green{background:var(--green-bg);color:var(--green)}
.qi-amber{background:#fef3c7;color:var(--amber)}
.qi-blue{background:#dbeafe;color:var(--blue)}
.qi-purple{background:#ede9fe;color:var(--purple)}
.qa-name{font-size:13px;font-weight:600;color:var(--dark)}
.qa-desc{font-size:10px;color:var(--muted)}

/* === STAT CARDS === */
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.scard{padding:20px;display:flex;justify-content:space-between;align-items:flex-start}
.sc-label{font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.sc-val{font-size:22px;font-weight:800;color:var(--dark)}
.sc-cur{display:block;font-size:10px;color:var(--muted);margin-top:2px;font-weight:400}
.sc-change{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;margin-top:6px}
.sc-change span{font-weight:400;color:var(--muted)}
.sc-up{color:var(--green)}.sc-down{color:var(--red)}
.sc-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.sci-green{background:var(--green-bg);color:var(--green)}
.sci-red{background:#fee2e2;color:var(--red)}
.sci-blue{background:#dbeafe;color:var(--blue)}
.sci-amber{background:#fef3c7;color:var(--amber)}

/* === DASH BOTTOM === */
.dash-bottom{display:grid;grid-template-columns:1fr 340px;gap:20px;margin-bottom:20px}

/* Transactions Table */
.trx-card{padding:0}
.trx-hdr{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px}
.trx-hdr strong{font-size:15px;font-weight:700;color:var(--dark);display:block}
.trx-hdr small{font-size:12px;color:var(--muted)}
.trx-viewall{font-size:13px;font-weight:600;color:var(--green);display:flex;align-items:center;gap:4px;white-space:nowrap}
.trx-viewall:hover{color:#246d3e}
.trx-table{width:100%;border-collapse:collapse}
.trx-table th{text-align:left;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.8px;padding:10px 24px;border-bottom:1px solid var(--border);text-transform:uppercase}
.trx-table td{padding:12px 24px;border-bottom:1px solid #f3f4f6;font-size:13px}
.trx-table.full td{padding:12px 20px}
.trx-table.full th{padding:10px 20px}
.trx-table tbody tr:hover{background:#fafaf8}
.trx-table tbody tr:last-child td{border-bottom:none}
.trx-cell{display:flex;align-items:center;gap:10px}
.trx-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.trx-name{display:block;font-size:13px;font-weight:600;color:var(--dark)}
.trx-sub{display:block;font-size:11px;color:var(--muted)}
.trx-cat{font-size:12px;color:#6b7280}
.trx-date{font-size:12px;color:var(--muted)}
.trx-status{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--green);font-weight:500}
.trx-amt{font-weight:700;font-size:13px}
.amt-up{color:var(--green)}.amt-down{color:var(--dark)}
.cat-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:500}
.acc-badge{font-size:12px;color:#6b7280;background:#f9fafb;padding:3px 8px;border-radius:6px}

/* Breakdown */
.brk-card{padding:0}
.brk-hdr{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 20px 12px}
.brk-hdr strong{font-size:15px;font-weight:700;color:var(--dark);display:block}
.brk-hdr small{font-size:12px;color:var(--muted)}
.brk-cnt{font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted)}
.brk-chart{display:flex;justify-content:center;padding:0 20px 8px}
.brk-list{padding:0 20px 16px}
.brk-item{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px}
.brk-bar{width:4px;height:24px;border-radius:2px;flex-shrink:0}
.brk-name{flex:1;color:#6b7280}
.brk-val{font-weight:700;color:var(--dark)}

/* Charts */
.dash-charts{margin-bottom:20px}
.chart-wrap{padding:24px}
.chart-wrap strong{display:block;font-size:15px;font-weight:700;color:var(--dark);margin-bottom:12px}
.chart-box{height:280px;position:relative}

/* === FORMS === */
.fi{width:100%;padding:10px 14px;background:#fafaf5;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:13px;color:var(--dark);transition:all .2s}
.fi:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(45,138,78,.1);background:#fff}
select.fi{cursor:pointer}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:12px;font-weight:500;color:#6b7280;margin-bottom:4px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
select.cur-sel{background:#fefce8;border-color:#fde68a;color:#92400e;font-weight:600}
select.cur-sel:focus{border-color:#f59e0b;box-shadow:0 0 0 3px rgba(245,158,11,.15)}
.filter-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}
.filter-row .fi{min-width:120px;flex:1}

/* === MODAL === */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(3px);z-index:200}
.overlay.on{display:block}
.modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.96);z-index:250;width:500px;max-width:95vw;max-height:90vh;overflow-y:auto;background:var(--card);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.15);opacity:0;transition:all .2s}
.modal.on{display:block;opacity:1;transform:translate(-50%,-50%) scale(1)}
.modal-box{width:100%}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid var(--border)}
.modal-hdr h3{font-size:16px;font-weight:700;color:var(--dark)}
.modal-x{background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer}
.modal-x:hover{color:var(--red)}
.modal-body{padding:20px 24px}
.modal-ft{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid var(--border)}

/* === PAGES === */
.pg-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.pg-hdr h2{font-size:20px;font-weight:800;color:var(--dark)}
.pg-acts{display:flex;gap:8px}
.pag{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}
.empty-box{text-align:center;padding:48px 20px;color:var(--muted)}
.empty-box i{font-size:40px;margin-bottom:14px;opacity:.3;display:block}
.empty-box p{margin-bottom:14px;font-size:14px}
.acc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.acc-card{padding:20px}
.acc-type{font-size:11px;color:var(--muted);background:#f3f4f6;padding:2px 8px;border-radius:20px}
.acc-bal{font-size:22px;font-weight:800;color:var(--dark);margin-top:12px}
.cat-grid{padding:16px 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}
.cat-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fafaf5;border-radius:10px;transition:background .2s}
.cat-item:hover{background:#f3f4f6}
.cat-name{flex:1;font-size:13px;font-weight:500}
.bud-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.bud-card{padding:20px}
.form-stack>*{margin-bottom:14px}
.form-stack>button{margin-bottom:0}

/* === DEBTS === */
.debt-type{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.dt-given{background:#dcfce7;color:#16a34a}
.dt-taken{background:#fee2e2;color:#ef4444}
.debt-status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.ds-active{background:#dbeafe;color:#3b82f6}
.ds-overdue{background:#fee2e2;color:#ef4444}
.ds-paid{background:#dcfce7;color:#16a34a}

/* === NOTIFICATIONS === */
.notif-unread{border-left:3px solid var(--green)}

/* === AUTH === */
.auth-body{background:var(--bg);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}
.auth-wrap{width:900px;max-width:100%;background:var(--card);border-radius:20px;display:flex;overflow:hidden;box-shadow:0 10px 40px rgba(0,0,0,.08);border:1px solid var(--border)}
.auth-left{flex:1;background:linear-gradient(135deg,#1a3a2a,#2d5a3d);padding:48px;display:flex;flex-direction:column;justify-content:center;color:#fff}
.auth-brand{margin-bottom:32px}
.auth-hero h1{font-size:28px;font-weight:800;line-height:1.3;margin-bottom:12px}
.auth-hero p{color:rgba(255,255,255,.7);font-size:14px}
.auth-features{margin-top:36px}
.auth-feat{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-size:13px;margin-bottom:12px}
.auth-feat i{color:var(--gold);width:16px;text-align:center}
.auth-right{flex:1;padding:48px;display:flex;flex-direction:column;justify-content:center}
.auth-form h2{font-size:24px;font-weight:800;color:var(--dark);margin-bottom:4px}
.auth-sub{color:var(--muted);font-size:13px;margin-bottom:24px}
.auth-link{text-align:center;margin-top:20px;font-size:13px;color:var(--muted)}
.auth-link a{font-weight:600}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:40px}
.pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer}

/* === RESPONSIVE === */
@media(max-width:1200px){.dash-top{grid-template-columns:1fr 1fr}.gauge-card{display:none}.dash-stats{grid-template-columns:1fr 1fr}.dash-bottom{grid-template-columns:1fr}.rpt-grid{grid-template-columns:1fr !important}}
@media(max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.on{transform:translateX(0)}.main{margin-left:0}.content{padding:16px}.hdr{padding:16px}.hdr-menu{display:block}.dash-top{grid-template-columns:1fr}.dash-stats{grid-template-columns:1fr}.fg-row{grid-template-columns:1fr}.auth-wrap{flex-direction:column}.auth-left{padding:32px}.auth-right{padding:28px}.pg-hdr{flex-direction:column;align-items:flex-start}.set-grid{grid-template-columns:1fr !important}}
