:root{--bg-color: #0A0A0B;--surface-color: #161618;--accent-color: #D4AF37;--text-primary: #F8F9FA;--text-secondary: #94A3B8;--danger: #EF4444;--success: #10B981;--glass: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .05);--font-display: "Outfit", sans-serif;--font-ui: "Inter", sans-serif;--gold: #D4AF37;--gold-light: #F1D57F}*{margin:0;padding:0;box-sizing:border-box}body{background-color:var(--bg-color);color:var(--text-primary);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;overflow-x:hidden}.app-container{display:flex;min-height:100vh}.sidebar{width:260px;background-color:var(--surface-color);border-right:1px solid var(--glass-border);padding:2rem 1.5rem;display:flex;flex-direction:column;gap:3rem;position:relative;transition:width .3s cubic-bezier(.4,0,.2,1),padding .3s ease;z-index:100}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:70px;background:#161618cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);justify-content:space-around;align-items:center;padding:0 10px;z-index:1000;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none;font-size:.65rem;font-weight:500;transition:all .3s ease;padding:8px;min-width:64px}.mobile-nav-item i,.mobile-nav-item svg{transition:transform .3s ease}.mobile-nav-item.active{color:var(--accent-color)}.mobile-nav-item.active i,.mobile-nav-item.active svg{transform:translateY(-2px)}@media (max-width: 768px){.sidebar{display:none}.mobile-bottom-nav{display:flex}.content-container{padding-bottom:80px}.app-container{flex-direction:column}}.nav-links li span{font-size:.85rem;font-weight:600;letter-spacing:.01em;opacity:1;color:var(--text-primary)}.nav-links li svg{opacity:.7;transition:all .3s ease}.nav-links li:hover{background-color:var(--glass);color:var(--text-primary)}.nav-links li:hover svg{opacity:1;transform:scale(1.1)}.nav-links li.active{background-color:var(--accent-color);color:var(--bg-color)}.nav-links li.active span{color:var(--bg-color)}.nav-links li.active svg{opacity:1}.sidebar-toggle{margin-top:auto;background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary);width:100%;padding:.75rem;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-toggle:hover{background:var(--accent-color);color:var(--bg-color);border-color:var(--accent-color)}.sidebar.collapsed .sidebar-toggle{width:40px;height:40px;padding:0}.month-carousel-full{width:100%;background:var(--surface-color);border:1px solid var(--glass-border);border-radius:20px;padding:.5rem;display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;overflow:hidden;position:relative;box-shadow:0 10px 30px #0000004d}.month-scroll-wrapper{flex:1;display:flex;gap:1.5rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:1rem 50%;scroll-behavior:smooth;-webkit-mask-image:linear-gradient(to right,transparent,black 25%,black 75%,transparent);mask-image:linear-gradient(to right,transparent,black 25%,black 75%,transparent)}.month-item{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.8rem 1.2rem;border-radius:16px;cursor:pointer;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--glass);border:1px solid var(--glass-border);min-width:130px;gap:.5rem}.month-item:hover{background:#ffffff0d}.month-item.active{background:var(--accent-color);color:var(--bg-color);transform:scale(1.1);box-shadow:0 10px 20px #d4af3733}.month-info{display:flex;flex-direction:column;gap:2px}.month-name{font-size:.85rem;font-weight:600}.month-year{font-size:.7rem;opacity:.6}.month-balance{font-size:.75rem;font-weight:700;font-family:var(--font-display);padding:.2rem .5rem;border-radius:8px;background:#ffffff0d}.month-balance.positive{color:var(--success)}.month-balance.negative{color:var(--danger)}.month-item.active .month-balance{background:#0000001a;color:var(--bg-color)}.main-content{flex:1;padding:2.5rem 3rem;background:radial-gradient(circle at 50% -20%,rgba(212,175,55,.05) 0%,transparent 50%)}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem}.welcome h1{font-family:var(--font-display);font-size:2rem;margin-bottom:.5rem}.welcome p{color:var(--text-secondary);font-size:1.1rem}.date-display{background:var(--glass);border:1px solid var(--glass-border);padding:.5rem 1rem;border-radius:999px;font-size:.875rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:3rem}.summary-card{background:var(--surface-color);border:1px solid var(--glass-border);padding:1.5rem;border-radius:20px;position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%}.summary-card.revenue:before{background:var(--success)}.summary-card.expenses:before{background:var(--danger)}.summary-card.balance:before{background:var(--accent-color)}.card-header{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.card-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.card-footer{font-size:.75rem;color:var(--text-secondary);opacity:.7}.categories-section h2,.evolution-section h2{font-family:var(--font-display);font-size:1.5rem;margin-bottom:1.5rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.category-card{background:var(--surface-color);border:1px solid var(--glass-border);padding:1.5rem;border-radius:24px;display:flex;align-items:center;gap:1.25rem;position:relative;overflow:hidden;cursor:pointer}.category-icon-wrapper{width:54px;height:54px;background:var(--glass);border-radius:16px;display:flex;align-items:center;justify-content:center;border:1px solid var(--glass-border)}.category-info h3{font-size:.9rem;font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.category-total{font-family:var(--font-display);font-size:1.25rem;font-weight:600}.category-progress-bg{position:absolute;bottom:0;left:0;width:100%;height:4px;background:var(--glass)}.category-progress-bar{height:100%;border-radius:0 4px 4px 0}.categories-view{animation:fadeIn .4s ease-out}.category-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.category-list-item{background:var(--surface-color);border:1px solid var(--glass-border);padding:1.25rem 1.5rem;border-radius:20px;display:flex;justify-content:space-between;align-items:center}.cat-item-main{display:flex;align-items:center;gap:1rem}.cat-color-dot{width:12px;height:12px;border-radius:50%}.cat-item-name{font-weight:500;font-size:1rem}.cat-item-actions{display:flex;gap:.5rem}.evolution-section{margin-top:4rem}.evolution-chart{background:var(--surface-color);border:1px solid var(--glass-border);padding:2rem;border-radius:24px;margin-top:2rem}.chart-bars{display:flex;align-items:flex-end;justify-content:space-between;height:200px;gap:.5rem}.chart-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem}.bar-wrapper{width:100%;height:160px;display:flex;align-items:flex-end;justify-content:center;background:var(--glass);border-radius:8px;overflow:hidden}.bar{width:60%;border-radius:4px 4px 0 0}.bar.positive{background:var(--success);opacity:.8}.bar.negative{background:var(--danger);opacity:.8}.month-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.transactions-view{animation:fadeIn .4s ease-out;display:flex;flex-direction:column;gap:0}.transactions-view .view-header{background:var(--surface-color);border:1px solid var(--glass-border);border-radius:24px 24px 0 0;padding:1.5rem 2rem;margin-bottom:0;display:flex;justify-content:space-between;align-items:center}.transactions-view .transactions-summary-bar{border-radius:0;border-top:none;border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);margin-bottom:0}.transactions-view .transactions-table-wrapper{border-top:none;border-radius:0 0 24px 24px;margin-bottom:0}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.view-title-group h2{font-family:var(--font-display);font-size:1.75rem;margin-bottom:.25rem}.view-subtitle{color:var(--text-secondary);font-size:.85rem}.header-actions,.filter-group{display:flex;gap:1rem}.cat-filter{background:var(--surface-color);border:1px solid var(--glass-border);color:var(--text-primary);padding:.75rem 1.25rem;border-radius:14px;font-family:var(--font-ui);font-size:.9rem;outline:none;cursor:pointer;transition:all .2s;height:44px}.cat-filter:hover{border-color:var(--accent-color)}.header-actions .add-btn,.search-bar{height:44px}.transactions-summary-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem;background:var(--glass);padding:1.5rem 2rem;border-radius:24px;border:1px solid var(--glass-border)}.summary-item .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.summary-item .value{font-size:1.5rem;font-weight:700;font-family:var(--font-display)}.summary-item.income .value{color:var(--success)}.summary-item.expenses .value{color:var(--text-primary)}.transactions-table{width:100%;border-collapse:collapse;text-align:left}.transactions-table th{padding:1.25rem 1.5rem;font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--glass-border)}.transactions-table td{padding:1.25rem 1.5rem;font-size:.95rem;border-bottom:1px solid var(--glass-border)}.transaction-row:last-child td{border-bottom:none}.desc-content{display:flex;align-items:center;gap:1rem}.recurring-indicator{display:flex;align-items:center;justify-content:center;color:var(--accent-color);opacity:.8;background:var(--glass);padding:.25rem;border-radius:6px;border:1px solid rgba(212,175,55,.1)}.report-tabs{display:flex;gap:.5rem;background:var(--glass);padding:.4rem;border-radius:12px;border:1px solid var(--glass-border)}.report-tab-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s}.report-tab-btn.active{background:var(--accent-color);color:var(--bg-color)}.simulator-section{background:var(--surface-color);border:1px solid var(--glass-border);border-radius:18px;padding:2rem;animation:fadeIn .4s ease-out}.simulator-controls{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--glass-border)}.simulator-controls input{background:var(--glass);border:1px solid var(--glass-border);padding:1rem;border-radius:12px;color:var(--text-primary);font-family:var(--font-ui);outline:none;transition:all .2s;width:100%}.simulator-controls input:focus{border-color:var(--accent-color);background:var(--surface-color);box-shadow:0 4px 12px #d4af371a}.input-with-icon{position:relative;display:flex;align-items:center}.currency-prefix{position:absolute;left:1rem;color:var(--text-secondary);font-weight:600;font-size:.9rem}.input-with-icon input{padding-left:2.5rem!important;width:100%}.simulation-table-wrapper{margin-top:1rem;overflow-x:auto}.simulation-table{width:100%;border-collapse:collapse}.simulation-table th{text-align:left;padding:1rem;color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:1px}.simulation-table td{padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.05)}.provision-balance{display:flex;align-items:center;gap:1rem}.provision-balance .old-val{color:var(--text-secondary);font-size:.9rem;text-decoration:line-through;opacity:.5}.simulator-summary{margin-top:2rem;background:var(--glass);padding:1.5rem;border-radius:14px;display:flex;justify-content:flex-end}.summary-item{display:flex;flex-direction:column;align-items:flex-end}.summary-item .label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.25rem}.summary-item .value{font-size:1.5rem;font-weight:700}.type-indicator{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center}.type-indicator.income{background:#10b9811a;color:#10b981}.type-indicator.expense{background:#ef44441a;color:#ef4444}.cat-badge{padding:.35rem .75rem;border-radius:999px;font-size:.75rem;font-weight:500;background:var(--glass)}.text-right{text-align:right}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.reports-view{animation:fadeIn .4s ease-out}.reports-grid{display:grid;grid-template-columns:1fr 340px;gap:2rem}.report-card{background:var(--surface-color);border:1px solid var(--glass-border);padding:2.5rem;border-radius:32px}.report-card .card-header{display:flex;align-items:center;gap:.75rem;color:var(--accent-color);margin-bottom:2rem;font-weight:600}.breakdown-list{display:flex;flex-direction:column;gap:1.5rem}.breakdown-item{display:flex;flex-direction:column;gap:.75rem}.item-info{display:flex;align-items:center;gap:.75rem}.item-rank{font-size:.75rem;color:var(--text-secondary);width:20px}.item-name{font-weight:500}.item-values{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-display)}.item-percentage{color:var(--text-secondary);font-size:.9rem}.item-amount{font-weight:600;font-size:1.1rem}.item-progress-bg{width:100%;height:6px;background:var(--glass);border-radius:999px;overflow:hidden}.item-progress-bar{height:100%;background:var(--accent-color);border-radius:999px}.reports-sidebar{display:flex;flex-direction:column;gap:1.5rem}.report-mini-card{background:var(--glass);border:1px solid var(--glass-border);padding:1.5rem;border-radius:24px;display:flex;align-items:center;gap:1.25rem}.mini-card-content{display:flex;flex-direction:column;gap:.25rem}.mini-card-content .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.mini-card-content .value{font-family:var(--font-display);font-size:1.25rem;font-weight:600}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:var(--surface-color);border:1px solid var(--glass-border);padding:2.5rem;border-radius:32px;width:100%;max-width:480px;box-shadow:0 40px 100px #0009;position:relative;max-height:90vh;overflow-y:auto}.modal-form input,.modal-form select,.form-group input,.form-group select{background:var(--glass);border:1px solid var(--glass-border);padding:.875rem 1rem;border-radius:12px;color:var(--text-primary);font-family:var(--font-ui);font-size:.95rem;outline:none;width:100%;transition:border-color .2s,box-shadow .2s}.modal-form input:focus,.modal-form select:focus,.form-group input:focus,.form-group select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #d4af3714}.modal-form input::placeholder,.form-group input::placeholder{color:var(--text-secondary);opacity:.5}.type-selector{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.type-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border-radius:12px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.type-btn:hover{background:#ffffff0d}.type-btn.income.active{background:#22c55e26;border-color:#22c55e4d;color:var(--success)}.type-btn.expense.active{background:#ef444426;border-color:#ef44444d;color:var(--danger)}.form-group input[type=date],.modal-form input[type=date]{color-scheme:dark}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem 0}.checkbox-label input{width:20px!important;height:20px!important;padding:0!important;accent-color:var(--accent-color)}.checkbox-content{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-weight:500}.field-help{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;opacity:.7;margin-left:2.25rem}.add-btn{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#000;border:none;padding:.75rem 1.25rem;border-radius:12px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.add-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #d4af3766}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.main-content>*{animation:fadeIn .6s ease-out both}.period-badge{display:inline-flex;align-items:center;gap:.5rem;background:#d4af371a;border:1px solid rgba(212,175,55,.2);color:var(--accent-color);padding:.5rem 1rem;border-radius:100px;font-size:.85rem;font-weight:600;margin-top:.75rem;animation:fadeIn .8s ease-out both}.period-badge .dot{width:6px;height:6px;background:var(--accent-color);border-radius:50%;box-shadow:0 0 10px var(--accent-color)}.header-actions{display:flex;align-items:center;gap:1rem}.search-bar{background:var(--surface-color);border:1px solid var(--glass-border);padding:.75rem 1.25rem;border-radius:14px;display:flex;align-items:center;gap:.75rem;width:320px;transition:all .2s cubic-bezier(.4,0,.2,1)}.search-bar:focus-within{border-color:var(--accent-color);background:var(--glass);transform:translateY(-1px);box-shadow:0 4px 20px #0003}.search-bar input{background:transparent;border:none;color:var(--text-primary);font-family:var(--font-ui);width:100%;outline:none}.search-bar svg{color:var(--text-secondary);opacity:.6}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h3{margin:0;font-family:Outfit,sans-serif;font-size:1.1rem;color:var(--text-primary)}.avatar{width:38px;height:38px;border-radius:10px;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:700;color:#000;font-size:.85rem;flex-shrink:0;overflow:hidden}.profile-photo-wrapper{position:relative;width:100px;height:100px;border-radius:24px;overflow:hidden;background:var(--glass);border:2px solid var(--glass-border);display:flex;align-items:center;justify-content:center;transition:all .3s}.profile-img{width:100%;height:100%;object-fit:cover}.profile-placeholder{font-size:2.5rem;font-weight:700;color:var(--gold);font-family:Outfit,sans-serif}.profile-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:center}.logout-action-btn{display:flex;align-items:center;gap:10px;padding:12px 28px;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2);border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.logout-action-btn:hover{background:#ef4444;color:#fff;transform:translateY(-2px);box-shadow:0 5px 15px #ef44444d}.change-photo-btn{position:absolute;bottom:0;left:0;right:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;color:#fff;padding:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s}.profile-photo-wrapper:hover .change-photo-btn{opacity:1}.modal-header h3{font-family:var(--font-display);font-size:1.5rem;color:var(--accent-color)}.close-btn{background:var(--glass);border:none;color:var(--text-secondary);padding:.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:#ffffff1a;color:var(--text-primary)}.type-selector{display:flex;gap:.75rem;padding:.4rem;background:var(--glass);border-radius:16px;margin-bottom:2rem;border:1px solid var(--glass-border)}.type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem;border-radius:12px;border:none;background:transparent;color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.type-btn.income.active{background:#10b98126;color:#10b981;box-shadow:0 4px 12px #10b9811a}.type-btn.expense.active{background:#ef444426;color:#ef4444;box-shadow:0 4px 12px #ef44441a}.type-btn svg{opacity:.5}.type-btn.active svg{opacity:1}.modal-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.save-btn,.delete-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.save-btn{background:var(--accent-color);color:var(--bg-color);border:none}.delete-btn{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.save-btn:hover{transform:translateY(-2px);opacity:.9}.delete-btn:hover{background:var(--danger);color:#fff}.edit-row-btn{opacity:.2;background:var(--glass);border:none;color:var(--text-secondary);padding:.35rem;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.edit-row-btn:hover{background:var(--accent-color);color:var(--bg-color)}.edit-row-btn.dupe:hover{background:var(--success);color:var(--bg-color)}.edit-row-btn.delete:hover{background:var(--danger);color:#fff}@media (max-width: 1024px){.sidebar{width:80px;padding:2rem 1rem}.brand-name,.nav-links span{display:none}.summary-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}.reports-grid{grid-template-columns:1fr}}.sidebar.minimized{width:80px;padding:1.5rem .75rem;align-items:center;gap:2rem}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:40px}.sidebar.minimized .sidebar-header{flex-direction:column;gap:.5rem}.logo{display:flex;align-items:center;gap:.75rem;overflow:hidden}.logo-icon{width:38px;height:38px;min-width:38px;background:var(--accent-color);color:var(--bg-color);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:.85rem;letter-spacing:-.03em}.logo-icon img{width:24px;height:24px;object-fit:contain}.logo-text{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--accent-color);letter-spacing:-.02em;white-space:nowrap}.toggle-sidebar{background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary);width:28px;height:28px;min-width:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.toggle-sidebar:hover{background:#ffffff12;color:var(--accent-color);border-color:var(--accent-color)}.nav-menu{flex:1}.nav-menu ul{list-style:none;display:flex;flex-direction:column;gap:.35rem;padding:0;margin:0}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;border-radius:12px;color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.9rem;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;overflow:hidden}.nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.nav-item.active{background:#d4af371a;color:var(--accent-color);border:1px solid rgba(212,175,55,.15)}.sidebar.minimized .nav-item{padding:.875rem;justify-content:center;gap:0}.sidebar-footer{margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--glass-border)}.user-profile{display:flex;align-items:center;gap:.875rem;overflow:hidden}.avatar{width:38px;height:38px;min-width:38px;background:#d4af3726;border:1px solid rgba(212,175,55,.3);color:var(--accent-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;font-family:var(--font-display)}.user-info{display:flex;flex-direction:column;gap:.15rem;overflow:hidden}.user-info .name{font-weight:600;font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .plan{font-size:.75rem;color:var(--accent-color);opacity:.8;white-space:nowrap}.content-container{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:100vh}.content-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2.5rem}.content-header h1{font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:-.03em;color:var(--text-primary)}.content-header .subtitle,.subtitle{color:var(--text-secondary);font-size:.925rem;margin-top:.25rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2.5rem}.stat-card{background:var(--surface-color);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px #0000004d}.stat-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.revenue{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.15)}.stat-icon.expense{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.15)}.stat-icon.balance{background:#d4af371a;color:var(--accent-color);border:1px solid rgba(212,175,55,.15)}.stat-info{display:flex;flex-direction:column;gap:.25rem}.stat-info span{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-info h3{font-family:var(--font-display);font-size:1.65rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.charts-section,.categories-section{margin-bottom:3rem}.section-header{margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between}.section-header h2{font-family:var(--font-display);font-size:1.35rem;font-weight:600;color:var(--text-primary)}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.carousel-btn{background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary);width:36px;height:36px;min-width:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.carousel-btn:hover{background:#d4af371a;border-color:#d4af374d;color:var(--accent-color)}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.categories-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.stats-grid,.categories-grid{grid-template-columns:1fr}.stat-card{padding:1.25rem}}.transactions-view,.reports-view,.categories-view,.settings-page{display:flex;flex-direction:column;gap:1.5rem;padding:2.5rem 3rem;flex:1}.view-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.view-title-group h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.view-subtitle{font-size:.85rem;color:var(--text-muted);margin:.2rem 0 0}.header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem}.cat-filter{background:var(--card-bg);border:1px solid var(--gold);color:var(--text-primary);border-radius:8px;padding:.5rem .75rem;font-size:.85rem;cursor:pointer;outline:none;transition:border-color .2s}.cat-filter:focus{border-color:var(--gold-light)}.cat-filter option{background:var(--bg-color);color:var(--text-primary)}.search-bar{display:flex;align-items:center;gap:.5rem;background:var(--card-bg);border:1px solid rgba(212,175,55,.3);border-radius:8px;padding:.5rem .75rem;min-width:200px;transition:border-color .2s}.search-bar:focus-within{border-color:var(--gold)}.search-bar svg{color:var(--text-muted);flex-shrink:0}.search-bar input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.875rem;width:100%}.search-bar input::placeholder{color:var(--text-muted)}.transactions-summary-bar{display:flex;gap:1rem;background:var(--card-bg);border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:1rem 1.5rem}.transactions-summary-bar .summary-item{flex:1;display:flex;flex-direction:column;gap:.25rem}.transactions-summary-bar .summary-item .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.transactions-summary-bar .summary-item .value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.transactions-summary-bar .summary-item.income .value{color:var(--success)}.transactions-summary-bar .summary-item.expenses .value{color:var(--danger)}.transactions-summary-bar .summary-item.total{border-left:1px solid rgba(212,175,55,.2);padding-left:1rem}.transactions-table-wrapper{background:var(--card-bg);border:1px solid rgba(212,175,55,.12);border-radius:16px;overflow:hidden}.transactions-table{width:100%;border-collapse:collapse;font-size:.875rem}.transactions-table thead tr{background:#d4af370f;border-bottom:1px solid rgba(212,175,55,.15)}.transactions-table th{padding:.875rem 1.25rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);font-weight:600;white-space:nowrap}.transactions-table th.text-right,.transactions-table td.text-right{text-align:right}.transaction-row{border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s;cursor:pointer}.transaction-row:hover{background:#d4af370a}.transactions-table td{padding:.875rem 1.25rem;color:var(--text-secondary);vertical-align:middle}.amount-cell{min-width:180px}.date-cell{white-space:nowrap;color:var(--text-muted)!important;font-size:.82rem}.desc-cell{max-width:300px}.desc-content{display:flex;align-items:center;gap:.6rem}.desc-content>span{color:var(--text-primary);font-weight:500}.type-indicator{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.type-indicator.income{background:#22c55e26;color:var(--success)}.recurring-indicator{color:var(--gold);opacity:.7;display:flex;align-items:center}.cat-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.77rem;font-weight:600;background:#d4af371f;color:var(--gold);border:1px solid rgba(212,175,55,.2);text-transform:capitalize}.amount-cell{white-space:nowrap;font-weight:600;color:var(--text-primary)!important}.amount-value{min-width:100px;text-align:right;font-weight:700}.edit-row-btn{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#ffffff08;border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all .2s;flex-shrink:0}.edit-row-btn:hover{background:#ffffff1a;color:var(--text-primary);transform:scale(1.05)}.edit-row-btn.confirm:hover{color:var(--success);border-color:var(--success);background:#10b9811a}.edit-row-btn.confirm.active{color:var(--success);background:#10b98126;border-color:#10b9814d}.edit-row-btn.dupe:hover{color:var(--gold);border-color:var(--gold)}.edit-row-btn.delete:hover{color:var(--danger);border-color:var(--danger);background:#ef44441a}.report-tabs{display:flex;gap:.5rem}.report-tab-btn{display:flex;align-items:center;gap:.5rem;background:var(--card-bg);border:1px solid rgba(212,175,55,.2);color:var(--text-muted);border-radius:8px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s;font-family:inherit}.report-tab-btn:hover{border-color:var(--gold);color:var(--gold)}.report-tab-btn.active{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#000;border-color:transparent;font-weight:600}.reports-grid{display:grid;grid-template-columns:1fr 280px;gap:1.5rem;align-items:start}.report-card{background:var(--card-bg);border:1px solid rgba(212,175,55,.12);border-radius:16px;padding:1.5rem}.report-card.main-chart-card{display:flex;flex-direction:column;gap:1.25rem}.card-header{display:flex;align-items:center;gap:.6rem;font-size:.9rem;font-weight:600;color:var(--gold);border-bottom:1px solid rgba(212,175,55,.1);padding-bottom:1rem;margin-bottom:.5rem}.breakdown-list{display:flex;flex-direction:column;gap:.875rem}.breakdown-item{display:flex;flex-direction:column;gap:.4rem}.item-info{display:flex;align-items:center;gap:.6rem}.item-rank{width:22px;height:22px;background:#d4af371f;color:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;flex-shrink:0}.item-name{font-size:.875rem;color:var(--text-primary);font-weight:500;flex:1}.invite-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.invite-code-wrapper{background:#0003;border:1px solid var(--glass-border);border-radius:12px;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.invite-code-wrapper:hover{border-color:var(--primary);background:#4f46e50d}.invite-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:1.25rem;font-weight:700;letter-spacing:.1em;color:var(--primary)}.share-link-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .2s}.share-link-btn:hover{background:var(--primary);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.share-link-btn.copied{background:#10b981;border-color:#10b981;color:#fff}.item-values{display:flex;align-items:center;justify-content:space-between;margin-left:28px}.item-percentage{font-size:.8rem;color:var(--text-muted)}.item-amount{font-size:.875rem;font-weight:600;color:var(--text-primary)}.item-progress-bg{height:4px;background:#ffffff0f;border-radius:4px;margin-left:28px;overflow:hidden}.item-progress-bar{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:4px}.reports-sidebar{display:flex;flex-direction:column;gap:1rem}.report-mini-card{background:var(--card-bg);border:1px solid rgba(212,175,55,.12);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:border-color .2s}.report-mini-card:hover{border-color:#d4af374d}.mini-card-content{display:flex;flex-direction:column;gap:.2rem}.mini-card-content .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.mini-card-content .value{font-size:1rem;font-weight:700;color:var(--text-primary)}.simulator-section{background:var(--card-bg);border:1px solid rgba(212,175,55,.12);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.simulator-controls{display:flex;gap:1.25rem;flex-wrap:wrap}.simulator-controls .form-group{display:flex;flex-direction:column;gap:.4rem;flex:1;min-width:160px}.simulator-controls .form-group label{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);font-weight:600}.input-with-icon{display:flex;align-items:center;background:#0000004d;border:1px solid rgba(212,175,55,.25);border-radius:8px;overflow:hidden;transition:border-color .2s}.input-with-icon:focus-within{border-color:var(--gold)}.currency-prefix{padding:.5rem .6rem;background:#d4af3714;color:var(--gold);font-size:.85rem;font-weight:600;border-right:1px solid rgba(212,175,55,.15);white-space:nowrap}.input-with-icon input,.simulator-controls .form-group input[type=number]{background:#0000004d;border:1px solid rgba(212,175,55,.25);border-radius:8px;color:var(--text-primary);font-size:.9rem;padding:.5rem .75rem;outline:none;width:100%;font-family:inherit;transition:border-color .2s}.input-with-icon input{background:transparent;border:none;border-radius:0}.simulator-controls .form-group input[type=number]:focus{border-color:var(--gold)}.simulation-table-wrapper{border-radius:12px;overflow:hidden;border:1px solid rgba(212,175,55,.1)}.simulation-table{width:100%;border-collapse:collapse;font-size:.875rem}.simulation-table thead tr{background:#d4af370f;border-bottom:1px solid rgba(212,175,55,.15)}.simulation-table th{padding:.75rem 1rem;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);font-weight:600}.simulation-table td{padding:.75rem 1rem;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.04)}.simulation-table tr:last-child td{border-bottom:none}.provision-balance{display:flex;align-items:center;gap:.5rem;font-size:.82rem}.provision-balance .old-val{color:var(--text-muted);text-decoration:line-through}.provision-balance svg{color:var(--text-muted);flex-shrink:0}.provision-balance .new-val{font-weight:600}.simulator-summary{background:#d4af370d;border:1px solid rgba(212,175,55,.15);border-radius:10px;padding:1rem 1.25rem}.simulator-summary .summary-item{display:flex;flex-direction:column;gap:.2rem}.simulator-summary .summary-item .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.simulator-summary .summary-item .value{font-size:1.25rem;font-weight:700}.category-list-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:1rem;margin-top:1.5rem}@media (max-width: 1400px){.category-list-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width: 1100px){.category-list-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.category-list-grid{display:flex;flex-direction:column;gap:.75rem}.category-card-item{flex-direction:row!important;padding:.75rem 1rem!important;justify-content:flex-start!important;gap:1rem!important;min-height:auto!important}.cat-card-icon{width:40px!important;height:40px!important;border-radius:10px!important}.cat-card-name{text-align:left!important}.cat-card-actions{position:relative!important;top:0!important;right:0!important;flex-direction:row!important;margin-left:auto;opacity:1!important;transform:none!important}}.category-card-item{background:var(--surface-color);border:1px solid var(--glass-border);padding:1.25rem .75rem;border-radius:20px;display:flex;flex-direction:column;align-items:center;gap:.6rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:default;overflow:hidden;min-height:140px}.category-card-item:hover{transform:translateY(-4px);border-color:var(--accent-color);background:var(--glass);box-shadow:0 8px 25px #0006}.cat-card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.category-card-item:hover .cat-card-icon{transform:scale(1.1)}.cat-card-name{font-weight:600;font-size:.85rem;color:var(--text-primary);text-align:center;word-break:break-word}.cat-card-actions{position:absolute;top:6px;right:6px;display:flex;gap:.3rem;opacity:0;transform:translateY(-5px);transition:all .2s ease}.category-card-item:hover .cat-card-actions{opacity:1;transform:translateY(0)}.card-action-btn{width:28px;height:28px;border-radius:8px;background:#0000004d;border:1px solid var(--glass-border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card-action-btn:hover{background:var(--accent-color);color:var(--bg-color);border-color:var(--accent-color);transform:scale(1.1)}.card-action-btn.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.item-icon-wrapper{width:32px;height:32px;border-radius:8px}.mini-card-icon{width:48px;height:48px;border-radius:14px}.settings-tabs{display:flex;gap:.5rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:2rem}.settings-tab-btn{display:flex;align-items:center;gap:.6rem;background:transparent;border:1px solid transparent;color:var(--text-secondary);padding:.6rem 1.25rem;border-radius:10px;font-weight:500;cursor:pointer;transition:all .2s}.settings-tab-btn:hover{color:var(--gold);background:#d4af370d}.icon-btn:hover{background:#ffffff0d;color:var(--text-primary);border-color:#fff3}.text-danger{color:#ff4d4d!important}.mb-2{margin-bottom:2rem!important}.income-header{color:var(--success)!important}.expense-header{color:var(--gold)!important}.empty-msg{text-align:center;padding:2rem;color:var(--text-muted);font-size:.9rem;font-style:italic}.settings-tab-btn.active{background:#d4af371a;color:var(--gold);border-color:#d4af3733;font-weight:600}.icon-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:.5rem;background:#0003;padding:1rem;border-radius:10px;border:1px solid rgba(255,255,255,.05);max-height:200px;overflow-y:auto}.icon-option-btn{width:40px;height:40px;border-radius:8px;background:transparent;border:1px solid transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.icon-option-btn:hover{background:#ffffff0d;color:var(--text-primary)}.icon-option-btn.active{background:var(--gold);color:#000}.family-settings{display:flex;flex-direction:column;gap:2.5rem}.settings-section{display:flex;flex-direction:column;gap:1.25rem}.section-header{display:flex;align-items:center;gap:.75rem;color:var(--gold)}.section-header h3{font-size:1.1rem;margin:0}.invite-card{background:#d4af370d;border:1px solid rgba(212,175,55,.15);padding:1.5rem;border-radius:16px}.invite-code-wrapper{margin-top:1rem;display:flex;align-items:center;justify-content:space-between;background:#0000004d;padding:1rem 1.5rem;border-radius:12px;border:1px dashed var(--gold);cursor:pointer}.invite-code{font-family:monospace;font-size:1.5rem;font-weight:700;letter-spacing:.1em;color:var(--gold)}.members-list{display:flex;flex-direction:column;gap:.75rem}.member-item{display:flex;align-items:center;gap:1rem;background:var(--card-bg);border:1px solid rgba(255,255,255,.05);padding:1rem;border-radius:12px}.member-avatar{width:42px;height:42px;background:var(--gold);color:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;overflow:hidden;flex-shrink:0}.avatar-img{width:100%;height:100%;object-fit:cover}.member-info{flex:1;display:flex;flex-direction:column}.member-name{font-weight:600;color:var(--text-primary)}.member-email{font-size:.85rem;color:var(--text-muted)}.member-date{font-size:.8rem;color:var(--text-muted)}.cat-item-actions{display:flex;gap:.4rem}.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-btn:hover{border-color:var(--gold);color:var(--gold);background:#d4af3714}.icon-btn.danger:hover{border-color:var(--danger);color:var(--danger);background:#ef444414}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.text-accent{color:var(--gold)!important}@media (max-width: 768px){.view-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.search-bar{min-width:unset;flex:1}.transactions-summary-bar{flex-direction:column;gap:.75rem}.transactions-summary-bar .summary-item.total{border-left:none;border-top:1px solid rgba(212,175,55,.2);padding-left:0;padding-top:.75rem}.reports-grid{grid-template-columns:1fr}.report-tabs{flex-direction:column;width:100%}.simulator-controls{flex-direction:column}.provision-balance{flex-wrap:wrap}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-color)}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15}.blob-1{width:500px;height:500px;background:var(--accent-color);top:-150px;left:-150px;animation:blob-float 8s ease-in-out infinite}.blob-2{width:400px;height:400px;background:#10b981;bottom:-100px;right:-100px;animation:blob-float 10s ease-in-out infinite reverse}.blob-3{width:300px;height:300px;background:#6366f1;top:50%;left:50%;transform:translate(-50%,-50%);animation:blob-float 12s ease-in-out infinite 2s}@keyframes blob-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}.auth-card{position:relative;z-index:10;width:100%;max-width:440px;background:var(--surface-color);border:1px solid var(--glass-border);border-radius:28px;padding:2.5rem 2rem;box-shadow:0 30px 80px #00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;gap:1.5rem}.auth-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.auth-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--accent-color),#c99a2e);border-radius:14px;display:flex;align-items:center;justify-content:center;color:#0a0a0b;box-shadow:0 8px 20px #d4af374d;padding:8px;overflow:hidden}.auth-logo-icon img{width:100%;height:100%;object-fit:contain}.auth-logo-text{font-family:var(--font-display);font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-tabs{display:flex;background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:4px;gap:4px}.auth-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);font-family:var(--font-ui);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.auth-tab.active{background:var(--accent-color);color:#0a0a0b}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#fca5a5;padding:.75rem 1rem;border-radius:12px;font-size:.875rem}.auth-form{display:flex;flex-direction:column;gap:1.1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-group input{background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;padding:.85rem 1rem;color:var(--text-primary);font-family:var(--font-ui);font-size:.9rem;outline:none;transition:all .2s;width:100%}.form-group input:focus{border-color:var(--accent-color);background:#d4af370a;box-shadow:0 0 0 3px #d4af371a}.form-group input::placeholder{color:var(--text-secondary);opacity:.5}.input-code{letter-spacing:.18em;font-weight:600;text-transform:uppercase}.form-hint{font-size:.75rem;color:var(--text-secondary);opacity:.7;line-height:1.4}.input-icon-right{position:relative;display:flex;align-items:center}.input-icon-right input{padding-right:2.75rem}.icon-btn{position:absolute;right:.75rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;line-height:1;transition:color .2s}.icon-btn:hover{color:var(--text-primary)}.btn-primary{background:linear-gradient(135deg,var(--accent-color),#c99a2e);border:none;border-radius:12px;padding:.95rem 1.5rem;color:#0a0a0b;font-family:var(--font-ui);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 6px 20px #d4af3740}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #d4af3759}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.btn-full{width:100%}.spinner{width:18px;height:18px;border:2.5px solid rgba(10,10,11,.3);border-top-color:#0a0a0b;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.family-toggle{display:flex;gap:.5rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;padding:4px}.family-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem .75rem;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-family:var(--font-ui);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.family-option.active{background:var(--surface-color);color:var(--text-primary);box-shadow:0 2px 8px #0000004d}.family-badge{display:flex;align-items:center;gap:.5rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:10px;padding:.55rem .85rem;font-size:.75rem;color:var(--text-secondary);margin-bottom:.75rem;overflow:hidden}.family-badge span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;color:var(--text-primary)}.family-code{background:#d4af371f;color:var(--accent-color);border-radius:6px;padding:.1rem .4rem;font-size:.7rem;font-family:monospace;letter-spacing:.06em}.logout-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.35rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.logout-btn:hover{color:var(--danger);background:#ef44441a}.month-carousel-full{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;background:var(--surface-color);border:1px solid var(--glass-border);border-radius:20px;padding:.75rem 1rem}.month-scroll-wrapper{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;flex:1;scroll-behavior:smooth}.month-scroll-wrapper::-webkit-scrollbar{display:none}.month-item{display:flex;flex-direction:column;align-items:center;padding:.6rem 1.1rem;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex-shrink:0;border:1px solid transparent}.month-item:hover{background:var(--glass);border-color:var(--glass-border)}.month-item.active{background:var(--accent-color);border-color:var(--accent-color)}.month-item.active .month-name,.month-item.active .month-year{color:var(--bg-color)}.month-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.month-year{font-size:.7rem;color:var(--text-secondary);margin-top:.1rem}.carousel-btn{background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary);width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.carousel-btn:hover{background:var(--accent-color);border-color:var(--accent-color);color:var(--bg-color)}.transactions-table-wrapper{background:var(--surface-color);border:1px solid var(--glass-border);border-radius:24px;overflow:hidden}.transactions-view .transactions-table-wrapper{border-top:none;border-radius:0 0 24px 24px}.transactions-table{width:100%;border-collapse:collapse}.transactions-table thead tr{border-bottom:1px solid var(--glass-border)}.transactions-table thead th{padding:1.1rem 1.5rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-weight:600;white-space:nowrap}.transaction-row{border-bottom:1px solid var(--glass-border);transition:background .15s}.transaction-row:last-child{border-bottom:none}.transaction-row:hover{background:var(--glass)}.transactions-table td{padding:1rem 1.5rem;vertical-align:middle}.date-cell{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.desc-cell{max-width:320px}.desc-content{display:flex;align-items:center;gap:.75rem}.type-indicator{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.type-indicator.income{background:#10b98126;color:var(--success)}.type-indicator.expense{background:#ef444426;color:var(--danger)}.recurring-indicator{color:var(--accent-color);display:flex;align-items:center;opacity:.7}.cat-cell{white-space:nowrap}.cat-badge{display:inline-block;padding:.25rem .7rem;border-radius:999px;font-size:.75rem;font-weight:500;background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary)}.amount-cell{white-space:nowrap;font-family:var(--font-display);font-weight:600}.amount-content{display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.edit-row-btn{background:var(--glass);border:1px solid var(--glass-border);color:var(--text-secondary);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;opacity:0;flex-shrink:0}.transaction-row:hover .edit-row-btn{opacity:1}.edit-row-btn:hover{background:var(--accent-color);border-color:var(--accent-color);color:var(--bg-color)}.edit-row-btn.dupe:hover{background:#10b98133;border-color:var(--success);color:var(--success)}@media (max-width: 768px){.main-content{padding:1.5rem 1rem}.welcome h1{font-size:1.5rem}.summary-grid{grid-template-columns:1fr;gap:.75rem}.category-grid{grid-template-columns:1fr}.reports-container{flex-direction:column!important;gap:2rem}.reports-sidebar{width:100%!important;margin-top:0}.transactions-summary-bar{grid-template-columns:1fr!important;padding:1rem!important;gap:1rem!important}.transactions-view .view-header{flex-direction:column;align-items:stretch;border-radius:20px 20px 0 0;padding:1.25rem 1rem}.header-actions,.filter-group{flex-direction:column;gap:.75rem}.search-bar,.cat-filter,.add-btn{width:100%!important;height:50px!important}.month-scroll-wrapper{padding:1rem 5%;-webkit-mask-image:none;mask-image:none}.settings-tabs{overflow-x:auto;padding-bottom:5px;justify-content:flex-start;gap:.5rem}.tab-btn{flex:0 0 auto;padding:.75rem 1rem}.modal-content{width:95%!important;padding:1.5rem!important;max-height:90vh;overflow-y:auto}.modal-actions{flex-direction:column;gap:.75rem}.modal-actions button{width:100%;height:50px}.icon-selector-grid{grid-template-columns:repeat(4,1fr)!important}}body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}@media (max-width: 768px){.evolution-chart .chart-bars{flex-direction:column!important;height:auto!important;gap:0!important;align-items:stretch!important}.evolution-chart .chart-column{flex-direction:row!important;justify-content:space-between!important;align-items:center!important;padding:.875rem 0!important;border-bottom:1px solid var(--glass-border)!important;gap:1rem!important;width:100%!important}.evolution-chart .chart-column:last-child{border-bottom:none!important}.evolution-chart .month-label{font-size:.85rem!important;font-weight:500!important;color:var(--text-primary)!important;width:100px!important;text-align:left!important}.evolution-chart .bar-wrapper{flex:1!important;height:6px!important;width:auto!important;background:var(--glass)!important;border-radius:10px!important}.evolution-chart .bar{width:var(--progress)!important;height:100%!important;border-radius:10px!important}.evolution-chart .month-value{display:block!important;font-size:.85rem!important;font-weight:600!important;color:var(--text-primary)!important;min-width:80px!important;text-align:right!important}}@media (min-width: 769px){.evolution-chart .bar{height:var(--progress)!important}.evolution-chart .chart-column{flex-direction:column-reverse!important}}.category-icon-small{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.desc-main{display:flex;flex-direction:column;gap:2px}.desc-text{font-weight:500;color:var(--text-primary)}.mobile-only-amount{display:none;font-size:.85rem;font-weight:600}@media (max-width: 768px){.transactions-table thead{display:none}.date-cell,.cat-cell,.amount-cell{display:none!important}.mobile-only-amount{display:block}.transaction-row{display:block;padding:.75rem .5rem;border-bottom:1px solid var(--glass-border)}.desc-cell{display:block;width:100%!important;padding:0!important}.desc-content{gap:1rem!important}}.profile-edit-card,.family-info-card{background:var(--surface-color);border:1px solid var(--glass-border);padding:2rem;border-radius:24px;margin-top:1rem}.profile-photo-section{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--glass-border)}.profile-photo-wrapper{position:relative;width:100px;height:100px}.profile-placeholder,.profile-img{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;background:var(--glass);color:var(--accent-color);border:2px solid var(--accent-color);object-fit:cover}.change-photo-btn{position:absolute;bottom:0;right:0;width:32px;height:32px;border-radius:50%;background:var(--accent-color);color:var(--bg-color);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 10px #0000004d;transition:all .2s}.change-photo-btn:hover{transform:scale(1.1)}.profile-meta h4{font-size:1.25rem;margin-bottom:.25rem}.profile-meta p{color:var(--text-secondary);font-size:.9rem}.form-actions{display:flex;align-items:center;gap:1.5rem;margin-top:2rem}.success-message{display:flex;align-items:center;gap:.5rem;color:var(--success);font-size:.9rem;font-weight:500}.input-with-action{display:flex;gap:.5rem}.input-with-action input{flex:1}.action-edit-btn,.action-save-btn{width:46px;height:46px;border-radius:12px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.action-edit-btn:hover{background:var(--surface-color);border-color:var(--accent-color);color:var(--accent-color)}.action-save-btn{background:var(--accent-color);color:var(--bg-color);border-color:var(--accent-color)}.modal-footer-info{display:flex;flex-direction:column;gap:.5rem;flex:1}.audit-info{font-size:.75rem;color:var(--text-secondary);opacity:.8}.audit-info strong{color:var(--accent-color)}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.animate-spin{animation:spin 1s linear infinite}.stat-detail{font-size:.75rem;color:var(--text-secondary);opacity:.7;margin-top:2px}.confirmed-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:100px;background:#10b9811a;color:#10b981;margin-left:8px}.pending-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:100px;background:#ffffff0d;color:var(--text-secondary);margin-left:8px}.category-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.75rem;max-height:240px;overflow-y:auto;padding:.5rem;background:#0003;border-radius:12px;border:1px solid var(--glass-border)}.category-tag{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1rem .5rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);color:var(--text-muted)}.category-tag:hover{background:#ffffff0d;border-color:var(--text-muted);transform:translateY(-2px)}.category-tag.active{background:var(--selector-bg);border-color:var(--selector-color);color:var(--text-primary);box-shadow:0 4px 12px var(--selector-shadow)}.category-tag-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}.category-tag.active .category-tag-icon{background:var(--selector-color)!important;color:#000!important}.category-tag-name{font-size:.75rem;font-weight:600;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.confirm-modal-content{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;width:100%;max-width:400px;padding:1.5rem;position:relative;box-shadow:0 20px 40px #0006}.confirm-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.confirm-icon-wrapper{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center}.confirm-icon-wrapper.danger{background:#ef44441a}.confirm-icon-wrapper.warning{background:#f59e0b1a}.confirm-icon-wrapper.success{background:#10b9811a}.confirm-icon-wrapper.info{background:#d4af371a}.confirm-close-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.confirm-close-btn:hover{background:#ffffff0d;color:var(--text-primary)}.confirm-modal-body{margin-bottom:2rem}.confirm-modal-body h3{font-size:1.35rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.confirm-modal-body p{color:var(--text-secondary);line-height:1.5}.confirm-modal-footer{display:flex;gap:1rem;justify-content:flex-end}.confirm-action-btn{padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;border:none;transition:all .2s;font-size:.94rem}.cancel-btn-outline{padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;background:transparent;border:1px solid var(--glass-border);color:var(--text-secondary);transition:all .2s;font-size:.94rem}.cancel-btn-outline:hover{background:#ffffff0d;border-color:var(--text-muted)}.confirm-btn-danger{background:var(--danger);color:#fff}.confirm-btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.confirm-btn-success{background:var(--success);color:#fff}.confirm-btn-success:hover{background:#059669;transform:translateY(-1px)}.confirm-btn-warning{background:var(--warning);color:#000}.confirm-btn-warning:hover{background:#d97706;transform:translateY(-1px)}.confirm-btn-info{background:var(--accent-color);color:var(--bg-color)}.confirm-btn-info:hover{background:var(--gold-light);transform:translateY(-1px)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.profile-photo-section{flex-direction:column;text-align:center;gap:1rem}.form-actions{flex-direction:column;align-items:stretch;gap:1rem}.success-message{justify-content:center}.modal-content{padding:1.5rem!important;max-height:92vh!important;width:92%!important;border-radius:20px!important}.modal-header{margin-bottom:1.5rem!important}.modal-header h3{font-size:1.25rem!important}.type-selector{margin-bottom:1.5rem!important}.category-selector-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))!important;max-height:160px!important;gap:.5rem!important}.category-tag{padding:.75rem .4rem!important}.category-tag-icon{width:28px!important;height:28px!important}.modal-footer{flex-direction:column-reverse!important;align-items:stretch!important;gap:.75rem!important;margin-top:1.5rem!important}.modal-footer button{width:100%!important;justify-content:center!important}.modal-footer-info{align-items:center!important;text-align:center!important}}.pwa-install-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:400px;background:#161618f2;backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px);border:1px solid rgba(212,175,55,.3);border-radius:24px;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:2rem;z-index:10000;box-shadow:0 20px 50px #000c,0 0 0 1000px #0009}.pwa-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.pwa-icon{width:72px;height:72px;background:var(--accent-gradient);border-radius:18px;padding:14px;flex-shrink:0;box-shadow:0 8px 25px #d4af3733}.pwa-icon img{width:100%;height:100%;object-fit:contain}.pwa-text h4{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);font-family:Outfit,sans-serif}.pwa-text p{margin:8px 0 0;font-size:.95rem;line-height:1.6;color:var(--text-secondary)}.pwa-actions{display:flex;flex-direction:column;align-items:center;width:100%;gap:1rem}.install-btn{background:var(--accent-color);color:var(--bg-color);border:none;width:100%;padding:.9rem 1.5rem;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:all .2s}.install-btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px #d4af3766}.ios-instructions{width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--gold);font-size:.9rem;background:#d4af371a;padding:1rem;border-radius:12px;border:1px solid rgba(212,175,55,.2)}.close-btn{position:absolute;top:1.25rem;right:1.25rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-btn:hover{color:var(--text-primary)}@media (max-width: 600px){.pwa-install-banner{width:88%;padding:2rem 1.5rem}.pwa-text h4{font-size:1.3rem}}
