*{box-sizing:border-box;margin:0;padding:0}body,html{overflow-x:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3f4f6;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#2c3e50;--primary-dark:#1a252f;--primary-light:#34495e;--success-color:#27ae60;--success-light:#e8f5e9;--danger-color:#e74c3c;--danger-light:#ffebee;--accent-color:#3498db;--accent-light:#ecf3f9;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#eee;--gray-300:#e0e0e0;--gray-400:#bdbdbd;--gray-500:#9e9e9e;--gray-600:#757575;--gray-700:#616161;--gray-800:#424242;--gray-900:#212121;--bg-primary:#fff;--bg-secondary:#fafafa;--text-primary:#212121;--text-secondary:#616161;--border-radius:8px;--border-radius-sm:4px;--box-shadow:0 1px 3px #00000014;--box-shadow-md:0 2px 8px #0000001a;--box-shadow-lg:0 4px 12px #0000001f;--transition:all 0.3s ease}[data-theme=dark]{--primary-color:#4a90e2;--primary-dark:#357abd;--primary-light:#6ba3e8;--success-color:#2ecc71;--success-light:#1a3a25;--danger-color:#e74c3c;--danger-light:#3a1f1f;--accent-color:#5dade2;--accent-light:#1a2a3a;--gray-50:#1a1a1a;--gray-100:#2d2d2d;--gray-200:#3a3a3a;--gray-300:#4a4a4a;--gray-400:#6a6a6a;--gray-500:#8a8a8a;--gray-600:#a0a0a0;--gray-700:silver;--gray-800:#e0e0e0;--gray-900:#f5f5f5;--bg-primary:#1e1e1e;--bg-secondary:#252525;--text-primary:#f5f5f5;--text-secondary:silver;--box-shadow:0 1px 3px #0000004d;--box-shadow-md:0 2px 8px #0006;--box-shadow-lg:0 4px 12px #00000080}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.App{background:#fafafa;background:var(--gray-50);min-height:100vh;padding:0}.dashboard{margin:0 auto;max-width:1400px}.dashboard-header{background:#fff;background:var(--bg-primary);border-bottom:1px solid #eee;border-bottom:1px solid var(--gray-200);box-shadow:0 1px 3px #0000000d;gap:30px;justify-content:space-between;margin-bottom:0;padding:24px 40px}.dashboard-header,.header-left{align-items:center;display:flex}.header-left{flex:1 1;gap:20px}.header-logo{align-items:center;background:linear-gradient(135deg,#2c3e50,#3498db);background:linear-gradient(135deg,var(--primary-color) 0,var(--accent-color) 100%);border-radius:12px;box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:48px;justify-content:center;width:48px}.header-title-section{display:flex;flex-direction:column;gap:4px}.dashboard-header h1{color:#212121;color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0}.dashboard-subtitle{color:#616161;color:var(--text-secondary);font-size:.85rem;font-weight:400;margin:0}.header-right{align-items:center;display:flex;gap:16px}.dashboard-nav{background:#fff;background:var(--bg-primary);border-bottom:1px solid #eee;border-bottom:1px solid var(--gray-200);display:flex;flex-wrap:wrap;gap:0;justify-content:flex-start;padding:0 40px}.nav-button{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:#616161;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:16px 24px;position:relative;transition:all .3s ease;transition:var(--transition)}.nav-button:hover{background:#f5f5f5;background:var(--gray-100);color:#212121;color:var(--text-primary)}.nav-button.active{background:#0000;border-bottom-color:#2c3e50;border-bottom-color:var(--primary-color);color:#2c3e50;color:var(--primary-color)}.dashboard-content{background:#fafafa;background:var(--bg-secondary);min-height:calc(100vh - 180px);padding:32px 40px}.section-header{align-items:center;display:flex;flex-direction:column;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:30px}.section-header h2{color:#212121;color:var(--text-primary);font-size:2rem;font-weight:700;text-align:center}.btn-primary{align-items:center;background:#2c3e50;background:var(--primary-color);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease;transition:var(--transition)}.btn-primary:hover{background:#1a252f;background:var(--primary-dark);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.btn-secondary{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#616161;color:var(--gray-700);cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .3s ease;transition:var(--transition)}.btn-secondary:hover{background:#fafafa;background:var(--gray-50);border-color:#bdbdbd;border-color:var(--gray-400)}.icon-button{align-items:center;background:#0000;border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#757575;color:var(--gray-600);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .3s ease;transition:var(--transition)}.icon-button:hover{background:#f5f5f5;background:var(--gray-100);color:#2c3e50;color:var(--primary-color)}.icon-button.delete:hover{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.summary-container{animation:fadeIn .3s ease}.summary-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:30px}.summary-title{color:#212121;color:var(--text-primary);font-size:2rem;font-weight:700;margin:0}.month-selector{align-items:center;display:flex;gap:12px}.month-label{color:#616161;color:var(--text-secondary);font-size:.9rem;font-weight:600}.month-select-summary{background:#fff;background:var(--bg-primary);border:2px solid #2c3e50;border:2px solid var(--primary-color);border-radius:8px;border-radius:var(--border-radius);color:#2c3e50;color:var(--primary-color);cursor:pointer;font-size:1rem;font-weight:600;min-width:200px;padding:10px 16px;transition:all .3s ease;transition:var(--transition)}.month-select-summary:hover{background:#ecf3f9;background:var(--accent-light)}.month-select-summary:focus{box-shadow:0 0 0 3px #2c3e501a;outline:none}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:40px}.summary-card{align-items:flex-start;background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);display:flex;flex-direction:column;gap:16px;padding:24px;transition:all .3s ease;transition:var(--transition)}.summary-card:hover{border-color:#e0e0e0;border-color:var(--gray-300);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.summary-card.balance{border-left:3px solid #2c3e50;border-left:3px solid var(--primary-color)}.summary-card.balance,.summary-card.income{background:#fff;background:var(--bg-primary)}.summary-card.income{border-left:3px solid #27ae60;border-left:3px solid var(--success-color)}.summary-card.expense{border-left:3px solid #e74c3c;border-left:3px solid var(--danger-color)}.summary-card.expense,.summary-card.topay{background:#fff;background:var(--bg-primary)}.summary-card.topay{border-left:3px solid #f59e0b}.summary-icon{align-items:center;background:#fafafa;background:var(--gray-50);border-radius:4px;border-radius:var(--border-radius-sm);color:#757575;color:var(--gray-600);display:flex;height:40px;justify-content:center;width:40px}.summary-card.balance .summary-icon{background:#ecf3f9;background:var(--accent-light);color:#2c3e50;color:var(--primary-color)}.summary-card.topay .summary-icon{background:#fef3c7;color:#f59e0b}.summary-card.income .summary-icon{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.summary-card.expense .summary-icon{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.summary-content{flex:1 1;width:100%}.summary-label{color:#757575;color:var(--gray-600);font-size:.85rem;font-weight:500;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.summary-value{color:#212121;color:var(--text-primary);font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.summary-card.balance .summary-value{color:#2c3e50;color:var(--primary-color)}.summary-card.income .summary-value{color:#27ae60;color:var(--success-color)}.summary-card.expense .summary-value{color:#e74c3c;color:var(--danger-color)}.summary-card.topay .summary-value{color:#f59e0b}.summary-hint{color:#9e9e9e;color:var(--gray-500);display:block;font-size:.75rem;font-weight:400;margin-top:4px}.category-summary{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);padding:24px}.category-summary-title{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.5rem;font-weight:700;gap:10px;margin-bottom:20px}.category-summary-list{display:flex;flex-direction:column;gap:15px}.category-summary-item{align-items:center;background:#fafafa;background:var(--bg-secondary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:4px;border-radius:var(--border-radius-sm);box-shadow:0 1px 3px #00000014;box-shadow:var(--box-shadow);display:flex;justify-content:space-between;padding:20px}.category-summary-info{display:flex;flex:1 1;flex-direction:column;gap:8px}.category-summary-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.category-summary-name{color:#212121;color:var(--text-primary);font-size:1.1rem;font-weight:600}.category-summary-percentage{background:#ecf3f9;background:var(--accent-light);border-radius:4px;border-radius:var(--border-radius-sm);color:#2c3e50;color:var(--primary-color);font-size:.9rem;font-weight:600;padding:4px 10px}.category-summary-progress{background:#eee;background:var(--gray-200);border-radius:4px;height:8px;margin:4px 0;overflow:hidden;width:100%}.category-summary-progress-bar{background:linear-gradient(90deg,#2c3e50,#3498db);background:linear-gradient(90deg,var(--primary-color),var(--accent-color));border-radius:4px;height:100%;transition:width .3s ease}.category-summary-progress-bar.receita{background:linear-gradient(90deg,#27ae60,#22c55e);background:linear-gradient(90deg,var(--success-color),#22c55e)}.category-summary-progress-bar.despesa{background:linear-gradient(90deg,#e74c3c,#ef4444);background:linear-gradient(90deg,var(--danger-color),#ef4444)}.category-summary-name.receita{color:#27ae60;color:var(--success-color)}.category-summary-name.despesa{color:#e74c3c;color:var(--danger-color)}.category-summary-count{color:#9e9e9e;color:var(--gray-500);font-size:.85rem}.category-summary-value{font-size:1.3rem;font-weight:700;min-width:120px;text-align:right}.category-summary-value .receita{color:#27ae60;color:var(--success-color)}.category-summary-value .despesa{color:#e74c3c;color:var(--danger-color)}.pie-chart-section{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-top:40px}.pie-chart-container{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);padding:24px}.pie-chart-title{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.5rem;font-weight:700;gap:10px;margin-bottom:20px}.totals-card{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);display:flex;flex-direction:column;padding:24px}.totals-card-title{color:#212121;color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:24px}.totals-content{display:flex;flex:1 1;flex-direction:column;gap:20px}.total-item{align-items:flex-start;background:#fafafa;background:var(--bg-secondary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:4px;border-radius:var(--border-radius-sm);display:flex;gap:16px;padding:20px}.total-item.income-total{border-left:3px solid #27ae60;border-left:3px solid var(--success-color)}.total-item.expense-total{border-left:3px solid #e74c3c;border-left:3px solid var(--danger-color)}.total-icon{align-items:center;border-radius:4px;border-radius:var(--border-radius-sm);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.income-total .total-icon{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.expense-total .total-icon{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.total-info{flex:1 1}.total-label{color:#757575;color:var(--gray-600);font-size:.9rem;font-weight:500;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.total-value{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.total-value.income{color:#27ae60;color:var(--success-color)}.total-value.expense{color:#e74c3c;color:var(--danger-color)}.total-hint{color:#9e9e9e;color:var(--gray-500);display:block;font-size:.75rem;font-weight:400}.total-divider{background:#eee;background:var(--gray-200);height:1px;margin:0}@media (max-width:1024px){.pie-chart-section{grid-template-columns:1fr}}.categories-container{animation:fadeIn .3s ease}.categories-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.category-card{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);display:flex;gap:15px;padding:20px;transition:all .3s ease;transition:var(--transition)}.category-card:hover{border-color:#e0e0e0;border-color:var(--gray-300);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.category-card.receita{background:#fff;background:var(--bg-primary);border-left:3px solid #27ae60;border-left:3px solid var(--success-color)}.category-card.despesa{background:#fff;background:var(--bg-primary);border-left:3px solid #e74c3c;border-left:3px solid var(--danger-color)}.category-icon{align-items:center;background:#fafafa;background:var(--gray-50);border-radius:4px;border-radius:var(--border-radius-sm);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.category-card.receita .category-icon{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.category-card.despesa .category-icon{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.category-info{flex:1 1}.category-info h3{color:#212121;color:var(--text-primary);font-size:1.2rem;margin-bottom:4px}.category-type{border-radius:4px;border-radius:var(--border-radius-sm);display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:4px 10px;text-transform:uppercase}.category-card.receita .category-type{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.category-card.despesa .category-type{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.category-actions{display:flex;gap:8px}.category-footer{border-top:1px solid #eee;border-top:1px solid var(--gray-200);margin-top:12px;padding-top:12px}.category-badges{display:flex;flex-wrap:wrap;gap:8px}.category-price{color:#2c3e50;color:var(--primary-color);font-size:1.1rem;font-weight:600}.category-description{color:#616161;color:var(--text-secondary);font-size:.875rem;margin:4px 0}.category-card.inactive{opacity:.6}.badge{align-items:center;border-radius:4px;border-radius:var(--border-radius-sm);display:inline-flex;font-size:.75rem;font-weight:500;gap:4px;padding:4px 8px}.badge-success{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.category-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.transactions-container{animation:fadeIn .3s ease}.filter-section{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);display:flex;flex-direction:column;gap:25px;margin-bottom:30px;padding:25px}.filter-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));max-width:1200px;width:100%}.filter-group{background:#fafafa;background:var(--gray-50);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);box-shadow:var(--box-shadow-sm);flex-direction:column;gap:12px;padding:20px}.filter-label{color:#616161;color:var(--text-secondary);font-size:.9rem;font-weight:600;text-align:center;width:100%}.filter-buttons{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.filter-buttons.vertical{flex-direction:column;gap:6px}.filter-buttons.vertical .filter-btn{justify-content:center;width:100%}.month-select{background:#fff;background:var(--bg-primary);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:8px;color:#212121;color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 16px;text-align:center;transition:all .2s ease;width:100%}.month-select:focus,.month-select:hover{border-color:#2c3e50;border-color:var(--primary-color)}.month-select:focus{box-shadow:0 0 0 3px #2c3e501a;outline:none}.month-indicator{color:#3498db;color:var(--accent-color);font-size:.9rem;font-weight:600;margin-top:4px}.filter-btn{background:#fff;background:var(--bg-primary);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:8px;color:#616161;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;min-width:-webkit-fit-content;min-width:fit-content;padding:8px 14px;transition:all .2s ease;white-space:nowrap}.filter-btn:hover{background:#ecf3f9;background:var(--accent-light);color:#2c3e50;color:var(--primary-color);transform:translateY(-1px)}.filter-btn.active,.filter-btn:hover{border-color:#2c3e50;border-color:var(--primary-color)}.filter-btn.active{background:#2c3e50;background:var(--primary-color);box-shadow:var(--box-shadow-sm);color:#fff}.transactions-list{display:flex;flex-direction:column;gap:15px}.transaction-card{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);padding:20px;transition:all .3s ease;transition:var(--transition)}.transaction-card:hover{border-color:#e0e0e0;border-color:var(--gray-300);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.transaction-main{align-items:flex-start;display:flex;gap:20px;justify-content:space-between}.transaction-info{flex:1 1}.transaction-info h3{color:#212121;color:var(--text-primary);font-size:1.2rem;font-weight:600;margin-bottom:8px}.transaction-description{align-items:center;color:#757575;color:var(--gray-600);display:flex;font-size:.9rem;gap:6px;margin-bottom:12px}.transaction-meta{display:flex;flex-wrap:wrap;gap:15px}.meta-item{align-items:center;color:#757575;color:var(--gray-600);display:flex;font-size:.85rem;gap:6px}.category-badge{border-radius:20px;font-weight:600;padding:6px 12px}.category-badge.receita{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.category-badge.despesa{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.payment-badge{background:#ecf3f9;background:var(--accent-light);border-radius:20px;color:#3498db;color:var(--accent-color);font-weight:600;padding:6px 12px}.transaction-value-section{align-items:flex-end;display:flex;flex-direction:column;gap:12px}.transaction-value{font-size:1.5rem;font-weight:700}.transaction-value.positive{color:#27ae60;color:var(--success-color)}.transaction-value.negative{color:#e74c3c;color:var(--danger-color)}.transaction-actions{display:flex;gap:8px}.btn-paid{background:#fff;background:var(--bg-primary);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#616161;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 14px;transition:all .3s ease;transition:var(--transition);white-space:nowrap}.btn-paid:hover{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.btn-paid.paid,.btn-paid:hover{border-color:#27ae60;border-color:var(--success-color)}.btn-paid.paid{background:#27ae60;background:var(--success-color);color:#fff;font-weight:600}.btn-paid.paid:hover{background:#eee;background:var(--gray-200);border-color:#bdbdbd;border-color:var(--gray-400);color:#616161;color:var(--gray-700)}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--bg-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #eee;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:30px 30px 20px}.modal-header h2{color:#212121;color:var(--text-primary);font-size:1.8rem;font-weight:700}.close-button{background:#0000;border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#616161;color:var(--text-secondary);cursor:pointer;padding:8px;transition:all .3s ease;transition:var(--transition)}.close-button:hover{background:#f5f5f5;background:var(--gray-100);color:#212121;color:var(--text-primary)}form{padding:30px}.form-group{margin-bottom:24px}.form-group label{color:#616161;color:var(--text-secondary);display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--bg-primary);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#212121;color:var(--text-primary);font-family:inherit;font-size:1rem;padding:12px 16px;transition:all .3s ease;transition:var(--transition);width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.modal-body{padding:30px}.modal-close-btn{align-items:center;background:#0000;border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#616161;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .3s ease;transition:var(--transition)}.modal-close-btn:hover{background:#f5f5f5;background:var(--gray-100);color:#212121;color:var(--text-primary)}.modal-small{max-width:400px}.modal-medium{max-width:600px}.modal-large{max-width:800px}.confirm-dialog{padding:20px 0;text-align:center}.confirm-dialog-icon{display:flex;justify-content:center;margin-bottom:20px}.confirm-dialog-icon .icon-danger{color:#e74c3c;color:var(--danger-color)}.confirm-dialog-icon .icon-warning{color:#f59e0b;color:var(--warning-color,#f59e0b)}.confirm-dialog-icon .icon-info{color:#2c3e50;color:var(--primary-color)}.confirm-dialog-message{color:#212121;color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin-bottom:30px}.confirm-dialog-actions{display:flex;gap:12px;justify-content:center}.btn-danger{background:#e74c3c;background:var(--danger-color);color:#fff}.btn-danger:hover{background:#dc2626;background:var(--danger-dark,#dc2626);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.alert-dialog{padding:20px 0;text-align:center}.alert-dialog-icon{display:flex;justify-content:center;margin-bottom:20px}.alert-dialog-icon .icon-warning{color:#f59e0b;color:var(--warning-color,#f59e0b)}.alert-dialog-message{color:#212121;color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin-bottom:30px}.alert-dialog-actions{display:flex;justify-content:center}.form-actions{border-top:1px solid #eee;border-top:1px solid var(--gray-200);display:flex;gap:12px;justify-content:flex-end;margin-top:30px;padding-top:20px}.empty-state{align-items:center;background:#fff;background:var(--bg-primary);border:2px dashed #e0e0e0;border:2px dashed var(--gray-300);border-radius:8px;border-radius:var(--border-radius);display:flex;flex-direction:column;justify-content:center;margin:60px auto;max-width:600px;min-height:400px;padding:100px 40px;text-align:center}.empty-icon{font-size:5rem;margin-bottom:30px;opacity:.4}.empty-state h3{color:#212121;color:var(--text-primary);font-size:1.75rem;font-weight:700;margin-bottom:16px}.empty-state p{color:#757575;color:var(--gray-600);font-size:1.05rem;line-height:1.6;margin-bottom:40px;max-width:450px}.empty-button{box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);font-size:1.05rem;font-weight:600;padding:16px 40px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-footer{background:#fff;background:var(--bg-primary);border-top:1px solid #eee;border-top:1px solid var(--gray-200);bottom:0;box-shadow:0 -2px 10px #0000000d;display:none;left:0;padding:8px 0;position:fixed;right:0;z-index:1000}.mobile-footer-btn{align-items:center;background:#0000;border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#616161;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.7rem;font-weight:500;gap:4px;justify-content:center;padding:8px 4px;transition:all .3s ease;transition:var(--transition)}.mobile-footer-btn:hover{background:#f5f5f5;background:var(--gray-100);color:#2c3e50;color:var(--primary-color)}.mobile-footer-btn.active{background:#ecf3f9;background:var(--accent-light);color:#2c3e50;color:var(--primary-color)}.mobile-footer-btn span{font-size:.7rem;font-weight:600}@media (max-width:768px){.App{padding:0 0 70px}.dashboard-header{align-items:flex-start;flex-direction:column;gap:16px;padding:16px 20px}.header-left{gap:12px;width:100%}.header-logo{font-size:1rem;height:40px;width:40px}.dashboard-header h1{font-size:1.3rem}.dashboard-subtitle{font-size:.8rem}.header-right{justify-content:space-between;width:100%}.navbar-user{gap:8px}.user-avatar-container{height:36px;width:36px}.user-avatar-placeholder{font-size:.9rem}.user-avatar-placeholder svg{height:18px;width:18px}.theme-toggle{height:30px;width:52px}.theme-toggle-slider{height:22px;width:22px}[data-theme=dark] .theme-toggle-slider{transform:translateX(22px)}.btn-logout{font-size:.75rem;padding:6px 12px}.btn-logout span,.dashboard-nav{display:none}.mobile-footer{display:flex}.dashboard-content{min-height:calc(100vh - 200px);padding:16px}.section-header{gap:12px;margin-bottom:20px}.section-header h2{font-size:1.4rem}.summary-header{align-items:flex-start;flex-direction:column;gap:15px}.summary-title{font-size:1.4rem}.month-selector{width:100%}.month-select-summary{flex:1 1;min-width:auto;width:100%}.summary-cards{gap:12px;grid-template-columns:1fr}.summary-card{padding:16px}.summary-value{font-size:1.5rem}.filter-section{gap:16px;padding:16px}.filter-row{gap:12px;grid-template-columns:1fr}.filter-group{padding:12px}.categories-grid{gap:12px;grid-template-columns:1fr}.category-card,.transaction-card{padding:16px}.transaction-main{flex-direction:column}.transaction-value-section{align-items:flex-start;flex-direction:row;justify-content:space-between;width:100%}.transaction-value{font-size:1.3rem}.recurring-grid{gap:12px;grid-template-columns:1fr}.chart-container,.recurring-card{padding:16px}.chart-title{font-size:1.1rem}.form-row{grid-template-columns:1fr}.modal-content{margin:10px;max-height:85vh}.modal-header,form{padding:16px}.modal-header h2{font-size:1.4rem}.empty-state{margin:30px 10px;min-height:300px;padding:60px 20px}.empty-icon{font-size:3.5rem}.empty-state h3{font-size:1.4rem}.empty-state p{font-size:.95rem}.empty-button{max-width:280px;padding:12px 24px;width:100%}}@media (max-width:480px){.header-logo{font-size:.9rem;height:36px;width:36px}.dashboard-header h1{font-size:1.1rem}.dashboard-subtitle{font-size:.75rem}.user-avatar-container{height:32px;width:32px}.user-avatar-placeholder{font-size:.85rem}.user-avatar-placeholder svg{height:16px;width:16px}.theme-toggle{height:28px;width:48px}.theme-toggle-slider{height:20px;width:20px}[data-theme=dark] .theme-toggle-slider{transform:translateX(20px)}.btn-logout{min-width:40px;padding:6px 10px}.section-header h2,.summary-title{font-size:1.2rem}.summary-value{font-size:1.3rem}.summary-card{padding:14px}.category-summary-item{align-items:flex-start;flex-direction:column;gap:10px}.transaction-card{padding:14px}.transaction-value{font-size:1.2rem}.filter-section{padding:12px}.filter-group{padding:10px}.chart-container{padding:12px}.modal-header,form{padding:14px}.empty-state{margin:20px 5px;min-height:250px;padding:40px 16px}.empty-icon{font-size:3rem}.empty-state h3{font-size:1.2rem}.empty-state p{font-size:.9rem}.mobile-footer-btn,.mobile-footer-btn span{font-size:.65rem}}@media (min-width:769px) and (max-width:1024px){.dashboard-content,.dashboard-header{padding:24px 30px}.categories-grid,.filter-row,.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (min-width:769px){.mobile-footer{display:none!important}.dashboard-nav{display:flex}}@media (max-width:768px){.btn-paid,.btn-primary,.btn-secondary,.filter-btn,.icon-button,.mobile-footer-btn,.nav-button{min-height:44px;min-width:44px}.form-group input,.form-group select,.form-group textarea,.month-select,.month-select-summary{font-size:16px;min-height:44px}.category-card,.recurring-card,.transaction-card{margin-bottom:12px}html{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#f5f5f5;background:var(--gray-100)}::-webkit-scrollbar-thumb{background:#bdbdbd;background:var(--gray-400);border-radius:3px}.btn-paid,.filter-btn,.mobile-footer-btn,.nav-button{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn-primary:active,.btn-secondary:active,.filter-btn:active,.icon-button:active{transform:scale(.98)}.category-card:active,.recurring-card:active,.transaction-card:active{transform:scale(.99);transition:transform .1s ease}}@media (max-width:480px){body{font-size:15px}.btn-primary{font-size:.95rem;padding:12px 24px}.modal-content{border-radius:4px;border-radius:var(--border-radius-sm);margin:5px;max-height:90vh}.chart-container{min-height:250px}.toast{min-width:auto;padding:12px 16px}.toast-message{font-size:.85rem}}.error-page{align-items:center;background:#fff;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:20px}.error-container{animation:fadeIn .3s ease;background:#fafafa;background:var(--bg-secondary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 12px #0000001f;box-shadow:var(--box-shadow-lg);max-width:600px;padding:60px 40px;text-align:center;width:100%}.error-icon{display:flex;justify-content:center;margin-bottom:30px}.error-icon .icon-error-403{animation:shake .5s ease;color:#f59e0b;color:var(--warning-color,#f59e0b)}.error-icon .icon-error-500{animation:pulse 2s infinite;color:#e74c3c;color:var(--danger-color)}.error-content{margin-bottom:40px}.error-code{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2c3e50,#1a252f);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));-webkit-background-clip:text;background-clip:text;font-size:8rem;font-weight:900;line-height:1;margin:0 0 20px}.error-title{color:#212121;color:var(--text-primary);font-size:2.5rem;font-weight:700;margin:0 0 16px}.error-message{font-size:1.2rem;font-weight:600;margin:0 0 16px}.error-description,.error-message{color:#616161;color:var(--text-secondary)}.error-description{font-size:1rem;line-height:1.6;margin:0;opacity:.8}.error-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.btn-error-primary{align-items:center;background:#2c3e50;background:var(--primary-color);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;transition:var(--transition)}.btn-error-primary:hover{background:#1a252f;background:var(--primary-dark);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-2px)}.btn-error-secondary{align-items:center;background:#fff;background:var(--bg-primary);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#212121;color:var(--text-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;transition:var(--transition)}.btn-error-secondary:hover{background:#fafafa;background:var(--gray-50);border-color:#2c3e50;border-color:var(--primary-color);color:#2c3e50;color:var(--primary-color);transform:translateY(-2px)}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-10px)}20%,40%,60%,80%{transform:translateX(10px)}}@media (max-width:768px){.error-container{padding:40px 20px}.error-code{font-size:5rem}.error-title{font-size:1.8rem}.error-message{font-size:1rem}.error-description{font-size:.9rem}.error-actions{flex-direction:column}.btn-error-primary,.btn-error-secondary{justify-content:center;width:100%}}@media (max-width:768px) and (orientation:landscape){.dashboard-header{padding:12px 20px}.dashboard-content{min-height:calc(100vh - 150px);padding:12px}.mobile-footer{padding:4px 0}.mobile-footer-btn{padding:6px 4px}.empty-state{min-height:200px;padding:40px 20px}}@media (display-mode:standalone){.App{padding-bottom:calc(70px + env(safe-area-inset-bottom));padding-top:env(safe-area-inset-top)}.mobile-footer{padding-bottom:env(safe-area-inset-bottom)}}.auth-container{align-items:center;background:#fafafa;background:var(--gray-50);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 12px #0000001f;box-shadow:var(--box-shadow-lg);color:#212121;color:var(--text-primary);max-width:420px;overflow:hidden;width:100%}.auth-header{border-bottom:1px solid #eee;border-bottom:1px solid var(--gray-200);padding:40px 40px 30px;text-align:center}.auth-icon{align-items:center;background:#ecf3f9;background:var(--accent-light);border-radius:8px;border-radius:var(--border-radius);color:#2c3e50;color:var(--primary-color);display:flex;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.auth-header h1{color:#212121;color:var(--gray-900);font-size:1.5rem;font-weight:600;margin-bottom:8px}.auth-header p{color:#757575;color:var(--gray-600);font-size:.9rem}.auth-form{padding:30px 40px}.auth-form .form-group{margin-bottom:20px}.auth-form .form-group:last-of-type{margin-bottom:24px}.auth-form label{align-items:center;color:#616161;color:var(--gray-700);display:flex;font-size:.9rem;font-weight:500;gap:8px;margin-bottom:8px}.auth-form input{background:#fafafa;background:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#212121;color:var(--text-primary);font-size:.95rem;padding:12px 16px;transition:all .3s ease;transition:var(--transition);width:100%}.auth-form input:focus{border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a90e240;outline:none}.auth-form input::placeholder{color:#9e9e9e;color:var(--gray-500);opacity:.85}.auth-form small{color:#9e9e9e;color:var(--gray-500);display:block;font-size:.8rem;margin-top:6px}.auth-submit{font-size:.95rem;padding:12px;width:100%}.auth-submit:disabled{cursor:not-allowed;opacity:.6}.auth-footer{background:#fff;background:var(--bg-primary);border-top:1px solid #eee;border-top:1px solid var(--gray-200);padding:20px 40px 30px;text-align:center}.auth-footer p{color:#757575;color:var(--gray-600);font-size:.9rem}.link-button{background:none;border:none;color:#2c3e50;color:var(--primary-color);cursor:pointer;font-weight:600;text-decoration:underline;transition:all .3s ease;transition:var(--transition)}.link-button:hover{color:#1a252f;color:var(--primary-dark)}[data-theme=dark] .auth-card{box-shadow:0 20px 40px #00000073}[data-theme=dark] .auth-card,[data-theme=dark] .auth-footer,[data-theme=dark] .auth-header{border-color:#e0e0e0;border-color:var(--gray-300)}[data-theme=dark] .auth-icon{background:#4a90e22e;color:#212121;color:var(--text-primary)}[data-theme=dark] .auth-form input{background:#ffffff0d;border-color:#e0e0e0;border-color:var(--gray-300)}[data-theme=dark] .auth-form input:focus{box-shadow:0 0 0 3px #4a90e259}[data-theme=dark] .auth-form input::placeholder{color:#757575;color:var(--gray-600)}.error-message{align-items:center;background:#ffebee;background:var(--danger-light);border:1px solid #e74c3c;border:1px solid var(--danger-color);border-radius:4px;border-radius:var(--border-radius-sm);color:#e74c3c;color:var(--danger-color)}.error-message,.success-message{display:flex;font-size:.9rem;gap:10px;margin-bottom:20px;padding:12px}.success-message{align-items:flex-start;background:#e8f5e9;background:var(--success-light);border:1px solid #27ae60;border:1px solid var(--success-color);border-radius:4px;border-radius:var(--border-radius-sm);color:#27ae60;color:var(--success-color)}.success-message div{flex:1 1}.success-message strong{display:block;margin-bottom:4px}.success-message p{font-size:.85rem;margin:0}.loading-container{align-items:center;background:#fafafa;background:var(--gray-50);display:flex;justify-content:center;min-height:100vh}.spinner{animation:spin .8s linear infinite;border:3px solid #eee;border-top-color:#2c3e50;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary-color);height:50px;width:50px}.navbar-user{align-items:center;display:flex;gap:12px;padding:0}.user-avatar-container{align-items:center;background:#fff;background:var(--bg-primary);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;transition:all .3s ease;transition:var(--transition);width:40px}.user-avatar-container:hover{border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:scale(1.05)}.user-avatar{display:block;height:100%;object-fit:cover;width:100%}.user-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#2c3e50,#3498db);background:linear-gradient(135deg,var(--primary-color) 0,var(--accent-color) 100%);border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:600;height:100%;justify-content:center;width:100%}.user-avatar-placeholder svg{color:#fff;height:20px;width:20px}[data-theme=dark] .user-avatar-container{background:#616161;background:var(--gray-700);border-color:#757575;border-color:var(--gray-600)}[data-theme=dark] .user-avatar-container:hover{background:#757575;background:var(--gray-600);border-color:#2c3e50;border-color:var(--primary-color)}[data-theme=dark] .user-avatar-placeholder svg{color:#fff}.user-info{align-items:flex-end;background:#fafafa;background:var(--gray-50);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);display:flex;flex-direction:column;padding:8px 16px}.user-name{color:#212121;color:var(--text-primary);font-size:.85rem;font-weight:600}.user-email{font-size:.75rem}.privacy-toggle,.user-email{color:#616161;color:var(--text-secondary)}.privacy-toggle{align-items:center;background:#fff;background:var(--bg-primary);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius);cursor:pointer;display:flex;height:40px;justify-content:center;margin-right:12px;transition:all .3s ease;transition:var(--transition);width:40px}.privacy-toggle:hover{background:#ecf3f9;background:var(--accent-light);border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);color:#2c3e50;color:var(--primary-color)}[data-theme=dark] .privacy-toggle{background:#616161;background:var(--gray-700);border-color:#757575;border-color:var(--gray-600);color:#212121;color:var(--text-primary)}[data-theme=dark] .privacy-toggle:hover{background:#757575;background:var(--gray-600);border-color:#2c3e50;border-color:var(--primary-color)}.theme-toggle{align-items:center;background:#eee;background:var(--gray-200);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:20px;cursor:pointer;display:flex;height:32px;padding:2px;position:relative;transition:all .3s ease;transition:var(--transition);width:56px}.theme-toggle:hover{border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.theme-toggle-slider{align-items:center;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;color:#2c3e50;color:var(--primary-color);display:flex;height:24px;justify-content:center;position:absolute;transition:transform .3s ease,background-color .3s ease;width:24px}[data-theme=dark] .theme-toggle{background:#616161;background:var(--gray-700);border-color:#757575;border-color:var(--gray-600)}[data-theme=dark] .theme-toggle-slider{background:#2c3e50;background:var(--primary-color);color:#fff;transform:translateX(24px)}.btn-logout{align-items:center;background:#0000;border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius);color:#616161;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .3s ease;transition:var(--transition)}.btn-logout:hover{background:#ffebee;background:var(--danger-light);border-color:#e74c3c;border-color:var(--danger-color);color:#e74c3c;color:var(--danger-color)}@media (max-width:768px){.auth-container{padding:10px}.auth-card{max-width:100%}.auth-header{padding:30px 24px 20px}.auth-form{padding:24px}.auth-footer{padding:16px 24px 24px}.auth-icon{height:50px;margin-bottom:16px;width:50px}.auth-header h1{font-size:1.3rem}.auth-header p{font-size:.85rem}.auth-form .form-group{margin-bottom:16px}.auth-form input{font-size:.9rem;padding:10px 14px}.auth-submit{font-size:.9rem;padding:10px}}@media (max-width:480px){.auth-card{border-left:none;border-radius:0;border-right:none;box-shadow:none}.auth-header{padding:24px 20px 16px}.auth-form{padding:20px}.auth-footer{padding:14px 20px 20px}.auth-icon{height:45px;width:45px}.auth-header h1{font-size:1.2rem}.auth-header p{font-size:.8rem}.auth-form .form-group{margin-bottom:14px}.auth-form label{font-size:.85rem}.auth-form input{font-size:.85rem;padding:9px 12px}.auth-submit{padding:9px}.auth-footer p,.auth-submit{font-size:.85rem}}.toast-container{display:flex;flex-direction:column;gap:12px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.toast{align-items:center;animation:slideInRight .3s ease-out;background:#fff;background:var(--bg-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;display:flex;gap:12px;max-width:420px;min-width:320px;padding:16px 20px;pointer-events:auto}.toast-success{border-left:4px solid #27ae60;border-left:4px solid var(--success-color)}.toast-error{border-left:4px solid #e74c3c;border-left:4px solid var(--danger-color)}.toast-warning{border-left:4px solid #f59e0b}.toast-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.toast-success .toast-icon{color:#27ae60;color:var(--success-color)}.toast-error .toast-icon{color:#e74c3c;color:var(--danger-color)}.toast-warning .toast-icon{color:#f59e0b}.toast-message{color:#212121;color:var(--text-primary);flex:1 1;font-size:.9rem;font-weight:500;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#9e9e9e;color:var(--gray-500);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .3s ease;transition:var(--transition)}.toast-close:hover{background:#f5f5f5;background:var(--gray-100);color:#616161;color:var(--gray-700)}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:480px){.toast-container{left:10px;right:10px;top:10px}.toast{min-width:auto;width:100%}}.recurring-container{animation:fadeIn .3s ease}.recurring-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.recurring-card{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);padding:20px;transition:all .3s ease;transition:var(--transition)}.recurring-card:hover{border-color:#e0e0e0;border-color:var(--gray-300);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.recurring-card.inactive{background:#fafafa;background:var(--gray-50);opacity:.6}.recurring-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px}.recurring-info{flex:1 1}.recurring-info h3{color:#212121;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:8px}.recurring-status{display:flex;gap:8px}.toggle-button{align-items:center;background:#f5f5f5;background:var(--gray-100);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#757575;color:var(--gray-600);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .3s ease;transition:var(--transition)}.toggle-button:hover{background:#eee;background:var(--gray-200)}.toggle-button.active{background:#e8f5e9;background:var(--success-light);border-color:#27ae60;border-color:var(--success-color);color:#27ae60;color:var(--success-color)}.recurring-details{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.recurring-detail{align-items:center;color:#757575;color:var(--gray-600);display:flex;font-size:.85rem;gap:8px}.recurring-footer{align-items:center;border-top:1px solid #eee;border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;padding-top:16px}.recurring-value{font-size:1.3rem;font-weight:700}.recurring-value.positive{color:#27ae60;color:var(--success-color)}.recurring-value.negative{color:#e74c3c;color:var(--danger-color)}.recurring-actions{display:flex;gap:8px}@media (max-width:768px){.recurring-grid{grid-template-columns:1fr}.section-header{align-items:flex-start;flex-direction:column}.section-header button,.section-header>div{width:100%}}.chart-container{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);margin-bottom:32px;padding:24px}.chart-header{flex-wrap:wrap;justify-content:space-between}.chart-title{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.25rem;font-weight:600;gap:10px}.chart-month{background:#ecf3f9;background:var(--accent-light);border-radius:4px;border-radius:var(--border-radius-sm);color:#3498db;color:var(--accent-color);font-size:.9rem;font-weight:600;padding:6px 12px}.chart-empty{background:#fff;background:var(--bg-primary);border:1px solid #eee;border:1px solid var(--gray-200);color:#9e9e9e;color:var(--gray-500);margin-bottom:32px;padding:60px 24px}.chart-empty,.chart-tooltip{border-radius:8px;border-radius:var(--border-radius)}.chart-tooltip{max-width:350px;min-width:250px;padding:16px;position:relative;z-index:1000}.tooltip-date{border-bottom:2px solid #eee;border-bottom:2px solid var(--gray-200);color:#212121;color:var(--text-primary);font-size:.95rem;font-weight:600;margin-bottom:12px;padding-bottom:8px}.tooltip-receitas{color:#27ae60;color:var(--success-color)}.tooltip-despesas,.tooltip-receitas{font-size:.9rem;font-weight:600;margin-bottom:4px}.tooltip-despesas{color:#e74c3c;color:var(--danger-color)}.tooltip-divider{background:#eee;background:var(--gray-200);height:1px;margin:12px 0}.tooltip-label{color:#616161;color:var(--gray-700);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}.tooltip-transactions{display:flex;flex-direction:column;gap:6px}.tooltip-transaction{align-items:flex-start;background:#fafafa;background:var(--gray-50);border-radius:4px;border-radius:var(--border-radius-sm);display:flex;gap:12px;justify-content:space-between;padding:6px 8px}.tooltip-trans-name{word-wrap:break-word;color:#616161;color:var(--gray-700);flex:1 1;font-size:.85rem;line-height:1.3;overflow-wrap:break-word}.tooltip-positive{color:#27ae60;color:var(--success-color)}.tooltip-negative,.tooltip-positive{font-size:.85rem;font-weight:600;white-space:nowrap}.tooltip-negative{color:#e74c3c;color:var(--danger-color)}@media (max-width:768px){.chart-container{padding:16px}.chart-title{font-size:1.1rem}.recharts-tooltip-wrapper{left:50%!important;transform:translateX(-50%)!important}.chart-tooltip{max-width:calc(100vw - 40px);min-width:180px;padding:12px}.tooltip-date{font-size:.85rem}.tooltip-despesas,.tooltip-receitas{font-size:.8rem}.tooltip-label{font-size:.75rem}.tooltip-negative,.tooltip-positive,.tooltip-trans-name{font-size:.8rem}}.profile-container{background:#fff;background:var(--bg-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);margin:0 auto;max-width:800px;padding:32px}.profile-header{margin-bottom:32px;text-align:center}.profile-header h2{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.75rem;font-weight:700;gap:12px;justify-content:center;margin-bottom:8px}.profile-subtitle{color:#616161;color:var(--text-secondary);font-size:.95rem}.profile-form{display:flex;flex-direction:column;gap:24px}.profile-photo-section{display:flex;justify-content:center;margin-bottom:8px}.profile-photo-wrapper{align-items:center;display:flex;flex-direction:column;gap:16px}.profile-photo{border:4px solid #eee;border:4px solid var(--gray-200);border-radius:50%;box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);height:150px;object-fit:cover;width:150px}.profile-photo-placeholder{align-items:center;background:#eee;background:var(--gray-200);border:4px solid #e0e0e0;border:4px solid var(--gray-300);border-radius:50%;color:#9e9e9e;color:var(--gray-500);display:flex;height:150px;justify-content:center;width:150px}.profile-photo-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.btn-upload-photo{align-items:center;background:#2c3e50;background:var(--primary-color);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease;transition:var(--transition)}.btn-upload-photo:hover{background:#1a252f;background:var(--primary-dark);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-1px)}.btn-upload-photo:active{transform:translateY(0)}.btn-remove-photo{align-items:center;background:#e74c3c;background:var(--danger-color);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease;transition:var(--transition)}.btn-remove-photo:hover{background:#c0392b;box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-1px)}.btn-remove-photo:active{transform:translateY(0)}.btn-remove-photo:disabled{cursor:not-allowed;opacity:.6;transform:none}.profile-form-group{margin-bottom:0}.profile-label{align-items:center;color:#616161;color:var(--text-secondary);display:flex;font-size:.95rem;font-weight:600;gap:8px;margin-bottom:8px}.profile-input{background:#fff;background:var(--bg-primary);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#212121;color:var(--text-primary);font-size:1rem;padding:12px 16px;transition:all .3s ease;transition:var(--transition);width:100%}.profile-input:focus{border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.profile-form-actions{border-top:2px solid #eee;border-top:2px solid var(--gray-200);display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:24px}.btn-cancel{align-items:center;background:#eee;background:var(--gray-200);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#212121;color:var(--text-primary);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease;transition:var(--transition)}.btn-cancel:hover:not(:disabled){background:#e0e0e0;background:var(--gray-300);transform:translateY(-1px)}.btn-cancel:active:not(:disabled){transform:translateY(0)}.btn-cancel:disabled{cursor:not-allowed;opacity:.5}.btn-save{align-items:center;background:#27ae60;background:var(--success-color);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease;transition:var(--transition)}.btn-save:hover:not(:disabled){background:#229954;box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-1px)}.btn-save:active:not(:disabled){transform:translateY(0)}.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:768px){.profile-container{border-radius:0;margin:0;padding:24px 16px}.profile-header h2{font-size:1.5rem}.profile-photo,.profile-photo-placeholder{height:120px;width:120px}.profile-photo-placeholder svg{height:48px;width:48px}.profile-form-actions{flex-direction:column-reverse}.btn-cancel,.btn-save{justify-content:center;width:100%}}.profile-tabs{border-bottom:2px solid #eee;border-bottom:2px solid var(--gray-200);display:flex;gap:8px;margin-bottom:24px}.profile-tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#616161;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px;margin-bottom:-2px;padding:12px 20px;transition:all .3s ease;transition:var(--transition)}.profile-tab:hover{background:#fafafa;background:var(--gray-50)}.profile-tab.active,.profile-tab:hover{color:#2c3e50;color:var(--primary-color)}.profile-tab.active{border-bottom-color:#2c3e50;border-bottom-color:var(--primary-color);font-weight:600}.profile-achievements-section{margin-top:0}.achievements-container{margin:0 auto;max-width:1200px;padding:0}.achievements-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.achievements-title-section{flex:1 1}.achievements-title-section h2{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.75rem;font-weight:700;gap:12px;margin-bottom:12px}.achievements-stats-summary{display:flex;flex-wrap:wrap;gap:24px}.stat-item{flex-direction:column;gap:4px}.stat-value{color:#2c3e50;color:var(--primary-color);font-size:1.5rem;font-weight:700}.achievements-progress-bar{background:#eee;background:var(--gray-200);border-radius:4px;height:8px;margin-bottom:24px;overflow:hidden;width:100%}.achievements-progress-fill{background:linear-gradient(90deg,#2c3e50,#3498db);background:linear-gradient(90deg,var(--primary-color),var(--accent-color));height:100%;transition:width .3s ease}.achievements-filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.filter-select{border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm)}.filter-select:focus{border-color:#2c3e50;border-color:var(--primary-color)}.achievements-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.achievement-card{background:#fff;background:var(--bg-primary);border:2px solid #eee;border:2px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);overflow:hidden;padding:20px;position:relative;transition:all .3s ease;transition:var(--transition)}.achievement-card.locked{opacity:.7}.achievement-card.unlocked{border-color:#3498db;border-color:var(--accent-color);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md)}.achievement-card.unlocked:before{background:linear-gradient(90deg,#2c3e50,#3498db);background:linear-gradient(90deg,var(--primary-color),var(--accent-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.achievement-icon-wrapper{display:inline-block;margin-bottom:12px;position:relative}.achievement-icon{align-items:center;border-radius:50%;display:flex;font-size:2rem;height:64px;justify-content:center;transition:all .3s ease;transition:var(--transition);width:64px}.achievement-unlocked-badge{background:#27ae60;background:var(--success-color);right:-4px}.achievement-recent-badge,.achievement-unlocked-badge{align-items:center;border:2px solid #fff;border:2px solid var(--bg-primary);border-radius:50%;color:#fff;display:flex;height:24px;justify-content:center;position:absolute;top:-4px;width:24px;z-index:2}.achievement-recent-badge{animation:pulse 2s infinite;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);box-shadow:0 2px 8px #ff6b6b66;left:-4px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.achievement-date-badge{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#2c3e50e6;border:2px solid #fff;border:2px solid var(--bg-primary);border-radius:12px;box-shadow:0 2px 4px #0003;color:#fff;display:flex;font-size:.7rem;font-weight:600;justify-content:center;padding:4px 8px;position:absolute;right:-4px;top:20px;white-space:nowrap;z-index:3}.achievement-info{flex:1 1}.achievement-name{color:#212121;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:8px}.achievement-description{color:#616161;color:var(--text-secondary);font-size:.9rem;line-height:1.4;margin-bottom:12px}.achievement-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.achievement-rarity{align-items:center;display:flex;font-size:.85rem;font-weight:500;gap:6px;text-transform:capitalize}.achievement-points{color:#616161;color:var(--text-secondary);font-size:.85rem;font-weight:600}.achievement-progress{margin-top:12px}.achievement-progress-bar{background:#eee;background:var(--gray-200);border-radius:3px;height:6px;margin-bottom:6px;overflow:hidden;width:100%}.achievement-progress-fill{background:#2c3e50;background:var(--primary-color);height:100%;transition:width .3s ease}.achievement-progress-text{color:#616161;color:var(--text-secondary);font-size:.8rem;text-align:right}.achievement-unlocked-date{color:#616161;color:var(--text-secondary);font-size:.75rem;font-style:italic;margin-top:8px}.achievements-empty{color:#616161;color:var(--text-secondary);padding:60px 20px;text-align:center}.achievements-empty svg{margin-bottom:16px;opacity:.5}.btn-check-achievements{align-items:center;background:#3498db;background:var(--accent-color);border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease;transition:var(--transition)}.btn-check-achievements:hover{background:#1a252f;background:var(--primary-dark);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-1px)}.achievements-loading{align-items:center;display:flex;justify-content:center;padding:60px 20px}@media (max-width:768px){.achievements-grid{grid-template-columns:1fr}.achievements-header{flex-direction:column}.achievements-stats-summary{justify-content:space-between;width:100%}.achievements-filters{flex-direction:column}.filter-group{width:100%}.filter-select{flex:1 1}.profile-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.profile-tab{white-space:nowrap}}.ranking-container{margin:0 auto;max-width:1200px;padding:0}.ranking-header{margin-bottom:24px}.ranking-title-section h2{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.75rem;font-weight:700;gap:12px;margin-bottom:8px}.ranking-subtitle{color:#616161;color:var(--text-secondary);font-size:.95rem}.current-user-card{background:linear-gradient(135deg,#2c3e50,#3498db);background:linear-gradient(135deg,var(--primary-color),var(--accent-color));border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);color:#fff;margin-top:20px;padding:16px}.current-user-info{align-items:center;display:flex;gap:16px}.current-user-avatar{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;display:flex;height:56px;justify-content:center;overflow:hidden;width:56px}.current-user-avatar img{height:100%;object-fit:cover;width:100%}.current-user-avatar svg{color:#fff}.current-user-details{flex:1 1}.current-user-name{font-size:1.1rem;font-weight:600;margin-bottom:4px}.current-user-stats{align-items:center;display:flex;font-size:.9rem;gap:8px;opacity:.9}.current-user-separator{opacity:.7}.current-user-position{font-weight:600}.ranking-search{margin-bottom:20px}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:#616161;color:var(--text-secondary);left:12px;pointer-events:none;position:absolute}.search-input{background:#fff;background:var(--bg-primary);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);color:#212121;color:var(--text-primary);font-size:.95rem;padding:12px 16px 12px 40px;transition:all .3s ease;transition:var(--transition);width:100%}.search-input:focus{border-color:#2c3e50;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.ranking-list{display:flex;flex-direction:column;gap:12px}.ranking-item{align-items:center;background:#fff;background:var(--bg-primary);border:2px solid #eee;border:2px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius);display:flex;gap:16px;padding:16px;transition:all .3s ease;transition:var(--transition)}.ranking-item:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-2px)}.ranking-item.current-user{background:linear-gradient(135deg,#4f46e50d,#3b82f60d);border-color:#3498db;border-color:var(--accent-color)}.ranking-item.rank-first{background:linear-gradient(135deg,#ffd7001a,#ffc1071a);border-color:gold;box-shadow:0 4px 12px #ffd70033}.ranking-item.rank-second{background:linear-gradient(135deg,#c0c0c01a,#a9a9a91a);border-color:silver;box-shadow:0 4px 12px #c0c0c033}.ranking-item.rank-third{background:linear-gradient(135deg,#cd7f321a,#b873331a);border-color:#cd7f32;box-shadow:0 4px 12px #cd7f3233}.ranking-position{color:#616161;color:var(--text-secondary);font-size:1.2rem;min-width:40px}.ranking-position .icon-gold{color:gold}.ranking-position .icon-silver{color:silver}.ranking-position .icon-bronze{color:#cd7f32}.position-number{color:#616161;color:var(--text-secondary);font-weight:600}.ranking-user-avatar{align-items:center;background:#eee;background:var(--gray-200);border:2px solid #e0e0e0;border:2px solid var(--gray-300);border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;overflow:hidden;width:48px}.ranking-user-avatar img{height:100%;object-fit:cover;width:100%}.ranking-user-avatar svg{color:#616161;color:var(--text-secondary)}.ranking-user-info{flex:1 1;min-width:0}.ranking-user-name{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1rem;font-weight:600;gap:8px;margin-bottom:4px}.current-user-badge{background:#3498db;background:var(--accent-color);border-radius:12px;color:#fff;font-size:.75rem;font-weight:500;padding:2px 8px}.ranking-user-email{color:#616161;color:var(--text-secondary);font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-user-stats{gap:16px}.ranking-user-stats,.stat-item{align-items:center;display:flex}.stat-item{font-size:.9rem;gap:6px}.stat-item svg{color:#3498db;color:var(--accent-color)}.stat-value{color:#212121;color:var(--text-primary);font-weight:600}.stat-label{font-size:.85rem}.ranking-empty,.stat-label{color:#616161;color:var(--text-secondary)}.ranking-empty{padding:60px 20px;text-align:center}.ranking-empty svg{margin-bottom:16px;opacity:.5}.ranking-loading{align-items:center;display:flex;justify-content:center;padding:60px 20px}.ranking-scroll-hint{background:#ecf3f9;background:var(--accent-light);border-radius:4px;border-radius:var(--border-radius-sm);color:#616161;color:var(--text-secondary);font-size:.9rem;margin-top:24px;padding:12px;text-align:center}.profile-ranking-section{margin-top:0}@media (max-width:768px){.ranking-item{gap:12px;padding:12px}.ranking-user-stats{align-items:flex-end;flex-direction:column;gap:8px}.current-user-info{flex-direction:column;text-align:center}.ranking-position{font-size:1rem;min-width:32px}.ranking-user-avatar{height:40px;width:40px}.search-input{font-size:16px}}.indicators-container{margin:0 auto;max-width:1400px;padding:24px}.indicators-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:32px}.indicators-title-section h2{align-items:center;color:#212121;color:var(--text-primary);display:flex;font-size:1.75rem;font-weight:700;gap:12px;margin-bottom:8px}.indicators-subtitle{color:#616161;color:var(--text-secondary);font-size:.95rem;margin:0}.indicators-filters{align-items:center;display:flex;gap:16px}.filter-group{align-items:center;display:flex;gap:8px}.filter-group label{color:#616161;color:var(--text-secondary);font-size:.9rem;font-weight:500}.filter-select{background:#fff;background:var(--bg-primary);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius);color:#212121;color:var(--text-primary);cursor:pointer;font-size:.9rem;padding:8px 12px;transition:all .3s ease;transition:var(--transition)}.filter-select:focus,.filter-select:hover{border-color:#3498db;border-color:var(--accent-color)}.filter-select:focus{box-shadow:0 0 0 3px #3498db1a;outline:none}.indicators-metrics{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.metric-card{align-items:flex-start;background:#fff;background:var(--bg-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--box-shadow);display:flex;gap:16px;padding:24px;transition:all .3s ease;transition:var(--transition)}.metric-card:hover{box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow-md);transform:translateY(-2px)}.metric-icon{align-items:center;border-radius:8px;border-radius:var(--border-radius);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.metric-card.income .metric-icon{background:#e8f5e9;background:var(--success-light);color:#27ae60;color:var(--success-color)}.metric-card.expense .metric-icon{background:#ffebee;background:var(--danger-light);color:#e74c3c;color:var(--danger-color)}.metric-card.balance .metric-icon{background:#ecf3f9;background:var(--accent-light);color:#3498db;color:var(--accent-color)}.metric-card.transactions .metric-icon{background:#eee;background:var(--gray-200);color:#616161;color:var(--gray-700)}.metric-content{flex:1 1;min-width:0}.metric-label{color:#616161;color:var(--text-secondary);font-size:.85rem;font-weight:500;margin:0 0 8px}.metric-value{color:#212121;color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 4px}.metric-value.positive{color:#27ae60;color:var(--success-color)}.metric-value.negative{color:#e74c3c;color:var(--danger-color)}.metric-hint{color:#616161;color:var(--text-secondary);font-size:.8rem;margin:0}.metric-variation{align-items:center;display:flex;font-size:.85rem;gap:4px;margin-top:8px}.metric-variation .positive{color:#27ae60;color:var(--success-color)}.metric-variation .negative{color:#e74c3c;color:var(--danger-color)}.indicators-chart-card{background:#fff;background:var(--bg-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--box-shadow);margin-bottom:24px;padding:24px}.chart-header{gap:12px;margin-bottom:24px}.chart-header,.chart-header h3{align-items:center;display:flex}.chart-header h3{color:#212121;color:var(--text-primary);font-size:1.25rem;font-weight:600;gap:8px;margin:0}.indicators-charts-row{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:24px}.chart-empty{color:#616161;color:var(--text-secondary);padding:60px 20px;text-align:center}.chart-empty p{font-size:.95rem;margin:0}.chart-loading{align-items:center;color:#616161;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.chart-loading .spinner{animation:spin 1s linear infinite;border:4px solid #eee;border-top-color:#3498db;border:4px solid var(--gray-200);border-radius:50%;border-top-color:var(--accent-color);height:40px;margin-bottom:16px;width:40px}.chart-loading p{font-size:.95rem;margin:0}@keyframes spin{to{transform:rotate(1turn)}}.indicators-table-card{background:#fff;background:var(--bg-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--box-shadow);padding:24px}.category-ranking{display:flex;flex-direction:column;gap:16px}.category-ranking-item{align-items:flex-start;background:#fafafa;background:var(--bg-secondary);border-radius:4px;border-radius:var(--border-radius-sm);display:flex;gap:16px;padding:16px;transition:all .3s ease;transition:var(--transition)}.category-ranking-item:hover{background:#eee;background:var(--gray-200)}.ranking-position{align-items:center;background:#3498db;background:var(--accent-color);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:40px;justify-content:center;width:40px}.ranking-info{flex:1 1;min-width:0}.ranking-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.ranking-name{font-weight:600}.ranking-name,.ranking-value{color:#212121;color:var(--text-primary);font-size:1rem}.ranking-value{font-weight:700}.ranking-progress{background:#eee;background:var(--gray-200);border-radius:4px;height:8px;margin-bottom:4px;overflow:hidden;width:100%}.ranking-progress-bar{height:100%;transition:width .3s ease}.ranking-percentage{color:#616161;color:var(--text-secondary);font-size:.85rem}.chart-tooltip{background:#fff;background:var(--bg-primary);border:1px solid #e0e0e0;border:1px solid var(--gray-300);border-radius:4px;border-radius:var(--border-radius-sm);box-shadow:0 4px 12px #0000001f;box-shadow:var(--box-shadow-lg);padding:12px}.tooltip-label{color:#212121;color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:8px}@media (max-width:768px){.indicators-container{padding:16px}.indicators-header{align-items:stretch;flex-direction:column}.indicators-charts-row,.indicators-metrics{grid-template-columns:1fr}.metric-card{padding:20px}.metric-value{font-size:1.5rem}.indicators-chart-card{padding:16px}.category-ranking-item{padding:12px}.ranking-header{align-items:flex-start;flex-direction:column;gap:4px}}
/*# sourceMappingURL=main.978161cc.css.map*/