*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: rgba(20, 20, 30, .8);--bg-input: rgba(30, 30, 45, .6);--text-primary: #f0f0f5;--text-secondary: #8888a0;--text-muted: #555566;--accent-gold: #ffd700;--accent-green: #00ff88;--accent-red: #ff4757;--accent-blue: #00d4ff;--accent-savings: #002654;--border-color: rgba(255, 255, 255, .06);--border-color-strong: rgba(255, 255, 255, .12);--shadow-color: rgba(0, 0, 0, .3);--grid-color: rgba(255, 255, 255, .02);--mesh-opacity: .08;--gradient-gold: linear-gradient(135deg, #ffd700 0%, #ffaa00 100%)}[data-theme=light]{--bg-primary: #f8f9fc;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .95);--bg-input: rgba(240, 242, 247, .8);--text-primary: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--accent-gold: #d4a012;--accent-green: #059669;--accent-red: #dc2626;--accent-blue: #0284c7;--accent-savings: #002654;--border-color: rgba(0, 0, 0, .06);--border-color-strong: rgba(0, 0, 0, .1);--shadow-color: rgba(0, 0, 0, .08);--grid-color: rgba(0, 0, 0, .02);--mesh-opacity: .04;--gradient-gold: linear-gradient(135deg, #fbbf24 0%, #d4a012 100%)}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;line-height:1.6;transition:background-color .5s ease,color .3s ease}.bg-mesh{position:fixed;inset:0;z-index:-2;background:radial-gradient(ellipse at 20% 20%,rgba(0,255,136,var(--mesh-opacity)) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(255,71,87,var(--mesh-opacity)) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(0,212,255,.05) 0%,transparent 60%);animation:meshMove 20s ease-in-out infinite;transition:background .5s ease}@keyframes meshMove{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(2deg)}}.grid-overlay{position:fixed;inset:0;z-index:-1;background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}.particle{position:fixed;pointer-events:none;z-index:-1;opacity:0;animation:floatUp linear forwards}@keyframes floatUp{0%{transform:translateY(100vh) rotate(0) scale(.5);opacity:0}10%{opacity:.8}90%{opacity:.8}to{transform:translateY(-100vh) rotate(720deg) scale(1);opacity:0}}@keyframes floatDown{0%{transform:translateY(-100vh) rotate(0) scale(.5);opacity:0}10%{opacity:.8}90%{opacity:.8}to{transform:translateY(100vh) rotate(720deg) scale(1);opacity:0}}.container{max-width:1400px;margin:0 auto;padding:2rem;position:relative;z-index:1;transition:margin-left .4s cubic-bezier(.4,0,.2,1)}.sidebar-toggle{position:fixed;top:1.5rem;left:1.5rem;z-index:2000;background:var(--bg-card);border:1px solid var(--border-color-strong);color:var(--text-primary);width:44px;height:44px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s;box-shadow:0 4px 15px var(--shadow-color)}.sidebar-toggle:hover{border-color:var(--accent-gold);transform:scale(1.05)}.sidebar{position:fixed;top:0;left:-350px;width:280px;height:100vh;background:var(--bg-card);border-right:1px solid var(--border-color);z-index:1999;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);display:flex;flex-direction:column;transition:left .4s cubic-bezier(.4,0,.2,1);padding:1rem;box-shadow:none}.sidebar.active{left:0;box-shadow:5px 0 30px #00000080}.sidebar-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1998;opacity:0;pointer-events:none;transition:opacity .4s cubic-bezier(.4,0,.2,1)}body.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);margin-top:3.5rem;flex-shrink:0}.sidebar-brand{font-size:1.1rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none}.sidebar-content{flex-grow:1;display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-color-strong) transparent;padding-right:2px}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background-color:var(--border-color-strong);border-radius:4px}.user-info-section{background:var(--bg-input);padding:.75rem;border-radius:12px;border:1px solid var(--border-color);flex-shrink:0;transition:border-color .2s ease,background .2s ease}.user-info-section:hover{border-color:var(--border-color-strong);background:#ffffff0d}.edit-username-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:.9rem;opacity:0;transition:opacity .2s ease,color .2s ease,transform .2s ease;padding:2px}.user-info-section:hover .edit-username-btn{opacity:1}.edit-username-btn:hover{color:var(--accent-gold);transform:scale(1.1)}.sidebar-group{display:flex;flex-direction:column;gap:.25rem}.sidebar-label{font-size:.65rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:700;margin-bottom:.25rem;padding-left:.75rem}.sidebar-link,.sidebar-btn{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:8px;color:var(--text-secondary);text-decoration:none;font-size:.85rem;font-weight:500;transition:all .2s ease;border:1px solid transparent;background:transparent;width:100%;cursor:pointer;text-align:left;font-family:inherit}.sidebar-link:hover,.sidebar-btn:hover{background:var(--bg-input);color:var(--text-primary);border-color:var(--border-color-strong);transform:translate(2px)}.sidebar-link.logout{color:var(--accent-red)}.sidebar-link.logout:hover{background:#ff47571a;border-color:#ff475733}.link-icon{font-size:1.1rem}.currency-dropdown{position:relative;width:100%}.currency-dropdown-header{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:8px;background:var(--bg-input);border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.currency-dropdown-header:hover{border-color:var(--border-color-strong)}.currency-dropdown.open .currency-dropdown-header{border-color:var(--accent-savings);box-shadow:0 0 0 2px #00265433;border-radius:8px 8px 0 0}.currency-selected{flex:1;font-size:.85rem;font-weight:500;color:var(--text-primary)}.currency-arrow{font-size:.65rem;color:var(--text-muted);transition:transform .2s ease}.currency-dropdown.open .currency-arrow{transform:rotate(180deg)}.currency-dropdown-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border-color-strong);border-top:none;border-radius:0 0 8px 8px;max-height:0;overflow:hidden;z-index:1000;transition:max-height .3s ease}.currency-dropdown.open .currency-dropdown-list{max-height:300px;overflow-y:auto;box-shadow:0 8px 24px #0000004d}.currency-search{width:100%;padding:.6rem .75rem;border:none;border-bottom:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-size:.8rem;font-family:inherit;outline:none}.currency-search::placeholder{color:var(--text-muted)}.currency-options{max-height:230px;overflow-y:auto}.currency-option{padding:.5rem .75rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.currency-option:hover{background:var(--bg-input);color:var(--text-primary)}.currency-option.selected{background:var(--accent-savings);color:#fff}.currency-option.hidden{display:none}select,.strategy-select,.input-period{background-color:var(--bg-input);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='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem;font-weight:500;padding:.5rem 2rem .5rem .75rem;outline:none;cursor:pointer;font-family:inherit;transition:all .2s ease;appearance:none;background-repeat:no-repeat;background-position:right .5rem center;background-size:14px}[data-theme=light] select,[data-theme=light] .strategy-select,[data-theme=light] .input-period{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='none' stroke='%23555' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}select:hover,.strategy-select:hover,.input-period:hover{border-color:var(--border-color-strong)}select:focus,.strategy-select:focus,.input-period:focus{border-color:var(--accent-savings);box-shadow:0 0 0 2px #00265433}select option,.strategy-select option,.input-period option{background:var(--bg-card);color:var(--text-primary);padding:.5rem}select option:checked,select option:hover,.strategy-select option:checked,.strategy-select option:hover,.input-period option:checked,.input-period option:hover{background:var(--accent-savings);color:#fff}.strategy-select{width:100%;font-size:.8rem}.input-period{font-size:.75rem;padding:4px 1.5rem 4px 6px;width:86px}.revenue-panel .input-period:hover{border-color:var(--accent-green)}.revenue-panel .input-period:focus{border-color:var(--accent-green);box-shadow:0 0 0 2px #00ff8826}.expense-panel .input-period:hover{border-color:var(--accent-red)}.expense-panel .input-period:focus{border-color:var(--accent-red);box-shadow:0 0 0 2px #ff475726}.savings-panel .input-period:hover{border-color:var(--accent-savings)}.savings-panel .input-period:focus{border-color:var(--accent-savings)}.sidebar-footer{font-size:.75rem;color:var(--text-muted);text-align:center;padding-top:1rem;border-top:1px solid var(--border-color)}.navbar{display:none}.navbar-brand{font-size:1.25rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none}.navbar-nav{display:flex;align-items:center;gap:1rem}.nav-link{color:var(--text-secondary);text-decoration:none;padding:.5rem 1rem;border-radius:8px;transition:all .3s;font-size:.9rem;font-weight:500}.nav-link:hover{color:var(--text-primary);background:var(--bg-input)}.nav-link.active{color:var(--accent-gold)}.user-greeting{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:var(--bg-input);border-radius:10px}.user-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent-gold),var(--accent-blue));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#0a0a0f}.user-name{font-weight:600;font-size:.9rem}.btn-logout{background:#ff475726;color:var(--accent-red);border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s}.btn-logout:hover{background:var(--accent-red);color:#fff}.btn-login{background:var(--gradient-gold);color:#0a0a0f;border:none;padding:.5rem 1.25rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .3s}.btn-login:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ffd7004d}.top-login-btn{position:fixed;top:1.5rem;right:1.5rem;background:var(--gradient-gold);color:#0a0a0f;border:none;padding:.6rem 1.25rem;border-radius:10px;font-weight:600;font-size:.9rem;text-decoration:none;transition:all .3s;z-index:100;box-shadow:0 4px 15px #ffd70033}.top-login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ffd70059}@media(max-width:768px){.top-login-btn{top:auto;bottom:1rem;right:1rem}}.theme-toggle{background:var(--bg-input);border:1px solid var(--border-color-strong);border-radius:8px;padding:.5rem .75rem;cursor:pointer;font-size:1rem;transition:all .3s}.theme-toggle:hover{border-color:var(--accent-gold)}.demo-banner{background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:12px;padding:1rem 1.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.demo-banner-text{color:var(--accent-gold);font-size:.9rem}.save-data-cta{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#00d4ff14,#00ff8814);border:1px solid rgba(0,212,255,.2);border-radius:16px;padding:1rem 1.5rem;margin-top:1.5rem;animation:fadeIn .5s ease-out}.save-data-icon{font-size:1.5rem;opacity:.8}.save-data-text{flex:1;display:flex;flex-direction:column;gap:.15rem}.save-data-text strong{color:var(--text-primary);font-size:.95rem}.save-data-text span{color:var(--text-secondary);font-size:.85rem}.save-data-btn{background:var(--gradient-gold);color:#0a0a0f;border:none;padding:.65rem 1.25rem;border-radius:10px;font-weight:600;font-size:.85rem;text-decoration:none;transition:all .3s;white-space:nowrap}.save-data-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffd70040}@media(max-width:600px){.save-data-cta{flex-direction:column;text-align:center}.save-data-btn{width:100%}}.header{text-align:center;padding:1rem 0 2rem}.logo{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-2px;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-gold) 50%,var(--text-primary) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 3s linear infinite}@keyframes shimmer{to{background-position:200% center}}.subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:.5rem;letter-spacing:2px;text-transform:uppercase}.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:1.5rem;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .4s}.metric-card:hover{transform:translateY(-4px);border-color:#ffd7004d;box-shadow:0 20px 40px var(--shadow-color)}.metric-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;font-weight:600}.metric-value{font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;margin:.5rem 0}.metric-icon{position:absolute;top:1.5rem;right:1.5rem;font-size:1.5rem;opacity:.5}.revenue-card .metric-value{color:var(--accent-green)}.expense-card .metric-value{color:var(--accent-red)}.balance-card .metric-value{color:var(--accent-gold)}.balance-card.surplus .metric-value{color:var(--accent-green)}.balance-card.deficit .metric-value{color:var(--accent-red)}.planned-card .metric-value{color:var(--accent-savings)}.main-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}@media(max-width:1024px){.main-grid{grid-template-columns:1fr}}.panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:1.5rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;box-shadow:0 10px 30px var(--shadow-color);transition:all .3s ease}.panel:hover{border-color:var(--border-color-strong);box-shadow:0 20px 50px var(--shadow-color)}.panel-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.panel-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}.revenue-panel .panel-icon{background:#00ff8826}.expense-panel .panel-icon{background:#ff475726}[data-theme=light] .revenue-panel .panel-icon{background:#05966926}[data-theme=light] .expense-panel .panel-icon{background:#dc262626}.panel-title{font-size:1.1rem;font-weight:700}.panel-subtitle{font-size:.75rem;color:var(--text-muted)}.data-header{display:grid;grid-template-columns:24px 1fr 90px 86px 32px;padding:0 12px 10px;gap:10px;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border-color);margin-bottom:8px}.spending-list,.revenue-list{display:flex;flex-direction:column;gap:4px;min-height:50px}.category-group{border:1px solid var(--border-color);border-radius:10px;background:#ffffff04;transition:all .3s;overflow:hidden;margin-bottom:4px}.category-header-row{background:var(--bg-input);display:flex;align-items:center;padding:6px 12px;gap:10px;border-bottom:1px solid var(--border-color)}.category-drag-handle{cursor:move;color:var(--text-muted);font-size:.9rem;width:20px;opacity:.6}.category-name{background:transparent;border:none;color:var(--accent-gold);font-weight:700;font-size:.85rem;flex-grow:1;outline:none;padding:4px 0;text-transform:uppercase;letter-spacing:1px}.revenue-panel .category-name{color:var(--accent-green)}.expense-panel .category-name{color:var(--accent-red)}.items-container{min-height:50px;display:flex;flex-direction:column;gap:4px;padding:10px 6px;position:relative;transition:all .2s}.items-container:empty:before{content:"DRAG & DROP ITEMS HERE";position:absolute;inset:8px;border:2px dashed var(--border-color-strong);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.7rem;font-weight:600;letter-spacing:1px;pointer-events:none;opacity:.6;background:#ffffff03;transition:all .2s}body.is-dragging .items-container:empty:before{border-color:var(--accent-gold);color:var(--accent-gold);background:#ffd7000d;opacity:1}body.is-dragging .revenue-panel .items-container:empty:before{border-color:var(--accent-green);color:var(--accent-green);background:#00ff880d}.spending-item,.revenue-item{display:grid;grid-template-columns:24px 1fr 90px 86px 32px;align-items:center;padding:6px 14px;gap:10px;background:var(--bg-input);border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.spending-item:hover,.revenue-item:hover{background:#ffffff0a;border-color:var(--border-color-strong);transform:translate(4px)}.revenue-panel .revenue-item:hover{border-color:var(--accent-green)}.expense-panel .spending-item:hover{border-color:var(--accent-red)}.spending-item.sortable-ghost,.revenue-item.sortable-ghost{opacity:.4;background:var(--accent-gold)}.spending-item.indented,.revenue-item.indented{margin-left:20px;background:#ffffff02;border-left:3px solid var(--border-color-strong);border-radius:0 8px 8px 0}.item-drag-handle{cursor:move;color:var(--text-muted);font-size:.85rem;opacity:.5;text-align:center}.item-drag-handle:hover{opacity:.9;color:var(--text-primary)}.delete-btn{background:#ff475714;border:none;color:var(--accent-red);width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:1.3rem;font-weight:300;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.delete-btn:hover{background:var(--accent-red);color:#fff;transform:scale(1.1)}.add-btn{width:100%;padding:12px;margin-top:.75rem;background:transparent;border:2px dashed var(--border-color-strong);border-radius:12px;color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s}.add-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#ffd7000d}.revenue-panel .add-btn:hover{border-color:var(--accent-green);color:var(--accent-green);background:#00ff880d}.expense-panel .add-btn:hover{border-color:var(--accent-red);color:var(--accent-red);background:#ff47570d}.savings-panel{grid-column:1 / -1;border-color:var(--accent-savings);transition:all .3s}.savings-panel .panel-icon{background:#00265426}.savings-panel .add-btn:hover{border-color:var(--accent-savings);color:var(--accent-savings);background:#0026540d}.savings-panel.disabled{opacity:.5;pointer-events:none;filter:grayscale(1)}.savings-list{display:flex;flex-direction:column;gap:4px;min-height:50px}.savings-item{display:grid;grid-template-columns:24px 1.2fr 1fr 2.2fr 120px 32px;align-items:center;padding:6px 14px;gap:10px;background:var(--bg-input);border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.savings-item:hover{background:#ffffff0a;border-color:var(--border-color-strong);transform:translate(4px)}.savings-panel .savings-item:hover{border-color:var(--accent-savings)}.strategy-inputs{display:flex;gap:12px;align-items:center}.input-mini{background:transparent;border:1px solid transparent;border-radius:4px;color:var(--text-primary);padding:4px 8px;font-size:.8rem;width:100%;min-width:60px;transition:all .3s;text-align:right}[data-theme=light] .input-mini{background:transparent}.input-mini:focus,.input-mini:hover{border-color:var(--border-color-strong);outline:none}.add-btn.group-add:hover{border-color:var(--accent-gold)!important;color:var(--accent-gold)!important;background:#ffd7000d!important}.actions-row{display:flex;gap:.75rem;margin-top:.75rem}.actions-row .add-btn{margin-top:0;width:auto}.actions-row .item-add{flex:3}.actions-row .group-add{flex:1}.input-name{background:transparent;border:none;color:var(--text-primary);font-size:.85rem;font-family:inherit;width:100%;outline:none;padding:6px 0}.input-name::placeholder{color:var(--text-muted)}.input-name:focus{color:var(--accent-gold)}.revenue-panel .input-name:focus{color:var(--accent-green)}.expense-panel .input-name:focus{color:var(--accent-red)}.savings-panel .input-name:focus{color:var(--accent-savings)}.input-amount-group{display:flex;align-items:center;background:#0000001f;border-radius:6px;padding:0 8px;border:1px solid transparent;transition:all .3s}[data-theme=light] .input-amount-group{background:#ffffff80}.input-amount-group:focus-within{border-color:var(--accent-gold)}.revenue-panel .input-amount-group:focus-within{border-color:var(--accent-green)}.expense-panel .input-amount-group:focus-within{border-color:var(--accent-red)}.savings-panel .input-amount-group:focus-within{border-color:var(--accent-savings)}.currency-symbol{color:var(--text-muted);font-weight:600;margin-right:4px;font-size:.75rem}.input-amount{background:transparent;border:none;color:var(--text-primary);font-size:.85rem;font-family:JetBrains Mono,monospace;width:100%;outline:none;text-align:right;padding:6px 0}.generate-section{text-align:center;margin:2rem 0;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.view-period-toggle{display:flex;background:var(--bg-input);padding:4px;border-radius:100px;border:1px solid var(--border-color-strong);width:fit-content;flex-shrink:0}.view-period-btn{padding:8px 24px;border-radius:100px;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.view-period-btn.active{background:var(--gradient-gold);color:#0a0a0f;box-shadow:0 4px 12px #ffd70033}.generate-btn{padding:1rem 3rem;font-size:1rem;font-weight:700;font-family:inherit;text-transform:uppercase;letter-spacing:2px;color:#0a0a0f;background:var(--gradient-gold);border:none;border-radius:100px;cursor:pointer;overflow:hidden;transition:all .4s;box-shadow:0 10px 40px #ffd7004d}.generate-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 20px 60px #ffd70066}.chart-container{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:2rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);margin-bottom:2rem;position:relative;gap:1.5rem;min-width:320px}.chart-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-gold),transparent)}#sankey-chart{min-height:400px;width:100%;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}@media(max-width:600px){#sankey-chart{min-height:400px;align-items:flex-start;padding-top:1rem}.chart-container{padding:1.5rem 1rem;gap:2rem;min-height:650px}.chart-header{flex-direction:column;align-items:flex-start;gap:1.5rem;margin-bottom:0}.view-period-btn{padding:10px 14px;font-size:.85rem;flex:1}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1.5rem;border:2px dashed var(--border-color-strong);border-radius:24px;background:#ffffff03;transition:all .4s cubic-bezier(.4,0,.2,1);max-width:600px;width:90%;animation:fadeIn .8s ease-out;cursor:pointer;overflow:hidden}@media(max-width:768px){.empty-state{padding:1.5rem 1rem;width:100%;margin:0}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{font-size:1.25rem;margin-bottom:.5rem}.empty-state p{font-size:.85rem;margin-bottom:1.5rem}}.empty-state:hover{border-color:var(--accent-gold);background:#ffd70008;transform:scale(1.02);box-shadow:0 30px 60px #0003}.empty-state-icon{font-size:5rem;margin-bottom:2rem;filter:drop-shadow(0 0 30px rgba(255,215,0,.3));animation:float 4s ease-in-out infinite}.empty-state h3{font-size:2rem;font-weight:800;margin-bottom:1rem;color:var(--text-primary);letter-spacing:-.5px}.empty-state p{font-size:1.1rem;color:var(--text-secondary);max-width:450px;margin-bottom:2.5rem;line-height:1.6}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chart-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;width:100%;position:relative;z-index:10;margin-bottom:0}.chart-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;flex:1 1 auto}.chart-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0;flex-wrap:nowrap}@media(max-width:600px){.chart-header{flex-direction:column;align-items:flex-start;gap:1rem}.chart-title{width:100%;font-size:1rem}.chart-actions{width:100%;justify-content:space-between}.view-period-toggle{flex:1}.view-period-btn{padding:8px 10px;font-size:.7rem;flex:1}}.export-btn{background:var(--bg-input);border:1px solid var(--border-color-strong);color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .3s}.export-btn:hover{background:var(--accent-gold);color:#0a0a0f;border-color:var(--accent-gold)}.status-indicator{position:fixed;top:5rem;right:2rem;padding:1rem 1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:none;align-items:center;gap:12px;z-index:100;animation:slideIn .5s;box-shadow:0 10px 40px var(--shadow-color)}@keyframes slideIn{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}.status-indicator.surplus{border-color:#00ff884d}.status-indicator.deficit{border-color:#ff47574d}.status-emoji{font-size:1.5rem}.status-text{font-weight:600}.status-amount{font-family:JetBrains Mono,monospace;font-weight:700}.status-indicator.surplus .status-amount{color:var(--accent-green)}.status-indicator.deficit .status-amount{color:var(--accent-red)}.loading{display:none;position:fixed;inset:0;background:#0a0a0fe6;z-index:1000;align-items:center;justify-content:center;flex-direction:column;gap:1rem}[data-theme=light] .loading{background:#f8f9fcf2}.loading.active{display:flex}[data-theme=dark] .sankey-node .node-label{filter:drop-shadow(0px 1px 2px rgba(0,0,0,1)) drop-shadow(0px 0px 4px rgba(0,0,0,.8));font-weight:600!important}.spinner{width:50px;height:50px;border:3px solid var(--border-color);border-top-color:var(--accent-gold);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-weight:500}.footer{text-align:center;padding:3rem 1.5rem 2rem;color:var(--text-muted);font-size:.85rem;border-top:1px solid var(--border-color);margin-top:2rem}.footer-content{display:flex;flex-direction:column;gap:.75rem;max-width:600px;margin:0 auto}.footer-row.links{display:flex;justify-content:center;gap:2rem}.footer-row.links a{color:var(--text-secondary);text-decoration:none;transition:all .3s ease;font-weight:500}.footer-row.links a:hover{color:var(--accent-gold);transform:translateY(-1px)}.flash-messages{position:fixed;top:5rem;right:2rem;z-index:2000;width:auto;max-width:400px;pointer-events:none;display:flex;flex-direction:column;align-items:flex-end;gap:10px}.flash-message{padding:1rem 1.5rem;border-radius:16px;font-size:.95rem;font-weight:600;box-shadow:0 10px 40px var(--shadow-color);animation:slideDownFade .5s cubic-bezier(.4,0,.2,1) forwards;pointer-events:auto;text-align:center;background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);color:var(--text-primary);display:flex;align-items:center;gap:10px}@keyframes slideDownFade{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.flash-message.fade-out{animation:fadeOut .8s forwards}@keyframes fadeOut{to{opacity:0;transform:translateY(-10px)}}.flash-message.success{border-color:#00ff884d}.flash-message.success:before{content:"✅";font-size:1.2rem}.flash-message.error{border-color:#ff47574d}.flash-message.error:before{content:"⚠️";font-size:1.2rem}.flash-message.info{border-color:#ffd7004d}.flash-message.info:before{content:"ℹ️";font-size:1.2rem}.content-panel{padding:2rem;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-color);box-shadow:0 4px 20px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);margin-bottom:2rem}.content-panel h2{color:var(--accent-gold);margin-top:1.5rem;margin-bottom:1rem}.content-panel p{margin-bottom:1rem;line-height:1.6;color:var(--text-secondary)}.content-panel ul{margin-left:1.5rem;margin-bottom:1.5rem;color:var(--text-secondary);line-height:1.6}.content-panel li{margin-bottom:.5rem}@media(max-width:768px){.container{padding:1rem}body.sidebar-open .container{margin-left:0}.sidebar{width:85%;max-width:320px;left:-100%;box-shadow:none}.sidebar.active{left:0;box-shadow:5px 0 30px #00000080}#sankey-chart{height:350px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:3000;display:none;justify-content:center;align-items:center;animation:modalFadeIn .3s ease-out forwards}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-window{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:2.5rem;max-width:480px;width:90%;text-align:center;box-shadow:0 20px 60px #00000080;position:relative;overflow:hidden;animation:modalScaleIn .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes modalScaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-icon{font-size:3rem;margin-bottom:1.5rem;display:inline-block;filter:drop-shadow(0 0 20px rgba(255,215,0,.2))}.modal-title{color:var(--text-primary);font-size:1.75rem;margin-bottom:1rem;font-weight:800;letter-spacing:-.5px}.modal-description{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:2rem}.form-group{margin-bottom:1.5rem;text-align:left}.form-label{display:block;margin-bottom:.75rem;color:var(--text-secondary);font-size:.75rem;font-weight:700;margin-left:4px;text-transform:uppercase;letter-spacing:1px}.form-input{width:100%;background:var(--bg-input);border:1px solid var(--border-color-strong);border-radius:12px;padding:12px 16px;color:var(--text-primary);font-family:inherit;font-size:1rem;outline:none;transition:all .3s}.form-input:focus{border-color:var(--accent-gold)!important;background:#ffffff0d;box-shadow:0 0 0 4px #ffd7001a}.auth-page-wrapper{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;pointer-events:none}.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:2.5rem;width:100%;max-width:420px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 60px var(--shadow-color);pointer-events:auto;animation:modalScaleIn .3s cubic-bezier(.4,0,.2,1) forwards}.auth-card h2{font-size:1.8rem;font-weight:800;margin-bottom:.5rem;text-align:center;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-card .subtitle{text-align:center;color:var(--text-muted);font-size:.85rem;margin-bottom:2rem;display:block;text-transform:none;letter-spacing:normal}.staging-badge{background:#ff4757;color:#fff;font-size:.6rem;padding:2px 6px;border-radius:4px;vertical-align:middle;margin-left:8px;letter-spacing:1px;font-weight:800;-webkit-text-fill-color:white}.modal-actions{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.modal-btn{width:100%;padding:14px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;border:none;display:flex;align-items:center;justify-content:center;gap:.5rem}.modal-btn-primary{background:var(--gradient-gold);color:#0a0a0f;box-shadow:0 4px 15px #ffd70033}.modal-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ffd7004d}.modal-btn-danger{background:#ff475726;color:var(--accent-red);border:1px solid rgba(255,71,87,.3)}.modal-btn-danger:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red);transform:translateY(-2px);box-shadow:0 8px 25px #ff47574d}.modal-btn-secondary{background:transparent;border:1px solid var(--border-color-strong);color:var(--text-secondary)}.modal-btn-secondary:hover{border-color:var(--text-primary);color:var(--text-primary);background:var(--bg-input)}.staging-badge{display:inline-block;vertical-align:middle;font-size:.8rem;background:#fa03;color:#fa0;-webkit-text-fill-color:#ffaa00;border:1px solid #ffaa00;padding:4px 8px;border-radius:6px;margin-left:10px;letter-spacing:1px;text-transform:uppercase;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:.7}50%{opacity:1;box-shadow:0 0 10px #ffaa004d}to{opacity:.7}}
