@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}.memories-page{min-height:100vh;width:100%;display:flex;flex-direction:column;position:relative;overflow-y:auto;box-sizing:border-box}.memories-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:40px 24px;z-index:10;position:relative}.memories-header-actions{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px}.memories-title{font-size:36px;font-weight:800;color:#fff;margin:0 0 8px}.memories-subtitle{font-size:16px;color:#c4b5fdbf;margin:0}.memories-add-btn{padding:12px 24px;border-radius:50px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:15px;font-weight:600;border:none;cursor:pointer;box-shadow:0 8px 24px #6366f14d;transition:all .3s ease}.memories-add-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #6366f166}.memories-back-btn{padding:8px 16px;border-radius:50px;background:#ffffff0d;border:1px solid rgba(167,139,250,.2);color:#c4b5fde6;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.memories-back-btn:hover{background:#ffffff1a;color:#fff}.memories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.memories-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;background:#ffffff08;border-radius:24px;border:1px dashed rgba(167,139,250,.3);text-align:center}.memories-empty-icon{font-size:64px;margin-bottom:24px;opacity:.8}.memories-empty h3{font-size:24px;font-weight:700;color:#f1f0ff;margin:0 0 12px}.memories-empty p{color:#c4b5fdb3;margin:0 0 32px;max-width:400px;line-height:1.6}.memory-card{background:#ffffff0d;border-radius:20px;padding:24px;border:1px solid rgba(167,139,250,.15);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all .3s ease;display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.memory-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:#a78bfa80;border-radius:4px 0 0 4px}.memory-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000004d;border-color:#a78bfa4d}.memory-card-header{display:flex;justify-content:space-between;align-items:center}.memory-emotion-badge{display:flex;align-items:center;gap:8px;background:#ffffff0f;padding:6px 12px;border-radius:50px}.memory-emoji{font-size:16px}.memory-label{font-size:12px;font-weight:600;color:#e8e4ff;letter-spacing:.5px;text-transform:uppercase}.memory-date{font-size:12px;color:#c4b5fd99}.memory-text{font-size:15px;color:#f1f0ff;line-height:1.6;margin:0;white-space:pre-wrap}.emotion-happy:before{background:gold}.emotion-sad:before{background:#6ca0dc}.emotion-stressed:before{background:#ff6b6b}.emotion-angry:before{background:#f44}.emotion-anxious:before{background:#ff8c00}.emotion-surprised:before{background:#9b59b6}.emotion-neutral:before{background:#a78bfa}.memory-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0c29cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.memory-modal-content{background:#1e1938f2;border:1px solid rgba(167,139,250,.3);border-radius:28px;padding:40px;width:100%;max-width:600px;position:relative;box-shadow:0 24px 64px #00000080;animation:cardIn .3s ease-out}.memory-modal-close{position:absolute;top:24px;right:24px;background:transparent;border:none;color:#c4b5fdb3;font-size:28px;cursor:pointer;transition:color .2s;line-height:1}.memory-modal-close:hover{color:#fff}.memory-modal-title{font-size:28px;font-weight:800;color:#fff;margin:0 0 8px}.memory-modal-subtitle{font-size:15px;color:#c4b5fdcc;margin:0 0 32px}.memory-form{display:flex;flex-direction:column;gap:24px}.memory-textarea{width:100%;background:#0003;border:1px solid rgba(167,139,250,.2);border-radius:16px;padding:20px;color:#f1f0ff;font-family:inherit;font-size:15px;line-height:1.6;resize:vertical;min-height:120px;outline:none;transition:all .2s}.memory-textarea:focus{border-color:#a78bfa99;background:#0000004d}.memory-emotion-selector{display:flex;flex-direction:column;gap:12px}.emotion-selector-title{font-size:14px;font-weight:600;color:#c4b5fde6;margin:0}.emotion-options{display:flex;gap:12px;flex-wrap:wrap}.emotion-option-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:50px;background:#ffffff0d;border:1px solid rgba(167,139,250,.2);color:#c4b5fdcc;cursor:pointer;transition:all .2s ease}.emotion-option-btn:hover{background:#ffffff1a}.emotion-option-btn.selected{background:#a78bfa40;border-color:#a78bfa99;color:#fff;box-shadow:0 0 20px #a78bfa33}.emotion-option-emoji{font-size:18px}.emotion-option-label{font-size:13px;font-weight:600}.memory-form-actions{display:flex;justify-content:flex-end;gap:16px;margin-top:16px}.memory-btn-cancel{padding:12px 24px;border-radius:50px;background:transparent;color:#c4b5fde6;border:1px solid rgba(167,139,250,.3);font-weight:600;cursor:pointer;transition:all .2s}.memory-btn-cancel:hover{background:#ffffff0d;color:#fff}.memory-btn-save{padding:12px 32px;border-radius:50px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;font-weight:600;cursor:pointer;box-shadow:0 8px 24px #6366f14d;transition:all .3s}.memory-btn-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #6366f166}.memory-btn-save:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.dash-app-layout{display:flex;flex-direction:column;min-height:100vh;width:100%;background:radial-gradient(circle at bottom right,#2dd4bf26,#10101b 40%,#0d0b1a);color:#fff;font-family:Inter,system-ui,sans-serif;overflow:hidden}.dash-top-nav{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 24px;border-bottom:1px solid rgba(255,255,255,.05);background:#0f0c1e99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:50}.dash-nav-brand{display:flex;align-items:center;gap:12px}.dash-logo-icon{font-size:24px;filter:drop-shadow(0 0 8px rgba(167,139,250,.6))}.dash-logo-text{font-size:16px;font-weight:700;letter-spacing:.5px}.dash-nav-profile{display:flex;align-items:center;gap:16px;font-size:14px}.dash-nav-greeting{color:#ffffffb3}.dash-nav-logout{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:6px 16px;border-radius:6px;cursor:pointer;transition:all .2s}.dash-nav-logout:hover{background:#ef444433;border-color:#ef444466}.dash-body{display:flex;flex:1;overflow:hidden}.dash-sidebar{width:80px;display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 0;border-right:1px solid rgba(255,255,255,.05);background:#0f0c1e66;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.dash-side-item{display:flex;flex-direction:column;align-items:center;gap:6px;color:#ffffff80;cursor:pointer;transition:all .2s;width:100%;padding:12px 0;position:relative}.dash-side-item:hover:not(.disabled){color:#fff}.dash-side-item.active{color:#fff;background:#ffffff0d}.dash-side-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:32px;width:3px;background:#a78bfa;border-radius:0 4px 4px 0}.dash-side-item.disabled{opacity:.3;cursor:not-allowed}.side-icon{font-size:22px}.side-label{font-size:11px;font-weight:500}.dash-content-area{flex:1;overflow-y:auto;padding:40px}.dash-content-inner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.dash-page-header{margin-bottom:8px}.dash-page-title{font-size:28px;font-weight:700;margin:0 0 8px}.dash-page-subtitle{font-size:14px;color:#fff9;margin:0}.dash-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.dash-stat-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;position:relative;box-shadow:inset 0 2px 10px #ffffff05}.shadow-icon{font-size:32px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}.stat-card-info{display:flex;flex-direction:column;gap:4px}.stat-card-val{font-size:28px;font-weight:700;line-height:1}.stat-card-lbl{font-size:13px;color:#fff9}.stat-card-badge{position:absolute;top:20px;right:20px;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.blue-badge{background:#3b82f633;color:#60a5fa}.red-badge{background:#ef444433;color:#f87171}.green-badge{background:#22c55e33;color:#4ade80}.dash-alert-bar{display:flex;align-items:center;gap:12px;background:#facc150d;border:1px solid rgba(250,204,21,.3);padding:14px 20px;border-radius:12px}.alert-bulb{font-size:18px;filter:drop-shadow(0 2px 4px rgba(250,204,21,.5))}.alert-msg{font-size:14px;color:#fef08a}.dash-middle-row{display:grid;grid-template-columns:3fr 2fr;gap:20px}.dash-panel{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px}.panel-title{font-size:16px;font-weight:600;margin:0 0 20px;color:#fff}.chart-container{display:flex;gap:16px;height:160px}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;font-size:11px;color:#fff6;padding-bottom:20px}.chart-graph-area{flex:1;position:relative}.chart-grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;padding-bottom:20px}.chart-grid-lines div{height:1px;background:#ffffff0d;width:100%}.chart-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:calc(100% - 20px)}.chart-x-axis{position:absolute;bottom:0;left:0;width:100%;display:flex;justify-content:space-between;font-size:11px;color:#fff6}.summary-header{display:flex;justify-content:space-between;align-items:center}.summary-icon{font-size:20px;margin-top:-20px}.summary-list{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:12px}.summary-list li{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#fffc}.summary-list strong{color:#fff;font-weight:600}.list-dots{color:#ffffff4d;letter-spacing:2px}.summary-footer-text{font-size:12px;color:#ffffff80;line-height:1.5;margin:0}.dash-actions-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.dash-action-box{background:#a78bfa1a;border:1px solid rgba(167,139,250,.2);border-radius:16px;padding:24px;display:flex;align-items:center;gap:20px;cursor:pointer;transition:all .3s}.dash-action-box:hover{background:#a78bfa26;transform:translateY(-4px);box-shadow:0 8px 24px #a78bfa1a}.action-box-icon{font-size:40px}.action-box-info h4{font-size:16px;font-weight:700;margin:0 0 4px;color:#fff}.action-box-info p{font-size:12px;color:#fff9;margin:0;line-height:1.4}.dash-footer{display:flex;justify-content:space-between;align-items:center;padding-top:40px;font-size:11px;color:#fff6}.footer-right{display:flex;align-items:center;gap:8px}.footer-star{font-size:16px;filter:drop-shadow(0 0 8px rgba(255,255,255,.5))}.profile-grid{display:grid;grid-template-columns:350px 1fr;gap:32px;width:100%;max-width:1200px;margin:0 auto}@media (max-width: 900px){.profile-grid{grid-template-columns:1fr}}.profile-info-panel{padding:0;overflow:hidden;display:flex;flex-direction:column}.profile-banner{height:120px;width:100%;background:linear-gradient(135deg,#a855f766,#6366f166);position:relative}.profile-banner:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.15}.profile-avatar-wrapper{margin-top:-50px;display:flex;flex-direction:column;align-items:center;padding:0 24px 24px}.profile-avatar-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#6366f1);display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;color:#fff;box-shadow:0 8px 32px #a855f780;border:4px solid #0f0c29;position:relative;z-index:2}.profile-avatar-text{text-align:center;margin-top:16px;width:100%}.profile-avatar-text h2{font-size:24px;font-weight:700;color:#fff;margin:0 0 4px}.profile-avatar-text p{color:#ffffff80;font-size:14px;margin:0 0 24px}.profile-details-list{background:#ffffff08;border-radius:12px;padding:16px;width:100%;border:1px solid rgba(255,255,255,.05)}.profile-detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{color:#fff9;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.emotion-badge{background:#2dd4bf26;color:#2dd4bf;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;border:1px solid rgba(45,212,191,.3);box-shadow:0 0 10px #2dd4bf33}.profile-read-only-note{font-size:12px;color:#ffffff4d;margin-top:24px;text-align:center;padding:0 16px}.profile-right-column{display:flex;flex-direction:column;gap:24px}.profile-prefs-panel,.profile-danger-panel{padding:32px}.panel-title{font-size:20px;font-weight:600;color:#fff;margin:0 0 24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08)}.pref-item{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;margin-bottom:16px;transition:all .3s ease}.pref-item:hover{background:#ffffff0a;border-color:#a855f74d;transform:translate(4px)}.pref-info-wrapper{display:flex;align-items:center;gap:16px}.pref-icon{font-size:24px;background:#ffffff0d;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px}.pref-info h4{font-size:15px;font-weight:600;color:#fff;margin:0 0 4px}.pref-info p{font-size:13px;color:#ffffff80;margin:0}.pref-switch{position:relative;display:inline-block;width:52px;height:28px}.pref-switch input{opacity:0;width:0;height:0}.pref-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ffffff1a;transition:.4s cubic-bezier(.4,0,.2,1);border-radius:34px}.pref-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s cubic-bezier(.4,0,.2,1);border-radius:50%;box-shadow:0 2px 4px #0003}input:checked+.pref-slider{background:linear-gradient(135deg,#a855f7,#6366f1)}input:checked+.pref-slider:before{transform:translate(24px)}.save-prefs-btn{background:linear-gradient(135deg,#a855f7,#6366f1);color:#fff;border:none;padding:16px 32px;border-radius:12px;font-weight:600;font-size:15px;cursor:pointer;margin-top:16px;width:100%;transition:all .3s;box-shadow:0 8px 24px #a855f74d;display:flex;align-items:center;justify-content:center;gap:8px}.save-prefs-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #a855f766}.save-prefs-btn:disabled{background:#ffffff1a;color:#ffffff4d;box-shadow:none;cursor:not-allowed}.profile-danger-panel{border:1px solid rgba(239,68,68,.2);background:linear-gradient(180deg,#ef444405,#0f0c1ecc)}.danger-title{color:#ef4444;display:flex;align-items:center;gap:12px}.danger-action-row{display:flex;justify-content:space-between;align-items:center;padding:24px;background:#0003;border-radius:12px;margin-bottom:16px;border:1px solid rgba(239,68,68,.1)}.danger-action-row:last-child{margin-bottom:0}.danger-action-info h4{color:#fff;font-size:16px;margin:0 0 6px;font-weight:600}.danger-action-info p{color:#ffffff80;font-size:13px;margin:0;max-width:400px;line-height:1.5}.danger-btn{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap}.danger-btn:hover:not(:disabled){background:#ef444433;transform:translateY(-1px);box-shadow:0 4px 12px #ef444433}.danger-btn.disabled{background:transparent;color:#fff3;border:1px dashed rgba(255,255,255,.1);cursor:not-allowed}
