:root{--bg-primary: #0a0a1a;--bg-secondary: #12122a;--bg-card: #1a1a3e;--bg-hover: #22224e;--text-primary: #f0f0ff;--text-secondary: #8888aa;--text-muted: #555577;--accent: #6c63ff;--accent-hover: #5a52e0;--accent-glow: rgba(108, 99, 255, .3);--success: #4ecdc4;--error: #ff6b6b;--warning: #ffd93d;--border: #2a2a4e;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", Menlo, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{max-width:480px;margin:0 auto;padding:0 16px;min-height:100dvh}.page{display:flex;flex-direction:column;min-height:100dvh;padding:16px 0}.page-header{display:flex;align-items:center;gap:12px;padding:8px 0 24px}.page-header h1{font-size:1.5rem;font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease;-webkit-tap-highlight-color:transparent;min-height:48px;position:relative;overflow:hidden;transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);width:100%}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn:active:not(:disabled){transform:translateY(1px) scale(.985)}.btn-large{flex-direction:column;padding:20px 24px;text-align:center}.btn-icon{font-size:1.5rem}.btn-desc{font-size:.8rem;font-weight:400;color:var(--text-secondary);margin-top:4px}.back-btn{background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;padding:8px;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent}.back-btn:hover{color:var(--text-primary);background:var(--bg-card)}.landing{justify-content:center;padding:28px 0 20px}.landing-shell{display:flex;flex:1;flex-direction:column;justify-content:center;gap:24px}.landing-hero{display:flex;flex-direction:column;gap:10px;padding:0 4px}.landing-title{font-size:1.5rem;font-weight:650;letter-spacing:-.03em;line-height:1.15;max-width:14ch}.logo-icon{font-size:.95rem}.landing-subtitle{color:var(--text-secondary);font-size:.82rem;letter-spacing:.02em;text-transform:uppercase}.landing-badge{display:inline-flex;align-items:center;gap:8px;width:fit-content;padding:7px 12px;border:1px solid rgba(140,155,180,.18);border-radius:var(--radius-full);background:#151e2ee0;color:#cfd8e6;font-size:.82rem;font-weight:600;letter-spacing:.01em}.language-selector{display:flex;flex-direction:column;gap:12px}.language-selector-header{display:flex;flex-direction:column;gap:4px}.language-label{display:block;font-size:.9rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.14em}.language-meta,.language-title{color:var(--text-muted);font-size:.84rem;line-height:1.4}.language-title{color:var(--text-secondary)}.language-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.language-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 10px;background:var(--bg-card);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;-webkit-tap-highlight-color:transparent;min-height:48px}.language-option:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border)}.language-option.selected{border-color:var(--accent);background:#6c63ff1a}.language-option:disabled{opacity:.5;cursor:not-allowed}.language-flag{font-size:1.35rem}.language-native{font-size:.82rem;font-weight:700;color:var(--text-primary);line-height:1.2}.room-entry{--entry-accent: #67e8f9;--entry-accent-strong: #34d6ff;--entry-accent-soft: rgba(103, 232, 249, .16);--entry-surface: linear-gradient(180deg, rgba(18, 18, 42, .94) 0%, rgba(11, 13, 32, .96) 100%);justify-content:flex-start;padding:18px 0 32px}.room-entry .back-btn{color:#b6c9de}.room-entry .back-btn:hover{color:var(--text-primary);background:#14222fcc}.entry-nav{width:min(100%,430px);margin:0 auto 10px}.entry-shell{width:min(100%,430px);margin:0 auto;display:flex;flex-direction:column;gap:20px;flex:1}.entry-hero{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.entry-hero--primary{align-items:flex-start;gap:6px;padding:0 2px;text-align:left}.entry-eyebrow,.section-eyebrow,.room-entry .language-label{color:var(--entry-accent);text-transform:uppercase;letter-spacing:.16em;font-size:.77rem;font-weight:700}.entry-title{max-width:12ch;font-size:clamp(2rem,7vw,2.6rem);line-height:1.08;letter-spacing:-.03em;word-break:keep-all;overflow-wrap:normal;text-wrap:balance}.entry-subtitle{max-width:28ch;color:#a8bbcc;font-size:.98rem;text-wrap:pretty}.entry-card{display:flex;flex-direction:column;gap:20px;padding:22px 18px 18px;border-radius:24px;border:1px solid rgba(103,232,249,.12);background:var(--entry-surface);box-shadow:0 22px 60px #0208145c}.entry-card--form{padding:0;border:none;background:transparent;box-shadow:none}.entry-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;border:1px solid rgba(103,232,249,.12);border-radius:18px;background:#08121db3}.entry-card--form .entry-section{padding:16px 18px 18px;border-radius:22px;border:1px solid rgba(103,232,249,.1);background:#0b0d20b8;box-shadow:0 18px 40px #0208142e}.room-entry--primary{padding:max(8px,env(safe-area-inset-top)) 0 20px}.room-entry--primary .entry-shell{gap:12px}.room-entry--primary .entry-card--form{gap:10px}.room-entry--primary .entry-eyebrow,.room-entry--primary .section-eyebrow,.room-entry--primary .language-label{letter-spacing:.14em;font-size:.72rem}.room-entry--primary .entry-title{max-width:9ch;font-size:clamp(1.45rem,6vw,2rem);line-height:1.04}.room-entry--primary .entry-card--form .entry-section{padding:12px 14px 14px;border-radius:18px}.room-entry--primary .entry-tabs{gap:6px;padding:4px;border-radius:16px}.room-entry--primary .entry-tab{min-height:38px;font-size:.88rem}.room-entry--primary .language-selector{gap:10px}.room-entry--primary .language-grid{gap:6px}.room-entry--primary .language-option{min-height:66px;padding:12px 8px}.entry-tab{min-height:42px;border:none;border-radius:12px;background:transparent;color:#8fa3b6;font-size:.9rem;font-weight:700;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}.entry-tab:hover{color:#d7e8f7}.entry-tab:disabled{cursor:default;opacity:.72}.entry-tab--active{background:linear-gradient(135deg,#3dd7f43d,#6370ff3d);color:#fff;box-shadow:inset 0 0 0 1px #8de6ff2e}.invite-banner{display:flex;flex-direction:column;gap:8px;padding:18px;border-radius:20px;border:1px solid rgba(103,232,249,.16);background:#0b1723c7;box-shadow:0 14px 40px #02081447}.invite-banner__eyebrow{color:var(--entry-accent);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:700}.invite-banner__title{font-size:1.2rem;line-height:1.2}.invite-banner__body{color:#a8bbcc;font-size:.9rem;line-height:1.5}.entry-card--status{align-items:center;text-align:center}.entry-section{display:flex;flex-direction:column;gap:10px}.field-helper{color:#94a8bb;font-size:.88rem;line-height:1.45;text-wrap:pretty}.field-helper--center{max-width:28ch;text-align:center}.entry-footnote{width:min(100%,32ch);margin:0 auto;color:#7e91a4;font-size:.78rem;line-height:1.45;text-align:center;text-wrap:pretty}.room-entry .language-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.room-entry .language-option{min-height:74px;background:#181d38e6;border-color:#67e8f914}.room-entry .language-option:hover:not(:disabled){background:#1b233ff5;border-color:#67e8f947;transform:translateY(-1px)}.room-entry .language-option.selected{border-color:var(--entry-accent-strong);background:#18354d8c;box-shadow:inset 0 0 0 1px #67e8f933}.room-entry .language-native{white-space:nowrap}.room-code-input{gap:8px}.room-code-input--invite{padding-left:14px;border-left:4px solid var(--entry-accent)}.invite-code-field{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid rgba(103,232,249,.24);border-radius:16px;background:#0c1420b8;cursor:text;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.invite-code-field:hover{border-color:#67e8f961}.invite-code-field:focus-within{border-color:var(--entry-accent-strong);box-shadow:0 0 0 3px #67e8f91f;transform:translateY(-1px)}.invite-code-field--invalid{border-color:#ff6b6bb3}.entry-text-field{display:flex;align-items:center;padding:12px 14px;border:1px solid rgba(103,232,249,.24);border-radius:16px;background:#0c1420b8;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.entry-text-field:focus-within{border-color:var(--entry-accent-strong);box-shadow:0 0 0 3px #67e8f91f;transform:translateY(-1px)}.entry-text-field__input{width:100%;border:none;background:transparent;color:var(--text-primary);font-size:1rem;outline:none}.entry-text-field__input::placeholder{color:#7e91a4}.code-input{flex:1;width:100%;padding:0;font-family:var(--font-mono);font-size:1.5rem;font-weight:800;letter-spacing:.18em;text-align:left;text-transform:uppercase;background:transparent;border:none;color:var(--text-primary);outline:none}.code-input::placeholder{color:#53657a}.code-input:disabled{opacity:.65}.invite-code-edit-hint{flex-shrink:0;color:#7e91a4;font-size:.74rem;letter-spacing:.04em}.code-hint,.code-error{display:block;font-size:.82rem;line-height:1.4}.code-hint{color:#8fa3b6}.code-error{color:var(--error)}.room-code-banner{display:flex;align-items:center;justify-content:center;min-height:76px;padding:10px 16px;border-left:4px solid var(--entry-accent);border-radius:16px;background:#0b1723c7}.room-code-value{font-family:var(--font-mono);font-size:clamp(1.6rem,5vw,2.2rem);font-weight:800;letter-spacing:.16em;color:var(--entry-accent-strong)}.entry-cta{background-image:linear-gradient(135deg,#3dd7f4,#3f9dfd 45%,#8d72ff);box-shadow:0 18px 36px #3dd7f42e,0 0 0 1px #ffffff14 inset}.entry-cta:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:linear-gradient(120deg,#ffffff47,#fff0 42%);opacity:.9;pointer-events:none}.entry-cta:hover:not(:disabled){box-shadow:0 22px 46px #3dd7f447,0 0 28px #3dd7f42e;filter:saturate(1.08)}.qr-display{align-items:center;text-align:center}.qr-container{background:#fff;padding:16px;border-radius:22px;display:inline-block;box-shadow:0 18px 38px #0000002e}.qr-hint{max-width:24ch}.waiting-indicator{display:flex;align-items:center;gap:8px;color:#a8bbcc;font-size:.9rem;justify-content:center}.pulse-dot{width:10px;height:10px;background:var(--entry-accent-strong);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.entry-animate{opacity:0;transform:translateY(16px);animation:entry-rise .46s cubic-bezier(.2,.7,.2,1) forwards}.entry-animate--2{animation-delay:.08s}.entry-animate--3{animation-delay:.16s}@keyframes entry-rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.paired,.error{align-items:center;text-align:center;justify-content:center}.success-icon{width:64px;height:64px;border-radius:50%;background:var(--success);color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.error-icon{width:64px;height:64px;border-radius:50%;background:var(--error);color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.redirect-hint{color:var(--text-muted);font-size:.85rem}.session{gap:16px}.session-intro{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px}.session-intro p{color:var(--text-secondary);font-size:.95rem}.dual-speaker-grid{display:grid;gap:12px}.speaker-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:10px}.speaker-card h2{font-size:1rem}.session-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.session-select{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px;font-size:.95rem}.session-meta{color:var(--text-muted);font-size:.82rem}.session-actions{display:flex;flex-direction:column;gap:8px}.session-textarea{width:100%;min-height:86px;resize:vertical;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px;font:inherit}.session-textarea:focus,.session-select:focus{outline:2px solid var(--accent);outline-offset:1px}.session-live{color:var(--success);font-size:.85rem}.session-warning{color:var(--warning);font-size:.9rem}.session-error{color:var(--error);font-size:.9rem}.session-log{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:10px}.session-log-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.session-log-header .btn{width:auto;padding:8px 14px;min-height:40px}.session-empty{color:var(--text-muted);font-size:.9rem}.turn{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;background:var(--bg-card);display:flex;flex-direction:column;gap:6px}.turn-a{border-left:4px solid var(--accent)}.turn-b{border-left:4px solid var(--success)}.turn-meta{color:var(--text-muted);font-size:.76rem}.turn-original{color:var(--text-primary);font-size:.95rem}.turn-translated{color:var(--success);font-size:.95rem;font-weight:600}.live-session{gap:12px;padding-top:max(10px,env(safe-area-inset-top));padding-bottom:0;min-height:100dvh}.live-session--chat{background:radial-gradient(circle at top,rgba(98,128,255,.18),transparent 36%),linear-gradient(180deg,#090f18,#070b12)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 4px #ffffff08}.status-dot--connected{background:var(--success)}.status-dot--connecting{background:var(--warning);animation:pulse 1.2s ease-in-out infinite}.status-dot--disconnected{background:var(--text-muted)}.status-dot--error{background:var(--error)}.live-chat-topbar{position:relative;display:grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:52px;height:52px}.live-chat-topbar__center{display:flex;align-items:center;justify-content:center;min-width:0}.live-chat-topbar__status{display:inline-flex;align-items:center;gap:5px;min-width:0;padding:0 10px;height:32px;border:1px solid rgba(174,200,236,.1);border-radius:999px;background:#ffffff0a;color:#c5d3e6e0;font-size:.68rem;font-weight:500;letter-spacing:.03em;white-space:nowrap}.live-chat-topbar__nav{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(174,200,236,.12);border-radius:14px;background:linear-gradient(180deg,#ffffff0b,#ffffff05);color:#edf3ff;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}.live-chat-topbar__nav svg{width:18px;height:18px}.live-chat-topbar__nav:hover{background:linear-gradient(180deg,#fff1,#ffffff08);border-color:#aec8ec33;box-shadow:0 10px 26px #020a1833}.live-chat-topbar__roomcode{justify-self:center;font-family:var(--font-mono);max-width:100%;overflow:hidden;font-size:.72rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;text-overflow:ellipsis;white-space:nowrap;color:#cad4ef}.live-chat-topbar__actions{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:8px}.live-chat-presence{display:inline-flex;align-items:center;justify-content:center;color:#d9e5ff;border:1px solid rgba(174,200,236,.12);border-radius:14px;background:linear-gradient(180deg,#ffffff0b,#ffffff05)}.live-chat-presence--trigger{position:relative;width:40px;height:40px;padding:0;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}.live-chat-presence--trigger:hover{background:linear-gradient(180deg,#fff1,#ffffff08);border-color:#aec8ec33;box-shadow:0 10px 26px #020a1833}.live-chat-presence--trigger[aria-expanded=true]{background:linear-gradient(180deg,#768dff2e,#6d7dee1f);border-color:#8fa7ff61;box-shadow:0 12px 30px #1e2e6a3d}.live-chat-presence__icon{display:inline-flex;width:18px;height:18px;transition:transform .2s ease}.live-chat-presence__icon svg{width:100%;height:100%}.live-chat-presence--trigger[aria-expanded=true] .live-chat-presence__icon{transform:translateY(-.5px) scale(1.03)}.live-chat-presence__count{position:absolute;top:-4px;right:-4px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:var(--radius-full);background:linear-gradient(135deg,#8de6ff,#6d8cff 48%,#5565f4);box-shadow:0 6px 16px #475ff44d;color:#fff;font-family:var(--font-mono);font-size:.64rem;font-weight:700;line-height:1}.btn-sm{padding:8px 14px;font-size:.85rem;min-height:36px;width:auto}.live-chat-menu-drawer{position:absolute;top:calc(100% + 8px);right:0;z-index:10;width:min(84vw,320px);padding:18px;border:1px solid rgba(174,200,236,.12);border-radius:24px;background:radial-gradient(circle at top right,rgba(141,230,255,.14),transparent 34%),linear-gradient(180deg,#181c33fa,#0b0d1efa);box-shadow:0 26px 60px #0000005c;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-6px) scale(.98);transform-origin:top right;transition:opacity .18s ease,transform .2s cubic-bezier(.22,1,.36,1),visibility .18s ease}.live-chat-menu-drawer--open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0) scale(1)}.live-chat-menu-drawer:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:linear-gradient(135deg,#ffffff14,#fff0 44%);pointer-events:none}.live-chat-menu-section{display:flex;flex-direction:column;gap:12px;position:relative}.live-chat-menu-section+.live-chat-menu-section{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.live-chat-menu-heading{color:#a7b6cf;font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase}.live-chat-profile-card{display:flex;flex-direction:column;align-items:flex-start;gap:5px;padding:12px 13px;border:1px solid rgba(255,255,255,.05);border-radius:18px;background:#ffffff0a;box-shadow:inset 0 1px #ffffff0a}.live-chat-profile-card strong{font-size:.94rem;font-weight:650}.live-chat-profile-card__label{color:#9ba9bf;font-size:.8rem}.live-chat-participant-list{display:flex;flex-direction:column;gap:10px}.live-chat-menu-section--actions{gap:10px}.live-chat-menu-action{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border:1px solid rgba(174,200,236,.12);border-radius:15px;background:#ffffff09;color:var(--text-primary);cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease}.live-chat-menu-action:hover{background:#ffffff0f;border-color:#aec8ec38;transform:translateY(-1px)}.live-chat-menu-action--danger{color:#ffdede;border-color:#ff6b6b42;background:#ff6b6b1f}.conversation-log{flex:1;overflow-y:auto;padding:8px 0 16px;display:flex;flex-direction:column;gap:8px;min-height:0}.conversation-log--chat{padding:10px 0 14px;gap:12px}.conversation-empty{color:var(--text-muted);font-size:.9rem;text-align:center;margin-top:24px;margin-inline:auto;max-width:24ch}.chat-system-event{display:flex;justify-content:center;padding:2px 0}.chat-system-event__pill{max-width:min(88%,26rem);padding:7px 12px;border:1px solid rgba(255,255,255,.07);border-radius:999px;background:#ffffff12;color:#dde7f3c7;font-size:.74rem;line-height:1.35;text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.bubble{max-width:78%;padding:10px 14px;border-radius:var(--radius-lg);word-break:break-word;line-height:1.4}.bubble--chat{display:flex;flex-direction:column;gap:5px;max-width:min(80%,34rem);border-radius:22px;padding:11px 14px 10px;box-shadow:0 14px 34px #020a1824}.bubble--self{align-self:flex-end;background:linear-gradient(135deg,#6280ff,#7a67ff);color:#fff;border-bottom-right-radius:8px}.bubble--peer{align-self:flex-start;background:#ffffff0a;color:var(--text-primary);border:1px solid rgba(255,255,255,.08);border-bottom-left-radius:8px}.bubble__sender{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.7}.bubble__text{font-size:.95rem}.bubble__note{align-self:flex-start;padding:4px 8px;border-radius:var(--radius-full);font-size:.73rem;line-height:1.35;opacity:.88}.bubble--self .bubble__note{background:#ffffff29}.bubble--peer .bubble__note{background:#6c82ff1f;color:#d7e1ff}.bubble__original{font-size:.76rem;line-height:1.45;opacity:.76}.bubble__original-toggle{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:1px solid transparent;border-radius:999px;background:transparent;color:inherit;opacity:.52;cursor:pointer;transition:opacity .16s ease,transform .16s ease,background .16s ease,border-color .16s ease}.bubble__original-toggle:hover{opacity:.88;transform:translateY(-.5px)}.bubble__original-toggle svg{width:14px;height:14px}.bubble__original-toggle--inline{flex-shrink:0;margin-left:auto}.bubble__original-toggle--active{opacity:.82;background:#ffffff1a;border-color:#ffffff1f}.bubble__meta{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px;color:inherit;opacity:.68;font-size:.66rem;text-transform:uppercase;letter-spacing:.08em}.bubble__meta span:first-child{margin-right:auto}.bubble__meta time{font-family:var(--font-mono);font-size:.64rem}.live-chat-composer{display:flex;flex-direction:column;gap:10px;position:sticky;bottom:0;margin:0 -16px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));flex-shrink:0;background:linear-gradient(180deg,#070b1200,#070b12eb 22%,#070b12fb);border-top:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.live-session-error{color:var(--error);font-size:.85rem;text-align:left}.live-chat-composer__shell{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:6px 6px 6px 14px;border:1px solid rgba(174,200,236,.12);border-radius:24px;background:linear-gradient(180deg,#0f1522f0,#0c111df5);box-shadow:0 10px 28px #0000003d,inset 0 1px #ffffff0b}.live-chat-composer__shell:focus-within{border-color:#8da6ff4d;box-shadow:0 14px 32px #00000047,0 0 0 1px #8da6ff1f,inset 0 1px #ffffff0e}.live-chat-composer__input{width:100%;min-width:0;min-height:44px;padding:0 2px 0 0;border:none;background:transparent;color:var(--text-primary);font-size:.94rem;outline:none}.live-chat-composer__input::placeholder{color:#728296}.live-chat-composer__send{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid rgba(173,235,255,.34);border-radius:999px;background:radial-gradient(circle at 30% 30%,#8de6ff,#6280ff 45%,#3a4ef3);color:#fff;cursor:pointer;box-shadow:0 12px 28px #3b4ef357,inset 0 1px #ffffff57;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.live-chat-composer__send:hover:not(:disabled){transform:translateY(-1px) scale(1.01);box-shadow:0 16px 32px #3b4ef36b,inset 0 1px #ffffff5c;filter:saturate(1.08)}.live-chat-composer__send svg{width:17px;height:17px;transform:translate(.5px)}.live-chat-composer__send:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}@keyframes mic-pulse{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 36px #6c63ff8c}}.btn-test{border-color:var(--accent);opacity:.85}.test-session{height:100dvh;overflow:hidden}.test-session-header{justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:12px}.log-link{font-size:.82rem;color:var(--accent);text-decoration:none;border:1px solid var(--accent);padding:4px 10px;border-radius:var(--radius-full);white-space:nowrap}.log-link:hover{background:#6c63ff1a}.test-setup{display:flex;flex-direction:column;gap:20px;overflow-y:auto;padding-bottom:20px;flex:1;min-height:0}.test-connecting{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary)}.connecting-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.test-status-bar{display:flex;align-items:center;gap:8px;padding:6px 0 10px;border-bottom:1px solid var(--border);flex-shrink:0}.test-ended-reason{font-size:.78rem;color:var(--text-muted);margin-left:auto}.test-transcript{flex:1;min-height:0;overflow-y:auto;padding:12px 0;display:flex;flex-direction:column;gap:10px}.test-transcript-empty{color:var(--text-muted);font-size:.9rem;text-align:center;margin-top:24px}.test-translated-line{font-size:1.1rem;line-height:1.5;color:var(--text-primary);padding:10px 14px;background:var(--bg-card);border-radius:var(--radius-lg);border-left:3px solid var(--accent)}.test-partial-text{font-size:.95rem;color:var(--text-muted);font-style:italic;padding:6px 14px}.test-footer{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:12px;padding:12px 0 20px}.test-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center}.test-error{color:var(--error);font-size:.85rem}.test-log{padding-bottom:0;min-height:100dvh}.test-log-header{justify-content:flex-start;gap:16px;border-bottom:1px solid var(--border);padding-bottom:12px;flex-shrink:0}.log-summary{display:flex;gap:16px;padding:10px 0;flex-wrap:wrap;flex-shrink:0}.log-stat{font-size:.85rem;color:var(--text-secondary)}.log-stat--final strong{color:var(--success)}.log-stat--partial strong{color:var(--accent)}.log-filters{display:flex;gap:8px;padding-bottom:12px;flex-shrink:0;flex-wrap:wrap}.log-filter-btn{padding:5px 12px;font-size:.8rem;border:1px solid var(--border);border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.log-filter-btn:hover{border-color:var(--accent);color:var(--accent)}.log-filter-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.log-empty-state{text-align:center;padding:48px 16px;display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-muted)}.log-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:40px}.log-table{border-collapse:collapse;font-size:.78rem;width:100%;min-width:900px}.log-table th{position:sticky;top:0;background:var(--bg-secondary);border-bottom:2px solid var(--border);padding:8px 10px;text-align:left;font-weight:600;color:var(--text-secondary);white-space:nowrap;z-index:1}.log-table td{padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:top;max-width:240px}.log-row--committed{background:#4ecdc40f}.log-row--partial{opacity:.65}.log-seq{color:var(--text-muted);font-family:var(--font-mono)}.log-time{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);white-space:nowrap}.log-type{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);white-space:nowrap}.log-text{max-width:200px;word-break:break-word}.log-translated{max-width:200px;word-break:break-word;color:var(--success)}.log-empty{color:var(--text-muted)}.log-expand-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.75rem;padding:2px 4px;border-radius:3px;white-space:nowrap}.log-expand-btn:hover{background:#6c63ff1a}.log-words-table{margin-top:6px;border-collapse:collapse;font-size:.7rem;min-width:260px}.log-words-table th,.log-words-table td{padding:3px 6px;border:1px solid var(--border);text-align:left}.log-words-table th{background:var(--bg-card);color:var(--text-muted);position:static}.log-raw-json{margin-top:6px;font-size:.68rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;max-height:240px;overflow-y:auto;white-space:pre-wrap;word-break:break-all;color:var(--text-secondary)}@media(max-width:360px){.language-grid{grid-template-columns:repeat(2,1fr)}.room-entry .language-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.code-input{font-size:1.2rem;letter-spacing:.12em}.invite-code-field{padding:12px}.invite-code-edit-hint{font-size:.68rem}.live-chat-topbar__status{padding-inline:8px;font-size:.62rem}}@media(min-width:768px){.dual-speaker-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(prefers-reduced-motion:reduce){.entry-animate,.pulse-dot,.btn,.live-chat-menu-drawer,.live-chat-presence__icon,.live-chat-composer__send,.bubble__original-toggle{animation:none;transition:none;transform:none}}.landing-sheet{display:flex;flex-direction:column;gap:6px;padding:10px;border-radius:24px;border:1px solid rgba(141,160,188,.12);background:linear-gradient(180deg,#1b273beb,#111926f5),#0e141ef5;box-shadow:0 22px 40px #0000003d,inset 0 1px #ffffff0a}.landing-sheet__label{padding:4px 10px 10px;color:#8d9bb0;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.landing-row{width:100%;justify-content:flex-start;gap:14px;padding:14px 16px;border:1px solid transparent;border-radius:18px;background:#ffffff05;color:var(--text-primary);text-align:left;box-shadow:none}.landing-row:hover:not(:disabled){background:#ffffff0d;border-color:#8497b429;box-shadow:none}.landing-row--primary{background:linear-gradient(180deg,#2f507b38,#1823354d);border-color:#618abe38}.landing-row__icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;border-radius:14px;background:#7ea7df1f;font-size:1.2rem}.landing-row__body{display:flex;min-width:0;flex:1;flex-direction:column;gap:2px}.landing-row__title{font-size:1rem;font-weight:650}.landing-row__desc{color:#9aa7ba;font-size:.82rem;font-weight:400;line-height:1.35;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.landing-row__chevron{color:#7e91ac;font-size:1.35rem;line-height:1}@media(min-width:480px){.landing{padding:40px 0 28px}.landing-shell{gap:28px}.landing-title{font-size:1.7rem}.landing-sheet{padding:12px}}.table-mode-entry{gap:24px}.table-mode-intro{text-align:center;padding:24px 16px;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border)}.table-mode-icon{font-size:3rem;margin-bottom:12px}.table-mode-intro h2{font-size:1.3rem;font-weight:700;margin-bottom:8px}.table-mode-intro p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.table-mode-setup{display:flex;flex-direction:column;gap:16px;flex:1}.table-mode-hint{text-align:center;color:var(--text-muted);font-size:.85rem;font-style:italic}.table-mode{padding:0;min-height:100dvh;background:var(--bg-primary)}.table-mode-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border);background:var(--bg-secondary);position:sticky;top:0;z-index:10}.table-mode-status{display:flex;align-items:center;gap:8px}.status-text{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.status-dot--paused{background:var(--warning);animation:pulse 1.5s ease-in-out infinite}.table-mode-actions{display:flex;gap:8px}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);font-size:1.2rem;display:flex;align-items:center;justify-content:center;min-height:40px}.btn-stop{background:#ff6b6b33;border-color:var(--error);color:var(--error)}.btn-stop:hover{background:#ff6b6b4d}.table-mode-conversation{flex:1;overflow-y:auto;padding:16px 16px 128px;display:flex;flex-direction:column;gap:16px}.utterance{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--radius-md);padding:14px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.utterance--live{opacity:.7;border-left-style:dashed}.utterance-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.speaker-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 8px;border-radius:var(--radius-full);color:#fff}.lang-tag{font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono)}.utterance-original{font-size:1rem;color:var(--text-primary);line-height:1.5;margin-bottom:8px}.utterance-translated{font-size:.95rem;color:var(--success);line-height:1.4;padding-top:8px;border-top:1px solid var(--border)}.utterance-translating{font-size:.85rem;color:var(--text-muted);font-style:italic;padding-top:8px;border-top:1px solid var(--border)}.speaker-indicator{position:fixed;bottom:120px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:5}.speaker-orb{width:64px;height:64px;border-radius:50%;animation:speaker-pulse 1.5s ease-in-out infinite;box-shadow:0 0 30px #8781ff80}@keyframes speaker-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}.speaker-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.pause-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a1af2;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pause-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.pause-icon{font-size:4rem;opacity:.5}.pause-content p{font-size:1.2rem;color:var(--text-secondary)}.error-banner{background:#ff6b6b1f;border:1px solid rgba(255,107,107,.3);border-radius:var(--radius-md);color:var(--error);font-size:.9rem;padding:12px 16px;margin:0 16px;display:flex;align-items:center;gap:8px}.error-icon{font-size:1.2rem}.table-mode-footer{position:fixed;left:50%;bottom:max(16px,env(safe-area-inset-bottom));transform:translate(-50%);z-index:20;background:#121222eb;border:1px solid var(--border);border-radius:999px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));box-shadow:0 10px 30px #00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
