*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=claro]{--bg-primary: #e9e9f1;--bg-secondary: #9b9bbd;--bg-card: rgba(139, 135, 135, .151);--bg-card-hover: rgba(136, 130, 130, .329);--glass-border: rgba(255, 255, 255, .384);--glass-border-focus: rgba(124, 58, 237, .6);--accent: #7c3aed;--accent-2: #2563eb;--accent-cyan: #06b6d4;--gradient: linear-gradient(135deg, #7c3aed 0%, #2563eb 100%);--gradient-soft: linear-gradient(135deg, rgba(124, 58, 237, .15), rgba(37, 99, 235, .1));--text-primary: #18181a;--text-secondary: #475569;--text-muted: #64748b}[data-theme=oscuro]{--bg-primary: #0a0a14;--bg-secondary: #111122;--bg-card: rgba(255, 255, 255, .045);--bg-card-hover: rgba(255, 255, 255, .075);--glass-border: rgba(255, 255, 255, .09);--glass-border-focus: rgba(124, 58, 237, .6);--accent: #7c3aed;--accent-2: #2563eb;--accent-cyan: #06b6d4;--gradient: linear-gradient(135deg, #7c3aed 0%, #2563eb 100%);--gradient-soft: linear-gradient(135deg, rgba(124, 58, 237, .15), rgba(37, 99, 235, .1));--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b}[data-theme=oceano]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: rgba(255, 255, 255, .05);--bg-card-hover: rgba(255, 255, 255, .1);--glass-border: rgba(14, 165, 233, .2);--glass-border-focus: rgba(14, 165, 233, .6);--accent: #0ea5e9;--accent-2: #3b82f6;--accent-cyan: #06b6d4;--gradient: linear-gradient(135deg, #0ea5e9 0%, #3b82f6 100%);--gradient-soft: linear-gradient(135deg, rgba(14, 165, 233, .15), rgba(59, 130, 246, .1));--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8}[data-theme=naturaleza]{--bg-primary: #14532d;--bg-secondary: #166534;--bg-card: rgba(255, 255, 255, .08);--bg-card-hover: rgba(255, 255, 255, .12);--glass-border: rgba(34, 197, 94, .3);--glass-border-focus: rgba(34, 197, 94, .6);--accent: #22c55e;--accent-2: #10b981;--accent-cyan: #14b8a6;--gradient: linear-gradient(135deg, #22c55e 0%, #10b981 100%);--gradient-soft: linear-gradient(135deg, rgba(34, 197, 94, .15), rgba(16, 185, 129, .1));--text-primary: #f0fdf4;--text-secondary: #bbf7d0;--text-muted: #86efac}[data-theme=atardecer]{--bg-primary: #431407;--bg-secondary: #7c2d12;--bg-card: rgba(255, 255, 255, .06);--bg-card-hover: rgba(255, 255, 255, .1);--glass-border: rgba(249, 115, 22, .2);--glass-border-focus: rgba(249, 115, 22, .6);--accent: #f97316;--accent-2: #ec4899;--accent-cyan: #fbbf24;--gradient: linear-gradient(135deg, #f97316 0%, #ec4899 100%);--gradient-soft: linear-gradient(135deg, rgba(249, 115, 22, .15), rgba(236, 72, 153, .1));--text-primary: #fff7ed;--text-secondary: #fed7aa;--text-muted: #fdba74}:root{--error: #ef4444;--error-bg: rgba(239, 68, 68, .12);--error-border: rgba(239, 68, 68, .35);--success: #22c55e;--success-bg: rgba(34, 197, 94, .12);--success-border: rgba(34, 197, 94, .35);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .12);--warning-border: rgba(245, 158, 11, .35);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .35);--shadow-md: 0 4px 24px rgba(0, 0, 0, .45);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .55);--glow: 0 0 40px rgba(124, 58, 237, .18);--transition: all .2s cubic-bezier(.4, 0, .2, 1);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body{height:100%;width:100%;overflow-x:hidden}body{font-family:var(--font);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:var(--radius-md);font-family:var(--font);font-size:.9375rem;font-weight:600;letter-spacing:.01em;cursor:pointer;border:none;outline:none;text-decoration:none;transition:var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 4px 18px #7c3aed66}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed8c}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--glass-border)}.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-danger{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border)}.btn-danger:hover{background:#ef444438}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);border:none;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:transparent}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-full{width:100%}.btn-sm{padding:9px 16px;font-size:.8125rem;border-radius:var(--radius-sm)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.065em}.form-control{width:100%;padding:14px 16px;background:#ffffff0d;border:1.5px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font);font-size:1rem;transition:var(--transition);outline:none;appearance:none;-webkit-appearance:none;color:#94a3b8}.form-control:focus{border-color:var(--glass-border-focus);background:#7c3aed12;box-shadow:0 0 0 3px #7c3aed2e}.form-control::placeholder{color:var(--text-muted)}.form-control.error{border-color:var(--error);box-shadow:0 0 0 3px #ef444426}.form-control:disabled{opacity:.55;cursor:not-allowed}select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='%2394a3b8'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:42px}.form-error{font-size:.75rem;color:var(--error);display:flex;align-items:center;gap:4px}.card{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.5;flex-shrink:0}.alert svg{flex-shrink:0;margin-top:1px}.alert-error{background:var(--error-bg);border:1px solid var(--error-border);color:#fca5a5}.alert-success{background:var(--success-bg);border:1px solid var(--success-border);color:#86efac}.alert-warning{background:var(--warning-bg);border:1px solid var(--warning-border);color:#fde68a}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;box-shadow:0 4px 24px #0000004d;z-index:1000;animation:toast-in .3s ease-out;pointer-events:none}.toast-success{background:#16a34a;color:#fff}.toast-error{background:#dc2626;color:#fff}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.badge-purple{background:#7c3aed33;color:#c4b5fd}.badge-cyan{background:#06b6d433;color:#67e8f9}.badge-green{background:#22c55e33;color:#86efac}.badge-amber{background:#f59e0b33;color:#fde68a}.badge-red{background:#ef444433;color:#fca5a5}.badge-blue{background:#2563eb33;color:#93c5fd}.app-page{min-height:100dvh;display:flex;flex-direction:column;max-width:640px;margin:0 auto}.app-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;padding-top:calc(14px + env(safe-area-inset-top));background:#b2b2b81a;border-radius:24px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.header-brand{display:flex;align-items:center;gap:10px}.header-brand-name{font-size:1.1rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:10px}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;color:#fff;flex-shrink:0}.loading-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary);font-size:.9rem}.loading-state .spinner{width:32px;height:32px;border-width:3px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:var(--text-muted);text-align:center}.empty-state svg{opacity:.4}.empty-state p{font-size:.9rem;max-width:200px}.divider{height:1px;background:var(--glass-border);margin:0}.pb-safe{padding-bottom:env(safe-area-inset-bottom,16px)}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:32px 20px;padding-top:calc(32px + env(safe-area-inset-top));padding-bottom:calc(32px + env(safe-area-inset-bottom))}.bg-mesh{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}.blob{position:absolute;border-radius:50%;filter:blur(90px)}.blob-1{width:380px;height:380px;background:radial-gradient(circle,rgba(124,58,237,.55),transparent 70%);top:-120px;right:-80px;animation:drift 9s ease-in-out infinite}.blob-2{width:300px;height:300px;background:radial-gradient(circle,rgba(37,99,235,.45),transparent 70%);bottom:-100px;left:-60px;animation:drift 12s ease-in-out infinite reverse}.blob-3{width:200px;height:200px;background:radial-gradient(circle,rgba(6,182,212,.3),transparent 70%);top:45%;right:5%;animation:drift 15s ease-in-out infinite}@keyframes drift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-25px) scale(1.06)}66%{transform:translate(-15px,18px) scale(.94)}}.login-main{position:relative;z-index:1;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:32px}.brand-header{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.brand-icon{filter:drop-shadow(0 6px 24px rgba(124,58,237,.55));animation:glow-pulse 3.5s ease-in-out infinite}@keyframes glow-pulse{0%,to{filter:drop-shadow(0 6px 24px rgba(124,58,237,.55))}50%{filter:drop-shadow(0 6px 36px rgba(124,58,237,.85))}}.brand-name{font-size:2.25rem;font-weight:800;letter-spacing:-.03em;line-height:1;background:linear-gradient(135deg,#c4b5fd,#93c5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.brand-tagline{font-size:.875rem;color:var(--text-secondary);font-weight:400;margin:0;letter-spacing:.02em}.login-card{width:100%;padding:28px 24px 24px;display:flex;flex-direction:column;gap:20px}.card-heading{display:flex;flex-direction:column;gap:4px}.card-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.card-sub{font-size:.875rem;color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:16px}.input-wrap{position:relative;display:flex;align-items:center}.input-ico{position:absolute;left:14px;color:var(--text-muted);pointer-events:none;flex-shrink:0;z-index:1}.input-wrap .form-control{padding-left:42px}.btn-eye{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:var(--transition);z-index:1}.btn-eye:hover{color:var(--text-primary);background:#ffffff14}.input-wrap .form-control:has(~.btn-eye){padding-right:50px}.input-wrap .form-control{padding-right:50px}.login-footer{font-size:.75rem;color:var(--text-muted);text-align:center}.socio-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:0}.stats-section{padding:20px 20px 0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-card{display:flex;flex-direction:column;gap:10px;padding:16px 14px;border-radius:var(--radius-md);border:1px solid var(--glass-border);background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;position:relative;transition:var(--transition)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.stat-hoy:before{background:linear-gradient(90deg,#7c3aed,#2563eb)}.stat-mes:before{background:linear-gradient(90deg,#06b6d4,#2563eb)}.stat-total:before{background:linear-gradient(90deg,#22c55e,#06b6d4)}.stat-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.stat-hoy .stat-icon{background:#7c3aed26;color:#a78bfa}.stat-mes .stat-icon{background:#06b6d426;color:#67e8f9}.stat-total .stat-icon{background:#22c55e26;color:#86efac}.stat-body{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.stat-value{font-size:.9rem;font-weight:800;color:var(--text-primary);line-height:1.1;word-break:break-all}.filter-section{padding:20px 20px 0;display:flex;flex-direction:column;gap:12px}.filter-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-title{font-size:1rem;font-weight:700;margin:0;display:flex;align-items:center;gap:8px}.count-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);background:#7c3aed26;color:#c4b5fd;font-size:.7rem;font-weight:600}.filter-toggle-btn{display:flex;align-items:center;gap:6px;position:relative;white-space:nowrap}.filter-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-cyan);position:absolute;top:5px;right:5px;box-shadow:0 0 6px var(--accent-cyan)}.filter-form{display:flex;flex-direction:column;gap:10px;animation:slide-down .2s ease}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-select{padding:11px 14px;font-size:.875rem}.filter-total-bar{font-size:.875rem;color:var(--text-secondary);padding:10px 14px;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-sm)}.filter-total-bar strong{color:var(--text-primary);font-weight:700}.gastos-list{list-style:none;padding:16px 20px;display:flex;flex-direction:column;gap:10px}.gasto-row{display:flex;align-items:stretch;gap:0;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);overflow:hidden;transition:var(--transition);animation:fade-in .2s ease}.gasto-row:hover{background:var(--bg-card-hover);border-color:#ffffff24}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.gasto-bar{width:4px;flex-shrink:0;border-radius:0}.gasto-row-body{flex:1;padding:14px 16px;display:flex;flex-direction:column;gap:4px;min-width:0}.gasto-row-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.gasto-row-desc{font-size:.9375rem;font-weight:600;color:var(--text-primary);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gasto-row-amount{font-size:1rem;font-weight:700;color:var(--text-primary);flex-shrink:0}.gasto-row-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.gasto-row-meta{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gasto-row-date{font-size:.7rem;color:var(--text-muted);flex-shrink:0}.ticket-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);border:none;background:#06b6d41f;color:var(--accent-cyan);font-size:.7rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:var(--transition);margin-top:4px}.ticket-btn:hover{background:#06b6d438}.ticket-modal-overlay{position:fixed;inset:0;z-index:300;background:#000000e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-modal .2s ease}@keyframes fade-modal{0%{opacity:0}to{opacity:1}}.ticket-modal-inner{position:relative;max-width:400px;width:100%;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);animation:scale-modal .2s cubic-bezier(.34,1.56,.64,1)}@keyframes scale-modal{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.ticket-modal-img{width:100%;display:block;object-fit:contain;max-height:70dvh}.ticket-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:#000000b3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:1}.ticket-modal-close:hover{background:var(--error)}.tab-bar{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-secondary);border-bottom:1px solid var(--glass-border);position:sticky;top:calc(56px + env(safe-area-inset-top,0px));z-index:90;margin:10px;border-radius:24px;background:#b2b2b8d7}.tab-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:14px 8px;background:transparent;border:none;color:var(--text-muted);font-family:var(--font);font-size:.875rem;font-weight:500;cursor:pointer;position:relative;transition:var(--transition);-webkit-tap-highlight-color:transparent}.tab-btn:after{content:"";position:absolute;bottom:0;left:10%;width:80%;height:2px;background:var(--gradient);border-radius:2px 2px 0 0;transform:scaleX(0);transition:transform .2s ease}.tab-btn.active{color:var(--text-primary)}.tab-btn.active:after{transform:scaleX(1)}.tab-btn:hover:not(.active){color:var(--text-secondary)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--gradient);color:#fff;font-size:.65rem;font-weight:700;line-height:1}.tab-panel{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.panel-inner{padding:20px 20px calc(20px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:20px;max-width:540px;margin:0 auto}.panel-header{display:flex;flex-direction:column;gap:4px}.panel-title{font-size:1.2rem;font-weight:700;margin:0}.panel-sub{font-size:.85rem;color:var(--text-secondary);margin:0}.gasto-form{display:flex;flex-direction:column;gap:16px}.amount-input-wrap{position:relative;display:flex;align-items:center}.currency-symbol{position:absolute;margin-right:20px;left:14px;right:14px;font-size:1.1rem;font-weight:600;color:var(--text-secondary);pointer-events:none;z-index:1}.amount-input{padding-left:40px;margin-right:20px;font-size:1.25rem;font-weight:700}.amount-input::placeholder{font-weight:400;font-size:1rem}.form-hint{font-size:.75rem;color:var(--text-muted);font-style:italic}.foto-upload-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 16px;border:1.5px dashed var(--glass-border);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:var(--transition);text-align:center}.foto-upload-btn:hover,.foto-upload-btn:focus-within{border-color:var(--accent);background:#7c3aed12;color:var(--text-primary);outline:none}.foto-upload-btn svg{color:var(--text-muted)}.foto-upload-btn:hover svg{color:var(--accent)}.foto-upload-btn span:first-of-type{font-size:.9rem;font-weight:500}.foto-hint{font-size:.7rem;color:var(--text-muted)}.foto-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.foto-preview-wrap{position:relative;display:inline-block;border-radius:var(--radius-md);overflow:hidden;max-width:200px}.foto-preview{width:100%;display:block;border-radius:var(--radius-md);object-fit:cover}.foto-remove{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;border:none;background:#000000b3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.foto-remove:hover{background:var(--error)}.total-banner{background:var(--gradient-soft);border:1px solid rgba(124,58,237,.2);border-radius:var(--radius-lg);padding:18px 20px;display:flex;flex-direction:column;gap:2px}.total-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.total-amount{font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1.1}.total-count{font-size:.8rem;color:var(--text-secondary)}.gasto-list{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0}.gasto-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:var(--transition);animation:slide-in .25s ease}.gasto-card:hover{background:var(--bg-card-hover)}@keyframes slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.gasto-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.gasto-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.gasto-desc{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gasto-meta{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gasto-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}.gasto-amount{font-size:1rem;font-weight:700;color:var(--text-primary)}.gasto-date{font-size:.7rem;color:var(--text-muted)}.ticket-link{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:600;color:var(--accent-cyan);text-decoration:none;padding:2px 6px;border-radius:var(--radius-sm);background:#06b6d41f;transition:var(--transition)}.ticket-link:hover{background:#06b6d438}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:640px;display:flex;align-items:stretch;background:#0a0a14eb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--glass-border);padding-bottom:env(safe-area-inset-bottom,0px);z-index:200;box-shadow:0 -4px 32px #00000073;background:#b2b2b81a;border-radius:24px}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;background:transparent;border:none;color:var(--text-muted);font-family:var(--font);font-size:.65rem;font-weight:500;letter-spacing:.03em;text-decoration:none;cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:transparent;position:relative}.bottom-nav-item:before{content:"";position:absolute;top:0;left:15%;width:70%;height:2px;background:var(--gradient);border-radius:0 0 4px 4px;transform:scaleX(0);transition:transform .2s ease}.bottom-nav-item.active,.bottom-nav-item:focus-visible{color:var(--text-primary)}.bottom-nav-item.active:before{transform:scaleX(1)}.bottom-nav-item:hover:not(.active){color:var(--text-secondary);background:#ffffff0a}.bottom-nav-item .nav-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);transition:var(--transition)}.bottom-nav-item.active .nav-icon{background:var(--gradient-soft);color:#a78bfa}.nav-logout{color:var(--text-muted)}.nav-logout:hover{color:#fca5a5;background:var(--error-bg)}.app-page{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}.table-container{width:100%;overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--glass-border);background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-sm)}.table-container:focus-visible{outline:2px solid var(--glass-border-focus);outline-offset:2px}table{width:100%;border-collapse:collapse;font-size:.9rem}thead{background:var(--gradient-soft);border-bottom:1px solid var(--glass-border)}thead th{padding:12px 16px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);text-align:left;white-space:nowrap}tbody tr{border-bottom:1px solid var(--glass-border);transition:background .15s ease}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-card-hover)}tbody td{padding:12px 16px;color:var(--text-primary);vertical-align:middle}thead th:last-child,tbody td:last-child{text-align:center;width:1%;white-space:nowrap}tbody td .btn-table-danger{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--error-border);background:var(--error-bg);color:var(--error);font-family:var(--font);font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition)}tbody td .btn-table-danger:hover{background:#ef444438;transform:translateY(-1px)}tbody td .btn-table-danger:active{transform:translateY(0)}.modal-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-end;justify-content:center;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:0;animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-card{width:100%;max-width:640px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-lg);padding:0 0 calc(24px + env(safe-area-inset-bottom,0px));animation:sheet-up .28s cubic-bezier(.32,.72,0,1);overflow:hidden}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--glass-border)}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.form-row{display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-left:1rem}.form-row-left{display:flex;gap:.75rem;align-items:center;min-width:0}.form-row-right{display:flex;gap:.5rem;align-items:center}.btn-add{padding:.5rem .9rem;white-space:nowrap;min-width:96px}@media(max-width:520px){.form-row{gap:.5rem}.form-row-left,.form-row-right{width:100%;justify-content:flex-start}.form-row-right{margin-top:.5rem}}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0;position:absolute}.slider{position:absolute;inset:0;border-radius:999px;background:var(--color-border);transition:background .18s ease}.slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;border-radius:50%;background:#fff;transition:transform .18s ease}.switch input:checked+.slider{background:#22c55e}.switch input:not(:checked)+.slider{background:#94a3b8}.switch input:checked+.slider:before{transform:translate(20px)}
