:root{--bg:#87ceeb;--fg:#0b1320;--accent:gold;--listening:#ff8c00;--thinking:#7a7a7a;--speaking:#1db954}html,body{height:100%}body{background:var(--bg);color:var(--fg);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji}.appShell{flex-direction:column;min-height:100vh;display:flex}.appHeader{background:gold;border-bottom:1px solid #ffffff14;flex-direction:column;gap:4px;padding:18px 20px;display:flex}.appHeaderBrand{letter-spacing:.2px;color:#0b1320;font-weight:800}.appMain{flex:1;gap:0;min-height:0;padding:16px;display:flex}.leftColumn{color:var(--fg);background:linear-gradient(#87ceeb 0%,#5babde 100%);border-radius:18px 0 0 18px;flex:0 0 65%;min-width:0;min-height:0;padding:18px 10px;display:flex;position:relative;overflow:hidden}.leftInner{z-index:2;background:0 0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;min-height:0;display:flex;position:relative}.stageStatus{text-align:center;letter-spacing:.1px;text-shadow:0 1px #ffffff40;margin-top:2px;font-weight:800}.stageStatus.idle{color:#0b1320}.stageStatus.listening{color:var(--listening)}.stageStatus.thinking{color:var(--thinking)}.stageStatus.speaking{color:var(--speaking)}.micButtonWrap{justify-content:center;margin-top:4px;display:flex}.rightColumn{color:var(--fg);background:#f0f8ff;border-left:3px solid #ffd700a6;border-radius:0 18px 18px 0;flex-direction:column;flex:0 0 35%;min-width:0;min-height:0;padding:14px 14px 10px;display:flex}.chatPanelHeader{color:#0b1320;background:var(--accent);letter-spacing:.2px;border-radius:14px;margin:0;padding:10px;font-weight:900}.chatPanelHeaderRow{justify-content:space-between;align-items:center;gap:10px;width:100%;margin-bottom:10px;display:flex}.newChatButton{color:#fff;cursor:pointer;white-space:nowrap;background:#ff8c00;border:0;border-radius:14px;padding:10px 14px;font-weight:900;transition:transform .12s,opacity .15s}.newChatButton:hover:not(:disabled){transform:translateY(-1px)}.newChatButton:disabled{cursor:not-allowed;opacity:.65}.sunnyDuck{background:var(--accent);color:#0b1320;-webkit-user-select:none;user-select:none;border-radius:9999px;justify-content:center;align-items:center;width:300px;height:300px;font-weight:900;transition:transform .2s,filter .2s,opacity .2s;display:flex;box-shadow:0 14px 35px #00000059}.sunnyDuckContainer{background:0 0;justify-content:center;align-items:center;width:420px;height:420px;display:flex}.sunnyDuckContainer video{object-fit:cover;width:100%;height:100%}.sunny-circle{background:#dcebf5d9;border-radius:50%;justify-content:center;align-items:center;width:380px;height:380px;display:flex;overflow:hidden;box-shadow:0 0 0 6px #dcebf580,0 0 0 12px #dcebf540,0 8px 32px #00000026}.sunny-circle video{object-fit:contain;width:100%;height:100%}.sunny-idle{animation:1.8s ease-in-out infinite sunnyBounce}.sunny-speaking{filter:brightness(1.05);transform:scale(1.02)}.sunny-listening{filter:hue-rotate(12deg)brightness(1.1);transform:scale(1.05)}@keyframes sunnyBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.voiceButton{cursor:pointer;color:#0b1320;background:#ff8c00;border:0;border-radius:9999px;justify-content:center;align-items:center;width:86px;height:86px;font-size:26px;transition:transform .12s,background .15s,opacity .15s;display:flex;box-shadow:0 18px 35px #ff8c0059}.voiceButton:hover{transform:translateY(-1px)}.voiceButton:disabled{cursor:not-allowed}.voiceButton.listening{background:#ff8c00;animation:1s ease-in-out infinite voicePulse;box-shadow:0 18px 35px #ff8c0073}.voiceButton.thinking{color:#0b1320cc;box-shadow:none;background:#ffffff47}@keyframes voicePulse{0%,to{transform:scale(1)}50%{transform:scale(1.07)}}.chatLog{flex:1;height:auto;min-height:0;max-height:none;padding:10px 4px 14px;overflow:auto}.statusMessage{width:100%;color:var(--fg);box-sizing:border-box;background:#ffffffc7;border:1px solid #0000001a;border-radius:12px;margin:0 0 10px;padding:10px 12px}.statusMessage.error{background:#ff8c0024;border-color:#ff8c0099}.chatInputRow{box-sizing:border-box;gap:10px;width:100%;padding:0 4px 6px;display:flex}.chatInput{color:var(--fg);box-sizing:border-box;background:#00000040;border:1px solid #ffffff1f;border-radius:14px;outline:none;flex:1;padding:12px 14px;font-size:16px}.chatInput:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ffd7002e}.sendButton{background:var(--accent);color:#0b1320;cursor:pointer;border:0;border-radius:14px;width:108px;font-weight:900;transition:transform .12s,opacity .15s}.sendButton:hover:not(:disabled){transform:translateY(-1px)}.sendButton:disabled{cursor:not-allowed;opacity:.65}@media (width<=980px){.appMain{flex-direction:column;gap:12px;padding:14px}.leftColumn,.rightColumn{border-radius:18px;flex:1;padding:18px 10px}.rightColumn{border-top:2px solid #ffd70059;border-left:0}}.chatRow{width:100%;margin:10px 0;display:flex}.chatRow.user{justify-content:flex-end}.chatRow.assistant{justify-content:flex-start}.bubble{white-space:pre-wrap;border-radius:16px;max-width:86%;padding:12px 14px;line-height:1.3;box-shadow:0 10px 25px #0000002e}.bubble.user{color:#0b1320;background:#ff8c00f2}.bubble.assistant{color:#0b1320;background:#ffd700eb}.bubbleHeader{opacity:.95;align-items:center;gap:8px;margin-bottom:6px;font-weight:800;display:flex}.bubbleHeader .duckIcon{font-size:16px}.envToggleRow{z-index:3;flex-wrap:wrap;justify-content:center;gap:8px;width:100%;display:flex}.envToggleButton{color:#0b1320;cursor:pointer;background:#ffffff2e;border:1px solid #ffd7008c;border-radius:999px;padding:8px 10px;font-size:12px;font-weight:900;transition:transform .12s,background .15s}.envToggleButton:hover:not(:disabled){transform:translateY(-1px)}.envToggleButton.active{background:var(--accent);border-color:#ffd700f2}.leftColumn.env-sunny{background:linear-gradient(#87ceeb 0%,#5babde 100%)}.leftColumn.env-safety{background:repeating-linear-gradient(135deg,#ff8c00 0 20px,gold 20px 40px)}.leftColumn.env-safety:after{content:"";z-index:0;pointer-events:none;background:#0b132024;position:absolute;inset:0}.leftColumn.env-pond{background:linear-gradient(#87ceeb 0%,#2f9fe3 45%,#3aa85a 100%)}.envDecor,.sunDecor,.cloud,.cone,.lily,.ripple{pointer-events:none;z-index:1;display:none;position:absolute}.leftColumn.env-sunny .sunDecor,.leftColumn.env-sunny .cloud{display:block}.sunDecor{background:radial-gradient(circle,gold 0% 38%,#ffd70000 39%),repeating-conic-gradient(#ffd700f2 0deg 10deg,#ffd70000 10deg 20deg);border-radius:9999px;width:120px;height:120px;top:18px;right:22px;box-shadow:0 0 0 8px #ffd70014}.cloud{filter:drop-shadow(0 10px 14px #0000001f);background:#fffffff5;border-radius:999px;width:180px;height:58px;animation:6s ease-in-out infinite cloudFloat}.cloud:before,.cloud:after{content:"";background:#fffffff5;border-radius:50%;position:absolute}.cloud:before{width:92px;height:68px;top:-22px;left:18px}.cloud:after{width:72px;height:54px;top:-14px;left:92px}.cloud1{--cloudScale:.95;top:20px;left:10%}.cloud2{--cloudScale:.75;animation-delay:-2.3s;top:38px;left:40%}.cloud3{--cloudScale:.9;animation-delay:-3.8s;top:26px;left:68%}@keyframes cloudFloat{0%,to{transform:translateX(0) scale(var(--cloudScale,1))}50%{transform:translateX(10px) scale(var(--cloudScale,1))}}.leftColumn.env-safety .cone{display:block}.cone{filter:drop-shadow(0 10px 14px #00000040);font-size:26px}.cone1{top:20px;left:20px}.cone2{top:20px;right:20px}.cone3{bottom:28px;right:40px}.leftColumn.env-pond .lily,.leftColumn.env-pond .ripple{display:block}.lily{filter:drop-shadow(0 10px 12px #0000002e);font-size:30px}.lily1{bottom:24px;left:16%}.lily2{bottom:18px;left:42%;transform:rotate(-8deg)}.lily3{bottom:26px;left:68%;transform:rotate(10deg)}.ripple{opacity:.9;font-size:22px;animation:2.8s ease-in-out infinite ripplePulse}.ripple1{top:46%;left:30%}.ripple2{animation-delay:-1.2s;top:52%;left:60%}.ripple3{animation-delay:-2.1s;top:50%;left:45%}@keyframes ripplePulse{0%,to{opacity:.75;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}.modalOverlay{z-index:9999;background:#0b13208c;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.modal{color:#0b1320;background:linear-gradient(#87ceeb 0%,#5babde 100%);border:2px solid #ffd700f2;border-radius:18px;width:min(460px,92vw);padding:16px 16px 14px;box-shadow:0 22px 50px #00000059}.modalTitle{letter-spacing:.1px;color:#0b1320;margin-bottom:10px;font-weight:1000}.modalForm{flex-direction:column;gap:14px;display:flex}.modalInput{color:#0b1320;box-sizing:border-box;background:#f0f8ffe0;border:2px solid #0b132040;border-radius:14px;outline:none;width:100%;padding:12px 14px;font-size:16px}.modalInput:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ffd70038}.modalActions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.modalConfirmButton{color:#fff;cursor:pointer;background:#ff8c00;border:0;border-radius:14px;padding:10px 14px;font-weight:1000}.modalCancelButton{color:#0b1320;cursor:pointer;background:#f0f8ff33;border:2px solid #ffd700f2;border-radius:14px;padding:8px 12px;font-weight:1000}.modalConfirmButton:disabled,.modalCancelButton:disabled{cursor:not-allowed;opacity:.7}@media (width<=520px){.modalActions{justify-content:stretch}.modalConfirmButton,.modalCancelButton{flex:1}}.nameEntryOverlay{background:linear-gradient(#87ceeb 0%,#5babde 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.nameEntryCard{text-align:center;background:#ffffff2e;border:2px solid #ffd700b3;border-radius:24px;flex-direction:column;align-items:center;gap:12px;width:min(420px,92vw);padding:40px 32px 36px;display:flex;box-shadow:0 22px 50px #0003}.nameEntryDuck{margin-bottom:4px;font-size:64px;line-height:1}.nameEntryHeading{color:#0b1320;letter-spacing:.1px;margin:0;font-size:1.6rem;font-weight:900}.nameEntrySubtext{color:#1a2a40;opacity:.85;margin:0;font-size:.97rem}.nameEntryForm{flex-direction:column;gap:12px;width:100%;margin-top:8px;display:flex}.nameEntryInput{color:#0b1320;box-sizing:border-box;text-align:center;background:#f0f8ffe6;border:2px solid #0b132033;border-radius:14px;outline:none;width:100%;padding:14px 16px;font-size:1rem}.nameEntryInput:focus{border-color:gold;box-shadow:0 0 0 3px #ffd70040}.nameEntrySelect{color:#0b1320;box-sizing:border-box;cursor:pointer;appearance:none;background:#f0f8ffe6 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230b1320' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") right 16px center no-repeat;border:2px solid #0b132033;border-radius:14px;outline:none;width:100%;padding:14px 40px 14px 16px;font-size:1rem}.nameEntrySelect:focus{border-color:gold;box-shadow:0 0 0 3px #ffd70040}.nameEntryError{color:#c0392b;margin:0;font-size:.88rem;font-weight:700}.nameEntryButton{color:#0b1320;cursor:pointer;background:gold;border:0;border-radius:14px;width:100%;padding:14px;font-size:1.05rem;font-weight:900;transition:transform .12s,opacity .15s}.nameEntryButton:hover{transform:translateY(-2px)}.nameEntryButton:active{opacity:.9;transform:translateY(0)}
