:root{--ink: #1f2933;--muted: #6b7280;--line: #e5e7eb;--primary: #4f46e5;--bg: #f4f5f8}*{box-sizing:border-box}body{margin:0;font-family:PingFang SC,Microsoft YaHei,Noto Sans SC,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6}button,textarea,input{font:inherit}.container{max-width:1080px;margin:0 auto;padding:0 24px}.app-header{background:linear-gradient(135deg,#4f46e5,#7c6cf0);color:#fff;padding:36px 0 40px}.app-header h1{margin:0 0 8px;font-size:26px}.app-header p{margin:0;max-width:640px;color:#ffffffe6;font-size:15px}main.container{padding-top:28px;padding-bottom:48px}.card{background:#fff;border-radius:16px;padding:22px 24px;box-shadow:0 6px 24px #1118270f;margin-bottom:22px}.card-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}.card-head h2{margin:0;font-size:18px}.step{width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;flex:none}.hint,.clock{margin-left:auto;font-size:13px;color:var(--muted)}.clock{background:#eef2ff;color:var(--primary);padding:4px 10px;border-radius:999px;font-variant-numeric:tabular-nums}label{display:block;font-size:13px;color:var(--muted);margin:12px 0 6px}input,textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 12px}input:focus,textarea:focus{outline:none;border-color:var(--primary)}textarea{min-height:110px;resize:vertical}.actions{margin-top:16px;display:flex;gap:10px}button{border:0;border-radius:10px;padding:10px 18px;background:var(--primary);color:#fff;cursor:pointer;font-size:14px}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:#eef0f4;color:var(--ink)}.banner-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:12px 16px;border-radius:10px;margin-bottom:20px;font-size:14px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}@media (max-width: 760px){.grid{grid-template-columns:1fr}}.roster{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width: 760px){.roster{grid-template-columns:repeat(2,1fr)}}.student-card{border:1px solid var(--line);border-radius:12px;padding:12px}.student-name{font-weight:600}.student-archetype{font-size:12px;color:var(--muted);margin:2px 0 10px}.bar-row{display:flex;align-items:center;gap:6px}.bar-label{font-size:11px;color:var(--muted);flex:none}.bar{flex:1;height:6px;background:#eef0f4;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:var(--primary)}.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 28px}@media (max-width: 760px){.plan-grid{grid-template-columns:1fr}}.plan-grid h3,.report h3{font-size:14px;margin:0 0 8px}.plan-grid ul{margin:0;padding-left:18px;font-size:14px}.plan-grid li{margin-bottom:4px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#eef2ff;color:var(--primary);border-radius:999px;padding:5px 12px;font-size:13px}.quick{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.chip-btn{background:#f3f4f6;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:12px}.empty{color:var(--muted);font-size:14px}.event{border-left:3px solid var(--line);background:#fafafb;border-radius:0 10px 10px 0;padding:10px 14px;margin-bottom:12px}.event-top{display:flex;align-items:center;gap:8px}.event-name{font-weight:600}.event-time{margin-left:auto;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.event-say{margin:8px 0 4px}.event-do{margin:4px 0;font-size:14px;color:#374151}.event-reason{color:var(--muted)}.badge{font-size:12px;padding:2px 9px;border-radius:999px}.ev-question{border-left-color:#3b82f6}.ev-wrong{border-left-color:#f59e0b}.ev-correct{border-left-color:#10b981}.ev-distraction{border-left-color:#9ca3af}.ev-emotion{border-left-color:#ec4899}.ev-positive{border-left-color:#10b981}.badge.ev-question{background:#dbeafe;color:#1d4ed8}.badge.ev-wrong{background:#fef3c7;color:#b45309}.badge.ev-correct{background:#d1fae5;color:#047857}.badge.ev-distraction{background:#e5e7eb;color:#4b5563}.badge.ev-emotion{background:#fce7f3;color:#be185d}.badge.ev-positive{background:#d1fae5;color:#047857}.report .summary{background:#eef2ff;border-radius:10px;padding:12px 14px;font-size:14px}.metric-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:18px 0 22px}@media (max-width: 760px){.metric-grid{grid-template-columns:repeat(2,1fr)}}.metric{border:1px solid var(--line);border-radius:10px;padding:12px;text-align:center}.metric-value{font-size:22px;font-weight:700;color:var(--primary)}.metric-label{font-size:12px;color:var(--muted);margin-top:4px}.app-footer{text-align:center;color:var(--muted);font-size:12px;margin-top:12px}.avatar{overflow:visible;display:block}@keyframes avIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.av-idle{animation:avIdle 3.4s ease-in-out infinite}@keyframes avBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.av-bounce{animation:avBounce .7s ease-in-out infinite}@keyframes avWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(2.5deg)}75%{transform:rotate(-2.5deg)}}.av-wiggle{animation:avWiggle 1.4s ease-in-out infinite}@keyframes avRock{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.av-rock{animation:avRock 2.6s ease-in-out infinite}@keyframes avBlink{0%,92%,to{transform:scaleY(1)}96%{transform:scaleY(.1)}}.av-eyes{animation:avBlink 4.2s infinite;transform-origin:center;transform-box:fill-box}@keyframes avMouth{0%,to{transform:scaleY(.45)}50%{transform:scaleY(1.1)}}.av-mouth-speak{animation:avMouth .22s ease-in-out infinite;transform-origin:center;transform-box:fill-box}.classroom{margin-top:4px}.focus-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}.focus-label{font-size:13px;color:var(--muted);flex:none}.focus-track{flex:1;height:12px;background:#eef0f4;border-radius:999px;overflow:hidden}.focus-fill{height:100%;border-radius:999px;transition:width .8s ease,background .8s ease}.focus-fill.tone-good{background:linear-gradient(90deg,#34d399,#10b981)}.focus-fill.tone-warn{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.focus-fill.tone-bad{background:linear-gradient(90deg,#f87171,#ef4444)}.focus-pct{font-size:14px;font-weight:700;font-variant-numeric:tabular-nums}.tone-text-good{color:#059669}.tone-text-warn{color:#b45309}.tone-text-bad{color:#dc2626}.focus-mood{font-size:12px;color:var(--muted);background:#f3f4f6;padding:3px 10px;border-radius:999px;flex:none}.room{position:relative;border-radius:16px;padding:26px 18px 30px;background:linear-gradient(180deg,#eef4fb,#eef4fb 46%,#f7e6c8 46%,#f1d9b0);transition:filter .8s ease;overflow:hidden}.room-haze{position:absolute;top:0;right:0;bottom:0;left:0;background:#9ca3af;pointer-events:none;transition:opacity .8s ease}.row{position:relative;display:flex;justify-content:center;align-items:flex-end;flex-wrap:nowrap}.row-back{gap:6px}.row-front{gap:30px;margin-top:-14px}.seat{position:relative;display:flex;flex-direction:column;align-items:center;transition:transform .4s ease}.seat-acting{transform:scale(1.07);z-index:5}.seat-acting:before{content:"";position:absolute;top:-8%;right:-12%;bottom:4%;left:-12%;background:radial-gradient(ellipse at 50% 60%,rgba(255,224,130,.6),transparent 70%);z-index:-1}.seat-name{margin-top:2px;font-size:12px;font-weight:600;color:#4b5563;background:#fffc;padding:1px 9px;border-radius:999px}.bubble{position:absolute;bottom:92%;left:50%;transform:translate(-50%);width:max-content;max-width:190px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:7px 11px;font-size:13px;line-height:1.4;box-shadow:0 6px 18px #11182724;z-index:6;animation:bubblePop .25s ease}@keyframes bubblePop{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}.bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:#fff}.bubble-do{color:var(--muted);font-style:italic}.teacher-line{position:relative;text-align:center;margin-top:14px;font-size:12px;letter-spacing:2px;color:#b08850}.disruption-alert{margin-top:12px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:10px;padding:9px 14px;font-size:13px}.controls{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}.btn-start{background:linear-gradient(135deg,#10b981,#059669);font-size:15px;padding:12px 26px}.btn-stop{background:#ef4444;flex:none}.hint-line{font-size:13px;color:var(--muted);margin:10px 0}.mic-row{display:flex;align-items:center;gap:10px}.mic-dot{width:12px;height:12px;border-radius:50%;background:#cbd5e1;flex:none}.mic-dot.on{background:#ef4444;animation:micPulse 1.3s ease-in-out infinite}@keyframes micPulse{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 7px #ef444400}}.mic-text{font-size:14px;color:var(--ink);margin-right:auto}.interim{margin-top:10px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;padding:8px 12px;font-size:14px;color:#475569;min-height:20px}.fallback{display:flex;gap:8px;margin-top:10px}.fallback input{flex:1}.my-lines{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.my-lines span{font-size:12px;color:var(--muted);background:#f3f4f6;padding:3px 9px;border-radius:999px}.my-lines .ml-new{background:#eef2ff;color:var(--primary)}.event-log{max-height:420px;overflow-y:auto}@media (max-width: 760px){.row-back{flex-wrap:wrap;gap:4px}.row-front{gap:14px}}
