@import"https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Rubik,sans-serif;line-height:1.6;color:#334155;background:#fff;min-height:100vh}.header{background:#fff;border-bottom:1px solid #e2e8f0;color:#1e293b;text-align:center;padding:2rem 0;margin-bottom:2rem}.header h1{font-size:2rem;margin-bottom:.5rem;font-weight:600;color:#1e293b}.header p{font-size:1rem;color:#64748b;font-weight:400}.container{max-width:1400px;margin:0 auto;padding:0 1rem}.controls{background:#fff;padding:2rem;border-radius:8px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.controls:hover{box-shadow:0 4px 6px #0000001a}.search-container{margin-bottom:2rem;position:relative}.search-container input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;font-family:Rubik,sans-serif;transition:border-color .2s ease;width:70%;margin-right:1rem;background:#fff}.search-container input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-container input::placeholder{color:#9ca3af;font-weight:400}.search-container button{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;font-family:Rubik,sans-serif;transition:background-color .2s ease}.search-container button:hover{background:#2563eb}.search-container button:active{background:#1d4ed8}.filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.filter-group{display:flex;flex-direction:column;position:relative}.filter-group label{margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem;font-family:Rubik,sans-serif}.filter-group input,.filter-group select{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;font-family:Rubik,sans-serif;transition:border-color .2s ease;background:#fff}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.aggregation-panel{background:#f8fafc;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:2rem}.aggregation-panel h3{margin-bottom:1rem;color:#1e293b;font-weight:600;font-family:Rubik,sans-serif;font-size:1.25rem}.agg-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.agg-item{text-align:center;padding:1rem;background:#fff;border-radius:4px;border:1px solid #e2e8f0}.agg-label{display:block;font-size:.75rem;color:#64748b;margin-bottom:.5rem;font-weight:500;font-family:Rubik,sans-serif}.agg-item span:last-child{font-size:1.5rem;font-weight:600;color:#1e293b;display:block;font-family:Rubik,sans-serif}.table-container{background:#fff;border-radius:8px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-container:hover{box-shadow:0 4px 6px #0000001a}.table-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.table-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;font-family:Rubik,sans-serif}.table-controls{display:flex;gap:.75rem}.table-controls button{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;font-family:Rubik,sans-serif;transition:background-color .2s ease}#exportData{background:#10b981;color:#fff}#exportData:hover{background:#059669}#addRecord{background:#3b82f6;color:#fff}#addRecord:hover{background:#2563eb}#testApiBtn{background:linear-gradient(135deg,#17a2b8,#6f42c1);color:#fff}#testApiBtn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #17a2b866}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;font-family:Rubik,sans-serif}.data-table th{background:#f1f5f9;padding:.75rem;text-align:left;font-weight:500;color:#475569;border-bottom:1px solid #e2e8f0;white-space:nowrap}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.data-table th.sortable:hover{background:#e2e8f0}.sort-icon{margin-left:.5rem;color:#64748b;font-size:.75rem}.data-table td{padding:.75rem;border-bottom:1px solid #f1f5f9;background:#fff}.data-table tbody tr{transition:background-color .2s ease}.data-table tbody tr:hover{background:#f8fafc}.data-table tbody tr:nth-child(2n){background:#fff}.data-table tbody tr:nth-child(2n):hover{background:linear-gradient(135deg,#667eea14,#764ba214)}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;font-family:Rubik,sans-serif}.status-active{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-inactive{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.status-discontinued{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.actions{white-space:nowrap}.actions button{padding:.5rem .75rem;margin:0 .25rem;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500;font-family:Rubik,sans-serif;background:#fff;color:#374151;transition:all .2s ease}.actions button:hover{background:#f9fafb;border-color:#9ca3af}.edit-btn{background:#fbbf24;color:#78350f;border-color:#f59e0b}.edit-btn:hover{background:#f59e0b;color:#fff}.delete-btn{background:#ef4444;color:#fff;border-color:#dc2626}.delete-btn:hover{background:#dc2626}.pagination{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#f8fafc;border-top:1px solid #e2e8f0}.pagination button{padding:.5rem 1rem;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;font-family:Rubik,sans-serif;transition:all .2s ease}.pagination button:hover{background:#f9fafb;border-color:#9ca3af}.pagination button:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}#pageInfo{font-weight:600;color:#2d3748;font-size:1.1rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}#pageSize{padding:.8rem 1rem;border:2px solid transparent;border-radius:10px;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(45deg,#667eea,#764ba2) border-box;font-weight:500;box-shadow:0 4px 15px #667eea1a}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background:#00000080}.modal-content{background:#fff;margin:5% auto;padding:0;border-radius:8px;width:90%;max-width:500px;border:1px solid #e2e8f0;box-shadow:0 10px 25px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:8px 8px 0 0}.modal-header h3{margin:0;color:#1e293b;font-size:1.25rem;font-weight:600;font-family:Rubik,sans-serif}#closeModal{background:#6b7280;border:none;font-size:1.25rem;cursor:pointer;color:#fff;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}#closeModal:hover{background:#374151}#recordForm{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem;font-family:Rubik,sans-serif}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:4px;font-size:1rem;font-family:Rubik,sans-serif;transition:border-color .2s ease;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.form-actions button{padding:.75rem 1.5rem;border:1px solid;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;font-family:Rubik,sans-serif;transition:all .2s ease}#saveRecord{background:#10b981;color:#fff;border-color:#059669}#saveRecord:hover{background:#059669}#cancelRecord{background:#6b7280;color:#fff;border-color:#4b5563}#cancelRecord:hover{background:#4b5563}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.container{padding:0 .5rem}.header h1{font-size:2rem}.controls{padding:1rem}.search-container input{width:100%;margin-bottom:1rem;margin-right:0}.filters{grid-template-columns:1fr;gap:1rem}.agg-results{grid-template-columns:repeat(2,1fr)}.table-header{flex-direction:column;gap:1rem;text-align:center}.table-controls{flex-direction:column;width:100%}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.5rem}.pagination{flex-direction:column;gap:1rem;text-align:center}.modal-content{margin:10% auto;width:95%}.form-actions{flex-direction:column}}@media (max-width: 480px){.agg-results{grid-template-columns:1fr}.data-table th,.data-table td{padding:.25rem;font-size:.75rem}.actions button{padding:.25rem .5rem;font-size:.75rem;margin:.1rem}}.loading-cell,.error-cell,.no-data-cell{text-align:center;padding:3rem 2rem;color:#6c757d}.loading-spinner{display:inline-block;width:2rem;height:2rem;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message,.no-data-message{display:flex;flex-direction:column;align-items:center;gap:1rem}.error-icon,.no-data-icon{font-size:3rem}.retry-btn{padding:.5rem 1rem;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.retry-btn:hover{background-color:#c82333}.footer{background:#fff;border-top:1px solid #e2e8f0;padding:1rem 0;margin-top:2rem;text-align:center}.footer p{color:#64748b;font-size:.75rem;font-family:Rubik,sans-serif;margin:0}.footer .developer{color:#374151;font-weight:500}@media print{.controls,.pagination,.actions,.table-controls,.footer{display:none!important}.table-container{box-shadow:none;border:1px solid #000}.data-table th,.data-table td{border:1px solid #000}}
