.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0003;text-align:center;max-width:400px;width:90%}.login-card h1{margin:0 0 1rem;color:#333;font-size:2rem}.login-card p{color:#666;margin:0 0 2rem;font-size:1rem}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;font-weight:600}.login-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.login-button:active{transform:translateY(0)}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.dashboard-header{background:#fffffff2;padding:1.5rem 2rem;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{margin:0;color:#333;font-size:1.8rem}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:50px;height:50px;border-radius:50%;object-fit:cover}.user-details{display:flex;flex-direction:column}.user-name{margin:0;font-weight:600;color:#333;font-size:1rem}.user-email{margin:0;color:#666;font-size:.875rem}.user-role{margin:0;color:#667eea;font-size:.875rem;font-weight:600}.logout-button{background:#dc3545;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:background .2s}.logout-button:hover{background:#c82333}.dashboard-content{padding:3rem 2rem;display:flex;justify-content:center}.room-section{max-width:800px;width:100%}.room-section h2{color:#fff;text-align:center;margin-bottom:2rem;font-size:2rem}.room-card{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 5px 20px #0000001a}.room-card h3{margin:0 0 .5rem;color:#333;font-size:1.5rem}.room-card p{margin:0 0 1.5rem;color:#666}.create-room-button,.join-room-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 2rem;font-size:1rem;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600;width:100%}.create-room-button:hover,.join-room-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.create-room-button:active,.join-room-button:active{transform:translateY(0)}.room-input{width:100%;padding:.875rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:1rem;box-sizing:border-box;transition:border-color .2s}.room-input:focus{outline:none;border-color:#667eea}.error-message{color:#dc3545;margin:0 0 1rem;padding:.5rem;background:#ffe6e6;border-radius:4px;font-size:.875rem}.loading-message,.no-rooms-message{color:#666;margin:0;text-align:center;padding:1rem 0}.rooms-list{display:flex;flex-direction:column;gap:.75rem}.room-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0;transition:all .2s}.room-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.room-item-info{display:flex;flex-direction:column;gap:.25rem}.room-item-id{font-weight:600;color:#333;font-size:1rem}.room-item-users{color:#666;font-size:.875rem}.room-item-join-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:transform .2s,box-shadow .2s;font-size:.875rem}.room-item-join-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.room-item-join-button:active{transform:translateY(0)}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.user-info{flex-direction:column}.room-item{flex-direction:column;gap:.75rem;align-items:stretch}.room-item-join-button{width:100%}}.alignment-view-container{position:relative;flex:1;width:100%;display:flex;flex-direction:column}.alignment-3d{position:relative;flex:1;width:100%;min-height:0}.alignment-bars{display:flex;flex-direction:column;gap:8px;padding:12px 16px}.alignment-bar{display:flex;align-items:center;gap:10px}.alignment-bar-label{font-weight:600;font-size:14px;color:#ccc;width:16px;text-align:center}.alignment-bar-track{flex:1;height:24px;background:#333;border-radius:4px;overflow:hidden}.alignment-bar-fill{height:100%;background:#e74c3c;border-radius:4px;transition:width 50ms linear,background-color .2s ease}.alignment-bar-fill.aligned{background:#2ecc71}.alignment-bar-value{font-size:13px;color:#999;width:50px;text-align:right;font-variant-numeric:tabular-nums}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh;overflow-x:hidden}body:has(.sonographer-view-new){overflow:hidden}.app{max-width:1200px;margin:0 auto;padding:20px}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #333}header h1{font-size:1.5rem}.connection-status{padding:8px 16px;border-radius:20px;font-size:.875rem}.connection-status.connected{background:#10b981;color:#fff}.connection-status.disconnected{background:#ef4444;color:#fff}.error{background:#ef4444;color:#fff;padding:12px 20px;border-radius:8px;margin-bottom:20px}.setup-panel{text-align:center;padding:60px 20px;background:#16213e;border-radius:12px}.setup-panel p{margin-bottom:20px;color:#aaa}.btn{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s;background:#333;color:#fff}.btn:hover{opacity:.9;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn:disabled:hover{opacity:.5;transform:none}.btn.primary{background:#3b82f6}.btn.danger{background:#ef4444}.btn.muted{background:#f59e0b}.controls{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding:12px 14px;background:#16213e;border-radius:12px;flex-wrap:nowrap;overflow-x:auto;width:100vw;margin-left:calc(-50vw + 50%)}.join-panel{display:flex;gap:10px}.join-panel input{padding:10px 16px;border:1px solid #333;border-radius:8px;background:#1a1a2e;color:#fff;font-size:1rem;width:200px}.join-panel input:focus{outline:none;border-color:#3b82f6}.room-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.room-info span{font-weight:500}.user-label{color:#aaa;font-size:.875rem}.media-controls{display:flex;gap:10px;margin-left:0;justify-content:flex-start;flex-wrap:wrap}.controls-right{display:flex;align-items:center;gap:10px;margin-left:auto}.eye-tracking-controls{display:flex;align-items:center;gap:10px}.controls-with-eye-tracking .media-controls{margin-left:0}.eye-tracking-error{color:#f59e0b;font-size:.85rem;font-weight:500}.eye-tracking-calibration{position:fixed;top:0;right:0;bottom:0;left:0;background:#050814bf;z-index:2000;display:flex;align-items:flex-start;justify-content:center;pointer-events:auto}.calibration-instructions{margin-top:40px;text-align:center;background:#16213ef2;padding:18px 22px;border-radius:12px;border:1px solid rgba(102,126,234,.6);box-shadow:0 10px 24px #00000059}.calibration-instructions h2{font-size:1.1rem;margin-bottom:6px;color:#c7d2fe}.calibration-instructions p{color:#cbd5f5;font-size:.9rem}.calibration-instructions .calibration-progress{margin:8px 0 12px;font-weight:600;color:#93c5fd}.calibration-point{position:absolute;width:18px;height:18px;border-radius:50%;background:#22d3ee;border:2px solid rgba(255,255,255,.9);transform:translate(-50%,-50%);box-shadow:0 0 0 6px #22d3ee40;cursor:pointer}.calibration-point:active{transform:translate(-50%,-50%) scale(.9)}.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.video-container{position:relative;background:#0f0f23;border-radius:12px;overflow:hidden;aspect-ratio:16 / 9}.video-container video{width:100%;height:100%;object-fit:cover}.video-container.local video{transform:scaleX(-1)}.video-label{position:absolute;bottom:10px;left:10px;background:#000000b3;padding:4px 12px;border-radius:4px;font-size:.875rem}.device-selector-panel{max-width:700px;margin:40px auto;padding:30px;background:#16213e;border-radius:12px}.device-selector-panel h2{margin-bottom:10px;color:#667eea}.device-selector-panel .instruction{margin-bottom:30px;color:#aaa;font-size:.95rem}.device-selectors{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.device-selector-group{display:flex;flex-direction:column;gap:8px}.device-selector-group label{font-weight:600;color:#ddd;font-size:.95rem}.device-select{padding:10px 12px;background:#0f0f23;border:1px solid #333;border-radius:8px;color:#fff;font-size:.95rem;cursor:pointer}.device-select:focus{outline:none;border-color:#667eea}.start-btn{width:100%;padding:14px;font-size:1rem;font-weight:600}.metadata-display{background:#667eea33;border:1px solid #667eea;border-radius:8px;padding:8px 16px;margin-bottom:10px;font-size:.875rem;color:#a5b4fc;flex-shrink:0}.metadata-display span{display:block}.sonographer-view-new{display:flex;flex-direction:column;height:calc(100vh - 220px);gap:12px;width:100vw;margin-left:calc(-50vw + 50%);padding:0 20px;overflow:hidden}.sonographer-content-wrapper{flex:1;display:flex;gap:12px;min-height:0;overflow:hidden}.main-video-area-new{flex:60;display:flex;justify-content:center;align-items:center;min-height:0;min-width:0;overflow:hidden}.right-panel{display:flex;gap:8px;flex:40;height:100%;min-width:0}.right-panel.with-alignment .threejs-iframe-container,.right-panel.with-alignment .stacked-3d-views,.right-panel.expanded .stacked-3d-views{flex:1}.threejs-iframe-container.alignment.hidden{display:none}.sonographer-content-wrapper.robot-enabled .main-video-area-new{flex:70}.sonographer-content-wrapper.robot-enabled .right-panel{flex:30}.sonographer-view-new.robot-enabled .camera-bar-bottom{height:80px}.sonographer-view-new.robot-enabled .camera-bar-bottom .video-container.thumbnail{width:100px;height:60px}.sonographer-view-new.robot-enabled{height:calc(100vh - 180px)}.threejs-iframe-container{flex:1;height:100%;background:#0f0f23;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;min-width:0}.stacked-3d-views{display:flex;flex-direction:column;gap:8px;height:100%;min-width:0;flex:1}.stacked-3d-views .threejs-view{flex:1;position:relative;border-radius:8px;overflow:hidden;background:#0f0f23}.stacked-3d-views .threejs-view iframe{width:100%;height:100%;border:none}.stacked-3d-views .view-label{position:absolute;bottom:8px;left:8px;font-size:11px;color:#fff;background:#0009;padding:2px 8px;border-radius:4px}.waiting-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#aaa;font-size:1rem}.view-controls{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;gap:4px;padding:6px;background:#16213ed9;border-radius:8px;z-index:10}.view-btn{padding:4px 10px;background:#0f0f23cc;border:1px solid transparent;border-radius:4px;color:#ddd;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.view-btn:hover{background:#1a2747;border-color:#667eea}.view-btn.active{background:#667eea;color:#fff;border-color:#667eea}.threejs-iframe{width:100%;flex:1;border:none;display:block}.video-container.main-view{width:100%;height:100%;max-width:calc((100vh - 220px - 120px - 12px) * 16 / 9);border-radius:12px;background:#0f0f23;display:flex;align-items:center;justify-content:center}.video-container.main-view video{width:100%;height:100%;object-fit:contain;border-radius:12px}.video-container.main-view.iframe-view{overflow:hidden}.main-iframe{width:100%;height:100%;border:none;border-radius:12px}.split-screen-container{display:flex;flex-direction:column;gap:12px;width:100%;height:100%;max-width:calc((100vh - 220px - 120px - 12px) * 16 / 9)}.video-container.split-view{flex:1;height:100%;border-radius:12px;background:#0f0f23;display:flex;align-items:center;justify-content:center}.video-container.split-view video{width:100%;height:100%;object-fit:contain;border-radius:12px}.video-container.split-view.iframe-view{overflow:hidden}.split-iframe{width:100%;height:100%;border:none;border-radius:12px}.camera-bar-bottom{display:flex;gap:10px;padding:10px 15px;background:#16213e;border-radius:12px;overflow-x:auto;flex-shrink:0;height:120px;align-items:center}.video-container.thumbnail{width:150px;min-width:150px;height:85px;cursor:pointer;border:3px solid transparent;transition:all .2s ease;border-radius:8px;flex-shrink:0}.video-container.thumbnail:hover{border-color:#667eea;transform:scale(1.02)}.video-container.thumbnail.selected{border-color:#10b981;box-shadow:0 0 12px #10b98166}.video-container.thumbnail .video-label{font-size:.75rem;padding:2px 8px}.video-container.thumbnail.iframe-thumbnail{background:#16213e}.iframe-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0f0f23}.iframe-icon{font-size:2.5rem;opacity:.7}.split-screen-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:150px;min-width:150px;height:85px;background:#16213e;border:3px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;flex-shrink:0;padding:8px;gap:4px}.split-screen-btn:hover{border-color:#667eea;transform:scale(1.02);background:#1a2747}.split-screen-btn.selected{border-color:#10b981;box-shadow:0 0 12px #10b98166;background:#1a2747}.split-icon{font-size:2rem;color:#667eea;line-height:1}.split-screen-btn.selected .split-icon{color:#10b981}.split-label{font-size:.75rem;color:#ddd;text-align:center}.waiting-message-inline{display:flex;align-items:center;padding:0 20px;color:#aaa;font-size:.9rem}.sonographer-view{display:flex;gap:20px;height:calc(100vh - 250px)}.main-video-area{flex:1;display:flex;flex-direction:column;gap:20px}.video-container.local-large{flex:1;min-height:400px}.tools-panel{background:#16213e;border-radius:12px;padding:20px;max-height:300px;overflow-y:auto}.tools-panel h3{margin-bottom:15px;color:#667eea;font-size:1.1rem}.tool-section{margin-bottom:20px}.tool-section h4{font-size:.9rem;margin-bottom:10px;color:#aaa}.tool-btn{display:block;width:100%;margin-bottom:8px;padding:8px 16px;background:#667eea;font-size:.875rem}.tool-btn:hover{background:#5568d3}.remote-feeds-sidebar{width:280px;background:#16213e;border-radius:12px;padding:15px;overflow-y:auto}.remote-feeds-sidebar h4{margin-bottom:15px;font-size:.95rem;color:#aaa}.video-container.remote-small{margin-bottom:15px;aspect-ratio:16 / 9}.medical-assistant-view-new{display:flex;flex-direction:column;height:calc(100vh - 220px);gap:12px;width:100vw;margin-left:calc(-50vw + 50%);padding:0 20px;overflow:hidden}body:has(.medical-assistant-view-new){overflow:hidden}.medical-assistant-view{display:flex;gap:20px;height:calc(100vh - 250px)}.video-feeds{flex:1;display:flex;flex-direction:column;gap:15px}.remote-feed-main{flex:1;display:flex;align-items:center;justify-content:center;background:#0f0f23;border-radius:12px;min-height:400px}.video-container.remote-large{width:100%;height:100%}.waiting-message{text-align:center;color:#aaa;padding:40px}.waiting-message p{font-size:1.2rem}.local-feed-small{height:180px}.video-container.local-mini{height:100%;aspect-ratio:16 / 9}.local-feeds-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;height:280px}.video-container.local-camera{background:#0f0f23;border-radius:8px;overflow:hidden;position:relative}.notes-panel{width:350px;background:#16213e;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.notes-panel h3{margin-bottom:10px;color:#667eea;font-size:1.1rem}.notes-section{display:flex;flex-direction:column;gap:10px}.notes-textarea{width:100%;min-height:200px;padding:12px;background:#0f0f23;border:1px solid #333;border-radius:8px;color:#fff;font-family:inherit;font-size:.875rem;resize:vertical}.notes-textarea:focus{outline:none;border-color:#667eea}.patient-info-section{display:flex;flex-direction:column;gap:10px}.patient-info-section h4{font-size:.95rem;margin-bottom:5px;color:#aaa}.patient-info-section .tool-btn{background:#10b981}.patient-info-section .tool-btn:hover{background:#059669}@media(max-width:1024px){.sonographer-view-new,.medical-assistant-view-new{height:calc(100vh - 240px)}.sonographer-content-wrapper{flex-direction:column}.threejs-iframe-container{width:100%;min-width:100%;height:300px}.video-container.main-view,.split-screen-container{max-width:calc((100vh - 240px - 100px - 12px) * 16 / 9)}.camera-bar-bottom{height:100px}.video-container.thumbnail{width:130px;min-width:130px;height:73px}.sonographer-view{flex-direction:column;height:auto}.remote-feeds-sidebar{width:100%;max-height:300px}.medical-assistant-view{flex-direction:column;height:auto}.notes-panel{width:100%;max-height:400px}.tools-panel{max-height:none}.local-feeds-grid{height:auto}}@media(max-width:600px){.controls{flex-direction:column}.media-controls{margin-left:0;flex-wrap:wrap}.eye-tracking-controls{margin:0;flex-wrap:wrap;justify-content:center}.join-panel{flex-direction:column}.join-panel input{width:100%}.sonographer-view-new,.medical-assistant-view-new{height:calc(100vh - 280px)}.video-container.main-view,.split-screen-container{max-width:calc((100vh - 280px - 80px - 12px) * 16 / 9)}.camera-bar-bottom{height:80px;padding:6px 10px;gap:6px}.video-container.thumbnail{width:100px;min-width:100px;height:56px}.sonographer-view,.medical-assistant-view{height:auto}.video-container.local-large,.remote-feed-main{min-height:250px}.local-feeds-grid{grid-template-columns:1fr;gap:8px}}.force-slider-controls{display:flex;align-items:center;gap:10px}.force-slider-label{display:flex;align-items:center;gap:12px;font-size:14px;color:#ddd}.force-slider-label span:first-child{min-width:90px}.force-slider-input{width:100px;accent-color:#10b981;cursor:pointer}.force-slider-value{min-width:40px;text-align:right;font-variant-numeric:tabular-nums}.clutch-controls{display:flex;align-items:center;gap:10px}.toggle-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.95rem;font-weight:500;color:#ddd}.toggle-label span:first-child{min-width:110px}.toggle-input{display:none}.toggle-slider{position:relative;width:50px;height:26px;background:#333;border-radius:13px;transition:background-color .3s ease;border:2px solid #555}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#999;top:2px;left:2px;transition:all .3s ease}.toggle-input:checked+.toggle-slider{background:#10b981;border-color:#10b981}.toggle-input:checked+.toggle-slider:before{transform:translate(24px);background:#fff}.toggle-input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.toggle-label:has(.toggle-input:disabled){cursor:not-allowed;opacity:.7}.traverse-gate-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.traverse-gate-card{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0003;text-align:center;max-width:440px;width:90%}.traverse-gate-icon{font-size:3rem;margin-bottom:1rem}.traverse-gate-card h1{margin:0 0 1rem;color:#333;font-size:1.75rem}.traverse-gate-card p{color:#666;margin:0 0 2rem;font-size:1rem;line-height:1.5}.traverse-gate-launch-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;font-weight:600;margin-bottom:1.5rem}.traverse-gate-launch-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.traverse-gate-launch-button:active{transform:translateY(0)}.traverse-gate-download{color:#666;font-size:.95rem;margin:0 0 1.5rem}.traverse-gate-download a{color:#667eea;font-weight:600;text-decoration:none}.traverse-gate-download a:hover{text-decoration:underline}.traverse-gate-waiting{color:#888;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.traverse-gate-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:#667eea;animation:traverse-gate-pulse-anim 1.5s ease-in-out infinite}@keyframes traverse-gate-pulse-anim{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
