:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:#111827;background-color:#f3f4f6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100%}body{margin:0;min-width:320px;min-height:100vh;background-color:#f3f4f6}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app{width:100%;min-height:100vh;padding:1rem}.app-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;margin-bottom:2rem}.app-header h1{margin:0;font-size:2.5rem}.app-header p{margin:.5rem 0 0;opacity:.9}.app-header>div:first-child{text-align:left}.tab-container{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.tab{padding:1rem 2rem;background:none;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.tab:hover{color:#667eea;background-color:#f3f4f6}.tab.active{color:#667eea;border-bottom-color:#667eea}.role-badge{background:#fff3;border:1px solid rgba(255,255,255,.35);padding:.35rem .7rem;border-radius:999px;font-size:.85rem;font-weight:700}.content{padding:1rem}.manager-container{max-width:1200px;margin:0 auto}.manager-container h2{font-size:1.8rem;margin-bottom:1.5rem;color:#1f2937}.manager-container h3{font-size:1.4rem;margin-bottom:1rem;color:#374151}.error-message{background-color:#fee2e2;border:1px solid #ef4444;color:#991b1b;padding:1rem;border-radius:4px;margin-bottom:1rem}.form{background-color:#f9fafb;padding:2rem;border-radius:8px;margin-bottom:3rem;box-shadow:0 1px 3px #0000001a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem;font-weight:600;color:#374151}.form-group input,.form-group select{padding:.75rem;border:1px solid #d1d5db;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.submit-button{background-color:#667eea;color:#fff;padding:.875rem 2rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .3s}.submit-button:hover{background-color:#5568d3}.submit-button:disabled{background-color:#9ca3af;cursor:not-allowed}.history-section{margin-top:3rem}.no-data{text-align:center;color:#6b7280;padding:2rem;font-style:italic}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;background-color:#fff;box-shadow:0 1px 3px #0000001a;border-radius:8px;overflow:hidden}.data-table th{background-color:#f3f4f6;padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.data-table td{padding:1rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background-color:#f9fafb}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:1.5rem 0 2rem}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.35rem;box-shadow:0 1px 3px #00000014}.summary-card strong{font-size:1.8rem;color:#111827}.summary-card small{color:#6b7280;font-size:.9rem}.section-description,.helper-text{color:#6b7280;font-size:.95rem}.report-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.report-actions{display:flex;flex-wrap:wrap;gap:.75rem}.admin-actions{display:flex;flex-wrap:wrap;gap:.5rem}.current-session-tag{margin-left:.35rem;color:#6b7280;font-size:.9rem}.dashboard-container{display:flex;flex-direction:column;gap:1.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.dashboard-controls{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.dashboard-month-picker{display:flex;flex-direction:column;gap:.4rem;font-weight:600;color:#374151}.dashboard-month-picker input{min-width:180px;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem}.dashboard-summary-grid{margin:0}.dashboard-summary-card{border:none;color:#fff}.dashboard-summary-card span,.dashboard-summary-card small,.dashboard-summary-card strong{color:inherit}.income-card{background:linear-gradient(135deg,#4f46e5,#6366f1)}.expense-card{background:linear-gradient(135deg,#dc2626,#ef4444)}.investment-card{background:linear-gradient(135deg,#059669,#10b981)}.dashboard-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.dashboard-panel{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb}.dashboard-panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.dashboard-panel-header h3{margin:0}.overview-chart{display:flex;flex-direction:column;gap:1rem}.overview-row{display:flex;flex-direction:column;gap:.5rem}.overview-labels{display:flex;justify-content:space-between;gap:1rem;color:#374151}.overview-track{width:100%;height:12px;border-radius:999px;background:#e5e7eb;overflow:hidden}.overview-fill{height:100%;border-radius:inherit;min-width:0;transition:width .3s ease}.expense-breakdown-layout{display:grid;grid-template-columns:minmax(220px,260px) 1fr;gap:1.5rem;align-items:center}.expense-pie-chart{display:flex;justify-content:center}.pie-chart-svg{width:100%;max-width:260px;height:auto}.pie-chart-background{fill:none;stroke:#e5e7eb;stroke-width:14}.pie-chart-center{fill:#fff}.pie-chart-total-label{fill:#6b7280;font-size:6px;font-weight:600}.pie-chart-total-value{fill:#111827;font-size:4.4px;font-weight:700}.expense-breakdown-list{display:flex;flex-direction:column;gap:.75rem}.expense-breakdown-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;background:#f9fafb;border-radius:8px}.expense-breakdown-title,.expense-breakdown-values{display:flex;align-items:center;gap:.65rem}.expense-breakdown-values{flex-direction:column;align-items:flex-end;gap:.2rem}.expense-breakdown-dot{width:.8rem;height:.8rem;border-radius:999px;flex-shrink:0}@media(max-width:768px){.app{padding:.5rem}.app-header{padding:1.5rem 1rem;flex-direction:column;gap:1rem}.app-header h1{font-size:2rem}.tab-container{flex-wrap:wrap}.user-info{padding-right:0;flex-wrap:wrap;justify-content:center}.tab{padding:.75rem 1rem;flex:1;min-width:100px}.form{padding:1rem}.form-row{grid-template-columns:1fr;gap:0}.dashboard-header,.dashboard-panel-header{flex-direction:column}.expense-breakdown-layout{grid-template-columns:1fr}.dashboard-controls{align-items:stretch;width:100%}.dashboard-month-picker input,.dashboard-controls .btn-secondary{width:100%}.expense-breakdown-item,.overview-labels{flex-direction:column;align-items:flex-start}.expense-breakdown-values{align-items:flex-start}.data-table{font-size:.9rem}.data-table th,.data-table td{padding:.75rem .5rem}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem}.auth-box{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;width:100%;max-width:420px}.auth-box h2{margin:0 0 1.5rem;color:#1f2937;font-size:1.75rem;text-align:center}.auth-box .form-group{margin-bottom:1.25rem}.auth-box label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500;font-size:.95rem}.auth-box input[type=email],.auth-box input[type=password]{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-box input[type=email]:focus,.auth-box input[type=password]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.auth-box input:disabled{background-color:#f3f4f6;cursor:not-allowed}.btn-primary{width:100%;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:.5rem}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:#6b7280}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.google-signin-section{display:flex;flex-direction:column;gap:.5rem}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#111827;font-size:1rem;font-weight:600;cursor:pointer}.btn-google:disabled{opacity:.65;cursor:not-allowed}.error-message{background-color:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.95rem}.auth-switch{text-align:center;margin-top:1.5rem;color:#6b7280;font-size:.95rem}.link-button{background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;padding:0;font-size:inherit}.link-button:hover:not(:disabled){color:#764ba2}.link-button:disabled{cursor:not-allowed;opacity:.6}.loading-container{display:flex;justify-content:center;align-items:center;min-height:80vh;color:#6b7280;font-size:1.1rem}.user-info{display:flex;align-items:center;gap:1rem;justify-content:flex-end;margin-top:1rem}.user-info span{font-size:.95rem}.btn-logout{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-logout:hover{background:#ffffff4d}.btn-secondary{padding:.55rem .9rem;background:#eef2ff;color:#4338ca;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}
