body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.header{background-color:#2c3e50;border-bottom:4px solid #1abc9c;color:#fff;padding:15px 25px}.header h1{font-size:1.8rem;font-weight:500}.container{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem}.content-box{animation:fadeInBox 1s ease-out forwards;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-width:600px;opacity:0;overflow:hidden;padding:3rem;position:relative;text-align:center;width:100%;z-index:1}.content-box h2{color:#2c3e50;font-size:2rem;font-weight:500;margin-bottom:2rem}.camera-icon{animation:pulse 2s ease-in-out infinite;height:100px;margin:1.5rem auto;opacity:.3;width:100px}.button-container{flex-wrap:wrap;gap:1.5rem;margin-top:2rem}.btn,.button-container{display:flex;justify-content:center}.btn{align-items:center;border:none;border-radius:6px;box-shadow:0 3px 6px #0000001a;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;min-width:200px;overflow:hidden;padding:12px 28px;position:relative;transition:all .3s ease}.btn:after{background-color:#fff0;content:"";height:100%;left:0;position:absolute;top:0;transition:background-color .3s ease;width:100%}.btn-primary{background-color:#27ae60}.btn-secondary{background-color:#3498db}.btn:hover{box-shadow:0 8px 15px #0003;transform:translateY(-3px)}.btn:hover:after{background-color:#ffffff1a}.btn:active{box-shadow:0 2px 5px #0003;transform:translateY(1px)}.btn svg{margin-right:8px;position:relative;z-index:1}.wave{background:url('data:image/svg+xml;utf8,<svg viewBox="0 0 1440 320" xmlns="http://www.w3.org/2000/svg"><path fill="%232c3e50" fill-opacity="0.05" d="M0,128L48,144C96,160,192,192,288,202.7C384,213,480,203,576,170.7C672,139,768,85,864,80C960,75,1056,117,1152,133.3C1248,149,1344,139,1392,133.3L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z"></path></svg>');background-repeat:no-repeat;background-size:cover;bottom:0;height:100px;left:0;pointer-events:none;position:absolute;width:100%;z-index:0}.btn-primary.doctor{animation:slideInLeft .8s ease-out forwards;animation-delay:.3s;animation-fill-mode:forwards;opacity:0}.btn-secondary.patient{animation:slideInRight .8s ease-out forwards;animation-delay:.5s;animation-fill-mode:forwards;opacity:0}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@media (max-width:600px){.button-container{flex-direction:column}.content-box{padding:2rem 1rem}}*{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background-color:#f0f2f5;display:flex;flex-direction:column;min-height:100vh}.auth-container{display:flex;flex:1 1;flex-direction:column;margin:0 auto;max-width:1200px;padding:2rem}.auth-header{animation:fadeInBox .8s ease-out forwards;background-color:#2c3e50;border-bottom:4px solid #1abc9c;border-radius:8px;box-shadow:0 4px 12px #0000001a;color:#fff;margin-bottom:2rem;padding:15px 25px}.auth-header h1{font-size:1.8rem;font-weight:500;margin-bottom:.5rem}.auth-header h2{color:#ecf0f1;font-size:1.2rem;font-weight:400}.auth-form-container{animation:fadeInBox 1s ease-out .3s forwards;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;margin:0 auto;max-width:600px;opacity:0;overflow:hidden;padding:3rem;position:relative;width:100%;z-index:1}.auth-form-container h3{color:#2c3e50;font-size:1.5rem;font-weight:500;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1.5rem;position:relative}.form-group label{color:#2c3e50;display:block;font-weight:500;margin-bottom:.5rem}.form-group input{background-color:#f9f9f9;border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db33;outline:none}.auth-button{background-color:#3498db;border:none;border-radius:6px;box-shadow:0 3px 6px #0000001a;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;overflow:hidden;padding:14px;position:relative;transition:all .3s ease;width:100%}.auth-button:hover{background-color:#2980b9;box-shadow:0 8px 15px #0003;transform:translateY(-2px)}.auth-button:active{box-shadow:0 2px 5px #0003;transform:translateY(1px)}.auth-button:after{background-color:#fff0;content:"";height:100%;left:0;position:absolute;top:0;transition:background-color .3s ease;width:100%}.auth-button:hover:after{background-color:#ffffff1a}.error-message{animation:shake .5s ease-in-out;background-color:#fdecea;color:#e74c3c}.error-message,.success-message{border-radius:4px;margin:1rem 0;padding:10px}.success-message{animation:fadeIn .5s ease-in-out;background-color:#e8f5e9}.auth-links{display:flex;justify-content:space-between;margin-top:1.5rem}.auth-links a{color:#3498db;font-weight:500;position:relative;text-decoration:none;transition:all .3s ease}.auth-links a:after{background-color:#3498db;bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.auth-links a:hover{color:#2980b9}.auth-links a:hover:after{width:100%}.contact-container{max-width:800px}.contact-methods{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:2rem 0}.contact-method{animation:fadeInBox .8s ease-out forwards;background-color:#f9f9f9;border-radius:8px;padding:1.5rem;transition:all .3s ease}.contact-method:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-5px)}.contact-method h4{color:#2c3e50;font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem;position:relative}.contact-method h4:after{background-color:#1abc9c;bottom:0;content:"";height:3px;left:0;position:absolute;width:50px}.contact-method p{color:#7f8c8d;line-height:1.5;margin-bottom:1rem}.contact-link{align-items:center;color:#3498db;display:inline-flex;font-weight:500;text-decoration:none;transition:all .3s ease}.contact-link svg{margin-right:8px;transition:transform .3s ease}.contact-link:hover{color:#2980b9}.contact-link:hover svg{transform:translateX(3px)}.contact-link.emergency{color:#e74c3c}.contact-link.emergency:hover{color:#c0392b}.back-button{background-color:#95a5a6;margin-top:2rem}.back-button:hover{background-color:#7f8c8d}.auth-form-container:after{background:url('data:image/svg+xml;utf8,<svg viewBox="0 0 1440 320" xmlns="http://www.w3.org/2000/svg"><path fill="%232c3e50" fill-opacity="0.05" d="M0,128L48,144C96,160,192,192,288,202.7C384,213,480,203,576,170.7C672,139,768,85,864,80C960,75,1056,117,1152,133.3C1248,149,1344,139,1392,133.3L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z"></path></svg>');background-repeat:no-repeat;background-size:cover;bottom:0;content:"";height:100px;left:0;pointer-events:none;position:absolute;width:100%;z-index:0}@keyframes fadeInBox{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shake{0%,to{transform:translateX(0)}20%,60%{transform:translateX(-5px)}40%,80%{transform:translateX(5px)}}.ripple{animation:ripple .6s linear;background-color:#ffffff4d;border-radius:50%;height:100px;margin:-50px 0 0 -50px;pointer-events:none;position:absolute;transform:scale(0);width:100px}@keyframes ripple{to{opacity:0;transform:scale(4)}}@media (max-width:768px){.auth-form-container{padding:2rem}.auth-header h1{font-size:1.5rem}.auth-header h2{font-size:1rem}.contact-methods{grid-template-columns:1fr}}@media (max-width:480px){.auth-form-container{padding:1.5rem}.auth-links{flex-direction:column;gap:1rem}.auth-button{padding:12px}}.success-message{color:#27ae60;padding:20px;text-align:center}.success-message h3{margin-bottom:10px}select{background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;font-size:16px;padding:12px;width:100%}select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db33;outline:none}.password-strength{border-radius:3px;font-size:.8rem;margin-top:5px;padding:3px}.password-strength.weak{background-color:#fdecea;color:#e74c3c}.password-strength.medium{background-color:#fef5e6;color:#f39c12}.password-strength.strong{background-color:#e8f5e9;color:#27ae60}.form-row{display:flex;gap:15px}.form-row .form-group{flex:1 1}@media (max-width:768px){.form-row{flex-direction:column;gap:0}}.patient-id-display{margin-bottom:2rem;text-align:center}.patient-id{background-color:#f8f9fa;border-radius:4px;font-family:monospace;font-size:1.8rem;font-weight:700;margin:.5rem 0;padding:.5rem}.info-message,.location-info{color:#7f8c8d;font-size:.9rem}.info-message{margin-top:1.5rem;text-align:center}.info-message p{margin:.3rem 0}.uuid-animation-container{margin:1rem 0}.auth-button:disabled{cursor:not-allowed;opacity:.7}.success-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.success-content{background:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;max-width:400px;padding:2rem;text-align:center;width:90%}.success-content h3{color:#2ecc71;margin-bottom:1rem}.success-content p{color:#333;margin:.5rem 0}.auth-header{padding:20px;position:relative;text-align:center}.back-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:6px;display:inline-flex;font-family:inherit;gap:6px;left:20px;padding:8px 12px;position:absolute;text-decoration:none;top:20px}.back-button:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.back-button:focus{outline:2px solid #ffffff80;outline-offset:2px}.back-button:active{background:#ffffff26;transform:translateY(0)}.debug-page{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.debug-header{align-items:center;border-bottom:1px solid #e1e4e8;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.debug-header h2{color:#2c3e50;margin:0}.back-button{background-color:#3498db;border:none;padding:8px 16px;transition:background-color .3s}.back-button:hover{background-color:#2980b9}.debug-controls{align-items:center;background-color:#f8f9fa;border-radius:8px;display:flex;gap:20px;margin-bottom:20px;padding:15px}.refresh-btn{background-color:#2ecc71;transition:background-color .3s}.refresh-btn:hover:not(:disabled){background-color:#27ae60}.refresh-btn:disabled{background-color:#95a5a6;cursor:not-allowed}.realtime-toggle{cursor:pointer}.connection-status,.realtime-toggle{align-items:center;display:flex;gap:8px}.connection-status{margin-left:auto}.status-indicator{border-radius:50%;height:12px;width:12px}.status-indicator.connected{background-color:#2ecc71}.status-indicator.active{animation:pulse 1.5s infinite;background-color:#f1c40f}.status-indicator.error{background-color:#e74c3c}.status-indicator.disconnected{background-color:#95a5a6}.debug-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:20px}.debug-section h3{border-bottom:1px solid #eee;color:#2c3e50;margin-top:0;padding-bottom:10px}.loading{color:#7f8c8d;font-style:italic}.no-data{padding:20px}pre{word-wrap:break-word;background-color:#f8f9fa;border-radius:4px;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.5;overflow-x:auto;padding:15px;white-space:pre-wrap}.message-notification{background-color:#4caf50;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;max-width:300px;opacity:1;padding:15px;top:20px;transform:translateX(0);transition:transform .5s ease-in-out,opacity .5s ease-in-out}.message-notification.slide-out{opacity:0;transform:translateX(100%)}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.alert{transition:all .3s ease}.notification-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.notification-header h3{font-size:16px;margin:0}.close-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:20px;line-height:1;padding:0 5px}.close-btn:hover{color:#e0e0e0}.message-content{padding:0}.alert-info{color:#0c5460}.alert-waiting{color:#856404}.message-text{font-size:14px;margin:0 0 10px}.room-assignment{background-color:#ffffff1a;border-radius:4px;font-size:15px;margin:10px 0;padding:8px}.timestamp{display:block;font-size:12px;opacity:.8;text-align:right}.waiting-message{font-style:italic;margin:0}.message-notification.alert-urgent{animation:pulse 1.5s infinite;background-color:#f8d7da;border-left:5px solid #dc3545;color:#721c24}@media (max-width:768px){.message-notification{bottom:20px;left:20px;right:20px;top:auto;width:calc(100% - 40px)}.message-notification.slide-out{transform:translateY(100%)}}body{color:#333}.app-header{position:relative;z-index:10}.app-header h1{gap:10px}.patient-id-header{color:#3498db;font-size:1em;font-weight:700}.back-button{font-size:14px;transition:all .2s ease}.mode-indicator{background:#e74c3c;border-radius:20px;display:inline-block;font-size:.9rem;margin-left:15px;padding:5px 15px}.mode-indicator.capture{background:#e67e22}.mode-indicator.stream{background:#2ecc71}.main-content{display:grid;grid-template-columns:280px 1fr 350px}.sidebar{height:100%;overflow-y:auto}.sidebar h3{background-color:#34495e;font-size:1.2rem;font-weight:500;letter-spacing:1px;padding-bottom:1rem;position:sticky;text-transform:uppercase;top:0;z-index:1}.button-group,.sidebar h3{margin-bottom:1.5rem}.start-session-btn{background-color:#2ecc71}.start-session-btn:hover{background-color:#27ae60}.camera-settings-btn{background-color:#3498db}.camera-settings-btn:hover{background-color:#2980b9}.icon{margin-right:10px}.camera-info{background-color:#ffffff1a;border-radius:8px;margin-top:auto;padding:1rem}.camera-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.camera-list p{font-size:.9rem;line-height:1.4;margin:0}.camera-list strong{color:#ecf0f1}.camera-count{align-items:center;display:flex;flex-direction:column;margin-top:1rem}.camera-count p{color:#bdc3c7;font-size:.85rem;margin-bottom:.5rem}.refresh-btn{background-color:#7f8c8d;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;max-width:120px;padding:8px 16px;transition:background-color .3s ease;width:100%}.refresh-btn:hover{background-color:#95a5a6}.camera-view{background-color:#ecf0f1;display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:1.5rem}.enhanced-camera-view{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.enhanced-capture-controls{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:20px}.enhanced-btn{background-color:#3498db;border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:500;padding:12px 20px;transition:all .25s ease}.enhanced-btn:hover{background-color:#2980b9}.enhanced-btn.active{background-color:#1a5276}.compact-camera-container{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;gap:10px;margin:0 auto;max-width:500px;padding:15px;width:100%}.compact-webcam{border:2px solid #e0e0e0;border-radius:6px;height:auto!important;max-height:300px;width:100%!important}.timer-display{flex-direction:column;margin-bottom:1rem}.timer-circle,.timer-display{align-items:center;display:flex}.timer-circle{background-color:#3498db;border-radius:50%;color:#fff;font-size:1.5rem;font-weight:700;height:50px;justify-content:center;margin-bottom:.5rem;width:50px}.camera-label{color:#7f8c8d;font-size:.9rem;margin-top:.5rem}.camera-controls{display:flex;justify-content:center;margin-top:1rem;width:100%}.enhanced-exit-btn{background-color:#e74c3c;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:10px 18px}.enhanced-exit-btn:hover{background-color:#c0392b}.stream-view{flex:1 1;min-height:0}.stream-view iframe{border:none;min-height:400px}.results-panel h3{background-color:#f8f9fa;flex-shrink:0;font-size:1.2rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:1rem}.results-panel{background:#f8f9fa;border-left:1px solid #e1e4e8;height:100%;padding:1rem;width:350px}.results-panel h3{background:#f8f9fa;margin-bottom:.5rem;padding:.5rem 0;position:sticky;top:0;z-index:10}.results-content{flex:1 1;max-height:calc(100vh - 200px);overflow-y:auto;padding-right:8px;scrollbar-color:#7f8c8d #e1e4e8;scrollbar-width:thin}.results-content::-webkit-scrollbar{width:8px}.results-content::-webkit-scrollbar-track{background:#f1f1f1}.results-content::-webkit-scrollbar-thumb{background:#888}.results-content::-webkit-scrollbar-thumb:hover{background:#555}.result-card{background:#fff;border-left:4px solid #0000;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:1.5rem;padding:1.25rem;position:relative;transition:all .3s ease}.result-card:hover{box-shadow:0 4px 20px #0000001f;transform:translateY(-2px)}.result-card:nth-child(odd){border-left-color:#3498db}.result-card:nth-child(2n){border-left-color:#9b59b6}.result-card h4{color:#2c3e50;font-size:1.1rem;font-weight:600;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.result-value{color:#2c3e50;font-size:2rem;font-weight:700;margin:.75rem 0;text-shadow:0 1px 2px #0000001a}.result-meta{background-color:#0000000d;border-radius:6px;color:#7f8c8d;font-family:Courier New,monospace;font-size:.85rem;margin:.5rem 0;padding:.5rem}.result-image{border:2px solid #eee;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:12px;max-width:100%;transition:transform .3s ease}.result-image:hover{transform:scale(1.02)}.no-data{background-color:#95a5a60d;border:2px dashed #bdc3c7;border-radius:12px;color:#95a5a6;margin:1rem 0;padding:3rem 2rem}.no-data p{font-size:1rem}.no-data:before{content:"📊";display:block;font-size:3rem;margin-bottom:1rem;opacity:.3}.results-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.results-spinner{animation:spin 1s linear infinite;border:3px solid #e1e4e8;border-radius:50%;border-top-color:#3498db;height:40px;width:40px}.modal-backdrop{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;max-width:400px;padding:20px;text-align:center;width:90%}.modal h3{color:#2c3e50;margin-bottom:1rem}.modal input{border:1px solid #ddd;border-radius:4px;font-size:1rem;margin:10px 0;padding:10px;width:100%}.modal-buttons{justify-content:center;margin-top:15px}.modal-buttons button{border:none;border-radius:4px;cursor:pointer;font-weight:500;padding:10px 20px}.modal-buttons button:first-child{background-color:#2ecc71;color:#fff}.modal-buttons button:first-child:hover{background-color:#27ae60}.modal-buttons button:last-child{background-color:#e74c3c;color:#fff}.modal-buttons button:last-child:hover{background-color:#c0392b}.camera-modal{max-width:450px}.camera-options{display:flex;flex-direction:column;gap:10px;margin:15px 0;max-height:300px;overflow-y:auto;padding:5px}.camera-option-btn{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;padding:12px 15px;text-align:left;transition:all .2s ease}.camera-option-btn:hover{background-color:#e9ecef}.message-notification{position:fixed;right:20px;top:80px;width:300px;z-index:1000}.alert{border-radius:5px;box-shadow:0 2px 10px #0000001a;margin-bottom:10px;padding:15px}.alert-info{background-color:#d1ecf1;border-left:5px solid #0dcaf0}.alert-waiting{background-color:#fff3cd;border-left:5px solid #ffc107}.room-assignment{color:#0d6efd;font-weight:700;margin-top:10px}.debug-link{background:#f0f0f0;border-radius:4px;bottom:10px;color:#333;font-size:12px;padding:5px 10px;position:fixed;right:10px;text-decoration:none;z-index:1000}.debug-link:hover{background:#e0e0e0}@media (max-width:1200px){.main-content{grid-template-columns:250px 1fr}.results-panel{border-top:1px solid #e1e4e8;grid-column:1/-1}}@media (max-width:768px){.main-content{grid-template-columns:1fr}.stream-view iframe{min-height:250px}.app-header{align-items:flex-start;flex-direction:column;padding:1rem}.app-header h1{font-size:1.2rem}.app-header h1,.back-button{margin-bottom:.5rem}.main-content{grid-template-columns:1fr;grid-template-rows:auto auto auto}.results-panel,.sidebar{height:auto;max-height:300px;width:100%}.compact-camera-container{width:100%}.enhanced-capture-controls{flex-direction:column}}.camera-settings-modal{max-height:80vh;max-width:600px;overflow-y:auto}.camera-assignments{margin:20px 0}.camera-assignment-row{align-items:center;display:flex;gap:15px;margin-bottom:15px}.assignment-label{min-width:130px;text-align:left}.camera-select{background-color:#fff;border:2px solid #ddd;border-radius:6px;flex:1 1;font-size:14px;padding:8px 12px}.camera-select:focus{border-color:#007bff;outline:none}.camera-info-section{background-color:#f8f9fa;border-radius:8px;margin:20px 0;padding:15px}.available-cameras{display:flex;flex-direction:column;gap:8px}.camera-info-item{align-items:center;display:flex;gap:10px;padding:5px 0}.camera-number{align-items:center;background-color:#007bff;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;width:24px}.camera-name{font-size:14px}.modal-buttons{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.save-btn{background-color:#28a745;color:#fff}.refresh-btn{background-color:#17a2b8;color:#fff}.cancel-btn{background-color:#6c757d;color:#fff}:root{--primary-color:#2c3e50;--primary-dark:#1a252f;--secondary-color:#1abc9c;--success-color:#2ecc71;--success-hover:#27ae60;--danger-color:#e74c3c;--danger-hover:#c0392b;--warning-color:#ffc107;--info-color:#3498db;--purple-accent:#9b59b6;--white:#fff;--gray-50:#f8f9fa;--gray-100:#f5f7fa;--gray-200:#ecf0f1;--gray-300:#e1e4e8;--gray-400:#bdc3c7;--gray-500:#95a5a6;--gray-600:#7f8c8d;--gray-700:#555;--gray-800:#34495e;--gray-900:#2c3e50;--black:#000;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--radius-sm:4px;--radius-md:8px;--radius-lg:10px;--radius-full:999px;--shadow-sm:0 2px 4px #0000000d;--shadow-md:0 4px 8px #0000001a;--shadow-lg:0 4px 12px #0000001a;--shadow-xl:0 0 20px #0000000d;--transition-fast:150ms ease;--transition-base:300ms ease;--transition-slow:500ms ease;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-popover:400;--z-tooltip:500}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;background-color:var(--gray-100);color:#2c3e50;color:var(--gray-900);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-family:var(--font-family);font-size:1rem;font-size:var(--font-size-base);line-height:1.6}.app-container{background-color:#fff;background-color:var(--white);box-shadow:0 0 20px #0000000d;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;margin:0 auto;max-width:1600px;min-height:100vh}.main-content{display:flex;flex:1 1;height:calc(100vh - 65px);overflow:hidden}.app-header{background-color:#2c3e50;background-color:var(--primary-color);border-bottom:3px solid #1abc9c;border-bottom:3px solid var(--secondary-color);color:#fff;color:var(--white);flex-shrink:0;justify-content:space-between;min-height:65px;padding:1rem 2rem;padding:var(--spacing-md) var(--spacing-xl)}.app-header,.app-header h1{align-items:center;display:flex}.app-header h1{flex-wrap:wrap;font-size:1.5rem;font-size:var(--font-size-2xl);font-weight:500;gap:.25rem;gap:var(--spacing-xs)}.doctor-name-header{color:#2ecc71;color:var(--success-color);font-weight:600}.back-button{background-color:initial;border:2px solid #fff;border:2px solid var(--white);border-radius:4px;border-radius:var(--radius-sm);color:#fff;color:var(--white);cursor:pointer;font-size:.875rem;font-size:var(--font-size-sm);margin-right:1rem;margin-right:var(--spacing-md);padding:6px 12px;transition:background-color .2s ease,color .2s ease}.back-button:hover{background-color:#fff;background-color:var(--white);color:#2c3e50;color:var(--primary-color)}.location-selector{margin-left:auto}.location-selector select{background:#fff;background:var(--white);border:2px solid #2c3e50;border:2px solid var(--primary-color);border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;font-size:var(--font-size-base);font-weight:500;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease;transition:all var(--transition-fast)}.location-selector select:focus,.location-selector select:hover{border-color:#1abc9c;border-color:var(--secondary-color)}.location-selector select:focus{box-shadow:0 0 0 3px #1abc9c1a;outline:none}.sidebar{background-color:#34495e;background-color:var(--gray-800);border-right:2px solid #e1e4e8;border-right:2px solid var(--gray-300);color:#fff;color:var(--white);display:flex;flex-direction:column;flex-shrink:0;gap:1.5rem;gap:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg);width:280px}.sidebar h3,.sidebar h4{font-weight:500;letter-spacing:1px;text-transform:uppercase}.sidebar h3{font-size:1.25rem;font-size:var(--font-size-xl)}.sidebar h3,.sidebar h4{color:#ecf0f1;color:var(--gray-200)}.sidebar h4{font-size:.875rem;font-size:var(--font-size-sm)}.button-group{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md)}.button{align-items:center;background-color:#2ecc71;background-color:var(--success-color);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;color:var(--white);cursor:pointer;display:flex;font-size:1rem;font-size:var(--font-size-base);font-weight:500;gap:.5rem;gap:var(--spacing-sm);justify-content:flex-start;padding:1rem 1.25rem;padding:var(--spacing-md) calc(var(--spacing-md)*1.25);text-align:left;transition:all .3s ease;transition:all var(--transition-base)}.button:hover{background-color:#27ae60;background-color:var(--success-hover);box-shadow:0 4px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.button:active{transform:translateY(0)}.button.active{background-color:#e74c3c;background-color:var(--danger-color)}.button.active:hover{background-color:#c0392b;background-color:var(--danger-hover)}.active-room{background:linear-gradient(135deg,#2ecc71,#1abc9c);background:linear-gradient(135deg,var(--success-color),var(--secondary-color));border-radius:8px;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;gap:.5rem;gap:var(--spacing-sm);justify-content:space-between;margin-top:1rem;margin-top:var(--spacing-md);padding:1rem;padding:var(--spacing-md)}.active-room,.copy-button{align-items:center;display:flex}.copy-button{background:#fff3;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;color:var(--white);cursor:pointer;justify-content:center;padding:.25rem;padding:var(--spacing-xs);transition:all .15s ease;transition:all var(--transition-fast)}.copy-button:hover{background:#ffffff4d;transform:scale(1.1)}.queue-section{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.queue-section h4{border-bottom:1px solid #ffffff1a;flex-shrink:0;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);padding-bottom:.25rem;padding-bottom:var(--spacing-xs)}.queue-section ul{flex:1 1;list-style:none;max-height:calc(100vh - 300px);overflow-y:auto;padding-right:.25rem;padding-right:var(--spacing-xs);scrollbar-color:#95a5a6 #34495e;scrollbar-color:var(--gray-500) var(--gray-800);scrollbar-width:thin}.queue-section ul::-webkit-scrollbar{width:8px}.queue-section ul::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px;border-radius:var(--radius-sm);margin:.25rem 0;margin:var(--spacing-xs) 0}.queue-section ul::-webkit-scrollbar-thumb{background:#95a5a6;background:var(--gray-500);border-radius:4px;border-radius:var(--radius-sm);-webkit-transition:background .15s ease;transition:background .15s ease;-webkit-transition:background var(--transition-fast);transition:background var(--transition-fast)}.queue-section ul::-webkit-scrollbar-thumb:hover{background:#bdc3c7;background:var(--gray-400)}.patient-item{background:#fffffff2;border-left:4px solid #0000;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);color:#000;color:var(--black);cursor:pointer;display:flex;flex-direction:column;font-size:.875rem;font-size:var(--font-size-sm);gap:.5rem;gap:var(--spacing-sm);margin:.5rem 0;margin:var(--spacing-sm) 0;padding:1rem;padding:var(--spacing-md);transition:all .15s ease;transition:all var(--transition-fast)}.patient-item:hover{background:#fff;border-left-color:#1abc9c;border-left-color:var(--secondary-color);box-shadow:0 4px 8px #0000001a;box-shadow:var(--shadow-md);transform:translateX(4px)}.patient-item.next-patient{background:#2ecc711a;border-left-color:#2ecc71;border-left-color:var(--success-color)}.patient-item.in_consultation{background:#ffc10726;border-left-color:#ffc107;border-left-color:var(--warning-color)}.patient-id{align-items:center;color:#2c3e50;color:var(--primary-color);display:flex;font-weight:600;justify-content:space-between}.status-badge{background-color:#ffc107;background-color:var(--warning-color);border-radius:999px;border-radius:var(--radius-full);color:#fff;color:var(--white);font-size:.75rem;font-size:var(--font-size-xs);font-weight:700;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);text-transform:uppercase}.patient-actions{align-items:center;display:flex;gap:.5rem;gap:var(--spacing-sm)}.wait-time{color:#2ecc71;color:var(--success-color);font-weight:500;text-align:right}.done-button,.message-button,.wait-time{font-size:.75rem;font-size:var(--font-size-xs)}.done-button,.message-button{border:none;border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;letter-spacing:.5px;padding:.25rem 1rem;padding:var(--spacing-xs) var(--spacing-md);text-transform:uppercase;transition:all .15s ease;transition:all var(--transition-fast)}.message-button{background-color:#2ecc71;background-color:var(--success-color);color:#fff;color:var(--white)}.message-button:hover{background-color:#27ae60;background-color:var(--success-hover);transform:translateY(-1px)}.message-button:disabled{background-color:#bdc3c7;background-color:var(--gray-400);cursor:not-allowed;transform:none}.done-button{background-color:#e74c3c;background-color:var(--danger-color);color:#fff;color:var(--white)}.done-button:hover{background-color:#c0392b;background-color:var(--danger-hover);transform:translateY(-1px)}.space-x-2>*+*{margin-left:.5rem;margin-left:var(--spacing-sm)}.camera-container{background-color:#ecf0f1;background-color:var(--gray-200);flex:1 1;min-height:0;padding:1.5rem;padding:var(--spacing-lg)}.camera-container,.stream-view{display:flex;flex-direction:column}.stream-view{background-color:#fff;background-color:var(--white);border-radius:10px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-lg);height:100%;padding:1rem;padding:var(--spacing-md);width:100%}.stream-view iframe{border-radius:8px;border-radius:var(--radius-md);flex:1 1;height:100%;min-height:500px;overflow:hidden;width:100%}.empty-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.empty-content{color:#7f8c8d;color:var(--gray-600);max-width:400px}.empty-content h2{color:#2c3e50;color:var(--primary-color);font-size:1.25rem;font-size:var(--font-size-xl);margin:1rem 0;margin:var(--spacing-md) 0}.empty-content p{font-size:1rem;font-size:var(--font-size-base)}.results-panel{background-color:#fff;background-color:var(--white);border-left:2px solid #e1e4e8;border-left:2px solid var(--gray-300);display:flex;flex-direction:column;flex-shrink:0;gap:1.5rem;gap:var(--spacing-lg);overflow-y:auto;padding:1.5rem;padding:var(--spacing-lg);width:320px}.results-panel h3{border-bottom:2px solid #1abc9c;border-bottom:2px solid var(--secondary-color);color:#2c3e50;color:var(--primary-color);font-size:1.25rem;font-size:var(--font-size-xl);letter-spacing:1px;margin:0;padding-bottom:.5rem;padding-bottom:var(--spacing-sm);text-transform:uppercase}.search-section{margin:0}.search-container{align-items:center;display:flex;position:relative;width:100%}.search-input{background-color:#f8f9fa;background-color:var(--gray-50);border:2px solid #e1e4e8;border:2px solid var(--gray-300);border-radius:999px;border-radius:var(--radius-full);font-size:1rem;font-size:var(--font-size-base);outline:none;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);padding-right:50px;transition:all .15s ease;transition:all var(--transition-fast);width:100%}.search-input:focus{background-color:#fff;background-color:var(--white);border-color:#3498db;border-color:var(--info-color);box-shadow:0 0 0 3px #3498db1a}.search-button{align-items:center;background-color:#2c3e50;background-color:var(--primary-color);border:none;border-radius:50%;color:#fff;color:var(--white);cursor:pointer;display:flex;font-size:1rem;font-size:var(--font-size-base);height:36px;justify-content:center;position:absolute;right:8px;transition:all .15s ease;transition:all var(--transition-fast);width:36px}.search-button:hover{background-color:#1a252f;background-color:var(--primary-dark);transform:scale(1.05)}.search-button:active{transform:scale(.95)}.search-button:disabled{background-color:#bdc3c7;background-color:var(--gray-400);cursor:not-allowed;transform:none}.data-cards,.results-content{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md)}.data-card{background:linear-gradient(135deg,#f8f9fa,#fff);background:linear-gradient(135deg,var(--gray-50),var(--white));border-left:4px solid #0000;border-radius:10px;border-radius:var(--radius-lg);box-shadow:0 4px 8px #0000001a;box-shadow:var(--shadow-md);padding:1.5rem;padding:var(--spacing-lg);position:relative;transition:all .15s ease;transition:all var(--transition-fast)}.data-card:hover{box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.temperature-card{border-left-color:#3498db;border-left-color:var(--info-color)}.temperature-card:before{content:"🌡️";font-size:1.125rem;font-size:var(--font-size-lg);opacity:.3;position:absolute;right:.5rem;right:var(--spacing-sm);top:.5rem;top:var(--spacing-sm)}.weight-card{border-left-color:#9b59b6;border-left-color:var(--purple-accent)}.weight-card:before{content:"⚖️";font-size:1.125rem;font-size:var(--font-size-lg);opacity:.3;position:absolute;right:.5rem;right:var(--spacing-sm);top:.5rem;top:var(--spacing-sm)}.data-card h4{color:#7f8c8d;color:var(--gray-600);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.data-card h4,.data-value{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.data-value{color:#2c3e50;color:var(--primary-color);font-size:1.5rem;font-size:var(--font-size-2xl);font-weight:700}.data-raw{background-color:#0000000d;border-radius:4px;border-radius:var(--radius-sm);color:#7f8c8d;color:var(--gray-600);font-family:Courier New,monospace;font-size:.875rem;font-size:var(--font-size-sm);padding:.5rem;padding:var(--spacing-sm);word-break:break-word}.loading-indicator{align-items:center;display:flex;justify-content:center;padding:3rem 0;padding:var(--spacing-2xl) 0}.spinner{animation:spin 1s linear infinite;border:3px solid #ecf0f1;border-top-color:#3498db;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--info-color);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.no-data{background-color:#f8f9fa;background-color:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);color:#7f8c8d;color:var(--gray-600);padding:3rem 0;padding:var(--spacing-2xl) 0;text-align:center}.no-data p{font-size:.875rem;font-size:var(--font-size-sm);margin:.5rem 0;margin:var(--spacing-sm) 0}.icon{background-position:50%;background-repeat:no-repeat;background-size:contain;flex-shrink:0;height:24px;width:24px}.icon.large{height:80px;margin-bottom:1rem;margin-bottom:var(--spacing-md);opacity:.3;width:80px}@media (max-width:1200px){.main-content{flex-direction:column;height:auto}.sidebar{align-items:flex-start;flex-direction:row;gap:1rem;gap:var(--spacing-md);justify-content:space-between;padding:1rem;padding:var(--spacing-md);width:100%}.queue-section{max-height:200px}.queue-section ul{max-height:150px}.button-group{flex-direction:row;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm)}.button{font-size:.875rem;font-size:var(--font-size-sm);padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md)}.results-panel{border-left:none;border-top:2px solid #e1e4e8;border-top:2px solid var(--gray-300);width:100%}.camera-container{min-height:400px}}@media (max-width:768px){.app-header{align-items:flex-start;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);padding:1rem;padding:var(--spacing-md)}.app-header h1{font-size:1.125rem;font-size:var(--font-size-lg)}.location-selector{margin-left:0;width:100%}.location-selector select{width:100%}.sidebar{flex-direction:column;gap:1rem;gap:var(--spacing-md)}.button-group{flex-direction:column;width:100%}.button{justify-content:center;width:100%}.camera-container{min-height:300px}.camera-container,.results-panel{padding:1rem;padding:var(--spacing-md)}.results-panel{width:100%}.data-card{padding:1rem;padding:var(--spacing-md)}.data-value{font-size:1.25rem;font-size:var(--font-size-xl)}.patient-item{padding:.5rem;padding:var(--spacing-sm)}.patient-actions{flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}.done-button,.message-button{text-align:center;width:100%}}.data-confidence{color:#666;font-size:.8rem;font-style:italic;margin-top:.5rem}.data-confidence:before{content:"Confidence: ";font-weight:700}.fill-room-button{background-color:#e0e0e0;border:1px solid #ccc;border-radius:4px;cursor:pointer;margin-left:8px;padding:5px 10px}.compatibility-warning{background:#fff3cd;border-left:4px solid #ffc107;margin:10px 0;padding:15px}.alert-warning{background-color:#fff3cd;border:1px solid #0000;border-radius:4px;color:#856404;margin-bottom:20px;padding:15px}.alert-warning h4{color:inherit;margin-top:0}.fill-room-button:hover{background-color:#d0d0d0}.results-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.download-button{align-items:center;background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 16px}.download-button:hover{background-color:#218838}.download-button:disabled{background-color:#6c757d;cursor:not-allowed}.auto-listening-indicator{align-items:center;background-color:#f8f9fa;border-left:3px solid #28a745;border-radius:4px;color:#495057;display:flex;font-size:14px;gap:8px;margin-bottom:10px;padding:8px 12px}.listening-dot{background-color:#dc3545;border-radius:50%;height:8px;width:8px}.listening-dot.active{animation:pulse 2s infinite;background-color:#28a745}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.search-button{white-space:nowrap}.auto-badge{background-color:#28a745;border-radius:3px;color:#fff;font-size:10px;font-weight:400;margin-left:8px;padding:2px 6px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:.5rem;margin-top:var(--spacing-sm)}.mt-2{margin-top:1rem;margin-top:var(--spacing-md)}.mt-3{margin-top:1.5rem;margin-top:var(--spacing-lg)}.mb-1{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:1rem;margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.hidden{display:none}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.w-full{width:100%}.h-full{height:100%}
/*# sourceMappingURL=main.20165aa9.css.map*/