.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:var(--bg-card);border-radius:1rem;padding:2.5rem;width:100%;max-width:450px;box-shadow:var(--shadow-lg)}.auth-card.register-card{max-width:800px}.auth-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:.5rem;color:var(--primary)}.auth-subtitle{text-align:center;color:var(--text-light);margin-bottom:2rem}.auth-form{margin-bottom:1.5rem}.auth-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin-bottom:1rem}.auth-form-grid .form-group{margin-bottom:0}.auth-form-grid .form-group.full-width{grid-column:1 / -1}@media (max-width: 768px){.auth-form-grid{grid-template-columns:1fr;gap:1rem}.auth-form-grid .form-group{margin-bottom:1rem}}.auth-footer{text-align:center;color:var(--text-light)}.auth-footer a{color:var(--primary);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.auth-footer .link-button,.forgot-password-link{background:none;border:none;color:var(--primary);cursor:pointer;font-size:inherit;font-weight:500;padding:0;text-decoration:none}.auth-footer .link-button:hover,.forgot-password-link:hover{text-decoration:underline}.auth-success-msg{color:var(--success, #059669);font-size:.9rem;margin-bottom:1rem;text-align:center}.password-input-wrapper{position:relative;width:100%}.password-input-wrapper .input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--text-light);transition:color .2s}.password-toggle:hover{color:var(--text)}.password-toggle:focus{outline:none;color:var(--primary)}@media (max-width: 768px){.auth-card{padding:2rem 1.5rem}.auth-title{font-size:1.75rem}}.dashboard-container{width:100%;max-width:1400px;margin:0 auto;padding:2rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title{color:#000;font-size:28px;font-weight:700;margin:0}.page-title{font-size:2.5rem;font-weight:700;color:#000;margin:0}.btn-refresh{background:#6366f1;color:#fff;border:none;padding:10px 15px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s}.btn-refresh svg{width:20px;height:20px}.btn-refresh:hover{background:#4f46e5}.dashboard-filters{background:var(--bg-card);border-radius:1rem;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border);display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:200px}.filter-group-dates{flex-direction:row;gap:1rem;flex:2}.filter-date-group{display:flex;flex-direction:column;gap:.5rem;flex:1}.filter-label{font-size:.875rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.filter-options{display:flex;gap:.5rem}.filter-btn{flex:1;padding:.625rem 1rem;border:2px solid var(--border);border-radius:.5rem;background:#fff;color:var(--text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.filter-btn:hover{border-color:var(--primary);background:var(--bg)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-btn svg{width:20px;height:20px;flex-shrink:0}.filter-input{padding:.625rem 1rem;border:2px solid var(--border);border-radius:.5rem;font-size:.875rem;transition:all .2s;background:#fff;color:var(--text)}.filter-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}@media (max-width: 768px){.dashboard-filters{flex-direction:column;gap:1rem}.filter-group{min-width:100%}.filter-group-dates{flex-direction:column}.filter-date-group{width:100%}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .3s ease;border:1px solid var(--border);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--secondary));opacity:0;transition:opacity .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px #0000001a}.stat-card:hover:before{opacity:1}.stat-card-expense:before{background:linear-gradient(90deg,#ef4444,#f87171)}.stat-card-income:before{background:linear-gradient(90deg,#10b981,#34d399)}.stat-card-balance:before{background:linear-gradient(90deg,#6366f1,#8b5cf6)}.stat-card-month:before{background:linear-gradient(90deg,#6366f1,#8b5cf6)}.stat-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.stat-icon-wrapper{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:transform .3s}.stat-card:hover .stat-icon-wrapper{transform:scale(1.1)}.stat-icon{font-size:2rem;display:flex;align-items:center;justify-content:center}.calendar-icon{color:#6366f1}.calendar-icon svg{width:100%;height:100%}.chart-icon{color:inherit}.chart-icon svg{width:100%;height:100%}.chart-icon-expense svg{color:#ef4444}.chart-icon-income svg{color:#10b981}.money-icon{color:inherit}.money-icon svg{width:100%;height:100%}.stat-trend{font-size:1.5rem;font-weight:700;opacity:.7}.stat-content{flex:1}.stat-label{color:var(--text-light);font-size:.875rem;font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:var(--text);margin-bottom:.25rem;line-height:1.2}.stat-sublabel{color:var(--text-light);font-size:.75rem;margin-top:.5rem}.stat-month-values{display:flex;flex-direction:column;gap:.75rem}.stat-month-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border)}.stat-month-item:last-child{border-bottom:none}.stat-month-item.stat-month-balance{padding-top:.75rem;margin-top:.5rem;border-top:2px solid var(--border);font-weight:600}.stat-month-label{color:var(--text-light);font-size:.875rem}.stat-month-value{font-size:1.125rem;font-weight:600}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--bg-card);border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border);transition:all .3s ease}.chart-card:hover{box-shadow:0 10px 25px #0000001a}.chart-card-full{grid-column:1 / -1}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border)}.chart-title{font-size:1.25rem;font-weight:600;color:var(--text);margin:0}.chart-subtitle{font-size:.875rem;color:var(--text-light);background:var(--bg);padding:.25rem .75rem;border-radius:1rem}.pie-chart-container{position:relative;margin:1rem 0}.chart-legend{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid var(--border);display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.chart-legend::-webkit-scrollbar{width:6px}.chart-legend::-webkit-scrollbar-track{background:var(--bg);border-radius:3px}.chart-legend::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.chart-legend::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.legend-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border-radius:.75rem;transition:all .2s;border:1px solid transparent;background:var(--bg)}.legend-item:hover{background:#fff;border-color:var(--border);transform:translate(4px);box-shadow:0 2px 8px #0000000d}.legend-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.legend-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.legend-color{width:20px;height:20px;border-radius:6px;flex-shrink:0;box-shadow:0 2px 4px #0000001a;border:2px solid white}.legend-label{font-size:.9375rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-percentage{font-size:.75rem;font-weight:700;color:var(--primary);background:#6366f11a;padding:.125rem .5rem;border-radius:1rem;white-space:nowrap}.legend-value{font-size:.875rem;font-weight:600;color:var(--text);white-space:nowrap}.empty-state{text-align:center;padding:4rem 2rem;background:var(--bg-card);border-radius:1rem;border:2px dashed var(--border)}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state-text{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.empty-state-subtext{color:var(--text-light);font-size:.875rem}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-container{padding:1rem}.page-title{font-size:1.75rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1.25rem}.stat-icon-wrapper{width:50px;height:50px}.stat-icon,.stat-value{font-size:1.5rem}.chart-card{padding:1rem}.chart-title{font-size:1.125rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;animation:fadeIn .2s}.modal{background:var(--bg-card);border-radius:.75rem;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:visible;overflow-x:hidden;animation:slideUp .3s;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.modal-body{overflow-y:visible;overflow-x:hidden;flex:1}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:1.5rem;font-weight:600;color:var(--text)}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--text-light);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.close-btn:hover{color:var(--text);background:var(--bg)}@media (max-width: 768px){.modal{padding:1.5rem}.modal-title{font-size:1.25rem}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:28rem;width:90%;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out;display:flex;flex-direction:column}@keyframes slideUp{0%{transform:translateY(1rem);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal-header{padding:1.5rem 1.5rem 1rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid #e5e7eb}.confirm-modal-icon{font-size:2rem;display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.75rem;background:#f3f4f6;flex-shrink:0}.confirm-modal-title{font-size:1.25rem;font-weight:600;color:#111827;margin:0;flex:1}.confirm-modal-body{padding:1.5rem;flex:1;overflow-y:auto}.confirm-modal-message{font-size:.9375rem;line-height:1.6;color:#4b5563;margin:0;white-space:pre-line}.confirm-modal-actions{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid #e5e7eb}.confirm-modal-btn{padding:.625rem 1.25rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;min-width:6rem}.confirm-modal-btn-cancel{background:#f3f4f6;color:#374151}.confirm-modal-btn-cancel:hover{background:#e5e7eb;color:#111827}.confirm-modal-btn-confirm{color:#fff}.confirm-modal-btn-default{background:#6366f1}.confirm-modal-btn-default:hover{background:#4f46e5}.confirm-modal-btn-danger{background:#ef4444}.confirm-modal-btn-danger:hover{background:#dc2626}.confirm-modal-btn-warning{background:#f59e0b}.confirm-modal-btn-warning:hover{background:#d97706}.confirm-modal-btn-info{background:#3b82f6}.confirm-modal-btn-info:hover{background:#2563eb}.confirm-modal-btn-success{background:#10b981}.confirm-modal-btn-success:hover{background:#059669}@media (max-width: 640px){.confirm-modal{max-width:95%;margin:1rem}.confirm-modal-header{padding:1.25rem 1.25rem .75rem}.confirm-modal-icon{width:2.5rem;height:2.5rem;font-size:1.5rem}.confirm-modal-title{font-size:1.125rem}.confirm-modal-body{padding:1.25rem}.confirm-modal-actions{padding:.75rem 1.25rem 1.25rem;flex-direction:column-reverse}.confirm-modal-btn{width:100%}}.expenses-page{width:100%;margin:0;padding:0}.expenses-header{background:linear-gradient(135deg,#1e293b,#334155);padding:2rem;border-radius:.75rem .75rem 0 0;margin-bottom:0}.expenses-header-content{max-width:100%;margin:0 auto;padding:0 1rem}.expenses-title-section{display:flex;align-items:center;gap:1rem}.expenses-icon{font-size:3rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);width:4rem;height:4rem;border-radius:1rem;display:flex;align-items:center;justify-content:center}.expenses-title{font-size:2rem;font-weight:700;color:#fff;margin:0}.expenses-action-bar{padding:2.5rem 0!important;border-bottom:1px solid var(--border);box-sizing:border-box}.action-bar-content{background:#fff;max-width:100%;margin:0 auto;padding:2.5rem 3rem!important;display:flex;justify-content:flex-end;align-items:center;gap:2rem!important;flex-wrap:wrap;box-sizing:border-box;border-radius:.5rem .5rem 0 0;min-height:110px!important}.action-bar-actions{display:flex;gap:1.25rem!important;align-items:center;flex-wrap:wrap}.expenses-action-bar .action-bar-actions .btn,.expenses-action-bar .action-bar-content .btn,.action-bar-actions .btn,.action-bar-content .btn{padding:1rem 2rem!important;font-size:1.125rem!important;min-height:56px!important;gap:1rem!important;font-weight:600!important;line-height:1.5!important}.expenses-action-bar .action-bar-actions .btn svg,.expenses-action-bar .action-bar-content .btn svg,.action-bar-actions .btn svg,.action-bar-content .btn svg{width:24px!important;height:24px!important;flex-shrink:0!important}.btn-filter{background:#3b82f6;color:#fff;border:none;padding:1rem 2rem!important;border-radius:.5rem;display:flex;align-items:center;gap:1rem!important;font-size:1.125rem!important;cursor:pointer;transition:all .2s;font-weight:600!important;min-height:56px!important;line-height:1.5!important}.btn-filter svg{width:24px!important;height:24px!important}.btn-group{background:#f59e0b;color:#fff;border:none;padding:1rem 2rem!important;border-radius:.5rem;display:flex;align-items:center;gap:1rem!important;font-size:1.125rem!important;cursor:pointer;transition:all .2s;font-weight:600!important;min-height:56px!important;line-height:1.5!important}.btn-group svg{width:24px!important;height:24px!important}.btn-group:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 2px 4px #f59e0b4d}.btn-import{background-color:#10b981;color:#fff;border:none;padding:1rem 2rem!important;border-radius:.5rem;font-weight:600!important;font-size:1.125rem!important;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:1rem!important;min-height:56px!important;line-height:1.5!important}.btn-import svg{width:24px!important;height:24px!important}.btn-import:hover{background-color:#059669;transform:translateY(-1px)}.btn-export{background:#06b6d4;color:#fff;border:none;padding:1rem 2rem!important;border-radius:.5rem;display:flex;align-items:center;gap:1rem!important;font-size:1.125rem!important;cursor:pointer;transition:all .2s;font-weight:600!important;min-height:56px!important;line-height:1.5!important}.btn-export svg{width:24px!important;height:24px!important}.btn-export:hover{background:#0891b2;transform:translateY(-1px);box-shadow:0 2px 4px #06b6d44d}.btn-add{background:#ec4899;color:#fff;border:none;padding:1rem 2rem!important;border-radius:.5rem;font-size:1.125rem!important;font-weight:600!important;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:1rem!important;min-height:56px!important;line-height:1.5!important}.btn-add:hover{background:#db2777;transform:scale(1.05)}.btn-expense{background:#ef4444}.btn-expense:hover{background:#dc2626}.btn-income{background:#10b981}.btn-income:hover{background:#059669}.month-selector{display:flex;align-items:center;gap:.5rem}.month-selector .month-input{min-width:200px}.month-input{padding:1rem 1.5rem!important;border:1px solid var(--border);border-radius:.5rem;font-size:1.125rem!important;background:#fff;cursor:pointer;min-height:56px!important;font-weight:600!important;min-width:220px!important}.filters-panel{margin:1rem auto 0;max-width:100%;padding:1.5rem;box-sizing:border-box}.form-group-full{grid-column:1 / -1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.expenses-table-container{background:var(--bg-card);border-radius:0 0 .75rem .75rem;padding:1rem;margin:0 auto 2rem;max-width:100%;box-sizing:border-box;box-shadow:var(--shadow);overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--primary) var(--bg);position:relative;scroll-behavior:smooth;overscroll-behavior-x:contain}.expenses-table-container:after{content:"";position:absolute;top:0;right:0;bottom:0;width:20px;background:linear-gradient(to right,transparent,rgba(0,0,0,.05));pointer-events:none;opacity:0;transition:opacity .3s}.expenses-table-container.scrollable:after{opacity:1}@media (max-width: 768px){.expenses-table-container{position:relative}.expenses-table-container:before{content:"";position:absolute;left:0;top:0;bottom:0;width:15px;background:linear-gradient(to right,rgba(99,102,241,.1),transparent);pointer-events:none;z-index:1;opacity:0;transition:opacity .3s}.expenses-table-container:after{content:"";position:absolute;right:0;top:0;bottom:0;width:15px;background:linear-gradient(to left,rgba(99,102,241,.1),transparent);pointer-events:none;z-index:1;opacity:1;transition:opacity .3s}.expenses-table-container.scrolled-left:before{opacity:1}.expenses-table-container.scrolled-right:after{opacity:0}}.expenses-table-container::-webkit-scrollbar{height:8px}.expenses-table-container::-webkit-scrollbar-track{background:var(--bg);border-radius:4px}.expenses-table-container::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}.expenses-table-container::-webkit-scrollbar-thumb:hover{background:#4f46e5}@media (max-width: 768px){.expenses-table-container::-webkit-scrollbar{height:6px}.expenses-table-container::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px}.expenses-table-container::-webkit-scrollbar-thumb:active{background:#4f46e5}}@media (max-width: 480px){.expenses-table-container::-webkit-scrollbar{height:4px}}.expenses-cards-container{display:none;padding:.5rem}.expense-card{background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;transition:all .2s}.expense-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.expense-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.expense-card-title{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.expense-card-icon{font-size:1.5rem;flex-shrink:0}.expense-card-description{font-weight:600;font-size:1rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.expense-card-amount{font-size:1.25rem;font-weight:700;flex-shrink:0;margin-left:.5rem}.expense-card-body{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.expense-card-field{display:flex;flex-direction:column;gap:.25rem}.expense-card-label{font-size:.75rem;color:var(--text-light);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.expense-card-value{font-size:.875rem;color:var(--text);font-weight:500;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.expense-card-field.full-width{grid-column:1 / -1}.expense-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border);gap:.5rem}.expense-card-balance{display:flex;flex-direction:column;gap:.25rem;flex:1}.expense-card-actions{display:flex;gap:.5rem;flex-shrink:0;align-items:center}.expense-card-actions .btn-small{display:flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:.5rem}@media (max-width: 768px){.expenses-table-container{padding:0;margin:0 .5rem 1.5rem;overflow-x:visible}.expenses-table{display:none}.expenses-cards-container{display:block}.expense-card{padding:.875rem}.expense-card-header{flex-direction:column;gap:.5rem}.expense-card-title{width:100%}.expense-card-amount{margin-left:0;align-self:flex-end}.expense-card-body{grid-template-columns:1fr;gap:.5rem}.expense-card-footer{flex-direction:row;align-items:center;gap:.5rem}.expense-card-balance{flex:1}.expense-card-actions{flex-shrink:0}.expense-card-actions .btn-small{min-width:2.25rem;height:2.25rem}}@media (min-width: 769px){.expenses-cards-container{display:none}}@media (max-width: 480px){.expenses-table-container{margin:0 .25rem 1rem}.expense-card{padding:.75rem}.expense-card-description{font-size:.9rem}.expense-card-amount{font-size:1.1rem}.expense-card-label{font-size:.7rem}.expense-card-value{font-size:.8rem}.expense-card-actions .btn-small{min-width:2rem;height:2rem;padding:.4rem}.expense-card-footer{flex-direction:column;gap:.5rem}.expense-card-actions{width:100%;justify-content:center}}@media (max-width: 480px){.expenses-table-container{margin:0 .25rem 1rem}}.expenses-table{width:100%;min-width:100%;border-collapse:collapse;table-layout:fixed}@media (max-width: 1400px){.expenses-table{min-width:auto}}@media (min-width: 1400px){.expenses-table{min-width:1400px}}.expenses-table thead{background:var(--bg)}.expenses-table th{padding:.75rem .5rem;text-align:left;font-weight:600;color:var(--text);border-bottom:2px solid var(--border);font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 1200px){.expenses-table th{font-size:.75rem;letter-spacing:.25px}}@media (max-width: 768px){.expenses-table th{font-size:.6875rem;letter-spacing:0;padding:.5rem .25rem}}@media (max-width: 480px){.expenses-table th{font-size:.625rem;padding:.375rem .25rem}}.table-header-cell{display:flex;align-items:center;gap:.5rem;min-width:0;overflow:hidden}.table-header-cell span{font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.table-header-cell svg{width:18px;height:18px;flex-shrink:0;color:var(--text-light);transition:color .2s}.table-header-cell.sortable:hover svg{color:var(--primary)}.table-header-cell.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s;padding:.25rem;margin:-.25rem;border-radius:.25rem}.table-header-cell.sortable:hover{background-color:#6366f11a}.sort-icon{margin-left:auto;font-size:.875rem;color:var(--primary);font-weight:700}.expense-row{border-bottom:1px solid var(--border);transition:background-color .2s}.expense-row:hover{background-color:var(--bg)}.expense-row td{padding:.75rem .5rem;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:0;word-wrap:break-word;box-sizing:border-box}@media (max-width: 1200px){.expense-row td{padding:.5rem .375rem;font-size:.8125rem}.expenses-table th{padding:.5rem .375rem;font-size:.75rem}}@media (max-width: 768px){.expense-row td{padding:.5rem .25rem;font-size:.75rem}.expenses-table th{padding:.5rem .25rem;font-size:.6875rem}.expense-description-text{max-width:150px;overflow:hidden;text-overflow:ellipsis}.category-badge{font-size:.75rem;padding:.25rem .5rem}.expense-amount-cell{font-size:.875rem}.expense-balance-cell{font-size:.875rem;padding:.125rem .375rem}.btn-icon{min-width:1.75rem;height:1.75rem;padding:.375rem}.btn-icon svg{width:16px;height:16px}}.expense-description-cell{display:flex;align-items:center;gap:.75rem;min-width:0;overflow:hidden}.expense-item-icon{font-size:1.25rem}.expense-description-text{font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.expense-category-cell,.expense-account-cell{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;min-width:0;overflow:hidden}.category-badge-container{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start}.parent-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500}.subcategory-badge{margin-left:0}.category-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.account-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500;color:#fff;opacity:.9;margin-left:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.category-badge-icon{font-size:1rem}@media (max-width: 768px){.category-badge-icon{font-size:.85rem}.category-badge-name{font-size:.65rem}.parent-badge{font-size:.7rem;padding:.25rem .5rem}.subcategory-badge{font-size:.65rem;padding:.2rem .4rem}}@media (max-width: 480px){.category-badge-icon{font-size:.75rem}.category-badge-name{font-size:.6rem}.parent-badge{font-size:.65rem;padding:.2rem .4rem}.subcategory-badge{font-size:.6rem;padding:.15rem .3rem}}.category-badge-name{white-space:nowrap}.category-badge.no-category{background:var(--bg);color:var(--text-light);border:1px solid var(--border)}.expense-date-cell{color:var(--text);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.expense-amount-cell{font-weight:700;color:var(--primary);font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.amount-expense{color:#ef4444}.amount-income{color:#10b981}.expense-balance-cell{font-weight:700;font-size:1rem;padding:.25rem .5rem;border-radius:.25rem;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.balance-positive{color:#10b981;background:#d1fae5}.balance-negative{color:#ef4444;background:#fee2e2}.group-header-row{background:#f8fafc;border-top:2px solid #e2e8f0;border-bottom:2px solid #e2e8f0;font-weight:600}.group-header{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.group-toggle-btn{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .2s;color:var(--text)}.group-toggle-btn:hover{background:#e2e8f0}.group-toggle-icon{font-size:.75rem;display:inline-block;transition:transform .2s}.group-info{display:flex;align-items:center;gap:.5rem;flex:1}.group-name{color:var(--text);font-weight:600}.group-parent{color:#64748b;font-weight:500}.group-count{color:#64748b;font-size:.875rem;font-weight:400}.group-total-cell{text-align:right}.group-totals{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.group-income{color:#10b981;font-size:.875rem;font-weight:600}.group-expense{color:#ef4444;font-size:.875rem;font-weight:600}.group-total-amount{font-weight:700;font-size:1rem;color:var(--text)}.expense-row-grouped{background:#fafbfc}.expense-row-grouped:hover{background:#f1f5f9}.category-icon{font-size:1.25rem}.expense-type-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;margin-left:.5rem}.expense-badge{background:#fee2e2;color:#991b1b}.income-badge{background:#d1fae5;color:#065f46}.expense-actions{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:nowrap;min-width:0;overflow:visible}.expense-row-actions{display:flex;gap:.5rem;flex-wrap:wrap}.recurrence-badge{font-size:.875rem;opacity:.7;cursor:help;display:inline-flex;align-items:center;flex-shrink:0;color:var(--primary)}.recurrence-badge svg{width:16px;height:16px}.checkbox-label{font-weight:500;color:var(--text);-webkit-user-select:none;user-select:none}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.expenses-totals{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;background:var(--bg);border-radius:.5rem;margin-bottom:1rem;flex-wrap:wrap;gap:1rem;box-sizing:border-box}.total-item{display:flex;flex-direction:column;gap:.25rem}.total-label{font-size:.875rem;color:var(--text-light);font-weight:500}.total-value{font-size:1.125rem;font-weight:700;color:var(--primary)}.total-expense{color:#ef4444}.total-income,.total-positive{color:#10b981}.total-negative{color:#ef4444}.pagination button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.expenses-totals{flex-direction:column;align-items:stretch;padding:.75rem;gap:.75rem}.total-item{flex-direction:row;justify-content:space-between;padding:.5rem 0}.total-label{font-size:.8rem}.total-value{font-size:1rem}.pagination-controls{flex-direction:column;gap:.75rem}.pagination-pages{flex-wrap:wrap;justify-content:center;gap:.25rem}.pagination-info{font-size:.8rem}}@media (max-width: 480px){.expenses-totals{padding:.5rem;gap:.5rem}.total-item{padding:.4rem 0}.total-label{font-size:.75rem}.total-value{font-size:.9rem}.items-per-page-select{font-size:.8rem;padding:.4rem}.pagination-info{font-size:.75rem}}.input-wrapper{position:relative;display:flex;align-items:center;width:100%}.input-prefix{position:absolute;left:.75rem;color:var(--text-light);font-weight:500;z-index:10;pointer-events:none;-webkit-user-select:none;user-select:none;background:#fff;padding-right:.25rem}.input-with-prefix{padding-left:2.75rem!important;width:100%;text-align:left}.input-date{padding-right:2.5rem}.input-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none;display:flex;align-items:center;justify-content:center;color:var(--text-light)}.input-icon svg{width:20px;height:20px;flex-shrink:0}.input-wrapper-with-add{position:relative;display:flex;align-items:center;width:100%}.input-with-add-icon{padding-right:2.75rem!important;width:100%}.input-add-icon{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:#6366f1;transition:all .2s;z-index:10;border-radius:.25rem}.input-add-icon:hover{color:#4f46e5;background-color:#6366f11a;transform:translateY(-50%) scale(1.1)}.input-add-icon:active{transform:translateY(-50%) scale(.95)}.input-add-icon svg{width:20px;height:20px;flex-shrink:0}.input-add-icon-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:.375rem;cursor:pointer;padding:.375rem;display:flex;align-items:center;justify-content:center;color:#6366f1;transition:all .2s;z-index:10;width:2rem;height:2rem}.input-add-icon-btn:hover{color:#4f46e5;background-color:#6366f126;border-color:#6366f14d;transform:translateY(-50%) scale(1.05)}.input-add-icon-btn:active{transform:translateY(-50%) scale(.95);background-color:#6366f133}.input-add-icon-btn svg{width:16px;height:16px;flex-shrink:0}.category-select-wrapper{display:flex;flex-direction:column;gap:0}.category-search-container{position:relative;display:flex;flex-direction:column}.category-search-container .input-add-icon-btn{z-index:1002}.category-search-input{width:100%;padding-right:2.75rem}.category-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-top:none;border-radius:0 0 .5rem .5rem;max-height:250px;overflow-y:auto;overflow-x:hidden;z-index:1001;box-shadow:var(--shadow-lg);margin-top:-1px;scrollbar-width:thin;scrollbar-color:var(--primary) var(--bg)}.category-dropdown::-webkit-scrollbar{width:6px}.category-dropdown::-webkit-scrollbar-track{background:var(--bg);border-radius:3px}.category-dropdown::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px}.category-dropdown::-webkit-scrollbar-thumb:hover{background:#4f46e5}.category-dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:all .2s;border-bottom:1px solid var(--border);position:relative}.category-dropdown-item:last-child{border-bottom:none}.category-dropdown-item:hover{background-color:var(--bg)}.category-dropdown-item.selected{background-color:#6366f11a;font-weight:600;color:var(--primary)}.category-dropdown-item.disabled{color:var(--text-light);cursor:not-allowed;font-style:italic}.category-dropdown-item.disabled:hover{background-color:var(--bg-card)}.category-dropdown-item.subcategory{padding-left:2.5rem;position:relative}.category-dropdown-item.subcategory:before{content:"";position:absolute;left:1rem;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,var(--primary) 10%,var(--primary) 90%,transparent);opacity:.3}.category-dropdown-item.subcategory:after{content:"└";position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--primary);opacity:.5;font-size:1.1rem;line-height:1;font-weight:400}@media (max-width: 768px){.expenses-header{padding:1.5rem 1rem}.expenses-title{font-size:1.5rem}.expenses-icon{width:3rem;height:3rem;font-size:2rem}.expenses-action-bar{padding:1rem 0}.action-bar-content{padding:0 1rem;flex-direction:column;align-items:stretch}.action-bar-actions{width:100%;justify-content:space-between}.expenses-table-container{margin:0 .5rem 1.5rem;padding:.5rem}.filters-panel{margin:1rem;padding:1rem}}@media (max-width: 480px){.expenses-table{min-width:650px;font-size:.65rem}.expenses-table th,.expenses-table td{padding:.3rem .15rem}.expense-description-cell{gap:.3rem;max-width:130px}.expense-item-icon{font-size:.9rem}.expense-item-icon svg{width:14px;height:14px}.expense-description-text{max-width:100px;font-size:.65rem}.category-badge,.account-badge{font-size:.6rem;padding:.15rem .3rem}.expense-amount-cell{font-size:.7rem}.expense-balance-cell{font-size:.7rem;padding:.1rem .25rem}.expense-date-cell{font-size:.65rem}.table-header-cell{gap:.15rem}.table-header-cell svg{width:10px;height:10px}.table-header-cell span{font-size:.65rem}.btn-icon{min-width:1.25rem;height:1.25rem;padding:.25rem}.btn-icon svg{width:12px;height:12px}.expense-actions{gap:.2rem}.expenses-table-container{margin:0 .15rem .75rem;padding:.15rem}.expenses-table-container::-webkit-scrollbar{height:3px}}@media (max-width: 360px){.expenses-table{min-width:600px;font-size:.6rem}.expenses-table th,.expenses-table td{padding:.25rem .1rem}.expense-description-cell{gap:.25rem;max-width:100px}.expense-item-icon{font-size:.85rem}.expense-item-icon svg{width:12px;height:12px}.expense-description-text{max-width:80px;font-size:.6rem}.category-badge,.account-badge{font-size:.55rem;padding:.1rem .25rem}.expense-amount-cell,.expense-balance-cell,.expense-date-cell{font-size:.65rem}.table-header-cell span{font-size:.6rem}.table-header-cell svg{width:9px;height:9px}.btn-icon{min-width:1.1rem;height:1.1rem;padding:.2rem}.btn-icon svg{width:10px;height:10px}.expenses-table-container{margin:0 .1rem .5rem;padding:.1rem}.expenses-table td[style*="minWidth: '80px'"],.expenses-table td[style*="minWidth: '120px'"]{padding:.2rem .1rem!important}.expenses-table td[style*="fontSize: '1.5rem'"] span{font-size:1rem!important}}@media (max-width: 768px){.expenses-table th,.expenses-table td{touch-action:manipulation}.btn-icon,.table-header-cell.sortable{min-height:44px;min-width:44px}.expense-row td[title="Duplo clique para editar"]{min-height:44px;display:flex;align-items:center}.expenses-table td[style*="minWidth: '80px'"],.expenses-table td[style*="minWidth: '120px'"]{min-width:auto!important;padding:.3rem .2rem!important}.expenses-table td[style*="fontSize: '0.875rem'"]{font-size:.7rem!important}.expenses-table td[style*="fontSize: '1.5rem'"] span{font-size:1.1rem!important}.group-header-row,.group-name{font-size:.7rem}.group-count{font-size:.65rem}.group-income,.group-expense{font-size:.7rem}.group-total-amount{font-size:.8rem}}.expenses-table td[title="Duplo clique para editar"]:hover{background-color:#6366f10d;transition:background-color .2s}.expenses-table td[title="Duplo clique para editar"] input,.expenses-table td[title="Duplo clique para editar"] select{outline:none;transition:all .2s;max-width:100%;box-sizing:border-box;width:100%}.expenses-table td[title="Duplo clique para editar"] input:focus,.expenses-table td[title="Duplo clique para editar"] select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.account-badge[title="Duplo clique para editar"]:hover{opacity:.8;transform:scale(1.02);transition:all .2s}.expenses-table td.column-selector-empty-cell{width:0!important;min-width:0!important;max-width:0!important;padding:0!important;margin:0!important;border:none!important;background:transparent!important;height:0!important;line-height:0!important;font-size:0!important;overflow:hidden!important}.expenses-table th:first-child{width:40px!important;min-width:40px!important;max-width:40px!important}.column-resizer{position:absolute;top:0;right:0;width:5px;height:100%;cursor:col-resize;background:transparent;z-index:10;-webkit-user-select:none;user-select:none;transition:background-color .2s;touch-action:none}.column-resizer:hover{background-color:var(--primary);opacity:.5}.column-resizer:active{background-color:var(--primary);opacity:.8}.expenses-table th{position:relative;box-sizing:border-box}.expenses-table td{box-sizing:border-box}@media (max-width: 768px){.expenses-table th:first-child{width:32px!important;min-width:32px!important;max-width:32px!important;padding:.5rem .125rem!important}.expenses-table td.column-selector-empty-cell{width:32px!important;min-width:32px!important;max-width:32px!important}}@media (max-width: 480px){.expenses-table th:first-child{width:28px!important;min-width:28px!important;max-width:28px!important;padding:.375rem .125rem!important}.expenses-table td.column-selector-empty-cell{width:28px!important;min-width:28px!important;max-width:28px!important}}.categories-page{width:100%;margin:0;padding:0}.categories-action-bar{padding:1rem 0;border-bottom:1px solid var(--border);box-sizing:border-box}.action-bar-title{font-size:1.25rem;font-weight:600;color:var(--text);margin:0}.categories-table-container{max-width:1200px;margin:0 auto;padding:1.5rem;box-sizing:border-box}.categories-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:.5rem;overflow:hidden;box-shadow:var(--shadow)}.categories-table thead{background:var(--bg);border-bottom:2px solid var(--border)}.categories-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.categories-table td{padding:1rem;border-bottom:1px solid var(--border)}.categories-table tbody tr:hover{background:var(--bg)}.categories-table tbody tr:last-child td{border-bottom:none}.category-row{background:var(--bg-card)}.subcategory-row{background:var(--bg)}.category-icon-cell{width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.subcategory-icon{width:2.5rem;height:2.5rem;font-size:1.25rem}.category-icon-text{display:flex;align-items:center;justify-content:center}.category-name-cell{font-size:.9375rem;color:var(--text)}.category-name-cell strong{font-weight:600}.subcategory-name{display:flex;align-items:center;gap:.5rem;padding-left:1rem}.subcategory-indent{color:var(--text-light);font-size:.875rem}.category-type-badge{display:inline-block;padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.type-income{background:#d1fae5;color:#065f46}.type-expense{background:#fee2e2;color:#991b1b}.category-color-cell{display:flex;align-items:center;gap:.75rem}.color-preview{width:2rem;height:2rem;border-radius:.375rem;border:1px solid var(--border);flex-shrink:0}.color-code{font-family:Courier New,monospace;font-size:.875rem;color:var(--text-light)}.category-actions{display:flex;gap:.5rem;align-items:center}.icon-category-section{margin-bottom:1.5rem}.icon-category-section:last-child{margin-bottom:0}.icon-category-title{font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.icon-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(3rem,1fr));gap:.5rem}.icon-option{width:3rem;height:3rem;border:2px solid var(--border);border-radius:.5rem;background:var(--bg-card);font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-option:hover{border-color:var(--primary);transform:scale(1.1)}.icon-option.selected{border-color:var(--primary);background:#6366f11a}.categories-cards-container{display:none;padding:.5rem}.category-card-mobile{background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;transition:all .2s}.category-card-mobile:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.category-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.category-card-icon{width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.category-card-info{flex:1;min-width:0}.category-card-name{font-weight:600;font-size:1rem;color:var(--text);margin-bottom:.25rem}.category-card-body{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.category-card-field{display:flex;flex-direction:column;gap:.25rem}.category-card-label{font-size:.75rem;color:var(--text-light);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.category-card-value{font-size:.875rem;color:var(--text);font-weight:500}.category-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border);gap:.5rem}.category-card-actions{display:flex;gap:.5rem;align-items:center}.category-card-actions .btn-small{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:2.5rem;width:2.5rem;height:2.5rem;padding:0;margin:0}.category-card-actions .btn-small svg{width:16px!important;height:16px!important;flex-shrink:0;display:block;margin:0}.subcategory-card-mobile{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;margin-left:1rem;margin-bottom:.5rem;margin-top:.5rem}.subcategory-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.subcategory-card-icon{width:2.5rem;height:2.5rem;border-radius:.375rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.subcategory-card-name{font-weight:500;font-size:.875rem;color:var(--text);flex:1}@media (max-width: 768px){.categories-table-container{padding:0;overflow-x:visible}.categories-table{display:none}.categories-cards-container{display:block}.action-bar-content{flex-direction:column;align-items:stretch;padding:1rem}.action-bar-actions{width:100%;flex-direction:column;gap:.75rem}.action-bar-actions .btn{width:100%;justify-content:center;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600}.category-card-body{grid-template-columns:1fr;gap:.5rem}.category-card-footer{flex-direction:column;align-items:stretch;gap:.75rem}.category-card-actions{width:100%;justify-content:center}.category-card-actions .btn-small{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:2.5rem;width:2.5rem;height:2.5rem;padding:0;margin:0}.category-card-actions .btn-small svg{width:16px!important;height:16px!important;flex-shrink:0;display:block;margin:0}}@media (min-width: 769px){.categories-cards-container{display:none}}.categories-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}.category-wrapper{display:flex;flex-direction:column;gap:1rem}.category-card{background:var(--bg-card);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;min-height:180px}.category-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.category-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.category-icon-wrapper{display:flex;justify-content:center;align-items:center;width:100%}.category-icon-large{width:5rem;height:5rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0}.category-name{font-size:1.125rem;font-weight:600;color:var(--text);text-align:center;margin-bottom:1rem;flex-grow:1}.category-actions .btn{flex:1;min-width:70px;padding:.625rem .75rem;font-size:.875rem;white-space:nowrap}.category-actions .btn-small{flex:0 0 auto;min-width:2.5rem;width:2.5rem;height:2.5rem;display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0}.category-actions .btn-small svg{width:16px!important;height:16px!important;flex-shrink:0;display:block;margin:0}.subcategories-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-left:2rem;padding-left:1rem;border-left:2px solid var(--border)}.subcategory-card{background:var(--bg);border-radius:.5rem;padding:1rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.75rem}.subcategory-header{display:flex;align-items:center;gap:.75rem}.subcategory-icon-wrapper{display:flex;align-items:center;justify-content:center}.subcategory-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.subcategory-name{font-size:.875rem;font-weight:600;color:var(--text);flex:1}.subcategory-actions{display:flex;gap:.5rem}.subcategory-actions .btn{flex:1;padding:.5rem;font-size:.75rem}.subcategory-actions .btn-small{flex:0 0 auto;min-width:2.5rem;width:2.5rem;height:2.5rem;display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0}.subcategory-actions .btn-small svg{width:16px!important;height:16px!important;flex-shrink:0;display:block;margin:0}@media (max-width: 768px){.categories-container{grid-template-columns:1fr;gap:1rem}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.category-card{padding:1.25rem;min-height:160px}.category-icon-large{width:4rem;height:4rem;font-size:2rem}.category-name{font-size:1rem}.category-actions{flex-wrap:wrap;gap:.5rem}.category-actions .btn{flex:1;min-width:80px}.subcategories-container{margin-left:0;padding-left:0;border-left:none;border-top:2px solid var(--border);padding-top:1rem;margin-top:.5rem}}.categories-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s;position:relative}.categories-table th.sortable:hover{background-color:#6366f11a}.accounts-page{width:100%;margin:0;padding:0}.accounts-action-bar{padding:1rem 0;border-bottom:1px solid var(--border);box-sizing:border-box}.action-bar-content{background:#fff;max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:flex-end;align-items:center;gap:1rem;flex-wrap:wrap;box-sizing:border-box;border-radius:.5rem .5rem 0 0}.action-bar-actions{display:flex;gap:.75rem;align-items:center}.action-bar-actions .btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s}.action-bar-actions .btn-primary{background:#6366f1;color:#fff}.action-bar-actions .btn-primary:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.action-bar-actions .btn svg{width:16px;height:16px}.action-bar-actions .btn-filter{background:#3b82f6;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.action-bar-actions .btn-filter:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 2px 4px #3b82f64d}.accounts-table-container{max-width:1200px;margin:0 auto;padding:1.5rem;box-sizing:border-box}.accounts-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:.5rem;overflow:hidden;box-shadow:var(--shadow)}.accounts-table thead{background:var(--bg);border-bottom:2px solid var(--border)}.accounts-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.accounts-table td{padding:1rem;border-bottom:1px solid var(--border)}.accounts-table tbody tr:hover{background:var(--bg)}.accounts-table tbody tr:last-child td{border-bottom:none}.account-row{background:var(--bg-card)}.account-icon-cell{width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.account-icon-text.icon-text-display{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.account-icon-cell:hover .account-icon-img{transform:scale(1.1)}.account-icon-cell i{font-size:1.75rem!important;display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:100%!important;line-height:1!important;transition:transform .3s ease}.account-icon-cell:hover i{transform:scale(1.1)}.account-name-cell{font-size:.9375rem;color:var(--text)}.account-name-cell strong{font-weight:600}.account-type-badge{display:inline-block;padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.type-bank{background:#dbeafe;color:#1e40af}.type-credit{background:#fef3c7;color:#92400e}.account-bank-cell,.account-number-cell{font-size:.875rem;color:var(--text-light)}.account-balance-cell{font-size:.9375rem;font-weight:600}.balance-positive{color:#10b981}.balance-negative{color:#ef4444}.account-actions{display:flex;gap:.5rem;align-items:center}.btn-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:.25rem;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;flex-shrink:0;color:var(--text-light)}.btn-icon svg{width:16px;height:16px;transition:all .2s}.btn-icon:hover{background:var(--bg);transform:scale(1.1);color:var(--primary)}.btn-icon:hover svg{transform:scale(1.1)}.btn-icon-danger{color:#ef4444}.btn-icon-danger:hover{background:#fee2e2;color:#dc2626}.btn-icon-danger:hover svg{transform:scale(1.1)}.input-color{width:100%;height:3rem;border:1px solid var(--border);border-radius:.5rem;cursor:pointer}.icon-selector-container{max-height:400px;overflow-y:auto;padding:.5rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg)}.icon-category{margin-bottom:1.5rem}.icon-category:last-child{margin-bottom:0}.icon-category-title{font-size:.875rem;font-weight:600;color:var(--text);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light)}.icon-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(4rem,1fr));gap:.75rem;padding:.5rem}.icon-option{width:4rem;height:4rem;border:2px solid var(--border);border-radius:.75rem;background:var(--bg-card);font-size:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;position:relative;font-weight:600;box-shadow:0 2px 4px #0000000d;overflow:hidden}.icon-option.icon-text{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.5rem}.icon-option:hover{transform:translateY(-2px) scale(1.05);z-index:1;box-shadow:0 8px 16px #00000026;border-color:var(--primary)}.icon-option.selected{border-width:3px;border-color:var(--primary);transform:scale(1.05);box-shadow:0 4px 12px #6366f14d;background:#6366f10d}.icon-option.selected:before{content:"✓";position:absolute;top:.25rem;right:.25rem;background:var(--primary);color:#fff;width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;z-index:2}.icon-option.icon-image{padding:.5rem;display:flex;align-items:center;justify-content:center}.icon-img{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:.5rem;transition:transform .3s ease}.icon-option:hover .icon-img{transform:scale(1.1)}.icon-option.icon-css{padding:.5rem;font-size:0}.icon-option.icon-css i{font-size:2rem!important;display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:100%!important;line-height:1!important;margin:0;padding:0;transition:transform .3s ease}.icon-option:hover.icon-css i{transform:scale(1.1)}.icon-option.icon-css i[class*=ibb]{font-size:2rem!important;display:block!important;width:100%!important;height:100%!important}.accounts-cards-container{display:none;padding:.5rem}.account-card-mobile{background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;transition:all .2s}.account-card-mobile:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.account-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.account-card-icon{width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.account-card-info{flex:1;min-width:0}.account-card-name{font-weight:600;font-size:1rem;color:var(--text);margin-bottom:.25rem}.account-card-body{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.account-card-field{display:flex;flex-direction:column;gap:.25rem}.account-card-label{font-size:.75rem;color:var(--text-light);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.account-card-value{font-size:.875rem;color:var(--text);font-weight:500}.account-card-balance{font-size:1.125rem;font-weight:700}.account-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border);gap:.5rem}.account-card-actions{display:flex;gap:.5rem;align-items:center}@media (max-width: 768px){.accounts-table-container{padding:0;overflow-x:visible}.accounts-table{display:none}.accounts-cards-container{display:block}.action-bar-content{flex-direction:column;align-items:stretch;padding:1rem}.action-bar-actions{width:100%;flex-direction:column;gap:.75rem}.action-bar-actions .btn{width:100%;justify-content:center;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600}.account-card-body{grid-template-columns:1fr;gap:.5rem}.account-card-footer{flex-direction:column;align-items:stretch;gap:.75rem}.account-card-actions{width:100%;justify-content:center}.account-card-actions .btn-small{display:flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:.5rem}}@media (min-width: 769px){.accounts-cards-container{display:none}}.btn-filter{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-filter:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 2px 4px #3b82f64d}.btn-clear{background:#6b7280;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-clear:hover{background:#4b5563;transform:translateY(-1px);box-shadow:0 2px 4px #6b72804d}.btn-small.btn-clear{padding:.375rem .75rem;font-size:.8125rem}.filters-panel{margin:1rem auto 0;max-width:1200px;padding:1.5rem;box-sizing:border-box}.filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.filters-title{font-size:1.125rem;font-weight:600;color:var(--text);margin:0}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.accounts-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s;position:relative}.accounts-table th.sortable:hover{background-color:#6366f11a}.account-dashboard{padding:20px;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard-header h1{font-size:28px;color:#1f2937;margin:0}.refresh-btn{background:#6366f1;color:#fff;border:none;padding:10px 15px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s}.refresh-btn:hover{background:#4f46e5}.dashboard-loading,.dashboard-error{text-align:center;padding:40px;font-size:18px;color:#6b7280}.dashboard-error{color:#ef4444}.dashboard-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.summary-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:15px;min-height:100px;overflow:hidden}.summary-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.summary-content{flex:1;min-width:0;overflow:hidden}.summary-content h3{font-size:14px;color:#6b7280;margin:0 0 8px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-value{font-size:20px;font-weight:700;color:#1f2937;margin:0 0 4px;word-break:break-word;overflow-wrap:break-word;line-height:1.2}.summary-detail{font-size:12px;color:#9ca3af;margin:0;word-break:break-word;overflow-wrap:break-word;line-height:1.3}.dashboard-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;margin-bottom:30px}.chart-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a}.chart-container.full-width{grid-column:1 / -1}.chart-container h2{font-size:18px;color:#1f2937;margin:0 0 20px}.accounts-list{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a}.accounts-list h2{font-size:20px;color:#1f2937;margin:0 0 20px}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.account-card{border:1px solid #e5e7eb;border-radius:8px;padding:15px;transition:box-shadow .2s}.account-card:hover{box-shadow:0 4px 6px #0000001a}.account-header{display:flex;align-items:center;gap:12px;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #e5e7eb}.account-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.account-card:hover .account-icon{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.account-icon-text{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.account-icon-text.icon-text-display{font-size:.65rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.account-icon-img{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:.5rem;transition:transform .3s ease}.account-card:hover .account-icon-img{transform:scale(1.1)}.account-icon i{font-size:1.75rem!important;display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:100%!important;line-height:1!important;transition:transform .3s ease}.account-card:hover .account-icon i{transform:scale(1.1)}.account-info{flex:1}.account-info h3{font-size:16px;color:#1f2937;margin:0 0 4px}.account-type{font-size:12px;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:4px}.account-details{display:flex;flex-direction:column;gap:8px}.account-detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:14px;color:#6b7280}.detail-value{font-size:14px;font-weight:600;color:#1f2937}.detail-value.positive{color:#10b981}.detail-value.negative{color:#ef4444}@media (max-width: 768px){.dashboard-summary,.dashboard-charts,.accounts-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column;align-items:flex-start;gap:15px}}.profile-page{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}.profile-header{margin-bottom:2rem}.profile-title{font-size:2rem;font-weight:700;color:var(--text);margin:0}.profile-content{display:flex;flex-direction:column;gap:1.5rem}.profile-card{background:var(--bg-card);border-radius:.75rem;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border)}.profile-info{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.profile-avatar-container{display:flex;flex-direction:column;align-items:center;gap:1rem;flex-shrink:0}.profile-avatar{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;overflow:hidden;position:relative;border:4px solid var(--border);box-shadow:var(--shadow-lg)}.profile-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-avatar-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem}.profile-details{flex:1}.profile-name{font-size:1.5rem;font-weight:600;color:var(--text);margin:0 0 .5rem}.profile-email{font-size:1rem;color:var(--text-light);margin:0}.profile-actions{display:flex;gap:1rem;flex-wrap:wrap}.avatar-selector{display:flex;flex-direction:column;gap:2rem}.avatar-option-section{display:flex;flex-direction:column;gap:1rem}.avatar-section-title{font-size:1.125rem;font-weight:600;color:var(--text);margin:0}.default-avatars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:1rem;max-height:300px;overflow-y:auto;padding:.5rem}.default-avatar-option{width:80px;height:80px;border-radius:50%;border:3px solid var(--border);padding:0;background:none;cursor:pointer;position:relative;overflow:hidden;transition:all .2s;display:flex;align-items:center;justify-content:center}.default-avatar-option:hover{border-color:var(--primary);transform:scale(1.1)}.default-avatar-option.selected{border-color:var(--primary);border-width:4px;box-shadow:0 0 0 3px #6366f133}.default-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-selected-indicator{position:absolute;top:0;right:0;background:var(--primary);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:2px solid white}.avatar-upload-hint{font-size:.875rem;color:var(--text-light);margin:0;text-align:center}.users-list{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;margin-top:1rem}.users-table thead{background:var(--bg-secondary);border-bottom:2px solid var(--border)}.users-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.users-table td{padding:1rem;border-bottom:1px solid var(--border);color:var(--text)}.users-table td:nth-child(4),.users-table td:nth-child(5),.plans-list .users-table td:nth-child(5){text-align:center;vertical-align:middle;width:auto;min-width:auto;max-width:none}.users-table th:nth-child(4),.users-table th:nth-child(5),.plans-list .users-table th:nth-child(5){text-align:center;width:auto;min-width:auto;max-width:none}.users-table tbody tr:hover{background:var(--bg-secondary)}.user-avatar-small{width:40px;height:40px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}.user-avatar-small img{width:100%;height:100%;object-fit:cover}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;min-width:fit-content}.status-badge.active{background:#10b981;color:#fff}.status-badge.inactive{background:#ef4444;color:#fff}.status-badge.admin{background:#6366f1;color:#fff}@media (max-width: 768px){.users-table th:nth-child(4),.users-table td:nth-child(4),.users-table th:nth-child(5),.users-table td:nth-child(5),.plans-list .users-table th:nth-child(5),.plans-list .users-table td:nth-child(5){width:auto;min-width:auto;max-width:none;padding:.5rem;white-space:nowrap}.status-badge{font-size:.6875rem;padding:.3rem .6rem;letter-spacing:.025em;display:inline-flex;width:fit-content;min-width:auto;max-width:none;justify-content:center;flex-shrink:0}}@media (max-width: 480px){.users-table th:nth-child(4),.users-table td:nth-child(4),.users-table th:nth-child(5),.users-table td:nth-child(5),.plans-list .users-table th:nth-child(5),.plans-list .users-table td:nth-child(5){width:auto;min-width:auto;max-width:none;padding:.4rem;white-space:nowrap}.status-badge{font-size:.625rem;padding:.25rem .5rem;letter-spacing:0;width:fit-content;min-width:auto;max-width:none;flex-shrink:0}}.user-actions{display:flex;gap:.5rem}.btn-small{padding:.375rem .75rem;font-size:.875rem;min-width:auto}.btn-warning{background:#f59e0b;color:#fff;border:none}.btn-warning:hover{background:#d97706}.btn-success{background:#10b981;color:#fff;border:none}.btn-success:hover{background:#059669}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}.plans-list{overflow-x:auto}.plans-list .users-table{margin-top:0}.table-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.search-container{flex:1;min-width:200px;max-width:400px}.search-container .input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:.875rem;background:#fff}.pagination-controls-top{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.items-per-page-select{padding:.5rem;border:1px solid var(--border);border-radius:.5rem;font-size:.875rem;background:var(--bg-card);cursor:pointer}.pagination{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1rem;align-items:center}.pagination-info{font-size:.875rem;color:var(--text-light)}.pagination-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.pagination-pages{display:flex;gap:.25rem;align-items:center}.pagination-ellipsis{padding:0 .5rem;color:var(--text-light)}.btn-pagination{background:#8b5cf6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-pagination:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px);box-shadow:0 2px 4px #8b5cf64d}.btn-pagination:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.btn-small.btn-pagination{padding:.375rem .75rem;font-size:.8125rem}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state-text{font-size:1rem;font-weight:600;color:var(--text);margin:.5rem 0}.empty-state-subtext{font-size:.875rem;color:var(--text-light);margin:.25rem 0}.users-cards-container,.plans-cards-container{display:none;padding:.5rem}.user-card-mobile,.plan-card-mobile{background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;transition:all .2s}.user-card-mobile:hover,.plan-card-mobile:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.user-card-header,.plan-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.user-card-avatar{width:3rem;height:3rem;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}.user-card-avatar img{width:100%;height:100%;object-fit:cover}.user-card-info{flex:1;min-width:0}.user-card-name,.plan-card-name{font-weight:600;font-size:1rem;color:var(--text);margin-bottom:.25rem}.user-card-email{font-size:.875rem;color:var(--text-light)}.user-card-body,.plan-card-body{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.user-card-field,.plan-card-field{display:flex;flex-direction:column;gap:.25rem}.user-card-label,.plan-card-label{font-size:.75rem;color:var(--text-light);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.user-card-value,.plan-card-value{font-size:.875rem;color:var(--text);font-weight:500}.user-card-footer,.plan-card-footer{display:flex;justify-content:center;align-items:center;padding-top:.75rem;border-top:1px solid var(--border);gap:.5rem}.user-card-actions,.plan-card-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:center}.user-card-actions .btn-small,.plan-card-actions .btn-small{display:flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:.5rem}@media (max-width: 768px){.profile-page{padding:1rem}.profile-card{padding:1.5rem}.profile-info{flex-direction:column;text-align:center}.profile-actions{width:100%}.profile-actions .btn{width:100%;justify-content:center}.default-avatars-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.75rem}.default-avatar-option{width:60px;height:60px}.users-table,.plans-list .users-table{display:none}.users-cards-container,.plans-cards-container{display:block}.user-card-body,.plan-card-body{grid-template-columns:1fr;gap:.5rem}.user-card-footer,.plan-card-footer{flex-direction:column;gap:.75rem}.user-card-actions,.plan-card-actions{width:100%;justify-content:center}.user-card-actions .btn,.plan-card-actions .btn{flex:1;min-width:0}.user-card-actions .btn-small,.plan-card-actions .btn-small{min-width:2.5rem;height:2.5rem;padding:.5rem;display:flex;align-items:center;justify-content:center}.profile-header{flex-direction:column;gap:1rem;align-items:flex-start!important}.profile-header .btn{width:100%;justify-content:center}.table-controls{flex-direction:column;align-items:stretch}.search-container{max-width:100%}.pagination-controls-top{width:100%;justify-content:space-between}.pagination-controls{flex-direction:column;gap:.75rem}.pagination-pages{flex-wrap:wrap;justify-content:center;gap:.25rem}.pagination-info{font-size:.8rem}}@media (min-width: 769px){.users-cards-container,.plans-cards-container{display:none}}.crop-modal-container{display:flex;flex-direction:column;gap:1rem}.crop-image-wrapper{position:relative;width:100%;max-width:500px;margin:0 auto;border:2px solid var(--border);border-radius:.5rem;overflow:hidden;background:#f3f4f6}.crop-image-container{position:relative;width:100%;padding-bottom:100%}.crop-image-preview{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:auto}.crop-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;pointer-events:none}.crop-area{position:absolute;border:2px solid #6366f1;box-shadow:0 0 0 9999px #00000080;cursor:move;box-sizing:border-box;transition:none}.crop-area.dragging{cursor:grabbing}.crop-handle{position:absolute;width:16px;height:16px;background-color:#6366f1;border:2px solid white;border-radius:50%;cursor:nwse-resize;z-index:10;box-shadow:0 2px 4px #0003}.crop-handle:hover{background-color:#4f46e5;transform:scale(1.2)}.crop-handle.se{bottom:-4px;right:-4px}.crop-handle.nw{top:-4px;left:-4px}.crop-instructions{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;color:var(--text-light);padding:.75rem;background:var(--bg);border-radius:.5rem}.crop-instructions p{margin:0;display:flex;align-items:center;gap:.5rem}.crop-instructions p:before{content:"•";color:var(--primary);font-weight:700}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--bg-card);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.navbar-container{max-width:1200px;margin:0 auto;padding:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.navbar-brand-wrapper{display:flex;align-items:center;gap:1rem}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text);transition:color .2s}.menu-toggle:hover{color:var(--primary)}.navbar-brand{font-size:1.5rem;font-weight:700;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:.5rem;transition:transform .2s ease}.navbar-brand:hover{transform:scale(1.05)}.brand-icon{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(245,158,11,.3))}.brand-text{background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-menu{display:flex;gap:1rem;flex:1;justify-content:center}.navbar-link{padding:.5rem 1rem;text-decoration:none;color:var(--text-light);border-radius:.5rem;transition:all .2s;font-weight:500}.navbar-link:hover,.navbar-link.active{color:var(--primary);background:#6366f11a}.navbar-user{display:flex;align-items:center;gap:1rem}.navbar-user-link{text-decoration:none;color:var(--text);font-weight:500;transition:color .2s;cursor:pointer;display:flex;align-items:center;gap:.75rem}.navbar-user-link:hover{color:var(--primary)}.navbar-user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.navbar-user-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid var(--border)}.navbar-user-name{color:inherit;font-weight:500}.main-content{flex:1;padding:1rem;max-width:100%;width:100%;box-sizing:border-box}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998;opacity:0;transition:opacity .3s ease;pointer-events:none}.sidebar-overlay.active{opacity:1;pointer-events:all}.sidebar{position:fixed;top:0;left:-280px;width:280px;height:100vh;background:var(--bg-card);border-right:1px solid var(--border);box-shadow:2px 0 8px #0000001a;z-index:999;transition:left .3s ease;display:flex;flex-direction:column;overflow-y:auto}.sidebar.open{left:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border)}.sidebar-brand{font-size:1.25rem;font-weight:700;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:.5rem}.sidebar-close{background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text);transition:color .2s;display:flex;align-items:center;justify-content:center}.sidebar-close:hover{color:var(--primary)}.sidebar-menu{flex:1;padding:1rem 0;display:flex;flex-direction:column;gap:.5rem}.sidebar-menu .navbar-link{padding:.75rem 1.5rem;width:100%;text-align:left;display:block}.sidebar-footer{padding:1rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1rem}.sidebar-user-link{text-decoration:none;color:var(--text);font-weight:500;display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:.5rem;transition:background .2s}.sidebar-user-link:hover{background:#6366f11a;color:var(--primary)}.sidebar-user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.sidebar-user-avatar-placeholder{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid var(--border)}.sidebar-user-name{color:inherit;font-weight:500}@media (max-width: 768px){.menu-toggle{display:block}.navbar-container{flex-wrap:nowrap}.navbar-menu,.navbar-user-name{display:none}.sidebar-overlay{display:block}.main-content{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg: #f8fafc;--bg-card: #ffffff;--text: #1e293b;--text-light: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}html{zoom:1;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%;font-size:16px!important;-webkit-text-size-adjust:100%!important;-moz-text-size-adjust:100%!important;-ms-text-size-adjust:100%!important;text-size-adjust:100%!important}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg);color:var(--text);line-height:1.6}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:var(--text-light)}.container{max-width:1200px;margin:0 auto;padding:1rem}@media (min-width: 768px){.container{padding:2rem}}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--bg)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-small{padding:.5rem 1rem;font-size:.875rem}.input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;transition:border-color .2s}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.card{background:var(--bg-card);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-title{font-size:1.25rem;font-weight:600;color:var(--text)}.form-group{margin-bottom:1.5rem}.fade{z-index:97;position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000;opacity:.5}.qrCode{z-index:98;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;border-radius:1rem;padding:2.5rem;box-shadow:var(--shadow-lg);display:flex;flex-flow:column;align-items:center;justify-content:center;gap:1rem}.qrCode button{font-size:.8rem}.qrCode p{font-weight:600}.sucesso{z-index:99;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;border-radius:1rem;padding:2.5rem;box-shadow:var(--shadow-lg);display:flex;flex-flow:column;gap:1rem}.sucesso button{background-color:#065f46}.sucesso button:hover{background-color:#013627}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text)}.form-error{color:var(--danger);font-size:.875rem;margin-top:.25rem}.form-hint{display:block;color:var(--text-light);font-size:.75rem;margin-top:.25rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media (max-width: 768px){.grid-2,.grid-3{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal{background:var(--bg-card);border-radius:.75rem;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-title{font-size:1.5rem;font-weight:600}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-light);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:var(--text)}.alert{padding:1rem;border-radius:.5rem;margin-bottom:1rem}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-light)}.empty-state-icon{font-size:4rem;margin-bottom:1rem}.empty-state-text{font-size:1.125rem;margin-bottom:.5rem}.empty-state-subtext{font-size:.875rem}
