.expense-form{background:#fff;border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.expense-form h2{margin:0 0 20px;font-size:20px;font-weight:600;color:#333}.form-group{margin-bottom:16px;display:flex;flex-direction:column}.form-group label{font-size:14px;font-weight:500;color:#555;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#ffebee;border-left:4px solid #f44336;color:#c62828;padding:12px;border-radius:4px;margin-bottom:16px;font-size:14px}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover:not(:disabled){background-color:#45a049}.btn:disabled{opacity:.6;cursor:not-allowed}.expense-list{background:#fff;border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.expense-list h2{margin:0 0 20px;font-size:20px;font-weight:600;color:#333}.empty-message{text-align:center;color:#999;padding:40px 20px;font-size:14px}.expenses-table-wrapper{overflow-x:auto;margin-bottom:16px}.expenses-table{width:100%;border-collapse:collapse;font-size:14px}.expenses-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.expenses-table th{padding:12px;text-align:left;font-weight:600;color:#555}.expenses-table td{padding:12px;border-bottom:1px solid #eee;color:#333}.expenses-table tbody tr:hover{background-color:#f9f9f9}.expenses-table .amount{font-weight:600;color:#2e7d32}.expenses-table .description{color:#777;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-total{text-align:right;font-size:16px;color:#333;padding:12px 0;border-top:2px solid #eee}.loading{text-align:center;color:#999;padding:40px 20px;font-size:14px}.expense-controls{background:#fff;border-radius:8px;padding:16px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a;display:flex;gap:20px;flex-wrap:wrap;align-items:flex-end}.control-group{display:flex;flex-direction:column;gap:6px}.control-group label{font-size:13px;font-weight:600;color:#555}.filter-container{display:flex;gap:8px;align-items:center}.control-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:13px;min-width:150px;background-color:#fff;cursor:pointer;transition:border-color .2s}.control-group select:focus{outline:none;border-color:#4caf50}.control-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.clear-filter-btn{padding:6px 10px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .2s}.clear-filter-btn:hover{background-color:#d32f2f}.clear-filter-btn:active{transform:scale(.95)}@media (max-width: 768px){.expense-controls{flex-direction:column;align-items:stretch}.filter-container{width:100%}.control-group select{min-width:unset;width:100%}}.app{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f5f5}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 20px;text-align:center}.app-header h1{font-size:32px;margin-bottom:8px;font-weight:700}.app-header p{font-size:16px;opacity:.9}.app-main{flex:1;padding:40px 20px}.container{max-width:900px;margin:0 auto}.app-footer{background-color:#333;color:#fff;text-align:center;padding:20px;font-size:14px;margin-top:40px}@media (max-width: 768px){.app-header{padding:24px 16px}.app-header h1{font-size:24px}.app-main{padding:20px 16px}.expense-controls{flex-direction:column;align-items:stretch!important}.control-group select{min-width:unset}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}#root{display:flex;flex-direction:column;min-height:100vh}
