*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-dark:#1e40af;--secondary:#f59e0b;--success:#10b981;--danger:#ef4444;--warning:#f97316;--info:#06b6d4;--light:#f8fafc;--dark:#1f2937;--gray:#6b7280;--border:#e5e7eb;--page-color:#0891b2;--page-color-light:#0891b21a}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--light);color:var(--dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}html{scroll-behavior:smooth}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--light)}::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--gray)}.customer-management-container,.management-container,.pricing-management-container,.sample-management-container,.staff-management-container,.test-management-container{margin:0 auto;max-width:1200px}.customer-header,.page-header,.pricing-header,.sample-header,.staff-header,.test-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:20px}.customer-header h2,.page-header h2,.pricing-header h2,.sample-header h2,.staff-header h2,.test-header h2{color:#2c3e50;font-size:28px;font-weight:600;margin:0}.tab-navigation{border-bottom:2px solid #e0e0e0;display:flex;gap:10px;margin-bottom:20px}.tab-btn{background:none;border:none;border-bottom:3px solid #0000;bottom:-2px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;position:relative;transition:all .3s ease}.tab-btn:hover{background:#f5f5f5;color:#2c3e50}.tab-btn.active{border-bottom-color:#667eea;color:#667eea}.alert{align-items:center;animation:slideIn .3s ease;border-radius:6px;display:flex;gap:10px;margin-bottom:20px;padding:15px 20px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{background-color:#fee;border:1px solid #fcc;color:#c33}.alert-success{background-color:#efe;border:1px solid #cfc;color:#3c3}.alert span{font-weight:700}.close-btn{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;margin-left:auto;padding:0}.close-btn:hover{opacity:.7}.form-section{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin-bottom:30px;margin-top:0;padding:25px}.form-section h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 20px}.customer-form,.pricing-form,.sample-form,.staff-form,.test-form{display:flex;flex-direction:column;gap:20px;margin:0;padding:0}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group,.form-row{margin:0;padding:0}.form-group label{color:#2c3e50;font-size:14px;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px 12px 10px 10px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#0891b2;border-color:var(--page-color);box-shadow:0 0 0 3px #0891b21a;box-shadow:0 0 0 3px var(--page-color-light)}.form-actions{display:flex;gap:10px;margin-bottom:0;margin-top:10px;padding:0}.btn-submit{background:#0891b2;background:var(--page-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-submit:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-cancel{background:#e0e0e0;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-cancel:hover{background:#d0d0d0}.search-section{border-bottom:1px solid #e0e0e0;gap:15px;margin-bottom:25px;padding-bottom:15px}.search-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:14px;padding:10px 15px 10px 10px;transition:border-color .3s ease}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-count{color:#666;font-size:13px;white-space:nowrap}.loading,.no-data{color:#666;font-size:16px;padding:40px;text-align:center}.no-data{background:#f8f9fa;border:1px dashed #ddd;border-radius:6px;color:#999}.no-data-row{background:#f8fafc;border:1px dashed #ddd;border-radius:8px;color:#999;font-size:16px;grid-column:1/-1;padding:40px;text-align:center}.customer-list,.pricing-list,.sample-list,.samples-list,.staff-list,.test-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.customer-card,.pricing-card,.sample-card,.staff-card,.test-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.customer-card:hover,.pricing-card:hover,.sample-card:hover,.staff-card:hover,.test-card:hover{box-shadow:0 10px 15px -3px #0000001a;transform:translateY(-4px)}.add-customer-card,.add-pricing-card,.add-sample-card,.add-staff-card,.add-test-card{align-items:center;background:#fff;border:2px dashed #e5e7eb;border-left:4px solid #0891b2;border:2px dashed var(--border);border-left:4px solid var(--page-color);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:180px;padding:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.add-customer-card:hover,.add-pricing-card:hover,.add-sample-card:hover,.add-staff-card:hover,.add-test-card:hover{border-color:#0891b2;border-color:var(--page-color);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.add-customer-content,.add-pricing-content,.add-sample-content,.add-staff-content,.add-test-content{color:#1f2937;text-align:center}.add-customer-icon,.add-pricing-icon,.add-sample-icon,.add-staff-icon,.add-test-icon{align-items:center;background:#0891b21a;background:var(--page-color-light);border-radius:12px;display:flex;font-size:48px;height:80px;justify-content:center;margin-bottom:15px;margin-left:auto;margin-right:auto;width:80px}.add-customer-card h4,.add-pricing-card h4,.add-sample-card h4,.add-staff-card h4,.add-test-card h4{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 10px}.add-customer-card p,.add-pricing-card p,.add-sample-card p,.add-staff-card p,.add-test-card p{color:#6b7280;font-size:13px;margin:0}.customer-card-header,.pricing-card-header,.sample-card-header,.staff-card-header,.test-card-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:15px}.customer-info,.pricing-info,.sample-info,.staff-info,.test-info{flex:1 1}.customer-info h4,.pricing-info h4,.sample-info h4,.staff-info h4,.test-info h4{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 5px}.email,.test-id{color:#6b7280;font-size:13px;margin:0}.status-badge{padding:5px 10px}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#7f1d1d}.customer-card-details,.pricing-card-details,.sample-card-details,.staff-card-details,.test-card-details{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.detail-item{display:flex;font-size:13px;justify-content:space-between}.detail-label{color:#6b7280;font-weight:600}.detail-value{color:#1f2937}.customer-card-actions,.pricing-card-actions,.sample-card-actions,.staff-card-actions,.test-card-actions{display:flex;gap:10px}.btn-delete,.btn-edit{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:8px 12px;transition:all .3s ease}.btn-edit{background:#0891b21a;color:#0891b2;color:var(--page-color)}.btn-edit:hover{background:#0891b233;transform:translateY(-1px)}.btn-delete{background:#fee2e2;color:#b91c1c}.btn-delete:hover{background:#fecaca;transform:translateY(-1px)}@media (max-width:1024px){.customer-list,.pricing-list,.sample-list,.samples-list,.staff-list,.test-list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.customer-management-container,.management-container,.pricing-management-container,.sample-management-container,.staff-management-container,.test-management-container{max-width:100%;padding:0}.customer-header,.page-header,.pricing-header,.sample-header,.staff-header,.test-header{align-items:flex-start;flex-direction:column;gap:15px;margin-bottom:15px;padding:15px}.customer-header h2,.page-header h2,.pricing-header h2,.sample-header h2,.staff-header h2,.test-header h2{font-size:24px;width:100%}.form-row{grid-template-columns:1fr}.customer-list,.pricing-list,.sample-list,.samples-list,.staff-list,.test-list{grid-template-columns:1fr;padding:0 5px}.customer-card,.pricing-card,.sample-card,.staff-card,.test-card{border-radius:8px;padding:15px}.add-customer-card,.add-pricing-card,.add-sample-card,.add-staff-card,.add-test-card{min-height:150px;padding:20px}.add-customer-icon,.add-pricing-icon,.add-sample-icon,.add-staff-icon,.add-test-icon{font-size:36px;height:60px;width:60px}.search-section{align-items:stretch;flex-direction:column;gap:10px;padding:0 5px}.search-input{font-size:16px;padding:10px 12px 10px 10px;width:100%}.search-count{font-size:12px;text-align:center;width:100%}.form-section{border-radius:6px;margin-bottom:20px;padding:15px}.form-section h3{font-size:16px;margin-bottom:15px}.form-group label{font-size:13px}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:10px 12px 10px 10px}.form-actions{flex-direction:column;gap:8px}.btn-cancel,.btn-submit{font-size:14px;padding:12px;width:100%}.tab-navigation{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab-btn{flex-shrink:0;font-size:13px;padding:10px 15px;white-space:nowrap}.customer-card-header,.pricing-card-header,.sample-card-header,.staff-card-header,.test-card-header{flex-direction:column;gap:8px}.customer-info h4,.pricing-info h4,.sample-info h4,.staff-info h4,.test-info h4{font-size:14px}.customer-card-details,.pricing-card-details,.sample-card-details,.staff-card-details,.test-card-details{gap:8px}.detail-item{flex-direction:column;gap:4px}.detail-label,.detail-value{font-size:12px}.customer-card-actions,.pricing-card-actions,.sample-card-actions,.staff-card-actions,.test-card-actions{flex-direction:column;gap:8px}.btn-delete,.btn-edit{font-size:12px;padding:10px;width:100%}.alert{flex-direction:column;font-size:13px;padding:12px}.close-btn{font-size:16px;margin-top:8px}.loading,.no-data-row{font-size:14px;padding:30px 15px}}@media (max-width:480px){.customer-header h2,.page-header h2,.pricing-header h2,.sample-header h2,.staff-header h2,.test-header h2{font-size:20px}.customer-list,.pricing-list,.sample-list,.samples-list,.staff-list,.test-list{gap:10px}.customer-card,.pricing-card,.sample-card,.staff-card,.test-card{padding:12px}.add-customer-card,.add-pricing-card,.add-sample-card,.add-staff-card,.add-test-card{min-height:140px;padding:15px}.add-customer-icon,.add-pricing-icon,.add-sample-icon,.add-staff-icon,.add-test-icon{font-size:30px;height:50px;width:50px}.form-section{padding:12px}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:8px 12px 8px 10px}.tab-btn{font-size:12px;padding:8px 12px}.btn-cancel,.btn-submit{font-size:13px;padding:10px}.search-input{font-size:16px;padding:8px 10px}}\n .welcome-container{background:linear-gradient(135deg,#f8fafc,#f1f5f9);overflow-x:hidden;width:100%}.logo{font-size:1.5rem}.logo-icon{font-size:2rem}.logo-text{color:#2563eb}.nav-links{align-items:center;display:flex;gap:2rem}.nav-links a{color:#6b7280;font-weight:500;text-decoration:none;transition:color .3s ease}.nav-links a:hover{color:#2563eb}.hero{display:flex;margin:0 auto;max-width:1200px;padding:4rem 2rem}.hero,.hero-content{align-items:center;gap:4rem}.hero-content{grid-gap:4rem;display:grid;grid-template-columns:1fr 1fr;width:100%}.hero-text{animation:slideUp .6s ease-out}.hero-title{color:#1f2937;font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1rem}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#1e40af 50%,#06b6d4);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#6b7280;font-size:1.25rem;line-height:1.6;margin-bottom:2rem}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem}.btn{align-items:center;border:none;border-radius:.75rem;cursor:pointer;display:inline-flex;font-weight:600;justify-content:center;padding:1rem 2rem;text-align:center;text-decoration:none;transition:all .3s ease}.btn-large{font-size:1.1rem;padding:1.25rem 2.5rem}.btn-primary{box-shadow:0 10px 20px #2563eb4d}.btn-primary:hover{box-shadow:0 15px 30px #2563eb66;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;box-shadow:0 10px 20px #06b6d44d}.btn-secondary:hover{background:linear-gradient(135deg,#0891b2,#067a8c);box-shadow:0 15px 30px #06b6d466}.hero-image{height:400px}.hero-illustration,.hero-image{align-items:center;display:flex;justify-content:center;position:relative}.hero-illustration{height:100%;width:100%}.lab-beaker{animation:float 3s ease-in-out infinite;font-size:5rem;left:50px;position:absolute;top:20px}.lab-chart{animation:float 3.5s ease-in-out .5s infinite;bottom:40px;left:80px}.lab-chart,.lab-clipboard{font-size:4rem;position:absolute}.lab-clipboard{animation:float 3s ease-in-out 1s infinite;right:80px;top:100px}.lab-users{animation:float 3.5s ease-in-out 1.5s infinite;bottom:80px;font-size:4rem;position:absolute;right:50px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.features{margin:0 auto;max-width:1200px;padding:5rem 2rem;text-align:center}.features h2{color:#1f2937;font-size:2.5rem;font-weight:800;margin-bottom:1rem}.section-subtitle{color:#6b7280;font-size:1.1rem;margin-bottom:3rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{animation:slideUp .6s ease-out forwards;background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000000d;opacity:0;padding:2rem;transition:all .3s ease}.feature-card:first-child{animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:nth-child(4){animation-delay:.4s}.feature-card:nth-child(5){animation-delay:.5s}.feature-card:nth-child(6){animation-delay:.6s}.feature-card:hover{box-shadow:0 15px 30px #0000001a;transform:translateY(-10px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#1f2937;font-size:1.3rem;font-weight:700;margin-bottom:.75rem}.feature-card p{color:#6b7280;line-height:1.6}.stats{background:linear-gradient(135deg,#2563eb,#1e40af);margin:3rem 0;padding:4rem 2rem}.stats-container{grid-gap:2rem;color:#fff;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0 auto;max-width:1200px;text-align:center}.stat-item{animation:slideUp .6s ease-out}.stat-number{font-size:3rem;font-weight:800;text-shadow:0 2px 4px #0000001a}.stat-label{font-size:1rem;opacity:.9}.about{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;padding:5rem 2rem}.about-content h2{color:#1f2937;font-size:2.5rem;font-weight:800;margin-bottom:1.5rem}.about-content p{color:#6b7280;font-size:1.1rem;line-height:1.8;margin-bottom:2rem}.about-features{align-items:center;color:#1f2937;display:flex;font-weight:500;gap:1rem;margin-bottom:1.5rem}.checkmark{background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;color:#fff;flex-shrink:0;font-weight:700;height:30px;width:30px}.about-image,.checkmark{align-items:center;display:flex;justify-content:center}.about-image{height:400px;position:relative}.about-illustration{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.circle{border-radius:50%;position:absolute}.circle-1{animation:pulse 4s ease-in-out infinite;background:#2563eb1a;height:300px;width:300px}.circle-2{animation:pulse 4s ease-in-out .5s infinite;background:#2563eb33;height:200px;width:200px}.circle-3{animation:pulse 4s ease-in-out 1s infinite;background:linear-gradient(135deg,#2563eb,#06b6d4);height:100px;width:100px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.cta{background:linear-gradient(135deg,#2563eb,#1e40af 50%,#06b6d4);border-radius:1.5rem;color:#fff;margin:3rem auto;max-width:900px;padding:4rem 2rem;text-align:center}.cta h2{font-size:2.5rem;font-weight:800;margin-bottom:1rem}.cta p{font-size:1.1rem;margin-bottom:2rem;opacity:.9}.footer{margin-top:3rem}@media (max-width:768px){.hero-content{gap:2rem;grid-template-columns:1fr}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-buttons{flex-direction:column}.btn-large{width:100%}.hero-illustration{height:300px}.lab-beaker,.lab-chart,.lab-clipboard,.lab-users{font-size:3rem!important}.features h2{font-size:2rem}.about{grid-template-columns:1fr;padding:3rem 2rem}.nav-links{gap:1rem}.navbar-content{padding:1rem}.logo-icon{font-size:1.5rem}.hero{padding:2rem 1rem}.features{padding:3rem 1rem}.stats-container{grid-template-columns:1fr 1fr}.cta h2{font-size:1.75rem}.footer-content{grid-template-columns:1fr}}@media (max-width:480px){.hero-title{font-size:1.75rem}.features h2{font-size:1.5rem}.features-grid,.stats-container{gap:1rem;grid-template-columns:1fr}.stat-number{font-size:2rem}.cta{margin:1rem;padding:2rem 1rem}}.login-page{background:linear-gradient(135deg,#f8fafc,#f1f5f9);display:flex;flex-direction:column;min-height:100vh}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 2px 10px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 2rem}.logo{color:#2563eb!important;text-decoration:none}.logo-icon{color:#2563eb}.logo-text{-webkit-text-fill-color:unset!important;text-fill-color:#2563eb!important}.navbar .logo .logo-text{-webkit-text-fill-color:unset!important;background:none!important;-webkit-background-clip:unset!important;background-clip:initial!important;color:#2563eb!important}.login-container{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:2rem;position:relative;z-index:10}.login-content{max-width:1000px;position:relative;width:100%;z-index:10}.login-wrapper{grid-gap:0;align-items:stretch;background-image:url(/static/media/chemical-science-laboratory.4c99d452c63bf0da0001.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:1.5rem;box-shadow:0 25px 50px #0000004d;display:grid;gap:0;grid-template-columns:1fr 1fr;min-height:500px;overflow:hidden;position:relative}.login-wrapper:before{background:linear-gradient(135deg,#2563eb80,#1e40af80);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.login-image-section{display:none}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:0;display:flex;flex-direction:column;grid-column:2;padding:3rem;position:relative;z-index:2}.login-header{margin-bottom:2rem;text-align:left}.login-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#1e40af);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:#6b7280;font-size:1rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.error-message{align-items:flex-start;animation:slideDown .3s ease-out;background-color:#fee2e2;border-left:4px solid #dc2626;border-radius:.75rem;color:#991b1b;display:flex;font-weight:500;gap:.75rem;padding:1rem}.form-group{gap:.5rem}.form-group label{color:#1f2937}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{font-size:1.3rem;left:1rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.form-group input{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;font-family:inherit;font-size:1rem;padding:.75rem 1rem .75rem 3.2rem!important;transition:all .3s ease;width:100%}.form-group input:focus{background:#f8fafc;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-group input:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.login-button{align-items:center;background:linear-gradient(135deg,#2563eb,#1e40af);border:none;border-radius:.75rem;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;margin-top:.5rem;padding:.875rem 1.5rem;transition:all .3s ease}.login-button:hover:not(:disabled){box-shadow:0 10px 20px #2563eb4d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.7}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.demo-section{background:#f0f9ff;border-left:3px solid #2563eb;border-radius:.75rem;padding:1.5rem}.demo-title{color:#1f2937;font-size:.95rem;font-weight:700;margin-bottom:1rem}.demo-cred{background:#fff;border-radius:.5rem;padding:.75rem}.demo-cred p{color:#4b5563;font-family:Courier New,monospace;font-size:.85rem;margin:.4rem 0}.demo-cred strong{color:#2563eb;font-weight:600}.footer{background:#1f2937;color:#e5e7eb;margin-top:auto;padding:3rem 2rem 1rem}.footer-content{grid-gap:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto 2rem}.footer-section h4{color:#fff;font-weight:700;margin-bottom:1rem}.footer-section p{line-height:1.8}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:.75rem}.footer-section a{color:#9ca3af;text-decoration:none;transition:color .3s ease}.footer-section a:hover{color:#2563eb}.footer-logo-section{align-items:center;display:flex;flex-direction:column;text-align:center}.footer-logo{height:50px;margin:1rem 0;opacity:.9;transition:opacity .3s ease;width:auto}.footer-logo:hover{opacity:1}.footer-company{color:#e5e7eb;font-weight:600;margin-top:.5rem}.footer-bottom{border-top:1px solid #374151;color:#9ca3af;margin:0 auto;max-width:1200px;padding-top:2rem;text-align:center}@media (max-width:900px){.login-wrapper{grid-template-columns:1fr;min-height:auto}.login-card{background:#fffffffa;grid-column:1;padding:2.5rem}.login-header h1{font-size:1.5rem}.login-header p{font-size:.9rem}}@media (max-width:600px){.login-container{padding:1rem}.login-card{padding:1.5rem}.login-wrapper:before{background:linear-gradient(135deg,#2563eb99,#1e40af99)}.login-header h1{font-size:1.25rem}.demo-cred p{font-size:.75rem}}@media (max-width:400px){.login-header h1{font-size:1.1rem}.login-card{padding:1.25rem}.demo-cred p{font-size:.7rem}}.login-button:focus{outline:2px solid #2563eb;outline-offset:2px}.form-group input:focus{outline:2px solid #2563eb;outline-offset:0}\n *{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#2563eb;--secondary-color:#1e40af;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--info-color:#06b6d4;--light-bg:#f8fafc;--white:#fff;--text-dark:#1f2937;--text-light:#6b7280;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}body{color:#1f2937;color:var(--text-dark);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.dashboard-container,body{background-color:#f8fafc;background-color:var(--light-bg)}.dashboard-container{display:flex;flex-direction:column;min-height:100vh}.dashboard-navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 2px 10px #0000000d;color:#1f2937;color:var(--text-dark);justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.dashboard-navbar,.navbar-left,.navbar-right{align-items:center;display:flex}.navbar-right{gap:2rem}.logo{align-items:center;color:#2563eb;color:var(--primary-color);display:flex;font-size:1.3rem;font-weight:700;gap:.75rem}.logo-icon{font-size:1.75rem}.logo-text{-webkit-text-fill-color:unset;background:none!important;background-clip:initial!important;-webkit-background-clip:unset!important;color:#2563eb!important;color:var(--primary-color)!important;font-weight:700}.user-info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:3px solid #2563eb;border-left:3px solid var(--primary-color);border-radius:8px;display:flex;flex-direction:column;gap:.5rem;min-width:220px;padding:.75rem 1rem;text-align:right}.user-details{gap:.25rem}.user-name{color:#1f2937;color:var(--text-dark)}.user-role{color:#6b7280;color:var(--text-light)}.user-entity{border-top:1px solid #2563eb33;color:#2563eb;color:var(--primary-color);padding-top:.25rem}.logout-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:6px;box-shadow:0 2px 4px #ef444433;color:#fff;color:var(--white);cursor:pointer;font-size:.9rem;font-weight:600;padding:.6rem 1.2rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.logout-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef444466;transform:translateY(-2px)}.logout-btn:active{transform:translateY(0)}.dashboard-wrapper{flex:1 1;overflow-y:auto;padding:2rem}.dashboard-content{display:flex;flex-direction:column}.dashboard-header{align-items:center;background:linear-gradient(135deg,#fee2e2,#f8fafc);border:1px solid #fecaca;border-radius:12px;box-shadow:0 2px 8px #0000000d;color:#1f2937;color:var(--text-dark);display:flex;justify-content:space-between;margin-bottom:2.5rem;padding:2rem}.header-content h1{color:#1f2937;color:var(--text-dark);font-size:2rem;font-weight:700;margin-bottom:.5rem}.header-content p{opacity:.8}.header-content p,.header-date{color:#6b7280;color:var(--text-light);font-size:.95rem}.header-date{opacity:.7;text-align:right}.charts-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:2rem}.chart-card{background:var(--white);border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.chart-card:hover{box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.chart-card .card-header{border:none;margin-bottom:1.5rem;padding:0}.chart-card h2,.chart-card h3{color:#1f2937;color:var(--text-dark);font-size:1.1rem;font-weight:600;margin:0}.chart-container{height:auto;width:100%}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{background:#fff;background:var(--white);border-left:4px solid;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);cursor:pointer;display:flex;gap:1.5rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.stat-card:hover{box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-card.samples{background:linear-gradient(135deg,#f0f4ff,#fff);border-left-color:#2563eb}.stat-card.sample-mgmt{background:linear-gradient(135deg,#f0fdf4,#fff);border-left-color:#10b981}.stat-card.customers{background:linear-gradient(135deg,#fee2e2,#fff);border-left-color:#dc2626}.stat-card.invoices{background:linear-gradient(135deg,#fef3c7,#fff);border-left-color:#f59e0b}.stat-card.pricing{background:linear-gradient(135deg,#f5f3ff,#fff);border-left-color:#8b5cf6}.stat-card.staff{background:linear-gradient(135deg,#ecf6ff,#fff);border-left-color:#06b6d4}.stat-icon{align-items:center;background-color:#f8fafc;background-color:var(--light-bg);border-radius:10px;display:flex;font-size:2.5rem;height:60px;justify-content:center;width:60px}.stat-card.samples .stat-icon{background-color:#2563eb26}.stat-card.sample-mgmt .stat-icon{background-color:#10b98126}.stat-card.customers .stat-icon{background-color:#dc262626}.stat-card.invoices .stat-icon{background-color:#f59e0b26}.stat-card.pricing .stat-icon{background-color:#8b5cf626}.stat-card.staff .stat-icon{background-color:#06b6d426}.stat-content h3{color:#6b7280;color:var(--text-light);font-size:.9rem;font-weight:600;margin-bottom:.5rem}.stat-number{color:#1f2937;color:var(--text-dark);font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#6b7280;color:var(--text-light);font-size:.8rem}.stat-label .pending{color:#ef4444;color:var(--danger-color);font-weight:600}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.card{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.card:hover{border-color:#d1d5db;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.card-header{align-items:center;background-color:#fff;background-color:var(--white);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:2rem}.card-header h2{color:#1f2937;color:var(--text-dark);font-size:1.25rem;font-weight:600}.view-all{color:#2563eb;color:var(--primary-color);font-size:.9rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.view-all:hover{color:#1e40af;color:var(--secondary-color)}.badge{background-color:#ef4444;background-color:var(--danger-color);border-radius:20px;color:#fff;color:var(--white);font-size:.8rem;font-weight:600;padding:.25rem .75rem}.card-body{padding:2rem}.action-buttons{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));width:100%}.action-btn{background:#fff;background:var(--white);border-left:4px solid;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:inherit;display:flex;gap:1.5rem;padding:1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.btn-icon{font-size:2.5rem}.btn-orange{background-color:#fff;background-color:var(--white);border-left-color:#fed7aa;color:#92400e}.btn-orange:hover{background-color:#fffbeb;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background-color:#fff;background-color:var(--white);border-left-color:#f59e0b;border-left-color:var(--warning-color);color:#fff;color:var(--white)}.btn-secondary:hover{background-color:#fffbeb;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-success{background-color:#fff;background-color:var(--white);border-left-color:#10b981;border-left-color:var(--success-color);color:#fff;color:var(--white)}.btn-success:hover{background-color:#f0fdf4;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-info{background-color:#fff;background-color:var(--white);border-left-color:#06b6d4;border-left-color:var(--info-color);color:#fff;color:var(--white)}.btn-info:hover{background-color:#ecf9ff;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.items-list{display:flex;flex-direction:column;gap:1rem}.item{align-items:center;background-color:#f8fafc;background-color:var(--light-bg);border-radius:8px;display:flex;justify-content:space-between;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.item:hover{background-color:#f1f5f9}.item-info{flex:1 1}.item-title{color:#1f2937;color:var(--text-dark);font-weight:600;margin-bottom:.25rem}.item-subtitle{color:#6b7280;color:var(--text-light);font-size:.85rem}.item-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.4rem .8rem;text-transform:uppercase}.item-badge.success{background-color:#10b9811a;color:#10b981;color:var(--success-color)}.item-badge.pending{background-color:#f59e0b1a;color:#f59e0b;color:var(--warning-color)}.item-badge.info{background-color:#06b6d41a;color:#06b6d4;color:var(--info-color)}.item-badge.default{background-color:#6b72801a;color:#6b7280;color:var(--text-light)}.metric{margin-bottom:1.5rem}.metric:last-child{margin-bottom:0}.metric-label{align-items:center;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:.5rem}.metric-label span:first-child{color:#6b7280;color:var(--text-light);font-weight:500}.metric-value{color:#2563eb;color:var(--primary-color);font-weight:700}.metric-bar{background-color:#f8fafc;background-color:var(--light-bg);border-radius:4px;height:8px;overflow:hidden;width:100%}.metric-progress{background:linear-gradient(90deg,#2563eb,#1e40af);background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:4px;height:100%;transition:width .3s ease}.task{background-color:#f8fafc;background-color:var(--light-bg);border-radius:8px;display:flex;gap:1rem;margin-bottom:.75rem;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.task:last-child{margin-bottom:0}.task:hover{background-color:#f1f5f9}.task-checkbox{align-items:center;background-color:#10b981;background-color:var(--success-color);border-radius:50%;color:#fff;color:var(--white);display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.task-info{flex:1 1}.task-title{color:#1f2937;color:var(--text-dark);font-weight:600;margin-bottom:.25rem}.task-time{color:#6b7280;color:var(--text-light);font-size:.85rem}.dashboard-footer{background:#fff;background:var(--white);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);margin-top:2rem;padding:1.5rem 2rem}.footer-content{align-items:center;display:flex;gap:2rem;justify-content:space-between;margin:0 auto;max-width:1200px}.footer-info{flex:1 1}.footer-branding,.footer-info{color:#6b7280;color:var(--text-light);font-size:.9rem}.footer-branding{align-items:center;display:flex;gap:.75rem}.footer-logo-small{height:30px;opacity:.8;transition:opacity .3s ease;width:auto}.footer-logo-small:hover{opacity:1}.footer-company-name{color:#2563eb;color:var(--primary-color);font-weight:600}@media (max-width:768px){.dashboard-container{flex-direction:column}.dashboard-content{max-width:100%;padding:1rem}.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.header-content h1{font-size:1.5rem}.header-date{font-size:.9rem;text-align:center}.charts-section,.dashboard-grid,.stats-grid{gap:1rem;grid-template-columns:1fr}.action-buttons{gap:.75rem;grid-template-columns:repeat(2,1fr)}.action-buttons button{font-size:.85rem;padding:.75rem}.stat-card{flex-direction:row;padding:1rem}.stat-icon{font-size:1.5rem}.stat-info h3{font-size:.9rem}.stat-info p{font-size:.75rem}.card{border-radius:.5rem}.card-body,.card-header{padding:.75rem 1rem}}@media (max-width:480px){.dashboard-content{padding:.5rem}.header-content h1{font-size:1.2rem}.dashboard-grid,.stats-grid{gap:.75rem;grid-template-columns:1fr}.action-buttons{gap:.5rem;grid-template-columns:1fr}.action-buttons button{font-size:.8rem;padding:.6rem;width:100%}.stat-card{padding:.75rem}.stat-icon{font-size:1.2rem}.stat-info h3{font-size:.8rem}.stat-info p{font-size:.7rem}.card-body,.card-header{padding:.5rem .75rem}}.staff-members-card{grid-column:1/-1}.staff-members-list{display:flex;flex-direction:column;gap:12px}.staff-member-item{align-items:center;background:#f8fafc;background:var(--light-bg);border-left:3px solid #2563eb;border-left:3px solid var(--primary-color);border-radius:6px;display:flex;justify-content:space-between;padding:12px;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.staff-member-item:hover{background:#f0f4f8;transform:translateX(4px)}.staff-member-info{flex:1 1}.staff-name{color:#1f2937;color:var(--text-dark);font-size:14px;font-weight:600;margin:0}.staff-email{color:#6b7280;color:var(--text-light);font-size:12px;margin:4px 0 0}.staff-member-role{margin:0 15px}.role-badge{background:#2563eb;background:var(--primary-color);border-radius:12px;color:#fff;color:var(--white);display:inline-block;font-size:12px;font-weight:600;padding:4px 10px}.status-indicator{font-size:16px;min-width:20px}.no-staff-message{color:#6b7280;color:var(--text-light);padding:20px;text-align:center}.no-staff-message p{font-size:14px;margin:0 0 10px}.action-link{color:#2563eb;color:var(--primary-color);font-size:13px;font-weight:600;text-decoration:none}.action-link:hover{text-decoration:underline}.view-more-staff{background:#f8fafc;background:var(--light-bg);border-radius:6px;color:#6b7280;color:var(--text-light);font-size:13px;margin-top:8px;padding:12px;text-align:center}.view-more-staff p{margin:0}.card{animation:fadeIn .3s ease-out}.dashboard-content::-webkit-scrollbar{width:8px}.dashboard-content::-webkit-scrollbar-track{background:#f8fafc;background:var(--light-bg)}.dashboard-content::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}.dashboard-content::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--text-light)}.user-info-header{background:linear-gradient(135deg,#fee2e2,#fecaca);border-left:4px solid #dc2626;border-radius:8px;box-shadow:0 4px 12px #dc262626;gap:.5rem;min-width:240px;padding:1rem 1.2rem;position:fixed;right:20px;top:20px;z-index:999}.user-details,.user-info-header{display:flex;flex-direction:column}.user-details{gap:.3rem}.user-name{color:#7f1d1d;font-size:.95rem;font-weight:700}.user-role{color:#991b1b;font-size:.85rem;font-weight:500}.user-entity{border-top:2px solid #dc26264d;color:#dc2626;font-size:.85rem;font-weight:600;padding-top:.35rem}.test-results-modal-overlay{align-items:center;animation:fadeIn .2s ease-in;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.test-results-modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:1000px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.test-results-modal-header{align-items:center;background:linear-gradient(135deg,#0891b2,#06b6d4);border-radius:12px 12px 0 0;color:#fff;display:flex;gap:15px;justify-content:space-between;padding:25px;position:relative}.test-results-modal-header h2{flex:1 1;font-size:22px;font-weight:700;margin:0}.customer-info{background:#fff3;border-radius:20px;font-size:18px;font-weight:700;letter-spacing:.3px;padding:8px 16px;white-space:nowrap}.test-results-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:32px;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.test-results-modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.test-results-error-message{background:#fee2e2;border-left:4px solid #dc2626;color:#991b1b}.test-results-error-message,.test-results-success-message{align-items:center;border-radius:8px;display:flex;font-weight:500;gap:10px;margin:15px;padding:12px 20px}.test-results-success-message{animation:slideDown .3s ease-out;background:#dcfce7;border-left:4px solid #22c55e;color:#166534}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.test-results-modal-body{flex:1 1;overflow-y:auto;padding:20px}.test-results-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.test-results-loading .spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#0891b2;height:40px;margin-bottom:15px;width:40px}.test-results-empty{align-items:center;color:#999;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.test-results-empty p{font-size:16px;margin:0}.test-results-table{overflow-x:auto}.test-results-table table{background:#fff;border-collapse:collapse;width:100%}.test-results-table thead{background:#f3f4f6;position:-webkit-sticky;position:sticky;top:0}.test-results-table th{font-size:13px;letter-spacing:.5px;padding:15px;text-transform:uppercase}.test-results-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s ease}.test-results-table tbody tr:hover{background:#f9fafb}.test-results-table tbody tr.has-result{background:#f0fdf4}.test-results-table td{padding:15px;vertical-align:middle}.test-name{width:20%}.test-value{width:25%}.test-unit{width:15%}.test-remarks{width:25%}.test-status{text-align:center;width:15%}.remarks-textarea,.test-input,.unit-input{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s ease;width:100%}.remarks-textarea:focus,.test-input:focus,.unit-input:focus{background:#f0fdff;border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a;outline:none}.test-input{text-align:right}.remarks-textarea{min-height:50px;resize:vertical}.status-badge{font-size:12px;padding:6px 12px}.status-badge.saved{background:#d1fae5;color:#065f46}.status-badge.modified{background:#fef3c7;color:#92400e}.status-badge.pending{background:#e0e7ff;color:#3730a3}.test-results-modal-footer{background:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 25px}.test-results-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.test-results-btn.save-btn{background:linear-gradient(135deg,#0891b2,#06b6d4);color:#fff}.test-results-btn.save-btn:hover:not(:disabled){box-shadow:0 10px 20px #0891b24d;transform:translateY(-2px)}.test-results-btn.close-btn{background:#e5e7eb;color:#6b7280}.test-results-btn.close-btn:hover:not(:disabled){background:#d1d5db}.test-results-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:900px){.test-results-modal-content{max-height:90vh;width:95%}.test-results-modal-header{flex-wrap:wrap;gap:10px}.test-results-modal-header h2{font-size:18px;order:1;width:100%}.customer-info{order:2}.test-results-modal-close{order:3}.test-name{width:25%}.test-value{width:20%}.test-unit{width:15%}.test-remarks{width:25%}.test-status{width:15%}}@media (max-width:768px){.test-results-modal-content{max-height:95vh;width:98%}.test-results-table{font-size:12px}.test-results-table th{font-size:11px;padding:10px}.test-results-table td{padding:10px}.remarks-textarea,.test-input,.unit-input{font-size:13px;padding:8px 10px}.test-results-btn{font-size:13px;padding:10px 16px}.test-results-modal-footer{flex-direction:column}.test-results-btn{justify-content:center;width:100%}}@media (max-width:500px){.test-results-modal-header{padding:15px}.test-results-modal-header h2{font-size:16px}.customer-info{font-size:14px;padding:6px 10px}.test-results-modal-body,.test-results-modal-footer{padding:15px}.test-results-table th{font-size:10px;padding:8px}.test-results-table td{padding:8px}.remarks-textarea,.test-input,.unit-input{font-size:12px;padding:6px 8px}.remarks-textarea{min-height:40px}.status-badge{font-size:10px;padding:4px 8px}}\n .samples-container{margin:0 auto;max-width:1400px;padding:2rem}.samples-header{border-bottom:2px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1.5rem}.samples-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#1e40af);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.5rem}.samples-header p{color:#6b7280;font-size:1rem;margin:0}.error-icon{flex-shrink:0;font-size:1.25rem}.retry-btn{background-color:#dc2626;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-left:auto;padding:.4rem .8rem;transition:all .3s ease}.retry-btn:hover{background-color:#b91c1c}.success-alert{align-items:center;background-color:#dcfce7;border-left:4px solid #10b981;border-radius:.75rem;color:#166534;display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.success-icon{flex-shrink:0;font-size:1.25rem}.close-alert-btn{background:none;border:none;color:inherit;cursor:pointer;font-size:1.5rem;margin-left:auto;padding:0;transition:all .3s ease}.close-alert-btn:hover{opacity:.7}.search-section{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.search-box{flex:1 1;min-width:300px;position:relative}.add-sample-btn{background-color:#10b981;border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.add-sample-btn:hover{background-color:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.search-icon{font-size:1.1rem;pointer-events:none;position:absolute;right:1rem;top:50%;transform:translateY(-50%);z-index:1}.search-input{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;font-family:inherit;font-size:1rem;padding:.75rem 1rem .75rem .75rem;transition:all .3s ease;width:100%}.search-input:focus{background:#f8fafc;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.results-info{color:#6b7280;font-size:.9rem;font-weight:500;white-space:nowrap}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.spinner{animation:spin .8s linear infinite;border:4px solid #2563eb1a;border-radius:50%;border-top-color:#2563eb;display:inline-block;height:40px;margin-bottom:1rem;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.loading-state p{color:#6b7280;font-size:1rem;margin:0}.empty-state{background:#f8fafc;border:2px dashed #e5e7eb;border-radius:1rem;padding:3rem}.table-wrapper{background:#fff;border-radius:.875rem;box-shadow:0 1px 3px #0000001a;overflow-x:auto;overflow-y:hidden}.samples-table{border-collapse:collapse;font-size:.95rem;width:100%}.samples-table thead{background:linear-gradient(135deg,#f0f4f8,#e8eef5);border-bottom:2px solid #e5e7eb}.samples-table th{color:#1f2937;font-size:.85rem;font-weight:700;letter-spacing:.5px;padding:1rem 1.25rem;text-align:left;text-transform:uppercase}.samples-table tbody tr{border-bottom:1px solid #e5e7eb;transition:all .3s ease}.samples-table tbody tr:hover{background-color:#f8fafc;box-shadow:inset 0 0 0 1px #2563eb1a}.samples-table tbody tr:last-child{border-bottom:none}.samples-table td{color:#374151;padding:1rem 1.25rem}.table-ref{color:#2563eb;font-weight:600}.table-ref strong{font-size:1.05rem}.table-customer{color:#1f2937;font-weight:500;min-width:150px}.table-date{color:#6b7280;font-size:.9rem;min-width:140px}.table-description{color:#6b7280;font-size:.9rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-created{color:#9ca3af;font-size:.9rem;min-width:140px}.table-created-by,.table-updated-by{color:#6b7280;font-size:.9rem;min-width:120px}.table-status{text-align:center}.status-badge{border-radius:.5rem;letter-spacing:.5px}.status-badge.active{background-color:#10b9811a;color:#10b981}.status-badge.pending{background-color:#f59e0b1a;color:#f59e0b}.status-badge.completed{background-color:#2563eb1a;color:#2563eb}.table-actions{min-width:130px;text-align:center;white-space:nowrap}.actions-row{display:flex;flex-wrap:nowrap;gap:.5rem}.action-btn,.actions-row{align-items:center;justify-content:center}.action-btn{border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:1rem;height:36px;transition:all .3s ease;width:36px}.view-btn{background-color:#e0f2fe;color:#0369a1}.view-btn:hover{background-color:#bae6fd;transform:scale(1.1)}.edit-btn{background-color:#fef3c7;color:#d97706}.edit-btn:hover{background-color:#fde68a;transform:scale(1.1)}.results-btn{background-color:#dbeafe;color:#0891b2}.results-btn:hover{background-color:#bfdbfe;transform:scale(1.1)}.delete-btn{background-color:#fee2e2;color:#dc2626}.delete-btn:hover{background-color:#fecaca;transform:scale(1.1)}@media (max-width:1024px){.samples-container{padding:1.5rem}.table-wrapper{overflow-x:auto}.samples-table{font-size:.9rem}.samples-table td,.samples-table th{padding:.75rem 1rem}}@media (max-width:768px){.samples-container{padding:1rem}.samples-header h1{font-size:1.5rem}.search-section{flex-direction:column}.search-box{min-width:100%}.results-info{text-align:center;width:100%}.add-sample-btn{width:100%}.table-wrapper{overflow-x:auto}.samples-table{font-size:.85rem;min-width:600px}.samples-table td,.samples-table th{padding:.6rem .8rem}.action-btn{font-size:.9rem;height:32px;margin:0 .15rem;width:32px}}@media (max-width:480px){.samples-container{padding:.75rem}.samples-header h1{font-size:1.25rem}.samples-header p{font-size:.9rem}.search-input{font-size:16px}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.samples-table{font-size:.8rem;min-width:500px}.samples-table td,.samples-table th{padding:.5rem .6rem}.action-btn{font-size:.85rem;height:30px;margin:0 .1rem;width:30px}.table-ref strong{font-size:.95rem}}@media print{.action-btn,.search-section{display:none}.samples-table{font-size:.9rem}.table-wrapper{box-shadow:none}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:.875rem;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem;position:-webkit-sticky;position:sticky;top:0}.modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;display:flex;font-size:1.75rem;height:36px;justify-content:center;padding:0;transition:all .3s ease;width:36px}.modal-close:hover{background-color:#f3f4f6;color:#1f2937}.modal-body{padding:1.5rem}.detail-row{grid-gap:1rem;align-items:flex-start;border-bottom:1px solid #f3f4f6;display:grid;gap:1rem;grid-template-columns:1fr 1fr;padding:.75rem 0}.detail-row:last-child{border-bottom:none}.detail-row label{color:#374151;font-weight:600;margin:0;padding:0;text-align:left}.detail-row span{color:#1f2937;margin:0;padding:0;text-align:left;word-break:break-word}.form-group{display:flex;flex-direction:column;margin-bottom:1rem}.form-group label{color:#374151;display:block;font-size:.95rem;font-weight:600;margin:0 0 .5rem;padding:0}.form-group input,.form-group select,.form-group textarea{background-clip:padding-box;border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box;font-family:inherit;font-size:.95rem;line-height:1.5;margin:0;padding:.75rem;text-align:left;transition:all .3s ease;width:100%}.form-group input[type=date],.form-group input[type=datetime-local],.form-group input[type=email],.form-group input[type=number],.form-group input[type=text],.form-group input[type=time]{padding:.75rem;text-align:left}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f3f4f6;cursor:not-allowed}.form-group textarea{min-height:80px;resize:vertical}.tests-checkbox-group{grid-gap:1rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);max-height:300px;overflow-y:auto;padding:.75rem}.checkbox-label{align-items:center;border-radius:.25rem;color:#374151;cursor:pointer;display:flex;flex-wrap:wrap;font-size:.95rem;gap:.5rem;padding:.5rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.checkbox-label:hover{background-color:#fff;box-shadow:0 1px 3px #0000001a;color:#1f2937}.checkbox-label input[type=checkbox]{accent-color:#10b981;cursor:pointer;flex-shrink:0;height:18px;width:18px}.checkbox-label input[type=checkbox]:hover{transform:scale(1.05)}.checkbox-label input[type=checkbox]:focus{outline:2px solid #10b981;outline-offset:2px}.selected-count{color:#10b981;font-size:.85rem;font-weight:600;margin-top:.5rem}.no-tests-message{color:#6b7280;font-size:.9rem;font-style:italic;margin-top:.5rem}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.modal-btn{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;color:#374151;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:all .3s ease}.modal-btn:hover{background-color:#f9fafb;border-color:#d1d5db}.close-btn{background-color:#f3f4f6;color:#6b7280}.close-btn:hover{background-color:#e5e7eb;color:#374151}.save-btn{background-color:#10b981;border-color:#10b981;color:#fff}.save-btn:hover{background-color:#059669;border-color:#059669}@media (max-width:768px){.modal-overlay{padding:.5rem}.modal-content{max-height:90vh}.modal-header h2{font-size:1.25rem}.detail-row{gap:.25rem;grid-template-columns:1fr}.detail-row label{margin-bottom:0}.detail-row span{text-align:left}.tests-checkbox-group{gap:.75rem;grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.tests-checkbox-group{gap:.5rem;grid-template-columns:1fr}.checkbox-label{font-size:.9rem;padding:.35rem}}\n
:root{--page-color:#0891b2;--page-color-light:#0891b21a;--page-color:#dc2628;--page-color-light:#dc26261a;--page-color:#10b981;--page-color-light:#10b9811a;--page-color:#8b5cf6;--page-color-light:#8b5cf61a}.reports-container{background:#f8fafc;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.reports-header{border-bottom:2px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1.5rem}.reports-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#1e40af);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.5rem}.reports-header p{color:#6b7280;font-size:1rem;margin:0}.reports-controls{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem;padding:2rem}.controls-dates,.controls-top{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.controls-dates{border-bottom:2px solid #f3f4f6;padding-bottom:1.5rem}.control-group,.controls-dates .control-group,.controls-top .control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{color:#374151;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.date-input,.report-select{background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:all .3s ease}.date-input:focus,.report-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.control-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-start}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #2563eb4d;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid #2563eb;color:#2563eb}.btn-secondary:hover:not(:disabled){background:#f0f4ff;transform:translateY(-2px)}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.error-alert{align-items:center;background-color:#fee2e2;border-left:4px solid #dc2626;border-radius:.75rem;color:#991b1b;display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.report-content{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem}.report-title-section{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.report-title-section h2{color:#1f2937;font-size:1.5rem;margin:0}.report-timestamp{color:#6b7280;font-size:.9rem}.metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.metric-card{background:linear-gradient(135deg,#f0f4ff,#fff);border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s ease}.metric-card:hover{border-color:#2563eb;box-shadow:0 4px 12px #0000001a;transform:translateY(-4px)}.metric-number{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.metric-label{color:#6b7280;font-size:.95rem;font-weight:500}.distribution-report{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-top:2rem}.chart-container{align-items:center;display:flex;justify-content:center}.chart-bars{gap:1.5rem;width:100%}.bar-item,.chart-bars{display:flex;flex-direction:column}.bar-item{gap:.5rem}.bar-label{color:#374151;font-size:.95rem;font-weight:600}.bar-wrapper{background:#f3f4f6;border-radius:8px;height:40px;overflow:hidden}.bar-fill{align-items:center;background:linear-gradient(90deg,#2563eb,#06b6d4);display:flex;font-size:.9rem;font-weight:600;height:100%;justify-content:flex-end;padding-right:.75rem;transition:all .3s ease}.bar-fill,.bar-value{color:#fff}.distribution-table{overflow-x:auto}.detailed-table table,.distribution-table table,.test-stats-table table{border-collapse:collapse;font-size:.95rem;width:100%}.detailed-table thead,.distribution-table thead,.test-stats-table thead{background:#f3f4f6;border-bottom:2px solid #e5e7eb}.detailed-table th,.distribution-table th,.test-stats-table th{color:#374151;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.detailed-table tbody tr,.distribution-table tbody tr,.test-stats-table tbody tr{border-bottom:1px solid #e5e7eb;transition:all .2s ease}.detailed-table tbody tr:hover,.distribution-table tbody tr:hover,.test-stats-table tbody tr:hover{background:#f9fafb}.detailed-table td,.distribution-table td,.test-stats-table td{color:#1f2937;padding:1rem}.test-results-report{margin-top:2rem}.summary-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,#f0f4ff,#fff);border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-align:center}.summary-card.success{background:linear-gradient(135deg,#f0fdf4,#fff);border-color:#86efac}.summary-card.warning{background:linear-gradient(135deg,#fef3c7,#fff);border-color:#fcd34d}.summary-number{color:#2563eb;font-size:2rem;font-weight:700;margin-bottom:.5rem}.summary-card.success .summary-number{color:#10b981}.summary-card.warning .summary-number{color:#f59e0b}.summary-label{color:#6b7280;font-size:.9rem;font-weight:500}.test-stats-table{margin-top:1.5rem;overflow-x:auto}.progress-text{font-size:.85rem}.detailed-report{margin-top:2rem}.report-summary{background:#f3f4f6;border-radius:8px;font-size:.95rem;margin-bottom:1.5rem;padding:1rem}.report-summary strong{color:#1f2937;font-weight:700}.detailed-table{overflow-x:auto}.sample-id{color:#2563eb;font-weight:700}.status-badge{border-radius:6px;font-size:.8rem;padding:.4rem .9rem;text-transform:uppercase}.status-badge.received{background:#06b6d41a;color:#0891b2}.status-badge.processing{background:#f59e0b1a;color:#f59e0b}.status-badge.tested{background:#10b9811a;color:#10b981}.customer-wise-report{margin-top:2rem}.customer-section{background:#fff;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:2rem;padding:1.5rem;page-break-inside:avoid}.customer-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.customer-header h3{color:#1f2937;font-size:1.25rem;margin:0}.customer-stats{display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-end}.stat-item{background:#f3f4f6;border-radius:6px;color:#374151;font-size:.85rem;font-weight:600;padding:.5rem 1rem}.stat-item.received{background:#06b6d41a;color:#0891b2}.stat-item.processing{background:#f59e0b1a;color:#f59e0b}.stat-item.tested{background:#10b9811a;color:#10b981}.customer-samples,.customer-samples-tests,.customer-tests{margin-bottom:1.5rem}.customer-samples-tests:last-child,.customer-samples:last-child,.customer-tests:last-child{margin-bottom:0}.customer-samples h4,.customer-samples-tests h4,.customer-tests h4{border-bottom:2px solid #f3f4f6;color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.customer-samples table,.customer-samples-tests table,.customer-tests table{border-collapse:collapse;font-size:.9rem;width:100%}.customer-samples thead,.customer-samples-tests thead,.customer-tests thead{background:#f9fafb}.customer-samples th,.customer-samples-tests th,.customer-tests th{border-bottom:1px solid #e5e7eb;color:#374151;font-weight:600;padding:.75rem;text-align:left}.customer-samples tbody tr,.customer-samples-tests tbody tr,.customer-tests tbody tr{border-bottom:1px solid #f3f4f6}.customer-samples tbody tr:hover,.customer-samples-tests tbody tr:hover,.customer-tests tbody tr:hover{background:#f9fafb}.customer-samples td,.customer-samples-tests td,.customer-tests td{color:#374151;padding:.75rem}.customer-samples h4,.customer-tests h4{border-bottom:2px solid #f3f4f6;color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.customer-samples table,.customer-tests table{border-collapse:collapse;font-size:.9rem;width:100%}.customer-samples thead,.customer-tests thead{background:#f9fafb}.customer-samples th,.customer-tests th{border-bottom:1px solid #e5e7eb;color:#374151;font-weight:600;padding:.75rem;text-align:left}.customer-samples tbody tr,.customer-tests tbody tr{border-bottom:1px solid #f3f4f6}.customer-samples tbody tr:hover,.customer-tests tbody tr:hover{background:#f9fafb}.customer-samples td,.customer-tests td{color:#374151;padding:.75rem}.test-name{color:#1f2937;font-weight:600}.success-text{color:#10b981;font-weight:600}.warning-text{color:#f59e0b;font-weight:600}.progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#10b981,#06b6d4);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#374151;font-size:.8rem;font-weight:600}.empty-state{align-items:center;background:#fff;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-title{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.empty-description{color:#6b7280;margin:0}@media (max-width:1024px){.controls-dates,.controls-top,.distribution-report{grid-template-columns:1fr}}@media (max-width:768px){.reports-container{padding:1rem}.reports-header h1{font-size:1.5rem}.report-content{padding:1rem}.metrics-grid{gap:1rem;grid-template-columns:repeat(2,1fr)}.report-title-section{align-items:flex-start;flex-direction:column;gap:.5rem}.control-actions{flex-direction:column}.btn-primary,.btn-secondary{justify-content:center;width:100%}.controls-dates,.controls-top{grid-template-columns:1fr}.detailed-table table,.test-stats-table table{font-size:.85rem}.detailed-table td,.detailed-table th,.distribution-table td,.distribution-table th,.test-stats-table td,.test-stats-table th{padding:.75rem}}@media (max-width:480px){.metrics-grid,.reports-controls,.summary-cards{grid-template-columns:1fr}.date-input,.report-select{font-size:16px}.btn-primary,.btn-secondary{font-size:.85rem;padding:.6rem 1rem}.metric-number{font-size:1.75rem}.summary-number{font-size:1.5rem}.metric-label,.summary-label{font-size:.85rem}}.company-comparison-report{display:flex;flex-direction:column;gap:2rem}.company-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.5rem;page-break-inside:avoid}.company-heading{align-items:center;border-bottom:2px solid #f3f4f6;display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.company-heading h3{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0}.sample-count{background:#dbeafe;border-radius:20px;color:#1e40af;font-size:.9rem;font-weight:500;padding:.25rem .75rem}.company-table-wrapper{overflow-x:auto}.company-samples-table{border-collapse:collapse;font-size:.9rem;margin-top:1rem;width:100%}.company-samples-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.company-samples-table th{color:#374151;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.company-samples-table td{border-bottom:1px solid #f3f4f6;padding:.875rem 1rem}.company-samples-table tbody tr:hover{background:#f9fafb}.company-samples-table tbody tr:last-child td{border-bottom:none}.sample-id-cell{color:#1f2937;font-weight:600}.test-name-cell{color:#2563eb;font-weight:500}.pending-result{color:#f59e0b;font-weight:600}.completed-result{color:#10b981;font-weight:600}.status-badge{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.status-badge.received{background:#dbeafe;color:#1e40af}.status-badge.processing{background:#fef3c7;color:#92400e}.status-badge.tested{background:#d1fae5;color:#065f46}.status-badge.to{background:#dbeafe;color:#1e40af}.no-data-message{color:#9ca3af;font-style:italic;padding:2rem;text-align:center}.trend-report,.trends-container{display:flex;flex-direction:column;gap:2rem}.date-trend-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.5rem;page-break-inside:avoid}.trend-date-header{align-items:center;border-bottom:2px solid #f3f4f6;display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.trend-date-header h3{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0}.test-count{background:#fef3c7;border-radius:20px;color:#92400e;font-size:.9rem;font-weight:500;padding:.25rem .75rem}.test-trend-card{background:#f9fafb;border:1px solid #f3f4f6;border-radius:8px;margin-bottom:1rem;padding:1rem;page-break-inside:avoid}.test-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.test-header h4{color:#2563eb;font-size:1rem;font-weight:600;margin:0}.test-metrics{align-items:center;display:flex;gap:1rem}.metric{border-radius:4px;font-size:.85rem;font-weight:600;padding:.3rem .6rem}.metric.completed{background:#d1fae5;color:#065f46}.metric.pending{background:#fef3c7;color:#92400e}.metric.rate{background:#dbeafe;color:#1e40af;min-width:50px;text-align:center}.test-results-table{border-collapse:collapse;font-size:.9rem;width:100%}.test-results-table thead{background:#fff;border-bottom:2px solid #e5e7eb}.test-results-table th{color:#374151;font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.test-results-table td{border-bottom:1px solid #f3f4f6;padding:.75rem}.test-results-table tbody tr:hover{background:#f3f4f6}.test-results-table tbody tr:last-child td{border-bottom:none}.test-results-table .sample-id{color:#1f2937;font-weight:600}.result-completed{color:#10b981;font-weight:600}.result-pending{color:#f59e0b;font-weight:600}@media print{.error-alert,.reports-controls{display:none}.reports-container{background:#fff;padding:0}.report-content{box-shadow:none;page-break-inside:avoid}.btn-primary,.btn-secondary{display:none}table{page-break-inside:avoid}}.charts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));margin-bottom:2rem}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;transition:all .3s ease}.chart-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px #0000001a}.chart-card h3{align-items:center;color:#1f2937;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.chart-card.wide{grid-column:span 2}@media (max-width:1200px){.charts-grid{grid-template-columns:1fr}.chart-card.wide{grid-column:span 1}}@media (max-width:768px){.charts-grid{gap:1rem;grid-template-columns:1fr}.chart-card{padding:1rem}.chart-card h3{font-size:1rem}}.recharts-surface{background:#0000!important}.recharts-text{fill:#1f2937}.recharts-cartesian-axis-line{stroke:#e5e7eb}.recharts-cartesian-axis-tick-value{fill:#6b7280;font-size:12px}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background:#1f2937f2!important;border:none!important;border-radius:8px;box-shadow:0 4px 6px #0000001a}.recharts-tooltip-label{color:#fff;font-weight:600}.recharts-tooltip-item{color:#fff}
/*# sourceMappingURL=main.4136be0c.css.map*/