:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app{min-height:100vh;display:flex;flex-direction:column;background:#000;color:#fff;position:relative}.app-header{position:absolute;top:0;left:0;right:0;padding:1rem;text-align:center;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:200}.app-header h1{margin:0;font-size:1.5rem;font-weight:300;text-shadow:0 2px 4px rgba(0,0,0,.5)}.app-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;gap:0;position:relative}.avatar-section{width:100vw;height:100vh;display:flex;justify-content:center;align-items:center}.avatar-container{position:relative;width:100vw;height:100vh;background:#000;overflow:hidden;display:flex;align-items:center;justify-content:center}.avatar-video{width:100%;height:100%;object-fit:contain;background-color:#000}.loading-overlay{position:absolute;inset:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid #fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.avatar-container.error{display:flex;align-items:center;justify-content:center;background:#ff00001a;border:2px dashed rgba(255,0,0,.3)}.error-message{text-align:center;padding:2rem}.error-message p{margin-bottom:1rem;color:#ff6b6b}.error-message button{background:#ff6b6b;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.error-message button:hover{background:#ff5252}.start-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000c;text-align:center;gap:1.5rem}.start-button{background:#4caf50;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #4caf504d}.start-button:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.start-overlay p{color:#ccc;font-size:.9rem;margin:0}.character-selection{display:flex;flex-direction:column;gap:1rem;align-items:center;margin-bottom:1rem}.character-selection label{color:#fff;font-size:1.1rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}.character-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.75rem 1rem;color:#fff;font-size:.9rem;min-width:300px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.character-select:hover{background:#ffffff26;border-color:#ffffff80}.character-select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf504d}.character-select option{background:#2a2a2a;color:#fff;padding:.5rem}.character-info{margin-top:.5rem;text-align:center}.character-badge{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:.3rem .8rem;font-size:.8rem;color:#ccc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.avatar-count{font-size:.8rem;color:#4caf50;margin-top:.5rem}.stt-selection{display:flex;flex-direction:column;gap:.5rem;align-items:center;margin-bottom:1rem}.stt-selection label{color:#fff;font-size:1rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}.stt-provider-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.75rem 1rem;color:#fff;font-size:.9rem;min-width:300px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.stt-provider-select:hover{background:#ffffff26;border-color:#ffffff80}.stt-provider-select:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f34d}.stt-provider-select option{background:#2a2a2a;color:#fff;padding:.5rem}.provider-info{font-size:.8rem;color:#ccc;text-align:center;margin-top:.3rem}.buffer-mode-selection{display:flex;flex-direction:column;gap:.5rem;align-items:center;margin-bottom:1rem}.buffer-mode-selection label{color:#fff;font-size:1rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}.buffer-mode-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.75rem 1rem;color:#fff;font-size:.9rem;min-width:300px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.buffer-mode-select:hover{background:#ffffff26;border-color:#ffffff80}.buffer-mode-select:focus{outline:none;border-color:#ff9800;box-shadow:0 0 0 2px #ff98004d}.buffer-mode-select option{background:#2a2a2a;color:#fff;padding:.5rem}.buffer-mode-info{font-size:.8rem;color:#ccc;text-align:center;margin-top:.3rem}.settings-summary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;margin-bottom:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.settings-summary p{margin:0 0 .5rem;color:#fff;font-weight:600}.settings-summary ul{list-style:none;padding:0;margin:0}.settings-summary li{padding:.2rem 0;color:#ccc;font-size:.9rem}.message-content h1,.message-content h2,.message-content h3,.message-content h4,.message-content h5,.message-content h6{margin:.5rem 0;color:#fff;font-weight:600}.message-content h1{font-size:1.4rem}.message-content h2{font-size:1.2rem}.message-content h3{font-size:1.1rem}.message-content h4{font-size:1rem}.message-content h5{font-size:.9rem}.message-content h6{font-size:.8rem}.message-content p{margin:.5rem 0;line-height:1.5}.message-content ul,.message-content ol{margin:.5rem 0;padding-left:1.5rem}.message-content li{margin:.25rem 0;line-height:1.4}.message-content strong{font-weight:600;color:#fff}.message-content em{font-style:italic;color:#e0e0e0}.message-content code{background:#ffffff1a;padding:.1rem .3rem;border-radius:3px;font-family:Consolas,Monaco,monospace;font-size:.85rem}.message-content pre{background:#ffffff0d;padding:.8rem;border-radius:8px;overflow-x:auto;margin:.5rem 0;border:1px solid rgba(255,255,255,.1)}.message-content pre code{background:none;padding:0;font-size:.9rem}.message-content blockquote{border-left:3px solid #4CAF50;padding-left:1rem;margin:.5rem 0;font-style:italic;color:#ccc}.message-content a{color:#4caf50;text-decoration:underline}.message-content a:hover{color:#45a049}.message-content table{width:100%;border-collapse:collapse;margin:.5rem 0}.message-content th,.message-content td{border:1px solid rgba(255,255,255,.2);padding:.5rem;text-align:left}.message-content th{background:#ffffff1a;font-weight:600}.message-content hr{border:none;height:1px;background:#fff3;margin:1rem 0}.character-select option{background:#2d2d2d;color:#fff;padding:.5rem}.character-info{display:flex;flex-direction:column;gap:.5rem;align-items:center}.character-badge{background:#4caf5033;color:#4caf50;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;border:1px solid rgba(76,175,80,.3);text-transform:capitalize}.avatar-count{color:#4caf50;font-size:.75rem;opacity:.8;margin-top:.25rem}.background-selector{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.background-selector label{color:#fff;font-size:1.1rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}.background-type-tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.background-type-tabs .tab{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.5rem 1rem;color:#fff;font-size:.8rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.background-type-tabs .tab:hover{background:#fff3}.background-type-tabs .tab.active{background:#4caf504d;border-color:#4caf50;color:#4caf50}.background-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.5rem;max-height:120px;overflow-y:auto}.background-option{width:80px;height:60px;border:2px solid rgba(255,255,255,.3);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .3s ease;background:#ffffff1a;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;text-align:center}.background-option:hover{border-color:#ffffff80;transform:scale(1.05)}.background-option.selected{border-color:#4caf50;box-shadow:0 0 0 2px #4caf504d}.background-option img{width:100%;height:100%;object-fit:cover}.background-placeholder{padding:.25rem;word-wrap:break-word}.gradient-name{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.7);font-weight:500}.color-picker{display:flex;align-items:center;gap:1rem;justify-content:center}.color-input{width:60px;height:40px;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;background:transparent}.color-input:hover{border-color:#ffffff80}.color-value{color:#fff;font-family:monospace;font-size:.9rem;padding:.25rem .5rem;background:#ffffff1a;border-radius:4px}.control-section{width:100%;max-width:400px}.control-panel{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:1.5rem;border:1px solid rgba(255,255,255,.2)}.status-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem;background:#0003;border-radius:8px}.status-icon{font-size:1.5rem}.control-buttons{display:flex;flex-direction:column;gap:.75rem}.primary-button,.secondary-button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.primary-button{background:#4caf50;color:#fff}.primary-button:hover{background:#45a049;transform:translateY(-2px)}.secondary-button{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.secondary-button:hover{background:#fff3;transform:translateY(-1px)}.secondary-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.stop-button{background:#f44336}.stop-button:hover{background:#da190b}.chat-history-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.chat-history-container{background:#fffffff2;color:#333;border-radius:16px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.chat-history-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#0000000d;border-bottom:1px solid rgba(0,0,0,.1)}.chat-history-header h3{margin:0;font-size:1.2rem}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.close-button:hover{background:#0000001a}.chat-history-content{flex:1;overflow-y:auto;padding:1rem}.message{margin-bottom:1rem;padding:.75rem;border-radius:8px;max-width:80%}.message.user{background:#e3f2fd;margin-left:auto}.message.agent{background:#f5f5f5;margin-right:auto}.message-role{font-size:.8rem;font-weight:600;color:#666;margin-bottom:.25rem}.message-content{font-size:.9rem;line-height:1.4}.live-chat-display{position:fixed;bottom:0;left:0;right:0;height:200px;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2);z-index:100}.chat-messages{height:100%;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#888;font-style:italic}.chat-message{display:flex;flex-direction:column;max-width:70%;word-wrap:break-word}.chat-message.user{align-self:flex-end;align-items:flex-end}.chat-message.agent{align-self:flex-start;align-items:flex-start}.chat-message .message-content{background:#ffffff1a;padding:.75rem 1rem;border-radius:16px;color:#fff;font-size:.9rem;line-height:1.4}.chat-message.user .message-content{background:#4caf50;border-bottom-right-radius:4px}.chat-message.agent .message-content{background:#ffffff26;border-bottom-left-radius:4px}.chat-message .message-meta{font-size:.7rem;color:#ccc;margin-top:.25rem;padding:0 .5rem}.floating-controls{position:absolute;top:50%;right:2rem;transform:translateY(-50%);display:flex;flex-direction:column;gap:1rem;z-index:300}.floating-button{width:60px;height:60px;border-radius:50%;border:none;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0000004d}.floating-button:hover{background:#000000e6;transform:scale(1.1)}.floating-button.primary{background:#4caf50cc}.floating-button.primary:hover{background:#4caf50}.floating-button.secondary{background:#ff5722cc}.floating-button.secondary:hover{background:#ff5722}.floating-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.status-overlay{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);padding:1rem 2rem;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50px;border:1px solid rgba(255,255,255,.2);z-index:300;display:flex;align-items:center;gap:.75rem}.status-icon{font-size:1.2rem}.status-text{font-size:.9rem;font-weight:500}.app-content{padding-bottom:220px}@media (max-width: 768px){.app-content{padding:1rem;padding-bottom:220px}.avatar-container{width:280px;height:498px}.control-panel{padding:1rem}.chat-history-overlay{padding:.5rem}.live-chat-display{height:150px}.app-content{padding-bottom:170px}.character-select{min-width:250px;font-size:.8rem}.character-selection{margin-bottom:.5rem}.character-selection label{font-size:1rem}}.start-controls{display:flex;flex-direction:column;gap:1rem;align-items:center}.kiosk-toggle-button{background:#2196f3;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #2196f34d}.kiosk-toggle-button:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 4px 15px #2196f366}.avatar-container.kiosk-mode{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1000;background:#000}.exit-kiosk-button{position:fixed;top:20px;right:20px;z-index:1001;padding:10px 15px;background:#000000b3;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.exit-kiosk-button:hover{background:#ff0000b3;transform:scale(1.05)}@media (orientation: portrait){.avatar-container.kiosk-mode .avatar-video{object-fit:contain}}@media (orientation: landscape){.avatar-container.kiosk-mode .avatar-video{object-fit:contain}}
