@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden;background:linear-gradient(150deg,#0f0c29,#1a1040 40%,#24243e);font-family:Plus Jakarta Sans,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#f1f0ff}#root{width:100%;min-height:100%;position:relative}@keyframes neuralDrift1{0%,to{transform:translateZ(0) scale(1)}40%{transform:translate3d(50px,-70px,0) scale(1.1)}70%{transform:translate3d(-30px,35px,0) scale(.95)}}@keyframes neuralDrift2{0%,to{transform:translateZ(0) scale(1)}35%{transform:translate3d(-55px,50px,0) scale(1.07)}65%{transform:translate3d(40px,-40px,0) scale(1.04)}}@keyframes neuralDrift3{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(25px,65px,0) scale(1.09)}}.global-blob-1,.global-blob-2,.global-blob-3{position:fixed;z-index:0;pointer-events:none;will-change:transform}.global-blob-1{width:700px;height:700px;border-radius:43% 57% 60% 40%/48% 42% 58% 52%;background:radial-gradient(ellipse at 40% 40%,rgba(99,102,241,.4) 0%,rgba(67,56,202,.2) 50%,transparent 75%);bottom:120px;left:-140px;filter:blur(50px);animation:neuralDrift1 20s ease-in-out infinite}.global-blob-2{width:560px;height:560px;border-radius:60% 40% 48% 52%/38% 62%;background:radial-gradient(ellipse at 60% 40%,rgba(20,184,166,.35) 0%,rgba(6,148,162,.18) 50%,transparent 75%);right:-100px;top:20%;filter:blur(55px);animation:neuralDrift2 24s ease-in-out infinite}.global-blob-3{width:500px;height:500px;border-radius:52% 48% 36% 64%/54% 46%;background:radial-gradient(ellipse at 50% 60%,rgba(167,139,250,.3) 0%,rgba(139,92,246,.15) 50%,transparent 75%);bottom:-80px;left:20%;filter:blur(45px);animation:neuralDrift3 22s ease-in-out infinite}.auth-page{min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px 100px;position:relative;overflow:hidden;box-sizing:border-box}.auth-brand{display:flex;justify-content:center;align-items:center;width:100%;margin-bottom:28px}.auth-brand-title-container{position:relative;display:inline-block}.auth-brand-logo-only{position:absolute;right:calc(100% + 16px);top:50%;transform:translateY(-50%) translateY(3px);height:52px;width:52px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(139,92,246,.4));transition:transform .3s ease}.auth-brand-logo-only:hover{transform:translateY(-50%) translateY(3px) scale(1.08)}.auth-brand-name{font-size:38px;font-weight:800;letter-spacing:-1px;background:linear-gradient(135deg,#c4b5fd,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0;line-height:1;text-shadow:0 4px 12px rgba(167,139,250,.2)}.auth-card{position:relative;z-index:10;width:100%;max-width:440px;background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(167,139,250,.3);border-bottom:2px solid rgba(167,139,250,.4);border-radius:36px;padding:48px 44px 40px;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;box-shadow:0 32px 80px #00000080;animation:cardIn .5s ease-out}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:32px;width:100%}.auth-title{font-size:28px;font-weight:700;color:#f1f0ff;margin:0 0 8px;letter-spacing:-.3px}.auth-subtitle{font-size:14px;color:#c4b5fdbf;margin:0;font-weight:400}.auth-form{width:100%;display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:8px}.auth-label{font-size:13px;font-weight:600;color:#c4b5fde6;padding-left:12px;text-transform:uppercase;letter-spacing:.5px}.auth-input{width:100%;padding:14px 20px;border-radius:50px;border:1.5px solid rgba(167,139,250,.55);background:#ffffff1f;font-size:14px;font-weight:400;color:#f1f0ff;transition:all .2s ease;outline:none;box-sizing:border-box;box-shadow:0 2px 8px #0000001a}.auth-input::placeholder{color:#c4b5fd80}.auth-input:focus{border-color:#818cf8b3;background:#ffffff26;box-shadow:0 0 0 4px #6366f126}.auth-button{margin-top:8px;width:100%;padding:14px;border-radius:50px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #6366f159}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.auth-button:disabled{background:#ffffff1a;color:#c4b5fd66;box-shadow:none;cursor:not-allowed}.auth-error{background:#ef444426;color:#fca5a5;padding:12px 16px;border-radius:12px;font-size:13px;margin-top:16px;text-align:center;border:1px solid rgba(239,68,68,.3)}.auth-footer{margin-top:36px;font-size:14px;color:#c4b5fdcc;text-align:center}.auth-link{color:#c4b5fd;text-decoration:none;font-weight:600;margin-left:6px;transition:all .2s ease}.auth-link:hover{color:#fff;text-decoration:none;text-shadow:0 0 8px rgba(196,181,253,.6)}.auth-security-badge{position:fixed;bottom:32px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#0f0c2999;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:10px 20px;border-radius:50px;font-size:12px;font-weight:500;color:#c4b5fde6;border:1px solid rgba(167,139,250,.2);z-index:20}.auth-security-icon{font-size:14px}.chat-page{height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.chat-navbar{display:flex;justify-content:space-between;align-items:center;padding:14px 32px;background:#ffffff0a;border-bottom:1px solid rgba(167,139,250,.15);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:20;flex-shrink:0;box-shadow:0 4px 12px #0003}.chat-nav-brand{font-size:20px;font-weight:700;color:#f1f0ff;letter-spacing:-.3px}.chat-nav-right{display:flex;align-items:center;gap:16px}.chat-nav-user{font-size:14px;font-weight:500;color:#c4b5fdcc}.chat-logout-btn{padding:8px 18px;border-radius:50px;background:#ef44441f;border:1px solid rgba(239,68,68,.25);color:#fca5a5;font-size:13px;font-weight:600;transition:all .2s ease;cursor:pointer}.chat-logout-btn:hover{background:#ef444438;transform:translateY(-1px)}.chat-main-layout{flex:1;display:flex;gap:24px;padding:24px;overflow:hidden;max-width:1600px;margin:0 auto;width:100%;box-sizing:border-box;z-index:10}.chat-sidebar{display:flex;flex-direction:column;gap:20px;width:320px;flex-shrink:0}.chat-tip-card{background:#ffffff0d;border-radius:24px;padding:24px;border:1px solid rgba(167,139,250,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 32px #0003}.chat-tip-text{font-size:13px;color:#c4b5fdbf;line-height:1.7}.chat-tip-text strong{color:#c4b5fd;font-size:14px;display:block;margin-bottom:6px}.chat-section{flex:1;display:flex;flex-direction:column;min-width:0}.chat-window{flex:1;display:flex;flex-direction:column;background:#ffffff0a;border-radius:32px;border:1px solid rgba(167,139,250,.2);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);overflow:hidden;box-shadow:0 20px 60px #0006}.chat-window-header{display:flex;align-items:center;gap:14px;padding:20px 28px;background:#ffffff0a;border-bottom:1px solid rgba(167,139,250,.15);flex-shrink:0}.chat-window-header-icon{font-size:30px}.chat-window-header-title{font-size:18px;font-weight:700;color:#f1f0ff}.chat-window-header-sub{font-size:12px;font-weight:600;color:#2dd4bf}.chat-window-messages{flex:1;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin;scrollbar-color:rgba(167,139,250,.3) transparent}.chat-window-messages::-webkit-scrollbar{width:6px}.chat-window-messages::-webkit-scrollbar-track{background:transparent}.chat-window-messages::-webkit-scrollbar-thumb{background:#a78bfa4d;border-radius:10px}.chat-bubble-row{display:flex;align-items:flex-end;gap:10px;margin-bottom:8px}.chat-bubble-row-ai{justify-content:flex-start}.chat-bubble-row-user{justify-content:flex-end}.chat-bubble{max-width:65%;padding:16px 20px;border-radius:24px;line-height:1.6;position:relative}.chat-bubble-ai{background:#ffffff14;border:1px solid rgba(167,139,250,.2);color:#e8e4ff;border-bottom-left-radius:8px;box-shadow:0 4px 12px #0003}.chat-bubble-user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:8px;box-shadow:0 6px 20px #6366f159}.chat-bubble-text{font-size:14px;margin:0}.chat-bubble-meta{display:flex;justify-content:flex-end;align-items:center;gap:5px;margin-top:6px}.chat-bubble-emoji-meta{font-size:13px}.chat-bubble-time{font-size:11px;opacity:.6;font-weight:500}.chat-window-input-area{padding:20px 28px;background:#ffffff08;border-top:1px solid rgba(167,139,250,.15);flex-shrink:0}.chat-input-form{display:flex;align-items:flex-end;gap:12px;background:#ffffff12;border-radius:32px;padding:12px 16px;border:1px solid rgba(167,139,250,.25);transition:all .2s ease;box-shadow:0 4px 12px #0000001a}.chat-input-form:focus-within{background:#ffffff1a;border-color:#818cf899;box-shadow:0 0 0 3px #6366f126}.chat-input-textarea{flex:1;resize:none;border:none;font-size:14px;background:transparent;line-height:1.5;max-height:120px;padding:8px;color:#f1f0ff;outline:none}.chat-input-textarea::placeholder{color:#c4b5fd66}.chat-input-button{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;border:none;cursor:pointer;box-shadow:0 4px 14px #6366f166}.chat-input-button:hover:not(:disabled){transform:translateY(-1px) scale(1.05);box-shadow:0 6px 18px #6366f180}.chat-input-button:disabled{background:#ffffff1a;color:#c4b5fd66;box-shadow:none;cursor:not-allowed}.camera-panel{display:flex;flex-direction:column;gap:16px;background:#ffffff0a;border:1px solid rgba(167,139,250,.2);border-radius:24px;padding:20px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 32px #0003}.camera-video-wrapper{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:16px;overflow:hidden;background:#0006;border:1px solid rgba(167,139,250,.15)}.camera-video{width:100%;height:100%;object-fit:cover;display:block;border-radius:16px;transform:scaleX(-1)}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f0c29bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:16px}.camera-overlay-text{font-size:13px;color:#c4b5fdd9;font-weight:500;text-align:center;padding:0 16px}.camera-error{font-size:12px;color:#fca5a5;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:12px;padding:10px 14px;line-height:1.5}.camera-hint{font-size:12px;color:#c4b5fd8c;line-height:1.5;text-align:center}.emotion-badge{display:flex;align-items:center;gap:12px;background:#ffffff0f;border:1px solid rgba(167,139,250,.2);border-radius:16px;padding:12px 16px;transition:all .3s ease;box-shadow:0 4px 12px #0003}.emotion-badge-emoji{font-size:28px;line-height:1;flex-shrink:0}.emotion-badge-label{font-size:11px;font-weight:600;color:#c4b5fd99;text-transform:uppercase;letter-spacing:.5px}.emotion-badge-type{font-size:15px;font-weight:700;color:#f1f0ff;margin-top:2px}.emotion-badge-intensity{margin-left:auto;font-size:13px;font-weight:700;color:#a78bfa;background:#a78bfa1f;padding:4px 10px;border-radius:10px}.emotion-badge-feliz{border-color:#ffd70059}.emotion-badge-triste{border-color:#6ca0dc59}.emotion-badge-estresado{border-color:#ff6b6b59}.emotion-badge-enojado{border-color:#ff444459}.emotion-badge-ansioso{border-color:#ff8c0059}.emotion-badge-sorprendido{border-color:#9b59b659}.emotion-badge-neutral{border-color:#a78bfa33}.call-page{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-bottom:180px;box-sizing:border-box;position:relative;overflow:hidden}.call-header{position:absolute;top:40px;text-align:center;z-index:10}.call-header-title{font-size:20px;font-weight:700;color:#f1f0ff;margin:0 0 6px;letter-spacing:.5px}.call-header-subtitle{font-size:13px;color:#c4b5fdb3;font-weight:500;margin:0}.call-video-wrapper{position:relative;width:320px;height:320px;border-radius:50%;z-index:10;display:flex;align-items:center;justify-content:center;background:#0f0c2966;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:2px solid rgba(167,139,250,.3);transition:box-shadow .3s ease}@keyframes pulseAura{0%{box-shadow:0 0 #2dd4bf66}70%{box-shadow:0 0 0 40px #2dd4bf00}to{box-shadow:0 0 #2dd4bf00}}.pulsing-aura{animation:pulseAura 3s infinite;border-color:#2dd4bf99}.call-video-circle{width:100%;height:100%;border-radius:50%;object-fit:cover;transform:scaleX(-1)}.call-video-off-placeholder{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff08}.call-video-off-icon{font-size:80px;opacity:.2}.call-hide-camera-btn{position:absolute;top:15px;right:15px;width:36px;height:36px;border-radius:50%;background:#0f0c2999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(167,139,250,.3);color:#f1f0ff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:20}.call-hide-camera-btn:hover{background:#0f0c29cc;transform:scale(1.05)}.call-controls-wrapper{position:absolute;bottom:40px;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px;z-index:15}.call-dock{display:flex;align-items:center;gap:16px;background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(167,139,250,.3);border-radius:50px;padding:14px 24px;box-shadow:0 16px 40px #0000004d}.call-dock-btn{display:flex;align-items:center;justify-content:center;gap:8px;border:none;background:#ffffff14;border:1px solid rgba(167,139,250,.2);color:#f1f0ff;cursor:pointer;transition:all .2s ease}.call-dock-btn:not(.secondary-action):not(.end-call){width:48px;height:48px;border-radius:50%}.call-dock-btn.secondary-action,.call-dock-btn.end-call{padding:12px 20px;border-radius:50px}.call-dock-btn:hover{background:#ffffff26;transform:translateY(-2px)}.call-dock-btn.muted{background:#ef444433;border-color:#ef444466;color:#ef4444}.call-dock-btn.end-call{background:#ef4444;border-color:#dc2626;color:#fff;font-weight:600}.call-dock-btn.end-call:hover{background:#dc2626;box-shadow:0 6px 20px #ef444466}.call-emotion-badge{position:absolute;bottom:20px;right:20px;background:#8661c5cc;color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);z-index:20}.call-action-area{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px}.call-ptt-container{display:flex;justify-content:center;width:100%}.call-ptt-btn{display:flex;align-items:center;gap:12px;background:#8b5cf633;border:1px solid rgba(139,92,246,.5);color:#fff;padding:16px 32px;border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 24px #8b5cf633}.call-ptt-btn:hover:not(.disabled){background:#8b5cf666;transform:translateY(-2px);box-shadow:0 12px 32px #8b5cf64d}.call-ptt-btn.listening{background:#ef44444d;border-color:#ef444499;box-shadow:0 0 20px #ef444466;animation:pulseRecording 1.5s infinite}.call-ptt-btn.disabled{opacity:.5;cursor:not-allowed}@keyframes pulseRecording{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 15px #ef444400}to{box-shadow:0 0 #ef444400}}.call-ai-subtitle{position:relative;max-width:80%;text-align:center;color:#fff;font-size:18px;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,.5);background:#0000004d;padding:10px 20px;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease}.btn-icon{font-size:18px;line-height:1}.btn-text{font-size:14px;font-weight:500}.chat-layout-wrapper{display:flex;height:100vh;width:100%;overflow:hidden;background:#f4f5f9}.chat-sidebar-dark{width:380px;background:#312652;color:#fff;display:flex;flex-direction:column;flex-shrink:0;box-shadow:2px 0 20px #0000001a;z-index:10;position:relative;overflow:hidden}.chat-sidebar-dark:before{content:"";position:absolute;top:-150px;left:-150px;width:400px;height:400px;background:radial-gradient(circle,rgba(134,97,197,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:32px 32px 24px}.sidebar-brand-logo-img{width:52px;height:52px;object-fit:contain;border-radius:12px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.15))}.sidebar-brand-icon{width:42px;height:42px;background:linear-gradient(135deg,#7c4dff,#ff4081);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.sidebar-brand-text h1{font-size:20px;font-weight:700;margin:0 0 2px;letter-spacing:-.5px}.sidebar-brand-text p{font-size:11px;color:#fff9;margin:0;letter-spacing:.5px}.sidebar-scroll-area{flex:1;overflow-y:auto;padding:0 32px 40px;display:flex;flex-direction:column;gap:24px}.sidebar-scroll-area::-webkit-scrollbar{width:4px}.sidebar-scroll-area::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.sidebar-camera-section{width:100%;min-height:240px;background:#00000026;border-radius:16px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}.sidebar-camera-section .camera-panel{padding:0;background:transparent;border:none;box-shadow:none;width:100%;height:100%}.sidebar-camera-section .camera-video-wrapper{height:100%;min-height:200px;max-height:220px;border-radius:12px}.sidebar-camera-section video.camera-video{height:100%;object-fit:cover}.sidebar-camera-section .emotion-badge,.sidebar-camera-section .camera-hint{display:none!important}.sidebar-therapist-info{border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:24px}.sidebar-therapist-info h2{font-size:22px;font-weight:700;margin:0 0 6px}.sidebar-therapist-info p{font-size:13px;color:#ffffffb3;line-height:1.4;margin:0}.sidebar-section-title{font-size:11px;color:#ffffff80;letter-spacing:1px;text-transform:uppercase;margin:0 0 12px}.emotion-display-card{background:#00000026;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px;margin-bottom:12px}.emotion-display-icon{font-size:24px;width:48px;height:48px;background:#ffffff0d;border-radius:10px;display:flex;align-items:center;justify-content:center}.emotion-display-text{display:flex;flex-direction:column}.emotion-name{font-size:16px;font-weight:700;color:#fff}.emotion-sub{font-size:12px;color:#ffffff80}.emotion-help-text{font-size:13px;color:#fff9;line-height:1.5}.sidebar-tip-card{background:#ffffff0d;border-radius:8px;padding:14px 16px;font-size:13px;display:flex;align-items:center;gap:12px}.tip-icon{font-size:18px;opacity:.8}.sidebar-footer{padding:24px 32px;border-top:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:12px}.sidebar-action-btn{width:100%;padding:12px;border-radius:8px;background:#ffffff1a;color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.sidebar-action-btn:hover{background:#ffffff26}.sidebar-logout-btn{background:transparent;border:1px solid rgba(255,255,255,.2)}.sidebar-logout-btn:hover{background:#ffffff0d}.chat-main-light{flex:1;background:#f8f9fa;display:flex;flex-direction:column;position:relative}.light-cw-root{flex:1;display:flex;flex-direction:column;height:100%}.light-cw-header{display:flex;justify-content:space-between;align-items:center;padding:24px 40px;background:#fff;border-bottom:1px solid #eaeaea}.light-cw-header-left{display:flex;align-items:center;gap:16px}.light-cw-avatar-circle{width:48px;height:48px;background:#5b809a;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600}.light-cw-header-info h2{font-size:18px;font-weight:700;color:#333;margin:0 0 4px}.light-cw-header-info p{font-size:13px;color:#10b981;margin:0;display:flex;align-items:center;gap:6px}.status-dot-green{width:8px;height:8px;background:#10b981;border-radius:50%}.light-cw-header-actions{display:flex;gap:12px}.light-header-btn{width:40px;height:40px;border-radius:10px;background:#fff;border:1px solid #eaeaea;box-shadow:0 2px 8px #00000005;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:16px}.light-header-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.light-timeline-divider{text-align:center;position:relative;margin:32px 40px}.light-timeline-divider:before{content:"";position:absolute;top:50%;left:0;right:0;border-top:1px solid #e2e8f0;z-index:1}.light-timeline-divider span{position:relative;z-index:2;background:#f8f9fa;padding:0 16px;font-size:11px;font-weight:600;color:#94a3b8;letter-spacing:1px}.light-cw-messages{flex:1;overflow-y:auto;padding:0 40px 24px;display:flex;flex-direction:column;gap:24px}.light-bubble-row{display:flex;align-items:flex-end;gap:16px;width:100%}.light-bubble-row-ai{justify-content:flex-start}.light-bubble-row-user{justify-content:flex-end}.light-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.light-avatar-ai{background:#5b809a}.light-avatar-user{background:#e2e8f0;color:#64748b}.light-bubble-content-wrapper{display:flex;flex-direction:column;max-width:70%}.wrapper-ai{align-items:flex-start}.wrapper-user{align-items:flex-end}.light-bubble{padding:16px 20px;border-radius:16px;font-size:15px;line-height:1.5}.light-bubble-ai{background:#fff;color:#334155;border-bottom-left-radius:4px;box-shadow:0 2px 12px #00000008;border:1px solid rgba(0,0,0,.02)}.light-bubble-user{background:#8661c5;color:#fff;border-bottom-right-radius:4px}.light-bubble-text{margin:0;white-space:pre-wrap}.light-bubble-time{font-size:11px;color:#94a3b8;margin-top:6px}.time-left{align-self:flex-start}.time-right{align-self:flex-end}.light-typing-indicator{display:flex;align-items:flex-end;gap:16px;animation:fadeIn .3s ease}.light-typing-bubble{background:#fff;padding:16px 20px;border-radius:16px 16px 16px 4px;box-shadow:0 2px 12px #00000008;display:flex;align-items:center;gap:4px;height:48px}.light-typing-bubble span{width:6px;height:6px;background:#cbd5e1;border-radius:50%;animation:lightPulse 1.4s infinite ease-in-out both}.light-typing-bubble span:nth-child(1){animation-delay:-.32s}.light-typing-bubble span:nth-child(2){animation-delay:-.16s}@keyframes lightPulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.light-cw-footer{padding:24px 40px 32px;background:transparent}.light-input-container{display:flex;flex-direction:column;gap:12px}.light-input-form{background:#fff;border-radius:24px;padding:8px 16px;display:flex;align-items:flex-end;box-shadow:0 4px 20px #00000008;border:1px solid #eaeaea;transition:all .2s}.light-input-form:focus-within{border-color:#8661c5;box-shadow:0 4px 20px #8661c51a}.light-textarea{flex:1;border:none;background:transparent;padding:12px 0;font-size:15px;color:#334155;resize:none;outline:none;font-family:inherit}.light-textarea::placeholder{color:#94a3b8}.light-input-actions{display:flex;align-items:center;gap:8px;padding-bottom:4px}.light-icon-btn{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:color .2s}.light-icon-btn:hover{color:#64748b}.light-icon-btn.recording{color:#ef4444;animation:lightPulse 1.5s infinite}.light-send-btn{width:40px;height:40px;border-radius:50%;background:#f1f5f9;border:none;color:#cbd5e1;display:flex;align-items:center;justify-content:center;cursor:not-allowed;transition:all .2s}.light-send-btn.ready{background:#8661c5;color:#fff;cursor:pointer}.light-send-btn.ready:hover{transform:scale(1.05)}.security-badge-inline{text-align:center;font-size:12px;color:#94a3b8;font-weight:500}.custom-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#08061ebf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.custom-modal-content{background:#fff;width:90%;max-width:520px;max-height:85vh;border-radius:20px;box-shadow:0 20px 40px #0003;overflow:hidden;display:flex;flex-direction:column;animation:cardIn .3s ease-out}.glass-modal{background:#120e32d9!important;border:1px solid rgba(139,92,246,.35);border-bottom:2px solid rgba(139,92,246,.5);box-shadow:0 32px 80px #0009,0 0 0 1px #8b5cf61a}.custom-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eaeaea;background:#f8f9fa;flex-shrink:0}.glass-modal-header{background:#ffffff08!important;border-bottom:1px solid rgba(139,92,246,.2)!important}.glass-modal-header h3{color:#f1f0ff!important;font-size:18px;font-weight:700;margin:0}.custom-modal-header h3{margin:0;font-size:18px;font-weight:700;color:#333}.close-modal-btn{background:transparent;border:none;font-size:16px;color:#c4b5fdb3;cursor:pointer;transition:color .2s;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}.close-modal-btn:hover{color:#ef4444;background:#ef44441a}.custom-modal-body{padding:24px;background:#fff;overflow-y:auto;flex:1}.glass-modal-body{background:transparent!important;padding:20px 24px 28px!important}.glass-textarea{background:#ffffff0f!important;border:1px solid rgba(139,92,246,.3)!important;color:#e8e4ff!important;border-radius:12px!important;resize:none;width:100%;padding:16px;font-family:inherit;font-size:14px;outline:none;transition:border-color .2s}.glass-textarea::placeholder{color:#c4b5fd66}.glass-textarea:focus{border-color:#8b5cf699!important;box-shadow:0 0 0 3px #8b5cf61a}.modal-history-container{display:flex;flex-direction:column;gap:12px}.hist-subtitle{font-size:12px;color:#c4b5fd99;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin:0 0 8px}.glass-history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;max-height:380px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.3) transparent}.glass-history-list::-webkit-scrollbar{width:4px}.glass-history-list::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:4px}.glass-history-item{background:#ffffff0a;border:1px solid rgba(139,92,246,.15);border-radius:14px;padding:14px 16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;gap:12px}.glass-history-item:hover{background:#8b5cf61f;border-color:#8b5cf666;transform:translate(2px)}.hist-item-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.hist-item-info{display:flex;flex-direction:column;gap:3px;min-width:0}.hist-item-date{font-size:14px;font-weight:600;color:#f1f0ff}.hist-item-meta{font-size:12px;color:#c4b5fda6}.hist-status.status-active{color:#2dd4bf;font-weight:600}.hist-status.status-done{color:#c4b5fd99}.hist-item-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.hist-chevron{font-size:20px;color:#8b5cf699;transition:transform .2s}.glass-history-item:hover .hist-chevron{transform:translate(3px);color:#a78bfa}.hist-tipo-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap;letter-spacing:.3px;flex-shrink:0}.badge-texto{background:#6366f133;color:#818cf8;border:1px solid rgba(99,102,241,.3)}.badge-video{background:#ec489933;color:#f472b6;border:1px solid rgba(236,72,153,.3)}.delete-session-btn{background:transparent;border:none;font-size:14px;cursor:pointer;padding:6px 8px;border-radius:8px;opacity:.5;transition:all .2s}.delete-session-btn:hover{opacity:1;background:#ef444426;transform:scale(1.1)}.hist-session-detail{display:flex;flex-direction:column;gap:16px}.hist-back-btn{background:#8b5cf61a;border:1px solid rgba(139,92,246,.25);color:#a78bfa;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;width:fit-content;transition:all .2s}.hist-back-btn:hover{background:#8b5cf633;border-color:#8b5cf680}.hist-session-detail-header{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(139,92,246,.15)}.hist-detail-date{font-size:15px;font-weight:600;color:#f1f0ff;flex:1}.hist-detail-count{font-size:12px;color:#c4b5fd99}.hist-messages-list{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.3) transparent;padding-right:4px}.hist-messages-list::-webkit-scrollbar{width:4px}.hist-messages-list::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:4px}.hist-msg-item{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:12px}.hist-msg-ai{background:#ffffff0a;border:1px solid rgba(139,92,246,.1);align-items:flex-start}.hist-msg-user{background:#6366f11f;border:1px solid rgba(99,102,241,.2);align-items:flex-end}.hist-msg-sender{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#c4b5fd99}.hist-msg-text{font-size:14px;color:#e8e4ff;margin:0;line-height:1.5;white-space:pre-wrap}.hist-msg-time{font-size:11px;color:#c4b5fd66}.hist-empty{text-align:center;padding:40px 20px;display:flex;flex-direction:column;align-items:center;gap:8px}.hist-empty-icon{font-size:40px;margin-bottom:8px}.hist-empty p{color:#c4b5fd99;font-size:14px;margin:0}.hist-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0;color:#c4b5fdb3;font-size:14px}.hist-spinner{width:28px;height:28px;border:3px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-history-message{text-align:center;color:#c4b5fd99;margin-top:10px;font-size:14px}.glass-setting-label{display:flex;align-items:center;gap:12px;font-size:14px;color:#c4b5fde6!important;cursor:pointer;padding:12px 16px;border-radius:10px;border:1px solid rgba(139,92,246,.1);background:#ffffff08;transition:all .2s}.glass-setting-label:hover{background:#8b5cf614;border-color:#8b5cf640}.glass-setting-label input[type=checkbox]{width:18px;height:18px;accent-color:#8b5cf6}.modal-settings{display:flex;flex-direction:column;gap:10px}.save-settings-btn{margin-top:16px;width:100%;padding:14px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-weight:600;border:none;cursor:pointer;transition:all .2s;font-size:14px}.save-settings-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f159}.new-session-btn{background:#6366f114!important;border-color:#6366f140!important;color:#6366f1!important}.new-session-btn:hover{background:#6366f12e!important;border-color:#6366f180!important;color:#818cf8!important}.hidden-file-input{display:none}.session-start-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.session-start-card{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);padding:40px;border-radius:24px;text-align:center;max-width:460px;box-shadow:0 20px 40px #0006}.session-start-icon{font-size:48px;margin-bottom:20px}.session-start-logo{width:110px;height:110px;object-fit:contain;margin-bottom:20px;filter:drop-shadow(0 4px 12px rgba(139,92,246,.35));border-radius:16px}.session-start-card h2{color:#fff;margin-bottom:15px}.session-start-card p{color:#ffffffb3;margin-bottom:30px}.session-start-btn{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;padding:15px 40px;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 20px #6366f14d}.session-start-btn:hover{transform:translateY(-2px);box-shadow:0 15px 30px #6366f180}.chat-main-light.dark-mode{background:#0d0b1f}.dark-mode .light-cw-root{background:transparent}.dark-mode .light-cw-header{background:#120e32f2;border-bottom:1px solid rgba(139,92,246,.2)}.dark-mode .light-cw-header-info h2{color:#f1f0ff}.dark-mode .light-cw-header-info p{color:#2dd4bf}.dark-mode .light-header-btn{background:#ffffff0f;border-color:#8b5cf640}.dark-mode .light-header-btn:hover{background:#8b5cf626;border-color:#8b5cf680}.dark-mode .light-cw-avatar-circle{background:linear-gradient(135deg,#5b5fcf,#8b5cf6)}.dark-mode .light-timeline-divider span{background:#0d0b1f;color:#c4b5fd80}.dark-mode .light-timeline-divider:before{border-color:#8b5cf633}.dark-mode .light-cw-messages{background:transparent}.dark-mode .light-bubble-ai{background:#ffffff0d;border:1px solid rgba(139,92,246,.2);color:#e8e4ff;box-shadow:0 4px 12px #0000004d}.dark-mode .light-bubble-user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.dark-mode .light-bubble-time{color:#c4b5fd73}.dark-mode .light-avatar-ai{background:linear-gradient(135deg,#5b5fcf,#8b5cf6)}.dark-mode .light-avatar-user{background:#ffffff1a;color:#c4b5fdcc}.dark-mode .light-typing-bubble{background:#ffffff0d;border-color:#8b5cf633}.dark-mode .light-typing-dot{background:#c4b5fd}.dark-mode .light-cw-input-area{background:#120e32f2;border-top:1px solid rgba(139,92,246,.2)}.dark-mode .light-input-form{background:#ffffff0d;border-color:#8b5cf64d}.dark-mode .light-input-form:focus-within{background:#ffffff14;border-color:#8b5cf699;box-shadow:0 0 0 3px #8b5cf626}.dark-mode .light-input-textarea{color:#f1f0ff}.dark-mode .light-input-textarea::placeholder{color:#c4b5fd80}.dark-mode .light-input-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.dark-mode .light-input-button:disabled{background:#ffffff1a;color:#c4b5fd66}.custom-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);background:#120e32e6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(139,92,246,.4);color:#f1f0ff;padding:14px 24px;border-radius:100px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;box-shadow:0 10px 30px #0006,0 0 20px #8b5cf633;z-index:99999;animation:toastSlideUp .3s cubic-bezier(.175,.885,.32,1.275) forwards}.custom-toast.toast-success{border-color:#2dd4bf66;box-shadow:0 10px 30px #0006,0 0 20px #2dd4bf26}.custom-toast.toast-error{border-color:#ef444466;box-shadow:0 10px 30px #0006,0 0 20px #ef444426}.toast-icon{font-size:18px;line-height:1}@keyframes toastSlideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.mode-selection-container{display:flex;flex-direction:column;gap:16px;margin:20px 0 32px;width:100%}.mode-select-card{width:100%;background:#ffffff0a;border:1px solid rgba(167,139,250,.2);border-radius:20px;padding:20px 24px;display:flex;flex-direction:row;align-items:center;text-align:left;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);color:#f1f0ff;outline:none;gap:20px}.mode-select-card:hover{background:#ffffff14;border-color:#a78bfa66;transform:translateY(-3px);box-shadow:0 10px 20px #0003}.mode-select-card.active{background:linear-gradient(135deg,#8b5cf626,#6366f126);border-color:#8b5cf6b3;box-shadow:0 0 24px #8b5cf64d;transform:translateY(-2px)}.mode-card-icon{font-size:36px;margin-bottom:0;display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:#ffffff0d;border-radius:16px;flex-shrink:0;box-shadow:inset 0 2px 10px #0003}.mode-select-card.active .mode-card-icon{background:#8b5cf633;box-shadow:inset 0 2px 10px #8b5cf64d}.mode-card-text{display:flex;flex-direction:column}.mode-card-text h3{font-size:16px;font-weight:700;margin:0 0 6px;color:#fff;letter-spacing:.3px}.mode-card-text p{color:#c4b5fdb3;line-height:1.4;margin:0}.call-ptt-container{position:relative;display:flex;justify-content:center;width:100%}.call-ptt-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:1px solid rgba(255,255,255,.1);color:#fff;padding:14px 28px;border-radius:50px;font-size:15px;font-weight:700;display:flex;align-items:center;gap:10px;cursor:pointer;box-shadow:0 8px 24px #6366f159;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.call-ptt-btn:hover:not(.disabled):not(:disabled){transform:translateY(-2px) scale(1.03);box-shadow:0 12px 30px #6366f180;background:linear-gradient(135deg,#4f46e5,#7c3aed)}.call-ptt-btn.listening{background:linear-gradient(135deg,#ef4444,#f43f5e);box-shadow:0 0 25px #ef444499;animation:pttPulse 1.8s infinite}.call-ptt-btn.disabled,.call-ptt-btn:disabled{background:#ffffff0d!important;color:#ffffff4d!important;border-color:#ffffff0d!important;box-shadow:none!important;cursor:not-allowed;transform:none!important}.call-ptt-btn.disabled .ptt-icon,.call-ptt-btn:disabled .ptt-icon{opacity:.5}@keyframes pttPulse{0%{box-shadow:0 0 #ef444480}70%{box-shadow:0 0 0 15px #ef444400}to{box-shadow:0 0 #ef444400}}.call-dock-btn.active-mode{background:#8b5cf640;border-color:#8b5cf680;box-shadow:0 0 12px #8b5cf633}
