*,:before,:after{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}#root{height:100%}.auth-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:380px;padding:40px 36px;box-shadow:0 4px 24px #00000014}.auth-title{color:#1a1a2e;margin:0 0 4px;font-size:1.8rem;font-weight:700}.auth-subtitle{color:#666;margin:0 0 28px;font-size:.95rem}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-form input{border:1.5px solid #e0e0e0;border-radius:10px;outline:none;padding:12px 14px;font-size:1rem;transition:border-color .2s}.auth-form input:focus{border-color:#6c63ff}.auth-form button{color:#fff;cursor:pointer;background:#6c63ff;border:none;border-radius:10px;margin-top:4px;padding:13px;font-size:1rem;font-weight:600;transition:background .2s}.auth-form button:hover:not(:disabled){background:#574fd6}.auth-form button:disabled{opacity:.6;cursor:default}.auth-error{color:#e53935;margin:0;font-size:.875rem}.auth-switch{text-align:center;color:#666;margin:20px 0 0;font-size:.9rem}.auth-switch a{color:#6c63ff;font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.auth-sent-icon{margin-bottom:16px;font-size:2.5rem}.auth-hint{color:#999;margin:-12px 0 0;font-size:.82rem}.verified-container{background:linear-gradient(135deg,#f0eeff 0%,#f5f5f5 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.verified-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:420px;padding:52px 44px;animation:.35s both fadeUp;box-shadow:0 8px 40px #6c63ff1f}.verified-card--error{box-shadow:0 8px 40px #e539351a}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.verified-icon{color:#6c63ff;background:#e8e6ff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 24px;font-size:2rem;font-weight:700;display:flex}.verified-icon--success{color:#2e7d32;background:#e6f4ea}.verified-card--error .verified-icon{color:#e53935;background:#fdecea}.verified-title{color:#1a1a2e;margin:0 0 12px;font-size:1.7rem;font-weight:700}.verified-text{color:#666;margin:0 0 32px;font-size:.97rem;line-height:1.6}.verified-button{color:#fff;cursor:pointer;background:#6c63ff;border:none;border-radius:10px;padding:13px 36px;font-size:1rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.verified-button:hover{background:#574fd6}.verified-button--outline{color:#6c63ff;background:0 0;border:2px solid #6c63ff}.verified-button--outline:hover{background:#f0eeff}*{box-sizing:border-box}body{background:#f0f0f5;margin:0;font-family:system-ui,sans-serif}.lesson-root{background:#fff;flex-direction:column;max-width:720px;height:100vh;margin:0 auto;display:flex;box-shadow:0 0 32px #0000000f}.lesson-header{z-index:10;background:#fff;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0}.lesson-header-left{align-items:center;gap:10px;display:flex}.btn-leave{cursor:pointer;color:#888;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1rem;transition:background .15s;display:flex}.btn-leave:hover{color:#333;background:#f0f0f5}.lesson-badge{color:#6c63ff;background:#e8e5ff;border-radius:20px;padding:3px 10px;font-size:.8rem;font-weight:600}.lesson-title{color:#1a1a2e;font-size:1rem;font-weight:600}.level-select{cursor:pointer;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;padding:6px 10px;font-size:.85rem}.btn-stop-tts{cursor:pointer;background:#e8f5e9;border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;animation:1.5s infinite pulse;display:flex}.btn-stop-tts:hover{background:#c8e6c9}.chat-area{flex-direction:column;flex:1;gap:10px;padding:16px 20px;display:flex;overflow-y:auto}.bubble{white-space:pre-wrap;border-radius:16px;max-width:75%;padding:10px 14px;font-size:.95rem;line-height:1.5}.bubble.user{color:#fff;background:#6c63ff;border-bottom-right-radius:4px;align-self:flex-end}.bubble.assistant{color:#1a1a2e;background:#f0f0f5;border-bottom-left-radius:4px;align-self:flex-start}.bubble.streaming{opacity:.85}.input-row{background:#fff;border-top:1px solid #eee;gap:8px;padding:12px 16px;display:flex;position:sticky;bottom:0}.chat-input{border:1.5px solid #e0e0e0;border-radius:24px;outline:none;flex:1;padding:11px 14px;font-size:.95rem;transition:border-color .2s}.chat-input:focus{border-color:#6c63ff}.btn-send,.btn-mic{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;transition:background .2s;display:flex}.btn-send{color:#fff;background:#6c63ff}.btn-send:hover:not(:disabled){background:#574fd6}.btn-send:disabled{opacity:.5;cursor:default}.btn-mic{color:#333;background:#f0f0f5}.btn-mic:hover:not(:disabled){background:#e0e0e8}.btn-mic.active{color:#e53935;background:#ffebee;animation:1.2s infinite pulse}.btn-mic.busy{color:#f57c00;background:#fff8e1}.btn-mic:disabled{opacity:.5;cursor:default}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.lesson-finished-overlay{z-index:20;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;justify-content:center;align-items:center;animation:.4s fadeIn;display:flex;position:absolute;inset:0}.lesson-root{position:relative}.lesson-finished-card{text-align:center;max-width:320px;padding:40px 32px}.lesson-finished-icon{color:#2e7d32;background:#e8f5e9;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;font-size:1.6rem;font-weight:700;display:flex}.lesson-finished-title{color:#1a1a2e;margin:0 0 10px;font-size:1.4rem;font-weight:700}.lesson-finished-sub{color:#666;margin:0 0 24px;font-size:.95rem;line-height:1.55}.lesson-finished-btn{color:#fff;cursor:pointer;background:#6c63ff;border:none;border-radius:10px;padding:11px 24px;font-size:.95rem;font-weight:600;transition:background .2s}.lesson-finished-btn:hover{background:#574fd6}@keyframes fadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}:root{--leaf-dark:#1a4d2e;--leaf-mid:#2d7a4f;--leaf-light:#4caf79;--leaf-pale:#a8d5b5;--cream:#f5f0e8;--text-main:#1c2e20;--text-muted:#5a7a63}.promo-root{background:var(--cream);color:var(--text-main);min-height:100vh;font-family:Georgia,serif;position:relative;overflow-x:hidden}.promo-root:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 60% at 50% -10%,#c8e6c9 0%,#0000 70%),radial-gradient(40% 30% at 20% 100%,#a5d6a7 0%,#0000 60%),radial-gradient(40% 30% at 80% 100%,#a5d6a7 0%,#0000 60%);position:fixed;inset:0}.promo-page{z-index:1;position:relative}.promo-hero{text-align:center;max-width:680px;margin:0 auto;padding:80px 24px 60px}.promo-badge{background:var(--leaf-dark);color:#fff;letter-spacing:2px;text-transform:uppercase;border-radius:100px;align-items:center;gap:8px;margin-bottom:32px;padding:6px 18px;font-family:Georgia,serif;font-size:13px;display:inline-flex}.promo-h1{color:var(--leaf-dark);letter-spacing:-.5px;margin-bottom:24px;font-size:clamp(2.4rem,7vw,4rem);font-weight:400;line-height:1.15}.promo-h1 em{color:var(--leaf-mid);font-style:italic}.promo-subtitle{color:var(--text-muted);max-width:500px;margin:0 auto 48px;font-size:1.15rem;line-height:1.7}.promo-benefits{flex-direction:column;max-width:600px;margin:0 auto 64px;padding:0 24px;display:flex}.promo-benefit{border-bottom:1px solid var(--leaf-pale);align-items:flex-start;gap:20px;padding:28px 0;display:flex}.promo-benefit:last-child{border-bottom:none}.promo-benefit-icon{flex-shrink:0;width:48px;height:48px}.promo-benefit-text h3{color:var(--leaf-dark);margin:0 0 6px;font-size:1.05rem;font-weight:700}.promo-benefit-text p{color:var(--text-muted);margin:0;font-size:.93rem;line-height:1.65}.promo-form-section{text-align:center;max-width:480px;margin:0 auto 80px;padding:0 24px}.promo-form-section h2{color:var(--leaf-dark);margin:0 0 10px;font-size:1.6rem;font-weight:400}.promo-form-sub{color:var(--text-muted);margin:0 0 28px;font-size:.9rem}.promo-email-row{gap:10px;display:flex}.promo-email-row input{border:2px solid var(--leaf-pale);color:var(--text-main);background:#fff;border-radius:12px;outline:none;flex:1;padding:14px 18px;font-family:inherit;font-size:1rem;transition:border-color .2s}.promo-email-row input:focus{border-color:var(--leaf-mid)}.promo-email-row button{background:var(--leaf-dark);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:12px;padding:14px 22px;font-family:inherit;font-size:.95rem;transition:background .2s,transform .1s}.promo-email-row button:hover:not(:disabled){background:var(--leaf-mid)}.promo-email-row button:active:not(:disabled){transform:scale(.97)}.promo-email-row button:disabled{opacity:.7;cursor:default}.promo-form-msg{min-height:22px;margin-top:14px;font-size:.9rem}.promo-form-msg.ok{color:var(--leaf-mid)}.promo-form-msg.err{color:#c0392b}.promo-qr-section{text-align:center;padding:0 24px 80px}.promo-qr-section p{color:var(--text-muted);margin-top:14px;font-size:.85rem}.promo-qr-canvas{border-radius:16px;box-shadow:0 8px 32px #2d7a4f26}.promo-footer{text-align:center;color:var(--leaf-pale);border-top:1px solid var(--leaf-pale);padding:24px;font-size:.8rem}@media (width<=480px){.promo-email-row{flex-direction:column}.promo-email-row button{width:100%}}
