*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1976d2;--primary-dark: #1565c0;--primary-light: #e3f2fd;--income: #4caf50;--income-light: #e8f5e9;--expense: #f44336;--expense-light: #ffebee;--warning: #ff9800;--warning-light: #fff3e0;--success: #43a047;--text: #212121;--text-secondary:#616161;--border: #e0e0e0;--bg: #f5f7fa;--bg-card: #ffffff;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--radius: 10px;--radius-sm: 6px;--navbar-h: 60px}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:.9375rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#bdbdbd;border-radius:3px}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;align-items:center;padding:4rem 0}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{max-width:1280px;width:100%;margin:0 auto;padding:calc(var(--navbar-h) + 1.5rem) 1.5rem 3rem;flex:1}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--navbar-h);background:var(--primary);color:#fff;display:flex;align-items:center;gap:1.5rem;padding:0 1.5rem;box-shadow:0 2px 8px #0003}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;flex-shrink:0}.brand-icon{background:#fff3;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:900}.navbar-links{display:flex;align-items:center;gap:.25rem;flex:1}.nav-link{color:#ffffffd9;padding:.5rem .875rem;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff26;color:#fff}.nav-link.active{background:#ffffff40;color:#fff}.navbar-user{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.user-name{font-size:.875rem;display:flex;align-items:center;gap:.5rem}.admin-badge{background:var(--warning);color:#fff;font-size:.6875rem;font-weight:700;padding:.125rem .5rem;border-radius:10px;letter-spacing:.5px;text-transform:uppercase}.btn-logout{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:.875rem;transition:background .15s}.btn-logout:hover{background:#ffffff40}.auth-page{min-height:100vh;background:linear-gradient(135deg,var(--primary) 0%,#0d47a1 100%);display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden}.auth-logo{background:linear-gradient(135deg,var(--primary) 0%,#0d47a1 100%);color:#fff;text-align:center;padding:2rem 1.5rem 1.5rem}.brand-icon-lg{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:#fff3;border-radius:50%;font-size:1.75rem;font-weight:900;margin-bottom:.75rem}.auth-logo h1{font-size:1.5rem;margin-bottom:.25rem}.auth-logo p{font-size:.875rem;opacity:.8}.auth-form{padding:2rem}.auth-form h2{font-size:1.25rem;margin-bottom:1.5rem;color:var(--text)}.auth-subtitle{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem;margin-top:-1rem}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:1.5rem}.card-title{font-size:1.0625rem;font-weight:600;margin-bottom:1.25rem;color:var(--text)}.card-label{font-size:.8125rem;color:var(--text-secondary);margin-bottom:.25rem}.card-value{font-size:1.75rem;font-weight:700}.card-sublabel{font-size:.75rem;color:var(--text-secondary);margin-top:.375rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:1.5rem}.summary-card{text-align:center;padding:1.75rem 1.5rem}.balance-positive{border-left:4px solid var(--primary)}.balance-negative{border-left:4px solid var(--expense)}.income-card{border-left:4px solid var(--income)}.expense-card{border-left:4px solid var(--expense)}.initial-balance-card{padding:1rem 1.5rem;margin-bottom:1.5rem}.initial-balance-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.initial-balance-edit{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.initial-balance-view{display:flex;align-items:center;gap:.75rem}.balance-input{width:140px;padding:.375rem .5rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem}.balance-value{font-weight:600;font-size:1rem}.charts-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.25rem;margin-bottom:1.5rem}.chart-card{overflow:hidden}.chart-empty{display:flex;align-items:center;justify-content:center;height:300px;color:var(--text-secondary);font-size:.9375rem}.chart-tooltip{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;box-shadow:var(--shadow-md);font-size:.875rem}.tooltip-label{font-weight:600;margin-bottom:.25rem;color:var(--text)}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-header h1{font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:.9375rem;flex:1}.total-badge{background:var(--primary-light);color:var(--primary);font-size:.8125rem;font-weight:600;padding:.25rem .75rem;border-radius:12px}.month-selector{display:flex;align-items:center;gap:.75rem;margin-left:auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.375rem .75rem;box-shadow:var(--shadow-sm)}.month-label{font-weight:600;min-width:140px;text-align:center}.btn-icon{background:none;border:none;font-size:1.375rem;color:var(--primary);padding:0 .25rem;line-height:1;transition:color .15s;border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--primary-light)}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text)}.form-group input,.form-group select,.form-group textarea{padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1976d21f}.form-group textarea{resize:vertical}.input-error{border-color:var(--expense)!important}.input-readonly{background:var(--bg)!important;color:var(--text-secondary)!important}.error-msg{color:var(--expense);font-size:.8125rem}.radio-group{display:flex;gap:.75rem}.radio-option{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:.9375rem;font-weight:500;transition:all .15s;flex:1;justify-content:center;-webkit-user-select:none;user-select:none}.radio-option input[type=radio]{display:none}.radio-option.selected.income{border-color:var(--income);background:var(--income-light);color:var(--income)}.radio-option.selected.expense{border-color:var(--expense);background:var(--expense-light);color:var(--expense)}.radio-option:not(.selected):hover{border-color:var(--primary);background:var(--primary-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:500;border:none;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);border-color:#9e9e9e}.btn-danger{background:var(--expense);color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f}.btn-success{background:var(--income);color:#fff}.btn-success:hover:not(:disabled){background:#388e3c}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#e65100}.btn-link{background:none;border:none;color:var(--primary);font-size:.9375rem}.btn-link:hover{text-decoration:underline}.btn-full{width:100%}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.action-buttons{display:flex;gap:.375rem;justify-content:center;flex-wrap:wrap}.btn-action{background:none;border:1px solid var(--border);width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.9375rem;transition:all .15s}.btn-edit:hover{background:var(--primary-light);border-color:var(--primary)}.btn-delete:hover{background:var(--expense-light);border-color:var(--expense)}.fab{position:fixed;bottom:2rem;right:2rem;z-index:50;width:56px;height:56px;background:var(--primary);color:#fff;border:none;border-radius:50%;font-size:1.75rem;line-height:1;box-shadow:0 4px 12px #1976d266;transition:transform .15s,box-shadow .15s;display:flex;align-items:center;justify-content:center}.fab:hover{transform:scale(1.1);box-shadow:0 6px 20px #1976d280}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-sm{max-width:420px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.125rem;color:var(--text-secondary);width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background .15s}.modal-close:hover{background:var(--bg)}.modal-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.alert{padding:.875rem 1rem;border-radius:var(--radius-sm);font-size:.9375rem;margin-bottom:1rem}.alert-error{background:var(--expense-light);color:#c62828;border:1px solid #ef9a9a}.alert-success{background:var(--income-light);color:#2e7d32;border:1px solid #a5d6a7}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.9375rem}.table th{text-align:left;font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:.75rem 1rem;border-bottom:2px solid var(--border);background:var(--bg);white-space:nowrap}.table td{padding:.875rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr{transition:background .1s}.table tbody tr:hover{background:#fafafa}.table tbody tr:last-child td{border-bottom:none}.row-inactive{opacity:.5}.badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-income{background:var(--income-light);color:#2e7d32}.badge-expense{background:var(--expense-light);color:#c62828}.badge-active{background:var(--income-light);color:#2e7d32}.badge-inactive{background:#f5f5f5;color:var(--text-secondary)}.badge-warning{background:var(--warning-light);color:#e65100}.category-chip{display:inline-block;background:var(--primary-light);color:var(--primary);padding:.2rem .6rem;border-radius:12px;font-size:.8125rem;font-weight:500}.chips-container{display:flex;flex-wrap:wrap;gap:.75rem;padding:.25rem 0}.category-chip-card{display:flex;align-items:center;gap:.5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.625rem 1rem;transition:box-shadow .15s}.category-chip-card:hover{box-shadow:var(--shadow-sm)}.global-chip{background:var(--primary-light);border-color:#90caf9}.chip-name{font-size:.9375rem;font-weight:500}.global-tag{font-size:.875rem}.chip-actions{display:flex;gap:.25rem}.categories-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.25rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.section-title{font-size:1.125rem;font-weight:700}.filters-panel{position:relative}.filter-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--expense);color:#fff;width:18px;height:18px;border-radius:50%;font-size:.6875rem;font-weight:700}.filters-body{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-top:.5rem;box-shadow:var(--shadow-md)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.filters-search{grid-column:span 2}.filters-actions{display:flex;justify-content:flex-end;margin-top:1rem}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 0 0;border-top:1px solid var(--border);margin-top:.5rem}.pagination-info{font-size:.875rem;color:var(--text-secondary);padding:0 .5rem}.temp-password-box{background:var(--bg);border:2px dashed var(--primary);border-radius:var(--radius-sm);padding:1rem;text-align:center;font-size:1.25rem;font-weight:700;letter-spacing:.15em;color:var(--primary);font-family:monospace}.income-text{color:var(--income)}.expense-text{color:var(--expense)}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--text-secondary)}.text-sm{font-size:.875rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.empty-state{text-align:center;color:var(--text-secondary);padding:2.5rem 0;font-size:.9375rem}@media (max-width: 768px){.main-content{padding:calc(var(--navbar-h) + 1rem) 1rem 5rem}.navbar{padding:0 1rem;gap:.75rem}.brand-text,.navbar-user .user-name{display:none}.nav-link{padding:.375rem .625rem;font-size:.875rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.month-selector{margin-left:0}.charts-section,.categories-layout,.form-row{grid-template-columns:1fr}.filters-grid{grid-template-columns:1fr 1fr}.filters-search{grid-column:span 1}.summary-cards{grid-template-columns:1fr}.fab{bottom:1.5rem;right:1.5rem}.action-buttons{flex-direction:column}}@media (max-width: 480px){.filters-grid{grid-template-columns:1fr}.filters-search{grid-column:1}.modal{max-height:95vh}.radio-group{flex-direction:column}}
