:root{font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif;color:#17211f;background:#f3f6f4;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea,select{font:inherit}button,input,textarea,select,p,span,small,strong,h1,h2,h3{overflow-wrap:anywhere}.app-shell{min-height:100vh;padding:24px}.app-header{max-width:1360px;margin:0 auto 20px}.app-header h1{margin:0;font-size:34px;line-height:1.16;letter-spacing:0}.app-header p:last-child{max-width:720px;margin:10px 0 0;color:#52615d}.eyebrow{margin:0 0 8px;color:#236f63;font-weight:700}.workspace-grid{display:grid;grid-template-columns:minmax(280px,360px) minmax(420px,1fr) minmax(320px,420px);gap:16px;max-width:1360px;margin:0 auto;align-items:start}.left-column,.right-column{display:grid;gap:16px}.panel{background:#fff;border:1px solid #dce5e0;border-radius:8px;padding:16px;box-shadow:0 10px 24px #27373112}.panel-heading h2{margin:0 0 12px;font-size:18px;line-height:1.25;letter-spacing:0}.experiment-grid{display:grid;gap:8px}.experiment-card{width:100%;min-height:76px;padding:12px;border:1px solid #d6e1dc;border-radius:8px;background:#f9fbfa;text-align:left;cursor:pointer}.experiment-card.active{border-color:#2f8f83;background:#eaf6f3}.experiment-card span,.experiment-card small{display:block}.experiment-card span{margin-bottom:4px;font-weight:700}.experiment-card small{color:#5d6b67;line-height:1.4}.field{display:grid;gap:8px;margin-bottom:12px}.field span{font-weight:700}input,textarea,select{width:100%;border:1px solid #cbd8d2;border-radius:8px;padding:10px 12px;color:#17211f;background:#fff}select{min-height:44px}textarea{resize:vertical;min-height:108px}.primary-button{width:100%;min-height:44px;border:0;border-radius:8px;color:#fff;background:#236f63;font-weight:700;cursor:pointer}.secondary-button{width:100%;min-height:42px;border:1px solid #236f63;border-radius:8px;color:#236f63;background:#fff;font-weight:700;cursor:pointer}.stage-panel{min-height:640px}.stage-header{display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.playback-controls{display:flex;flex:0 0 auto;gap:8px}.icon-button{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid #cbd8d2;border-radius:8px;color:#236f63;background:#fff;cursor:pointer}.icon-button:hover,.timeline-step:hover,.review-button:hover,.secondary-button:hover{border-color:#2f8f83;background:#f2f8f6}.visual-stage{display:grid;grid-template-columns:minmax(260px,1fr) minmax(220px,280px);gap:16px;align-items:stretch;min-height:350px;margin-top:8px;padding:16px;overflow:hidden;border:1px solid #dce5e0;border-radius:8px;background:linear-gradient(180deg,#f8fbfaf5,#fffffffa),linear-gradient(90deg,#236f6314,#c55f4514)}.apparatus-area{display:grid;min-width:0;place-items:center;border:1px solid #e3ebe7;border-radius:8px;background:#fbfcfc}.apparatus{position:relative;width:min(100%,360px);min-height:300px}.apparatus.gas-generator{width:min(100%,430px)}.apparatus.warm:after{position:absolute;right:46px;bottom:24px;padding:3px 8px;border-radius:999px;color:#7b4b12;background:#fff0cc;font-size:12px;font-weight:700;content:"微热"}.vessel-shell,.test-vessel{position:absolute;overflow:hidden;border:4px solid #8b9d98;background:#ffffffc2}.vessel-shell{left:50%;bottom:28px;width:150px;height:235px;transform:translate(-50%)}.test-tube .vessel-shell{border-top:0;border-radius:0 0 46px 46px}.beaker .vessel-shell,.gas-generator .vessel-shell{width:188px;height:178px;border-top-color:#b6c3bf;border-radius:0 0 24px 24px}.gas-generator .vessel-shell{left:30%}.test-vessel{right:28px;bottom:28px;width:128px;height:176px;border-top:0;border-radius:0 0 36px 36px}.delivery-tube{position:absolute;right:118px;bottom:162px;width:148px;height:66px;border-top:5px solid #8b9d98;border-right:5px solid #8b9d98;border-radius:0 18px 0 0}.liquid-fill{position:absolute;right:0;bottom:0;left:0;height:54%;background:var(--liquid)}.liquid-fill.secondary{background:var(--secondary-liquid)}.liquid-fill.misty,.liquid-fill.cloudy{background:radial-gradient(circle at 30% 35%,rgba(255,255,255,.72),transparent 18%),radial-gradient(circle at 70% 55%,rgba(255,255,255,.66),transparent 22%),var(--secondary-liquid)}.liquid-fill.blue-fade{background:linear-gradient(180deg,var(--liquid),#bcdedc)}.liquid-fill.pink-to-clear,.liquid-fill.fade{background:linear-gradient(180deg,var(--liquid),#f7faf8)}.cloudiness{position:absolute;right:14px;bottom:24px;left:14px;height:54px;border-radius:50%;background:#f5f2dcb8}.solid-sample{position:absolute;right:42px;bottom:24px;width:62px;height:18px;border-radius:999px;background:#9a8f7d;transform:rotate(-8deg)}.solid-sample.calcium-carbonate,.solid-sample.manganese-dioxide{right:50px;width:50px;height:28px;border-radius:45%;background:#e5dfca}.solid-sample.manganese-dioxide{background:#4f4b45}.solid-sample.copper-coating{background:#b86c44;box-shadow:0 0 0 4px #b86c442e}.bubble-layer{position:absolute;inset:16px 24px 34px;pointer-events:none}.stage-bubble{position:absolute;width:12px;height:12px;border:2px solid var(--accent);border-radius:50%;background:#ffffffd6;animation:rise 1.8s ease-in-out infinite}.bubble-0{left:18%;bottom:14%}.bubble-1{left:44%;bottom:28%;animation-delay:.22s}.bubble-2{left:62%;bottom:42%;animation-delay:.44s}.bubble-3{left:32%;bottom:56%;animation-delay:.66s}.bubble-4{left:72%;bottom:68%;animation-delay:.88s}.flame{position:absolute;top:42px;right:72px;width:34px;height:54px;border-radius:50% 50% 48% 48%;background:linear-gradient(180deg,#ffe6a8,#f57f35 62%,#c94f45);box-shadow:0 0 24px #f57f356b}.flame.ember{height:28px;background:#d86d55}.active-observation{display:grid;align-content:start;gap:10px;min-width:0;padding:14px;border:1px solid #e4ebe8;border-radius:8px;background:#fff}.active-observation span,.active-observation em{display:inline-flex;width:fit-content;min-height:24px;align-items:center;padding:2px 8px;border-radius:999px;font-size:12px;font-style:normal;font-weight:700}.active-observation span{color:#236f63;background:#e2f1ed}.active-observation em{color:#765125;background:#fff1dd}.active-observation h3{margin:0;font-size:17px}.active-observation p,.active-observation strong{margin:0;line-height:1.6}.active-observation p{color:#52615d}.timeline-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:8px;margin-top:14px}.timeline-step{display:grid;grid-template-columns:28px 1fr;gap:2px 8px;min-height:74px;align-items:center;padding:10px;border:1px solid #d6e1dc;border-radius:8px;color:#17211f;background:#fff;text-align:left;cursor:pointer}.timeline-step span{display:inline-flex;width:28px;height:28px;grid-row:span 2;align-items:center;justify-content:center;border-radius:50%;color:#fff;background:#8b9d98;font-weight:800}.timeline-step strong{font-size:13px}.timeline-step small{color:#65736f}.timeline-step.active{border-color:#2f8f83;background:#edf8f5}.timeline-step.active span{background:#236f63}@keyframes rise{0%{transform:translateY(8px) scale(.92);opacity:.45}60%{opacity:.9}to{transform:translateY(-18px) scale(1.08);opacity:.25}}.feedback-block p,.follow-up p,.muted{color:#52615d;line-height:1.65}.status-pill{display:inline-block;margin:0 0 8px;padding:4px 8px;border-radius:999px;color:#fff;background:#64736e;font-size:12px;font-weight:700}.status-pill.accurate{background:#24765e}.status-pill.partial{background:#8a6a1f}.status-pill.misconception{background:#a94442}.status-pill.empty{background:#64736e}.feedback-block{margin-top:12px;padding-top:12px;border-top:1px solid #edf2ef}.feedback-block h3,.follow-up h3{margin:0 0 6px;font-size:15px}.equation{color:#17211f;font-family:SFMono-Regular,Consolas,monospace}.follow-up{margin-top:12px;padding:12px;border:1px solid #dce5e0;border-radius:8px;background:#f2f7f5}.notebook-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.notebook-list li{display:grid;gap:4px;padding:10px;border-radius:8px;background:#f9fbfa}.notebook-list span,.notebook-list small,.notebook-list p{color:#52615d}.notebook-list p{margin:2px 0 0;line-height:1.55}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.tag-row em{display:inline-flex;min-height:24px;align-items:center;padding:2px 8px;border-radius:999px;color:#236f63;background:#eaf6f3;font-size:12px;font-style:normal;font-weight:700}.iteration-note{margin-top:12px;padding:4px 0 4px 12px;border-left:3px solid #7aa8a0}.iteration-note p{margin:6px 0 0;color:#52615d;line-height:1.55}.feedback-list{display:grid;gap:8px;margin:12px 0 0;padding:0;list-style:none}.feedback-list li{display:grid;gap:4px;padding:10px;border-radius:8px;background:#f2f7f5}.feedback-context{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.feedback-context strong{margin-right:2px}.feedback-context em{display:inline-flex;min-height:22px;align-items:center;padding:2px 7px;border-radius:999px;color:#5c4b13;background:#fff2bf;font-size:12px;font-style:normal;font-weight:700}.feedback-context em:last-child{color:#236f63;background:#e2f1ed}.feedback-list span{color:#52615d;line-height:1.5}.memory-card{display:grid;gap:12px}.memory-card header{display:grid;gap:6px;padding:12px;border:1px solid #e2ebe7;border-radius:8px;background:#fbfcfc}.memory-card header strong{font-size:16px}.memory-card header span{color:#765125;line-height:1.55}.memory-section{display:grid;gap:6px;padding:12px;border:1px solid #edf2ef;border-radius:8px;background:#fff}.memory-section h3,.reveal-block h3{margin:0;font-size:14px}.phenomena-list{display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none}.phenomena-list li{min-height:26px;padding:3px 8px;border-radius:999px;color:#236f63;background:#eaf6f3;font-size:12px;font-weight:700}.reveal-grid{display:grid;gap:8px}.reveal-block{display:grid;gap:8px;padding:12px;border:1px solid #e2ebe7;border-radius:8px;background:#f9fbfa}.reveal-block p,.reveal-block strong,.answer-placeholder{margin:0;line-height:1.55}.reveal-block p,.answer-placeholder{color:#52615d}.reveal-block strong{color:#17211f}.compact-button{width:auto;min-height:38px;justify-self:start;padding:0 12px}.review-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.review-list li{display:grid;gap:10px;padding:12px;border:1px solid #e1e9e5;border-radius:8px;background:#fbfcfc}.review-card-main{display:grid;gap:4px;min-width:0}.review-card-main span,.review-card-main small{color:#52615d;line-height:1.5}.review-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.review-button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:6px;border:1px solid #cbd8d2;border-radius:8px;font-weight:700;cursor:pointer}.review-button.mastered{color:#236f63;background:#eef8f5}.review-button.due{color:#8a541f;background:#fff4e7}@media(max-width:1100px){.workspace-grid{grid-template-columns:1fr}.stage-panel{min-height:auto}}@media(max-width:640px){.app-shell{padding:16px}.app-header h1{font-size:26px}.stage-header,.visual-stage{grid-template-columns:1fr}.visual-stage{min-height:auto;padding:12px}.apparatus-area{min-height:330px}.apparatus.gas-generator{transform:scale(.86);transform-origin:center}.timeline-steps,.review-actions{grid-template-columns:1fr}.playback-controls{justify-content:flex-start}}
