*,: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:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";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}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.ml-2{margin-left:.5rem}.block{display:block}.flex-1{flex:1 1 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))}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.border{border-width:1px}.text-sm{font-size:.875rem;line-height:1.25rem}.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)}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;background-color:#f0f0f0}#root{width:100%;height:100vh}.tts-button-container{display:inline-flex;align-items:center;gap:4px}.tts-button{background:#fffc;border:1px solid rgba(139,69,19,.3);border-radius:6px;padding:4px 8px;cursor:pointer;transition:all .2s ease;font-size:14px;display:flex;align-items:center;justify-content:center;min-width:32px;height:28px}.tts-button:hover{background:#fffffff2;border-color:#8b451380;transform:translateY(-1px)}.tts-button.playing{background:#22c55e1a;border-color:#22c55e4d}.tts-button.loading{background:#3b82f61a;border-color:#3b82f64d;cursor:wait}.tts-button:disabled{opacity:.6;cursor:not-allowed}.tts-loading{animation:spin 1s linear infinite}.tts-error{color:#ef4444;font-size:12px;cursor:help}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message-row{display:flex;align-items:flex-start;gap:8px}.message-row p{margin:0;flex:1}.tts-settings-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.tts-settings-panel{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid #e5e7eb;padding-bottom:12px}.settings-header h3{margin:0;color:#374151}.close-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#6b7280}.close-btn:hover{color:#374151}.setting-group{margin-bottom:16px}.setting-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151}.setting-group select,.setting-group input[type=range]{width:100%;padding:8px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.setting-group select:focus,.setting-group input[type=range]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.setting-actions{display:flex;gap:12px;margin:20px 0}.test-btn,.clear-btn{flex:1;padding:10px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:14px;transition:all .2s ease}.test-btn:hover,.clear-btn:hover{background:#f9fafb;border-color:#9ca3af}.test-btn{border-color:#3b82f6;color:#3b82f6}.clear-btn{border-color:#ef4444;color:#ef4444}.tts-status{background:#f9fafb;padding:16px;border-radius:6px;margin-top:16px}.tts-status p{margin:0 0 8px;font-weight:500}.tts-status ul{margin:0;padding-left:20px}.tts-status li{margin-bottom:4px;font-size:14px}.tts-btn{transition:all .3s ease}.tts-btn.active{background:#22c55e1a;border-color:#22c55e4d;color:#22c55ecc}.tts-btn:not(.active){background:#ef44441a;border-color:#ef44444d;color:#ef4444cc}.character-indicator.playing-tts{animation:tts-pulse 1s ease-in-out infinite}.tts-icon{display:inline-flex;align-items:center;margin-left:8px;animation:tts-bounce .6s ease-in-out infinite alternate}@keyframes tts-pulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 10px #22c55e00}}@keyframes tts-bounce{0%{transform:scale(1)}to{transform:scale(1.2)}}.log-message.playing-tts{background:#22c55e1a;border-left:3px solid rgba(34,197,94,.5);padding-left:8px;animation:log-tts-highlight 1s ease-in-out infinite}.tts-indicator{color:#22c55ecc;font-size:12px;margin-left:8px;animation:tts-bounce .6s ease-in-out infinite alternate}@keyframes log-tts-highlight{0%,to{background:#22c55e1a}50%{background:#22c55e33}}@media (min-width: 768px){.md\:text-base{font-size:1rem;line-height:1.5rem}}.sit-out-scene{font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;position:relative;width:100vw;height:100vh;background:linear-gradient(135deg,#f1f8e9,#e8f5e8)}.header-controls{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#e8f5e9fa,#c8e6c9fa);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;z-index:100;box-shadow:0 4px 25px #4caf5026;border-bottom:2px solid rgba(76,175,80,.2)}.logo{display:flex;align-items:center;gap:.75rem}.house-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.logo h1{color:#1a202c;font-size:1.5rem;font-weight:700;margin:0;letter-spacing:-.5px}.subtitle{color:#4a5568;margin:0;font-size:.9rem;font-weight:500}.api-warning{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,gold,#ffb347);color:#8b4513;padding:.75rem 1.25rem;border-radius:2rem;font-size:.9rem;font-weight:600;box-shadow:0 2px 10px #ffd7004d;border:1px solid rgba(255,255,255,.2)}.controls{display:flex;gap:.75rem;align-items:center}.control-btn{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:none;border-radius:.875rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .25s ease;color:#fff;box-shadow:0 3px 10px #0000001f;border:1px solid rgba(255,255,255,.2)}.control-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.start-btn{background:linear-gradient(135deg,#16a085,#2ecc71)}.start-btn:hover{background:linear-gradient(135deg,#138d75,#27ae60)}.pause-btn{background:linear-gradient(135deg,#f39c12,#f1c40f)}.pause-btn:hover{background:linear-gradient(135deg,#e67e22,#f39c12)}.resume-btn{background:linear-gradient(135deg,#16a085,#2ecc71)}.resume-btn:hover{background:linear-gradient(135deg,#138d75,#27ae60)}.reset-btn{background:linear-gradient(135deg,#e74c3c,#ec7063)}.reset-btn:hover{background:linear-gradient(135deg,#c0392b,#e74c3c)}.log-btn{background:linear-gradient(135deg,#3498db,#5dade2)}.log-btn:hover{background:linear-gradient(135deg,#2980b9,#3498db)}.settings-btn{background:linear-gradient(135deg,#95a5a6,#bdc3c7)}.settings-btn:hover{background:linear-gradient(135deg,#7f8c8d,#95a5a6)}.control-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:0 2px 8px #0000001a!important}.control-btn:active{transform:translateY(0)}.scene-background{position:relative;width:100vw;height:100vh;margin-top:65px;background-color:#f8f9fa}.scene-overlay{position:absolute;inset:0;background:#ffffff0d;z-index:1}.character-container{transition:all .3s ease;cursor:pointer;z-index:10}.character-indicator{text-align:center;transition:transform .3s ease;position:relative;display:flex;flex-direction:column;align-items:center}.character-indicator.speaking{transform:scale(1.05)}.character-label{background:#fffffffa;padding:.6rem 1.2rem;border-radius:1.5rem;box-shadow:0 4px 15px #0000001a;display:flex;align-items:center;gap:.6rem;justify-content:center;min-width:90px;border:2px solid rgba(52,152,219,.2);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.character-indicator.speaking .character-label{background:#2ecc71f2;color:#fff;border-color:#2ecc71;box-shadow:0 6px 25px #2ecc714d;transform:translateY(-2px)}.character-name{font-weight:600;font-size:.95rem;letter-spacing:.2px}.speaker-icon{display:flex;align-items:center}.pulse-dot{width:10px;height:10px;background:#2ecc71;border-radius:50%;animation:pulse 1.5s infinite;box-shadow:0 0 10px #2ecc7180}.speech-bubble{position:absolute;bottom:calc(100% + 20px);left:50%;transform:translate(-50%);width:auto;min-width:200px;max-width:min(500px,85vw);animation:bubbleAppear .4s ease-out;z-index:30;filter:drop-shadow(0 4px 20px rgba(0,0,0,.1))}.bubble-content{background:#fffffffa;padding:1rem 1.5rem;border-radius:1.5rem;box-shadow:0 8px 25px #0000001f;position:relative;border:1px solid rgba(52,152,219,.15);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:.95rem;line-height:1.4;color:#2c3e50;max-height:120px;overflow-y:auto;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;white-space:pre-wrap;text-align:left;width:-moz-fit-content;width:fit-content;min-width:180px}.speech-bubble.active .bubble-content{background:#e8f5e9fa;border-color:#2ecc71;box-shadow:0 8px 30px #2ecc7133}.bubble-tail{position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:15px solid transparent;border-right:15px solid transparent;border-top:15px solid rgba(255,255,255,.98);filter:drop-shadow(0 3px 6px rgba(0,0,0,.1))}.speech-bubble.active .bubble-tail{border-top-color:#e8f5e9fa}.bubble-content::-webkit-scrollbar{width:4px}.bubble-content::-webkit-scrollbar-track{background:#0000000d;border-radius:2px}.bubble-content::-webkit-scrollbar-thumb{background:#3498db4d;border-radius:2px}.bubble-content::-webkit-scrollbar-thumb:hover{background:#3498db80}.bubble-content p{margin:0;display:inline-block;width:100%;text-wrap:balance}.speech-bubble.fallback .bubble-content{background:#fff8dcfa;border-color:#ffc1074d}.speech-bubble.fallback .bubble-tail{border-top-color:#fff8dcfa}.loading-spinner{position:absolute;top:-40px;left:50%;transform:translate(-50%);background:#ffffffe6;padding:.5rem .8rem;border-radius:1rem;box-shadow:0 4px 15px #0000001a}.spinner-dots{display:flex;gap:6px}.dot{width:8px;height:8px;background:#3498db;border-radius:50%;animation:dotPulse 1.5s infinite ease-in-out}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}.conversation-log{position:fixed;bottom:20px;left:20px;width:350px;max-height:300px;background:#fffffffa;border-radius:1.25rem;box-shadow:0 8px 30px #0000001f;z-index:50;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(52,152,219,.1)}.log-header{background:linear-gradient(135deg,#3498db,#5dade2);color:#fff;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center}.log-header h3{margin:0;font-size:1.1rem;font-weight:600}.close-log{background:#fff3;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:.25rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.close-log:hover{background:#ffffff4d}.log-content{max-height:220px;overflow-y:auto;padding:1.25rem}.log-message{margin-bottom:1rem;font-size:.9rem;line-height:1.5;color:#2c3e50}.log-message strong{color:#3498db;font-weight:600}.no-messages{color:#7f8c8d;font-style:italic;text-align:center;margin:1.5rem 0;font-size:.9rem}@keyframes bubbleAppear{0%{opacity:0;transform:translate(-50%) translateY(15px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes dotPulse{0%,60%,to{transform:scale(1);opacity:1}30%{transform:scale(.7);opacity:.4}}@keyframes pulse{0%{transform:scale(1);opacity:1;box-shadow:0 0 10px #2ecc7180}50%{transform:scale(1.2);opacity:.8;box-shadow:0 0 20px #2ecc71cc}to{transform:scale(1);opacity:1;box-shadow:0 0 10px #2ecc7180}}@media (max-width: 768px){.header-controls{padding:1rem;flex-direction:column;gap:1rem;text-align:center}.logo{flex-direction:column;gap:.5rem}.logo h1{font-size:1.5rem}.subtitle{font-size:.85rem}.controls{flex-wrap:wrap;justify-content:center;gap:.5rem}.control-btn{padding:.6rem 1rem;font-size:.85rem;min-width:120px}.api-warning{font-size:.8rem;padding:.6rem 1rem;text-align:center}.character-avatar{width:50px;height:50px}.speech-bubble{min-width:180px;max-width:min(400px,95vw)}.conversation-log{width:calc(100vw - 40px);left:20px;right:20px}.scene-background{margin-top:140px}}@media (max-width: 480px){.header-controls{padding:.75rem}.controls{gap:.4rem}.control-btn{padding:.5rem .8rem;font-size:.8rem;min-width:100px}.logo h1{font-size:1.3rem}.house-icon{font-size:2rem}.bubble-content{padding:.8rem 1.2rem;font-size:.9rem;line-height:1.3;max-height:100px}}
