.app.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;text-align:center}.app.login-screen{display:flex;justify-content:center;align-items:center;min-height:100vh}.login-container{text-align:center;padding:2rem;background:#ffffff0d;border-radius:16px;width:100%;max-width:320px}.login-container h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#f5f5f6,#bdbdc2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .25rem}.login-subtitle{color:#ffffff80;margin:0 0 2rem;font-size:1rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0d;color:#fff;font-size:1rem;transition:border-color .2s,background .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#d0d0d5;background:#ffffff14}.form-group input::placeholder{color:#fff6}.form-group input:disabled{opacity:.6;cursor:not-allowed}.auth-error{padding:.75rem;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fffc;font-size:.875rem}.login-button{padding:.75rem 1.5rem;border:none;border-radius:8px;background:linear-gradient(135deg,#f0f0f2,#b8b8be);color:#111113;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ffffff40}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.app{display:flex;flex-direction:column;min-height:100vh}.kid-ui{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:3rem 1.5rem 2rem;min-height:60vh}.gear-button{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;border:none;background:#ffffff14;color:#ffffff59;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.gear-button:hover{background:#ffffff24;color:#fff9}.story-titles{text-align:center;display:flex;flex-direction:column;gap:.35rem}.series-title{font-size:clamp(1.25rem,4vw,1.75rem);font-weight:600;color:#ffffffe6}.story-title{font-size:clamp(1rem,3vw,1.375rem);font-weight:400;color:#ffffff8c}.mic-button{width:88px;height:88px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;background:linear-gradient(135deg,#ffffff26,#ffffff0d);color:#ffffffe6;box-shadow:0 0 24px #fff3;touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;animation:gentle-pulse 3s ease-in-out infinite}.mic-button:hover:not(:disabled){background:linear-gradient(135deg,#ffffff38,#ffffff1a);box-shadow:0 0 36px #ffffff59;transform:scale(1.05)}.mic-button:active:not(:disabled){transform:scale(.95)}.mic-button:disabled{cursor:not-allowed;opacity:.5;animation:none}.mic-button.mic-on{width:auto;min-width:110px;height:64px;padding:0 1.5rem;border-radius:32px;gap:.5rem;background:radial-gradient(circle,#ffffff47,#ffffff1a);color:#fff;box-shadow:0 0 28px #ffffff73;animation:none}.mic-button.mic-on:hover{background:radial-gradient(circle,#ffffff5c,#ffffff29);box-shadow:0 0 36px #ffffff8c}.mic-button-text{font-size:1rem;font-weight:600;white-space:nowrap}.mic-button.mic-loading{color:#ffffff4d;animation:none}.mic-spinner{animation:spin 1s linear infinite}.activity-label{font-size:1rem;color:#ffffff73;letter-spacing:.03em}.parent-panel{border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:1rem;padding:1rem 1rem 2rem}.parent-panel-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.parent-username{font-size:.875rem;color:#ffffff80}.parent-progress{font-size:.875rem;color:#ffffff59;flex:1}.logout-button{padding:.25rem .75rem;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:transparent;color:#fff6;font-size:.8rem;cursor:pointer;transition:all .2s}.logout-button:hover{border-color:#ffffff4d;color:#ffffffb3}.transcript{background:#ffffff0a;border-radius:10px;padding:1rem;max-height:250px;overflow-y:auto}.transcript .messages{display:flex;flex-direction:column;gap:.75rem}.transcript .message{padding:.6rem .875rem;border-radius:8px;line-height:1.5;font-size:.9rem}.transcript .message.user{background:#ffffff0d;border-left:3px solid rgba(255,255,255,.3)}.transcript .message.assistant{background:#ffffff12;border-left:3px solid rgba(255,255,255,.5)}.transcript .message.assistant.streaming{animation:pulse 1.5s infinite}.transcript .message.error{background:#ffffff08;border-left:3px solid rgba(255,255,255,.2)}.transcript .message strong{display:block;margin-bottom:.2rem;font-size:.8rem;opacity:.6}.log-messages{background:#00000040;border-radius:10px;padding:.75rem;max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:.2rem;font-family:Consolas,Monaco,Courier New,monospace;font-size:.72rem}.log-entry{display:flex;gap:.5rem;padding:.2rem .4rem;border-radius:4px}.log-entry .timestamp{color:#ffffff40;flex-shrink:0}.log-entry .type{font-weight:600;flex-shrink:0;min-width:65px}.log-entry.ws .type{color:#60a5fa}.log-entry.server .type{color:#34d399}.log-entry.init .type{color:#fbbf24}.log-entry.story .type{color:#a78bfa}.log-entry.vad .type{color:#8b5cf6}.log-entry.audio .type{color:#fb923c}.log-entry.error .type{color:#f87171}.log-entry.system .type{color:#94a3b8}.log-entry .message{color:#fff9;word-break:break-word}.transcript::-webkit-scrollbar,.log-messages::-webkit-scrollbar{width:6px}.transcript::-webkit-scrollbar-track,.log-messages::-webkit-scrollbar-track{background:#ffffff0a;border-radius:3px}.transcript::-webkit-scrollbar-thumb,.log-messages::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes gentle-pulse{0%,to{box-shadow:0 0 24px #fff3;transform:scale(1)}50%{box-shadow:0 0 36px #ffffff59;transform:scale(1.03)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#0f0f10,#1a1a1c,#26262a);min-height:100vh;color:#fff}#root{min-height:100vh;display:flex;flex-direction:column}
