@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Mono:wght@300;400;500&display=swap";:root{--bg:#0d0f14;--surface:#151820;--surface-2:#1c2030;--surface-3:#232839;--border:#2a3045;--border-light:#333a52;--text:#e8eaf2;--text-muted:#7a82a0;--text-dim:#4a5070;--amber:#f59e0b;--amber-dim:#f59e0b1f;--amber-glow:#f59e0b40;--red:#f87171;--red-dim:#f871711a;--green:#34d399;--green-dim:#34d3991a;--blue:#60a5fa;--blue-dim:#60a5fa1a;--radius:8px;--radius-lg:12px;--shadow:0 4px 24px #0006;--shadow-lg:0 8px 48px #0009;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:DM Mono,Courier New,monospace;font-size:14px;line-height:1.6}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}h1,h2,h3,h4{letter-spacing:-.02em;font-family:Syne,sans-serif}.app-loader{justify-content:center;align-items:center;height:100vh;display:flex}.logo-mark{color:var(--amber);font-family:Syne,sans-serif;font-weight:800}.logo-text{color:var(--text);letter-spacing:-.02em;font-family:Syne,sans-serif;font-size:1rem;font-weight:700}.btn-primary{background:var(--amber);color:#0d0f14;border-radius:var(--radius);white-space:nowrap;border:none;align-items:center;gap:6px;padding:.5rem 1rem;font-family:Syne,sans-serif;font-size:.8rem;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-full{justify-content:center;width:100%}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);background:0 0;align-items:center;gap:6px;padding:.5rem .875rem;font-family:Syne,sans-serif;font-size:.8rem;font-weight:500;transition:color .15s,border-color .15s;display:inline-flex}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-light)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--red);color:#0d0f14;border-radius:var(--radius);border:none;align-items:center;gap:6px;padding:.5rem 1rem;font-family:Syne,sans-serif;font-size:.8rem;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-danger:hover:not(:disabled){opacity:.85}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.icon-btn{color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:inline-flex}.icon-btn:hover{color:var(--text);background:var(--surface-3)}.edit-btn:hover{color:var(--amber)}.delete-btn:hover{color:var(--red)}.link-btn{color:var(--amber);font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;text-decoration:underline}.field-group{flex-direction:column;flex:1;gap:6px;display:flex}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:500}.optional{text-transform:none;letter-spacing:0;font-weight:400}.field-input{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.85rem;transition:border-color .15s,box-shadow .15s}.field-input:focus{border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-dim)}.field-input.field-error{border-color:var(--red)}.field-input::placeholder{color:var(--text-dim)}.field-input:disabled{opacity:.6;cursor:not-allowed}select.field-input{appearance:none;cursor:pointer}textarea.field-input{min-height:64px}.field-hint{font-size:.72rem}.field-hint.error{color:var(--red)}.input-with-icon{position:relative}.input-with-icon .field-input{padding-right:2.5rem}.input-icon-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:2px;position:absolute;top:50%;right:.6rem;transform:translateY(-50%)}.spinner{border:2px solid #0000004d;border-top-color:#0d0f14;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.skeleton-line{background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);background-size:200% 100%;border-radius:4px;height:14px;animation:1.4s infinite shimmer}@keyframes shimmer{to{background-position:-200% 0}}.auth-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.auth-bg-grid{background-image:radial-gradient(circle at 20% 30%, #f59e0b0f 0%, transparent 50%), radial-gradient(circle at 80% 70%, #60a5fa0a 0%, transparent 50%), radial-gradient(var(--border) 1px, transparent 1px);pointer-events:none;background-size:100% 100%,100% 100%,28px 28px;position:absolute;inset:0}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);z-index:1;padding:2.5rem;animation:.4s fadeUp;position:relative}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-logo{align-items:center;gap:8px;margin-bottom:1.75rem;display:flex}.auth-logo .logo-mark{font-size:1.5rem}.auth-heading{color:var(--text);margin-bottom:.25rem;font-family:Syne,sans-serif;font-size:1.5rem;font-weight:700}.auth-sub{color:var(--text-muted);margin-bottom:1.5rem;font-size:.82rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-toggle{text-align:center;color:var(--text-muted);margin-top:1.25rem;font-size:.8rem}.auth-footer{z-index:1;color:var(--text-dim);letter-spacing:.04em;margin-top:1.5rem;font-size:.72rem;position:relative}.dashboard{flex-direction:column;height:100vh;display:flex;overflow:hidden}.navbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 1.5rem;display:flex}.navbar-brand{align-items:center;gap:8px;display:flex}.navbar-right{align-items:center;gap:1rem;display:flex}.navbar-user{color:var(--text-muted);font-size:.78rem}.dashboard-body{flex:1;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:280px;display:flex;overflow-y:auto}.sidebar-tabs{border-bottom:1px solid var(--border);display:flex}.sidebar-tab{color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:5px;padding:.6rem;font-family:Syne,sans-serif;font-size:.75rem;font-weight:500;transition:color .15s,border-color .15s;display:flex}.sidebar-tab.active{color:var(--amber);border-bottom-color:var(--amber)}@media (width>=769px){.sidebar-tabs{display:none}.hidden-mobile{display:block!important}}@media (width<=768px){.sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;height:auto;overflow:visible}.dashboard-body{flex-direction:column;overflow:auto}.main-content{overflow:visible}.hidden-mobile{display:none}.visible{display:block}}.main-content{flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.content-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.page-title{color:var(--text);font-family:Syne,sans-serif;font-size:1.4rem;font-weight:700}.page-sub{color:var(--text-muted);margin-top:2px;font-size:.78rem}.filter-bar{border-bottom:1px solid var(--border);flex-direction:column;gap:.875rem;padding:1rem;display:flex}.filter-header{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);align-items:center;gap:6px;font-family:Syne,sans-serif;font-size:.72rem;font-weight:600;display:flex}.filter-tabs{flex-wrap:wrap;gap:4px;display:flex}.filter-tab{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);border-radius:4px;padding:.3rem .6rem;font-family:Syne,sans-serif;font-size:.73rem;font-weight:500;transition:all .15s}.filter-tab.active{background:var(--amber-dim);border-color:var(--amber);color:var(--amber)}.filter-tab:hover:not(.active){color:var(--text)}.filter-inputs{flex-direction:column;gap:.75rem;display:flex}.filter-row{gap:.75rem;display:flex}.filter-error{color:var(--red);font-size:.75rem}.filter-actions{justify-content:flex-end;gap:.5rem;display:flex}.analytics-panel{flex-direction:column;gap:1rem;padding:1rem;display:flex}.analytics-header{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);flex:1;font-family:Syne,sans-serif;font-size:.72rem;font-weight:600}.month-nav{align-items:center;gap:4px;display:flex}.month-label{color:var(--text);text-align:center;min-width:100px;font-size:.75rem}.analytics-cards{flex-direction:column;gap:.5rem;display:flex}.summary-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.75rem;display:flex}.summary-card.accent-amber{border-left-color:var(--amber)}.summary-card.accent-red{border-left-color:var(--red)}.summary-card.accent-green{border-left-color:var(--green)}.summary-icon{color:var(--text-muted);flex-shrink:0}.summary-card.accent-amber .summary-icon{color:var(--amber)}.summary-card.accent-red .summary-icon{color:var(--red)}.summary-card.accent-green .summary-icon{color:var(--green)}.summary-label{color:var(--text-muted);font-size:.7rem}.summary-value{color:var(--text);font-family:Syne,sans-serif;font-size:.95rem;font-weight:700}.chart-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.72rem}.analytics-error{color:var(--red);font-size:.78rem}.analytics-empty{color:var(--text-dim);text-align:center;padding:1rem 0;font-size:.78rem}.table-wrapper{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow-x:auto}.expense-table{border-collapse:collapse;width:100%;font-size:.83rem}.expense-table th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;padding:.65rem 1rem;font-family:Syne,sans-serif;font-size:.68rem;font-weight:600}.expense-table td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text);padding:.7rem 1rem}.expense-table tr:last-child td{border-bottom:none}.expense-table tbody tr:hover td{background:var(--surface-2)}.text-right{text-align:right}.expense-title{font-weight:500}.expense-desc{color:var(--text-muted);margin-top:2px;font-size:.73rem}.category-badge{background:var(--surface-3);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;border-radius:20px;padding:2px 8px;font-size:.68rem;display:inline-block}.amount-cell{color:var(--amber);font-family:DM Mono,monospace;font-weight:500}.date-cell{color:var(--text-muted);white-space:nowrap;font-family:DM Mono,monospace;font-size:.78rem}.action-btns{justify-content:flex-end;gap:4px;display:flex}.empty-state{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text-dim);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.empty-state p{color:var(--text-muted);font-family:Syne,sans-serif;font-size:1rem}.empty-state span{font-size:.8rem}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0009;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.2s scaleIn;overflow-y:auto}.modal-sm{max-width:380px}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal-header{justify-content:space-between;align-items:center;padding:1.25rem 1.5rem 0;display:flex}.modal-title{font-family:Syne,sans-serif;font-size:1.1rem;font-weight:700}.modal-form{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem;display:flex}.form-row{gap:.75rem;display:flex}@media (width<=480px){.form-row{flex-direction:column}}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.delete-msg{color:var(--text-muted);padding:1rem 1.5rem;font-size:.85rem;line-height:1.6}.delete-msg strong{color:var(--text)}
