@import"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}button,input,textarea,select{font:inherit}:root{--bg: #fff6ec;--bg-soft: #fffaf4;--card: rgba(255, 255, 255, .9);--ink: #1f2937;--muted: #6b7280;--line: rgba(22, 101, 52, .16);--brand: #0ea35f;--brand-deep: #0b7d48;--ok: #159947;--ok-soft: rgba(21, 153, 71, .12);--bad: #dc2626;--bad-soft: rgba(220, 38, 38, .14);--warm: #ff8a00;--warm-soft: rgba(255, 138, 0, .16);--radius-xl: 28px;--radius-lg: 18px;--radius-md: 12px;--shadow-lg: 0 20px 48px rgba(25, 31, 41, .16);--shadow-md: 0 8px 24px rgba(25, 31, 41, .1);--ease: cubic-bezier(.22, .61, .36, 1);font-family:Outfit,"Baloo 2",PingFang SC,Microsoft YaHei,sans-serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;color:var(--ink);background:radial-gradient(860px 440px at -8% -15%,rgba(255,138,0,.28),transparent 72%),radial-gradient(700px 420px at 108% 0%,rgba(14,163,95,.24),transparent 72%),linear-gradient(135deg,#fff9f2,#f7fff8 52%,#fff4ed);padding:max(12px,env(safe-area-inset-top)) 12px max(12px,env(safe-area-inset-bottom))}.speak-app{width:min(980px,100%);margin:0 auto;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.8);background:var(--card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-lg);padding:16px;display:grid;gap:12px;animation:rise .42s var(--ease)}.hero{border-radius:calc(var(--radius-xl) - 6px);border:1px solid rgba(14,163,95,.24);background:linear-gradient(135deg,#0ea35f33,#0ea35f05 58%),linear-gradient(320deg,#ff8a0033,#ff8a0005 62%),var(--bg-soft);padding:16px;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-70px;top:-70px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(255,138,0,.24),transparent 70%);pointer-events:none}.eyebrow{margin:0;color:var(--brand-deep);text-transform:uppercase;font-size:.78rem;font-weight:700;letter-spacing:.14em}h1{margin:8px 0 0;font-size:clamp(1.4rem,1.1rem + 1.9vw,2.1rem);letter-spacing:-.02em}.subtitle{margin:8px 0 0;max-width:740px;color:var(--muted);font-size:.92rem;line-height:1.55}.metrics{display:grid;gap:8px;grid-template-columns:repeat(4,minmax(0,1fr))}.metric-card{border-radius:var(--radius-lg);border:1px solid rgba(14,163,95,.18);background:linear-gradient(180deg,#fffffff0,#f7fffae6);box-shadow:0 8px 16px #131c240f;padding:10px}.metric-card span{display:block;color:var(--muted);font-size:.78rem}.metric-card strong{display:block;margin-top:6px;font-size:1.18rem;letter-spacing:-.01em}.metric-card small{display:block;margin-top:4px;color:var(--muted);font-size:.78rem}.tabs{display:flex;flex-wrap:wrap;gap:7px}.tabs button{border:1px solid rgba(32,74,54,.16);border-radius:999px;background:#ffffffeb;color:var(--ink);font:inherit;font-size:.88rem;padding:8px 14px;cursor:pointer;transition:all .16s var(--ease)}.tabs button.active{color:#fff;border-color:#0b7d484d;background:linear-gradient(145deg,var(--brand),var(--brand-deep));box-shadow:0 8px 16px #0b7d4842;transform:translateY(-1px)}.message{margin:0;border-radius:10px;border:1px solid rgba(255,138,0,.3);background:var(--warm-soft);color:#8a4a00;padding:8px 10px;font-size:.84rem}.panel{border-radius:var(--radius-lg);border:1px solid rgba(26,89,61,.14);background:#ffffffeb;padding:12px}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}h2{margin:0;font-size:1.02rem}.panel-head p{margin:6px 0 0;color:var(--muted);font-size:.85rem}h3{margin:0;font-size:.93rem}.tag{border-radius:999px;border:1px solid rgba(14,163,95,.25);background:#0ea35f1a;color:var(--brand-deep);font-size:.76rem;padding:4px 10px;white-space:nowrap}.chip-group{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.chip{border-radius:999px;border:1px solid rgba(17,24,39,.15);background:#fff;color:var(--ink);font:inherit;font-size:.83rem;padding:6px 12px;cursor:pointer;transition:all .14s var(--ease)}.chip.easy{border-color:#0ea35f57}.chip.medium{border-color:#ff8a0066}.chip.hard{border-color:#dc262666}.chip.active{background:linear-gradient(145deg,var(--brand),var(--brand-deep));color:#fff;border-color:transparent;box-shadow:0 8px 18px #0b7d4847}.phrase-card,.result-card,.challenge-box,.scene-card,.day-card,.history,.danger-zone{margin-top:10px;border-radius:var(--radius-md);border:1px solid rgba(17,24,39,.1);background:#fff;padding:10px}.phrase-label{margin:0;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}.target-phrase{margin:6px 0 0;font-size:1rem;font-weight:700;line-height:1.5}.hint{margin:7px 0 0;color:var(--muted);font-size:.82rem}.actions{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.primary-btn,.secondary-btn,.danger-btn,.done-btn{border-radius:10px;border:1px solid transparent;font:inherit;font-size:.84rem;padding:8px 12px;cursor:pointer;transition:transform .13s var(--ease),box-shadow .13s var(--ease)}.primary-btn{color:#fff;background:linear-gradient(145deg,var(--brand),var(--brand-deep));box-shadow:0 8px 16px #0b7d4840}.primary-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.secondary-btn,.done-btn{color:var(--ink);border-color:#11182724;background:#fffffff0}.done-btn.done{color:#fff;border-color:transparent;background:linear-gradient(145deg,var(--brand),var(--brand-deep))}.danger-btn{color:#fff;border-color:transparent;background:linear-gradient(145deg,#ef4444,#dc2626);box-shadow:0 8px 16px #dc262642}.primary-btn:hover,.secondary-btn:hover,.danger-btn:hover,.done-btn:hover{transform:translateY(-1px)}.input-grid,.form-grid,.weekly-grid,.scene-grid{margin-top:10px;display:grid;gap:8px}.input-grid,.weekly-grid,.scene-grid{grid-template-columns:repeat(2,minmax(0,1fr))}label{display:grid;gap:6px;color:var(--muted);font-size:.84rem}input,select,textarea{width:100%;border-radius:10px;border:1px solid rgba(17,24,39,.18);background:#fff;color:var(--ink);font:inherit;outline:none;padding:8px 10px}input,select{height:38px}textarea{min-height:92px;resize:vertical;line-height:1.5}input:focus,select:focus,textarea:focus{border-color:#0ea35f80;box-shadow:0 0 0 3px #0ea35f24}.result-head,.scene-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.result-meta{margin:6px 0 0;color:var(--muted);font-size:.82rem}.score-ok{color:var(--ok)}.score-bad{color:var(--bad)}.token-wrap{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.token{border-radius:999px;border:1px solid transparent;padding:4px 10px;font-size:.78rem;font-weight:600}.token.ok{border-color:#1599475c;background:var(--ok-soft);color:var(--ok)}.token.bad{border-color:#dc262657;background:var(--bad-soft);color:var(--bad)}.challenge-box h3,.history h3,.danger-zone h3{margin:0}.challenge-box ul,.scene-card ul,.history ul{margin:8px 0 0;padding-left:18px;display:grid;gap:6px}.challenge-box li,.scene-card li,.history li{color:var(--ink);font-size:.84rem;line-height:1.45}.scene-situation,.scene-prompt,.empty,.danger-zone p,.day-card span,.history small{margin:6px 0 0;color:var(--muted);font-size:.81rem}.day-card strong{display:block;margin-top:6px;font-size:1.03rem}.bar-track{margin-top:8px;width:100%;height:8px;border-radius:999px;overflow:hidden;background:#0ea35f1f}.bar-fill{height:100%;background:linear-gradient(90deg,var(--brand),#2fc27d)}.history ul{list-style:none;padding-left:0}.history li{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid rgba(17,24,39,.1);border-radius:10px;padding:8px}.history p{margin:0;font-size:.83rem}.checkbox-row{align-items:center;grid-auto-flow:column;justify-content:flex-start;gap:8px;color:var(--ink)}.checkbox-row input{width:16px;height:16px;margin:0}.danger-zone{border-color:#dc26263d;background:linear-gradient(180deg,#dc26260f,#fffffff2)}@media(max-width:980px){.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.input-grid,.weekly-grid,.scene-grid,.form-grid{grid-template-columns:1fr}}@media(max-width:560px){body{padding:max(10px,env(safe-area-inset-top)) 10px max(10px,env(safe-area-inset-bottom))}.speak-app{border-radius:16px;padding:10px}.hero{padding:13px}.tabs button{font-size:.82rem;padding:6px 11px}.metric-card strong{font-size:1.06rem}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.metric-card strong.ok{color:var(--ok)}.token.close{border-color:#ff8a0066;background:#ff8a0029;color:#b65e00}.extra-note{margin:8px 0 0;color:#a95600;font-size:.82rem}.feedback{margin:8px 0 0;color:var(--muted);font-size:.83rem}.mismatch-list{margin:8px 0 0;padding-left:18px;color:var(--muted);font-size:.82rem;display:grid;gap:4px}.word-card{margin-top:12px;border-radius:var(--radius-md);border:1px solid rgba(17,24,39,.1);background:#fff;padding:10px}.word-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.word-head span{color:var(--muted);font-size:.8rem}.word-list{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:8px}.word-list li{border:1px solid rgba(17,24,39,.1);border-radius:10px;padding:9px;background:#fff;display:grid;gap:8px}.word-title,.word-meaning,.word-example,.word-meta{margin:0}.word-title{font-weight:700}.word-title small{color:var(--muted);font-weight:500}.word-meaning{margin-top:4px;color:var(--ink);font-size:.84rem}.word-example,.word-meta{margin-top:4px;color:var(--muted);font-size:.8rem}.word-actions{display:flex;flex-wrap:wrap;gap:8px}.danger-lite-btn{border-radius:10px;border:1px solid rgba(220,38,38,.26);background:#dc262614;color:var(--bad);font:inherit;font-size:.84rem;padding:8px 12px;cursor:pointer}.material-layout{margin-top:10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.material-card{border-radius:var(--radius-md);border:1px solid rgba(17,24,39,.1);background:#fff;padding:10px}.material-head{display:flex;justify-content:space-between;align-items:center}.material-head span,.material-meta{color:var(--muted);font-size:.8rem}.script-box{margin:8px 0 0;border:1px solid rgba(17,24,39,.1);border-radius:10px;background:#fff;padding:8px;color:var(--ink);font-size:.83rem;line-height:1.55}.qa-list{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:8px}.qa-list li{border:1px solid rgba(17,24,39,.1);border-radius:10px;padding:8px}.qa-list p{margin:0;font-size:.84rem}.option-row{margin-top:8px;display:grid;gap:6px}.option-btn{border-radius:10px;border:1px solid rgba(17,24,39,.16);background:#fff;color:var(--ink);font:inherit;font-size:.8rem;padding:7px 9px;text-align:left;cursor:pointer}.option-btn.active{border-color:#0ea35f61;background:#0ea35f1a;color:var(--brand-deep)}.qa-answer{margin-top:7px;color:var(--muted);font-size:.8rem}.material-actions{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.material-actions span{color:var(--muted);font-size:.8rem}.dialogue-toolbar{margin-top:10px;display:grid;grid-template-columns:1.2fr 1fr;gap:8px;align-items:end}.tip-box{margin-top:9px;border-radius:10px;border:1px solid rgba(255,138,0,.3);background:#ff8a001f;color:#9c5200;padding:8px;font-size:.82rem}.chat-stream{margin-top:10px;border:1px solid rgba(17,24,39,.1);border-radius:10px;background:#fff;padding:8px;display:grid;gap:8px;max-height:360px;overflow:auto}.bubble{max-width:88%;border-radius:10px;padding:8px;display:grid;gap:4px}.bubble p,.bubble small{margin:0}.bubble small{color:var(--muted);font-size:.75rem}.bubble.coach{justify-self:start;border:1px solid rgba(14,163,95,.25);background:#0ea35f14}.bubble.user{justify-self:end;border:1px solid rgba(17,24,39,.16);background:#1118270f}.dialogue-input-row{margin-top:10px;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end}.progress-card{margin-top:10px;border-radius:var(--radius-md);border:1px solid rgba(17,24,39,.1);background:#fff;padding:10px}.progress-card h3,.progress-card p{margin:0}.progress-card p{margin-top:6px;color:var(--muted);font-size:.82rem}.weak-list,.attempt-list{margin:9px 0 0;padding:0;list-style:none;display:grid;gap:8px}.weak-list li,.attempt-list li{border:1px solid rgba(17,24,39,.1);border-radius:10px;padding:8px}.attempt-list li{display:flex;justify-content:space-between;align-items:center;gap:8px}.attempt-list p,.attempt-list small{margin:0}.attempt-list small{color:var(--muted);font-size:.78rem}@media(max-width:760px){.material-layout,.dialogue-toolbar,.dialogue-input-row{grid-template-columns:1fr}}:root{--bg: #f2f7ff;--bg-soft: #ffffff;--card: rgba(255, 255, 255, .92);--ink: #1a2440;--muted: #63708b;--line: rgba(24, 100, 255, .18);--brand: #1a7dff;--brand-deep: #0d56c9;--ok: #16a34a;--ok-soft: rgba(22, 163, 74, .14);--bad: #e11d48;--bad-soft: rgba(225, 29, 72, .14);--warm: #ff9d2f;--warm-soft: rgba(255, 157, 47, .18)}body{background:radial-gradient(980px 520px at -8% -18%,rgba(255,157,47,.34),transparent 72%),radial-gradient(820px 440px at 108% 4%,rgba(26,125,255,.3),transparent 72%),linear-gradient(140deg,#f8fbff,#f0f7ff 42%,#fff8f0)}.speak-app{position:relative;overflow:hidden;border:1px solid rgba(26,125,255,.16);box-shadow:0 24px 56px #11275426}.speak-app:before{content:"";position:absolute;width:240px;height:240px;left:-110px;bottom:-120px;border-radius:50%;background:radial-gradient(circle,rgba(26,125,255,.2),transparent 70%);pointer-events:none}.hero{border-color:#1a7dff47;background:linear-gradient(122deg,#1a7dff33,#1a7dff0a 58%),linear-gradient(300deg,#ff9d2f3d,#ff9d2f08 62%),#fff}.hero:after{width:260px;height:260px;right:-88px;top:-84px;background:radial-gradient(circle,rgba(255,157,47,.28),transparent 72%)}.subtitle{color:#495776}.metric-card{border-color:#1a7dff33;background:linear-gradient(180deg,#fff,#f5fafff2)}.tabs button{border-color:#1a7dff33;background:#fffffff2}.tabs button.active{background:linear-gradient(145deg,#1a7dff,#0d56c9);box-shadow:0 10px 20px #0d56c947}.panel{border-color:#1a7dff29;background:#fffffff2}.message{border-color:#ff9d2f5c;color:#9f5600}.word-preview-card{margin-top:10px;border-radius:var(--radius-md);border:1px solid rgba(26,125,255,.2);background:linear-gradient(180deg,#1a7dff14,#fff);padding:10px}.word-preview-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.word-preview-head span{color:var(--muted);font-size:.78rem}.token-wrap-preview{margin-top:8px}.token-wrap-preview .token{display:grid;gap:2px;align-items:start}.token-wrap-preview .token small{display:block;font-size:.68rem;font-weight:600;opacity:.9}.token.neutral{border-color:#63708b3d;background:#63708b1a;color:#53607d}.suggestion-box{margin-top:10px;border:1px solid rgba(26,125,255,.18);border-radius:10px;background:#1a7dff14;padding:8px}.suggestion-box p{margin:0;color:#3e4f73;font-size:.8rem}.suggestion-row{margin-top:8px;display:flex;flex-wrap:wrap;gap:7px}.suggestion-btn{border-radius:999px;border:1px solid rgba(26,125,255,.24);background:#fff;color:#1f417b;font:inherit;font-size:.78rem;padding:6px 10px;cursor:pointer}.suggestion-btn:hover{border-color:#1a7dff6b;background:#1a7dff14}.chat-stream{background:linear-gradient(180deg,#fffffff7,#f4f9fff0)}.bubble.coach{border-color:#1a7dff4d;background:#1a7dff1c}.bubble.user{border-color:#ff9d2f4d;background:#ff9d2f1f}
