@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 16px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .2);--shadow-glow: 0 0 40px rgba(26, 107, 191, .22);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.16, 1, .3, 1);--bg-primary: #0c0d12;--bg-secondary: #141520;--bg-card: rgba(22, 24, 36, .75);--bg-card-hover: rgba(30, 33, 50, .85);--bg-input: rgba(22, 24, 36, .9);--bg-badge: rgba(26, 107, 191, .15);--bg-loading: rgba(22, 24, 36, .95);--border-subtle: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .1);--border-input-focus: rgba(26, 107, 191, .55);--text-primary: #e8e9f0;--text-secondary: #8b8ea3;--text-muted: #5c5f73;--text-accent: #7eb8f7;--text-link: #5aa3f0;--text-link-hover: #7eb8f7;--accent: #1a6bbf;--accent-soft: rgba(26, 107, 191, .2);--meta-bg: rgba(255, 255, 255, .05);--diff-delete-bg: rgba(239, 68, 68, .12);--diff-delete-text: #f87171;--diff-insert-bg: rgba(52, 211, 153, .12);--diff-insert-text: #34d399;--scrollbar-track: transparent;--scrollbar-thumb: rgba(255, 255, 255, .1);--icon-color: #9ca3b0}@media(prefers-color-scheme:light){:root{--bg-primary: #f5f5f8;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .85);--bg-card-hover: rgba(255, 255, 255, .95);--bg-input: rgba(255, 255, 255, .95);--bg-badge: rgba(0, 53, 128, .09);--bg-loading: rgba(255, 255, 255, .95);--border-subtle: rgba(0, 0, 0, .06);--border-input: rgba(0, 0, 0, .12);--border-input-focus: rgba(0, 53, 128, .45);--text-primary: #1a1b25;--text-secondary: #5c5f73;--text-muted: #8b8ea3;--text-accent: #003580;--text-link: #0047a8;--text-link-hover: #003580;--accent: #003580;--accent-soft: rgba(0, 53, 128, .1);--meta-bg: rgba(0, 0, 0, .04);--diff-delete-bg: rgba(239, 68, 68, .08);--diff-delete-text: #dc2626;--diff-insert-bg: rgba(22, 163, 74, .08);--diff-insert-text: #16a34a;--scrollbar-track: transparent;--scrollbar-thumb: rgba(0, 0, 0, .12);--icon-color: #4b505f;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow: 0 0 40px rgba(0, 53, 128, .12)}}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--radius-full)}.app-container{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem;position:relative}.ambient-glow{position:fixed;top:-200px;left:50%;transform:translate(-50%);width:600px;height:400px;background:radial-gradient(ellipse,rgba(26,107,191,.1) 0%,transparent 70%);pointer-events:none;z-index:-1}@media(prefers-color-scheme:light){.ambient-glow{background:radial-gradient(ellipse,rgba(0,53,128,.06) 0%,transparent 70%)}}.app-header{text-align:center;margin-bottom:2.5rem}.app-title{font-size:1.75rem;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:.25rem}.app-title .accent{background:linear-gradient(135deg,var(--accent),#4a9fe0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{font-size:.875rem;color:var(--text-muted);font-weight:400}.back-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-muted);text-decoration:none;transition:color var(--transition-fast);margin-bottom:.5rem}.back-link:hover{color:var(--text-accent)}.app-footer{text-align:center;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border-subtle);color:var(--text-muted);font-size:.75rem;line-height:1.8}.app-footer a{color:var(--text-accent);text-decoration:none;transition:color var(--transition-fast)}.app-footer a:hover{color:var(--accent)}@media(max-width:600px){.app-container{padding:1.5rem 1rem 3rem}.app-title{font-size:1.35rem}}.footer-actions{display:flex;justify-content:center;gap:.6rem;flex-wrap:wrap;margin-bottom:1.25rem}.report-bug-btn{display:inline-flex;align-items:center;background:transparent;border:1.5px solid var(--border-input);border-radius:var(--radius-full);padding:.45rem 1rem;font-family:var(--font-sans);font-size:.78rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);text-decoration:none}.report-bug-btn:hover{color:var(--text-accent);border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}.report-bug-btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-full)}a.report-bug-btn,a.report-bug-btn:hover{color:var(--text-secondary)}a.report-bug-btn:hover{color:var(--text-accent)}.report-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;transition:opacity .2s ease}.report-modal-overlay.hidden{display:none}.report-modal-overlay.open{opacity:1}@media(prefers-color-scheme:light){.report-modal-overlay{background:#0000004d}}.report-modal{width:100%;max-width:480px;background:var(--bg-card);border:1px solid var(--border-input);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-lg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transform:translateY(12px) scale(.98);transition:transform .22s cubic-bezier(.16,1,.3,1)}.report-modal-overlay.open .report-modal{transform:translateY(0) scale(1)}.report-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.report-modal-title{font-size:1rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.report-modal-close{background:none;border:none;padding:.2rem .4rem;font-size:.9rem;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);line-height:1;-webkit-user-select:none;user-select:none}.report-modal-close:hover{color:var(--text-primary);background:var(--meta-bg)}.report-modal-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.report-modal-hint{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.report-textarea{width:100%;padding:.875rem 1rem;font-family:var(--font-sans);font-size:.9rem;color:var(--text-primary);background:var(--bg-input);border:1.5px solid var(--border-input);border-radius:var(--radius-md);outline:none;resize:vertical;min-height:110px;line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.report-textarea::placeholder{color:var(--text-muted)}.report-textarea:focus{border-color:var(--border-input-focus);box-shadow:0 0 0 3px var(--accent-soft)}.report-char-count{font-size:.72rem;color:var(--text-muted);text-align:right;margin-top:.35rem;margin-bottom:1rem}.suggest-email-label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.4rem}.suggest-email-optional{font-weight:400;color:var(--text-muted)}.suggest-email-input{width:100%;padding:.65rem 1rem;font-family:var(--font-sans);font-size:.9rem;color:var(--text-primary);background:var(--bg-input);border:1.5px solid var(--border-input);border-radius:var(--radius-md);outline:none;margin-bottom:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.suggest-email-input::placeholder{color:var(--text-muted)}.suggest-email-input:focus{border-color:var(--border-input-focus);box-shadow:0 0 0 3px var(--accent-soft)}.report-session-label{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:1rem;padding:.65rem .85rem;background:var(--meta-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:1.4}.report-session-checkbox{margin-top:.15rem;flex-shrink:0;accent-color:var(--accent);width:15px;height:15px;cursor:pointer}.report-session-label>div{font-size:.85rem;font-weight:500;color:var(--text-primary)}.report-session-hint{display:block;font-size:.75rem;font-weight:400;color:var(--text-muted);margin-top:.15rem}.report-actions{display:flex;justify-content:flex-end;gap:.6rem}.report-cancel,.report-submit{padding:.55rem 1.1rem;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);border:1.5px solid transparent}.report-cancel{background:var(--meta-bg);color:var(--text-secondary);border-color:var(--border-subtle)}.report-cancel:hover{background:var(--bg-card-hover);color:var(--text-primary)}.report-submit{background:var(--accent);color:#fff}.report-submit:hover:not(:disabled){background:#1e40af;box-shadow:0 0 0 3px var(--accent-soft);transform:translateY(-1px)}.report-submit:disabled{opacity:.6;cursor:not-allowed}.report-cancel:focus-visible,.report-submit:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.report-feedback{margin-top:.85rem;font-size:.82rem;padding:.5rem .75rem;border-radius:var(--radius-sm);line-height:1.4}.report-feedback.hidden{display:none}.report-feedback--success{background:var(--diff-insert-bg);color:var(--diff-insert-text)}.report-feedback--error{background:var(--diff-delete-bg);color:var(--diff-delete-text)}.report-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%) translateY(8px);z-index:1100;background:var(--bg-card);border:1px solid var(--border-input);border-radius:var(--radius-full);padding:.6rem 1.25rem;font-size:.82rem;color:var(--text-secondary);box-shadow:var(--shadow-md);opacity:0;transition:opacity .22s ease,transform .22s ease;pointer-events:none;white-space:nowrap}.report-toast.open{opacity:1;transform:translate(-50%) translateY(0)}@media(max-width:600px){.report-modal{padding:1.35rem;border-radius:var(--radius-md)}.report-actions{flex-direction:column-reverse}.report-cancel,.report-submit{width:100%;text-align:center}}:root{--bubble-char-bg: rgba(30, 33, 50, .85);--bubble-char-border: rgba(255, 255, 255, .07);--bubble-user-bg: rgba(26, 107, 191, .22);--bubble-user-border: rgba(26, 107, 191, .35);--assess-bg: rgba(15, 17, 28, .7);--assess-border: rgba(255, 255, 255, .05);--grammar-fg: #f87171;--grammar-bg: rgba(248, 113, 113, .1);--vocab-fg: #fbbf24;--vocab-bg: rgba(251, 191, 36, .1);--praise-fg: #34d399;--praise-bg: rgba(52, 211, 153, .1);--level-a1-bg: rgba(52, 211, 153, .14);--level-a1-fg: #34d399;--level-a2-bg: rgba(56, 189, 248, .14);--level-a2-fg: #38bdf8;--level-b1-bg: rgba(167, 139, 250, .14);--level-b1-fg: #a78bfa;--level-b2-bg: rgba(251, 191, 36, .14);--level-b2-fg: #fbbf24}@media(prefers-color-scheme:light){:root{--bubble-char-bg: rgba(240, 242, 250, .95);--bubble-char-border: rgba(0, 0, 0, .06);--bubble-user-bg: rgba(0, 53, 128, .08);--bubble-user-border: rgba(0, 53, 128, .18);--assess-bg: rgba(245, 246, 252, .9);--assess-border: rgba(0, 0, 0, .05);--grammar-fg: #dc2626;--grammar-bg: rgba(220, 38, 38, .07);--vocab-fg: #d97706;--vocab-bg: rgba(217, 119, 6, .08);--praise-fg: #059669;--praise-bg: rgba(5, 150, 105, .07);--level-a1-bg: rgba(5, 150, 105, .1);--level-a1-fg: #059669;--level-a2-bg: rgba(2, 132, 199, .1);--level-a2-fg: #0284c7;--level-b1-bg: rgba(109, 40, 217, .1);--level-b1-fg: #6d28d9;--level-b2-bg: rgba(180, 83, 9, .1);--level-b2-fg: #b45309}}.conv-container{max-width:680px;padding-bottom:0;min-height:100dvh;display:flex;flex-direction:column}.conv-container:has(#view-chat:not(.hidden)),.conv-container:has(#view-scenes:not(.hidden)){padding:0;max-width:680px;height:100dvh;max-height:100dvh;overflow:hidden}.hidden{display:none!important}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(1rem);background:var(--accent);color:#fff;font-family:var(--font-sans);font-size:.875rem;font-weight:500;padding:.65rem 1.25rem;border-radius:var(--radius-full);box-shadow:0 4px 20px #0000004d;opacity:0;pointer-events:none;max-width:calc(100vw - 2rem);white-space:normal;text-align:center;transition:opacity .2s ease,transform .2s ease;z-index:100}.toast--visible{opacity:1;transform:translate(-50%) translateY(0)}.conv-sub-header{padding:1.25rem 0 .5rem;display:flex;align-items:center}.back-btn{background:none;border:none;font-family:var(--font-sans);font-size:.82rem;color:var(--text-muted);cursor:pointer;padding:.25rem 0;transition:color var(--transition-fast)}.back-btn:hover{color:var(--text-accent)}.back-btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}#view-scenes{display:flex;flex-direction:column;height:100dvh;max-height:100dvh;overflow:hidden;padding:2rem 1.5rem 1.5rem}#scenes-list{flex:1;overflow-y:auto;min-height:0;padding:1rem}#view-scenes .app-footer{margin-top:0;padding-top:1.25rem;border-top:1px solid var(--border-subtle);flex-shrink:0}.scenes-loading{text-align:center;color:var(--text-muted);font-size:.875rem;padding:3rem 0}.family-group{margin-bottom:2.5rem}.family-heading{display:flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.family-icon{font-size:1rem}.scenes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.scene-card{display:block;text-decoration:none;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.1rem 1.25rem;cursor:pointer;text-align:left;font-family:var(--font-sans);color:inherit;transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:scene-card-in .4s cubic-bezier(.16,1,.3,1) both}@keyframes scene-card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.scene-card:hover{background:var(--bg-card-hover);border-color:var(--border-input);box-shadow:var(--shadow-md);transform:translateY(-2px)}.scene-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.scene-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}.scene-title{font-size:.95rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em;line-height:1.3}.scene-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.45;margin:0}.level-badge{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.04em;flex-shrink:0;white-space:nowrap}.level-A1{background:var(--level-a1-bg);color:var(--level-a1-fg)}.level-A2{background:var(--level-a2-bg);color:var(--level-a2-fg)}.level-B1{background:var(--level-b1-bg);color:var(--level-b1-fg)}.level-B2{background:var(--level-b2-bg);color:var(--level-b2-fg)}.briefing-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.75rem;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:fade-up .35s cubic-bezier(.16,1,.3,1) both}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.briefing-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.briefing-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0;flex:1;min-width:0}.briefing-block{margin-bottom:1.1rem}.briefing-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.35rem}.briefing-body{margin:0;font-size:.9rem;color:var(--text-secondary);line-height:1.55}.briefing-goal-text{color:var(--text-primary);font-weight:500;background:var(--accent-soft);padding:.65rem .9rem;border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.vocab-details{margin-bottom:1.5rem;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);overflow:hidden}.vocab-summary{font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;padding:.65rem .9rem;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast),background var(--transition-fast);list-style:none}.vocab-summary::-webkit-details-marker{display:none}.vocab-summary:hover{color:var(--text-primary);background:var(--meta-bg)}.vocab-list{margin:0;padding:.5rem .9rem .75rem 1.5rem;display:flex;flex-direction:column;gap:.3rem}.vocab-list li{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.vocab-list li strong{color:var(--text-primary);font-family:var(--font-mono);font-size:.78rem}.briefing-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.4rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.9rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn-primary:hover{background:#1e5fad;box-shadow:0 0 0 3px var(--accent-soft);transform:translateY(-1px)}.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-primary:active{transform:translateY(0)}#view-chat{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden}.chat-topbar,.chat-goal-strip,.chat-window,.chat-input-row,.chat-disclaimer{max-width:720px;width:100%;margin-inline:auto}.chat-topbar{display:flex;align-items:center;justify-content:space-between;column-gap:1.5rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0;background:var(--bg-primary);box-sizing:border-box}.chat-topbar-left{display:flex;align-items:center;flex-shrink:0}.chat-topbar-actions{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.4rem .5rem;flex:1;min-width:0}@media(prefers-color-scheme:light){.chat-topbar{background:var(--bg-secondary)}}.chat-topbar-space{flex:1}.btn-finish{background:none;border:1px solid var(--border-input);border-radius:var(--radius-full);font-family:var(--font-sans);font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:.3rem .75rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.btn-finish:hover:not(:disabled){background:var(--bg-badge);border-color:var(--accent);color:var(--text-accent)}.btn-finish:disabled{opacity:.35;cursor:not-allowed}.btn-finish:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-vocab-hints{background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-family:var(--font-sans);font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:.3rem .7rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.btn-vocab-hints:hover{background:var(--bg-badge);border-color:var(--vocab-fg);color:var(--vocab-fg)}.btn-vocab-hints:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-restart{background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-family:var(--font-sans);font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:.3rem .7rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.btn-restart:hover:not(:disabled){background:var(--bg-badge);border-color:var(--text-accent);color:var(--text-accent)}.btn-restart:disabled{opacity:.35;cursor:not-allowed}.btn-restart:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-report{background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-family:var(--font-sans);font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:.3rem .7rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.btn-report:hover{background:var(--bg-badge);border-color:var(--diff-delete-text);color:var(--diff-delete-text)}.btn-report:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.chat-char-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .75rem;background:var(--bg-badge);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:var(--text-accent);letter-spacing:.01em}.chat-goal-strip{display:flex;align-items:baseline;gap:.4rem;padding:.55rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.chat-goal-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);flex-shrink:0}.chat-goal-text{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.chat-window{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;scroll-behavior:smooth}.msg{display:flex;flex-direction:column;max-width:80%;animation:msg-in .3s cubic-bezier(.16,1,.3,1) both}@keyframes msg-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.msg-char{align-self:flex-start;align-items:flex-start}.msg-user{align-self:flex-end;align-items:flex-end}.msg-sender{font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.25rem;padding:0 .15rem}.bubble{padding:.65rem .9rem;border-radius:var(--radius-md);font-size:.95rem;line-height:1.55;word-break:break-word;white-space:pre-wrap}.bubble-char{background:var(--bubble-char-bg);border:1px solid var(--bubble-char-border);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px;color:var(--text-primary);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.bubble-user{background:var(--bubble-user-bg);border:1px solid var(--bubble-user-border);border-radius:var(--radius-md) var(--radius-md) 4px var(--radius-md);color:var(--text-primary)}.translate-toggle{background:none;border:none;font-family:var(--font-sans);font-size:.7rem;color:var(--text-muted);cursor:pointer;padding:.2rem .15rem;margin-top:.25rem;transition:color var(--transition-fast);display:inline-flex;align-items:center;gap:.25rem}.translate-toggle:hover{color:var(--text-secondary)}.bubble-translation{font-size:.8rem;color:var(--text-secondary);font-style:italic;margin-top:.35rem;padding:.35rem .6rem;border-left:2px solid var(--border-input);line-height:1.45}.word-link{color:inherit;text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.3);cursor:pointer;transition:color var(--transition-fast),border-bottom-color var(--transition-fast)}.word-link:hover,.word-link:focus-visible{color:var(--text-accent);border-bottom-color:var(--text-accent);outline:none}@media(prefers-color-scheme:light){.word-link{border-bottom-color:#00000040}}.assessment-wrap{margin-top:.3rem;align-self:flex-end;max-width:82%;animation:assessment-in .4s cubic-bezier(.16,1,.3,1) both;transition:transform .3s cubic-bezier(.16,1,.3,1)}@keyframes assessment-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.assessment-details{border-radius:var(--radius-sm);border:1px solid var(--assess-border);background:var(--assess-bg);overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:border-color .3s ease,box-shadow .3s ease,background-color .3s ease}.assessment-wrap--latest .assessment-details{border-color:#1a6bbf73;box-shadow:0 4px 16px #1a6bbf1f;background:#1a6bbf0a}.assessment-wrap--latest.assessment-wrap--has-grammar .assessment-details{border-color:#f8717173;box-shadow:0 4px 16px #f8717124;background:#f8717108}.assessment-wrap--latest.assessment-wrap--has-vocab .assessment-details{border-color:#fbbf2466;box-shadow:0 4px 16px #fbbf241f;background:#fbbf2408}.assessment-wrap--latest.assessment-wrap--has-praise:not(.assessment-wrap--has-grammar):not(.assessment-wrap--has-vocab) .assessment-details{border-color:#34d39966;box-shadow:0 4px 16px #34d3991f;background:#34d39908}@media(prefers-color-scheme:light){.assessment-wrap--latest .assessment-details{border-color:#1a6bbf59;box-shadow:0 4px 16px #1a6bbf14;background:#1a6bbf05}.assessment-wrap--latest.assessment-wrap--has-grammar .assessment-details{border-color:#dc262659;box-shadow:0 4px 16px #dc262614;background:#dc262605}.assessment-wrap--latest.assessment-wrap--has-vocab .assessment-details{border-color:#d9770659;box-shadow:0 4px 16px #d9770614;background:#d9770605}.assessment-wrap--latest.assessment-wrap--has-praise:not(.assessment-wrap--has-grammar):not(.assessment-wrap--has-vocab) .assessment-details{border-color:#05966959;box-shadow:0 4px 16px #05966914;background:#05966905}}.assessment-summary{font-size:.74rem;font-weight:600;color:var(--text-muted);cursor:pointer;padding:.5rem .85rem;-webkit-user-select:none;user-select:none;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem;transition:color var(--transition-fast),background-color var(--transition-fast)}.assessment-summary::-webkit-details-marker{display:none}.assessment-summary:hover{color:var(--text-secondary);background:#ffffff08}@media(prefers-color-scheme:light){.assessment-summary:hover{background:#00000005}}.assessment-summary-title{font-weight:600;color:var(--text-muted);transition:color var(--transition-fast)}.assessment-wrap--latest .assessment-summary-title{color:var(--text-primary);font-weight:700}.assessment-summary-badges{display:inline-flex;align-items:center;gap:.4rem}.assess-badge{font-size:.64rem;font-weight:700;padding:.12rem .5rem;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.assess-badge--grammar{color:var(--grammar-fg);background:var(--grammar-bg);border:1px solid rgba(248,113,113,.15)}.assess-badge--vocab{color:var(--vocab-fg);background:var(--vocab-bg);border:1px solid rgba(251,191,36,.15)}.assess-badge--praise{color:var(--praise-fg);background:var(--praise-bg);border:1px solid rgba(52,211,153,.15)}@media(prefers-color-scheme:light){.assess-badge--grammar{border-color:#dc26261f}.assess-badge--vocab{border-color:#d977061f}.assess-badge--praise{border-color:#0596691f}}.assessment-body{padding:.6rem .85rem .75rem;display:flex;flex-direction:column;gap:.6rem;border-top:1px solid var(--assess-border)}.assess-section{display:flex;flex-direction:column;gap:.3rem}.assess-section-title{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.assess-note{font-size:.78rem;line-height:1.45;padding:.35rem .55rem;border-radius:6px}.assess-grammar{color:var(--grammar-fg);background:var(--grammar-bg)}.assess-grammar .assess-section-title{color:var(--grammar-fg)}.assess-vocab{color:var(--vocab-fg);background:var(--vocab-bg)}.assess-vocab .assess-section-title{color:var(--vocab-fg)}.assess-praise{color:var(--praise-fg);background:var(--praise-bg)}.assess-praise .assess-section-title{color:var(--praise-fg)}.assess-goal{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.note-pair{display:flex;flex-wrap:wrap;align-items:baseline;gap:.2rem .4rem}.note-original{font-family:var(--font-mono);font-size:.76rem;text-decoration:line-through;opacity:.75}.note-arrow{opacity:.55}.note-corrected{font-family:var(--font-mono);font-size:.76rem;font-weight:600}.note-explanation{font-size:.74rem;color:inherit;opacity:.85;display:block;margin-top:.1rem}.typing-indicator{display:flex;align-items:center;gap:4px;padding:.65rem .9rem;background:var(--bubble-char-bg);border:1px solid var(--bubble-char-border);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px;width:fit-content;margin-bottom:.25rem}.typing-indicator span{display:block;width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:typing-bounce 1.2s ease-in-out infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.45}30%{transform:translateY(-5px);opacity:1}}.chat-input-row{display:flex;align-items:flex-end;gap:.5rem;padding:.75rem 1.5rem 1rem;border-top:1px solid var(--border-subtle);background:var(--bg-primary);flex-shrink:0}@media(prefers-color-scheme:light){.chat-input-row{background:var(--bg-secondary)}}.chat-input{flex:1;min-width:0;padding:.6rem .85rem;font-family:var(--font-sans);font-size:.95rem;color:var(--text-primary);background:var(--bg-input);border:1.5px solid var(--border-input);border-radius:var(--radius-md);outline:none;resize:none;min-height:2.6rem;max-height:8rem;overflow-y:hidden;line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:var(--border-input-focus);box-shadow:0 0 0 3px var(--accent-soft)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.btn-send{flex-shrink:0;width:2.6rem;height:2.6rem;border-radius:50%;border:none;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn-send:hover:not(:disabled){background:#1e5fad;box-shadow:0 0 0 3px var(--accent-soft);transform:scale(1.05)}.btn-send:active:not(:disabled){transform:scale(.97)}.btn-send:disabled{opacity:.4;cursor:not-allowed}.btn-send:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.chat-disclaimer{font-size:.7rem;color:var(--text-muted);text-align:center;padding:.3rem 1.5rem .6rem;margin:0;flex-shrink:0;background:var(--bg-primary);line-height:1.5}@media(prefers-color-scheme:light){.chat-disclaimer{background:var(--bg-secondary)}}.chat-disclaimer-link{color:var(--text-muted);text-underline-offset:2px;white-space:nowrap;transition:color var(--transition-fast)}.chat-disclaimer-link:hover{color:var(--text-secondary)}.vocab-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:60;display:flex;align-items:center;justify-content:center;padding:1rem;animation:summary-backdrop-in .2s ease both}@media(prefers-color-scheme:light){.vocab-modal-backdrop{background:#00000040}}.vocab-modal{width:100%;max-width:420px;max-height:70dvh;background:var(--bg-card);border:1px solid var(--border-input);border-radius:var(--radius-lg);padding:1.25rem 1.5rem 1.5rem;overflow-y:auto;box-shadow:var(--shadow-lg);animation:vocab-modal-in .25s cubic-bezier(.16,1,.3,1) both}@keyframes vocab-modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.vocab-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.vocab-modal-title{font-size:.95rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary);margin:0}.vocab-modal-close{background:none;border:none;font-size:1rem;color:var(--text-muted);cursor:pointer;padding:.2rem .4rem;border-radius:var(--radius-sm);line-height:1;transition:color var(--transition-fast),background var(--transition-fast)}.vocab-modal-close:hover{color:var(--text-primary);background:var(--meta-bg)}.vocab-modal-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.vocab-modal-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.vocab-modal-item{display:flex;align-items:baseline;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border-subtle);font-size:.85rem;line-height:1.4}.vocab-modal-item:last-child{border-bottom:none}.vocab-modal-item strong{font-family:var(--font-mono);font-size:.82rem;color:var(--text-primary);flex-shrink:0}.vocab-modal-item span{color:var(--text-secondary)}.summary-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:50;display:flex;align-items:flex-end;justify-content:center;animation:summary-backdrop-in .3s ease both}@keyframes summary-backdrop-in{0%{opacity:0}to{opacity:1}}@media(prefers-color-scheme:light){.summary-backdrop{background:#0000004d}}.summary-sheet{width:100%;max-width:680px;max-height:82dvh;background:var(--bg-card);border:1px solid var(--border-input);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:1.75rem 1.75rem 2.5rem;overflow-y:auto;box-shadow:var(--shadow-lg);animation:summary-sheet-in .4s cubic-bezier(.16,1,.3,1) both}@keyframes summary-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.summary-header{text-align:center;margin-bottom:1.5rem}.summary-emoji{font-size:2.5rem;display:block;margin-bottom:.5rem}.summary-title{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .25rem}.summary-subtitle{font-size:.82rem;color:var(--text-muted)}.summary-sections{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.75rem}.summary-section-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin:0 0 .5rem}.summary-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.summary-list li{font-size:.85rem;color:var(--text-secondary);line-height:1.5;padding:.5rem .75rem;border-radius:var(--radius-sm);display:flex;gap:.5rem;align-items:flex-start}.summary-list li:before{flex-shrink:0}.summary-achievements .summary-section-title{color:var(--praise-fg)}.summary-achievements li{background:var(--praise-bg)}.summary-achievements li:before{content:"✓";color:var(--praise-fg)}.summary-improvements .summary-section-title{color:var(--vocab-fg)}.summary-improvements li{background:var(--vocab-bg)}.summary-improvements li:before{content:"→";color:var(--vocab-fg)}.summary-vocab .summary-section-title{color:var(--text-accent)}.vocab-table{width:100%;border-collapse:collapse;font-size:.82rem}.vocab-table tr{border-bottom:1px solid var(--border-subtle)}.vocab-table tr:last-child{border-bottom:none}.vocab-table td{padding:.45rem .5rem;line-height:1.4}.vocab-table td:first-child{font-family:var(--font-mono);font-weight:600;color:var(--text-primary);width:45%}.vocab-table td:last-child{color:var(--text-secondary)}.summary-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.btn-ghost{display:inline-flex;align-items:center;padding:.6rem 1.2rem;background:var(--meta-bg);border:1.5px solid var(--border-input);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);text-decoration:none}.btn-ghost:hover{background:var(--bg-card-hover);border-color:var(--border-input-focus);color:var(--text-primary)}.btn-ghost:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-secondary{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.25rem;background:transparent;border:1.5px solid var(--accent);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.9rem;font-weight:600;color:var(--text-accent);cursor:pointer;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn-secondary:hover{background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft);transform:translateY(-1px)}.btn-secondary:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-secondary:active{transform:translateY(0)}.action-strip{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem;align-self:flex-start;max-width:88%;animation:action-strip-in .3s cubic-bezier(.16,1,.3,1) both}@keyframes action-strip-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.action-strip.action-strip--exit{animation:action-strip-out .2s ease forwards}@keyframes action-strip-out{to{opacity:0;transform:translateY(-4px) scale(.97)}}.action-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;padding:.55rem .9rem;background:var(--bg-card);border:1px solid var(--border-input);border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--text-primary);cursor:pointer;text-align:left;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.action-btn:hover{background:var(--bg-card-hover);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);transform:translateY(-1px)}.action-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.action-btn:active{transform:translateY(0)}.action-btn-label{font-size:.85rem;font-weight:600;letter-spacing:-.01em;line-height:1.3}.action-btn-label-en{font-size:.72rem;color:var(--text-muted);line-height:1.2}.msg-action{align-self:center;align-items:center;max-width:90%;animation:msg-in .3s cubic-bezier(.16,1,.3,1) both}.action-narration{display:flex;align-items:center;gap:.5rem;padding:.45rem .85rem;border-radius:var(--radius-full);border:1px solid var(--border-subtle);background:#ffffff0a;font-size:.82rem;font-style:italic;color:var(--text-secondary);line-height:1.4;white-space:pre-wrap;word-break:break-word}@media(prefers-color-scheme:light){.action-narration{background:#0000000a}}.msg-action .translate-toggle{margin-top:.2rem}@media(max-width:600px){.conv-container{padding:0}#view-briefing{padding:1.5rem 1rem 2rem}#view-scenes{padding:1.5rem 1rem 1rem}.chat-topbar{padding:.65rem 1rem}.chat-goal-strip{padding:.5rem 1rem}.chat-window{padding:1rem}.chat-input-row{padding:.65rem 1rem .85rem}.msg{max-width:90%}.assessment-wrap{max-width:94%}.briefing-card{padding:1.25rem}.scenes-grid{grid-template-columns:1fr}.summary-sheet{padding:1.25rem 1.25rem 2rem}.summary-actions{flex-direction:column}.summary-actions .btn-primary,.summary-actions .btn-secondary,.summary-actions .btn-ghost{width:100%;justify-content:center}}@media(max-width:480px){.chat-topbar{padding:.5rem .75rem}.chat-topbar-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem .5rem;flex:1;min-width:0}.chat-topbar-actions button{display:inline-flex;align-items:center;justify-content:center;width:100%;box-sizing:border-box}}
