*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#000;background-image:radial-gradient(circle at 50% 50%,#14141e80,#000),linear-gradient(rgba(0,33,71,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,33,71,.03) 1px,transparent 1px);background-size:100% 100%,40px 40px,40px 40px;background-attachment:fixed;color:#e0e0e0;line-height:1.6;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;background:#000}.spinner{width:40px;height:40px;border:3px solid rgba(0,33,71,.1);border-top:3px solid #002147;border-radius:50%;animation:spin 1s linear infinite;box-shadow:0 0 15px #00214733}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:#000;position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(0,33,71,.05) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(138,43,226,.05) 0%,transparent 50%);animation:bgPulse 10s ease-in-out infinite alternate;z-index:0}@keyframes bgPulse{0%{opacity:.5}to{opacity:1}}.auth-header{text-align:center;margin-bottom:3rem;color:#fff;position:relative;z-index:1}.auth-header h1{font-size:3rem;font-weight:800;margin-bottom:.5rem;color:#fff;letter-spacing:-.02em;text-shadow:0 2px 10px rgba(0,0,0,.5)}.auth-header p{font-size:1.1rem;color:#8899ac;font-weight:300}.auth-form{background:#0a0c10cc;padding:3rem;border-radius:16px;border:2px solid rgba(255,255,255,.3);width:100%;max-width:420px;position:relative;z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 25px 50px -12px #00000080;transition:transform .3s ease,box-shadow .3s ease}.auth-form:hover{border-color:#00214733;box-shadow:0 25px 50px -12px #00000080,0 0 30px #0021470d}.auth-form h2{text-align:center;margin-bottom:2rem;color:#fff;font-size:1.75rem;font-weight:600;letter-spacing:-.01em;text-shadow:0 2px 10px rgba(0,0,0,.5)}.app-header{background:#050505cc;border:2px solid rgba(255,255,255,.3);padding:1.25rem 0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:sticky;top:0;z-index:50}.header-content{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center}.header-left h1{font-size:1.25rem;font-weight:700;color:#fff;margin-bottom:.25rem;letter-spacing:-.01em;text-shadow:0 2px 10px rgba(0,0,0,.5)}.header-left p{color:#8899ac;font-size:.875rem}.header-left{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.5rem}.header-session-info{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;margin-left:1rem;padding-left:1rem;border-left:1px solid rgba(255,255,255,.2)}.header-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.8125rem;color:#94a3b8}.header-status-icon.connected{color:#22c55e;flex-shrink:0}.header-status-icon.spinner{color:#94a3b8;animation:spin 1s linear infinite}.header-intervention-text{font-size:.8125rem;color:#94a3b8}.header-intervention-text strong{color:#e2e8f0}.header-session-id{font-size:.75rem;color:#64748b;font-family:ui-monospace,monospace}.voice-session-subtitle-minimal{margin-top:.25rem;font-size:.8rem;color:#94a3b8}.header-right{display:flex;align-items:center;gap:1.5rem}.app-main{flex:1;padding:2rem 0;display:flex;flex-direction:column;min-height:0}.main-content{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;gap:2rem;flex:1;min-height:0;width:100%}.main-content>*{flex:1;min-height:0;display:flex;flex-direction:column}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;color:#94a3b8;margin-bottom:.5rem;font-size:.875rem;letter-spacing:.02em}.form-group input{width:100%;padding:.875rem 1rem;background:#ffffff08;border:2px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:1rem;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#002147;background:#00214705;box-shadow:0 0 0 2px #0021471a}.form-group input::placeholder{color:#475569}.error-text{color:#ff4d4d;font-size:.8125rem;margin-top:.5rem;display:block}.error-message{background:#ef444426;border:2px solid rgba(255,255,255,.3);color:#fca5a5;padding:1rem 1.25rem;border-radius:10px;margin-top:1rem;font-size:.9375rem;display:flex;align-items:center;gap:.75rem}.error-message svg{color:#ef4444;flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;letter-spacing:.01em}.btn:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(100%)}.btn.primary{background:#002147;color:#fff;width:100%;position:relative;overflow:hidden;box-shadow:0 4px 15px #00214766;border:2px solid rgba(255,255,255,.3)}.btn.primary:hover:not(:disabled){background:#036;box-shadow:0 6px 25px #00214780;transform:translateY(-2px);border-color:#fff6}.btn.primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #0021474d}.btn.secondary{background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1)}.btn.secondary:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.auth-switch{text-align:center;margin-top:1.5rem;color:#94a3b8;font-size:.9375rem}.link-button{background:none;border:none;color:#002147;cursor:pointer;font-weight:600;font-size:inherit;margin-left:.5rem;padding:0;transition:color .2s}.link-button:hover{color:#fff;text-decoration:underline}.voice-session-container{background:#0a0c1099;border-radius:20px;border:2px solid rgba(255,255,255,.3);overflow:hidden;position:relative;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;flex:1;min-width:0;min-height:0;height:100%}.voice-session-outer{display:flex;flex-direction:row;width:100%;flex:1;min-height:100vh;align-items:stretch;height:100%}.voice-session-sidebar{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:0;position:relative;top:auto;align-self:stretch}.voice-session-sidebar-left,.voice-session-sidebar-right{width:16rem;min-width:16rem}.risk-light-panel{width:calc(100% - 1rem);min-height:calc(100vh - 1rem);height:100%;margin-top:0;padding:1rem .5rem .9rem;border-radius:1rem;background:linear-gradient(165deg,#080e22f5,#080c18f0 58%,#040812f2);border:1px solid rgba(120,184,255,.28);box-shadow:inset 0 0 0 1px #ffffff0d,inset 0 12px 28px #78b8ff0f,0 14px 32px #0006;display:flex;flex-direction:column;align-items:center;gap:.6rem;position:relative;overflow:hidden}.risk-light-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(0deg,#82b4ff0f,#82b4ff0f) 0 0 / 100% 1px no-repeat,repeating-linear-gradient(180deg,rgba(123,177,255,.08) 0,rgba(123,177,255,.08) 1px,transparent 1px,transparent 7px);opacity:.38;pointer-events:none}.risk-light-panel:after{content:"";position:absolute;left:.35rem;right:.35rem;top:.35rem;height:2px;border-radius:999px;background:linear-gradient(90deg,transparent 0%,rgba(140,200,255,.9) 50%,transparent 100%);opacity:.75;pointer-events:none}.risk-light-panel.green{border-color:#22c55e57}.risk-light-panel.amber{border-color:#f59e0b57}.risk-light-panel.red{border-color:#ef44445c}.risk-light{width:14.4rem;max-width:100%;height:auto;flex:1;min-height:0;border-radius:.95rem;border:1px solid rgba(215,233,255,.78);box-shadow:0 0 0 2px #060c18f2,inset 0 0 24px #ffffff24,0 0 26px #00000061;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease,filter .2s ease;position:relative;overflow:hidden;z-index:1;display:flex;align-items:center;justify-content:center}.risk-light:before{content:"";position:absolute;top:.24rem;right:.24rem;bottom:.24rem;left:.24rem;border-radius:.72rem;background:linear-gradient(180deg,#ffffff38,#ffffff0a,#fff0 44%);pointer-events:none}.risk-light:after{content:"";position:absolute;top:-.14rem;right:-.14rem;bottom:-.14rem;left:-.14rem;border-radius:1.05rem;border:1px solid rgba(159,208,255,.45);opacity:.86;pointer-events:none}.risk-light-grid{position:absolute;top:.52rem;right:.52rem;bottom:.52rem;left:.52rem;display:grid;grid-template-rows:repeat(27,1fr);gap:.1rem;z-index:2}.risk-light-segment{border-radius:.26rem;border:1px solid rgba(255,255,255,.22);background:currentColor;opacity:.3;box-shadow:inset 0 0 5px #ffffff1f}.risk-light-scan{position:absolute;left:.46rem;right:.46rem;height:.42rem;border-radius:.35rem;background:linear-gradient(90deg,#fff0,#ffffff70,#fff0);mix-blend-mode:screen;opacity:.9;pointer-events:none;z-index:3;display:none}.risk-light.green{box-shadow:0 0 0 2px #060c18f2,inset 0 0 18px #fff3,0 0 20px #16a34a59,0 0 42px #16a34a57;filter:saturate(1.1)}.risk-light.amber{box-shadow:0 0 0 2px #060c18f2,inset 0 0 18px #fff3,0 0 20px #d977066b,0 0 42px #f59e0b61;filter:saturate(1.16)}.risk-light.red{box-shadow:0 0 0 2px #060c18f2,inset 0 0 18px #ffffff29,0 0 24px #dc262680,0 0 48px #f8717170;transform:none}.risk-indicator-label{position:relative;z-index:2;margin:0;padding:0;font-size:1.12rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#fffffffa;text-shadow:0 1px 3px rgba(0,0,0,.6);text-align:center;width:100%;white-space:nowrap}.risk-indicator-label-left,.risk-indicator-label-right{margin-top:0}.risk-indicator-note{margin:0;width:100%;min-height:3.6rem;padding:.55rem .35rem 0;text-align:center;font-size:.82rem;line-height:1.2;color:#ffffffe6;letter-spacing:.01em;font-weight:600}@keyframes riskRingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes riskBarScan{0%,to{top:10%;opacity:.5}50%{top:84%;opacity:.95}}@keyframes riskSegmentPulse{0%,to{opacity:.22}50%{opacity:.42}}@keyframes riskAlertPulse{0%,to{transform:scale(1.01);filter:saturate(1.12) brightness(1)}50%{transform:scale(1.04);filter:saturate(1.22) brightness(1.08)}}@keyframes riskPanelScan{0%{transform:translateY(-18%)}to{transform:translateY(18%)}}.voice-session-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#002147,transparent);opacity:.5}.disclaimer-screen{background:#050505f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:fixed;top:0;left:0;right:0;bottom:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:2rem}.disclaimer-content{background:#0f1115;border:2px solid rgba(255,255,255,.3);border-radius:16px;padding:3rem;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080}.disclaimer-header h2{color:#fff;margin-bottom:1.5rem;font-size:2rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}.legal-section{background:#ffffff08;border:2px solid rgba(255,255,255,.3);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.legal-section h3{color:#002147;border-bottom-color:#ffffff1a;text-shadow:-1px -1px 0 #ffffff,1px -1px 0 #ffffff,-1px 1px 0 #ffffff,1px 1px 0 #ffffff,0 0 2px #ffffff}.legal-text{color:#94a3b8}.legal-text strong{color:#fff}.acceptance-section{background:#00214705;border:2px solid rgba(255,255,255,.3);border-radius:12px}.checkbox-label{color:#e2e8f0}.checkbox-label:hover{color:#fff}.acceptance-checkbox{accent-color:#002147}.disclaimer-button{background:#002147;color:#fff;border:2px solid rgba(255,255,255,.3);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.disclaimer-button:hover:not(:disabled){background:#036;border-color:#fff6}.disclaimer-button:disabled{background:#1e293b;color:#64748b}.voice-session-header{border-bottom:2px solid rgba(255,255,255,.3);border-top:2px solid rgba(255,255,255,.3);border-left:2px solid rgba(255,255,255,.3);border-right:2px solid rgba(255,255,255,.3);padding:1rem 2rem;background:#ffffff05;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.voice-session-header-minimal{padding:.35rem .75rem;border-width:1px;background:#00000040;flex-shrink:0}.voice-session-title-minimal{color:#ffffffd9;font-size:.85rem;font-weight:600;letter-spacing:.02em;margin:0}.voice-session-header-controls-minimal{display:flex;align-items:center;gap:.5rem}.session-timer-minimal{font-size:2.7rem;font-variant-numeric:tabular-nums;font-weight:600;color:#ffffffe6;margin-right:.5rem}.btn-session-action{display:inline-flex;align-items:center;justify-content:center;min-width:64px;height:36px;padding:0 1rem;border:1px solid rgba(255,255,255,.25);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.btn-session-action.btn-start{background:#ffffff14;color:#ffffffe6}.btn-session-action.btn-start:hover:not(:disabled){background:#ffffff24;color:#fff}.btn-session-action.btn-start.btn-start-active{background:#22c55e59;border-color:#22c55e99;color:#22c55e}.btn-session-action.btn-start.btn-start-active:hover:not(:disabled){background:#22c55e73;border-color:#22c55e}.btn-session-action.btn-end{background:#ffffff0f;color:#f87171f2;border-color:#f871714d}.btn-session-action.btn-end:hover{background:#ef444433;color:#f87171;border-color:#f8717180}.btn-session-action:disabled{opacity:.5;cursor:not-allowed}.btn-icon-minimal{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0d;color:#fffc;cursor:pointer;transition:background .15s,color .15s}.btn-icon-minimal:hover:not(:disabled){background:#ffffff1f;color:#fff}.btn-icon-minimal:disabled{opacity:.5;cursor:not-allowed}.live-indicator-minimal{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:#64748b}.live-indicator-minimal.live{background:#22c55e;animation:live-glow 2.5s ease-in-out infinite}.live-indicator-minimal.disconnected{background:#64748b;animation:none}@keyframes live-glow{0%,to{box-shadow:0 0 4px #22c55e66;opacity:1}50%{box-shadow:0 0 12px #22c55eb3;opacity:.9}}.connection-dot-minimal{width:8px;height:8px;border-radius:50%;flex-shrink:0}.connection-dot-minimal.connected{background:#22c55e;box-shadow:0 0 6px #22c55e80}.connection-dot-minimal.disconnected{background:#64748b}.audio-status-minimal{font-size:.95rem;color:#ffffffd9;margin-left:.5rem;white-space:nowrap}.audio-error-minimal{font-size:.75rem;color:#f87171;margin-left:.25rem}.btn-close-minimal{width:32px;height:32px;padding:0;font-size:1.25rem;line-height:1}.voice-session-header h2{color:#fff;font-size:1.25rem;font-weight:600;letter-spacing:.02em;text-shadow:0 2px 10px rgba(0,0,0,.5);animation:none;margin:0}.voice-session-header-controls{display:flex;align-items:center;gap:1rem;flex-wrap:nowrap}@media (max-width: 768px){.voice-session-header-controls{flex-wrap:wrap}}.session-timer-inline{flex-direction:row;align-items:center;gap:.35rem}.session-timer-inline .timer-label{font-size:.75rem;color:#94a3b8}.session-timer-inline .timer-value{font-size:1rem;font-weight:600;color:#e2e8f0}.btn-header-control{padding:.5rem 1rem;font-size:.875rem}.audio-status-inline{font-size:.8rem;color:#94a3b8}.status-indicator{background:#0021471a;padding:.375rem .75rem;border-radius:9999px;border:2px solid rgba(255,255,255,.3);font-size:.75rem;color:#002147;text-shadow:none}.btn-close{color:#64748b}.btn-close:hover{color:#fff;background:#ffffff1a;border-radius:8px}.voice-session-content{padding:2rem;flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.voice-session-content-fullscreen{padding:0;flex:1;min-height:0;display:flex;flex-direction:column;height:100%}.session-active-fullscreen-transcript{flex:1;display:flex;flex-direction:column;min-height:0;padding:0;width:100%;height:100%}.session-active-fullscreen-transcript .message-minimal{margin:.5rem 1rem;padding:.5rem .75rem;font-size:.85rem}.session-panel-transcript-fullscreen{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;width:100%;height:100%}.transcript-two-panels-wrapper{display:flex;flex-direction:row;width:100%;min-height:0}.transcript-single-wrapper{display:flex;flex-direction:column;width:100%;min-height:0}.transcript-panel-heading-single{border-bottom:1px solid rgba(255,255,255,.1);color:#ffffffe6;font-size:1rem;font-weight:600;padding:.75rem 1.25rem}.transcript-text-single{padding-top:1rem}.transcript-single-wrapper .entry-text{font-size:1.05rem;line-height:1.6}.transcript-single-wrapper .speaker-label{font-size:.8rem}.transcript-panel{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.transcript-panel-heading{flex-shrink:0;padding:.5rem 1rem;font-size:1rem;font-weight:600;color:#ffffffe6;border-bottom:1px solid rgba(255,255,255,.1)}.transcript-panel-left .transcript-panel-heading{color:#34d399}.transcript-panel-right .transcript-panel-heading{color:#60a5fa}.transcript-panel-divider{width:2px;flex-shrink:0;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.2),transparent)}.transcript-row-spacer{min-height:1.5rem;flex-shrink:0}.transcript-container-fullscreen{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;height:100%}.transcript-text-fullscreen{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:1.25rem 1.5rem;overscroll-behavior:contain;max-height:none}.transcript-two-panels-wrapper .entry-text{font-size:1.2rem;line-height:1.6}.transcript-two-panels-wrapper .speaker-label{font-size:.9rem}.transcript-two-panels-wrapper .transcript-placeholder{font-size:1.05rem}.transcript-text-fullscreen::-webkit-scrollbar{width:8px}.transcript-text-fullscreen::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.transcript-text-fullscreen::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.transcript-text-fullscreen::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.video-float-wrapper{position:fixed;bottom:1rem;right:1rem;z-index:100;max-width:320px;max-height:200px;box-shadow:0 8px 32px #0006;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.15)}.video-float-card{display:flex;flex-direction:column;height:100%;background:#1e293b}.video-float-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.8rem;color:#e2e8f0;background:#0003}.video-float-header span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-close-float{padding:.25rem;background:transparent;border:none;color:#94a3b8;cursor:pointer;border-radius:4px}.btn-close-float:hover{color:#fff;background:#ffffff1a}.video-float-embed{flex:1;min-height:0;aspect-ratio:16/9}.video-float-embed iframe{width:100%;height:100%}.session-ready{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0;height:100%;overflow:hidden}.student-info{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;background:#10b9811a;border:2px solid rgba(255,255,255,.3);border-radius:12px;flex-shrink:0}.student-info p{color:#fff;font-size:1rem;margin:0}.student-info strong{color:#10b981;font-weight:600}.success-icon{color:#10b981;flex-shrink:0}.features-info{padding:1rem 1.2rem;background:#1e293b80;border:2px solid rgba(255,255,255,.3);border-radius:12px;flex:1;min-height:0;overflow-y:auto}.features-info h4{color:#fff;font-size:.95rem;font-weight:600;margin-bottom:.65rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}.features-info ul{list-style:none;padding:0;margin:0}.features-info li{color:#cbd5e1;font-size:.9375rem;line-height:1.8;padding-left:1.5rem;position:relative}.features-info li:before{content:"•";color:#3b82f6;font-weight:700;position:absolute;left:0}.features-note{color:#94a3b8;font-size:.8125rem;font-style:italic;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05)}.intervention-notice{color:#cbd5e1;font-size:.89rem;line-height:1.55}.intervention-notice p{margin-bottom:.65rem;color:#cbd5e1}.intervention-notice p:last-child{margin-bottom:0}.intervention-notice strong{color:#fff;font-weight:600}.start-session-btn{margin-top:.5rem;padding:1rem 2rem;font-size:1rem}.status-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 2rem;text-align:center}.status-message p{color:#e2e8f0;font-size:1rem}.status-message.error{background:#ef44441a;border:2px solid rgba(255,255,255,.3);border-radius:12px}.status-message.error p{color:#fca5a5}.token-input-section{display:flex;flex-direction:column;gap:.75rem;margin-top:0;padding-top:.15rem;flex-shrink:0}.token-input-section label{color:#e2e8f0;font-size:1rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.token-input{background:#0006;border:2px solid rgba(255,255,255,.3);color:#fff;font-family:JetBrains Mono,Courier New,monospace;font-size:1.5rem;font-weight:600;letter-spacing:.35em;text-align:center;padding:1rem 1.5rem;border-radius:12px;text-transform:uppercase;transition:all .2s ease}.token-input::placeholder{color:#4a5568;font-weight:400;letter-spacing:.2em}.token-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633,0 0 20px #3b82f61a;background:#0009}.token-input:valid:not(:placeholder-shown){border-color:#10b981}.session-controls .btn.danger{background:#ff4d4d;color:#fff;border:none;width:64px;height:64px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #ff4d4d4d}.session-controls .btn.danger:hover{transform:scale(1.05);box-shadow:0 0 30px #ff4d4d80}.mic-icon{color:#fff;width:24px;height:24px}.transcript-container{background:#0000004d;border:2px solid rgba(255,255,255,.3);border-radius:16px;box-shadow:none}.transcript-container h3{color:#002147;font-size:.75rem;letter-spacing:.1em;margin-bottom:1rem;text-shadow:-1px -1px 0 #ffffff,1px -1px 0 #ffffff,-1px 1px 0 #ffffff,1px 1px 0 #ffffff,0 0 2px #ffffff}.transcript-text{background:transparent;border:none;color:#e2e8f0;font-family:Inter,sans-serif;line-height:1.7}.text-input{background:#ffffff08;border:2px solid rgba(255,255,255,.3);border-radius:9999px;padding-left:1.5rem;padding-right:1.5rem}.text-input:focus{border-color:#3b82f6;background:#0006;box-shadow:0 0 0 2px #3b82f633}.session-active{display:flex;flex-direction:column;gap:1.5rem}.session-info{padding:1rem 1.25rem;background:#1e293b80;border:2px solid rgba(255,255,255,.3);border-radius:12px}.session-info p{color:#fff;margin:.5rem 0 0}.session-info strong{color:#3b82f6}.status-indicator{display:inline-flex;align-items:center;gap:.5rem;background:#10b98126;padding:.5rem 1rem;border-radius:9999px;border:2px solid rgba(255,255,255,.3);font-size:.875rem;color:#10b981}.status-indicator .status-icon{width:16px;height:16px}.status-indicator .status-icon.connected{color:#10b981}.session-controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;padding:1rem 0}.session-controls .btn{min-width:140px}.audio-status{text-align:center;padding:.75rem;background:#0003;border-radius:8px}.audio-status .note{color:#94a3b8;font-size:.8125rem;margin:0}.transcript-container{background:#0000004d;border:2px solid rgba(255,255,255,.3);border-radius:16px;padding:1.5rem}.transcript-container h3{color:#002147;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem;text-shadow:-1px -1px 0 #ffffff,1px -1px 0 #ffffff,-1px 1px 0 #ffffff,1px 1px 0 #ffffff,0 0 2px #ffffff}.transcript-text{background:#0003;border-radius:12px;padding:1rem;min-height:150px;max-height:300px;overflow-y:auto;color:#e2e8f0;font-size:.9375rem;line-height:1.7}.transcript-text-fullscreen.transcript-text{max-height:none;min-height:0}.transcript-container-fullscreen.transcript-container{padding:0}.text-input-form{display:flex;gap:.75rem;margin-top:1rem}.text-input-form .text-input{flex:1;background:#ffffff0d;border:2px solid rgba(255,255,255,.3);border-radius:9999px;padding:.75rem 1.25rem;color:#fff;font-size:.9375rem}.text-input-form .text-input::placeholder{color:#64748b}.text-input-form .btn{width:auto;padding:.75rem 1.5rem;border-radius:9999px}.text-input-hint{margin-top:.5rem;font-size:.8125rem;color:#94a3b8;text-align:center;font-style:italic}.message{padding:.75rem 1rem;border-radius:8px;display:flex;align-items:center;gap:.5rem;font-size:.875rem}.message.warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:#fbbf24}.message.error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.video-card-container{margin-bottom:1.5rem}.video-card{background:#00000080;border:2px solid rgba(255,0,0,.3);border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000004d}.video-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem;background:#ff000026;border-bottom:1px solid rgba(255,255,255,.1)}.video-card-info{display:flex;align-items:flex-start;gap:.75rem;flex:1}.video-card-icon{color:#f44;flex-shrink:0;margin-top:.125rem}.video-card-title{font-weight:600;color:#e2e8f0;font-size:1rem;margin:0 0 .25rem}.video-card-reason{font-size:.8125rem;color:#94a3b8;font-style:italic;margin:0}.btn-close-video-card{background:#ffffff1a;border:none;border-radius:8px;padding:.5rem;color:#94a3b8;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-close-video-card:hover{background:#fff3;color:#fff}.video-card-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;background:#000}.video-card-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-card-footer{padding:.75rem 1.25rem;background:#0000004d;text-align:center;font-size:.8125rem;color:#94a3b8}.video-container{background:#0006;border:2px solid rgba(255,255,255,.3);border-radius:16px;overflow:hidden;margin-bottom:1rem}.video-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#ff00001a;border-bottom:1px solid rgba(255,255,255,.1)}.video-info{display:flex;align-items:center;gap:.5rem;color:#f44}.video-title{font-weight:500;color:#e2e8f0;font-size:.875rem}.btn-close-video{background:#ffffff1a;border:none;border-radius:8px;padding:.5rem;color:#94a3b8;cursor:pointer;transition:all .2s ease}.btn-close-video:hover{background:#fff3;color:#fff}.video-reason{padding:.5rem 1rem;font-size:.8125rem;color:#94a3b8;font-style:italic;background:#0003}.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;background:#000}.video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-security-notice{position:absolute;bottom:0;left:0;right:0;background:#000c;padding:.5rem 1rem;text-align:center;font-size:.75rem;color:#94a3b8;z-index:10;pointer-events:none}.video-results{margin-bottom:1rem}.video-results h4{color:#002147;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem;text-shadow:-1px -1px 0 #ffffff,1px -1px 0 #ffffff,-1px 1px 0 #ffffff,1px 1px 0 #ffffff,0 0 2px #ffffff}.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.video-card{background:#0000004d;border:2px solid rgba(255,255,255,.3);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s ease;text-align:left;display:flex;flex-direction:column}.video-card:hover{border-color:#f44;transform:translateY(-2px);box-shadow:0 4px 20px #ff444426}.video-thumbnail{width:100%;aspect-ratio:16/9;object-fit:cover}.video-card-title{padding:.75rem;font-size:.8125rem;color:#e2e8f0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.transcript-placeholder{color:#64748b;font-style:italic;text-align:center;padding:2rem}.transcript-entry{padding:.9rem 1.15rem;margin-bottom:.6rem;border-radius:12px;animation:fadeIn .3s ease;line-height:1.55}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.transcript-entry.user{background:#3b82f62e;border:1px solid rgba(59,130,246,.35);margin-left:10%;margin-right:0}.transcript-entry.user.streaming{border-color:#3b82f680;box-shadow:0 0 0 1px #3b82f633}.transcript-entry.ai{background:#10b9811f;border:1px solid rgba(16,185,129,.25);margin-right:10%;margin-left:0}.transcript-entry.ai.streaming{border-color:#10b98173;box-shadow:0 0 0 1px #10b98126}.speaker-label{font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:.25rem}.transcript-entry.user .speaker-label{color:#60a5fa}.transcript-entry.ai .speaker-label{color:#34d399}.entry-text{color:#e2e8f0;font-size:.9375rem;line-height:1.6}.transcript-link{color:#60a5fa;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .375rem;border-radius:4px;background:#3b82f61a;transition:all .2s ease;word-break:break-all}.transcript-link:hover{color:#93c5fd;background:#3b82f633;text-decoration:underline}.transcript-link svg{flex-shrink:0}.typing-indicator{display:inline-block;animation:blink 1s step-end infinite;color:#34d399}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.session-panels{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:stretch;min-height:50vh}@media (max-width: 1024px){.session-panels{grid-template-columns:1fr}}.session-panel{display:flex;flex-direction:column;gap:.75rem}.session-panel-video{min-height:320px}.session-panel-transcript{height:50vh;min-height:280px;max-height:50vh;display:flex;flex-direction:column;overflow:hidden}.transcript-panel-title{color:#fff;font-weight:600;font-size:.9rem;letter-spacing:.05em;text-transform:uppercase;margin:0;flex-shrink:0}.panel-title{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#e2e8f0;opacity:.9}.panel-title svg{width:14px;height:14px}.transcript-container-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.transcript-text-panel{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.session-controls.stacked{flex-direction:column;align-items:stretch;justify-content:flex-start}.session-controls.stacked .btn{width:100%}.video-card-container.full-height,.video-results.full-height{height:100%;display:flex;flex-direction:column}.video-placeholder{height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:1rem;font-size:.875rem;color:#94a3b8;background:#0003;border-radius:12px}.controls-text-input{margin-top:1rem}.controls-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.session-timer{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.timer-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.timer-value{font-family:JetBrains Mono,Courier New,monospace;font-size:.95rem;color:#e2e8f0}.safeguarding-app{max-width:1400px;margin:0 auto;padding:2rem 1.5rem 3rem}.safeguarding-header{margin-bottom:1.25rem}.safeguarding-header h1{font-size:1.75rem;color:#fff;margin-bottom:.25rem}.safeguarding-header p{color:#94a3b8}.safeguarding-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.safeguarding-status{display:flex;align-items:center;gap:.5rem;color:#cbd5e1}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.status-dot.active{background:#22c55e;box-shadow:0 0 10px #22c55e99}.status-dot.idle{background:#64748b}.updated-time{color:#94a3b8;margin-left:.5rem;font-size:.875rem}.safeguarding-table-wrap{border:2px solid rgba(255,255,255,.25);border-radius:12px;overflow:auto;background:#00000059}.safeguarding-table{width:100%;border-collapse:collapse;min-width:980px}.safeguarding-table th,.safeguarding-table td{padding:.75rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:left;color:#e2e8f0;font-size:.9rem}.safeguarding-table th{font-weight:600;color:#cbd5e1;background:#ffffff0a;position:sticky;top:0}.safeguarding-token-input{width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.25);border-radius:8px;color:#fff;padding:.5rem .625rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.safeguarding-token-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.safeguarding-remove-btn{padding:.5rem .75rem}
