.monthly-control{max-width:1400px;margin:0 auto;padding:1rem}.monthly-control-header{margin-bottom:2rem}.monthly-control-header h1{margin-bottom:1rem;color:#333}.month-navigator{display:flex;align-items:center;justify-content:center;gap:2rem;margin:1.5rem 0}.nav-btn{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.nav-btn:hover:not(:disabled){background:#e8e8e8;border-color:#bbb}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.current-month{font-size:1.8rem;font-weight:700;color:#2c5aa0;margin:0;min-width:200px;text-align:center}.incomes-panel{margin-bottom:1.5rem;padding:1.5rem}.incomes-panel h3{margin:0 0 1rem;color:#2c5aa0;font-size:1.2rem}.incomes-list{margin-bottom:1rem}.income-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f9f9f9;border-radius:4px;margin-bottom:.5rem}.income-source{font-weight:500;flex:1}.income-amount{font-weight:600;color:#38a169;margin-right:1rem}.income-form{display:flex;gap:.5rem;margin-bottom:.5rem;padding:.75rem;background:#f0f7ff;border-radius:4px;border:2px solid #2c5aa0}.income-form input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.income-form input[type=text]{flex:2}.income-form input[type=number]{flex:1}.form-actions{display:flex;gap:.25rem}.save-btn,.cancel-btn{padding:.5rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500}.save-btn{background:#38a169;color:#fff}.save-btn:hover{background:#2f855a}.cancel-btn{background:#e8e8e8;color:#333}.cancel-btn:hover{background:#d0d0d0}.add-btn{padding:.6rem 1rem;background:#2c5aa0;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background .2s}.add-btn:hover{background:#1e4177}.delete-btn{background:none;border:none;color:#e53e3e;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:color .2s}.delete-btn:hover{color:#c53030}.incomes-summary{margin-top:1.5rem;border-top:2px solid #e8e8e8;padding-top:1rem}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:1rem}.summary-row.total{border-top:2px solid #333;border-bottom:2px solid #333;margin-top:.5rem;padding-top:.75rem;padding-bottom:.75rem;font-weight:700;font-size:1.1rem}.summary-row.projection{color:#666;font-style:italic;font-size:.9rem}.summary-row .amount{font-weight:600;color:#38a169}.balance-input{width:120px;padding:.25rem .5rem;border:1px solid #ddd;border-radius:4px;text-align:right;font-weight:600}.summary-cards{display:grid;grid-template-columns:2fr 1fr;gap:1rem;margin-bottom:1.5rem;align-items:stretch}.summary-card{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;border-left:4px solid #666}.summary-card h4{margin:0 0 .5rem;color:#666;font-size:.9rem;font-weight:500;text-transform:uppercase}.summary-card .amount{font-size:1.5rem;font-weight:700;color:#333}.summary-card.investment{border-left-color:#38a169}.summary-card.investment .amount{color:#38a169}.summary-card.debt{border-left-color:#e53e3e}.summary-card.debt .amount{color:#e53e3e}.summary-card.savings{border-left-color:#3182ce}.summary-card.savings .amount{color:#3182ce}.summary-card.balance.positive{border-left-color:#38a169;background:#f0fff4}.summary-card.balance.positive .amount{color:#38a169}.summary-card.balance.negative{border-left-color:#e53e3e;background:#fff5f5}.summary-card.balance.negative .amount{color:#e53e3e}.summary-card.total-spent{border-left-color:#805ad5}.summary-card.total-spent .amount{color:#805ad5}.summary-metrics-group{display:flex;gap:.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:.5rem;box-shadow:0 2px 8px #0000000f}.summary-metrics-group .summary-card{flex:1;box-shadow:none}.summary-totals-group{display:flex;gap:.5rem;background:linear-gradient(135deg,#f0f4ff,#fdf0ff);border:1px solid #d6bcfa;border-radius:12px;padding:.5rem;box-shadow:0 6px 20px #667eea2e}.summary-totals-group .summary-card{flex:1;box-shadow:0 1px 4px #00000014}.summary-totals-group .summary-card h4{font-size:.8rem}.summary-totals-group .summary-card .amount{font-size:1.6rem}.transactions-section{padding:1.5rem}.transactions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.transactions-header h3{margin:0;color:#2c5aa0;font-size:1.2rem}.header-actions{display:flex;gap:.75rem;align-items:center}.export-btn{padding:.5rem 1rem;background:#38a169;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.export-btn:hover{background:#2f855a}.copy-btn{padding:.5rem 1rem;background:#3182ce;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.copy-btn:hover:not(:disabled){background:#2c5aa0}.copy-btn:disabled{opacity:.6;cursor:not-allowed}.filters{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filters select,.filters .search-input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.filters select{flex:0 1 180px}.filters .search-input{flex:1 1 200px;min-width:150px}.transactions-table-container{overflow-x:auto;margin-top:1rem}.transactions-table{width:100%;border-collapse:collapse;font-size:.9rem}.transactions-table thead{background:#f5f5f5;border-bottom:2px solid #ddd}.transactions-table th{padding:.75rem .5rem;text-align:left;font-weight:600;color:#333;white-space:nowrap}.transactions-table td{padding:.75rem .5rem;border-bottom:1px solid #e8e8e8}.transactions-table tr.pending{background:#fffbeb}.transactions-table tr:hover{background:#f9f9f9}.transactions-table td.description{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transactions-table td.amount{text-align:right;font-weight:600}.transactions-table td.type{font-size:.85rem;font-weight:500}.transactions-table td.type.inversión{color:#38a169}.transactions-table td.type.deuda{color:#e53e3e}.transactions-table td.type.ahorro{color:#3182ce}.transactions-table td.paid-status{text-align:center}.paid-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:transform .2s}.paid-toggle:hover{transform:scale(1.2)}.paid-toggle.paid{color:#38a169}.paid-toggle.pending{color:#f59e0b}.transactions-table td.balance{text-align:right;font-weight:600;font-size:.95rem}.transactions-table td.balance.positive{color:#38a169}.transactions-table td.balance.negative{color:#e53e3e}@media (max-width: 768px){.month-navigator{flex-direction:column;gap:1rem}.current-month{font-size:1.4rem}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.transactions-header{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;flex-direction:column}.header-actions button{width:100%}.filters{flex-direction:column}.filters select,.filters .search-input{width:100%}.transactions-table{font-size:.8rem}.transactions-table th,.transactions-table td{padding:.5rem .25rem}}.notification-settings{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000000d}.notification-header h3{margin:0 0 8px;font-size:18px;color:#333}.notification-header p{margin:0;font-size:14px;color:#666}.notification-status{display:flex;gap:20px;margin:16px 0;padding:12px;background:#f8f9fa;border-radius:6px;flex-wrap:wrap}.status-item{display:flex;align-items:center;gap:8px}.status-item .label{font-weight:500;color:#555;font-size:14px}.badge{padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500;white-space:nowrap}.badge.active{background:#d4edda;color:#155724}.badge.inactive{background:#f8d7da;color:#721c24}.notification-schedule{margin:16px 0;padding:12px;background:#e7f3ff;border-left:4px solid #2196f3;border-radius:4px}.notification-schedule p{margin:6px 0;font-size:14px;color:#333}.notification-error{padding:12px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin:12px 0;font-size:14px}.notification-warning{padding:12px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;margin:12px 0;font-size:14px}.notification-unsupported{padding:12px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-size:14px}.notification-actions{margin-top:16px;display:flex;justify-content:flex-end}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover:not(:disabled){background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px #2196f34d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px);box-shadow:0 2px 8px #6c757d4d}@media (max-width: 600px){.notification-status{flex-direction:column;gap:12px}.notification-actions{justify-content:stretch}.btn{width:100%}}.alert-banner-container{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem 0}.alert-banner{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-radius:8px;font-size:.875rem;line-height:1.4}.alert-banner--warning{background:#fff8e1;border:1px solid #f59e0b;color:#78350f}.alert-banner--error{background:#fef2f2;border:1px solid #ef4444;color:#7f1d1d}.alert-banner--info{background:#eff6ff;border:1px solid #3b82f6;color:#1e3a8a}.alert-banner__icon{flex-shrink:0;font-size:1rem}.alert-banner__body{flex:1}.alert-banner__detail{font-weight:400}.alert-banner__detail a{color:inherit;font-weight:600;text-decoration:underline}.alert-banner__dismiss{flex-shrink:0;background:none;border:none;cursor:pointer;font-size:.8rem;color:inherit;opacity:.6;padding:0 .25rem;line-height:1}.alert-banner__dismiss:hover{opacity:1}.app{min-height:100vh;display:flex;flex-direction:column}.marketing-shell{min-height:calc(100vh - 2rem);display:grid;gap:1.5rem;padding:2rem 0 3rem}.marketing-hero{padding:2rem;border-radius:24px;background:radial-gradient(circle at top right,rgba(61,164,255,.2),transparent 35%),linear-gradient(135deg,#0b1624,#12314c 55%,#1f6cab);color:#fff;box-shadow:0 24px 60px #12314c33}.hero-logo{width:96px;height:96px;border-radius:20px;margin-bottom:1rem;display:block}.marketing-eyebrow{margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:#ffffffb8}.marketing-hero h1{margin:0;font-size:clamp(2.5rem,7vw,4.5rem);line-height:.95;letter-spacing:-.04em}.marketing-lead{max-width:720px;margin:1.25rem 0 0;font-size:1.05rem;line-height:1.7;color:#ffffffe0}.marketing-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.5rem}.marketing-primary,.marketing-secondary{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.8rem 1.2rem;border-radius:999px;text-decoration:none;font-weight:700;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.marketing-primary{background:#f9b54c;color:#0b1624;box-shadow:0 14px 30px #0b162440}.marketing-secondary{color:#fff;border:1px solid rgba(255,255,255,.32);background:#ffffff14}.marketing-primary:hover,.marketing-secondary:hover{transform:translateY(-1px)}.marketing-card-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.marketing-card{padding:1.4rem;border-radius:18px;background:#fff;box-shadow:0 14px 36px #0b162414}.marketing-card h2{margin:0 0 .75rem;font-size:1.05rem;color:#12314c}.marketing-card p{margin:0;color:#4c6074;line-height:1.65}.marketing-footer{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding:1.25rem 0 0;color:#4c6074}.marketing-footer p{margin-top:.25rem}.marketing-footer-links{display:flex;flex-wrap:wrap;gap:1rem}.marketing-footer-links a{color:#12314c;text-decoration:none;font-weight:600}.nav{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #00000026;position:relative}.nav-brand{cursor:pointer;transition:transform .2s ease;display:flex;align-items:center;gap:.5rem}.nav-logo{height:36px;width:36px;border-radius:8px;flex-shrink:0}.nav-brand:hover{transform:translateY(-1px)}.nav-brand:active{transform:translateY(0)}.nav h1{margin:0;font-size:1.2rem;flex-shrink:0;color:#fff;font-weight:700;letter-spacing:-.5px}.hamburger-btn{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;z-index:1001;border-radius:4px;transition:background-color .2s ease}.hamburger-btn:hover{background-color:#ffffff1a}.hamburger-btn:active{background-color:#ffffff26}.hamburger-icon{width:24px;height:20px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger-icon span{display:block;height:3px;width:100%;background-color:#fff;border-radius:2px;transition:all .3s ease}.hamburger-icon.open span:nth-child(1){transform:translateY(8.5px) rotate(45deg)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.menu-drawer{position:fixed;top:0;right:-300px;width:280px;height:100vh;background-color:#fff;box-shadow:-2px 0 8px #00000026;z-index:1000;transition:right .3s ease;display:flex;flex-direction:column;overflow-y:auto}.menu-drawer.open{right:0}.menu-header{background:linear-gradient(135deg,#2c3e50,#34495e);padding:1.5rem 1rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.menu-profile-img{width:48px;height:48px;border-radius:50%;border:2px solid white}.menu-user-info{flex:1;overflow:hidden}.menu-user-name{color:#fff;font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-user-email{color:#fffc;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.25rem}.menu-links{flex:1;padding:.5rem 0}.menu-links a{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;color:#2c3e50;text-decoration:none;transition:all .2s ease;border-left:3px solid transparent;font-size:.95rem;font-weight:500}.menu-links a:hover{background-color:#f8f9fa;border-left-color:#3498db;color:#3498db}.menu-links a:active{background-color:#e9ecef}.menu-icon{font-size:1.2rem;width:24px;text-align:center}.menu-footer{padding:1rem;border-top:1px solid #e9ecef}.menu-signout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1rem;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:background-color .2s ease}.menu-signout-btn:hover{background-color:#c82333}.menu-signout-btn:active{background-color:#bd2130}.main{flex:1;padding:1rem;max-width:1200px;width:100%;margin:0 auto}@media (min-width: 768px){.nav{padding:1rem 1.5rem;box-shadow:0 2px 10px #0003}.nav h1{font-size:1.5rem;letter-spacing:-.75px}.main{padding:1.5rem}}@media (max-width: 767px){.marketing-hero{padding:1.5rem;border-radius:20px}.marketing-shell{padding-top:1rem}}@media (min-width: 1024px){.nav{padding:1.25rem 2rem}.nav h1{font-size:1.65rem}.main{padding:2rem}}.card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;overflow-x:auto}.card h2{margin-top:0;margin-bottom:1rem;color:#2c3e50;font-size:1.25rem}.stats-grid{display:grid;grid-template-columns:1fr;gap:.75rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a}.stat-card h3{margin:0;font-size:.85rem;color:#7f8c8d;font-weight:500}.stat-card .value{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-top:.5rem}@media (min-width: 640px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card .value{font-size:1.75rem}}@media (min-width: 768px){.card{padding:1.5rem;margin-bottom:1.5rem}.card h2{font-size:1.5rem}.stat-card{padding:1.5rem}}@media (min-width: 1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card h3{font-size:.9rem}.stat-card .value{font-size:2rem}}.table{width:100%;border-collapse:collapse;font-size:.85rem}.table th,.table td{padding:.5rem;text-align:left;border-bottom:1px solid #ecf0f1}.table th{background-color:#f8f9fa;font-weight:600;color:#2c3e50;font-size:.8rem;position:sticky;top:0;z-index:10}.table tbody tr:hover{background-color:#f8f9fa}@media (max-width: 767px){.table th:nth-child(n+5),.table td:nth-child(n+5){display:none}}@media (min-width: 768px){.table{font-size:.9rem}.table th,.table td{padding:.75rem}.table th{font-size:.9rem}}@media (min-width: 1024px){.table{font-size:1rem}}.loading{text-align:center;padding:2rem 1rem;color:#7f8c8d;font-size:.9rem}.error{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem}@media (min-width: 768px){.loading{padding:3rem;font-size:1rem}.error{font-size:1rem}}.responsive-grid-1{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 640px){.responsive-grid-1{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.responsive-grid-1{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
