*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f0f2f5;color:#1a1a2e;font-size:15px;line-height:1.5}.app{min-height:100vh}.app-header{background:#1a1a2e;color:#fff;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-header h1{font-size:1.4rem;font-weight:700;letter-spacing:-.3px}.month-selector{display:flex;align-items:center;gap:.5rem}.month-selector label{font-size:.85rem;opacity:.7}.month-selector input[type=month]{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;padding:.35rem .6rem;font-size:.9rem;cursor:pointer}.month-selector input[type=month]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.app-main{max-width:1100px;margin:0 auto;padding:1.5rem 1.5rem 3rem;display:flex;flex-direction:column;gap:1.5rem}.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 700px){.app-grid{grid-template-columns:1fr}.app-header{flex-direction:column;align-items:flex-start}}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 4px #00000012}.card h2{font-size:1rem;font-weight:600;margin-bottom:1.2rem;color:#374151}.error-banner{background:#fee2e2;color:#dc2626;border-radius:8px;padding:.75rem 1rem;font-size:.9rem;max-width:1100px;margin:0 auto;width:calc(100% - 3rem)}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.summary-card{border-radius:12px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.4rem}.summary-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.75}.summary-amount{font-size:1.6rem;font-weight:700;letter-spacing:-.5px}.summary-ingreso{background:#f0fdf4;color:#15803d}.summary-gasto{background:#fef2f2;color:#dc2626}.summary-balance{background:#eff6ff;color:#1d4ed8}.summary-balance.balance-negative{background:#fff7ed;color:#c2410c}@media (max-width: 500px){.summary-grid{grid-template-columns:1fr}}.transaction-form{display:flex;flex-direction:column;gap:.9rem}.form-row{display:flex;flex-direction:column;gap:.3rem}.form-row label{font-size:.8rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.3px}.form-row input,.form-row select{border:1.5px solid #e5e7eb;border-radius:8px;padding:.55rem .75rem;font-size:.95rem;font-family:inherit;color:#1a1a2e;background:#fff;transition:border-color .15s;width:100%}.form-row input:focus,.form-row select:focus{outline:none;border-color:#6366f1}.type-toggle{display:flex;gap:.5rem}.type-btn{flex:1;padding:.5rem;border:1.5px solid #e5e7eb;border-radius:8px;background:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;color:#6b7280}.type-btn:hover{border-color:#d1d5db;background:#f9fafb}.type-btn.active-gasto{background:#fef2f2;border-color:#fca5a5;color:#dc2626;font-weight:600}.type-btn.active-ingreso{background:#f0fdf4;border-color:#86efac;color:#15803d;font-weight:600}.form-error{font-size:.85rem;color:#dc2626;background:#fef2f2;padding:.5rem .75rem;border-radius:6px}.btn-primary{background:#1a1a2e;color:#fff;border:none;border-radius:8px;padding:.7rem 1rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.2rem}.btn-primary:hover:not(:disabled){background:#2d2d4e}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.empty-state{color:#9ca3af;font-size:.9rem;padding:1rem 0}.table-wrapper{overflow-x:auto}.transactions-table{width:100%;border-collapse:collapse;font-size:.9rem}.transactions-table th{text-align:left;padding:.5rem .75rem;font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.4px;border-bottom:1.5px solid #f3f4f6}.transactions-table td{padding:.7rem .75rem;border-bottom:1px solid #f9fafb;color:#374151}.transactions-table tr:last-child td{border-bottom:none}.transactions-table tr:hover td{background:#fafafa}.badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:20px}.badge-gasto{background:#fef2f2;color:#dc2626}.badge-ingreso{background:#f0fdf4;color:#15803d}.description-cell{color:#9ca3af;max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.amount-gasto{color:#dc2626;font-weight:600;font-variant-numeric:tabular-nums}.amount-ingreso{color:#15803d;font-weight:600;font-variant-numeric:tabular-nums}.btn-delete{background:none;border:none;color:#d1d5db;font-size:.85rem;cursor:pointer;padding:.3rem .5rem;border-radius:4px;transition:all .15s;line-height:1}.btn-delete:hover{background:#fef2f2;color:#dc2626}.chart{display:flex;flex-direction:column;gap:.85rem}.chart-row{display:grid;grid-template-columns:110px 1fr 80px;align-items:center;gap:.75rem}.chart-label{font-size:.85rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-bar-track{background:#f3f4f6;border-radius:4px;height:10px;overflow:hidden}.chart-bar-fill{height:100%;background:linear-gradient(90deg,#6366f1,#818cf8);border-radius:4px;transition:width .4s ease;min-width:4px}.chart-value{font-size:.82rem;font-weight:600;color:#6366f1;text-align:right;font-variant-numeric:tabular-nums}
