*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.static{position:static}.absolute{position:absolute}.relative{position:relative}.z-10{z-index:10}.mx-auto{margin-left:auto;margin-right:auto}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1\.5{margin-left:.375rem}.ml-auto{margin-left:auto}.mr-2\.5{margin-right:.625rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-video{aspect-ratio:16 / 9}.h-10{height:2.5rem}.h-12{height:3rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-4{height:1rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-full{height:100%}.min-h-0{min-height:0px}.min-h-full{min-height:100%}.w-10{width:2.5rem}.w-12{width:3rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-4{width:1rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-full{width:100%}.min-w-0{min-width:0px}.max-w-2xl{max-width:42rem}.max-w-5xl{max-width:64rem}.max-w-\[88\%\]{max-width:88%}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.resize-none{resize:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t-transparent{border-top-color:transparent}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.object-cover{-o-object-fit:cover;object-fit:cover}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pr-1{padding-right:.25rem}.pt-2{padding-top:.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[10px\]{font-size:10px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.sepia{--tw-sepia: sepia(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--emotion-color: #888780;--emotion-color-soft: rgba(136, 135, 128, .1);--emotion-color-medium: rgba(136, 135, 128, .25);--emotion-color-glow: rgba(136, 135, 128, .08);--emotion-transition: background-color 1.5s cubic-bezier(.4, 0, .2, 1), border-color 1.5s cubic-bezier(.4, 0, .2, 1), color 1.5s cubic-bezier(.4, 0, .2, 1), box-shadow 1.5s cubic-bezier(.4, 0, .2, 1), filter 1.5s cubic-bezier(.4, 0, .2, 1);--bg-primary: #08080d;--bg-secondary: #101018;--bg-tertiary: #16161f;--bg-card: rgba(255, 255, 255, .035);--bg-card-hover: rgba(255, 255, 255, .065);--text-primary: #f0eff4;--text-secondary: #a09eab;--text-muted: #5c5a66;--border-color: rgba(255, 255, 255, .07);--border-color-strong: rgba(255, 255, 255, .12);--sidebar-width: 300px;--radius-sm: .625rem;--radius-md: 1rem;--radius-lg: 1.25rem;--radius-xl: 1.5rem}html,body,#root{height:100%;margin:0;font-family:Outfit,Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{transition:var(--emotion-transition)}.emotion-bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(ellipse 80% 50% at 50% -10%,var(--emotion-color-soft) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,var(--emotion-color-glow) 0%,transparent 50%);transition:var(--emotion-transition);pointer-events:none}.glass-card{background:var(--bg-card);backdrop-filter:blur(24px) saturate(1.2);-webkit-backdrop-filter:blur(24px) saturate(1.2);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--emotion-transition);box-shadow:0 2px 16px #00000026}.glass-card:hover{background:var(--bg-card-hover);box-shadow:0 4px 24px #0003}.glass-card-strong{background:#ffffff0e;backdrop-filter:blur(32px) saturate(1.3);-webkit-backdrop-filter:blur(32px) saturate(1.3);border:1px solid var(--border-color-strong);border-radius:var(--radius-lg);transition:var(--emotion-transition);box-shadow:0 4px 32px #0003,0 0 0 1px #ffffff08 inset}.emotion-tinted{background-color:var(--emotion-color-soft);border-color:var(--emotion-color);transition:var(--emotion-transition)}.emotion-text{color:var(--emotion-color);transition:var(--emotion-transition)}.emotion-bg{background-color:var(--emotion-color);transition:var(--emotion-transition)}.emotion-border{border-color:var(--emotion-color);transition:var(--emotion-transition)}.emotion-glow{box-shadow:0 0 30px -5px var(--emotion-color-medium),0 0 60px -10px var(--emotion-color-soft);transition:var(--emotion-transition)}.avatar-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.avatar-pulse-ring{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:2px solid var(--emotion-color);opacity:.3;animation:avatar-pulse 3s ease-in-out infinite;transition:var(--emotion-transition)}@keyframes avatar-pulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.06);opacity:.15}}.avatar-glow-bg{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;background:radial-gradient(circle,var(--emotion-color-medium) 0%,transparent 70%);filter:blur(20px);transition:var(--emotion-transition);pointer-events:none}.avatar-emotion-ring{position:absolute;border-radius:50%;overflow:hidden;opacity:.6;animation:ring-rotate 20s linear infinite}@keyframes ring-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.avatar-ring-gif{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%;transition:opacity .5s ease}.avatar-face-frame{border-radius:50%;overflow:hidden;border-style:solid;position:relative;z-index:2;box-shadow:0 4px 24px #0006}.avatar-face-photo{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.avatar-emotion-badge{position:absolute;bottom:-2px;right:-2px;width:52px;height:52px;border-radius:.5rem;overflow:hidden;border:2px solid var(--bg-primary);box-shadow:0 2px 8px #00000080;z-index:3}.avatar-badge-gif{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.landmark-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:5;pointer-events:none}.scan-badge{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:1rem;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#4ade80;font-size:.6875rem;font-weight:500;z-index:10}.scan-badge-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:scan-dot-pulse 1s ease-in-out infinite}@keyframes scan-dot-pulse{0%,to{opacity:1}50%{opacity:.3}}.admin-row:hover{background:#ffffff08}.admin-delete-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:1.75rem;padding:0 .5rem;border-radius:.375rem;border:1px solid transparent;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s ease}.admin-delete-btn:hover{border-color:#ef44444d;background:#ef44441a!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--emotion-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--emotion-color);opacity:.8}.emotion-scrollbar{overflow-y:auto!important;scrollbar-width:thin!important}.emotion-scrollbar::-webkit-scrollbar{width:8px!important;height:8px!important}.emotion-scrollbar::-webkit-scrollbar-track{background:transparent!important;border-radius:4px!important}.emotion-scrollbar::-webkit-scrollbar-thumb{background:var(--emotion-color)!important;border-radius:4px!important;border:2px solid transparent!important;background-clip:content-box!important;min-height:20px!important}.emotion-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--emotion-color)!important;opacity:.9!important}.emotion-scrollbar::-webkit-scrollbar-thumb:active{background:var(--emotion-color)!important;opacity:1!important}.emotion-scrollbar{scrollbar-color:var(--emotion-color) transparent!important}.app-light-theme .emotion-scrollbar::-webkit-scrollbar-thumb{background:var(--emotion-color)!important}.app-light-theme .emotion-scrollbar{scrollbar-color:var(--emotion-color) transparent!important}.input-dark{background:#ffffff0a;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);padding:.75rem 1rem;font-size:.875rem;font-family:inherit;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease;outline:none;width:100%}.input-dark::-moz-placeholder{color:var(--text-muted)}.input-dark::placeholder{color:var(--text-muted)}.input-dark:focus{border-color:var(--emotion-color);box-shadow:0 0 0 3px var(--emotion-color-soft),0 0 20px var(--emotion-color-glow);background:#ffffff0f}.input-dark:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--emotion-color);color:#0a0a0f;font-weight:600;padding:.7rem 1.5rem;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:.875rem;font-family:inherit;letter-spacing:.01em;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary:hover{filter:brightness(1.15);transform:translateY(-2px);box-shadow:0 6px 20px var(--emotion-color-medium),0 0 40px var(--emotion-color-glow)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:#ffffff0d;color:var(--text-secondary);font-weight:500;padding:.7rem 1.5rem;border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;font-size:.875rem;font-family:inherit;transition:all .25s cubic-bezier(.4,0,.2,1)}.btn-secondary:hover{background:#ffffff1a;color:var(--text-primary);border-color:var(--border-color-strong);transform:translateY(-1px)}.btn-icon{width:2.5rem;height:2.5rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);flex-shrink:0}.btn-icon:hover{background:#ffffff1f;color:var(--text-primary);transform:scale(1.05)}.btn-icon.active{background:var(--emotion-color-soft);border-color:var(--emotion-color);color:var(--emotion-color);box-shadow:0 0 16px var(--emotion-color-glow)}.voice-recording{position:relative}.voice-recording:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--emotion-color);animation:voice-ring 1.5s ease-in-out infinite}@keyframes voice-ring{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:0}}.tts-btn{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:.375rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:10px;transition:all .2s ease;position:relative}.tts-btn:hover{color:var(--text-secondary);background:#ffffff0f}.tts-btn-active{color:var(--emotion-color)}.tts-waves{display:inline-flex;gap:2px;height:12px;align-items:center}.tts-waves:before,.tts-waves:after{content:"";width:2px;height:8px;border-radius:1px;background:var(--emotion-color);animation:tts-wave .8s ease-in-out infinite alternate}.tts-waves:after{height:12px;animation-delay:.2s}@keyframes tts-wave{0%{height:4px}to{height:12px}}.sidebar-toggle{position:fixed;top:1rem;left:1rem;z-index:50;width:2.25rem;height:2.25rem}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:55;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.chat-sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);max-width:92vw;background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:60;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.chat-sidebar-open{transform:translate(0)}.sidebar-conversations{flex:1;overflow-y:auto;padding:.5rem}.sidebar-conv-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:.75rem;cursor:pointer;transition:all .15s ease;position:relative}.sidebar-conv-item:hover{background:#ffffff0d}.sidebar-conv-active{background:var(--emotion-color-soft)!important;border:1px solid var(--emotion-color-medium)}.sidebar-delete-btn{opacity:0;color:var(--text-muted);background:none;border:none;padding:.25rem;border-radius:.375rem;cursor:pointer;transition:all .15s ease;flex-shrink:0}.sidebar-conv-item:hover .sidebar-delete-btn{opacity:1}.sidebar-delete-btn:hover{color:#f87171;background:#ef44441a}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.scan-oval{width:55%;height:72%;border:3px dashed rgba(255,255,255,.5);border-radius:50%;position:relative;transition:border-color .3s ease}.scan-oval.detected{border-color:#4ade80;border-style:solid;box-shadow:0 0 20px #4ade8033}.scan-oval.warning{border-color:#facc15;border-style:dashed}.scan-instruction{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:.8125rem;font-weight:500;padding:.375rem .75rem;border-radius:.5rem;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff}.camera-pip{position:fixed;bottom:calc(5rem + env(safe-area-inset-bottom,0px));right:calc(1rem + env(safe-area-inset-right,0px));width:clamp(120px,38vw,180px);aspect-ratio:4 / 3;border-radius:.75rem;overflow:hidden;box-shadow:0 8px 32px #00000080;border:1px solid var(--border-color-strong);z-index:40;transition:all .3s ease}.camera-pip:hover{transform:scale(1.05);box-shadow:0 12px 40px #0009}.camera-pip video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.progress-bar{height:4px;border-radius:2px;background:#ffffff14;overflow:hidden}.progress-bar-fill{height:100%;border-radius:2px;background:var(--emotion-color);transition:width .3s ease,background-color 1.2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fadeIn{animation:fadeIn .4s ease forwards}.animate-slideUp{animation:slideUp .5s ease forwards}.animate-float{animation:float 4s ease-in-out infinite}.app-footer{position:fixed;bottom:0;left:0;right:0;text-align:center;font-size:.6875rem;color:var(--text-muted);padding:.5rem;background:linear-gradient(to top,var(--bg-primary),transparent);pointer-events:none;z-index:10}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:60;text-align:center;font-size:.8125rem;font-weight:500;color:#fff;background:#b91c1c;padding:.5rem 1rem;box-shadow:0 2px 8px #0003}.auto-read-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:500;padding:.3rem .7rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:all .18s ease}.auto-read-toggle:hover{color:var(--text-secondary);border-color:var(--emotion-color-medium)}.auto-read-toggle.auto-read-on{color:var(--emotion-color);border-color:var(--emotion-color);background:var(--emotion-color-soft)}.auto-read-toggle .auto-read-state{font-weight:700;letter-spacing:.03em}.emotion-capture-overlay{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:10}.emotion-capture-card{display:flex;align-items:center;gap:10px;padding:8px 16px;border-radius:1rem;background:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid;transition:border-color .3s ease;white-space:nowrap}.emotion-chip{display:flex;align-items:center;gap:3px;padding:4px 8px;border-radius:1rem;background:#ffffff0a;border:1px solid var(--border-color);font-size:.875rem;opacity:.4;transition:all .3s ease}.emotion-chip.current{opacity:1;background:#ffffff14;border-width:2px;animation:chip-pulse 1.5s ease-in-out infinite}.emotion-chip.captured{opacity:1;background:#4ade801a;border-color:#4ade804d}@keyframes chip-pulse{0%,to{box-shadow:0 0 #ffffff1a}50%{box-shadow:0 0 8px 2px #ffffff0d}}.face-mismatch-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-light-theme{--bg-primary: #f8f7ff;--bg-secondary: #f3f0ff;--bg-tertiary: #ede9fe;--bg-card: rgba(255, 255, 255, .7);--bg-card-hover: rgba(255, 255, 255, .85);--text-primary: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: rgba(0, 0, 0, .08);--border-color-strong: rgba(0, 0, 0, .12);background:radial-gradient(circle at top right,#fde68a55,transparent 50%),radial-gradient(circle at bottom left,#c084fc44,transparent 50%),linear-gradient(160deg,#f5f3ff,#fdf2f8,#fffbeb);min-height:100vh;min-height:100dvh;color:var(--text-primary)}.app-light-theme .glass-card{background:#ffffff8c;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 20px #0000000f}.app-light-theme .glass-card:hover{background:#ffffffb3;box-shadow:0 8px 32px #00000014}.app-light-theme .glass-card-strong{background:#ffffffb3;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.5);box-shadow:0 8px 32px #00000014}.app-light-theme .emotion-text{filter:brightness(.7) saturate(1.3)}.app-light-theme .emotion-bg-gradient{background:radial-gradient(ellipse 80% 50% at 50% -10%,var(--emotion-color-soft) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,var(--emotion-color-glow) 0%,transparent 50%);opacity:.7}.app-light-theme .btn-primary{background:linear-gradient(90deg,#a855f7,#ec4899)!important;color:#fff!important;border:none!important;border-radius:12px;font-weight:700;box-shadow:0 4px 16px #a855f740;transition:all .3s ease}.app-light-theme .btn-primary:hover{transform:scale(1.02);filter:brightness(1.1);box-shadow:0 6px 20px #a855f759}.app-light-theme .btn-secondary{background:#fff9!important;color:#374151!important;border:1.5px solid rgba(0,0,0,.1)!important;border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:600;transition:all .3s ease}.app-light-theme .btn-secondary:hover{background:#ffffffd9!important;box-shadow:0 4px 12px #00000014}.app-light-theme .btn-icon{background:#fff9;border:1px solid rgba(0,0,0,.08);color:#374151;box-shadow:0 2px 8px #0000000a}.app-light-theme .btn-icon:hover{background:#ffffffd9;box-shadow:0 4px 12px #00000014}.app-light-theme .btn-icon.active{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-color:transparent}.app-light-theme .input-dark,.app-light-theme input[type=text],.app-light-theme input[type=email],.app-light-theme input[type=tel],.app-light-theme input[type=password]{background:#fff!important;border:1px solid rgba(0,0,0,.1)!important;border-radius:12px!important;color:#1a1a2e!important;padding:.55rem .875rem;font-family:inherit;transition:all .3s ease}.app-light-theme input:focus{border-color:#8b5cf6!important;box-shadow:0 0 0 3px #8b5cf61a!important;outline:none}.app-light-theme input::-moz-placeholder{color:#9ca3af!important}.app-light-theme input::placeholder{color:#9ca3af!important}.app-light-theme input:disabled{background:#00000008!important;color:#9ca3af!important}.app-light-theme header{background:#ffffffb3!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.06)!important;box-shadow:0 1px 8px #0000000a}.app-light-theme section[style*=borderLeft]{border-left-color:#0000000f!important;background:#ffffff4d!important}.app-light-theme .chat-container-glass{background:#fff6;border:1px solid rgba(0,0,0,.06)}.app-light-theme .chat-bubble-user{background:var(--emotion-color);color:#fff;box-shadow:0 2px 12px var(--emotion-color-glow)}.app-light-theme .chat-bubble-assistant{background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,.06);color:#1a1a2e;box-shadow:0 2px 8px #0000000a}.app-light-theme .face-mismatch-overlay{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-light-theme .camera-pip{box-shadow:0 8px 32px #0000001f;border:2px solid rgba(255,255,255,.8)}.app-light-theme .admin-row:hover{background:#8b5cf60a}.app-light-theme .admin-delete-btn{border-radius:8px;padding:.35rem .75rem}.app-light-theme [class*=rounded-xl][style*="background: rgba(239"]{background:#ef44440f!important;border:1px solid rgba(239,68,68,.15)!important}.app-light-theme [class*=rounded-xl][style*="background: rgba(251"]{background:#fbbf240f!important;border:1px solid rgba(251,191,36,.15)!important}.app-light-theme ::-webkit-scrollbar{width:6px}.app-light-theme ::-webkit-scrollbar-track{background:transparent}.app-light-theme ::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}.app-light-theme .progress-bar{background:#0000000f}.app-light-theme .progress-bar-fill{background:linear-gradient(90deg,#a855f7,#ec4899)}.app-light-theme .scan-badge{background:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#1a1a2e}.app-light-theme .emotion-chip{background:#fff9;border:1px solid rgba(0,0,0,.08)}.app-light-theme .emotion-chip.captured{background:#4ade801a;border-color:#4ade80}.app-light-theme .app-footer{color:#9ca3af;border-top:1px solid rgba(0,0,0,.06)}.app-light-theme .chat-sidebar{background:#ffffffd9!important;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(0,0,0,.08)!important}.app-light-theme .chat-input-area,.app-light-theme [class*=chat-input]{background:#fff9;border:1px solid rgba(0,0,0,.08);border-radius:16px}.app-light-theme .typing-dot{background:var(--emotion-color);opacity:.6}.login-page{display:grid;grid-template-columns:280px 1fr;min-height:100vh;min-height:100dvh;height:100vh;height:100dvh;width:100%;background:radial-gradient(circle at top right,#fde68a55,transparent 50%),radial-gradient(circle at bottom left,#c084fc44,transparent 50%),#f8fafc;font-family:Outfit,Inter,system-ui,sans-serif;color:#1a1a2e;overflow:hidden}.login-zone-avatar{grid-column:1;height:100vh;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:1.25rem 1rem;background:linear-gradient(160deg,#c084fc,#f472b6,#facc15);overflow:hidden}.login-zone-avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff14;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none}.login-zone-avatar:after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:#ffffff12;top:-60px;left:-80px;animation:floatParticle 8s ease-in-out infinite;pointer-events:none}@keyframes floatParticle{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,40px) scale(1.15)}}.login-avatar-title{font-size:1rem;font-weight:700;color:#fff;z-index:1;text-align:center;margin-bottom:.15rem}.login-avatar-subtitle{font-size:.7rem;color:#fffc;z-index:1;text-align:center;margin-bottom:.875rem;max-width:180px;line-height:1.4}.avatar-video-wrap{position:relative;width:clamp(120px,12vw,160px);aspect-ratio:9 / 16;border-radius:1.25rem;overflow:hidden;box-shadow:0 0 40px #fff3,0 8px 40px #00000040;z-index:1;flex-shrink:0;animation:avatarFloat 4s ease-in-out infinite}@keyframes avatarFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.avatar-video-wrap video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.avatar-carousel-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;animation:avatarCarouselFade .45s ease}@keyframes avatarCarouselFade{0%{opacity:0}to{opacity:1}}.avatar-nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:#ffffff40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.4);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:all .2s ease;font-size:1rem;padding:0}.avatar-nav-arrow:hover{background:#ffffff73;transform:translateY(-50%) scale(1.1)}.avatar-nav-arrow.left{left:6px}.avatar-nav-arrow.right{right:6px}.login-avatar-footer{display:flex;align-items:center;gap:8px;margin-top:.75rem;z-index:1}.login-avatar-footer-icon{width:28px;height:28px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:.75rem}.login-avatar-footer-text{font-size:.7rem;color:#ffffffd9;font-weight:500}.login-avatar-quote{position:absolute;bottom:1.5rem;left:1rem;right:1rem;text-align:center;font-size:.7rem;color:#ffffffb3;font-style:italic;z-index:1;line-height:1.4}.login-right-col{grid-column:2;display:flex;flex-direction:column;padding:0;overflow-y:auto;overflow-x:hidden;position:relative;height:100vh;height:100dvh}.login-hero-form-row{display:grid;grid-template-columns:1fr 360px;gap:1.5rem;padding:1.25rem 1.5rem 1rem;align-items:start;flex-shrink:0}.login-bottom-content{padding:0 1.5rem 1rem;display:flex;flex-direction:column;gap:.875rem;flex-shrink:0}.login-form-card{width:100%;max-width:min(380px,92vw);margin:0;background:#ffffffb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.25rem;box-shadow:0 12px 32px #0000001a}.login-form-logo{display:flex;align-items:center;gap:8px;margin-bottom:.35rem}.login-form-logo-icon{font-size:1.75rem}.login-form-logo-text{font-size:1.5rem;font-weight:800;color:#6b21a8;letter-spacing:-.02em}.login-form-desc{font-size:.875rem;color:#6b7280;margin-bottom:.875rem;line-height:1.4}.login-form-welcome{font-size:1.125rem;font-weight:700;color:#1a1a2e;margin-bottom:.15rem}.login-form-welcome-sub{font-size:.875rem;color:#6b7280;margin-bottom:.875rem}.login-input-group{margin-bottom:.625rem}.login-input-label{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.25rem;display:block}.login-input-wrap{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:12px;padding:0 16px;transition:all .3s ease}.login-input-wrap:focus-within{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.login-input-icon{color:#9ca3af;flex-shrink:0}.login-input-wrap input{flex:1;border:none;background:transparent;padding:.55rem 0;font-size:.95rem;color:#1a1a2e;outline:none;font-family:inherit}.login-input-wrap input::-moz-placeholder{color:#9ca3af}.login-input-wrap input::placeholder{color:#9ca3af}.login-input-toggle{background:none;border:none;color:#9ca3af;cursor:pointer;padding:0;display:flex}.login-form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.875rem}.login-form-options label{display:flex;align-items:center;gap:4px;color:#6b7280;cursor:pointer}.login-form-options label input[type=checkbox]{accent-color:#8b5cf6;width:14px;height:14px}.login-form-options a{color:#8b5cf6;text-decoration:none;font-weight:600}.login-form-options a:hover{text-decoration:underline}.login-btn-submit{width:100%;padding:.6rem;border:none;border-radius:10px;background:linear-gradient(90deg,#a855f7,#ec4899);color:#fff;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease;margin-bottom:.625rem}.login-btn-submit:hover{transform:scale(1.02);filter:brightness(1.1);box-shadow:0 6px 20px #a855f759}.login-btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-form-register{font-size:.9rem;color:#6b7280;text-align:center}.login-form-register a{color:#8b5cf6;font-weight:700;text-decoration:none}.login-form-register a:hover{text-decoration:underline}.login-form-privacy{display:flex;align-items:flex-start;gap:6px;margin-top:1rem;font-size:.8rem;color:#9ca3af;line-height:1.4}.login-form-error{font-size:.9rem;color:#ef4444;margin-bottom:.5rem}.login-zone-landing{min-height:unset;overflow:visible;padding:0;display:flex;flex-direction:column;gap:.75rem}.landing-navbar{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.625rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.06);background:#ffffff80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:10;flex-shrink:0}.landing-nav-item{display:flex;align-items:center;gap:4px;padding:.4rem .75rem;border-radius:2rem;font-size:.7rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s;border:none;background:transparent;font-family:inherit;white-space:nowrap}.landing-nav-item:hover{background:#8b5cf614;color:#6b21a8}.landing-nav-item.active{background:#8b5cf61a;color:#6b21a8;font-weight:600}.landing-hamburger{width:32px;height:32px;border-radius:.5rem;background:#0000000a;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;margin-left:auto}.landing-content{flex:1;padding:0;max-width:100%;margin:0}.landing-hero-text{font-size:clamp(1.5rem,2.2vw,2.2rem);font-weight:800;color:#1a1a2e;line-height:1.15;letter-spacing:-.02em;margin-bottom:.625rem}.landing-hero-accent{color:#8b5cf6}.landing-hero-sparkle{color:#f59e0b}.landing-hero-desc{font-size:.8rem;color:#6b7280;line-height:1.5;margin-bottom:.875rem;max-width:480px}.landing-callout{display:flex;align-items:center;gap:8px;padding:.5rem .875rem;background:linear-gradient(135deg,#fce7f3,#fdf2f8);border-radius:.75rem;border:1px solid rgba(244,114,182,.2);margin-bottom:1rem}.landing-callout-icon{font-size:1.5rem}.landing-callout-text{font-size:.8rem;color:#9d174d;font-weight:500;line-height:1.4}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(140px,100%),1fr));gap:.75rem;margin-bottom:1rem}.landing-feature-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:1rem;text-align:center;transition:all .3s ease;box-shadow:0 4px 12px #0000000d}.landing-feature-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px #0000001a}.landing-feature-icon{width:36px;height:36px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem;font-size:1.125rem}.landing-feature-icon.purple{background:#ede9fe;color:#7c3aed}.landing-feature-icon.coral{background:#ffe4e6;color:#f43f5e}.landing-feature-icon.teal{background:#ccfbf1;color:#0d9488}.landing-feature-icon.green{background:#dcfce7;color:#16a34a}.landing-feature-title{font-size:.75rem;font-weight:700;color:#1a1a2e;margin-bottom:.2rem}.landing-feature-desc{font-size:.6rem;color:#6b7280;line-height:1.4}.landing-research{background:linear-gradient(135deg,#fdf4ff,#fef3c7);border-radius:.875rem;padding:1rem 1.25rem;border:1px solid rgba(0,0,0,.05);margin-bottom:.75rem}.landing-research-title{font-size:1rem;font-weight:800;color:#1a1a2e;margin-bottom:.3rem}.landing-research-title span{font-style:italic;color:#8b5cf6}.landing-research-desc{font-size:.75rem;color:#6b7280;line-height:1.5;margin-bottom:.75rem}.landing-research-btn{display:inline-flex;align-items:center;gap:6px;padding:.5rem 1.25rem;border-radius:2rem;border:1.5px solid #1a1a2e;background:transparent;color:#1a1a2e;font-size:.75rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.landing-research-btn:hover{background:#1a1a2e;color:#fff}.login-navari-decor{position:absolute;left:50%;top:30%;transform:translate(-50%,-50%);z-index:2;pointer-events:auto}.navari-glass-card{background:#fff9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:20px;box-shadow:0 20px 60px #00000014;border:1px solid rgba(255,255,255,.4);position:relative;display:flex;flex-direction:column;align-items:center;gap:10px}.navari-glass-card video{width:180px;border-radius:16px;display:block}.navari-glass-label{font-size:.85rem;font-weight:700;color:#6b21a8;letter-spacing:.02em}.navari-glass-sub{font-size:.7rem;color:#888;text-align:center;line-height:1.3}.navari-mute-btn{width:32px;height:32px;border-radius:50%;background:#6b21a81a;border:1px solid rgba(107,33,168,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s ease;padding:0}.navari-mute-btn:hover{background:#6b21a833;transform:scale(1.1)}.login-mute-btn{z-index:5;margin-top:.5rem;width:36px;height:36px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.35);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .2s ease;padding:0}.login-mute-btn:hover{background:#fff6;transform:scale(1.1)}.mini-chat{max-width:min(360px,92vw);border-radius:16px;background:#ffffff80;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.4);overflow:hidden;box-shadow:0 8px 30px #0000000f}.mini-chat-header{display:flex;align-items:center;gap:6px;padding:.5rem .875rem;font-size:.8rem;font-weight:700;color:#6b21a8;border-bottom:1px solid rgba(0,0,0,.05)}.mini-chat-messages{max-height:clamp(120px,22vh,160px);overflow-y:auto;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.375rem}.mini-msg{font-size:.8rem;line-height:1.4;padding:.35rem .625rem;border-radius:12px;max-width:85%;word-break:break-word}.mini-msg.assistant{background:#8b5cf61a;color:#4c1d95;align-self:flex-start;border-bottom-left-radius:4px}.mini-msg.user{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.mini-chat-input{display:flex;border-top:1px solid rgba(0,0,0,.05);padding:.375rem;gap:.375rem}.mini-chat-input input{flex:1;border:none;background:#00000008;border-radius:10px;padding:.4rem .75rem;font-size:.8rem;font-family:inherit;color:#1a1a2e;outline:none}.mini-chat-input input::-moz-placeholder{color:#9ca3af}.mini-chat-input input::placeholder{color:#9ca3af}.mini-chat-input button{width:32px;height:32px;border-radius:50%;border:none;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.mini-chat-input button:hover{transform:scale(1.08)}.mini-chat-input button:disabled{opacity:.4;cursor:not-allowed;transform:none}@media(max-width:1024px){.login-page{grid-template-columns:1fr;height:auto;min-height:100vh;min-height:100dvh}.login-zone-avatar{display:none}.login-right-col{height:auto;overflow-y:visible}.login-hero-form-row{grid-template-columns:1fr;gap:1rem;padding:1rem}.login-bottom-content{padding:0 1rem 1rem}.login-navari-decor{display:none}}@media(max-width:768px){.landing-features{grid-template-columns:1fr 1fr}.landing-navbar{overflow-x:auto;justify-content:flex-start}}.register-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}@media(max-width:480px){.register-field-row{grid-template-columns:1fr}}.whatsapp-float{position:fixed!important;bottom:1.5rem!important;right:1.5rem!important;width:56px!important;height:56px!important;border-radius:50%!important;z-index:9999!important;box-shadow:0 4px 16px #25d36666!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:1.5rem!important}.typing-dots{display:inline-flex;gap:4px;align-items:center;padding:4px 0}.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--emotion-color);opacity:.4;animation:typingBounce 1.4s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.chat-bubble-user{border-radius:1.25rem 1.25rem .375rem;padding:.75rem 1rem;font-size:.875rem;white-space:pre-wrap;line-height:1.55;background:var(--emotion-color);color:#0a0a0f;box-shadow:0 2px 12px var(--emotion-color-glow);transition:var(--emotion-transition)}.chat-bubble-assistant{border-radius:1.25rem 1.25rem 1.25rem .375rem;padding:.75rem 1rem;font-size:.875rem;white-space:pre-wrap;line-height:1.55;background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-color);color:var(--text-primary);box-shadow:0 2px 8px #0000001a}.chat-container-glass{background:#ffffff05;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.75rem;transition:var(--emotion-transition)}.dashboard-left-panel{gap:0;background:var(--bg-secondary);border-right:1px solid var(--border-color)}.emotion-state-label{font-size:1.1rem;font-weight:700;letter-spacing:-.01em;transition:var(--emotion-transition)}.emotion-state-sub{font-size:.7rem;margin-top:.2rem;line-height:1.4}.emotion-tip-card{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;border-radius:.875rem;border:1px solid;background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:280px;width:100%;transition:border-color .8s ease,background .5s ease;animation:fadeIn .4s ease forwards}.emotion-tip-icon{font-size:1.25rem;flex-shrink:0}.emotion-tip-text{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.emotion-quick-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:280px;width:100%;margin-top:.25rem}.emotion-quick-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.375rem .75rem;border-radius:2rem;border:1px solid;background:var(--bg-card);font-size:.725rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .25s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.emotion-quick-btn:hover{background:var(--bg-card-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.emotion-quick-btn:active{transform:translateY(0)}.emotion-timeline{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;border-radius:.875rem;background:var(--bg-card);border:1px solid var(--border-color);margin-bottom:.625rem;min-height:52px}.emotion-timeline-label{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.emotion-timeline-track{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.emotion-timeline-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:default;transition:transform .2s ease;position:relative;opacity:.85}.emotion-timeline-dot:last-child{opacity:1;transform:scale(1.15);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 3px currentColor}.emotion-timeline-dot:hover{transform:scale(1.2);opacity:1}.emotion-timeline-emoji{font-size:.875rem;line-height:1}.camera-activate-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.625rem 1rem;border-radius:.875rem;border:1px dashed;background:transparent;font-size:.75rem;font-family:inherit;cursor:pointer;transition:all .25s ease;opacity:.7}.camera-activate-hint:hover{opacity:1;background:var(--bg-card)}.camera-activate-hint:disabled{opacity:.35;cursor:not-allowed}.chat-empty-state{text-align:center;padding:3rem 1rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.chat-empty-icon{font-size:2.5rem;margin-bottom:.5rem}.chat-empty-headline{font-size:1rem;font-weight:600;letter-spacing:-.01em;transition:var(--emotion-transition)}.chat-empty-sub{font-size:.8rem;color:var(--text-muted);max-width:240px;line-height:1.5}.chat-empty-hint{font-size:.7rem;color:var(--text-muted);opacity:.5;margin-top:.25rem}.app-light-theme .dashboard-left-panel{background:#fff6;border-right-color:#0000000f}.app-light-theme .emotion-tip-card{background:#ffffffb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-light-theme .emotion-quick-btn{background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-light-theme .emotion-quick-btn:hover{background:#ffffffe6}.app-light-theme .emotion-timeline{background:#fff9;border-color:#0000000f}.app-light-theme .camera-activate-hint{color:var(--text-muted)}@media(max-width:1023px){.dashboard-left-panel{border-right:none;border-bottom:1px solid var(--border-color);padding:1.25rem}.emotion-quick-actions{max-width:100%}}.emotion-selector-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:opacity .3s ease}.emotion-selector-modal{position:relative;width:90%;max-width:520px;background:#14141eeb;backdrop-filter:blur(40px) saturate(1.4);-webkit-backdrop-filter:blur(40px) saturate(1.4);border:1px solid rgba(255,255,255,.1);border-radius:1.5rem;padding:2rem;box-shadow:0 24px 80px #00000080,0 0 0 1px #ffffff0a inset;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s ease;overflow:hidden}.emotion-selector-glow{position:absolute;top:0;left:0;right:0;height:200px;pointer-events:none;transition:background .5s ease}.emotion-selector-header{text-align:center;margin-bottom:1.5rem;position:relative;z-index:1}.emotion-selector-title{font-size:1.375rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem;letter-spacing:-.02em}.emotion-selector-subtitle{font-size:.8125rem;color:var(--text-muted);line-height:1.5}.emotion-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(140px,100%),1fr));gap:.625rem;position:relative;z-index:1;margin-bottom:1.25rem}.emotion-selector-option{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:1rem .625rem;border-radius:1rem;border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:inherit;color:inherit}.emotion-selector-option:hover{transform:translateY(-2px)}.emotion-selector-option.selected{transform:translateY(-3px) scale(1.02)}.emotion-selector-emoji{font-size:1.75rem;transition:transform .25s cubic-bezier(.34,1.56,.64,1);line-height:1}.emotion-selector-label{font-size:.8125rem;font-weight:600;transition:color .25s ease}.emotion-selector-phrase{font-size:.6875rem;color:var(--text-muted);text-align:center;line-height:1.3}.emotion-selector-check{position:absolute;top:.5rem;right:.5rem;font-size:.75rem;font-weight:700;animation:checkBounce .35s cubic-bezier(.34,1.56,.64,1)}@keyframes checkBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}.emotion-selector-footer{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.emotion-selector-hint{font-size:.6875rem;color:var(--text-muted);font-style:italic}.app-light-theme .emotion-selector-modal{background:#ffffffe0;border:1px solid rgba(0,0,0,.08);box-shadow:0 24px 80px #00000026}.app-light-theme .emotion-selector-option{background:#fff9;border-color:#00000014}.live-avatar-container{position:relative;border-radius:1.5rem;overflow:hidden;background:#0000000a;box-shadow:0 12px 32px #0000001f,inset 0 0 0 2px var(--emotion-color, rgba(255, 255, 255, .15));transition:box-shadow .4s ease}.live-avatar-video,.live-avatar-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;background:#0b0b14}.live-avatar-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000073;color:#fff;font-size:.875rem;letter-spacing:.02em;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:5}.live-avatar-mini{position:absolute;bottom:14px;left:14px;width:clamp(64px,22vw,84px);aspect-ratio:2 / 3;border-radius:1rem;overflow:hidden;border:2px solid rgba(255,255,255,.85);box-shadow:0 8px 20px #00000059,0 0 0 1px #00000026;background:#0b0b14;z-index:10;transition:transform .25s ease,box-shadow .25s ease}.live-avatar-mini:hover{transform:scale(1.05)}.live-avatar-mini video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.face-overlay{filter:drop-shadow(0 0 8px var(--emotion-color));transition:filter .3s ease}.face-overlay video,.face-overlay img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.face-scan-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(circle at 20% 0%,rgba(168,85,247,.15),transparent 40%),radial-gradient(circle at 80% 100%,rgba(236,72,153,.15),transparent 40%),#0f0f1a}.face-scan-step{width:100%;max-width:480px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:1.5rem;padding:2rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#f1f5f9;box-shadow:0 24px 48px #00000059}.face-scan-header{text-align:center;margin-bottom:1.25rem}.face-scan-header h2{font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.face-scan-header p{color:#f1f5f9b3;font-size:.9rem;margin:0}.face-scan-preview{position:relative;aspect-ratio:4 / 3;border-radius:1rem;overflow:hidden;background:#0b0b14;margin-bottom:1rem;border:1px solid rgba(255,255,255,.08)}.face-scan-preview video,.face-scan-preview canvas{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scaleX(-1)}.face-scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000008c;color:#fff;font-size:.95rem;letter-spacing:.02em;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.face-scan-tips{list-style:none;padding:0;margin:0 0 1rem;display:grid;gap:.25rem;font-size:.85rem;color:#f1f5f9bf}.face-scan-error{color:#fca5a5;font-size:.85rem;margin:0 0 .75rem}.face-scan-error button{color:#fff;background:transparent;border:none;cursor:pointer;text-decoration:underline;padding:0}.face-scan-actions{display:flex;gap:.75rem;justify-content:flex-end}.face-scan-btn-primary,.face-scan-btn-secondary{flex:1;padding:.75rem 1rem;border-radius:.75rem;font-weight:600;font-size:.9rem;cursor:pointer;border:1px solid transparent;transition:transform .15s ease,background .2s ease}.face-scan-btn-primary{background:linear-gradient(90deg,#a855f7,#ec4899);color:#fff}.face-scan-btn-primary:hover:not(:disabled){transform:translateY(-1px)}.face-scan-btn-primary:disabled{opacity:.6;cursor:not-allowed}.face-scan-btn-secondary{background:transparent;color:#cbd5e1;border-color:#ffffff2e}.face-scan-btn-secondary:hover{background:#ffffff0f}.face-mismatch-warning{position:fixed;bottom:2rem;right:2rem;z-index:90;display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-radius:1rem;background:#ef44441f;border:1px solid rgba(239,68,68,.3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:warningSlide .4s ease forwards}.face-mismatch-warning-text{font-size:.8125rem;font-weight:500;color:#f87171}.face-mismatch-warning-count{font-size:1.25rem;font-weight:700;color:#f87171;min-width:1.5rem;text-align:center}@keyframes warningSlide{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.landing-page{scroll-behavior:smooth;background:radial-gradient(ellipse 70% 50% at 20% -5%,rgba(155,89,182,.12) 0%,transparent 55%),radial-gradient(ellipse 60% 45% at 90% 10%,rgba(55,138,221,.1) 0%,transparent 50%),var(--bg-primary)}.landing-nav{display:flex;align-items:center;justify-content:space-between;max-width:1140px;margin:0 auto;padding:1.25rem 1.5rem}.landing-hero{max-width:1140px;margin:0 auto;padding:2rem 1.5rem 3.5rem;display:grid;grid-template-columns:1.05fr .95fr;gap:2.5rem;align-items:center}.landing-hero-copy{display:flex;flex-direction:column;gap:1.1rem}.landing-eyebrow{display:inline-flex;align-self:flex-start;align-items:center;gap:.4rem;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);background:#ffffff0d;border:1px solid var(--border-color);padding:.35rem .85rem;border-radius:999px}.landing-title{font-family:Outfit,sans-serif;font-weight:600;font-size:clamp(2.4rem,5vw,3.75rem);line-height:1.05;letter-spacing:-.02em;color:var(--text-primary);margin:0}.landing-gradient-text{background:linear-gradient(120deg,#f5c842,#d4537e 35%,#9b59b6 60%,#378add 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.landing-subtitle{font-size:1.05rem;line-height:1.6;color:var(--text-secondary);max-width:34rem}.landing-cta{font-size:.95rem;padding:.75rem 1.5rem}.landing-hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:320px}.landing-laptop{filter:drop-shadow(0 30px 60px rgba(0,0,0,.5))}.landing-phone{position:absolute;right:0;bottom:-10px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.6));animation:floatY 6s ease-in-out infinite}@keyframes floatY{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.landing-section{max-width:1140px;margin:0 auto;padding:3rem 1.5rem}.landing-section-kicker{text-align:center;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}.landing-section-title{text-align:center;font-family:Outfit,sans-serif;font-weight:600;font-size:clamp(1.6rem,3.5vw,2.3rem);letter-spacing:-.01em;color:var(--text-primary);margin:0 0 1.75rem}.landing-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.landing-pillar{padding:1.75rem;display:flex;flex-direction:column;gap:.65rem}.landing-pillar-icon{width:3rem;height:3rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.landing-pillar-tag{font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.landing-pillar-title{font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0}.landing-pillar-body{font-size:.92rem;line-height:1.6;color:var(--text-secondary);margin:0}.landing-roadmap-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:2.5rem;align-items:center}.landing-roadmap{list-style:none;padding:0;margin:1rem 0 0;position:relative}.landing-roadmap-item{display:flex;gap:1rem;padding:0 0 1.6rem;position:relative}.landing-roadmap-item:before{content:"";position:absolute;left:7px;top:18px;bottom:-4px;width:2px;background:var(--border-color-strong)}.landing-roadmap-item:last-child:before{display:none}.landing-roadmap-dot{flex-shrink:0;width:16px;height:16px;border-radius:50%;margin-top:3px;border:2px solid var(--border-color-strong);background:var(--bg-tertiary)}.landing-roadmap-item.done .landing-roadmap-dot{background:linear-gradient(120deg,#f5c842,#639922);border-color:transparent}.landing-roadmap-phase{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0}.landing-roadmap-title{font-family:Outfit,sans-serif;font-weight:600;color:var(--text-primary);margin:.1rem 0}.landing-roadmap-body{font-size:.88rem;line-height:1.5;color:var(--text-secondary);margin:0}.landing-totem{display:flex;flex-direction:column;align-items:center;gap:.75rem}.landing-totem-caption{font-size:.75rem;color:var(--text-muted);text-align:center;max-width:14rem}.landing-final-cta{text-align:center;padding-top:1rem;padding-bottom:4rem}.landing-footer{max-width:1140px;margin:0 auto;padding:2rem 1.5rem 3rem;border-top:1px solid var(--border-color);display:flex;align-items:center;gap:1rem;font-size:.8rem;color:var(--text-muted)}@media(max-width:860px){.landing-hero{grid-template-columns:1fr;text-align:center}.landing-hero-copy{align-items:center}.landing-eyebrow{align-self:center}.landing-hero-visual{min-height:280px}.landing-phone{right:8%}.landing-pillars,.landing-roadmap-grid{grid-template-columns:1fr}.landing-totem{order:-1}}.feria-badge{position:fixed;left:12px;bottom:12px;z-index:60;display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .75rem;font-size:.72rem;font-weight:600;letter-spacing:.04em;color:#fde68a;background:#f5c8421f;border:1px solid rgba(245,200,66,.35);border-radius:999px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:none}.feria-badge-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80;animation:feriaPulse 1.8s ease-in-out infinite}@keyframes feriaPulse{0%,to{opacity:1}50%{opacity:.4}}.hover\:underline:hover{text-decoration-line:underline}@media(min-width:640px){.sm\:inline{display:inline}.sm\:max-w-\[78\%\]{max-width:78%}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-\[1fr_1\.2fr\]{grid-template-columns:1fr 1.2fr}}
