@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap");:root{--bg:#0c0a14;--bg-gradient-start:#0f0e1a;--bg-gradient-end:#14122a;--surface:rgba(26,25,48,.85);--surface-card:rgba(30,28,55,.95);--surface-hover:rgba(50,47,85,.6);--border:rgba(99,102,241,.2);--border-light:hsla(0,0%,100%,.06);--text:#f4f3f8;--text-muted:#a5a3b8;--accent:#6366f1;--accent-light:#818cf8;--accent-glow:rgba(99,102,241,.4);--user-bubble:linear-gradient(135deg,#4f46e5,#6366f1 50%,#7c3aed);--assistant-bubble:var(--surface-card);--success:#34d399;--error:#f87171;--mic-idle:linear-gradient(135deg,#6366f1,#8b5cf6);--mic-recording:#ef4444;--radius:20px;--radius-sm:12px;--radius-pill:999px;--shadow:0 8px 32px rgba(0,0,0,.35);--shadow-glow:0 0 40px var(--accent-glow);--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(99,102,241,.15),transparent),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(139,92,246,.08),transparent),linear-gradient(180deg,var(--bg-gradient-start) 0,var(--bg-gradient-end) 100%);color:var(--text);overflow-x:hidden;line-height:1.5}#__next,body,main{min-height:100dvh;min-height:100vh}#__next,main{display:flex;flex-direction:column}.header{padding:24px 20px 20px;text-align:center;background:linear-gradient(180deg,rgba(99,102,241,.12),transparent 70%);border-bottom:1px solid var(--border-light)}.teacher-avatar-wrap{display:flex;justify-content:center;margin-bottom:14px}.teacher-robot{position:relative;display:inline-flex;align-items:center;justify-content:center;filter:drop-shadow(0 8px 24px rgba(99,102,241,.35))}.teacher-robot.speaking .teacher-pulse{position:absolute;inset:-8px;border-radius:50%;background:var(--accent-glow);animation:teacherSpeak 1.2s ease-in-out infinite;pointer-events:none}@keyframes teacherSpeak{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.15}}.teacher-robot.small{flex-shrink:0}.header h1{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;color:var(--text);margin-bottom:4px}.header p{font-size:.8rem;color:var(--text-muted)}.header .badge{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:6px 14px;border-radius:var(--radius-pill);background:rgba(99,102,241,.2);border:1px solid var(--border);font-size:.75rem;font-weight:600;color:var(--accent-light)}.header .badge-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:badgePulse 2s ease-in-out infinite}.restart-btn{margin-top:12px;padding:8px 16px;border-radius:var(--radius-pill);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .2s,border-color .2s,background .2s}.restart-btn:hover{color:var(--text);border-color:var(--border);background:hsla(0,0%,100%,.05)}.voice-selector{margin-top:16px;padding-top:14px;border-top:1px solid var(--border-light)}.voice-label{display:block;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.voice-hint,.voice-label{font-size:.7rem;color:var(--text-muted)}.voice-hint{margin-top:6px;margin-bottom:0}.voice-select{width:100%;max-width:280px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-card);color:var(--text);font-size:.85rem;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding:10px 36px 10px 14px}.voice-select:focus,.voice-select:hover{border-color:var(--accent);outline:none}.voice-options{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.voice-btn{padding:8px 16px;border-radius:var(--radius-pill);border:1px solid var(--border);background:rgba(99,102,241,.1);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s,border-color .2s;-webkit-tap-highlight-color:transparent}.voice-btn:hover{background:rgba(99,102,241,.2);color:var(--text)}.voice-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.5}}.chat-area{flex:1 1;overflow-y:auto;padding:20px 16px 100px;padding-bottom:calc(100px + var(--safe-bottom));display:flex;flex-direction:column;gap:20px}.message.processing-in-chat{align-self:flex-start;max-width:92%;display:flex;gap:12px;align-items:flex-start}.message.processing-in-chat .message-inner.processing-inner{padding:16px 20px;border-radius:var(--radius);border-top-left-radius:6px;background:var(--surface-card);border:1px solid var(--border-light);box-shadow:var(--shadow);min-width:200px}.processing-dots{display:flex;gap:6px;margin-bottom:10px}.processing-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent-light);animation:processingBounce 1.4s ease-in-out infinite both}.processing-dots span:first-child{animation-delay:0s}.processing-dots span:nth-child(2){animation-delay:.2s}.processing-dots span:nth-child(3){animation-delay:.4s}@keyframes processingBounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.processing-text{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:4px}.processing-sub{font-size:.8rem;color:var(--text-muted);margin:0}.message.user{align-self:flex-end;max-width:85%;display:flex;align-items:flex-end;gap:10px;flex-direction:row-reverse}.message.user .message-inner{padding:14px 18px;border-radius:var(--radius);border-top-right-radius:6px;background:var(--user-bubble);box-shadow:0 4px 20px rgba(99,102,241,.25)}.message.user .label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:hsla(0,0%,100%,.8);margin-bottom:4px}.message.user .transcript{font-size:1rem;font-weight:500;color:#fff}.message.user .avatar-wrap{width:36px;height:36px;border-radius:50%;background:hsla(0,0%,100%,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.message.assistant{align-self:flex-start;max-width:92%;display:flex;gap:12px;align-items:flex-start}.message.assistant .avatar-wrap{flex-shrink:0}.message.assistant .message-inner{flex:1 1;padding:16px 18px;border-radius:var(--radius);border-top-left-radius:6px;background:var(--assistant-bubble);border:1px solid var(--border-light);box-shadow:var(--shadow)}.message.assistant .assistant-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.message.assistant .assistant-head .label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-light);margin-bottom:0}.message .label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px}.message .correction{font-size:1.1rem;font-weight:700;color:var(--text);line-height:1.45;padding:10px 14px;background:rgba(99,102,241,.12);border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.message .row{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light)}.message .row:first-of-type{margin-top:10px;padding-top:10px;border-top:none}.message .row-label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.message .row-value{font-size:.95rem;color:var(--text);line-height:1.5}.message .row.mistake .row-value{color:var(--error)}.message .correction-row .correction{margin-top:4px}.message .correction-failed{margin-top:4px;display:flex;flex-direction:column;gap:10px}.message .retry-translation-btn{align-self:flex-start;padding:6px 14px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--accent-light);font-size:.85rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,color .2s}.message .retry-translation-btn:hover:not(:disabled){background:rgba(99,102,241,.15);color:var(--accent)}.message .retry-translation-btn:disabled{opacity:.7;cursor:not-allowed}.message .explanation{font-size:.9rem;color:var(--text-muted);margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);line-height:1.5}.message .next-question{font-size:.95rem;color:var(--accent-light);margin-top:12px;font-weight:600}.message .next-question span{color:var(--text-muted);font-weight:500;font-size:.8rem}.score-chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light)}.score-chip{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--text-muted)}.score-stars{display:inline-flex;gap:2px}.score-stars .star{color:var(--border);font-size:1rem}.score-stars .star.filled{color:#fbbf24}.message audio{width:100%;margin-top:12px;border-radius:var(--radius-sm);height:44px;background:rgba(0,0,0,.2)}.message .audio-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px}.message .audio-row audio{margin-top:0;flex:1 1;min-width:140px}.message .play-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-pill);border:none;background:linear-gradient(135deg,var(--accent) 0,#7c3aed 100%);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 4px 14px rgba(99,102,241,.4);-webkit-tap-highlight-color:transparent;transition:transform .15s ease,box-shadow .2s ease}.message .play-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,.5)}.message .play-btn.playing,.message .play-btn:disabled{opacity:.85;cursor:default;transform:none}.welcome-card{max-width:400px;margin:0 auto;padding:28px 24px;border-radius:var(--radius);background:var(--surface-card);border:1px solid var(--border-light);box-shadow:var(--shadow);text-align:center}.welcome-card .welcome-icon{width:56px;height:56px;margin:0 auto 16px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0,#7c3aed 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(99,102,241,.35);color:#fff}.welcome-card h2{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:12px}.welcome-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin-bottom:8px}.welcome-card p:last-of-type{margin-bottom:0}.welcome-example{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);font-size:.85rem;color:var(--text-muted)}.welcome-tip{font-size:.85rem;color:var(--accent-light);font-weight:500;margin-top:4px}.welcome-example em{font-style:normal;font-weight:600}.welcome-card strong,.welcome-example em{color:var(--accent-light)}.status-wrap{display:flex;justify-content:center;padding:8px 0;min-height:44px;align-items:center}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-pill);font-size:.85rem;font-weight:600;background:rgba(99,102,241,.2);border:1px solid var(--border);color:var(--accent-light)}.status-pill.recording{background:rgba(239,68,68,.2);border-color:rgba(239,68,68,.4);color:#f87171;animation:statusPulse 1.5s ease-in-out infinite}.status-pill.error{background:hsla(0,91%,71%,.15);border-color:hsla(0,91%,71%,.4);color:var(--error)}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.85}}.status-pill-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.status-pill.recording .status-pill-dot{background:#ef4444;animation:dotPulse .8s ease-in-out infinite}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.mic-bar{position:fixed;bottom:0;left:0;right:0;padding:20px 16px;padding-bottom:calc(20px + var(--safe-bottom));background:linear-gradient(0deg,var(--bg) 0,var(--bg) 60%,transparent 100%);display:flex;flex-direction:column;align-items:center;gap:12px}.mic-hint{font-size:.8rem;color:var(--text-muted);font-weight:500}.mic-btn{width:80px;height:80px;border-radius:50%;border:none;background:var(--mic-idle);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(99,102,241,.45);transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.mic-btn:hover{transform:scale(1.05);box-shadow:0 12px 40px rgba(99,102,241,.5)}.mic-btn:active{transform:scale(.98)}.mic-btn.recording{background:var(--mic-recording);box-shadow:0 8px 32px rgba(239,68,68,.45);animation:micPulse 1.2s ease-in-out infinite}@keyframes micPulse{0%,to{box-shadow:0 0 0 0 rgba(239,68,68,.5)}50%{box-shadow:0 0 0 20px rgba(239,68,68,0)}}.mic-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;animation:none}.summary-bar{display:flex;justify-content:center;padding:12px 16px;background:rgba(99,102,241,.08);border-top:1px solid var(--border-light)}.summary-btn{padding:12px 24px;border-radius:var(--radius-pill);border:1px solid var(--border);background:linear-gradient(135deg,var(--accent) 0,#7c3aed 100%);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s ease,box-shadow .2s ease}.summary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,.5)}.summary-btn:disabled{opacity:.7;cursor:not-allowed}.summary-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.summary-backdrop{position:absolute;inset:0;background:rgba(12,10,20,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.summary-card{position:relative;max-width:480px;width:100%;padding:24px;border-radius:var(--radius);background:var(--surface-card);border:1px solid var(--border-light);box-shadow:var(--shadow);max-height:85vh;overflow-y:auto}.summary-title{font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:16px}.summary-tamil{font-size:1rem;color:var(--text);line-height:1.6;margin-bottom:20px;white-space:pre-wrap}.summary-key-sentences h3{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px}.summary-key-text{font-size:.95rem;color:var(--text);line-height:1.6;white-space:pre-wrap;font-family:inherit;margin:0;padding:14px;background:rgba(0,0,0,.2);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.summary-close{display:block;width:100%;margin-top:20px;padding:12px 20px;border-radius:var(--radius-pill);border:1px solid var(--border);background:rgba(99,102,241,.2);color:var(--accent-light);font-size:.9rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,color .2s}.summary-close:hover{background:rgba(99,102,241,.35);color:var(--text)}