.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.spinner-container.fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#fffffff2;z-index:9999}.spinner{border:3px solid #f3f3f3;border-top:3px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite}.spinner.small{width:24px;height:24px;border-width:2px}.spinner.medium{width:40px;height:40px;border-width:3px}.spinner.large{width:60px;height:60px;border-width:4px}.spinner-message{color:#666;font-size:16px;font-weight:500;text-align:center}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;line-height:1.5;pointer-events:auto;animation:slideIn .3s ease-out;min-width:300px;max-width:400px}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast.toast-exit{animation:slideOut .3s ease-in forwards}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.toast-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;border-radius:50%}.toast-message{flex:1;word-wrap:break-word;padding-top:2px}.toast-close{flex-shrink:0;background:none;border:none;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s;opacity:.7}.toast-close:hover{opacity:1;background-color:#0000001a}.toast-success{background-color:#d1fae5;color:#065f46;border-left:4px solid #10b981}.toast-success .toast-icon{background-color:#10b981;color:#fff}.toast-success .toast-close{color:#065f46}.toast-error{background-color:#fee2e2;color:#991b1b;border-left:4px solid #dc2626}.toast-error .toast-icon{background-color:#dc2626;color:#fff}.toast-error .toast-close{color:#991b1b}.toast-warning{background-color:#fef3c7;color:#92400e;border-left:4px solid #f59e0b}.toast-warning .toast-icon{background-color:#f59e0b;color:#fff}.toast-warning .toast-close{color:#92400e}.toast-info{background-color:#dbeafe;color:#1e40af;border-left:4px solid #3b82f6}.toast-info .toast-icon{background-color:#3b82f6;color:#fff}.toast-info .toast-close{color:#1e40af}@media (max-width: 768px){.toast-container{bottom:10px;right:10px;left:10px;max-width:none}.toast{min-width:auto;max-width:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#047857);padding:20px}.login-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-header h1{margin:0 0 8px;font-size:2rem;color:#059669}.login-header p{margin:0;color:#6b7280;font-size:16px}.login-form{display:flex;flex-direction:column;gap:20px}.login-button{padding:14px 24px;background-color:#059669;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:8px}.login-button:hover:not(:disabled){background-color:#047857}.login-button:disabled{background-color:#9ca3af;cursor:not-allowed}.forgot-password-link{text-align:center;margin-top:12px}.forgot-password-link a{color:#059669;text-decoration:none;font-size:14px;font-weight:500}.forgot-password-link a:hover{text-decoration:underline}.login-footer{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb;text-align:center}.demo-credentials{margin:0;font-size:13px;color:#6b7280;font-family:monospace;background:#f3f4f6;padding:8px 12px;border-radius:6px}.signup-link{text-align:center;margin-top:24px;color:#6b7280;font-size:14px}.signup-link .link-button{background:none;border:none;color:#059669;font-weight:500;cursor:pointer;padding:0;font-size:14px}.signup-link .link-button:hover{text-decoration:underline;color:#047857}@media (max-width: 480px){.login-container{padding:24px}.login-header h1{font-size:1.5rem}}.signup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#047857);padding:20px}.signup-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:480px;box-shadow:0 20px 60px #0000004d}.signup-header{text-align:center;margin-bottom:32px}.signup-header h1{margin:0 0 8px;font-size:2rem;color:#059669}.signup-header h2{margin:0 0 8px;font-size:1.5rem;color:#111827;font-weight:600}.signup-header p{margin:0;color:#6b7280;font-size:14px}.signup-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group input,.form-group textarea{padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.form-group small{font-size:12px;color:#6b7280}.password-errors{list-style:none;padding:0;margin:4px 0 0}.password-errors li{font-size:12px;color:#dc2626;margin:2px 0}.password-match-error{font-size:12px;color:#dc2626;margin-top:4px}.password-requirements{background:#eff6ff;border:1px solid: #bfdbfe;border-radius:8px;padding:12px;margin-top:8px}.password-requirements p{font-size:12px;font-weight:600;color:#1e40af;margin:0 0 8px}.password-requirements ul{list-style:none;padding:0;margin:0}.password-requirements li{font-size:12px;color:#1e40af;margin:4px 0;padding-left:16px;position:relative}.password-requirements li:before{content:"•";position:absolute;left:0}.divider{position:relative;text-align:center;margin:24px 0}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb}.divider span{position:relative;display:inline-block;padding:0 12px;background:#fff;color:#6b7280;font-size:14px}.login-link{text-align:center;margin-top:24px;color:#6b7280;font-size:14px}.login-link .link-button{background:none;border:none;color:#059669;font-weight:500;cursor:pointer;padding:0;font-size:14px}.login-link .link-button:hover{text-decoration:underline;color:#047857}@media (max-width: 480px){.signup-container{padding:24px}.signup-header h1{font-size:1.5rem}.signup-header h2{font-size:1.25rem}}.forgot-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#047857);padding:20px}.forgot-password-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d}.forgot-password-header{text-align:center;margin-bottom:32px}.forgot-password-header h1{margin:0 0 8px;font-size:2rem;color:#059669}.forgot-password-header p{margin:0;color:#6b7280;font-size:16px}.forgot-password-content h2{font-size:1.5rem;margin:0 0 12px;color:#111827}.forgot-password-form{display:flex;flex-direction:column;gap:20px}.form-group input{padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.success-message{text-align:center}.success-icon{width:64px;height:64px;margin:0 auto 24px;background-color:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700}.success-message h2{font-size:1.5rem;margin:0 0 16px;color:#111827}.success-message p{color:#6b7280;margin-bottom:12px;line-height:1.5}.help-text{font-size:14px;color:#9ca3af}.actions{margin-top:32px}.back-to-login{display:inline-block;padding:12px 24px;background-color:#059669;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:background-color .2s}.back-to-login:hover{background-color:#047857}@media (max-width: 480px){.forgot-password-container{padding:24px}.forgot-password-header h1{font-size:1.5rem}}.reset-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#047857);padding:20px}.reset-password-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:480px;box-shadow:0 20px 60px #0000004d}.reset-password-header{text-align:center;margin-bottom:32px}.reset-password-header h1{margin:0 0 8px;font-size:2rem;color:#059669}.reset-password-header p{margin:0;color:#6b7280;font-size:16px}.reset-password-content h2{font-size:1.5rem;margin:0 0 12px;color:#111827}.description{color:#6b7280;margin-bottom:24px;line-height:1.5}.reset-password-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#374151}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding:12px 48px 12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s;width:100%}.password-input-wrapper input:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.password-input-wrapper input:disabled{background-color:#f3f4f6;cursor:not-allowed}.toggle-password{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:18px;padding:4px;opacity:.6;transition:opacity .2s}.toggle-password:hover{opacity:1}.password-requirements{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-top:-8px}.requirements-title{font-size:13px;font-weight:600;color:#374151;margin:0 0 8px}.password-requirements ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.password-requirements li{font-size:13px;color:#6b7280;display:flex;align-items:center;gap:8px}.password-requirements li.met,.password-requirements ul.all-met li{color:#10b981;font-weight:500}.submit-button{padding:14px 24px;background-color:#059669;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:8px}.submit-button:hover:not(:disabled){background-color:#047857}.submit-button:disabled{background-color:#9ca3af;cursor:not-allowed}.footer-links{margin-top:24px;text-align:center}.back-link{color:#059669;text-decoration:none;font-size:14px;font-weight:500}.back-link:hover{text-decoration:underline}@media (max-width: 480px){.reset-password-container{padding:24px}.reset-password-header h1{font-size:1.5rem}}.verification-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#047857);padding:20px}.verification-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:480px;box-shadow:0 20px 60px #0000004d}.icon-container{display:flex;align-items:center;justify-content:center;margin-bottom:24px}.icon-circle{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center}.icon-circle.success{background-color:#d1fae5}.icon-circle.error{background-color:#fee2e2}.icon-circle.pending{background-color:#dbeafe}.icon-circle.loading{background-color:#f3f4f6;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.icon-circle svg{width:40px;height:40px}.icon-circle.success svg{color:#10b981}.icon-circle.error svg{color:#ef4444}.icon-circle.pending svg{color:#3b82f6}.icon-circle.loading svg{color:#9ca3af}.verification-header{text-align:center;margin-bottom:24px}.verification-header h1{margin:0 0 12px;font-size:1.875rem;color:#111827;font-weight:700}.verification-content{text-align:center;margin-bottom:24px}.verification-content p{color:#6b7280;margin:12px 0;line-height:1.6}.email-display{font-weight:600;color:#111827;background:#f3f4f6;padding:8px 16px;border-radius:6px;margin:12px 0;word-break:break-all}.info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:16px;margin:16px 0}.info-box.success{background:#d1fae5;border-color:#6ee7b7}.info-box.error{background:#fee2e2;border-color:#fca5a5}.info-box p{font-size:13px;color:#1e40af;margin:0 0 8px;font-weight:600}.info-box.success p{color:#065f46}.info-box.error p{color:#991b1b}.info-box ul{list-style:none;padding:0;margin:0}.info-box li{font-size:13px;color:#1e3a8a;margin:6px 0;padding-left:16px;position:relative}.info-box.success li{color:#047857}.info-box.error li{color:#991b1b}.info-box li:before{content:"•";position:absolute;left:0}.verification-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.primary-button{padding:14px 24px;background-color:#059669;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;text-align:center;text-decoration:none;display:inline-block}.primary-button:hover:not(:disabled){background-color:#047857}.primary-button:disabled{background-color:#9ca3af;cursor:not-allowed}.secondary-button{padding:14px 24px;background-color:#fff;color:#059669;border:1px solid #059669;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;text-decoration:none;display:inline-block}.secondary-button:hover{background-color:#f0fdf4}.footer-links{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb;text-align:center}.footer-links p{margin:8px 0;font-size:14px;color:#6b7280}.footer-links .link-button{background:none;border:none;color:#059669;font-weight:500;cursor:pointer;padding:0;font-size:14px}.footer-links .link-button:hover{text-decoration:underline;color:#047857}.redirect-message{text-align:center;font-size:13px;color:#9ca3af;margin:16px 0 8px}.spinner{border:4px solid #f3f4f6;border-top:4px solid #059669;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite}@media (max-width: 480px){.verification-container{padding:24px}.verification-header h1{font-size:1.5rem}.icon-circle{width:64px;height:64px}.icon-circle svg{width:32px;height:32px}}.oauth-callback-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#047857);padding:20px}.oauth-callback-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d;text-align:center}.oauth-callback-loading{display:flex;flex-direction:column;align-items:center;gap:24px}.oauth-callback-spinner{width:64px;height:64px;border:4px solid #e5e7eb;border-top-color:#059669;border-radius:50%;animation:spin 1s linear infinite}.oauth-callback-loading h2{margin:0;font-size:1.75rem;color:#111827;font-weight:600}.oauth-callback-loading p{margin:0;color:#6b7280;font-size:16px}.oauth-callback-error{display:flex;flex-direction:column;align-items:center;gap:24px}.oauth-callback-error-icon{font-size:4rem;line-height:1}.oauth-callback-error h2{margin:0;font-size:1.75rem;color:#111827;font-weight:600}.oauth-callback-error-message{margin:0;color:#6b7280;font-size:16px;line-height:1.6}.oauth-callback-error-button{width:100%;padding:14px 24px;background-color:#059669;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:8px}.oauth-callback-error-button:hover{background-color:#047857}.oauth-callback-error-button:focus{outline:none;box-shadow:0 0 0 3px #0596694d}.create-org-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f9fafb;padding:48px 16px}.create-org-container{max-width:672px;width:100%;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:32px}.create-org-header{text-align:center;margin-bottom:32px}.create-org-header h1{font-size:1.875rem;font-weight:700;color:#1f2937;margin:0 0 8px}.create-org-header p{color:#6b7280;margin:0}.create-org-form{display:flex;flex-direction:column;gap:24px}.form-field{display:flex;flex-direction:column}.form-field label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.form-field label .required{color:#ef4444}.form-field input,.form-field select{width:100%;padding:10px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-field input:focus,.form-field select:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.form-field select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.form-actions{padding-top:16px}.create-org-button{width:100%;padding:12px 24px;background-color:#059669;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.create-org-button:hover:not(:disabled){background-color:#047857}.create-org-button:disabled{opacity:.5;cursor:not-allowed}.info-note{margin-top:24px;padding:16px;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px}.info-note p{margin:0;font-size:14px;color:#374151;line-height:1.5}.info-note strong{font-weight:600}.create-org-footer{margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb;text-align:center}.back-button{background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:0}.back-button:hover:not(:disabled){color:#1f2937}.back-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.create-org-container{padding:24px}.create-org-header h1{font-size:1.5rem}}.duplicate-org-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:50;display:flex;align-items:center;justify-content:center;background-color:#00000080;padding:16px}.duplicate-org-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:448px;width:100%;padding:24px}.modal-icon-container{display:flex;align-items:center;justify-content:center;margin-bottom:16px}.modal-icon-wrapper{background-color:#fef3c7;border-radius:50%;padding:12px}.modal-warning-icon{width:32px;height:32px;color:#d97706}.modal-title{font-size:1.5rem;font-weight:700;color:#1f2937;text-align:center;margin:0 0 16px}.modal-content{margin-bottom:24px}.modal-text{color:#374151;text-align:center;margin:0 0 12px}.modal-text strong{font-weight:600}.existing-org-name{font-size:1.125rem;font-weight:600;color:#1f2937;text-align:center;background-color:#f3f4f6;padding:8px 16px;border-radius:8px;margin:12px 0}.modal-warning-box{background-color:#fffbeb;border-left:4px solid #f59e0b;padding:16px;border-radius:8px;margin:12px 0}.modal-warning-box p{font-size:14px;color:#92400e;margin:0 0 8px}.modal-warning-box strong{font-weight:600}.modal-warning-list{list-style:disc;list-style-position:inside;font-size:14px;color:#b45309;margin:8px 0 0;padding:0}.modal-warning-list li{margin:4px 0}.modal-suggestion{font-size:14px;color:#6b7280;text-align:center;margin:12px 0 0}.modal-actions{display:flex;flex-direction:column;gap:12px}.modal-button-primary,.modal-button-secondary{width:100%;padding:10px 16px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.modal-button-primary{background-color:#059669;color:#fff}.modal-button-primary:hover{background-color:#047857}.modal-button-secondary{background-color:#fff;color:#374151;border:2px solid #d1d5db}.modal-button-secondary:hover{background-color:#f9fafb;border-color:#9ca3af}.oauth-intermediate-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f9fafb;padding:48px 16px}.oauth-intermediate-container{max-width:672px;width:100%;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:32px}.oauth-intermediate-header{text-align:center;margin-bottom:32px}.oauth-intermediate-header h1{font-size:1.875rem;font-weight:700;color:#1f2937;margin:0 0 8px}.oauth-intermediate-header p{color:#6b7280;margin:0}.oauth-intermediate-loading{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:300px}.oauth-intermediate-spinner{width:64px;height:64px;border:4px solid #e5e7eb;border-top-color:#059669;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.oauth-intermediate-loading p{color:#6b7280;margin:0}.status-message{margin-bottom:24px;padding:16px;border-radius:8px;border-left:4px solid;display:flex;align-items:flex-start}.status-message-icon{flex-shrink:0;width:20px;height:20px;margin-right:12px}.status-message-content h3{font-size:14px;font-weight:600;margin:0 0 4px}.status-message-content p{font-size:14px;margin:0;line-height:1.5}.status-message-content p strong{font-weight:600}.status-message-content .rejection-reason{display:block;margin-top:4px;font-style:italic}.status-message.pending{background-color:#fffbeb;border-left-color:#f59e0b}.status-message.pending .status-message-icon{color:#f59e0b}.status-message.pending h3{color:#92400e}.status-message.pending p{color:#b45309}.status-message.rejected{background-color:#fef2f2;border-left-color:#ef4444}.status-message.rejected .status-message-icon{color:#ef4444}.status-message.rejected h3{color:#991b1b}.status-message.rejected p{color:#dc2626}.status-message.expired{background-color:#fff7ed;border-left-color:#f97316}.status-message.expired .status-message-icon{color:#f97316}.status-message.expired h3{color:#9a3412}.status-message.expired p{color:#ea580c}.oauth-intermediate-content{margin-bottom:24px}.oauth-intermediate-text{color:#6b7280;margin-bottom:24px;text-align:center}.org-info-box{background-color:#eff6ff;border:1px solid: #bfdbfe;border-radius:12px;padding:24px;margin-bottom:24px}.org-info-header{font-weight:600;color:#1f2937;margin:0 0 8px;font-size:16px;display:flex;align-items:center}.org-info-icon{width:20px;height:20px;margin-right:8px;color:#3b82f6}.org-info-description{color:#374151;margin:0 0 8px}.org-info-description strong{font-weight:600}.org-name{font-weight:600;font-size:1.125rem;margin:8px 0 0;color:#059669!important}.oauth-button-group{display:flex;flex-direction:column;gap:12px}.oauth-button-primary,.oauth-button-secondary{width:100%;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.oauth-button-primary{background-color:#059669;color:#fff}.oauth-button-primary:hover:not(:disabled){background-color:#047857}.oauth-button-primary:disabled{opacity:.5;cursor:not-allowed}.oauth-button-secondary{background-color:#fff;color:#374151;border:2px solid #d1d5db}.oauth-button-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.oauth-divider{position:relative;text-align:center;margin:12px 0}.oauth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#d1d5db}.oauth-divider span{position:relative;display:inline-block;padding:0 8px;background:#fff;color:#6b7280;font-size:14px}.oauth-intermediate-footer{margin-top:32px;padding-top:24px;border-top:1px solid: #e5e7eb;text-align:center}.oauth-back-button{background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:0}.oauth-back-button:hover{color:#1f2937}@media (max-width: 640px){.oauth-intermediate-container{padding:24px}.oauth-intermediate-header h1{font-size:1.5rem}}.select-org-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.select-org-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:2.5rem;max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column}.select-org-header{text-align:center;margin-bottom:2rem}.select-org-header h1{margin:0 0 .5rem;color:#2d3748;font-size:2rem;font-weight:700}.select-org-header p{margin:.25rem 0;color:#718096;font-size:.95rem}.org-count{font-weight:500;color:#4a5568!important;margin-top:.5rem!important}.search-box{margin-bottom:1.5rem}.search-input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.org-list{flex:1;overflow-y:auto;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem}.org-list::-webkit-scrollbar{width:8px}.org-list::-webkit-scrollbar-track{background:#f7fafc;border-radius:4px}.org-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.org-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.org-card{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .2s;width:100%;text-align:left}.org-card:hover:not(:disabled){background:#edf2f7;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.org-card:disabled{opacity:.6;cursor:not-allowed}.org-card-content{display:flex;align-items:center;gap:1rem}.org-icon{font-size:2rem;flex-shrink:0}.org-info{flex:1}.org-info h3{margin:0 0 .25rem;color:#2d3748;font-size:1.1rem;font-weight:600}.org-id{margin:0;color:#718096;font-size:.85rem}.org-arrow{font-size:1.5rem;color:#a0aec0;transition:transform .2s}.org-card:hover:not(:disabled) .org-arrow{transform:translate(4px);color:#667eea}.no-results{text-align:center;padding:3rem 1rem;color:#718096}.no-results p{margin:0;font-size:1rem}.select-org-footer{text-align:center;padding-top:1rem;border-top:1px solid #e2e8f0}.logout-link{background:none;border:none;color:#718096;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:color .2s}.logout-link:hover:not(:disabled){color:#2d3748;text-decoration:underline}.logout-link:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.select-org-page{padding:1rem}.select-org-container{padding:1.5rem;max-height:85vh}.select-org-header h1{font-size:1.5rem}.org-card{padding:1rem}.org-icon{font-size:1.5rem}.org-info h3{font-size:1rem}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.confirm-modal{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:500px;width:90%;animation:slideUp .3s ease}.confirm-modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb}.confirm-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.confirm-modal-body{padding:1.5rem}.confirm-modal-body p{margin:0;font-size:1rem;color:#4b5563;line-height:1.6}.confirm-modal-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem}.confirm-modal-footer .btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease}.confirm-modal-footer .btn-primary{background:#3b82f6;color:#fff}.confirm-modal-footer .btn-primary:hover{background:#2563eb}.confirm-modal-footer .btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.confirm-modal-footer .btn-secondary:hover{background:#f9fafb}@media (max-width: 768px){.confirm-modal{width:95%;max-width:none;margin:1rem}.confirm-modal-footer{flex-direction:column-reverse}.confirm-modal-footer .btn{width:100%}}.onboarding-container{height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow:hidden}.onboarding-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.onboarding-header{padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.onboarding-logo h1{margin:0;font-size:1.5rem;color:#fff;font-weight:700}.org-name{margin:.25rem 0 0;font-size:.875rem;color:#ffffffe6;font-weight:500}.btn-logout{padding:.5rem 1.5rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-logout:hover{background:#ffffff4d;transform:translateY(-1px)}.onboarding-content{flex:1;padding:1rem 2rem;max-width:1400px;width:100%;margin:0 auto;display:flex;flex-direction:column;overflow:hidden}.onboarding-progress{margin-bottom:1rem;flex-shrink:0}.progress-bar{display:flex;justify-content:space-between;align-items:center;position:relative;padding:0 2rem}.progress-bar:before{content:"";position:absolute;top:20px;left:10%;right:10%;height:4px;background:#fff3;z-index:0}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:1}.step-circle{width:40px;height:40px;border-radius:50%;background:#fff3;border:3px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff9;transition:all .3s}.progress-step.active .step-circle{background:#fff;color:#667eea;border-color:#fff}.progress-step.current .step-circle{box-shadow:0 0 0 4px #ffffff4d;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 4px #ffffff4d}50%{box-shadow:0 0 0 8px #ffffff1a}}.step-label{font-size:.875rem;color:#ffffffb3;font-weight:500;white-space:nowrap}.progress-step.active .step-label{color:#fff;font-weight:600}.onboarding-step-content{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 20px 60px #0000004d;flex:1;display:flex;flex-direction:column;overflow:hidden}.onboarding-step{display:flex;flex-direction:column;height:100%;overflow:hidden}.step-header{text-align:center;margin-bottom:1rem;flex-shrink:0}.step-header h2{font-size:1.5rem;margin:0 0 .5rem;color:#1a202c}.step-header p{font-size:.875rem;color:#718096;margin:.25rem 0}.step-header .selected-count{margin-top:.5rem;color:#667eea;font-weight:600;font-size:.95rem}.step-header .hint{font-size:.75rem;color:#a0aec0;font-style:italic}.step-content{flex:1;overflow-y:auto;padding-right:.5rem}.step-content::-webkit-scrollbar{width:6px}.step-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.step-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.step-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}.step-form{display:flex;flex-direction:column;gap:1.5rem;height:100%}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#2d3748;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.field-hint{font-size:.75rem;color:#718096;margin-top:.25rem;font-style:italic}.crops-section{display:flex;flex-direction:column;height:100%;gap:1rem}.crop-search{flex-shrink:0}.crop-search input{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem}.crop-search input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.crops-grid-wrapper{flex:1;overflow-y:auto;padding-right:.5rem}.crops-grid-wrapper::-webkit-scrollbar{width:6px}.crops-grid-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.crops-grid-wrapper::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.crops-grid-wrapper::-webkit-scrollbar-thumb:hover{background:#a0aec0}.crops-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.crop-card{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s;text-align:center}.crop-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea1a}.crop-card.selected{background:#667eea;border-color:#667eea;color:#fff}.crop-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.crop-checkbox input{width:20px;height:20px;cursor:pointer}.crop-icon{font-size:2rem}.crop-card-body h3{margin:0 0 .25rem;font-size:.875rem;font-weight:600}.crop-card.selected h3{color:#fff}.strain-name{font-size:.75rem;color:#718096;margin:0}.crop-card.selected .strain-name{color:#ffffffe6}.selected-summary{text-align:center;padding:.75rem;background:#f0f4ff;border-radius:8px;color:#667eea;font-weight:600;flex-shrink:0;font-size:.875rem}.stations-list{flex:1;overflow-y:auto;padding-right:.5rem}.stations-list::-webkit-scrollbar{width:6px}.stations-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.stations-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.stations-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.stations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.station-card{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;transition:all .2s}.station-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.station-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.station-card-header h3{margin:0;font-size:.875rem;color:#1a202c;font-weight:600}.btn-delete-small{width:24px;height:24px;border-radius:50%;border:none;background:#feb2b2;color:#c53030;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-delete-small:hover{background:#fc8181;transform:scale(1.1)}.station-card-body p{margin:.25rem 0;font-size:.75rem;color:#4a5568}.station-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.tag{padding:.25rem .75rem;background:#e6fffa;color:#319795;border-radius:12px;font-size:.75rem;font-weight:500}.tag.editable{display:flex;align-items:center;gap:.5rem}.remove-tag-btn{background:none;border:none;color:#319795;cursor:pointer;font-size:1.25rem;line-height:1;padding:0}.targets-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;padding-right:.5rem;min-height:0}.targets-content::-webkit-scrollbar{width:6px}.targets-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.targets-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.targets-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}.unit-info{text-align:center;padding:.75rem;background:#f0f4ff;border-radius:8px;color:#4a5568;font-size:.875rem;flex-shrink:0}.thresholds-container{display:flex;flex-direction:column;gap:.75rem}.crop-threshold-section{border:2px solid #e2e8f0;border-radius:8px;overflow:hidden}.crop-expand-btn{width:100%;padding:.75rem 1rem;background:#f7fafc;border:none;cursor:pointer;display:flex;align-items:center;gap:.75rem;font-size:.875rem;transition:all .2s}.crop-expand-btn:hover{background:#edf2f7}.expand-icon{font-size:.75rem;transition:transform .2s}.stages-vertical-list{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#f7fafc;border-radius:8px;margin-top:.5rem}.stages-list{padding:.75rem;background:#fff}.stage-section{border:1px solid #e2e8f0;border-radius:6px;margin-bottom:.75rem;overflow:hidden}.stage-expand-btn{width:100%;padding:.75rem 1rem;background:#f7fafc;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:background .2s;font-size:.875rem}.stage-expand-btn:hover{background:#edf2f7}.stage-name{font-weight:600;color:#2d3748}.analyte-count{font-size:.8rem;color:#718096;margin-left:auto}.stage-content{padding:1rem;background:#fff}.empty-stage-message{color:#718096;font-size:.875rem;font-style:italic;margin:0 0 .75rem}.analytes-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.analyte-threshold-row-new{display:grid;grid-template-columns:140px 1fr auto;gap:.75rem;align-items:center;padding:.75rem;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0;transition:all .2s ease}.analyte-threshold-row-new:hover{border-color:#cbd5e0;box-shadow:0 2px 4px #0000000d}.analyte-threshold-row-with-unit{display:grid;grid-template-columns:120px 110px 1fr auto;gap:.75rem;align-items:center;padding:.75rem;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0;transition:all .2s ease;position:relative}.analyte-threshold-row-with-unit:hover{border-color:#cbd5e0;box-shadow:0 2px 4px #0000000d}.unit-select{padding:.5rem;border:1px solid #cbd5e0;border-radius:4px;font-size:.875rem;width:100%;background:#fff;transition:all .2s ease}.unit-select:disabled{background:#edf2f7;cursor:not-allowed;color:#718096}.unit-select:not(:disabled):hover{border-color:#a0aec0}.unit-select:not(:disabled):focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.analyte-info strong{color:#2d3748;font-size:.875rem}.analyte-unit{font-size:.75rem;color:#718096}.threshold-inputs-new{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.threshold-inputs-new input{padding:.5rem;border:1px solid #cbd5e0;border-radius:4px;font-size:.875rem;width:100%}.threshold-inputs-new input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.threshold-inputs-new input::placeholder{color:#a0aec0;font-size:.75rem}.remove-analyte-btn{width:28px;height:28px;border:none;background:#fed7d7;color:#c53030;border-radius:4px;cursor:pointer;font-size:1.25rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.remove-analyte-btn:hover{background:#fc8181;color:#742a2a}.add-analyte-section{margin-top:.5rem}.add-analyte-select{width:100%;padding:.75rem;border:2px dashed #cbd5e0;border-radius:6px;background:#f7fafc;font-size:.875rem;color:#718096;cursor:pointer;transition:all .2s ease}.add-analyte-select:hover{border-color:#667eea;background:#fff}.add-analyte-select:focus{outline:none;border-color:#667eea;border-style:solid;box-shadow:0 0 0 3px #667eea1a}.stage-card-vertical{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a}.stage-name-vertical{margin:0 0 .75rem;color:#2d3748;font-size:1rem;font-weight:600;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.analytes-table-compact{display:flex;flex-direction:column;gap:.5rem}.analyte-row-inputs{display:grid;grid-template-columns:150px 1fr;gap:.75rem;align-items:center;padding:.5rem;border-radius:4px;transition:background .2s}.analyte-row-inputs:hover{background:#f7fafc}.analyte-label-col{font-weight:500;color:#2d3748;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.threshold-inputs-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.threshold-inputs-row input{padding:.5rem;border:1px solid #cbd5e0;border-radius:4px;font-size:.875rem;width:100%}.threshold-inputs-row input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.threshold-inputs-row input::placeholder{font-size:.75rem;color:#a0aec0}.analyte-label{font-size:.75rem;font-weight:600;color:#4a5568;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stage-inputs-cell{text-align:center;min-width:200px}.threshold-inputs-compact{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem}.threshold-inputs-compact input{padding:.4rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.75rem;width:100%}.threshold-inputs-compact input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.threshold-inputs-compact input::placeholder{font-size:.7rem}.users-actions-top{margin-bottom:1rem;flex-shrink:0;padding-bottom:1rem;border-bottom:1px solid #e2e8f0;background:#fff;position:relative;z-index:2}.users-list{flex:1;overflow-y:auto;padding-right:.5rem;min-height:0}.users-list::-webkit-scrollbar{width:6px}.users-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.users-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.users-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.users-table-compact{width:100%;border-collapse:collapse;background:#f7fafc;border-radius:12px;overflow:hidden}.users-table-compact thead{background:#edf2f7}.users-table-compact th,.users-table-compact td{padding:1rem;text-align:left}.users-table-compact th{font-weight:600;color:#2d3748;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.users-table-compact td{border-top:1px solid #e2e8f0}.role-badge{padding:.25rem .75rem;background:#bee3f8;color:#2c5282;border-radius:12px;font-size:.75rem;font-weight:600}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.device-instructions-simple{background:#f0f4ff;padding:.75rem 1rem;border-radius:8px;border-left:4px solid #667eea;flex-shrink:0;margin-bottom:1rem;text-align:center}.device-instructions-simple p{margin:0;color:#4a5568;font-size:.95rem}.device-instructions-simple strong{color:#667eea;font-weight:600}.device-controls-top{display:flex;flex-direction:column;gap:1rem;flex-shrink:0;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.device-profile-selector{display:flex;flex-direction:column;gap:.5rem}.connection-banner{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:12px;background:#f0fff4;border:2px solid #9ae6b4}.connection-banner.success{background:#f0fff4;border-color:#9ae6b4}.banner-icon{font-size:2rem;color:#38a169}.banner-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.banner-info strong{font-size:1.125rem;color:#1a202c}.banner-info span{font-size:.875rem;color:#4a5568}.btn-large{width:100%;padding:1.25rem;font-size:1.125rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.spinner-small{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.registered-devices-section{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.registered-devices-section h4{margin:0 0 .75rem;color:#2d3748;font-size:1rem;flex-shrink:0}.registered-devices-section .step-content{flex:1;min-height:0;overflow-y:auto;padding-right:.5rem}.registered-devices-section .step-content::-webkit-scrollbar{width:6px}.registered-devices-section .step-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.registered-devices-section .step-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.registered-devices-section .step-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}.devices-empty{padding:2rem 1rem;text-align:center;color:#a0aec0;font-size:.875rem}.devices-list-compact{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;padding-right:.5rem;flex:1;min-height:0}.devices-list-compact::-webkit-scrollbar{width:6px}.devices-list-compact::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.devices-list-compact::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.devices-list-compact::-webkit-scrollbar-thumb:hover{background:#a0aec0}.device-item-compact{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.device-info{display:flex;flex-direction:column;gap:.25rem}.device-info strong{font-size:1rem;color:#1a202c}.device-id-small{font-size:.75rem;color:#a0aec0;font-family:Courier New,monospace}.status-dot{width:12px;height:12px;border-radius:50%}.status-dot.active{background:#48bb78}.status-dot.inactive{background:#cbd5e0}.device-not-supported{text-align:center;padding:3rem 2rem}.warning-icon{font-size:4rem;margin-bottom:1rem}.device-not-supported h3{margin:1rem 0 .5rem;color:#2d3748}.device-not-supported p{margin:.5rem 0;color:#4a5568}.empty-state{text-align:center;padding:3rem 2rem;color:#a0aec0;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state p{margin:.5rem 0}.empty-hint{font-size:.875rem;color:#cbd5e0;margin-bottom:1.5rem}.empty-state .btn{margin-top:1rem}.step-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0;flex-shrink:0}.btn{padding:.75rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.btn-primary:disabled{background:#cbd5e0;cursor:not-allowed}.btn-secondary{background:#edf2f7;color:#2d3748}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-secondary:disabled{background:#f7fafc;color:#cbd5e0;cursor:not-allowed}.btn-outline{background:transparent;color:#667eea;border:2px solid #667eea}.btn-outline:hover{background:#667eea1a}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.5rem;color:#1a202c}.close-btn{width:32px;height:32px;border-radius:50%;border:none;background:#edf2f7;color:#4a5568;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:#e2e8f0;transform:scale(1.1)}.modal form{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.tag-input-container{display:flex;flex-direction:column;gap:.75rem}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.add-tag-input{display:flex;gap:.5rem}.add-tag-input input{flex:1}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#a0aec0}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@media (max-width: 768px){.onboarding-content{padding:1rem}.onboarding-step-content{padding:2rem 1.5rem}.progress-bar{padding:0}.step-label{font-size:.75rem}.crops-grid,.stations-grid,.form-row{grid-template-columns:1fr}.step-actions{flex-direction:column}.step-actions .btn{width:100%}.analyte-row-compact{grid-template-columns:1fr}.analyte-threshold-row-new,.analyte-threshold-row-with-unit{grid-template-columns:1fr;gap:.75rem}.threshold-inputs-new{grid-template-columns:1fr}.remove-analyte-btn{width:100%;height:32px}}.drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .2s ease-in}.lab-reports-drawer{width:500px;max-width:90vw;height:100%;background-color:#fff;box-shadow:-2px 0 8px #0000001a;display:flex;flex-direction:column;animation:slideIn .3s ease-out}.drawer-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background-color:#f8f9fa}.drawer-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.drawer-close:hover{background-color:#e0e0e0}.empty-state{text-align:center;padding:40px;color:#666}.lab-reports-list-drawer{display:flex;flex-direction:column;gap:12px}.lab-report-item-drawer{border:1px solid #e0e0e0;border-radius:8px;padding:16px;background-color:#fff;transition:box-shadow .2s}.lab-report-item-drawer:hover{box-shadow:0 2px 8px #0000001a}.lab-report-item-drawer.in_progress{border-left:4px solid #ffc107}.lab-report-item-drawer.completed{border-left:4px solid #28a745}.lab-report-item-drawer.failed{border-left:4px solid #dc3545}.lab-report-header-drawer{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.lab-report-id-drawer{font-weight:600;color:#333;font-size:1.1rem}.lab-report-details-drawer{margin-bottom:12px}.lab-report-file-drawer{color:#666;font-size:.9rem;margin-bottom:4px;word-break:break-all}.lab-report-date-drawer{color:#999;font-size:.85rem;margin-bottom:4px}.lab-report-error-drawer{color:#dc3545;font-size:.9rem;margin-top:8px;padding:8px;background-color:#f8d7da;border-radius:4px}.lab-report-actions-drawer{display:flex;gap:8px;align-items:center}.status-badge{padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:500}.status-badge.processing{background-color:#fff3cd;color:#856404}.status-badge.completed{background-color:#d4edda;color:#155724}.status-badge.failed{background-color:#f8d7da;color:#721c24}.processing-indicator{color:#666;font-size:.9rem;font-style:italic}.loading-more-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;color:#666}.loading-more-container .loading-spinner{width:30px;height:30px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:8px}.end-of-list{text-align:center;padding:20px;color:#999;font-size:.9rem;border-top:1px solid #e0e0e0;margin-top:10px}.btn-sm{padding:6px 12px;font-size:.875rem}.manual-analysis-form{max-width:800px;margin:0 auto}.form-section{margin-bottom:32px}.form-section h3{margin:0 0 16px;color:#333;font-size:1.2rem;border-bottom:2px solid #e0e0e0;padding-bottom:8px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;color:#555;font-weight:500;font-size:.9rem}.form-group input,.form-group select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.analyte-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-top:16px}.analyte-input-group{display:flex;flex-direction:column}.analyte-input-group label{font-size:.85rem;margin-bottom:4px;color:#666}.analyte-input-group input{padding:6px 10px;font-size:.9rem}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.new-analysis-modal{max-width:800px;width:90vw}.options-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;padding:20px 0}.option-card{border:2px solid #e0e0e0;border-radius:8px;padding:16px;text-align:center;cursor:pointer;transition:all .2s;background-color:#fff}.option-card:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.option-icon{font-size:1.2rem;margin-bottom:8px}.option-card h3{margin:8px 0 6px;color:#333;font-size:1rem}.option-card p{margin:0;color:#666;font-size:.85rem;line-height:1.4}.info-message{padding:20px;background-color:#f8f9fa;border-radius:8px;margin-top:16px}.info-message h3{margin-top:0;color:#333}.info-message ol{text-align:left;margin:16px 0;padding-left:24px}.info-message li{margin:8px 0;color:#555}.info-message p{color:#666;line-height:1.6}.info-message .btn{margin-top:16px}.dashboard-page{padding:20px;background-color:#f5f7fa;min-height:100vh}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.metric-card{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;display:flex;align-items:flex-start;gap:20px;transition:transform .2s,box-shadow .2s}.metric-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #0000001f}.metric-icon{font-size:48px;width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}.alerts-icon{background:linear-gradient(135deg,#fee2e2,#fecaca)}.analysis-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.stations-icon{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.metric-content{flex:1}.metric-content h3{margin:0 0 8px;font-size:14px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:36px;font-weight:700;color:var(--color-dark-green);margin-bottom:8px;line-height:1}.metric-subtext{font-size:13px;color:#6b7280}.metric-subtext .highlight{font-weight:600;color:var(--color-dark-green)}.metric-subtext .separator{margin:0 8px;color:#d1d5db}.dashboard-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.dashboard-left-column,.dashboard-right-column{display:flex;flex-direction:column;gap:20px}.dashboard-card{background:var(--color-white);border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.card-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.card-header h2{margin:0;font-size:18px;font-weight:600;color:var(--color-dark-green)}.card-subtitle{font-size:13px;color:#6b7280}.card-content{padding:24px}.empty-state{text-align:center;padding:40px 20px;color:#9ca3af}.alerts-list{display:flex;flex-direction:column;gap:12px}.alert-item{padding:16px;background:#f9fafb;border-radius:8px;border-left:4px solid #d1d5db;transition:background .2s,border-color .2s}.alert-item:hover{background:#f3f4f6;border-left-color:var(--color-dark-green)}.alert-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.severity-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.severity-badge-high{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.severity-badge-medium{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.severity-badge-low{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.alert-time{font-size:12px;color:#6b7280}.alert-item-details{display:flex;gap:16px;font-size:13px;color:#374151}.alert-station,.alert-analyte{display:flex;align-items:center;gap:4px}.analyses-list{display:flex;flex-direction:column;gap:12px}.analysis-item{padding:16px;background:#f9fafb;border-radius:8px;border-left:4px solid #bfdbfe;transition:background .2s,border-color .2s}.analysis-item:hover{background:#f3f4f6;border-left-color:#3b82f6}.analysis-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.analysis-id{font-weight:600;color:#3b82f6;font-size:13px}.analysis-time{font-size:12px;color:#6b7280}.analysis-item-details{display:flex;gap:16px;font-size:13px;color:#374151;flex-wrap:wrap}.analysis-station,.analysis-sample{display:flex;align-items:center;gap:4px}.analysis-alerts-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fee2e2;color:#991b1b;border-radius:10px;font-size:11px;font-weight:600}.severity-breakdown{display:flex;flex-direction:column;gap:16px}.severity-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-radius:8px;transition:transform .2s}.severity-item:hover{transform:translate(4px)}.severity-item.severity-high{background:linear-gradient(135deg,#fee2e2,#fecaca);border-left:4px solid #dc2626}.severity-item.severity-medium{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.severity-item.severity-low{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-left:4px solid #10b981}.severity-label{display:flex;align-items:center;gap:8px;font-weight:600;color:#374151}.severity-icon{font-size:20px}.severity-value{font-size:28px;font-weight:700;color:var(--color-dark-green)}.station-chart{display:flex;flex-direction:column;gap:16px}.station-bar-item{display:flex;flex-direction:column;gap:8px}.station-bar-label{font-size:13px;font-weight:600;color:#374151}.station-bar-container{position:relative;height:36px;background:#f3f4f6;border-radius:8px;overflow:hidden}.station-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-dark-green) 0%,#4ade80 100%);transition:width .8s ease;border-radius:8px}.station-bar-value{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-weight:600;color:#374151;font-size:14px}.trend-chart{display:flex;justify-content:space-around;align-items:flex-end;gap:8px;height:200px;padding:10px 0}.trend-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.trend-bar-container{width:100%;height:140px;display:flex;align-items:flex-end;justify-content:center}.trend-bar-fill{width:80%;background:linear-gradient(180deg,#3b82f6,#60a5fa);border-radius:6px 6px 0 0;transition:height .8s ease;min-height:4px}.trend-bar-value{font-size:13px;font-weight:600;color:#374151}.trend-bar-label{font-size:11px;color:#6b7280;text-align:center}@media (max-width: 1200px){.dashboard-content-grid{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-page{padding:16px}.metrics-grid{grid-template-columns:1fr}.metric-card{padding:20px}.metric-icon{font-size:36px;width:56px;height:56px}.metric-value{font-size:28px}.page-header h1{font-size:1.5rem}.alert-item-details,.analysis-item-details{flex-direction:column;gap:8px}}.sync-success-banner{padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#10b981,#059669);color:#fff;animation:slideDown .3s ease-out}.sync-success-banner .banner-content{display:flex;align-items:center;gap:1rem}.sync-success-banner .banner-icon{width:50px;height:50px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem}.sync-success-banner .banner-info{display:flex;flex-direction:column}.sync-success-banner .banner-info strong{font-size:1.25rem;margin-bottom:.25rem}.sync-success-banner .banner-info span{font-size:.875rem;opacity:.9}.sync-success-banner .banner-actions{display:flex;gap:.75rem;align-items:center}.device-banner{padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.device-banner.connected{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.device-banner.disconnected{background:linear-gradient(135deg,#64748b,#475569);color:#fff}.device-banner-content{display:flex;align-items:center;gap:1rem}.device-banner-icon{width:50px;height:50px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem}.device-banner-info{display:flex;flex-direction:column}.device-banner-info strong{font-size:1.25rem;margin-bottom:.25rem}.device-banner-info span{font-size:.875rem;opacity:.9}.device-banner-actions{display:flex;gap:.75rem;align-items:center}.banner-hint{font-size:.875rem;opacity:.9;font-style:italic}.sync-progress{display:flex;align-items:center;gap:1rem;min-width:200px}.progress-bar{flex:1;height:8px;background:#ffffff4d;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#fff;transition:width .3s ease;border-radius:4px}.progress-text{font-weight:600;font-size:.875rem}.synced-results-card{margin-bottom:2rem}.synced-results-table-wrapper{overflow-x:auto;margin-bottom:1rem}.synced-results-table{width:100%;border-collapse:collapse}.synced-results-table thead{background:#f9fafb}.synced-results-table th{text-align:left;padding:.75rem 1rem;font-size:.875rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.synced-results-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.synced-results-table tbody tr:hover{background-color:#f9fafb}.synced-results-table td{padding:1rem;font-size:.875rem;color:#1f2937}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.813rem;font-weight:500}.status-badge.synced{background:#dcfce7;color:#166534}.synced-results-actions{display:flex;justify-content:flex-end;gap:.5rem}.btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-success{background:#fff;color:#16a34a}.btn-success:hover:not(:disabled){background:#f0fdf4}.btn-secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-secondary:hover:not(:disabled){background:#ffffff4d}.lab-reports-section{margin-bottom:2rem}.lab-reports-section.status-in-progress{border-left:4px solid #f59e0b;background:#fef3c7}.lab-reports-section.status-all-ready{border-left:4px solid #10b981;background:#d1fae5}.lab-reports-subsection{margin-bottom:1.5rem}.lab-reports-subsection:last-child{margin-bottom:0}.subsection-title{font-size:1rem;font-weight:600;color:var(--color-dark-green);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.lab-reports-list{display:flex;flex-direction:column;gap:.75rem}.lab-report-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:8px;border-left:4px solid #d1d5db;transition:all .2s ease}.lab-report-item:hover{background:#f3f4f6;transform:translate(2px)}.lab-report-item.in-progress{border-left-color:#f59e0b}.lab-report-item.completed{border-left-color:#10b981}.lab-report-item.failed{border-left-color:#ef4444;background:#fef2f2}.lab-report-item.failed:hover{background:#fee2e2}.lab-report-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.lab-report-id{font-weight:600;color:#374151;font-size:.875rem}.lab-report-file{font-size:.813rem;color:#6b7280;word-break:break-word}.lab-report-date{font-size:.75rem;color:#9ca3af}.lab-report-status{font-size:.813rem;color:#6b7280;font-style:italic}.lab-report-error{font-size:.813rem;color:#dc2626;font-weight:500;margin-top:.25rem}.lab-report-actions{display:flex;align-items:center;gap:.5rem}.status-badge.processing{background:#fef3c7;color:#92400e;border:1px solid #fcd34d;padding:.25rem .75rem;border-radius:12px;font-size:.813rem;font-weight:500}.status-badge.failed{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;padding:.25rem .75rem;border-radius:12px;font-size:.813rem;font-weight:500}.btn-sm{padding:.5rem 1rem;font-size:.813rem}.btn-primary:hover:not(:disabled){background:#059669}@media (max-width: 768px){.sync-success-banner,.device-banner{flex-direction:column;gap:1rem}.device-banner-actions{width:100%;justify-content:stretch}.device-banner-actions button{flex:1}.sync-progress{width:100%}.lab-report-item{flex-direction:column;align-items:flex-start;gap:.75rem}.lab-report-actions{width:100%;justify-content:flex-end}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#fff;font-size:1.5rem}.modal-close{background:none;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.modal-close:hover{background-color:#f0f0f0}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid #e0e0e0}.form-group label{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-weight:500;color:#333}.prompt-badge{display:inline-block;padding:2px 8px;background-color:var(--color-dark-green);color:#fff;font-size:.75rem;font-weight:600;border-radius:4px;text-transform:uppercase}.file-info{padding:12px;background-color:#f5f7fa;border-radius:4px;display:flex;align-items:center;gap:8px}.file-size{color:#666;font-size:.9rem}.system-prompt-textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5;resize:vertical;min-height:300px;box-sizing:border-box}.system-prompt-textarea:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #0596691a}.form-help-text{display:block;margin-top:6px;color:#666;font-size:.85rem}@media (max-width: 768px){.modal-content{max-width:100%;max-height:100vh;border-radius:0}.modal-body{padding:15px}.system-prompt-textarea{min-height:200px}}.stations-page{padding:20px}.station-modal .modal-header h3{color:#fff!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-in}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.sample-modal .modal-header h2{margin:0;font-size:1.5rem;color:#fff!important}.modal-close{background:none;border:none;font-size:28px;color:#9ca3af;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background-color:#f3f4f6;color:#374151}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:#374151}.form-group .required{color:#dc2626}.form-control{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-control:focus{outline:none;border-color:var(--color-dark-green)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb;border-radius:0 0 12px 12px}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.checkbox-label{display:flex;align-items:flex-start;gap:8px;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{margin-top:2px;cursor:pointer;width:18px;height:18px;flex-shrink:0}.checkbox-label span{flex:1;line-height:1.5}.form-hint{display:block;margin-top:6px;font-size:12px;color:#6b7280;font-style:italic}@media (max-width: 600px){.modal-content{width:95%;max-height:95vh}.modal-header h2{font-size:1.25rem}.modal-body{padding:16px}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.samples-page{padding:20px}.filters-section{background:var(--color-white);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.filters-row{display:grid;grid-template-columns:1fr 1fr 2fr;gap:15px;margin-bottom:15px;overflow:visible}.search-row{display:flex;gap:15px;align-items:flex-end}.search-input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.table-container{background:var(--color-white);border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.samples-table th,.samples-table td{padding:12px;text-align:left;border-bottom:1px solid #eee;vertical-align:middle}.samples-table th{background-color:#f8f9fa;font-weight:600;color:var(--color-dark-green)}.samples-table tbody tr:hover{background-color:#f8f9fa}.sample-code{font-weight:600;color:var(--color-dark-green)}.analyses-count{display:inline-flex;align-items:center;justify-content:center;min-width:30px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;background-color:#e5e7eb;color:#6b7280}.analyses-count.has-analyses{background-color:#dbeafe;color:#1e40af}.action-buttons{display:flex;gap:8px}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background-color:#047857}.btn-secondary{background-color:#e5e7eb;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#d1d5db}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-sm{padding:6px 12px;font-size:13px}.no-results{text-align:center;padding:40px;color:#666}@media (max-width: 768px){.samples-page{padding:16px}.filters-row{grid-template-columns:1fr}.search-row{flex-direction:column;align-items:stretch}.action-buttons{flex-direction:column}.page-header{flex-direction:column;gap:16px;align-items:stretch}}.link-sample-modal{max-width:600px;display:flex;flex-direction:column;max-height:90vh;overflow:hidden!important}.link-sample-modal .modal-body{overflow:visible;flex:1;min-height:0}.link-sample-modal .form-group{position:relative}.link-sample-modal .react-select-container{width:100%}.link-sample-modal .react-select__menu{max-height:300px;overflow-y:auto}.link-sample-modal .modal-header h2{color:#fff}.search-hint{margin-top:8px;padding:8px 0;font-size:12px;color:#6b7280}.analysis-page{padding:20px;min-height:100vh}.header-actions{display:flex;gap:10px}.filters-row{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:15px;overflow:hidden}.filters-row-second{grid-template-columns:1.4fr 1fr auto;align-items:flex-end}.filters-row-second .search-container{display:flex;flex-direction:column;gap:5px}.filters-row-second .search-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;transition:border-color .3s}.filters-row-second .search-input:focus{outline:none;border-color:var(--color-dark-green)}.filter-dropdown,.date-range-picker{display:flex;flex-direction:column;gap:5px}.filter-label{font-size:14px;font-weight:600;color:var(--color-dark-green);margin-bottom:5px}.filter-select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;transition:border-color .3s}.filter-select:focus{outline:none;border-color:var(--color-dark-green)}.date-inputs{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.date-input{flex:1;min-width:0;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.date-input:focus{outline:none;border-color:var(--color-dark-green)}.date-separator{color:#666;font-size:14px;flex-shrink:0;white-space:nowrap}.analysis-table{width:100%;border-collapse:collapse}.analysis-table thead th{background-color:#f8f9fa;padding:15px 12px;text-align:left;font-weight:600;color:var(--color-dark-green);border-bottom:2px solid #dee2e6}.analysis-table tbody td{padding:12px;border-bottom:1px solid #eee;vertical-align:middle}.analysis-table tbody tr.clickable-row:hover{background-color:#f0f7f0;cursor:pointer}.analysis-table tbody tr.row-expanded{background-color:#e8f5e9;border-left:3px solid var(--color-dark-green)}.expand-btn{background:none;border:none;cursor:pointer;font-size:12px;color:var(--color-dark-green);padding:5px 10px;transition:transform .2s}.expand-btn:hover{transform:scale(1.2)}.sample-code{font-family:Courier New,monospace;font-weight:600;color:var(--color-dark-green)}.station-name{font-weight:500}.text-muted{color:#999}.alert-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.alert-badge.has-alert{background-color:#fff3cd;color:#856404;border:1px solid #ffc107}.alert-badge.no-alert{background-color:#d4edda;color:#155724;border:1px solid #28a745}.expanded-row td{padding:0!important;background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.expanded-content{padding:15px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.expanded-section{margin-bottom:15px}.expanded-section h4{margin:0 0 10px;color:var(--color-dark-green);font-size:1rem}.analyte-groups{display:flex;flex-direction:column;gap:12px}.analyte-group{border:1px solid #e5e5e5;border-radius:8px;padding:10px;background:#fbfbfb}.group-header{font-weight:700;color:#2f3b1f;margin-bottom:10px;font-size:.95rem;text-transform:uppercase;letter-spacing:.4px}.analyte-subgroups{display:flex;flex-direction:column;gap:10px}.analyte-subgroup{display:flex;flex-direction:column;gap:6px}.subgroup-header{font-weight:600;color:#55614a;font-size:.9rem}.analyte-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.analyte-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:6px;transition:all .2s;box-shadow:0 1px 3px #0000001a;height:100px}.analyte-item.normal{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #28a745}.analyte-item.borderline{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffc107}.analyte-item.alert{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:1px solid #dc3545;box-shadow:0 1px 4px #dc354533}.analyte-item:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.analyte-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;justify-content:center}.analyte-name{font-weight:600;font-size:11px;text-transform:capitalize;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analyte-item.normal .analyte-name{color:#155724}.analyte-item.borderline .analyte-name{color:#856404}.analyte-item.alert .analyte-name{color:#721c24}.analyte-value{font-weight:700;font-size:13px;line-height:1.2}.analyte-item.normal .analyte-value{color:#0a3d14}.analyte-item.borderline .analyte-value{color:#664d03}.analyte-item.alert .analyte-value{color:#5a1419}.analyte-range{font-size:9px;line-height:1.2;font-style:italic;opacity:.85}.analyte-item.normal .analyte-range{color:#155724}.analyte-item.borderline .analyte-range{color:#856404}.analyte-item.alert .analyte-range{color:#721c24}.status-icon{font-size:18px;flex-shrink:0;margin-left:8px;display:flex;align-items:center;justify-content:center}.analyte-item.alert .status-icon,.analyte-item.borderline .status-icon{animation:pulse 2s ease-in-out infinite}.analyte-item.normal .status-icon{opacity:.7}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.expanded-actions{display:flex;gap:10px;padding-top:15px;border-top:1px solid #dee2e6}.drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999;animation:fadeIn .3s ease-out}.metadata-drawer{position:fixed;top:0;right:-500px;width:500px;max-width:90vw;height:100vh;background:#fff;box-shadow:-2px 0 10px #0003;z-index:1000;transition:right .3s ease-out;display:flex;flex-direction:column}.metadata-drawer.open{right:0}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #dee2e6;background-color:var(--color-dark-green);color:#fff}.drawer-header h3{margin:0;font-size:1.2rem}.drawer-header .close-btn{color:#fff;font-size:28px}.drawer-header .close-btn:hover{color:var(--color-bright-green)}.drawer-content{flex:1;overflow-y:auto;padding:20px}.metadata-grid{display:flex;flex-direction:column;gap:15px}.metadata-item{padding:15px;background:#f8f9fa;border-radius:6px;border-left:3px solid var(--color-dark-green)}.metadata-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:5px}.metadata-value{font-size:14px;font-weight:500;color:var(--color-text);word-break:break-word}.no-metadata{text-align:center;color:#999;padding:40px 20px}@media (max-width: 1024px){.filters-row{grid-template-columns:1fr 1fr}.filters-row .date-range-picker{grid-column:span 2}.analyte-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.analyte-group{padding:8px}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:15px}.filters-row{grid-template-columns:1fr}.filters-row .date-range-picker{grid-column:1}.search-row{flex-direction:column;align-items:stretch}.search-row .search-container{max-width:100%}.analyte-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.action-buttons,.expanded-actions{flex-direction:column}.metadata-drawer{width:100%;right:-100%}}.alerts-page{padding:20px;min-height:100vh}.page-header h1{margin:0;color:var(--color-dark-green);font-size:2rem}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:20px;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card.highlight{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:2px solid #ffc107}.stat-icon{font-size:48px;line-height:1}.stat-content{flex:1}.stat-value{font-size:36px;font-weight:700;color:var(--color-dark-green);line-height:1;margin-bottom:8px}.stat-label{font-size:14px;color:#666;font-weight:500}.filters-section{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.filters-row{display:grid;grid-template-columns:1fr 1fr 1fr 1.5fr;gap:15px;margin-bottom:15px;overflow:hidden}.search-row{display:flex;gap:15px;align-items:flex-end;justify-content:flex-end}.alerts-table{width:100%;border-collapse:collapse}.alerts-table thead th{background-color:#f8f9fa;padding:15px 12px;text-align:left;font-weight:600;color:var(--color-dark-green);border-bottom:2px solid #dee2e6;white-space:nowrap}.alerts-table tbody td{padding:12px;border-bottom:1px solid #eee;vertical-align:middle}.alerts-table tbody tr.alert-row:hover{background-color:#f8f9fa}.severity-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.severity-badge.severity-high{background-color:#f8d7da;color:#721c24;border:1px solid #dc3545}.severity-badge.severity-medium{background-color:#fff3cd;color:#856404;border:1px solid #ffc107}.severity-badge.severity-low{background-color:#d1ecf1;color:#0c5460;border:1px solid #17a2b8}.analyte-cell{display:flex;flex-direction:column;gap:2px}.analyte-name{font-weight:600;color:#333}.analyte-code{font-size:11px;color:#666;font-family:Courier New,monospace}.value-highlight{font-weight:700;color:#dc3545;font-size:14px}.threshold-range{font-size:13px;color:#666;font-family:Courier New,monospace}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.modal{background:#fff;border-radius:12px;padding:0;max-width:700px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #dee2e6;background-color:var(--color-dark-green);color:#fff;border-radius:12px 12px 0 0}.modal-header h3{margin:0;font-size:1.3rem}.modal-header .close-btn{color:#fff;font-size:28px;background:none;border:none;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.modal-header .close-btn:hover{background-color:#fff3}.modal-body{padding:24px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-item label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.detail-item span{font-size:15px;font-weight:500;color:#333}.modal-footer{padding:20px 24px;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end;gap:10px}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;padding:20px;border-top:1px solid #eee}.pagination-info{font-size:14px;color:#666}.pagination button:disabled{opacity:.5;cursor:not-allowed}.no-results{text-align:center;padding:40px 20px;color:#999;font-style:italic}.table-wrapper{overflow-x:auto}@media (max-width: 1024px){.filters-row{grid-template-columns:1fr 1fr}.filters-row>*:last-child{grid-column:span 2}.detail-grid,.stats-container{grid-template-columns:1fr}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:15px}.filters-row{grid-template-columns:1fr}.filters-row>*:last-child{grid-column:1}.search-row{justify-content:flex-start}.action-buttons{flex-direction:column}.modal{width:95%}.alerts-table{font-size:13px}.alerts-table thead th,.alerts-table tbody td{padding:8px 6px}}.multi-select-dropdown{position:relative;width:100%}.dropdown-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:6px}.dropdown-control{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:border-color .2s;min-height:42px}.dropdown-control:hover{border-color:var(--color-dark-green)}.dropdown-value{flex:1;color:#374151;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{color:#6b7280;font-size:10px;transition:transform .2s;margin-left:8px}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;z-index:1000}.dropdown-select-all{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;font-weight:600;color:var(--color-dark-green);transition:background .2s}.dropdown-select-all:hover{background:#f3f4f6}.dropdown-divider{height:1px;background:#e5e7eb;margin:4px 0}.dropdown-option{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:background .2s}.dropdown-option:hover{background:#f3f4f6}.dropdown-option input[type=checkbox],.dropdown-select-all input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--color-dark-green)}.dropdown-option span{color:#374151;font-size:14px}.dropdown-empty{padding:20px 12px;text-align:center;color:#9ca3af;font-size:14px}.dropdown-menu::-webkit-scrollbar{width:8px}.dropdown-menu::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.dropdown-menu::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:#9ca3af}.line-chart-container{width:100%}.chart-legend{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.legend-item-station{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#fff;border-radius:6px;box-shadow:0 1px 2px #0000000d}.legend-color-box{width:20px;height:12px;border-radius:2px;flex-shrink:0}.legend-label{font-size:14px;font-weight:600;color:#374151}.legend-count{font-size:12px;color:#6b7280}.chart-wrapper{width:100%;overflow-x:auto;background:#fff;border-radius:8px;padding:20px}.line-chart-svg{width:100%;height:auto;max-width:1000px;display:block;margin:0 auto}.chart-empty{text-align:center;padding:60px 20px;color:#9ca3af;font-size:14px}@media (max-width: 768px){.chart-legend{gap:8px}.legend-item-station{padding:4px 8px;font-size:12px}.legend-color-box{width:16px;height:10px}.chart-wrapper{padding:10px;overflow-x:scroll}.line-chart-svg{min-width:600px}}.chart-tooltip{background:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026,0 0 0 1px #0000000d;min-width:280px;max-width:320px;font-size:13px;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-100%) scale(.95)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.tooltip-header{padding:12px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb;border-radius:8px 8px 0 0;border-left:4px solid;font-size:14px;color:#111827}.tooltip-body{padding:12px 16px}.tooltip-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;gap:12px}.tooltip-row.tooltip-highlight{background:#f0fdf4;margin:0 -16px;padding:8px 16px;border-left:3px solid #10b981}.tooltip-label{color:#6b7280;font-weight:500;white-space:nowrap}.tooltip-value{color:#111827;text-align:right;flex:1}.tooltip-value.tooltip-warning{color:#dc2626;font-weight:600}.tooltip-value.tooltip-success{color:#10b981;font-weight:600}.tooltip-divider{height:1px;background:#e5e7eb;margin:8px 0}.tooltip-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;line-height:1}.tooltip-badge-success{background:#d1fae5;color:#065f46}.tooltip-badge-warning{background:#fee2e2;color:#991b1b}.tooltip-footer{font-size:11px;color:#9ca3af;padding-top:8px}svg circle{cursor:pointer;transition:r .2s ease,stroke-width .2s ease}svg circle:hover{r:8;stroke-width:3}.trends-page{padding:20px;background-color:#f5f7fa;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h1{color:var(--color-dark-green);font-size:1.8rem}.alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.filters-section{background:var(--color-white);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a;overflow:visible}.filters-row{display:grid;grid-template-columns:1.5fr 1fr 1.5fr;gap:15px;margin-bottom:15px;overflow:visible}.filters-row>*{min-width:0}.action-buttons{display:flex;gap:10px;justify-content:flex-end}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background:var(--color-white);border-radius:8px;box-shadow:0 2px 4px #0000001a}.chart-section{background:var(--color-white);border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.chart-title h2{margin:0 0 4px;color:var(--color-dark-green);font-size:1.5rem}.chart-subtitle{font-size:14px;color:#6b7280}.threshold-legend{display:flex;gap:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#374151;padding:6px 12px;background:#f9fafb;border-radius:6px}.legend-line{width:30px;height:2px;display:inline-block}.legend-line.legend-min,.legend-line.legend-max{background:repeating-linear-gradient(to right,#dc2626 0,#dc2626 8px,transparent 8px,transparent 12px)}.legend-line.legend-target{background:repeating-linear-gradient(to right,#10b981 0,#10b981 8px,transparent 8px,transparent 12px)}.threshold-setup-prompt{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;flex-wrap:wrap}.prompt-content{display:flex;align-items:center;gap:8px;flex:1}.prompt-icon{font-size:18px}.prompt-text{font-size:13px;color:#92400e;font-weight:500}.threshold-setup-prompt .btn{white-space:nowrap}.empty-chart-state{text-align:center;padding:80px 20px;color:#6b7280;background:#f9fafb;border-radius:8px;border:2px dashed #d1d5db}.empty-chart-state p{margin:8px 0;font-size:14px}.empty-chart-hint{color:#9ca3af;font-size:13px!important}.empty-state{text-align:center;padding:80px 20px;background:var(--color-white);border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-state-icon{font-size:64px;margin-bottom:16px}.empty-state h3{color:var(--color-dark-green);margin:0 0 8px;font-size:1.3rem}.empty-state p{color:#6b7280;margin:0;font-size:14px}@media (max-width: 1024px){.filters-row{grid-template-columns:1fr}.chart-header{flex-direction:column;gap:16px}.threshold-legend{justify-content:flex-start}}@media (max-width: 768px){.trends-page{padding:16px}.page-header h1{font-size:1.5rem}.action-buttons{flex-direction:column}.action-buttons button{width:100%}}.settings-page{max-width:1400px;margin:0 auto;padding:2rem}.settings-header{margin-bottom:24px;padding-bottom:0;border-bottom:none}.settings-header h1{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-page-header);font-weight:600}.settings-header p{margin:0;color:#666;font-size:.875rem}.alert{padding:15px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;animation:slideIn .3s ease-out}.alert-success{background-color:#d4edda;color:#155724;border-left:4px solid #28a745}.alert-error{background-color:#f8d7da;color:#721c24;border-left:4px solid #dc3545}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.settings-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px;overflow:hidden;transition:box-shadow .3s ease}.settings-card:hover{box-shadow:0 4px 12px #0000001f}.settings-card-header{padding:20px 24px;background:#fff;border-bottom:none}.settings-card-header h2{margin:0;color:var(--color-text);font-size:var(--font-size-section-header);font-weight:600}.settings-card-body{padding:24px}.settings-card-footer{padding:20px 24px;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex-direction:column}.form-group label{color:var(--color-dark-green);margin-bottom:8px;font-size:.95rem}.form-group input,.form-group select{padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:all .3s ease;background:#fff}.field-hint{margin:6px 0 0;font-size:.85rem;color:#666;font-style:italic}.crops-select-wrapper{margin-top:8px}.crops-react-select{font-size:.95rem}.crops-select__control{border:2px solid #e0e0e0!important;border-radius:8px!important;min-height:48px!important;box-shadow:none!important;transition:all .3s ease!important}.crops-select__control:hover{border-color:var(--color-dark-green)!important}.crops-select__control--is-focused{border-color:var(--color-dark-green)!important;box-shadow:0 0 0 3px #0032321a!important}.crops-select__placeholder{color:#999!important}.crops-select__input-container{color:#333!important}.crops-select__multi-value{background-color:var(--color-bright-green)!important;border:1px solid var(--color-dark-green)!important;border-radius:20px!important;padding:4px 8px!important}.crops-select__multi-value__label{color:var(--color-dark-green)!important;font-size:.85rem!important;font-weight:500!important;padding:0 4px 0 0!important}.crops-select__multi-value__remove{color:var(--color-dark-green)!important;cursor:pointer!important;padding:2px!important;border-radius:50%!important}.crops-select__multi-value__remove:hover{background-color:#0032321a!important;color:var(--color-dark-green)!important}.crops-select__menu{border-radius:8px!important;box-shadow:0 4px 12px #00000026!important;border:2px solid #e0e0e0!important;margin-top:4px!important}.crops-select__menu-list{padding:4px!important;max-height:300px!important;overflow-y:auto!important;overflow-x:hidden!important}.crops-select__menu-list::-webkit-scrollbar{width:8px}.crops-select__menu-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.crops-select__menu-list::-webkit-scrollbar-thumb{background:silver;border-radius:4px}.crops-select__menu-list::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.crops-select__option{padding:12px 16px!important;border-radius:6px!important;margin:2px 0!important;cursor:pointer!important;transition:all .2s ease!important}.crops-select__option:hover{background-color:#f0f7f4!important}.crops-select__option--is-selected{background-color:#e8f5f0!important;color:var(--color-dark-green)!important}.crops-select__option--is-focused{background-color:#f0f7f4!important}.crops-select__indicator-separator{display:none!important}.crops-select__dropdown-indicator{color:#666!important;padding:8px!important}.crops-select__dropdown-indicator:hover{color:var(--color-dark-green)!important}.crops-select__clear-indicator{color:#666!important;padding:8px!important}.crops-select__clear-indicator:hover{color:var(--color-dark-green)!important}.settings-card-footer .btn{padding:12px 24px;font-size:.95rem;font-weight:600;border-radius:8px;transition:all .3s ease}.settings-card-footer .btn-primary{background:var(--color-dark-green);color:#fff;border:none}.settings-card-footer .btn-primary:hover:not(:disabled){background:var(--color-dark-green-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0032324d}.settings-card-footer .btn-primary:disabled{background:var(--color-earth-grey);cursor:not-allowed;opacity:.6}.settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-earth-grey)}.settings-loading p{font-size:1.1rem;margin:0}.settings-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:40px}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.settings-empty h2{color:var(--color-dark-green);margin:0 0 12px;font-size:1.5rem}.settings-empty p{color:#666;margin:0;font-size:1rem;max-width:500px}.thresholds-container{display:flex;flex-direction:column;gap:20px}.crop-threshold-section{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.crop-expand-btn{width:100%;padding:16px;background:#f8f9fa;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:12px;transition:background .2s;font-size:1rem}.crop-expand-btn:hover{background:#e9ecef}.expand-icon{font-size:.8rem;color:var(--color-dark-green);display:flex;align-items:center}.stages-list{padding:12px;background:#fff}.stage-section{border:1px solid #e9ecef;border-radius:6px;margin-bottom:12px;overflow:hidden}.stage-section:last-child{margin-bottom:0}.stage-expand-btn{width:100%;padding:12px 16px;background:#fafbfc;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .2s;font-size:.95rem}.stage-expand-btn:hover{background:#f3f4f6}.stage-name{font-weight:600;color:var(--color-dark-green)}.analyte-count{font-size:.85rem;color:#666;margin-left:auto}.stage-content{padding:16px;background:#fff}.empty-stage-message{color:#666;font-size:.9rem;font-style:italic;margin:0 0 12px}.analytes-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.analyte-threshold-row-new{display:grid;grid-template-columns:180px 1fr auto;gap:12px;align-items:center;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;transition:all .2s ease}.analyte-threshold-row-new:hover{border-color:#d0d0d0;box-shadow:0 2px 4px #0000000d}.analyte-threshold-row-with-unit{display:grid;grid-template-columns:140px 120px 1fr auto;gap:12px;align-items:center;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;transition:all .2s ease;position:relative}.analyte-threshold-row-with-unit:hover{border-color:#d0d0d0;box-shadow:0 2px 4px #0000000d}.validation-error{grid-column:1 / -1;color:#dc3545;font-size:.85rem;margin-top:4px;padding:8px;background:#f8d7da;border:1px solid #f5c2c7;border-radius:4px}.unit-input-section{display:flex;align-items:center}.unit-select{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;transition:all .3s ease;width:100%;background:#fff}.unit-select:disabled{background:#f5f5f5;cursor:not-allowed;color:#666}.unit-select:not(:disabled):hover{border-color:#bbb}.unit-select:not(:disabled):focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #0032321a}.analyte-info{display:flex;flex-direction:column;gap:2px}.analyte-info strong{color:var(--color-dark-green);font-size:.95rem}.analyte-unit{font-size:.8rem;color:#666}.threshold-inputs-new{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.threshold-inputs-new input{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;transition:all .3s ease;width:100%}.threshold-inputs-new input:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #0032321a}.threshold-inputs-new input::placeholder{color:#aaa;font-size:.85rem}.remove-analyte-btn{width:32px;height:32px;border:none;background:#fee;color:#c00;border-radius:4px;cursor:pointer;font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.remove-analyte-btn:hover{background:#fcc;color:#900}.add-analyte-section{margin-top:8px}.add-analyte-select{width:100%;padding:10px 12px;border:2px dashed #d0d0d0;border-radius:6px;background:#fafbfc;font-size:.9rem;color:#666;cursor:pointer;transition:all .2s ease}.add-analyte-select:hover{border-color:var(--color-dark-green);background:#fff}.add-analyte-select:focus{outline:none;border-color:var(--color-dark-green);border-style:solid;box-shadow:0 0 0 3px #0032321a}.stages-threshold-grid{padding:16px;background:#fff}.stage-threshold-card{margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:8px}.stage-threshold-card:last-child{margin-bottom:0}.stage-threshold-card h4{margin:0 0 16px;color:var(--color-dark-green);font-size:1.1rem}.analytes-grid{display:flex;flex-direction:column;gap:12px}.analyte-threshold-row{display:grid;grid-template-columns:200px 1fr;gap:16px;align-items:center;padding:12px;background:#fff;border-radius:6px}.analyte-name{display:flex;flex-direction:column}.analyte-name strong{color:var(--color-dark-green)}.threshold-inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.threshold-inputs input{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;transition:all .3s ease}.threshold-inputs input:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #0032321a}.threshold-inputs input::placeholder{color:#aaa;font-size:.85rem}@media (max-width: 768px){.settings-page{padding:15px}.settings-header h1{font-size:1.5rem}.form-row{grid-template-columns:1fr;gap:15px}.settings-card-header,.settings-card-body{padding:20px}.settings-card-footer{padding:16px 20px;flex-direction:column}.settings-card-footer .btn{width:100%}.card-title-group{flex-direction:column;gap:10px}.card-icon{font-size:1.5rem}.crops-select__menu-list{max-height:200px!important}.crops-select__multi-value{font-size:.8rem!important;padding:3px 6px!important}.analyte-threshold-row{grid-template-columns:1fr;gap:8px}.threshold-inputs{grid-template-columns:1fr}.analyte-threshold-row-new,.analyte-threshold-row-with-unit{grid-template-columns:1fr;gap:12px}.threshold-inputs-new{grid-template-columns:1fr}.remove-analyte-btn{width:100%;height:36px}}.profile-page{padding:2rem;max-width:1200px;margin:0 auto}.profile-header{margin-bottom:1.5rem}.profile-header h1{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-page-header);font-weight:600}.profile-header p{margin:0;color:#666;font-size:.875rem}.profile-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem;overflow:hidden;transition:box-shadow .3s ease}.profile-card:hover{box-shadow:0 4px 12px #0000001f}.profile-card-header{padding:20px 24px;background:#fff;border-bottom:none}.card-title-group{display:flex;align-items:center;gap:10px}.card-icon{font-size:1.125rem;flex-shrink:0;color:var(--color-text)}.profile-card-header h2{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-section-header);font-weight:600}.profile-card-header p{margin:0;color:#666;font-size:.8125rem}.profile-card-body{padding:24px}.profile-card-footer{padding:20px 24px;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{font-size:.8125rem;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:.9375rem;color:var(--color-text);font-weight:400}.role-badge{display:inline-block;padding:.25rem .75rem;background:#edf2f7;color:#2d3748;border-radius:6px;font-size:.875rem;font-weight:600;text-transform:capitalize}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600}.status-badge.active{background:#c6f6d5;color:#22543d}.status-badge.inactive{background:#fed7d7;color:#742a2a}.password-form{max-width:500px}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-text);font-size:.875rem}.form-group input,.form-group select{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:all .3s ease;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #0032321a}.form-group input:hover,.form-group select:hover{border-color:#bbb}.form-group input:disabled{background:#f7fafc;cursor:not-allowed}.form-actions{display:flex;gap:1rem;margin-top:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-dark-green);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-dark-green-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0032324d}.btn-secondary{background:#f3f4f6;color:var(--color-text);border:1px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.permission-name{font-size:.875rem;color:#2d3748;font-weight:500}.permission-status{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px}.permission-status.enabled{background:#c6f6d5;color:#22543d}.permission-status.disabled{background:#fed7d7;color:#742a2a}.no-permissions{color:#718096;font-style:italic;text-align:center;padding:2rem}.field-hint{margin:6px 0 0;font-size:.8125rem;color:#666;font-style:italic}@media (max-width: 768px){.profile-page{padding:1rem}.info-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn{width:100%}}.export-columns-list{display:flex;flex-direction:column;gap:8px}.export-column-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;transition:all .2s ease}.export-column-item:hover{background-color:#f0f0f0;border-color:#d0d0d0}.column-checkbox{display:flex;align-items:center;gap:12px;flex:1}.column-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.column-label{display:flex;align-items:center;gap:8px;cursor:pointer;margin:0;font-size:.95rem}.column-name{font-weight:500;color:#333}.column-type{font-size:.85rem;color:#666;font-style:italic}.column-actions{display:flex;gap:4px}.btn-icon{padding:6px;border:1px solid #d0d0d0;background-color:#fff;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-icon:hover:not(:disabled){background-color:#f0f0f0;border-color:#b0b0b0}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-icon:active:not(:disabled){transform:scale(.95)}.subnav{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e2e8f0;padding-bottom:0}.subnav-btn{background:none;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#718096;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s}.subnav-btn:hover{color:var(--color-dark-green);background-color:#f7fafc}.subnav-btn.active{color:var(--color-dark-green);border-bottom-color:var(--color-dark-green)}.access-requests-container{padding:20px}.access-requests-header{margin-bottom:30px}.access-requests-header h2{font-size:24px;font-weight:600;color:#1f2937;margin-bottom:5px}.access-requests-header p{color:#6b7280;font-size:14px}.status-filter-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid #e5e7eb;padding-bottom:2px}.filter-tab{padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.filter-tab:hover{color:#059669}.filter-tab.active{color:#059669;border-bottom-color:#059669}.no-requests-message{text-align:center;padding:60px 20px;color:#9ca3af}.no-requests-icon{width:64px;height:64px;margin:0 auto 20px;color:#d1d5db}.no-requests-message p{font-size:16px;color:#6b7280}.requests-list{display:flex;flex-direction:column;gap:16px}.request-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .2s}.request-card:hover{box-shadow:0 4px 6px #0000000d}.request-info{flex:1;display:flex;align-items:center;justify-content:space-between;gap:16px}.request-user{display:flex;align-items:center;gap:16px}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-approved{background:#d1fae5;color:#065f46}.status-badge.status-rejected{background:#fee2e2;color:#991b1b}.status-badge.status-expired{background:#f3f4f6;color:#4b5563}.user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#059669,#10b981);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;flex-shrink:0}.user-details h3{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:4px}.user-email{color:#6b7280;font-size:14px;margin-bottom:8px}.request-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#9ca3af}.request-meta span{display:block}.rejection-reason{color:#ef4444;font-weight:500}.request-actions{display:flex;gap:8px;flex-shrink:0}.btn-approve,.btn-reject{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-approve{background:#059669;color:#fff}.btn-approve:hover{background:#047857}.btn-reject{background:#ef4444;color:#fff}.btn-reject:hover{background:#dc2626}.reject-form{padding:20px}.reject-info{margin-bottom:20px;color:#4b5563}.reject-form .form-group{margin-bottom:20px}.reject-form label{display:block;margin-bottom:8px;font-weight:500;color:#374151}.reject-form textarea{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical}.reject-form textarea:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.btn-reject-confirm{background:#ef4444!important}.btn-reject-confirm:hover{background:#dc2626!important}.no-org-message,.loading-message{text-align:center;padding:40px 20px;color:#6b7280}.results-summary{padding:12px 0;font-size:14px;color:#6b7280;border-bottom:1px solid #e5e7eb;margin-bottom:16px}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding:20px 0}.pagination-btn{padding:8px 16px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#059669;color:#059669}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-pages{display:flex;align-items:center;gap:4px}.pagination-page{min-width:40px;height:40px;padding:8px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination-page:hover{background:#f9fafb;border-color:#059669;color:#059669}.pagination-page.active{background:#059669;border-color:#059669;color:#fff}.pagination-ellipsis{padding:0 8px;color:#9ca3af;font-size:14px}.users-page{padding:2rem;max-width:1400px;margin:0 auto}.users-sub-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e5e7eb}.sub-tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-2px}.sub-tab:hover{color:#059669;background:#f3f4f6}.sub-tab.active{color:#059669;border-bottom-color:#059669}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.users-header h1{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-page-header);font-weight:600}.users-header p{margin:0;color:#666;font-size:.875rem}.users-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:#f8f9fa;color:var(--color-text)}.users-table th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:1rem;border-bottom:1px solid #e2e8f0}.users-table tbody tr:hover{background-color:#f7fafc}.users-table tbody tr:last-child td{border-bottom:none}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8125rem;font-weight:500;background-color:#edf2f7;color:var(--color-text);border:1px solid #e2e8f0}.status-badge{display:inline-block;padding:.375rem .875rem;border-radius:12px;font-size:.8125rem;font-weight:600;text-transform:capitalize;letter-spacing:.3px}.status-badge.active{background-color:#48bb78;color:#fff}.status-badge.inactive{background-color:#cbd5e0;color:#2d3748}.status-badge.pending{background-color:#fbbf24;color:#78350f}.status-badge.accepted{background-color:#10b981;color:#fff}.status-badge.rejected{background-color:#ef4444;color:#fff}.status-badge.expired{background-color:#f97316;color:#fff}.status-badge.cancelled{background-color:#6b7280;color:#fff}.actions-cell{display:flex;gap:.5rem}.btn-action{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s}.btn-action:hover:not(:disabled){background-color:#edf2f7}.btn-action:disabled{opacity:.4;cursor:not-allowed}.btn-action.btn-edit:hover:not(:disabled){background-color:#bee3f8}.btn-action.btn-password:hover:not(:disabled){background-color:#feebc8}.btn-action.btn-delete:hover:not(:disabled){background-color:#fed7d7}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e2e8f0}.modal-header h2{margin:0;font-size:var(--font-size-section-header);font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:2rem;color:#718096;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s}.modal-close:hover{background-color:#f7fafc}.user-form{padding:2rem}.user-form .form-group{margin-bottom:1.25rem}.user-form .form-group label{display:block;margin-bottom:.5rem;color:var(--color-text);font-size:.875rem}.user-form .form-group input[type=email],.user-form .form-group input[type=password],.user-form .form-group input[type=text],.user-form .form-group select{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:all .3s ease;background:#fff}.user-form .form-group input:focus,.user-form .form-group select:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #0032321a}.user-form .form-group input:hover:not(:disabled),.user-form .form-group select:hover{border-color:#bbb}.user-form .form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.user-form .form-group small{display:block;margin-top:.375rem;color:#666;font-size:.8125rem}.user-form .checkbox-wrapper{margin-top:0}.user-form .checkbox-label{display:flex;align-items:center;cursor:pointer;margin-bottom:0;font-size:.875rem;font-weight:400}.user-form .checkbox-label input[type=checkbox]{width:auto;margin-right:.5rem;cursor:pointer;margin-top:0}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1.5rem;margin-top:1rem;border-top:1px solid #e2e8f0}.btn-primary{background-color:var(--color-dark-green);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background-color:var(--color-dark-green-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0032324d}.btn-secondary{background-color:#f3f4f6;color:var(--color-text);border:1px solid #e5e7eb;padding:.75rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background-color:#e5e7eb}.no-data{text-align:center;padding:3rem 1rem;color:#718096;font-style:italic}.no-org-message,.loading-message{text-align:center;padding:3rem 1rem;color:#718096;font-size:1.1rem}@media (max-width: 768px){.users-page{padding:1rem}.users-header{flex-direction:column;align-items:flex-start;gap:1rem}.users-table{font-size:.9rem}.users-table th,.users-table td{padding:.75rem .5rem}.actions-cell{flex-direction:column}.modal-content{width:95%}}.roles-page{padding:2rem;max-width:1400px;margin:0 auto}.roles-header{margin-bottom:1.5rem}.roles-header h1{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-page-header);font-weight:600}.roles-subtitle{margin:0;color:#666;font-size:.875rem}.roles-content{display:grid;grid-template-columns:300px 1fr;gap:2rem}.roles-list{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;height:fit-content}.roles-list h3{margin:0 0 1rem;color:var(--color-text);font-size:var(--font-size-section-header);font-weight:var(--font-weight-section)}.roles-items{display:flex;flex-direction:column;gap:.75rem}.role-item{padding:1rem;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.role-item:hover{border-color:var(--color-dark-green);background-color:#f7fafc}.role-item.active{border-color:var(--color-dark-green);background-color:#0032320d}.role-name{font-weight:600;color:var(--color-text);margin-bottom:.25rem}.role-description{font-size:.85rem;color:#718096}.role-details{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.role-header{margin-bottom:1.5rem;padding-bottom:0;border-bottom:none}.role-header h2{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-section-header);font-weight:var(--font-weight-section)}.role-desc{margin:0;color:#666;font-size:.8125rem}.permissions-section{margin-bottom:2rem}.permissions-section h3{margin:0 0 .875rem;color:var(--color-text);font-size:var(--font-size-card-header);font-weight:var(--font-weight-section)}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.permission-badge{display:flex;align-items:center;padding:.625rem .875rem;background-color:#f8f9fa;border:1px solid #e2e8f0;border-radius:6px;color:var(--color-text);font-size:.8125rem;font-weight:400}.permission-badge.all-permissions{background-color:var(--color-dark-green);border-color:var(--color-dark-green);color:#fff;grid-column:1 / -1;justify-content:center;font-size:.875rem;font-weight:500}.no-permissions{text-align:center;padding:2rem;color:#718096;font-style:italic}.role-info-box{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;display:flex;gap:2rem}.info-item{color:var(--color-text);font-size:.95rem}.info-item strong{color:#2d3748;margin-right:.5rem}.no-selection{display:flex;align-items:center;justify-content:center;height:300px;color:#718096;font-size:1.1rem;font-style:italic}.loading-message{text-align:center;padding:3rem 1rem;color:#718096;font-size:1.1rem}@media (max-width: 992px){.roles-content{grid-template-columns:1fr}.roles-list{order:2}.role-details{order:1}}@media (max-width: 768px){.roles-page{padding:1rem}.permissions-grid{grid-template-columns:1fr}.role-info-box{flex-direction:column;gap:1rem}}.devices-page{padding:2rem;max-width:1400px;margin:0 auto}.devices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.devices-header h1{margin:0 0 4px;color:var(--color-text);font-size:var(--font-size-page-header);font-weight:600}.devices-header p{margin:0;color:#666;font-size:.875rem}.devices-unsupported{text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.unsupported-icon{font-size:4rem;margin-bottom:1rem}.devices-unsupported h2{font-size:var(--font-size-section-header);font-weight:var(--font-weight-section);color:#ef4444;margin-bottom:1rem}.devices-unsupported p{color:#6b7280;margin-bottom:.5rem}.device-profile-selector{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}.device-profile-selector label{font-weight:500;color:#374151}.device-profile-selector select{flex:1;padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:#fff;cursor:pointer}.device-profile-selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.connection-banner{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.banner-content{display:flex;align-items:center;gap:1rem}.banner-icon{width:40px;height:40px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.banner-info{display:flex;flex-direction:column}.banner-info strong{font-size:1.125rem;margin-bottom:.25rem}.banner-info span{font-size:.875rem;opacity:.9}.banner-actions{display:flex;gap:.75rem}.wifi-status-indicator{display:block;margin-top:.25rem;font-size:.813rem;opacity:.95;font-weight:500}.devices-list{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:2rem}.devices-list h2{font-size:var(--font-size-section-header);font-weight:var(--font-weight-section);color:var(--color-text);margin-bottom:1.25rem}.empty-state{text-align:center;padding:3rem 1rem;color:#6b7280}.empty-state p{margin-bottom:.5rem}.devices-table-wrapper{overflow-x:auto}.devices-table{width:100%;border-collapse:collapse}.devices-table thead{background:#f8f9fa}.devices-table th{text-align:left;padding:.75rem 1rem;font-size:.8125rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.devices-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.devices-table tbody tr:hover{background-color:#f9fafb}.devices-table td{padding:1rem;font-size:.875rem;color:#1f2937}.device-name{font-weight:500}.device-id{font-family:monospace;color:#6b7280;font-size:.813rem}.device-profile{color:#6b7280}.device-status{display:flex;align-items:center;gap:.5rem}.status-indicator{width:8px;height:8px;border-radius:50%}.status-text{font-size:.875rem;font-weight:500}.device-actions{display:flex;gap:.5rem}.devices-info{background:#f0f9ff;border:1px solid #bfdbfe;border-radius:8px;padding:1.5rem}.devices-info h3{font-size:var(--font-size-card-header);font-weight:var(--font-weight-section);color:var(--color-text);margin-bottom:.875rem}.devices-info ul{list-style:none;padding:0;margin:0}.devices-info li{padding-left:1.5rem;position:relative;margin-bottom:.5rem;color:#1e40af;font-size:.875rem}.devices-info li:before{content:"→";position:absolute;left:0;font-weight:700}.btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#f9fafb}.btn-sm{padding:.375rem .75rem;font-size:.813rem}.loading{text-align:center;padding:3rem;color:#6b7280;font-size:1rem}@media (max-width: 768px){.devices-page{padding:1rem}.devices-header{flex-direction:column;align-items:stretch;gap:1rem}.devices-header h1{font-size:1.5rem}.connection-banner{flex-direction:column;gap:1rem}.devices-table-wrapper{overflow-x:scroll}.devices-table{min-width:800px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body .form-group{margin-bottom:1.5rem}.modal-body .form-group:last-child{margin-bottom:0}.modal-body label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.modal-body input{width:100%;padding:.625rem .875rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .15s ease,box-shadow .15s ease}.modal-body input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-body input:disabled{background-color:#f9fafb;cursor:not-allowed}.wifi-status-display{padding:.75rem 1rem;background:#f0f9ff;border:1px solid #bfdbfe;border-radius:6px;font-size:.875rem;color:#1e40af;margin-top:1rem}.wifi-status-display.configuring{background:#fef3c7;border-color:#fbbf24;color:#92400e}.wifi-status-display strong{font-weight:600;display:block;margin-bottom:.5rem}.wifi-status-display p{margin:.5rem 0 0;font-size:.813rem}.wifi-status-display p small{font-size:.75rem;color:#6b7280}.modal-footer{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem}.modal-footer .btn{min-width:100px}.settings-layout{display:flex;height:100vh;width:100%;overflow:hidden}.settings-sidebar{width:280px;min-width:280px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;overflow-y:auto;height:100vh}.settings-sidebar-header{padding:2rem 1.5rem 1.5rem;border-bottom:1px solid #e5e7eb}.settings-sidebar-header h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#111827}.settings-sidebar-header p{margin:0;font-size:.875rem;color:#6b7280}.settings-sidebar-nav{flex:1;padding:1rem 0}.settings-sidebar-nav ul{list-style:none;padding:0;margin:0}.settings-sidebar-nav li{margin:0}.settings-sidebar-nav a{display:flex;align-items:center;padding:.875rem 1.5rem;color:#4b5563;text-decoration:none;transition:all .2s ease;font-size:.95rem;font-weight:500;border-left:3px solid transparent}.settings-sidebar-nav a:hover{background-color:#f3f4f6;color:#111827}.settings-sidebar-nav a.active{background-color:#eff6ff;color:#2563eb;border-left-color:#2563eb}.settings-sidebar-nav .nav-icon{font-size:1.25rem;margin-right:.75rem;display:flex;align-items:center;justify-content:center;width:24px}.settings-sidebar-nav .nav-label{flex:1}.settings-content{flex:1;overflow-y:auto;background:#f9fafb;height:100vh}.settings-sidebar-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;margin-top:auto}.exit-settings-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.exit-settings-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.exit-settings-btn:active{transform:translateY(0)}.exit-icon{font-size:1.25rem;font-weight:600}.exit-label{flex:1;text-align:center}@media (max-width: 768px){.settings-layout{flex-direction:column}.settings-sidebar{width:100%;border-right:none;border-bottom:1px solid #e5e7eb;height:auto;max-height:50vh}.settings-content{height:auto;min-height:50vh}.settings-sidebar-nav{padding:.5rem 0}.settings-sidebar-nav a,.settings-sidebar-footer{padding:.75rem 1rem}}.review-sync-page{padding:2rem;max-width:100%;margin:0 auto;width:100%}.review-sync-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.review-sync-header h1{font-size:2rem;color:#1f2937;margin:0}.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.stat-item{background:#fff;padding:1rem 1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.75rem;color:#1f2937;font-weight:700}.sample-setup-box{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;border:2px solid #e5e7eb;transition:border-color .2s}.sample-setup-box.required{border-color:#ef4444;background:#fef2f2}.setup-box-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.setup-box-title{display:flex;align-items:center;gap:.75rem}.setup-icon{font-size:1.5rem}.setup-box-title h3{margin:0;font-size:1.25rem;color:#1f2937}.required-badge{background:#ef4444;color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600}.setup-box-content{padding:1.5rem}.success-message{color:#059669;font-weight:500;margin:0 0 1rem}.warning-message{color:#dc2626;font-weight:500;margin:0}.sample-chips{display:flex;flex-wrap:wrap;gap:.5rem}.sample-chip{background:#eff6ff;color:#1e40af;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500}.bulk-assign-section{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.bulk-assign-section h4{margin:0 0 1rem;font-size:1rem;color:#374151}.bulk-assign-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.results-section{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;overflow:hidden}.results-section h3{padding:1.5rem;margin:0;border-bottom:1px solid #e5e7eb;font-size:1.25rem;color:#1f2937}.results-table-wrapper{max-height:500px;overflow-y:auto;overflow-x:hidden;width:100%}.results-table{width:100%;border-collapse:collapse;table-layout:auto}.results-table thead{background:#f9fafb;position:sticky;top:0;z-index:10}.results-table th{padding:.75rem .5rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.results-table tbody tr{border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .15s}.results-table tbody tr:hover{background:#f9fafb}.results-table tbody tr.selected{background:#eff6ff}.results-table tbody tr.selected:hover{background:#dbeafe}.results-table td{padding:.75rem .5rem;color:#4b5563;font-size:.875rem}.checkbox-column{width:40px;text-align:center}.checkbox-column input[type=checkbox]{width:18px;height:18px;cursor:pointer}.sample-column{width:22%;min-width:180px}.sample-select{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;width:100%;cursor:pointer}.sample-select:focus{outline:none;border-color:#3b82f6}.not-configured{color:#dc2626;font-size:.875rem;font-style:italic}.action-section{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.device-delete-option{padding-top:1rem;border-top:1px solid #e5e7eb}.device-delete-option label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:#4b5563}.device-delete-option input[type=checkbox]{width:18px;height:18px;cursor:pointer}.drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer{background:#fff;width:500px;max-width:90vw;height:100%;display:flex;flex-direction:column;box-shadow:-4px 0 6px #0000001a;animation:slideIn .3s}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.drawer-header h2{margin:0;font-size:1.5rem;color:#fff}.close-btn{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:.375rem;transition:background-color .15s}.close-btn:hover{background:#f3f4f6}.drawer-content{flex:1;overflow-y:auto;padding:1.5rem}.drawer-footer{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:1rem}.form-section{margin-bottom:2rem}.form-section label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500;font-size:.875rem}.form-hint{margin-top:.25rem;font-size:.75rem;color:#6b7280}.checkbox-option{margin-bottom:1rem}.checkbox-option label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-option input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500;font-size:.875rem}.form-input,.form-select{width:100%;padding:.625rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.form-input:focus,.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled{background:#f3f4f6;color:#6b7280}.samples-list{display:flex;flex-direction:column;gap:1.5rem}.sample-item{background:#f9fafb;padding:1.5rem;border-radius:.5rem;border:1px solid #e5e7eb}.sample-item h4{margin:0 0 1rem;color:#1f2937;font-size:1rem}.processing-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.processing-spinner{background:#fff;padding:2rem 3rem;border-radius:.5rem;text-align:center}.spinner{width:50px;height:50px;margin:0 auto 1rem;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.processing-spinner p{margin:0;color:#374151;font-weight:500}.btn{padding:.625rem 1.25rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.5rem 1rem;font-size:.8125rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{background:#fff;color:#3b82f6;border:1px solid #3b82f6}.btn-outline:hover:not(:disabled){background:#eff6ff}.section-card{background:#fff;border-radius:.75rem;box-shadow:0 2px 8px #0000001a;padding:1.5rem;margin-bottom:2rem;transition:all .3s ease;position:relative}.section-card.focused{border:2px solid #3b82f6;box-shadow:0 4px 16px #3b82f633;animation:pulseGlow 2s ease-in-out infinite}.section-card.completed{border:2px solid #10b981;background:linear-gradient(to right,#10b98108,#fff)}.section-card.disabled{opacity:.5;pointer-events:none;filter:grayscale(.5);background:#f9fafb}.disabled-content{pointer-events:none;opacity:.6}@keyframes pulseGlow{0%,to{box-shadow:0 4px 16px #3b82f633}50%{box-shadow:0 6px 24px #3b82f666}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.section-header h3{font-size:1.25rem;color:#1f2937;margin:0;font-weight:600}.required-badge,.completed-badge,.disabled-badge,.in-progress-badge,.ready-badge{padding:.375rem .875rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:inline-block}.required-badge{background:#fee2e2;color:#991b1b;animation:pulse 2s ease-in-out infinite}.completed-badge{background:#d1fae5;color:#065f46}.disabled-badge{background:#f3f4f6;color:#6b7280}.in-progress-badge{background:#dbeafe;color:#1e40af}.ready-badge{background:#d1fae5;color:#065f46;animation:shimmer 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%,to{background:#d1fae5}50%{background:#a7f3d0}}@media (max-width: 768px){.review-sync-page{padding:1rem}.review-sync-header{flex-direction:column;align-items:flex-start;gap:1rem}.stats-bar{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}.drawer{width:100%;max-width:100vw}.bulk-assign-buttons{flex-direction:column}.bulk-assign-buttons .btn{width:100%}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.react-select-container{width:100%}.react-select__control{min-height:32px!important;border:2px solid #d1d5db!important;box-shadow:none!important}.react-select__control:hover{border:2px solid #d1d5db!important}.react-select__control--is-focused{border:2px solid #3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important}.react-select__value-container{padding:.2rem .4rem!important}.react-select__input{margin:0!important;padding:0!important;font-size:.875rem!important}.react-select__placeholder{color:#9ca3af!important;font-size:.875rem!important}.react-select__menu{font-size:.875rem!important;z-index:1000!important}.react-select__option{font-size:.875rem!important;padding:.5rem .75rem!important}.react-select__option--is-focused{background-color:#eff6ff!important;color:#1f2937!important}.react-select__option--is-selected{background-color:#dbeafe!important;color:#1f2937!important}.react-select__indicator{padding:.4rem!important}.react-select__clear-indicator{padding:.2rem!important}.station-select{width:100%;padding:.4rem;border:2px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;transition:all .2s}.station-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.station-select:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed;opacity:.7}.station-column{position:relative;width:18%;min-width:140px}.station-locked-hint{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none}.sample-column input,.station-column select{width:100%}.results-table tbody tr.unmapped{background:#fef2f2}.results-table tbody tr.unmapped:hover{background:#fee2e2}.results-table tbody tr.mapped{background:#f0fdf4}.results-table tbody tr.mapped:hover{background:#dcfce7}.review-sync-lab-results-page{padding:20px;background-color:#f5f7fa;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{color:var(--color-dark-green);font-size:2rem;margin:0}.lab-report-info{background:var(--color-white);border-radius:12px;padding:20px;margin-bottom:30px;box-shadow:0 2px 8px #00000014}.lab-report-info p{margin:8px 0;color:#374151}.samples-table-container{background:var(--color-white);border-radius:12px;padding:20px;margin-bottom:30px;box-shadow:0 2px 8px #00000014;overflow-x:auto}.samples-table{width:100%;border-collapse:collapse}.samples-table thead{background-color:#f9fafb}.samples-table th{padding:12px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.samples-table td{padding:12px;border-bottom:1px solid #e5e7eb}.sample-row{cursor:pointer;transition:background-color .2s}.sample-row:hover{background-color:#f9fafb}.expand-button{background:none;border:none;cursor:pointer;font-size:12px;color:#6b7280;padding:4px 8px}.expand-button:hover{color:var(--color-dark-green)}.expanded-row{background-color:#f9fafb}.expanded-row td{padding:0;border-bottom:2px solid #e5e7eb}.analytes-table-container{padding:20px}.analytes-table{width:100%;border-collapse:collapse;background:var(--color-white);border-radius:8px;overflow:hidden}.analytes-table thead{background-color:var(--color-dark-green);color:#fff}.analytes-table th{padding:12px;text-align:left;font-weight:600}.analytes-table td{padding:12px;border-bottom:1px solid #e5e7eb}.analytes-table tbody tr:hover{background-color:#f9fafb}.analyte-input{width:120px;padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.analyte-input:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #3b82f61a}.station-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-width:200px}.station-select:focus{outline:none;border-color:var(--color-dark-green);box-shadow:0 0 0 3px #3b82f61a}.action-section{background:var(--color-white);border-radius:12px;padding:30px;box-shadow:0 2px 8px #00000014}.action-buttons{display:flex;gap:15px;justify-content:center}.error-message{text-align:center;padding:40px;background:var(--color-white);border-radius:12px;box-shadow:0 2px 8px #00000014}.error-message p{margin-bottom:20px;color:#6b7280;font-size:16px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-earth-grey)}.loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:var(--color-dark-green);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.pdf-drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:2000;display:flex;justify-content:flex-end;animation:fadeIn .2s ease-in;pointer-events:auto}.pdf-drawer-overlay.collapsed{background-color:transparent;pointer-events:none}.pdf-drawer-overlay.collapsed .pdf-drawer{pointer-events:auto}.pdf-drawer{width:60%;max-width:1200px;min-width:400px;height:100%;background-color:#fff;box-shadow:-2px 0 8px #0000001a;display:flex;flex-direction:column;animation:slideInRight .3s ease-out;transition:width .3s ease;pointer-events:auto}.pdf-drawer.collapsed{width:60px;min-width:60px;box-shadow:-2px 0 12px #00000026}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.pdf-drawer-header{padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background-color:#f8f9fa;flex-shrink:0}.pdf-drawer-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text)}.pdf-drawer.collapsed .pdf-drawer-header h3{display:none}.pdf-drawer-actions{display:flex;gap:.5rem;align-items:center}.pdf-drawer-toggle,.pdf-drawer-close{background:none;border:none;color:#666;cursor:pointer;padding:.5rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.pdf-drawer-toggle:hover,.pdf-drawer-close:hover{background-color:#e0e0e0}.pdf-drawer-content{flex:1;overflow:hidden;position:relative}.pdf-drawer.collapsed .pdf-drawer-content{display:none}.duplicates-section{background:var(--color-white);border-radius:12px;padding:20px;margin-bottom:30px;box-shadow:0 2px 8px #00000014;border:2px solid #ffc107}.duplicates-section h2{margin-top:0}.duplicate-row{background-color:#fff3cd}.duplicate-row:hover{background-color:#ffe69c}.duplicate-badge{display:inline-block;padding:4px 8px;background-color:#ffc107;color:#856404;border-radius:4px;font-size:12px;font-weight:600}.duplicate-actions{display:flex;gap:8px;align-items:center}.duplicate-actions .btn{padding:6px 12px;font-size:12px}.exports-container{padding:2rem;max-width:1400px;margin:0 auto}.exports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.exports-header h1{font-size:2rem;font-weight:600;color:#1f2937;margin:0}.header-actions{display:flex;gap:1rem}.header-actions button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.new-export-button{padding:.5rem 1rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.refresh-button{background:#fff;color:#6b7280;border:1px solid #e5e7eb!important}.refresh-button:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db!important}.refresh-button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--color-dark-green);color:#fff}button.primary:hover:not(:disabled){background:#1d4ed8}.loading{text-align:center;padding:3rem;color:#6b7280;font-size:1.1rem}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:.75rem;border:2px dashed #e5e7eb}.empty-state svg{color:#9ca3af;margin-bottom:1rem}.empty-state h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.empty-state p{color:#6b7280;margin:0 0 1.5rem}.exports-table-container{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.exports-table{width:100%;border-collapse:collapse}.exports-table thead{background:#f9fafb;border-bottom:1px solid #e5e7eb}.exports-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.exports-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.exports-table tbody tr:hover{background:#f9fafb}.exports-table tbody tr:last-child{border-bottom:none}.exports-table td{padding:1rem;color:#374151}.status-badge{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500;vertical-align:middle}.status-badge svg{display:inline-block;vertical-align:middle;flex-shrink:0}.status-badge.completed{background:#d1fae5;color:#065f46}.status-badge.failed{background:#fee2e2;color:#991b1b}.status-badge.in-progress{background:#dbeafe;color:#1e40af}.status-badge .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-bar{position:relative;width:100%;height:24px;background:#e5e7eb;border-radius:.375rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .3s ease;border-radius:.375rem}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:#1f2937}.progress-complete{color:#059669;font-weight:600}.download-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.download-button:hover{background:#1d4ed8}.error-tooltip{display:inline-flex;align-items:center;gap:.5rem;color:#dc2626;cursor:help}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:1.5rem;font-weight:600;color:#fff!important;margin:0}.close-button{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-group input[type=date]{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;color:#1f2937;transition:all .2s}.form-group input[type=date]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input[type=date]:disabled{background:#f3f4f6;cursor:not-allowed}.error-message{padding:.75rem;background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b;font-size:.875rem;margin-bottom:1rem}.help-text{font-size:.875rem;color:#6b7280;margin:0;line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb}.modal-footer button{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.modal-footer button:not(.primary){background:#fff;color:#374151;border:1px solid #d1d5db!important}.modal-footer button:not(.primary):hover:not(:disabled){background:#f9fafb}.modal-footer button:disabled{opacity:.5;cursor:not-allowed}*{box-sizing:border-box;margin:0;padding:0}:root{--color-white: #FFFFFF;--color-dark-green: #003232;--color-bright-green: #64F08C;--color-sky-blue: #C8E6FA;--color-earth-grey: #AAAAA0;--color-text: #333333;--color-bg: #f5f5f5;--color-dark-green-hover: #004d4f;--font-size-page-header: 1.5rem;--font-size-section-header: 1rem;--font-size-card-header: .95rem;--font-weight-header: 600;--font-weight-section: 500}body{font-family:Google Sans,Roboto,RobotoDraft,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg);color:var(--color-text)}.app{display:flex;height:100vh}.sidebar{width:250px;background-color:var(--color-dark-green);color:#fff;padding:0;position:fixed;height:100vh;overflow-y:auto;transition:width .3s ease;display:flex;flex-direction:column}.sidebar.collapsed{width:60px}.sidebar-header{padding:20px;border-bottom:1px solid var(--color-dark-green-hover);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar h1{margin:0;font-size:1.5rem;transition:opacity .3s ease}.sidebar h1.collapsed{opacity:0;width:0;overflow:hidden}.collapse-btn{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;padding:5px;border-radius:3px;transition:background-color .3s}.collapse-btn:hover{background-color:var(--color-dark-green-hover)}.sidebar-nav-container{flex:1;padding:20px 0}.sidebar-bottom{margin-top:auto;padding:20px 0;border-top:1px solid var(--color-dark-green-hover)}.sidebar-nav{list-style:none;margin:0;padding:0}.sidebar-nav li{margin:0}.sidebar-nav a{display:flex;align-items:center;padding:15px 20px;color:#fff;text-decoration:none;transition:background-color .3s;position:relative}.sidebar-nav a:hover,.sidebar-nav a.active{background-color:var(--color-dark-green-hover)}.nav-icon{font-size:18px;margin-right:10px;min-width:20px;text-align:center}.nav-label{transition:opacity .3s ease}.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .nav-icon{margin-right:0}.main-content{flex:1;margin-left:250px;padding:20px;overflow-y:auto;transition:margin-left .3s ease}.main-content.full-width{margin-left:0;padding:0}.sidebar.collapsed+.main-content{margin-left:60px}.sidebar.collapsed+.main-content.full-width{margin-left:0}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.table-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.table-header h2{margin:0;color:var(--color-dark-green)}table{width:100%;border-collapse:collapse}th,td{padding:12px;text-align:left;border-bottom:1px solid #eee}th:last-child,td:last-child{width:150px;min-width:150px}.metric-tags{display:flex;flex-wrap:wrap;gap:4px;max-width:300px}.metric-tag{background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap;border:1px solid #bbdefb}.metric-tag.truncated{background:#f5f5f5;color:#666;border:1px solid #ddd}.metric-reading-tag{background:#e8f5e8;color:#2e7d32;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap;border:1px solid #a5d6a7;margin:2px;display:inline-block}.metric-reading-tag.alert{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}.reading-set-badge{background:#fff3e0;color:#f57c00;padding:2px 6px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid #ffcc02}.multi-select{min-height:120px;max-height:200px;border:1px solid #ddd;border-radius:4px;padding:8px;overflow-y:auto;background:#fff}.multi-select select{width:100%;height:100%;border:none;outline:none;background:transparent;font-family:inherit}.multi-select select[multiple]{padding:4px}th{background-color:#f8f9fa;font-weight:600;color:var(--color-dark-green)}tr:hover{background-color:#f8f9fa}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s;text-decoration:none;display:inline-block}.btn-primary{background-color:var(--color-dark-green);color:#fff}.btn-primary:hover{background-color:var(--color-dark-green-hover)}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.btn-sm{padding:6px 12px;font-size:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:8px;padding:20px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{margin:0;color:var(--color-dark-green)}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#95a5a6}.close-btn:hover{color:var(--color-dark-green)}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;color:var(--color-dark-green)}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-dark-green)}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;margin-bottom:20px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chart-header h3{margin:0;color:#2c3e50}.chart-filters{display:flex;gap:10px;align-items:center}.chart-filters select{padding:6px 12px;border:1px solid #ddd;border-radius:4px}.loading{text-align:center;padding:40px;color:#95a5a6}.error{background-color:#e74c3c;color:#fff;padding:10px;border-radius:4px;margin-bottom:20px}.success{background-color:#27ae60;color:#fff;padding:10px;border-radius:4px;margin-bottom:20px}.stations-controls{display:flex;gap:15px;margin-bottom:20px;align-items:center}.search-container{flex:1;max-width:400px}.search-input{width:100%;padding:10px 15px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.search-input:focus{outline:none;border-color:var(--color-dark-green)}.filter-container{min-width:150px}.tag-filter{width:100%;padding:10px 15px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;color:#fff;font-size:11px;font-weight:600;text-transform:uppercase}.tag-container{display:flex;flex-wrap:wrap;gap:4px;max-width:200px}.station-tag{background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap;border:1px solid #bbdefb}.station-tag.editable{position:relative;padding-right:20px}.remove-tag-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;color:#1976d2;cursor:pointer;font-size:12px;padding:0;width:12px;height:12px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.remove-tag-btn:hover{background-color:#1976d21a}.tag-input-container{border:1px solid #ddd;border-radius:6px;padding:10px;background:#f9f9f9}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;min-height:20px}.add-tag-input{display:flex;gap:8px;align-items:center}.add-tag-input input{flex:1;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:12px}.add-tag-input input:focus{outline:none;border-color:var(--color-dark-green)}@media (max-width: 768px){.sidebar{width:200px}.sidebar.collapsed{width:50px}.main-content{margin-left:200px}.sidebar.collapsed+.main-content{margin-left:50px}.table-header{flex-direction:column;gap:10px;align-items:stretch}.form-actions{flex-direction:column}.chart-header{flex-direction:column;gap:10px;align-items:stretch}.chart-filters{justify-content:space-between}.stations-controls{flex-direction:column;align-items:stretch}.search-container{max-width:none}}.current-org{margin-bottom:10px;padding:0 10px}.org-switcher-btn{width:100%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:10px;font-size:14px}.org-switcher-btn:hover{background:#ffffff26;border-color:#ffffff4d}.sidebar.collapsed .org-switcher-btn{justify-content:center;padding:12px 5px}.org-info{display:flex;flex-direction:column;align-items:flex-start;flex:1;overflow:hidden}.org-label{font-size:11px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.org-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.switch-icon{font-size:18px;opacity:.7}.org-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.org-modal{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.org-modal-header{padding:20px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.org-modal-header h3{margin:0;color:#2d3748;font-size:1.25rem}.close-btn{background:none;border:none;font-size:28px;color:#718096;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s}.close-btn:hover{background-color:#f7fafc}.org-modal-search{padding:15px 20px;border-bottom:1px solid #e2e8f0}.org-search-input{width:100%;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:border-color .2s}.org-search-input:focus{outline:none;border-color:var(--color-dark-green)}.org-modal-list{flex:1;overflow-y:auto;padding:10px}.org-modal-list::-webkit-scrollbar{width:8px}.org-modal-list::-webkit-scrollbar-track{background:#f7fafc}.org-modal-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.org-item{width:100%;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-bottom:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:12px;text-align:left}.org-item:hover:not(:disabled){background:#edf2f7;border-color:var(--color-dark-green);transform:translate(2px)}.org-item:disabled{opacity:.6;cursor:not-allowed}.org-item.active{background:#0032321a;border-color:var(--color-dark-green)}.org-item-icon{font-size:20px}.org-item-name{flex:1;color:#2d3748;font-size:14px;font-weight:500}.current-badge{background:var(--color-dark-green);color:#fff;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.no-orgs{text-align:center;padding:40px 20px;color:#718096}.no-orgs p{margin:0;font-size:14px}
