*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--primary: #6366f1;--primary-h: #4f46e5;--income: #10b981;--outcome: #f43f5e;--shadow: 0 1px 3px rgba(15,23,42,.07), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 16px rgba(15,23,42,.1);--r: 10px;--r-sm: 6px;--nav-w: 220px}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;font-size:15px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.env-banner{position:fixed;top:0;left:0;right:0;height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;z-index:1000}.env-banner--dev{background:#f59e0b;color:#1c1917}.env-banner--stage{background:#6366f1;color:#fff}.layout{display:flex;height:100%}.sidebar{width:var(--nav-w);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0;position:sticky;top:0;flex-shrink:0}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 20px 24px;font-weight:700;font-size:18px;color:var(--primary);letter-spacing:-.3px}.sidebar-logo span{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary);color:#fff;border-radius:var(--r-sm);font-size:14px;font-weight:800}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--text-2);text-decoration:none;font-size:14px;font-weight:500;border-radius:0;transition:background .15s,color .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:#eef2ff;color:var(--primary)}.nav-item svg{width:18px;height:18px;flex-shrink:0}.sidebar-bottom{margin-top:auto;padding:12px 20px 0;border-top:1px solid var(--border)}.user-info{display:flex;align-items:center;gap:10px;padding:10px 0}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.user-name{font-size:13px;font-weight:500}.btn-logout{background:none;border:none;color:var(--text-3);font-size:12px;cursor:pointer;padding:0;margin-top:2px;text-align:left}.btn-logout:hover{color:var(--outcome)}.content{flex:1;min-width:0;overflow-y:auto}.page{max-width:900px;margin:0 auto;padding:32px 28px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.4px;margin-bottom:20px}.section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:20px}.cards-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card{padding:18px 20px}.stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:8px}.stat-value{font-size:24px;font-weight:700;letter-spacing:-.5px}.stat-value.income{color:var(--income)}.stat-value.outcome{color:var(--outcome)}.stat-value.balance{color:var(--primary)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-sm);font-size:14px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s,opacity .15s;line-height:1}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-h);border-color:var(--primary-h)}.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-2)}.btn-sm{padding:3px 10px;font-size:12px}.btn-icon{padding:6px;border-radius:var(--r-sm);background:none;border:none;color:var(--text-3);cursor:pointer;transition:color .15s,background .15s;display:inline-flex}.btn-icon:hover{color:var(--text);background:var(--surface-2)}.btn-icon.danger:hover{color:var(--outcome)}.btn svg{width:16px;height:16px}.month-picker{display:flex;align-items:center;gap:4px;margin-bottom:24px}.month-picker-label{font-size:20px;font-weight:700;letter-spacing:-.3px;min-width:160px;text-align:center}.month-picker button{background:none;border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 10px;cursor:pointer;color:var(--text-2);font-size:16px;line-height:1;transition:background .15s}.month-picker button:hover{background:var(--surface-2)}.cat-list{display:flex;flex-direction:column;gap:10px}.cat-row{display:grid;grid-template-columns:160px 1fr 90px;align-items:center;gap:12px;font-size:14px}.cat-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-2)}.cat-bar-track{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.cat-bar-fill{height:100%;background:var(--primary);border-radius:99px;transition:width .4s ease;opacity:.75}.cat-amount{text-align:right;font-weight:600;font-variant-numeric:tabular-nums;font-size:13px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;padding:10px 12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:11px 12px;border-bottom:1px solid var(--surface-2);color:var(--text-2);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2)}.amount-cell{font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.amount-cell.income{color:var(--income)}.amount-cell.outcome{color:var(--outcome)}.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:12px;font-weight:500;background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow-md);width:100%;max-width:440px;padding:28px}.modal-title{font-size:18px;font-weight:700;margin-bottom:22px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full{grid-column:1 / -1}label{font-size:13px;font-weight:500;color:var(--text-2)}input,select,textarea{padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s;width:100%;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11f}textarea{resize:vertical;min-height:68px}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-2);cursor:pointer}.checkbox-row input{width:auto}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:380px}.login-logo{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;color:var(--primary);margin-bottom:28px;letter-spacing:-.4px}.login-logo span{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--primary);color:#fff;border-radius:var(--r-sm);font-size:16px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px}.tab{padding:8px 0;margin-right:20px;font-size:15px;font-weight:500;color:var(--text-3);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.login-form{display:flex;flex-direction:column;gap:14px}.login-form .btn{width:100%;justify-content:center;padding:10px;font-size:15px}.error-msg{padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--r-sm);font-size:13px;color:var(--outcome)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-3);font-size:14px}.spinner{display:flex;justify-content:center;padding:40px;color:var(--text-3);font-size:14px}@media (max-width: 768px){.sidebar{width:100%;min-height:auto;flex-direction:row;padding:0;position:fixed;bottom:0;top:auto;left:0;right:0;z-index:50;border-right:none;border-top:1px solid var(--border);justify-content:space-around}.sidebar-logo,.sidebar-bottom{display:none}.nav-item{flex-direction:column;gap:3px;font-size:11px;padding:10px 16px}.layout{flex-direction:column}.content{padding-bottom:70px}.page{padding:20px 16px}.cards-row{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.form-group.full{grid-column:auto}.dashboard-grid{grid-template-columns:1fr!important}.dashboard-col-outcome{order:-1}.dashboard-col-income{order:0}}
