@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-color:#0d1117;--bg-gradient:linear-gradient(135deg, #0d1117 0%, #161b22 100%);--surface-color:#1e232bb3;--surface-border:#ffffff1a;--text-primary:#e6edf3;--text-secondary:#8b949e;--accent-color:#58a6ff;--accent-hover:#79c0ff;--danger-color:#f85149;--success-color:#3fb950;--warning-color:#d29922;--glass-bg:#161b2299;--glass-border:#ffffff14;--glass-shadow:0 8px 32px 0 #0000005e;--font-family:"Inter", system-ui, -apple-system, sans-serif;--transition-speed:.25s;--cell-bg:#00000026;--cell-focus:#58a6ff1f;--row-hover:#ffffff08;--select-bg:#1c2128;--select-text:#e6edf3;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg-gradient);color:var(--text-primary);-webkit-font-smoothing:antialiased;background-attachment:fixed;min-height:100vh;line-height:1.5}.app-container{flex-direction:column;gap:1.5rem;max-width:1200px;min-height:100vh;margin:0 auto;padding:1.5rem;display:flex}header{justify-content:space-between;align-items:center;display:flex}header h1{background:linear-gradient(90deg, var(--accent-color), #bc8cff);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.8rem;font-weight:800}.tabs{background:var(--surface-color);border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:99px;gap:.5rem;width:fit-content;margin:0 auto;padding:.4rem;display:flex}.tab{color:var(--text-secondary);cursor:pointer;transition:all var(--transition-speed) ease;font-size:.9rem;font-weight:600;font-family:var(--font-family);background:0 0;border:none;border-radius:99px;align-items:center;gap:.45rem;padding:.65rem 1.4rem;display:flex}.tab:hover{color:var(--text-primary);background:#ffffff0d}.tab.active{background:var(--accent-color);color:#fff;box-shadow:0 4px 12px #58a6ff4d}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:transform var(--transition-speed), box-shadow var(--transition-speed);border-radius:16px;padding:1.5rem}.hero-stat{text-align:center;flex-direction:column;align-items:center;padding:2rem 1rem;display:flex;position:relative;overflow:hidden}.hero-stat:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0a 0%,#0000 60%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.hero-stat>*{z-index:1;position:relative}.hero-stat h2{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:1rem;font-weight:500}.hero-stat .amount{letter-spacing:-2px;margin:.4rem 0;font-size:3rem;font-weight:800;line-height:1.1}.hero-stat .amount.positive{color:var(--success-color)}.hero-stat .amount.negative{color:var(--danger-color)}.desglose-row{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:1rem;display:flex}.desglose-item{text-align:center}.desglose-label{color:var(--text-secondary);font-size:.8rem}.desglose-value{font-size:1.05rem;font-weight:700}.btn{border:1px solid var(--surface-border);background:var(--surface-color);color:var(--text-primary);font-size:.88rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-speed);white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:.45rem;padding:.55rem 1.1rem;display:inline-flex}.btn:hover{background:var(--glass-border)}.btn-primary{background:var(--accent-color);color:#fff;border:none}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #58a6ff4d}.btn-danger{color:var(--danger-color);background:#f851491a;border-color:#f8514933}.btn-danger:hover{background:#f8514933}.btn-sm{border-radius:6px;padding:.35rem .7rem;font-size:.8rem}.btn-ghost{color:var(--text-secondary);background:0 0;border:none;padding:.3rem}.btn-ghost:hover{color:var(--text-primary);background:#ffffff14;border-radius:6px}.spreadsheet-wrapper{border:1px solid var(--glass-border);border-radius:12px;overflow-x:auto}.spreadsheet{border-collapse:collapse;width:100%;font-size:.9rem}.spreadsheet thead th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--glass-border);z-index:2;white-space:nowrap;background:#00000040;padding:.7rem .6rem;font-size:.78rem;font-weight:600;position:sticky;top:0}.spreadsheet tbody tr{transition:background .15s}.spreadsheet tbody tr:hover{background:var(--row-hover)}.spreadsheet tbody td{vertical-align:middle;border-bottom:1px solid #ffffff08;padding:.25rem .3rem}.spreadsheet .cell-input,.cell-input{background:var(--select-bg);width:100%;color:var(--select-text);font-family:var(--font-family);appearance:none;border:1px solid #0000;border-radius:6px;padding:.5rem .55rem;font-size:.9rem;transition:all .2s}.spreadsheet .cell-input:hover,.cell-input:hover{border-color:var(--surface-border)}.spreadsheet .cell-input:focus,.cell-input:focus{border-color:var(--accent-color);background:var(--cell-focus);outline:none;box-shadow:0 0 0 2px #58a6ff26}.spreadsheet .cell-input.cell-number,.cell-input.cell-number{text-align:right;font-variant-numeric:tabular-nums}.spreadsheet .cell-input.cell-readonly{color:var(--text-secondary);cursor:default;background:0 0;border-color:#0000;font-weight:500}.spreadsheet .cell-input.cell-readonly:focus{box-shadow:none;background:0 0;border-color:#0000}.spreadsheet select.cell-input,select.cell-input,.filter-control,.form-control{background-color:var(--select-bg);color:var(--select-text)}.spreadsheet select.cell-input option,select.cell-input option,.filter-control option,.form-control option{color:#e6edf3;background-color:#1c2128}.spreadsheet .cell-actions{justify-content:center;gap:.3rem;display:flex}.spreadsheet tfoot td{border-top:2px solid var(--glass-border);background:#00000026;padding:.7rem .6rem;font-weight:700}.spreadsheet .inactive-row{opacity:.45}.spreadsheet .inactive-row .cell-input{text-decoration:line-through}.dashboard-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=768px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.col-span-2{grid-column:span 2}}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.section-header h3{font-size:1.1rem;font-weight:700}.filters-bar{flex-wrap:wrap;align-items:flex-end;gap:.8rem;margin-bottom:1rem;display:flex}.filter-group{flex-direction:column;gap:.3rem;display:flex}.filter-group label{color:var(--text-secondary);align-items:center;gap:.3rem;font-size:.75rem;font-weight:500;display:flex}.filter-control{border:1px solid var(--surface-border);background-color:var(--select-bg);color:var(--select-text);font-family:var(--font-family);border-radius:8px;padding:.5rem .7rem;font-size:.88rem}.filter-control:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 2px #58a6ff26}.budget-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.8rem;display:grid}.budget-card{border:1px solid var(--glass-border);background:#0003;border-radius:12px;flex-direction:column;gap:.5rem;padding:.9rem;transition:border-color .2s;display:flex}.budget-card.over-budget{border-color:#f8514959}.budget-card.within-budget{border-color:#3fb95040}.budget-card-header{justify-content:space-between;align-items:center;display:flex}.budget-cat-name{text-transform:capitalize;font-size:.85rem;font-weight:600}.budget-bar-track{background:#ffffff14;border-radius:99px;width:100%;height:6px;overflow:hidden}.budget-bar-fill{border-radius:99px;height:100%;transition:width .4s}.budget-bar-fill.green{background:var(--success-color)}.budget-bar-fill.yellow{background:var(--warning-color)}.budget-bar-fill.red{background:var(--danger-color)}.budget-values{color:var(--text-secondary);justify-content:space-between;font-size:.78rem;display:flex}.budget-values .spent,.budget-values .remaining{font-weight:600}.budget-values .remaining.over{color:var(--danger-color)}.budget-values .remaining.ok{color:var(--success-color)}.budget-inline-input{background:var(--select-bg);width:80px;color:var(--select-text);font-family:var(--font-family);text-align:right;font-variant-numeric:tabular-nums;border:1px solid #0000;border-radius:5px;padding:.3rem .4rem;font-size:.82rem;transition:all .2s}.budget-inline-input:hover{border-color:var(--surface-border)}.budget-inline-input:focus{border-color:var(--accent-color);background:var(--cell-focus);outline:none;box-shadow:0 0 0 2px #58a6ff1f}.badge{background:#ffffff14;border-radius:99px;align-items:center;gap:.25rem;padding:.15rem .55rem;font-size:.72rem;font-weight:600;display:inline-flex}.tooltip-trigger{cursor:help;color:var(--text-secondary);position:relative}.tooltip-trigger:hover .tooltip-text{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.tooltip-text{color:var(--text-primary);white-space:nowrap;opacity:0;pointer-events:none;border:1px solid var(--surface-border);z-index:20;background:#1c2128;border-radius:8px;padding:.5rem .75rem;font-size:.78rem;transition:all .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px);box-shadow:0 8px 24px #0006}.toast{z-index:200;border-radius:10px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;animation:.3s forwards toastIn;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)translateY(20px);box-shadow:0 8px 32px #0006}.toast.success{background:var(--success-color);color:#fff}.toast.error{background:var(--danger-color);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.form-control{border:1px solid var(--surface-border);background-color:var(--select-bg);color:var(--select-text);font-family:var(--font-family);transition:all var(--transition-speed);border-radius:8px;padding:.7rem 1rem;font-size:1rem}.form-control:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 2px #58a6ff33}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-fade{animation:fadeIn var(--transition-speed) ease}.empty-state{text-align:center;color:var(--text-secondary);padding:2.5rem 1rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{width:90%;max-width:500px;max-height:90vh;animation:.3s cubic-bezier(.175,.885,.32,1) slideUp;overflow-y:auto}@media (width<=640px){.app-container{padding:1rem}header h1{font-size:1.4rem}.spreadsheet{font-size:.82rem}.spreadsheet .cell-input{padding:.4rem;font-size:.82rem}.desglose-row{gap:1rem}.budget-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.auth-container{background:var(--bg-gradient);background-attachment:fixed;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.auth-card{width:100%;max-width:420px;padding:2.5rem}.auth-tabs{background:#0003;border-radius:10px;gap:.5rem;margin-bottom:1.5rem;padding:.3rem;display:flex}.auth-tab{color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:600;font-family:var(--font-family);background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.6rem;transition:all .2s;display:flex}.auth-tab:hover{color:var(--text-primary)}.auth-tab.active{background:var(--accent-color);color:#fff}.auth-msg{border-radius:8px;margin-bottom:.5rem;padding:.6rem .8rem;font-size:.85rem}.auth-msg.error{color:var(--danger-color);background:#f8514926;border:1px solid #f8514933}.auth-msg.success{color:var(--success-color);background:#3fb95026;border:1px solid #3fb95033}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}
