:root{--sidebar:#18202e;--accent:#2a9df4;--bg:#f6f8fa }body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);font-size:105%;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100vh}.main{flex:1;display:flex;min-height:0}.sidebar{width:260px;padding:16px;background:var(--sidebar);color:#fff;display:flex;flex-direction:column}.sidebar-bottom{margin-top:auto}.sidebar h2{margin-top:0}.sidebar ul{list-style:none;padding:0}.sidebar .dropdown{margin-bottom:8px}.sidebar .dropdown-summary{width:100%;text-align:left;padding:10px;background:#fff1;border:none;color:#fff;cursor:pointer;border-radius:6px;font-weight:700}.sidebar .dropdown-content{margin-top:8px;max-height:60vh;overflow:auto}.sidebar .exp-list{margin:0;padding:0}.sidebar .exp-item{padding:8px;margin:4px 0;background:#fff1;border-radius:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar .exp-title{font-weight:400;font-size:15px;line-height:1.25}.sidebar .exp-item.active{outline:2px solid var(--accent)}.sidebar .exp-actions{margin-top:12px;display:flex;gap:8px}.sidebar .exp-actions button{flex:1}.sidebar button{width:100%;text-align:left;padding:8px;margin:4px 0;background:#fff1;border:none;color:#fff;cursor:pointer;border-radius:6px}.sidebar input,.sidebar textarea,.sidebar select{width:100%;box-sizing:border-box;padding:8px;border-radius:6px;border:1px solid #0000;margin:4px 0}.panel{background:#fff;border:1px solid #eee;border-radius:8px;padding:12px}.section-card{border:1px solid #e4e8ee;border-radius:12px;background:#fff;box-shadow:0 1px 2px #1018280a}.section-summary{font-weight:700;font-size:18px;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.section-summary::-webkit-details-marker{display:none}.mat-grid{display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;padding-bottom:2px}.mat-grid-two-rows{display:grid;grid-template-rows:repeat(2,minmax(0,1fr));grid-auto-flow:column;gap:8px 6px;overflow-x:auto;overflow-y:hidden;align-items:start}.mat-grid::-webkit-scrollbar{height:8px}.mat-grid::-webkit-scrollbar-thumb{background:#d4dbe5;border-radius:999px}.mat-chip{display:flex;align-items:center;gap:6px;padding:6px 8px;border:1px solid #e5e7eb;border-radius:9px;background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;line-height:1.2;color:inherit;text-align:left;position:relative;z-index:1;white-space:nowrap}.mat-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none}.mat-chip:focus{outline:none}.mat-chip:focus-visible{outline:2px solid var(--accent)}.mat-chip.selected{outline:2px solid var(--accent);border-color:#bfdbfe;background:#f8fbff}.mat-check{width:12px;height:12px;border-radius:4px;border:1px solid #cfd6de;background:linear-gradient(#fff,#f3f5f7);flex:0 0 auto}.mat-check.on{background:var(--accent);border-color:var(--accent)}.mat-check.on:after{content:"";display:block;width:7px;height:3px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:translate(1px,3px) rotate(-45deg)}.mat-chip span{pointer-events:none}.row{display:flex;gap:8px;align-items:center}.row>*{flex:1}.pane{flex:1;padding:24px}.placeholder{display:flex;align-items:center;justify-content:center;color:#666}.pane button{border:1px solid #d5dce5;border-radius:10px;background:#fff;color:#0f172a;padding:8px 12px;font-weight:600;cursor:pointer}.pane button:hover{border-color:#c7d2e0;background:#f8fafc}.pane input,.pane select,.pane textarea{border:1px solid #d5dce5;border-radius:10px;padding:8px 10px;font:inherit;background:#fff}.primary-btn{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}.primary-btn:hover{filter:brightness(.95)}.sim-two-col{display:grid;grid-template-columns:minmax(300px,1fr) minmax(240px,360px);gap:12px;align-items:start}.sim-visual-panel{min-height:220px}.sim-visual-title{font-weight:700;margin-bottom:8px}.sim-container-block{border:1px dashed #d5dce5;border-radius:10px;padding:10px;margin-bottom:10px;background:#fafcff}.sim-container-title{font-size:14px;font-weight:700;color:#334155;margin-bottom:8px;text-transform:uppercase;letter-spacing:.02em}.sim-container-list{display:flex;flex-wrap:wrap;gap:8px}.sim-container-item{padding:6px 10px;border:1px solid #d9e4f2;border-radius:999px;background:#eef6ff;font-size:14px;color:#1e3a5f;font-weight:600}.sim-container-empty{font-size:14px;color:#475569;line-height:1.35}.gas-beaker{position:relative;width:100%;max-width:320px;height:180px;margin:0 auto;border:2px solid #cfd6de;border-radius:12px 12px 16px 16px;background:linear-gradient(#f8fbff,#eef4fa);overflow:hidden}.gas-liquid{position:absolute;left:0;right:0;bottom:0;height:58%;background:linear-gradient(180deg,#d4ecff,#afd5fa)}.gas-bubble{position:absolute;bottom:16px;width:8px;height:8px;border-radius:50%;background:var(--bubble-color, rgba(255,255,255,.95));border:1px solid rgba(56,121,191,.38);box-shadow:0 0 10px #6eb4ff73;opacity:0;transform:translateZ(0) scale(.75);will-change:transform,opacity}.gas-beaker.active .gas-bubble{animation:gasUp 1.1s linear infinite}.sim-visual-note{font-size:14px;color:#334155;margin-top:8px;line-height:1.35}.oxacid-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;padding-top:58px;width:100%}.oxacid-spoon{position:absolute;top:0;right:calc(50% - 68px);transform-origin:top center;transform:rotate(-22deg) translateY(0);transition:transform .1s;z-index:10;pointer-events:none}.oxacid-spoon--dip{animation:oxacidSpoonDip .95s cubic-bezier(.35,0,.65,1)}@keyframes oxacidSpoonDip{0%{transform:rotate(-22deg) translateY(0)}35%{transform:rotate(-12deg) translateY(52px)}68%{transform:rotate(-12deg) translateY(52px)}to{transform:rotate(-22deg) translateY(0)}}.oxacid-beaker{position:relative;width:160px;height:200px;border:2.5px solid #9ab9cf;border-radius:8px 8px 18px 18px;background:linear-gradient(135deg,#f0faffc7,#d7eeff61);overflow:hidden;box-shadow:inset 3px 0 10px #ffffff8c,inset -2px 0 5px #96c8e638,0 4px 12px #64aad224}.oxacid-beaker.active{box-shadow:inset 3px 0 10px #ffffff9e,inset -2px 0 8px #96c8e642,0 6px 16px #5082aa38}.oxacid-beaker.active .gas-bubble{animation:gasUp 1.1s linear infinite}.oxacid-beaker-shine{position:absolute;top:8px;left:6px;width:6px;height:80%;border-radius:3px;background:#ffffff8c;pointer-events:none;z-index:2}.oxacid-liquid{position:absolute;left:0;right:0;bottom:0;height:62%;border-radius:0 0 15px 15px;transition:background .7s ease}.oxacid-liquid-glow{position:absolute;left:10px;right:10px;bottom:34px;height:54px;border-radius:50%;background:radial-gradient(ellipse at center,#ffffff5c,#ffffff0d 60%,#fff0);opacity:.35;pointer-events:none;z-index:2}.oxacid-liquid-glow.active{animation:oxacidLiquidPulse 2.2s ease-in-out infinite}.oxacid-surface-wave{position:absolute;left:0;right:0;bottom:61%;height:10px;background:linear-gradient(180deg,#ffffff7a,#ffffff05);border-radius:50%;opacity:.45;z-index:3}.oxacid-surface-wave.active{animation:oxacidWave 1.6s ease-in-out infinite}.oxacid-gas-haze{position:absolute;left:12%;right:12%;top:10%;height:46%;border-radius:50% 50% 42% 42%;background:radial-gradient(ellipse at center,#ffc47838,#ffc4780f 58%,#ffc47800);z-index:1;pointer-events:none;animation:oxacidHaze 2.4s ease-in-out infinite}.oxacid-metal-piece{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;z-index:3}.oxacid-metal-lbl{font-size:10px;font-weight:700;color:#555;text-shadow:0 1px 2px rgba(255,255,255,.8)}.oxacid-falling-metal{position:absolute;top:6px;left:74%;z-index:5;width:26px;height:140px;pointer-events:none}.oxacid-falling-dot{position:absolute;top:0;left:8px;display:block;width:10px;height:10px;border-radius:50%;border:1px solid #666;box-shadow:0 1px 3px #0003;opacity:0;animation:oxacidDropMetal .78s cubic-bezier(.24,.82,.27,1) forwards}.oxacid-hint{font-size:12px;color:#54657a;text-align:center;padding:6px 10px;border:1px dashed #c4d2e1;border-radius:10px;background:#f8fbff;max-width:260px}.oxacid-acid-lbl{font-size:12px;color:#4a6480;font-weight:600;text-align:center}.oxacid-status{padding:5px 14px;border-radius:12px;font-size:12px;font-weight:600;text-align:center;line-height:1.35;max-width:220px}.oxacid-status--reacted{background:#ffc8826b;color:#a04000;border:1px solid #e09040}.oxacid-status--none{background:#c3e4c36b;color:#005020;border:1px solid #80be80}@keyframes oxacidDropMetal{0%{transform:translate(var(--drop-x-start, 0px)) scale(.95);opacity:.95}to{transform:translate(var(--drop-x-end, -16px),132px) scale(.82);opacity:0}}@keyframes oxacidWave{0%{transform:translate(-6px) scaleX(1);opacity:.42}50%{transform:translate(6px) scaleX(1.04);opacity:.58}to{transform:translate(-6px) scaleX(1);opacity:.42}}@keyframes oxacidHaze{0%{transform:translateY(0) scale(1);opacity:.25}50%{transform:translateY(-6px) scale(1.04);opacity:.38}to{transform:translateY(0) scale(1);opacity:.25}}@keyframes oxacidLiquidPulse{0%{opacity:.32;transform:scale(1)}50%{opacity:.55;transform:scale(1.03)}to{opacity:.32;transform:scale(1)}}@keyframes gasUp{0%{opacity:.15;transform:translateY(0) scale(.65)}18%{opacity:1}75%{opacity:.9}to{opacity:0;transform:translate3d(var(--bubble-sway, 0px),-122px,0) scale(1.18)}}.simulation .sim-output pre{max-height:220px;overflow:auto}.sim-result-panel{border-color:#dfe6ef;background:#fcfdff}.sim-result-grid{display:grid;gap:10px}.sim-result-row{display:grid;grid-template-columns:130px 1fr;gap:12px;align-items:start;padding:6px 0;border-bottom:1px solid #edf1f5}.sim-result-row:last-child{border-bottom:none;padding-bottom:0}.sim-result-label{font-weight:700;color:#0f172a;letter-spacing:.01em}.sim-result-value{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;color:#1e293b;line-height:1.4}.sim-result-empty{font-size:15px;color:#475569}.color-swatch{width:28px;height:18px;display:inline-block;vertical-align:middle;margin-left:8px;border-radius:4px;border:1px solid #ccc;transition:background-color .6s ease}.bulb{width:40px;height:40px;border-radius:50%;background:#bbb;display:inline-block;box-shadow:none;transition:box-shadow .3s,transform .3s}.bulb.lit{background:#ffd54f;box-shadow:0 0 18px 6px #ffd54f59;transform:scale(1.05)}.egg-container{width:120px;height:120px;background:linear-gradient(#e6f7ff,#bfeaff);border-radius:8px;position:relative;overflow:hidden;border:1px solid #cfeefc}.egg{width:34px;height:44px;background:#fff;border-radius:50% 50% 45% 45%;position:absolute;left:43px;transition:top .8s cubic-bezier(.2,.9,.2,1);box-shadow:0 2px 6px #00000026}.egg.sinking{top:72px}.egg.neutral{top:42px}.egg.floating{top:12px}.acidlab .acidlab-wrap{position:relative;background:#f3f5f7;border:1px solid #eee;border-radius:10px;padding:16px}.acidlab .beakers{display:flex;gap:12px;align-items:flex-end;justify-content:flex-start;flex-wrap:nowrap;padding-top:54px}.acidlab .beaker{flex:0 0 110px;min-width:0;cursor:pointer;-webkit-user-select:none;user-select:none}.acidlab .beaker.target .beaker-glass,.acidlab .beaker.target .erlen-wrap{outline:2px solid var(--accent)}.acidlab .beaker-glass{height:120px;border:2px solid #cfd6de;border-radius:10px 10px 14px 14px;position:relative;overflow:hidden;background:transparent;box-shadow:inset 0 0 0 1px #fff9,0 2px 6px #0000000f}.acidlab .beaker-glass:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffffa6,#ffffff0d);pointer-events:none}.acidlab .beaker-glass:after{content:"";position:absolute;top:10px;left:10px;width:16px;height:90px;border-radius:10px;background:linear-gradient(180deg,#ffffffa6,#fff0);opacity:.7;pointer-events:none}.acidlab .liquid{position:absolute;left:0;right:0;bottom:0;height:58%;background:purple;transition:background-color .7s ease}.acidlab .beaker-label{font-size:14px;margin-top:8px;text-align:center;color:#333}.acidlab .erlen-wrap{height:120px;border-radius:12px;overflow:hidden;background:transparent}.acidlab .acidlab-indicators{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.acidlab .acidlab-indicator{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;border:1px solid #eee;background:#fff;cursor:pointer}.acidlab .acidlab-indicator.selected{outline:2px solid var(--accent)}.acidlab .acidlab-swatch{width:18px;height:18px;border-radius:6px;border:1px solid #ddd;flex:0 0 auto}.acidlab .dropper{position:absolute;top:6px;width:44px;height:64px;touch-action:none;z-index:3;--dropColor: var(--accent) }.acidlab .dropper-bulb{width:24px;height:18px;margin:0 auto 2px;border-radius:14px;background:linear-gradient(#f2f5f8,#cfd6de);border:1px solid #cfd6de}.acidlab .dropper-body{width:14px;height:36px;margin:0 auto;border-radius:8px;border:1px solid #cfd6de;background:linear-gradient(#fff,#eef2f6);position:relative;overflow:hidden}.acidlab .dropper-liquid{position:absolute;left:1px;right:1px;bottom:1px;height:62%;border-radius:7px;background:var(--dropColor);opacity:.85}.acidlab .dropper-tip{width:0;height:0;margin:0 auto;border-left:8px solid transparent;border-right:8px solid transparent;border-top:12px solid #cfd6de}.acidlab .drop{position:absolute;left:50%;top:52px;width:8px;height:8px;margin-left:-4px;background:var(--dropColor);border-radius:50%;opacity:0;border:1px solid rgba(0,0,0,.18);box-shadow:0 1px 2px #0000001a}.acidlab .drop.go{animation:dropFall .52s ease-in forwards}@keyframes dropFall{0%{transform:translateY(0);opacity:0}15%{opacity:1}to{transform:translateY(120px);opacity:0}}.mix-pane .mix-type-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}.mix-pane .mix-type-card{border:1px solid #d7e3f3;border-radius:12px;padding:10px;background:#f8fbff}.mix-pane .mix-type-card.active{outline:2px solid var(--accent)}.mix-pane .mix-type-title{font-weight:700;margin-bottom:4px}.mix-pane .mix-type-text{font-size:14px;color:#334155}.mix-pane .mix-lab-wrap{display:grid;grid-template-columns:minmax(320px,1fr) minmax(260px,320px);gap:14px;align-items:start}.mix-pane .mix-controls{display:grid;gap:10px}.mix-pane .mix-actions{display:flex;gap:8px;flex-wrap:wrap}.mix-pane .mix-box-title{font-weight:700;margin-bottom:6px}.mix-pane .mix-box{border:1px solid #e2e8f0;border-radius:12px;padding:10px;background:#fff}.mix-pane .mix-chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.mix-pane .mix-chip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;border:1px solid #d7e3f3;border-radius:999px;background:#fff;text-align:left}.mix-pane .mix-chip strong{font-size:14px;color:#334155}.mix-pane .mix-chip.selected{outline:2px solid var(--accent);background:#f8fbff}.mix-pane .mix-chip:disabled{opacity:.56;cursor:not-allowed}.mix-pane .mix-status{font-size:15px;color:#1e293b;display:grid;gap:6px}.mix-pane .mix-visual{position:relative;min-height:320px;border:1px solid #d7e3f3;border-radius:14px;background:#f8fbff;display:flex;align-items:flex-end;justify-content:center;padding:14px}.mix-pane .mix-faucet{position:absolute;top:10px;left:50%;margin-left:28px;width:70px;height:110px;pointer-events:none}.mix-pane .mix-faucet-head{position:absolute;right:4px;top:0;width:48px;height:14px;border-radius:999px;background:#cbd5e1;border:1px solid #94a3b8}.mix-pane .mix-faucet-neck{position:absolute;right:10px;top:10px;width:18px;height:42px;border-radius:6px;background:#e2e8f0;border:1px solid #94a3b8}.mix-pane .mix-faucet-stream{position:absolute;right:16px;top:52px;width:6px;height:0;border-radius:999px;background:#9ed8ff;opacity:.9}.mix-pane .mix-faucet.flowing .mix-faucet-stream{animation:mixFaucetFlow .7s ease}.mix-pane .mix-beaker{position:relative;width:210px;height:240px;border:3px solid #cfd6de;border-top:6px solid #b7c3d4;border-radius:12px 12px 16px 16px;background:linear-gradient(180deg,#ffffffb3,#f4f8fdcc);overflow:hidden}.mix-pane .mix-beaker-glass{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffff38,#fff0)}.mix-pane .mix-liquid-base{position:absolute;left:0;right:0;bottom:0;transition:height .32s ease,background-color .32s ease}.mix-pane .mix-liquid-base.uniform{background-image:linear-gradient(180deg,#fff3,#ffffff0a)}.mix-pane .mix-liquid-layer{position:absolute;left:0;right:0;top:0;border-bottom:1px dashed rgba(15,23,42,.2);opacity:.85}.mix-pane .mix-particles{position:absolute;left:0;right:0;bottom:0;height:66%;pointer-events:none}.mix-pane .mix-particle{position:absolute;top:var(--start-y, 18%);width:var(--particle-size, 6px);height:var(--particle-size, 6px);border-radius:50%;background:#475569;opacity:.78;box-shadow:0 0 0 1px #ffffff2e}.mix-pane .mix-particle.settling{animation-name:mixParticleSettle;animation-timing-function:cubic-bezier(.22,.64,.19,.99);animation-fill-mode:forwards}.mix-pane .mix-solid-drop{position:absolute;left:50%;top:-6px;width:90px;height:120px;margin-left:-45px;pointer-events:none}.mix-pane .mix-solid-dot{position:absolute;width:7px;height:7px;border-radius:50%;background:#64748b;opacity:0;animation:mixSolidDrop .65s ease forwards}.mix-pane .mix-solid-dot:nth-child(1){left:8px;animation-delay:0ms}.mix-pane .mix-solid-dot:nth-child(2){left:18px;animation-delay:70ms}.mix-pane .mix-solid-dot:nth-child(3){left:30px;animation-delay:.13s}.mix-pane .mix-solid-dot:nth-child(4){left:42px;animation-delay:.17s}.mix-pane .mix-solid-dot:nth-child(5){left:54px;animation-delay:.2s}.mix-pane .mix-solid-dot:nth-child(6){left:66px;animation-delay:.25s}.mix-pane .mix-solid-dot:nth-child(7){left:76px;animation-delay:.3s}@keyframes mixFaucetFlow{0%{height:0;opacity:0}15%{height:80px;opacity:1}to{height:0;opacity:0}}@keyframes mixSolidDrop{0%{transform:translateY(0);opacity:0}20%{opacity:1}to{transform:translateY(110px);opacity:0}}@keyframes mixParticleSettle{0%{top:var(--start-y, 18%);transform:translate(0);opacity:.82}70%{opacity:.8}to{top:var(--end-y, 90%);transform:translate(var(--drift-x, 0));opacity:.95}}.sep-pane .sep-toolbar{display:grid;gap:10px;margin-bottom:12px}.sep-pane .sep-method-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:8px}.sep-pane .sep-method-btn{display:grid;gap:3px;text-align:left;border:1px solid #d7e3f3;border-radius:12px;padding:8px 10px;background:#fff;transition:box-shadow .2s ease}.sep-pane .sep-method-btn strong{font-size:15px;color:#0f172a}.sep-pane .sep-method-btn span{font-size:13px;color:#475569}.sep-pane .sep-method-btn.active{outline:2px solid var(--accent);background:#f8fbff}.sep-pane .sep-option-row{display:flex;flex-wrap:wrap;gap:8px}.sep-pane .sep-option-btn,.sep-pane .sep-param-btn{border:1px solid #d7e3f3;border-radius:999px;padding:6px 10px;background:#fff;font-size:14px;transition:box-shadow .2s ease}.sep-pane .sep-option-btn.active,.sep-pane .sep-param-btn.active{outline:2px solid var(--accent);background:#f8fbff}.sep-pane .sep-parameter-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sep-pane .sep-param-label{font-size:14px;font-weight:700;color:#334155}.sep-pane .sep-param-options{display:flex;gap:8px;flex-wrap:wrap}.sep-pane .sep-stepper{display:inline-flex;align-items:center;gap:10px;border:1px solid #d7e3f3;border-radius:999px;padding:4px 8px;background:#fff}.sep-pane .sep-stepper button{width:28px;height:28px;border:1px solid #c7d6ea;border-radius:50%;background:#f8fbff;font-size:18px;line-height:1}.sep-pane .sep-stepper strong{min-width:24px;text-align:center;color:#0f172a}.sep-pane .sep-action-row{display:flex;gap:8px;flex-wrap:wrap}.sep-pane .sep-status-panel{display:grid;gap:6px;margin-bottom:12px;font-size:15px;color:#334155}.sep-pane .sep-visual-wrap{border:1px solid #cfddef;border-radius:14px;background:linear-gradient(180deg,#f8fbff,#f1f6ff);box-shadow:inset 0 0 0 1px #ffffffb3;padding:12px;min-height:300px}.sep-pane .sep-sim{position:relative;min-height:320px;color:#1e293b}.sep-pane .sep-mini-title{font-size:14px;font-weight:700;color:#334155}.sep-pane .sep-mini-note{font-size:14px;color:#475569;text-align:center;line-height:1.35;max-width:170px}.sep-pane .sep-col{display:grid;justify-items:center;gap:6px}.sep-pane .sep-beaker{position:relative;width:112px;height:145px;border:2px solid #9fb1c8;border-top:4px solid #8ea4c0;border-radius:10px 10px 14px 14px;overflow:hidden;background:linear-gradient(180deg,#ffffffd1,#edf4ffdb);box-shadow:0 8px 16px #0f172a14}.sep-pane .sep-beaker-liquid{position:absolute;left:0;right:0;bottom:0;height:58%;transition:height 2.1s ease}.sep-pane .sep-solid-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.sep-pane .sep-solid-particle{position:absolute;width:6px;height:6px;border-radius:50%;opacity:.78}.sep-pane .sep-solid-particle.pasta{border-radius:999px;box-shadow:inset 0 1px #ffffff47}.sep-pane .sep-solid-particle:nth-child(1){left:16%;top:58%}.sep-pane .sep-solid-particle:nth-child(2){left:28%;top:62%}.sep-pane .sep-solid-particle:nth-child(3){left:42%;top:64%}.sep-pane .sep-solid-particle:nth-child(4){left:54%;top:61%}.sep-pane .sep-solid-particle:nth-child(5){left:66%;top:63%}.sep-pane .sep-solid-particle:nth-child(6){left:77%;top:60%}.sep-pane .sep-solid-particle:nth-child(7){left:20%;top:71%}.sep-pane .sep-solid-particle:nth-child(8){left:38%;top:73%}.sep-pane .sep-solid-particle:nth-child(9){left:58%;top:74%}.sep-pane .sep-solid-particle:nth-child(10){left:74%;top:72%}.sep-pane .sep-funnel-stack{display:grid;justify-items:center;align-items:start;gap:0;position:relative;padding-bottom:0}.sep-pane .sep-funnel-top{width:102px;height:64px;clip-path:polygon(0 0,100% 0,68% 100%,32% 100%);background:linear-gradient(180deg,#e2eaf7f2,#cddbeef2);border:2px solid #9fb1c8;box-shadow:inset 0 8px 14px #ffffff7a;position:relative}.sep-pane .sep-funnel-residue{position:absolute;left:50%;bottom:8px;transform:translate(-50%);width:56px;height:9px;border-radius:999px;opacity:0;transition:opacity .45s ease}.sep-pane .sep-funnel-neck{width:10px;height:66px;background:#d8e3f3;border:1px solid #9fb1c8;border-radius:0 0 8px 8px}.sep-pane .sep-filter-stream{position:absolute;left:50%;top:126px;transform:translate(-50%);width:5px;height:0;border-radius:999px;opacity:0;pointer-events:none}.sep-pane .sep-sim-filtration{display:grid;align-content:center}.sep-pane .sep-filtration-rig{display:grid;grid-template-columns:minmax(160px,210px) minmax(160px,200px);gap:20px;align-items:start;justify-content:center;min-height:290px}.sep-pane .sep-filtration-source{position:relative;display:grid;justify-items:center;gap:8px;padding-top:8px}.sep-pane .sep-source-beaker-shell{position:relative;display:grid;justify-items:center;transform:translate(var(--drag-x,0),var(--drag-y,0));transition:transform .28s ease;touch-action:none}.sep-pane .sep-source-beaker-shell.interactive{cursor:grab}.sep-pane .sep-source-beaker-shell.dragging{cursor:grabbing;transition:none}.sep-pane .sep-source-beaker-shell.interactive .sep-source-beaker{box-shadow:0 0 0 2px #38bdf847,0 8px 16px #0f172a14}.sep-pane .sep-source-beaker-shell.over-funnel .sep-source-beaker{box-shadow:0 0 0 2px #3b82f66b,0 10px 18px #0f172a1f}.sep-pane .sep-sim-filtration.phase-running .sep-source-beaker-shell,.sep-pane .sep-sim-filtration.phase-done .sep-source-beaker-shell{transform:translate(96px,-26px)!important;transition:transform .8s ease!important;z-index:10}.sep-pane .sep-source-beaker{width:126px;height:154px;transform-origin:88% 92%;transition:transform 3.7s ease}.sep-pane .sep-source-liquid{height:64%;transition:height 4s ease;filter:saturate(1.2) contrast(1.04);opacity:.95;overflow:hidden}.sep-pane .sep-source-particles{transition:opacity 1.2s ease}.sep-pane .sep-source-stream{position:absolute;right:-68px;left:auto;top:30px;width:80px;height:7px;border-radius:999px;transform:rotate(32deg);opacity:0}.sep-pane .sep-filtration-help{min-height:32px;max-width:190px;text-align:center}.sep-pane .sep-filtration-target{display:grid;justify-items:center;align-items:start;padding-top:20%}.sep-pane .sep-filtration-main-col{display:grid;justify-items:center;gap:6px;min-width:148px}.sep-pane .sep-filtration-funnel-wrap{position:relative;height:196px;display:grid;justify-items:center;align-items:start;overflow:visible}.sep-pane .sep-filtration-funnel{margin-top:10px;transform:none!important;transition:none!important}.sep-pane .sep-filtration-funnel.drop-active .sep-funnel-top{box-shadow:inset 0 8px 14px #ffffff7a,0 0 0 2px #3b82f647}.sep-pane .sep-filtration-residue-note{position:absolute;left:calc(50% + 66px);top:52px;min-height:auto;max-width:120px;text-align:left;opacity:0;transition:opacity .35s ease}.sep-pane .sep-filtration-main-col .sep-mini-note{min-height:30px}.sep-pane .sep-filtrate-title,.sep-pane .sep-filtrate-note{opacity:0;transition:opacity .35s ease}.sep-pane .sep-sim-filtration.phase-done .sep-filtration-residue-note,.sep-pane .sep-sim-filtration.phase-done .sep-filtrate-title,.sep-pane .sep-sim-filtration.phase-done .sep-filtrate-note{opacity:1}.sep-pane .sep-filtration-filtrate-beaker{width:146px;height:138px}.sep-pane .sep-filtrate-liquid{height:0;transition:height 4s ease;filter:saturate(1.2) contrast(1.04);opacity:.95}.sep-pane .sep-sim-filtration.phase-running .sep-funnel-stack,.sep-pane .sep-sim-filtration.phase-done .sep-funnel-stack{padding-bottom:92px}.sep-pane .sep-sim-filtration.phase-running .sep-source-stream{animation:sepSourceStream 4.45s linear;z-index:11}.sep-pane .sep-sim-filtration.phase-running .sep-filter-stream{animation:sepStreamDown 4.45s linear}.sep-pane .sep-sim-filtration.phase-running .sep-source-beaker,.sep-pane .sep-sim-filtration.phase-done .sep-source-beaker{transform:rotate(44deg) translate(1px,-9px)}.sep-pane .sep-sim-filtration.phase-running .sep-source-liquid{height:22%}.sep-pane .sep-sim-filtration.phase-done .sep-source-liquid{height:0}.sep-pane .sep-sim-filtration.phase-running .sep-filtrate-liquid,.sep-pane .sep-sim-filtration.phase-done .sep-filtrate-liquid{height:58%}.sep-pane .sep-sim-filtration.phase-running .sep-source-particles{opacity:.32}.sep-pane .sep-sim-filtration.phase-done .sep-source-particles{opacity:0}.sep-pane .sep-sim-filtration.phase-running .sep-funnel-residue,.sep-pane .sep-sim-filtration.phase-done .sep-funnel-residue{opacity:.92}.sep-pane .sep-sim-foot{width:100%;margin-top:8px;display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:14px;color:#334155;text-align:center}.sep-pane .sep-sim-foot-right{grid-template-columns:1fr;justify-items:end;text-align:right;padding-right:18px}.sep-pane .sep-sim-distillation{display:grid;align-content:center;min-height:300px}.sep-pane .sep-dist-svg{display:block;width:100%;height:auto;max-width:680px;margin:0 auto}.pixi-surface-host canvas{display:block;width:100%;height:100%}.sep-pane .sep-sim-distillation-pixi{min-height:320px}.sep-pane .sep-pixi-distillation-wrap{position:relative;width:100%;max-width:680px;height:320px;margin:0 auto}.sep-pane .sep-pixi-distillation-surface{width:100%;height:100%;border-radius:14px;overflow:hidden}.sep-pane .sep-distillation-overlay{position:absolute;font-size:12px;line-height:1.2;color:#475569;pointer-events:none;text-align:center}.sep-pane .sep-distillation-overlay-title{left:50%;top:18px;transform:translate(-50%);font-weight:700;color:#334155}.sep-pane .sep-distillation-object-hitbox{position:absolute;z-index:2;border:none;background:transparent;padding:0;margin:0;cursor:grab;touch-action:none;display:flex;align-items:center;justify-content:center;border-radius:999px}.sep-pane .sep-distillation-object-hitbox:active{cursor:grabbing}.sep-pane .sep-distillation-object-hitbox-dot{width:100%;height:100%;border-radius:999px;border:2px solid rgba(14,165,233,.95);background:radial-gradient(circle at 35% 35%,#f8fdff 0,#f8fdff 30%,#7dd3fc 32%,#0284c7);box-shadow:0 0 0 2px #ffffffeb,0 6px 12px #0284c738}.sep-pane .sep-distillation-object-hitbox:hover .sep-distillation-object-hitbox-dot,.sep-pane .sep-distillation-object-hitbox:focus-visible .sep-distillation-object-hitbox-dot{transform:scale(1.08);box-shadow:0 0 0 2px #fffffff5,0 8px 16px #0284c747}.sep-pane .sep-distillation-mini-menu{position:absolute;z-index:3;min-width:180px;max-width:220px;padding:10px 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fffffff7;box-shadow:0 12px 30px #0f172a29;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sep-pane .sep-distillation-mini-menu.is-notice{min-width:196px}.sep-pane .sep-distillation-mini-menu-title{font-size:12px;font-weight:700;color:#0f172a;margin-bottom:8px}.sep-pane .sep-distillation-mini-menu-note{font-size:11px;line-height:1.35;color:#475569}.sep-pane .sep-distillation-mini-menu-btn{display:inline-flex;align-items:center;justify-content:center;min-width:110px;padding:7px 10px;border:none;border-radius:8px;background:linear-gradient(180deg,#0ea5e9,#0284c7);color:#fff;font-size:12px;font-weight:700;cursor:pointer;margin-bottom:8px}.sep-pane .sep-distillation-mini-menu-btn:hover{filter:brightness(1.03)}.sep-pane .sep-distillation-overlay-subtitle{left:50%;top:34px;transform:translate(-50%);font-size:11px}.sep-pane .sep-distillation-overlay-flask{left:68px;top:44px;width:96px;font-weight:700;color:#334155}.sep-pane .sep-distillation-overlay-heater{left:56px;top:262px;width:120px;font-weight:700;color:#334155}.sep-pane .sep-distillation-overlay-receiver{right:64px;top:116px;width:92px;font-weight:700;color:#334155}.sep-pane .sep-distillation-overlay-receiver-note{right:44px;top:278px;width:132px}.sep-pane .sep-distillation-overlay-residue{left:36px;top:286px;width:148px}.sep-pane .sep-vapor-dot-svg{fill:#9ed8ff;opacity:0}.sep-pane .sep-sim-distillation.phase-running .sep-vapor-dot-svg{animation:sepVaporMove 1.9s linear infinite;animation-delay:var(--vdelay)}.sep-pane .sep-bubble-svg{fill:#ffffffe0;opacity:0}.sep-pane .sep-sim-distillation.phase-running .sep-bubble-svg{animation:sepBoilBubble 1.35s ease-in infinite;animation-delay:var(--bdelay)}.sep-pane .sep-sim-funnel,.sep-pane .sep-sim-extraction{display:grid;justify-items:center;align-content:start;gap:8px}.sep-pane .sep-funnel-main{display:grid;justify-items:center;gap:4px;position:relative;min-height:218px;padding-bottom:90px}.sep-pane .sep-separator-funnel{position:relative;width:144px;height:188px;clip-path:polygon(10% 2%,90% 2%,72% 72%,72% 92%,28% 92%,28% 72%);background:linear-gradient(180deg,#d7e8fff5,#b9d6fcf0);box-shadow:inset 0 0 0 3px #5a7eb8,inset 0 0 0 7px #ffffff70,0 10px 18px #0f172a24;overflow:hidden}.sep-pane .sep-separator-funnel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(100deg,#ffffff38,#fff0 42%);pointer-events:none}.sep-pane .sep-sim-funnel .sep-separator-funnel,.sep-pane .sep-sim-extraction .sep-separator-funnel{width:154px;height:204px;clip-path:polygon(11% 2%,89% 2%,76% 28%,64% 60%,59% 73%,59% 94%,41% 94%,41% 73%,36% 60%,24% 28%);background:linear-gradient(180deg,#d7ebfffa,#afd2fff5);box-shadow:inset 0 0 0 3px #3d6fba,inset 0 0 0 7px #ffffff80,0 12px 22px #0f172a29}.sep-pane .sep-sim-funnel .sep-separator-funnel:before,.sep-pane .sep-sim-extraction .sep-separator-funnel:before{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;clip-path:polygon(11% 2%,89% 2%,76% 28%,64% 60%,59% 73%,59% 94%,41% 94%,41% 73%,36% 60%,24% 28%);border:2px solid rgba(61,111,186,.44);opacity:.9;pointer-events:none}.sep-pane .sep-funnel-upper{position:absolute;left:0;right:0;top:0;height:55%;opacity:.98;transition:height 1.75s ease,bottom 1.75s ease,filter .95s ease}.sep-pane .sep-funnel-lower{position:absolute;left:0;right:0;bottom:0;height:45%;opacity:.95;transition:height 1.75s ease,filter .95s ease}.sep-pane .sep-funnel-valve{width:50px;height:14px;border-radius:999px;border:2px solid #3d6fba;background:#6990c8}.sep-pane .sep-funnel-drip{position:absolute;left:50%;top:206px;bottom:auto;transform:translate(-50%);width:5px;height:0;border-radius:999px;opacity:0;pointer-events:none}.sep-pane .sep-sim-funnel .sep-funnel-drip{top:222px}.sep-pane .sep-collector-wrap{display:grid;justify-items:center;gap:6px}.sep-pane .sep-collector-beaker{height:126px}.sep-pane .sep-collector-liquid,.sep-pane .sep-extract-collector{height:0;transition:height 1.85s ease;opacity:.96;filter:saturate(1.22) contrast(1.04)}.sep-pane .sep-sim-funnel.phase-running .sep-funnel-drip,.sep-pane .sep-sim-extraction.phase-running .sep-funnel-drip{animation:sepStreamDown 1.8s ease}.sep-pane .sep-funnel-legend{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;font-size:14px;color:#334155}.sep-pane .sep-sim-funnel .sep-collector-wrap,.sep-pane .sep-sim-extraction .sep-collector-wrap{transform:none}.sep-pane .sep-sim-sieve{display:grid;align-content:center}.sep-pane .sep-sieve-rig{display:flex;justify-content:center;gap:60px;align-items:flex-end;position:relative;min-height:380px;padding-bottom:20px;perspective:980px}.sep-pane .sep-sieve-top{display:grid;justify-items:center;gap:6px;transition:transform 1.2s ease,z-index 0s;z-index:2;transform:translate(0) rotateX(17deg);transform-style:preserve-3d}.sep-pane .sep-sieve-bottom{display:grid;justify-items:center;gap:6px;transition:transform 1.2s ease;z-index:1;transform:translate(0) rotateX(8deg);transform-style:preserve-3d}.sep-pane .sep-sim-sieve.phase-running .sep-sieve-top,.sep-pane .sep-sim-sieve.phase-done .sep-sieve-top{transform:translate(97px,-155px) rotateX(17deg)}.sep-pane .sep-sim-sieve.phase-running .sep-sieve-bottom,.sep-pane .sep-sim-sieve.phase-done .sep-sieve-bottom{transform:translate(-97px,40px) rotateX(8deg)}.sep-pane .sep-sieve-tool-label{font-size:13px;letter-spacing:.03em;color:#5b708c;font-weight:700}.sep-pane .sep-sieve-tray{position:relative;width:156px;height:98px;border:2px solid #9aaec8;border-radius:12px;background:linear-gradient(180deg,#f7fbff,#e9f1fc);box-shadow:inset 0 0 0 1px #ffffff8f,0 6px 10px #0f172a14;overflow:hidden;transform:translateZ(16px)}.sep-pane .sep-sieve-tray:before{content:"";position:absolute;top:10px;right:8px;bottom:10px;left:8px;border-radius:8px;background:repeating-linear-gradient(0deg,#92a5c06b 0,#92a5c06b 1px,#fff0 1px,#fff0 8px),repeating-linear-gradient(90deg,#92a5c06b 0,#92a5c06b 1px,#fff0 1px,#fff0 8px);box-shadow:inset 0 0 0 1px #97abc652}.sep-pane .sep-sieve-tray:after{content:"";position:absolute;left:0;right:0;top:0;height:16px;background:linear-gradient(180deg,#f0f6fff2,#e2ecf9c7);border-bottom:1px solid rgba(144,166,193,.52)}.sep-pane .sep-sieve-retained{position:absolute;width:11px;height:9px;border-radius:6px;opacity:.92;z-index:2}.sep-pane .sep-sieve-fine{position:absolute;width:6px;height:6px;border-radius:50%;opacity:.82;animation-delay:var(--delay);z-index:2}.sep-pane .sep-sim-sieve.phase-running .sep-sieve-tray{animation:sepSieveShake .88s ease-in-out infinite}.sep-pane .sep-sim-sieve.phase-running .sep-sieve-fine{animation:sepSieveFall 2.1s ease forwards;animation-delay:var(--delay)}.sep-pane .sep-sieve-collected{height:0;transition:height 2.9s ease;border-radius:4px 4px 8px 8px;clip-path:polygon(0 8%,15% 0,35% 6%,55% 2%,80% 9%,100% 3%,100% 100%,0 100%);background-image:radial-gradient(rgba(0,0,0,.2) 1px,transparent 1px);background-size:5px 5px}.sep-pane .sep-sieve-beaker{transform:translateZ(8px);box-shadow:0 12px 20px #0f172a24,inset 0 0 0 1px #ffffff61}.sep-pane .sep-sim-magnetic{display:grid;align-content:center;min-height:252px}.sep-pane .sep-magnetic-rig{position:relative;display:grid;justify-items:center;gap:8px;min-height:246px;width:min(100%,390px)}.sep-pane .sep-magnet-container{position:absolute;right:15px;top:-5px;display:flex;flex-direction:column;align-items:center;transition:transform 1.2s ease;z-index:3}.sep-pane .sep-magnet-label{font-size:12px;font-weight:700;color:#1e293b;margin-bottom:4px;padding:2px 6px;background:#f1f5f9;border-radius:4px;border:1px solid #cbd5e1}.sep-pane .sep-magnet-u-shape{width:50px;height:50px;border:12px solid #ef4444;border-bottom:0;border-radius:25px 25px 0 0;position:relative;box-sizing:border-box;box-shadow:0 -4px 8px #0000001a}.sep-pane .sep-magnet-pole{position:absolute;bottom:-16px;width:14px;height:16px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}.sep-pane .left-pole{left:-12px;background:#ef4444;border-radius:0 0 4px 4px}.sep-pane .right-pole{right:-12px;background:#3b82f6;border-radius:0 0 4px 4px}.sep-pane .sep-magnet-head:after{content:"";position:absolute;left:8px;top:3px;width:38px;height:9px;border-radius:6px;background:radial-gradient(circle at 4px 4px,#1e293bf5 0,#1e293bf5 2px,#fff0 2.1px),radial-gradient(circle at 10px 6px,#1e293bf5 0,#1e293bf5 2px,#fff0 2.1px),radial-gradient(circle at 16px 3px,#1e293bf5 0,#1e293bf5 2px,#fff0 2.1px),radial-gradient(circle at 22px 6px,#1e293bf5 0,#1e293bf5 2px,#fff0 2.1px),radial-gradient(circle at 28px 4px,#1e293bf5 0,#1e293bf5 2px,#fff0 2.1px);opacity:0;transition:opacity .35s ease}.sep-pane .sep-mix-tray{position:relative;margin-top:66px;width:228px;height:126px;border:2px solid #9fb1c8;border-radius:12px;background:#eef4fc;box-shadow:0 6px 12px #0f172a14;overflow:hidden;z-index:1}.sep-pane .sep-sim-magnetic.phase-running .sep-magnet-head,.sep-pane .sep-sim-magnetic.phase-done .sep-magnet-head,.sep-pane .sep-sim-magnetic.phase-running .sep-magnet-arm,.sep-pane .sep-sim-magnetic.phase-done .sep-magnet-arm{transform:translate(-64px,54px)}.sep-pane .sep-sim-magnetic.phase-running .sep-magnet-head:after,.sep-pane .sep-sim-magnetic.phase-done .sep-magnet-head:after{opacity:.98}.sep-pane .sep-mag-particle{position:absolute;width:8px;height:8px;border-radius:50%;opacity:.88}.sep-pane .sep-mag-particle.magnetic{transition:transform 1s ease,opacity .7s ease;transition-delay:var(--delay, 0ms)}.sep-pane .sep-sim-magnetic.phase-running .sep-mag-particle.magnetic,.sep-pane .sep-sim-magnetic.phase-done .sep-mag-particle.magnetic{transform:translate(var(--mx),var(--my));opacity:.98}.sep-pane .sep-mag-legend{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;font-size:14px;color:#334155}.sep-pane .sep-extraction-funnel{overflow:visible}.sep-pane .sep-extract-dots{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.sep-pane .sep-extract-dot{position:absolute;width:7px;height:7px;border-radius:50%;opacity:.8;animation-delay:var(--delay)}.sep-pane .sep-sim-extraction.extract-upper.phase-running .sep-extract-dot{animation:sepExtractToUpper 1.05s ease forwards;animation-delay:var(--delay)}.sep-pane .sep-sim-extraction.extract-lower.phase-running .sep-extract-dot{animation:sepExtractToLower 1.05s ease forwards;animation-delay:var(--delay)}.sep-pane .sep-sim-extraction.extract-upper.phase-running .sep-funnel-upper,.sep-pane .sep-sim-extraction.extract-upper.phase-done .sep-funnel-upper,.sep-pane .sep-sim-extraction.extract-lower.phase-running .sep-funnel-lower,.sep-pane .sep-sim-extraction.extract-lower.phase-done .sep-funnel-lower{filter:saturate(1.25) brightness(.95)}.sep-pane .sep-sim-soxhlet{display:grid;justify-items:center;align-content:center;min-height:290px}.sep-pane .sep-soxhlet-rig{display:grid;justify-items:center;gap:8px;position:relative;width:min(100%,340px);padding-top:6px}.sep-pane .sep-soxhlet-condenser{display:grid;justify-items:center;gap:4px}.sep-pane .sep-soxhlet-cond-title{font-size:12px;font-weight:700;color:#334155}.sep-pane .sep-soxhlet-condenser-body{width:76px;height:52px;border:2px solid #9fb1c8;border-radius:14px;background:linear-gradient(180deg,#e4f3ffdb,#cce1f2e0);box-shadow:inset 0 7px 12px #ffffff80,0 6px 10px #0f172a14}.sep-pane .sep-soxhlet-extractor{position:relative;display:grid;justify-items:center}.sep-pane .sep-soxhlet-chamber{width:94px;height:108px;border:2px solid #9fb1c8;border-radius:12px;background:linear-gradient(180deg,#f5faffd1,#e3edfadb);overflow:hidden;position:relative}.sep-pane .sep-soxhlet-chamber-liquid{position:absolute;left:0;right:0;bottom:0;height:18%;opacity:.86;transition:height 1.9s ease}.sep-pane .sep-soxhlet-solid-bed{position:absolute;left:18%;right:18%;top:40%;height:16px;border-radius:999px;background:radial-gradient(circle at 20% 45%,#9a6538 0 2px,transparent 3px),radial-gradient(circle at 48% 40%,#7a4b27 0 2px,transparent 3px),radial-gradient(circle at 74% 50%,#9a6538 0 2px,transparent 3px),#b78658;opacity:.94}.sep-pane .sep-soxhlet-siphon{position:absolute;right:-8px;top:12px;width:16px;height:96px;border:2px solid #9fb1c8;border-left:none;border-radius:0 12px 12px 0;background:#ebf3fbe0}.sep-pane .sep-soxhlet-drip-line{position:absolute;left:50%;top:109px;transform:translate(-50%);width:4px;height:0;border-radius:999px;background:#8b5e34;opacity:0}.sep-pane .sep-soxhlet-flask-wrap{display:grid;justify-items:center;gap:6px}.sep-pane .sep-soxhlet-flask{width:126px;height:126px}.sep-pane .sep-soxhlet-flask-liquid{position:absolute;left:0;right:0;bottom:0;height:36%;transition:height 2.1s ease;opacity:.92;filter:saturate(1.14)}.sep-pane .sep-soxhlet-bubble{position:absolute;left:48%;bottom:24px;width:7px;height:7px;border-radius:50%;background:#ffffffdb;opacity:0;animation-delay:var(--delay)}.sep-pane .sep-sim-soxhlet.phase-running .sep-soxhlet-bubble{animation:sepSoxhletBubble 1.25s ease-in infinite;animation-delay:var(--delay)}.sep-pane .sep-sim-soxhlet.phase-running .sep-soxhlet-drip-line{animation:sepStreamDown 1.45s ease}.sep-pane .sep-sim-soxhlet.phase-done .sep-soxhlet-drip-line{height:78px;opacity:.88}@keyframes sepSourceStream{0%{opacity:0;transform:rotate(24deg) scaleX(.1)}18%{opacity:.95;transform:rotate(24deg) scaleX(1)}82%{opacity:.95;transform:rotate(24deg) scaleX(1)}to{opacity:0;transform:rotate(24deg) scaleX(.1)}}@keyframes sepStreamDown{0%{height:0;opacity:0}18%{height:86px;opacity:.95}82%{height:86px;opacity:.95}to{height:0;opacity:0}}@keyframes sepBoilBubble{0%{transform:translateY(0) scale(.6);opacity:0}20%{opacity:.9}to{transform:translateY(-42px) scale(1.15);opacity:0}}@keyframes sepVaporMove{0%{left:-10px;opacity:0}10%{opacity:1}90%{opacity:1}to{left:136px;opacity:0}}@keyframes sepSieveFall{0%{transform:translateY(0);opacity:.8}to{transform:translateY(var(--drop-distance, 54px));opacity:0}}@keyframes sepSieveShake{0%{transform:translate(0)}25%{transform:translate(-2px)}50%{transform:translate(2px)}75%{transform:translate(-1px)}to{transform:translate(0)}}@keyframes sepExtractToUpper{0%{transform:translateY(0);opacity:.8}to{transform:translateY(-50px);opacity:0}}@keyframes sepExtractToLower{0%{transform:translateY(0);opacity:.8}to{transform:translateY(50px);opacity:0}}@keyframes sepSoxhletBubble{0%{transform:translate(-8px) scale(.7);opacity:0}22%{opacity:.88}to{transform:translate(10px,-44px) scale(1.1);opacity:0}}.quiz-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quiz-card{display:flex;flex-direction:column;gap:10px}.quiz-card-head{display:flex;gap:12px;align-items:flex-start}.quiz-img{width:56px;height:56px;flex:0 0 auto}.quiz-options{display:flex;gap:8px;flex-wrap:wrap}.quiz-option{padding:8px 10px;border:1px solid #eee;border-radius:10px;background:#fff;cursor:pointer;font:inherit;color:inherit}.quiz-option.selected,.quiz-option.correct{outline:2px solid var(--accent)}.quiz-option.wrong{outline:2px dashed var(--accent)}.ecg-pane .ecg-title-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ecg-pane .ecg-subtitle{margin-top:0}.ecg-pane .ecg-chip{font-size:14px;border:1px solid #d5dce5;border-radius:999px;padding:4px 10px;background:#fff}.ecg-level-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.ecg-level-card{position:relative;overflow:hidden}.ecg-level-card:after{content:"";position:absolute;right:-24px;bottom:-34px;width:90px;height:90px;border-radius:50%;background:#2a9df41f}.ecg-level-stars{letter-spacing:2px;color:#0f172a;font-size:15px}.ecg-level-icons{display:flex;gap:8px;margin-top:10px;font-size:20px}.ecg-hud{display:grid;gap:8px}.ecg-hud-row{display:flex;gap:8px;flex-wrap:wrap}.ecg-stat{border:1px solid #d7e3f3;background:#f8fbff;border-radius:999px;padding:6px 10px;font-size:14px}.ecg-progress-wrap{display:grid;gap:4px}.ecg-progress-label{font-size:13px;color:#475569}.ecg-progress-track{width:100%;height:8px;border-radius:999px;background:#e6edf6;overflow:hidden}.ecg-progress-track>span{display:block;height:100%;background:var(--accent);transition:width .25s ease}.ecg-progress-track.time>span{background:#1f7cc5}.ecg-arena{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:14px;align-items:stretch}.ecg-scene{border:1px solid #d7e3f3;border-radius:14px;padding:12px;background:#f8fbff;display:grid;gap:8px;justify-items:center;text-align:center;position:relative;overflow:hidden}.ecg-scene:after{content:"";position:absolute;left:-20px;top:-20px;width:80px;height:80px;border-radius:50%;background:#2a9df41f}.ecg-scene-icon{font-size:24px;position:relative;z-index:2}.ecg-scene-img{width:88px;height:88px;object-fit:contain;position:relative;z-index:2}.ecg-scene-meta{display:grid;gap:4px;width:100%;position:relative;z-index:2}.ecg-scene-formula{font-size:24px;font-weight:700;line-height:1.1}.ecg-scene-name{font-size:15px;color:#334155}.ecg-mini-badges{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.ecg-mini-badges span{font-size:13px;border:1px solid #d7e3f3;background:#fff;border-radius:999px;padding:4px 8px}.ecg-question-card{border:1px solid #e4e8ee;border-radius:14px;padding:12px;background:#fff;display:grid;align-content:start}.ecg-options-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.ecg-options-grid .quiz-option{text-align:left;min-height:44px}.ecg-feedback{display:flex;align-items:flex-start;gap:8px;background:#f8fbff;border:1px solid #d7e3f3;border-radius:10px;padding:8px}.ecg-combo-visual{min-height:22px;margin-top:8px;letter-spacing:2px;font-size:20px}.ecg-result{text-align:left;background:linear-gradient(180deg,#fff,#f8fbff)}.ecg-result-stars{font-size:28px;letter-spacing:3px;margin:4px 0 8px}.ecg-result-label{font-size:15px;margin-bottom:10px}.quiz-accordion{width:100%;background:transparent;border:none;padding:0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font:inherit;color:inherit}.quiz-accordion:focus{outline:none}.quiz-accordion:focus-visible{outline:2px solid var(--accent);border-radius:10px}.quiz-accordion-body{margin-top:12px}.product-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.product-card{border:1px solid #eee;border-radius:10px;background:#fff;padding:10px;cursor:pointer;font:inherit;color:inherit;text-align:center}.product-card.selected{outline:2px solid var(--accent)}.product-img{width:48px;height:48px;display:block;margin:0 auto 6px}.acid-maze .acid-maze-wrap{display:grid;grid-template-columns:auto minmax(280px,1fr);gap:14px;align-items:start}.acid-maze .acid-maze-levels{display:flex;gap:8px;flex-wrap:wrap}.acid-maze .acid-maze-levels button{font-size:14px}.acid-maze .acid-maze-grid{display:grid;gap:6px;background:linear-gradient(180deg,#eef3f9,#dfe7f2);padding:12px;border-radius:14px;width:max-content;border:1px solid #d6e1ef;box-shadow:0 8px 20px #0f172a1a,inset 0 1px #ffffffb3;perspective:620px;transform:rotateX(8deg);transform-origin:center top}.acid-maze .acid-maze-cell{position:relative;width:38px;height:38px;border-radius:10px;background:linear-gradient(180deg,#d6dde7,#c5cfdb);display:flex;align-items:center;justify-content:center;font-size:20px;border:1px solid #c1cad7;box-shadow:0 2px #b2bcc9,0 6px 10px #1e293b24;transform:translateZ(0);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.acid-maze .acid-maze-cell:before{content:"";position:absolute;left:5px;right:5px;top:4px;height:9px;border-radius:999px;background:linear-gradient(180deg,#ffffff8c,#fff0);pointer-events:none}.acid-maze .acid-maze-cell.path{background:linear-gradient(180deg,#fcfdff,#ecf3fc);border-color:#cfe0f5;box-shadow:0 2px #c4d7ef,0 6px 12px #1e293b1f}.acid-maze .acid-maze-cell.start{background:radial-gradient(circle at 30% 25%,#f0f8ff,#d7ebff 72%);border-color:#b8d6f7;box-shadow:0 2px #a9c8e9,0 0 0 2px #2a9df426,0 6px 12px #1e293b24}.acid-maze .acid-maze-cell.goal{background:radial-gradient(circle at 30% 25%,#fffdf0,#fff1b8 70%);border-color:#e8cf75;box-shadow:0 2px #dcbc5e,0 6px 12px #c3922133;transform:translateZ(3px)}.acid-maze .acid-maze-cell.player{border-color:var(--accent);box-shadow:0 2px #2587d1,0 0 0 2px #2a9df438,0 8px 14px #1e293b2e;transform:translateZ(6px) scale(1.02)}.acid-maze .acid-maze-goal-icon,.acid-maze .acid-maze-player-icon,.acid-maze .acid-maze-start-icon{filter:drop-shadow(0 2px 2px rgba(15,23,42,.28));line-height:1;transform:translateY(-1px)}.acid-maze .acid-maze-goal-icon{font-size:19px}.acid-maze .acid-maze-player-icon{font-size:20px}.acid-maze .acid-maze-start-icon{font-size:18px;opacity:.92}.acid-maze .acid-maze-player-icon.walk{animation:acidRobotWalk .38s ease}.acid-maze .acid-maze-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.acid-maze .acid-maze-chip{font-size:14px;padding:6px 8px;border:1px solid #d7e3f3;border-radius:999px;background:#f8fbff;color:#1e293b}.acid-maze .acid-maze-success{position:relative;overflow:hidden}.acid-maze .acid-maze-fireworks{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.acid-maze .acid-firework{position:absolute;left:var(--fx-left);top:var(--fx-top);width:8px;height:8px;border-radius:50%;background:#ffd166;box-shadow:0 -14px #ffd166,0 14px #ef476f,14px 0 #06d6a0,-14px 0 #118ab2,10px 10px #8338ec,-10px -10px #ff9f1c,10px -10px #80ed99,-10px 10px #ff6b6b;opacity:0;transform:scale(.4);animation:acidFirework 1.2s ease-out infinite;animation-delay:var(--fx-delay)}.crossword-pane .crossword-wrap{display:grid;gap:12px;align-items:start;overflow:auto}.crossword-pane .crossword-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between}.crossword-pane .crossword-difficulty{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.crossword-pane .crossword-actions{display:flex;gap:8px;flex-wrap:wrap}.crossword-pane .crossword-meta{font-size:15px;color:#334155}.crossword-pane .crossword-clue-viewer{display:grid;gap:4px;font-size:15px;color:#334155;background:#f8fbff;border:1px solid #d7e3f3;border-radius:10px;padding:9px 11px}.crossword-pane .crossword-clue-viewer strong{color:#0f172a}.crossword-pane .crossword-layout{display:grid;grid-template-columns:minmax(420px,1fr) minmax(280px,360px);gap:12px;align-items:start}.crossword-pane .crossword-board{--crossword-cell-size:52px;overflow:auto;border:1px solid #d7e3f3;border-radius:12px;padding:10px;background:linear-gradient(180deg,#f8fbff,#f1f6ff)}.crossword-pane .crossword-grid{display:grid;gap:4px;background:#dbe4f1;border-radius:10px;padding:8px;width:max-content}.crossword-pane .crossword-grid-clarified{box-shadow:inset 0 0 0 1px #ffffff9e}.crossword-pane .crossword-cell{position:relative;width:var(--crossword-cell-size, 52px);height:var(--crossword-cell-size, 52px);border-radius:7px;display:flex;align-items:center;justify-content:center;text-transform:uppercase;overflow:hidden}.crossword-pane .crossword-cell.blocked{background:#9fb0c7}.crossword-pane .crossword-cell.used{background:#fff;border:1px solid #ccd8e7}.crossword-pane .crossword-cell.solved{background:#ecfdf3;border-color:#86efac}.crossword-pane .crossword-cell.active{box-shadow:0 0 0 2px #2a9df452 inset}.crossword-pane .crossword-cell-input{width:100%;height:100%;border:none;background:transparent;text-align:center;font-size:24px;font-weight:700;text-transform:uppercase;color:#0f172a;padding:0}.crossword-pane .crossword-cell-input:focus{outline:none;background:#eaf3ff}.crossword-pane .crossword-no-btn{position:absolute;left:2px;top:2px;min-width:17px;height:14px;border:1px solid #c8d5e8;border-radius:4px;background:#fff;color:#475569;font-size:10px;font-weight:700;padding:0 3px;line-height:1;cursor:pointer}.crossword-pane .crossword-clue-panel{display:grid;gap:10px;border:1px solid #d7e3f3;border-radius:12px;background:#fff;padding:10px}.crossword-pane .crossword-clue-section{display:grid;gap:8px}.crossword-pane .crossword-clue-section h3{margin:0;font-size:16px;color:#0f172a}.crossword-pane .crossword-clue-list{margin:0;padding-left:0;list-style:none;display:grid;gap:6px;max-height:240px;overflow:auto}.crossword-pane .crossword-clue-item{width:100%;text-align:left;border:1px solid #d8e3f2;border-radius:9px;background:#f8fbff;color:#1e293b;padding:7px 9px;display:flex;gap:8px;align-items:flex-start}.crossword-pane .crossword-clue-item-no{font-weight:700;color:#0f172a;min-width:26px}.crossword-pane .crossword-clue-item.selected{background:#e8f3ff;border-color:#93c5fd;box-shadow:0 0 0 2px #2a9df433 inset}@keyframes acidFirework{0%{opacity:0;transform:scale(.2)}18%{opacity:1}to{opacity:0;transform:scale(1.15)}}@keyframes acidRobotWalk{0%{transform:translateY(0) scale(1)}25%{transform:translateY(-2px) rotate(-8deg) scale(1.05)}50%{transform:translateY(0) rotate(6deg) scale(1)}75%{transform:translateY(-2px) rotate(-6deg) scale(1.04)}to{transform:translateY(0) scale(1)}}@media (max-width: 980px){.acid-maze .acid-maze-wrap,.crossword-pane .crossword-layout{grid-template-columns:1fr}.crossword-pane .crossword-board{--crossword-cell-size:44px }.crossword-pane .crossword-cell-input{font-size:20px}.crossword-pane .crossword-clue-list{max-height:none}}@media (max-width: 980px){.mix-pane .mix-type-grid,.mix-pane .mix-lab-wrap,.mix-pane .mix-chip-grid,.sep-pane .sep-method-row{grid-template-columns:1fr}.sep-pane .sep-condenser-wrap{margin-bottom:0}.sep-pane .sep-filtration-rig{grid-template-columns:1fr;gap:10px}.sep-pane .sep-source-stream{display:none}.sep-pane .sep-pixi-distillation-wrap{height:280px}.sep-pane .sep-distillation-overlay{font-size:11px}.sep-pane .sep-distillation-overlay-title{top:10px}.sep-pane .sep-distillation-overlay-subtitle{top:24px}.sep-pane .sep-distillation-overlay-flask{left:38px;top:38px;width:88px}.sep-pane .sep-distillation-overlay-heater{left:24px;top:228px;width:110px}.sep-pane .sep-distillation-overlay-receiver{right:28px;top:98px;width:86px}.sep-pane .sep-distillation-overlay-receiver-note{right:12px;top:244px;width:110px}.sep-pane .sep-distillation-overlay-residue{left:20px;top:248px;width:118px}.sep-pane .sep-sieve-rig,.sep-pane .sep-sim-foot,.ecg-level-grid,.ecg-arena,.ecg-options-grid,.quiz-grid{grid-template-columns:1fr}.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.sim-two-col{grid-template-columns:1fr}.sim-result-row{grid-template-columns:1fr;gap:6px}}.ecg2{position:relative;overflow:hidden;min-height:100vh;background:linear-gradient(170deg,#f0f4ff,#e8f0fe,#f5f7ff)}.ecg2-molecules{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.ecg2-molecule{position:absolute;bottom:-30px;font-family:Courier New,monospace;font-weight:700;color:#94a3b8;animation:ecg2Float linear infinite}@keyframes ecg2Float{0%{transform:translateY(0) rotate(0);opacity:0}5%{opacity:1}90%{opacity:1}to{transform:translateY(-105vh) rotate(360deg);opacity:0}}.ecg2-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.ecg2-logo{display:flex;align-items:center;gap:10px}.ecg2-logo-icon{font-size:34px;filter:drop-shadow(0 2px 6px rgba(42,157,244,.3))}.ecg2-logo h2{margin:0;font-size:22px;color:#0f172a;letter-spacing:-.3px}.ecg2-tagline{font-size:14px;color:#64748b;margin-top:1px}.ecg2-card-count{font-size:14px;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:5px 12px}.ecg2-msg{position:relative;z-index:2;font-size:15px;color:#ca8a04;background:#fefce8;border:1px solid #fde047;border-radius:10px;padding:8px 12px;margin-bottom:12px}.ecg2-menu{position:relative;z-index:2;display:grid;gap:20px;justify-items:center;padding:30px 0}.ecg2-menu-title{font-size:24px;font-weight:800;color:#0f172a}.ecg2-levels{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;width:100%;max-width:860px}.ecg2-level-btn{all:unset;cursor:pointer;box-sizing:border-box;display:grid;gap:8px;padding:18px;border-radius:16px;background:var(--lg);border:2px solid color-mix(in srgb,var(--lc) 30%,transparent);transition:transform .2s,box-shadow .2s}.ecg2-level-btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px color-mix(in srgb,var(--lc) 25%,transparent)}.ecg2-level-top{display:flex;justify-content:space-between;align-items:center}.ecg2-level-title{font-size:20px;font-weight:800;color:#0f172a}.ecg2-level-stars{color:var(--lc);letter-spacing:2px}.ecg2-level-sub{font-size:14px;color:#475569;line-height:1.35}.ecg2-level-stats{display:flex;gap:10px;font-size:14px;color:#334155;flex-wrap:wrap}.ecg2-level-play{margin-top:4px;font-weight:700;color:var(--lc);font-size:16px}.ecg2-countdown{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:16px}.ecg2-cd-num{font-size:96px;font-weight:900;color:#0f172a;animation:ecg2CdPulse .65s ease-out;text-shadow:0 4px 20px rgba(42,157,244,.25)}.ecg2-cd-level{font-size:18px;color:#64748b}@keyframes ecg2CdPulse{0%{transform:scale(2.2);opacity:0}50%{transform:scale(.95);opacity:1}to{transform:scale(1);opacity:1}}.ecg2-game{position:relative;z-index:2;display:grid;gap:12px}.ecg2-hud{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.ecg2-hud-left{display:flex;align-items:center;gap:10px}.ecg2-hud-center{display:flex;flex-direction:column;align-items:center;gap:4px}.ecg2-hud-right{display:flex;align-items:center}.ecg2-hearts{display:flex;gap:3px}.ecg2-heart{font-size:20px;transition:transform .2s}.ecg2-heart.full{transform:scale(1)}.ecg2-heart.empty{filter:grayscale(1);opacity:.5;transform:scale(.85)}.ecg2-heart.lost{animation:ecg2HeartLost .4s ease-out}@keyframes ecg2HeartLost{0%{transform:scale(1.3)}50%{transform:scale(.6) rotate(-15deg)}to{transform:scale(.85)}}.ecg2-timer{display:flex;align-items:center;gap:4px;font-size:16px;font-weight:700;color:#334155;background:#fff;border-radius:999px;padding:5px 10px;border:1px solid #e2e8f0}.ecg2-timer-icon{font-size:17px}.ecg2-timer.low{color:#ef4444;border-color:#fca5a5;animation:ecg2Blink 1s infinite}@keyframes ecg2Blink{0%,to{opacity:1}50%{opacity:.5}}.ecg2-score-wrap{position:relative;display:flex;align-items:baseline;gap:6px}.ecg2-score-label{font-size:13px;color:#64748b;text-transform:uppercase;letter-spacing:1px}.ecg2-score-val{font-size:26px;font-weight:900;color:#0f172a}.ecg2-score-popup{position:absolute;right:-36px;top:-6px;font-weight:800;font-size:18px;pointer-events:none;animation:ecg2PopFloat .8s ease-out forwards}.ecg2-score-popup.up{color:#16a34a}.ecg2-score-popup.down{color:#ef4444}@keyframes ecg2PopFloat{0%{transform:translateY(0);opacity:1}to{transform:translateY(-28px);opacity:0}}.ecg2-combo-bar{width:180px;height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden;position:relative}.ecg2-combo-fill{height:100%;background:linear-gradient(90deg,#f97316,#ef4444);border-radius:999px;transition:width .25s}.ecg2-combo-bar.maxed .ecg2-combo-fill{background:linear-gradient(90deg,#f97316,#ef4444,#ec4899);animation:ecg2ComboGlow 1s ease-in-out infinite}.ecg2-combo-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:4px;font-size:12px;font-weight:700;color:#0f172a;pointer-events:none}.ecg2-combo-count{color:#ea580c}.ecg2-combo-bonus{color:#dc2626;animation:ecg2CdPulse .5s ease-out}.ecg2-combo-hint{color:#94a3b8}@keyframes ecg2ComboGlow{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}.ecg2-q-badge{font-size:15px;font-weight:700;color:#475569;background:#f1f5f9;border-radius:999px;padding:5px 12px}.ecg2-bars{display:flex;gap:10px}.ecg2-mix-note{font-size:14px;color:#475569;font-weight:600}.ecg2-bar{position:relative;flex:1;height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.ecg2-bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.ecg2-bar-fill.prog{background:var(--accent)}.ecg2-bar-fill.time{background:#1e88e5}.ecg2-bar-fill.time.low{background:#ef4444;animation:ecg2Blink 1s infinite}.ecg2-bar span{position:absolute;left:6px;top:50%;transform:translateY(-50%);font-size:11px;color:#475569;font-weight:700}.ecg2-arena{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;align-items:start;animation:ecg2FadeIn .4s ease-out}@keyframes ecg2FadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ecg2-scene-card{position:relative;background:#fff;border-radius:18px;border:1px solid #e2e8f0;padding:22px 16px;text-align:center;display:grid;gap:10px;justify-items:center;box-shadow:0 2px 12px #0f172a0f;overflow:hidden}.ecg2-scene-glow{position:absolute;width:120px;height:120px;border-radius:50%;top:-40px;right:-30px;opacity:.15;filter:blur(30px)}.ecg2-scene-icon-wrap{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#f0f4ff;border-radius:50%;position:relative;z-index:1}.ecg2-scene-big-icon{font-size:30px}.ecg2-formula{font-size:30px;font-weight:800;color:#0f172a;position:relative;z-index:1}.ecg2-cname{font-size:15px;color:#64748b;position:relative;z-index:1}.ecg2-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}.ecg2-badge{font-size:13px;border:1px solid;border-radius:999px;padding:3px 10px;background:#fff;color:#334155}.ecg2-q-panel{background:#fff;border-radius:18px;border:1px solid #e2e8f0;padding:18px;display:grid;gap:12px;align-content:start;box-shadow:0 2px 12px #0f172a0f}.ecg2-prompt{font-size:18px;font-weight:700;color:#0f172a;line-height:1.4}.ecg2-opts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.ecg2-opt{all:unset;cursor:pointer;box-sizing:border-box;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;background:#f8fafc;border:2px solid #e2e8f0;font-size:16px;font-weight:600;color:#0f172a;transition:border-color .15s,background .15s,transform .15s;animation:ecg2OptIn .3s ease-out backwards;animation-delay:calc(var(--oi) * 60ms)}.ecg2-opt:hover:not(:disabled){border-color:#94a3b8;background:#f1f5f9;transform:translateY(-1px)}.ecg2-opt.correct{border-color:#22c55e;background:#f0fdf4;color:#15803d}.ecg2-opt.wrong{border-color:#ef4444;background:#fef2f2;color:#b91c1c;animation:ecg2WrongShake .35s ease-out}.ecg2-opt.selected{border-color:var(--accent)}.ecg2-opt:disabled{cursor:default}.ecg2-opt-letter{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#e2e8f0;font-size:14px;font-weight:800;color:#475569;flex:0 0 auto}.ecg2-opt.correct .ecg2-opt-letter{background:#22c55e;color:#fff}.ecg2-opt.wrong .ecg2-opt-letter{background:#ef4444;color:#fff}@keyframes ecg2OptIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}@keyframes ecg2WrongShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(3px)}}.ecg2-fb{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;font-size:16px;font-weight:600;animation:ecg2FadeIn .25s ease-out}.ecg2-fb.ok{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.ecg2-fb.bad{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.ecg2-streak-fire{display:flex;align-items:center;gap:4px;font-size:20px;letter-spacing:2px;min-height:24px}.ecg2-streak-txt{font-size:15px;font-weight:800;color:#ea580c;letter-spacing:0}.ecg2-next-btn{all:unset;cursor:pointer;box-sizing:border-box;text-align:center;padding:10px;border-radius:12px;background:var(--accent);color:#fff;font-weight:700;font-size:16px;transition:filter .15s}.ecg2-next-btn:hover{filter:brightness(.92)}.ecg2-shake{animation:ecg2Shake .4s ease-out}@keyframes ecg2Shake{0%,to{transform:translate(0)}15%{transform:translate(-5px)}30%{transform:translate(5px)}45%{transform:translate(-3px)}60%{transform:translate(3px)}}.ecg2-result{position:relative;z-index:2;display:flex;justify-content:center;padding:30px 0}.ecg2-result-inner{background:#fff;border-radius:22px;padding:28px 32px;text-align:center;display:grid;gap:8px;justify-items:center;box-shadow:0 4px 24px #0f172a14;border:1px solid #e2e8f0;max-width:440px;width:100%;animation:ecg2FadeIn .5s ease-out}.ecg2-result-icon{font-size:52px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.12))}.ecg2-result-inner h3{margin:0;font-size:24px;color:#0f172a}.ecg2-result-stars{font-size:34px;letter-spacing:3px;color:#f59e0b}.ecg2-result-rank{font-size:16px;color:#64748b;font-weight:600}.ecg2-result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;margin:8px 0}.ecg2-result-stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px 8px;display:grid;gap:2px}.ecg2-rval{font-size:24px;font-weight:900;color:#0f172a}.ecg2-rlbl{font-size:13px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.ecg2-result-actions{display:flex;gap:10px;margin-top:6px}.ecg2-btn{all:unset;cursor:pointer;box-sizing:border-box;padding:10px 20px;border-radius:12px;font-weight:700;font-size:16px;background:#f1f5f9;color:#0f172a;border:1px solid #e2e8f0;transition:background .15s,transform .15s}.ecg2-btn:hover{background:#e2e8f0;transform:translateY(-1px)}.ecg2-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.ecg2-btn.primary:hover{filter:brightness(.92)}.ecg2-confetti-wrap{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10}.ecg2-confetti{position:absolute;left:var(--cx);top:50%;width:var(--size);height:var(--size);animation:ecg2Confetti var(--dur) ease-out var(--delay) forwards;opacity:0}.ecg2-confetti-circle{border-radius:50%}.ecg2-confetti-rect{border-radius:2px}@keyframes ecg2Confetti{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(calc(cos(var(--angle))*var(--dist)),calc(sin(var(--angle))*var(--dist) - 60px)) rotate(720deg);opacity:0}}@media (max-width:768px){.ecg2-levels,.ecg2-arena,.ecg2-opts{grid-template-columns:1fr}.ecg2-result-grid{grid-template-columns:repeat(2,1fr)}.ecg2-hud{flex-direction:column;align-items:stretch}.ecg2-hud-center{flex-direction:row;justify-content:center}}.ecg2-score-panel{width:100%;max-width:860px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px;display:grid;gap:8px}.ecg2-score-title{font-size:15px;font-weight:800;color:#0f172a;text-transform:uppercase;letter-spacing:.6px}.ecg2-score-row{display:flex;justify-content:space-between;align-items:center;font-size:16px;color:#334155}.ecg2-score-row strong{font-size:18px;color:#0f172a}.ecg2-top10{width:100%;max-width:860px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px;display:grid;gap:6px}.ecg2-top10-title{font-size:16px;font-weight:800;color:#0f172a}.ecg2-top10-head,.ecg2-top10-row{display:grid;grid-template-columns:40px minmax(120px,1fr) 80px 80px 80px 90px;gap:6px;align-items:center;font-size:14px}.ecg2-top10-head{color:#64748b;font-weight:700;border-bottom:1px solid #e2e8f0;padding-bottom:6px}.ecg2-top10-row{color:#334155;padding:6px 0;border-bottom:1px dashed #e2e8f0}.ecg2-top10-row.me{background:#f0f9ff;border-radius:8px;padding-left:6px;padding-right:6px}.ecg2-top10-row.self-only{border-top:1px solid #cfe7ff;margin-top:2px}.ecg2-top10-empty{font-size:14px;color:#64748b;padding:8px 0}.ecg2-correct-boost{animation:ecg2CorrectBoost .35s ease-out}@keyframes ecg2CorrectBoost{0%{transform:scale(.98)}50%{transform:scale(1.01)}to{transform:scale(1)}}.ecg2-mini-burst{z-index:5}.ecg2-score-popup{opacity:0;transform:translateY(0) scale(.8)}.ecg2-score-popup.show{animation:ecg2PopFloat .8s ease-out forwards}@media (max-width:768px){.ecg2-top10-head,.ecg2-top10-row{grid-template-columns:28px minmax(88px,1fr) 54px 54px 54px 64px;font-size:13px}}.csg-pane{display:grid;gap:12px;background:linear-gradient(180deg,#f8fbff,#eef5ff)}.csg-header{display:grid;gap:10px}.csg-header h2{margin:0;color:#0f172a}.csg-question{font-weight:700;color:#1e3a8a;background:#eaf2ff;border:1px solid #cfe0ff;border-radius:10px;padding:8px 10px;font-size:18px}.csg-question.live{animation:csgQuestionPulse .6s ease-out}.csg-cards-status{font-size:14px;color:#64748b;margin-top:6px}@keyframes csgQuestionPulse{0%{transform:translateY(-4px);opacity:.5}to{transform:translateY(0);opacity:1}}.csg-stats{display:flex;gap:10px;flex-wrap:wrap;font-size:15px;color:#334155}.csg-stats strong{color:#0f172a}.csg-bottom-stats{background:#fff;border:1px solid #d9e3f1;border-radius:10px;padding:8px 10px}.csg-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.csg-controls label{display:flex;align-items:center;gap:8px;font-size:15px;color:#334155}.csg-msg{font-size:15px;color:#475569}.csg-score-panel{background:#fff;border:1px solid #d9e3f1;border-radius:12px;padding:10px;display:grid;gap:6px;max-width:380px}.csg-score-title{font-size:14px;font-weight:800;color:#0f172a;text-transform:uppercase;letter-spacing:.5px}.csg-score-row{display:flex;justify-content:space-between;align-items:center;font-size:15px;color:#334155}.csg-board-wrap{border:1px solid #d9e3f1;border-radius:14px;background:#fff;padding:8px;overflow:hidden}.csg-board{width:min(100%,calc((100vh - 260px) * 22 / 12));margin:0 auto;display:grid;gap:1px;background:#dbe7f7;border-radius:10px;padding:1px}.csg-cell{min-height:0;aspect-ratio:1 / 1;background:#f8fbff;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:15px;text-align:center;overflow:hidden}.csg-cell.obstacle{background:linear-gradient(180deg,#d6e3f5,#c6d7ee);font-size:14px}.csg-cell.target-correct{background:#e6f7eb;border:1px solid #a7efbe}.csg-cell.target-wrong{background:#fff3f2;border:1px solid #ffd4d1}.csg-cell.target-neutral{background:#eef4ff;border:1px solid #c8d9ff}.csg-target-label{font-size:12px;font-weight:700;color:#0f172a;line-height:1.05;padding:0 1px}.csg-cell.target-wide{justify-content:flex-start;padding-left:4px}.csg-cell.target-tail{opacity:.95;justify-content:flex-start;padding-left:2px}.csg-cell.snake-body{background:#2a9df4;border:1px solid #2086d6}.csg-cell.snake-head{background:#0369a1;border:1px solid #075985;color:#fff;font-size:14px}.csg-head-eyes{display:flex;gap:4px;align-items:center;justify-content:center}.csg-head-eyes .eye{width:5px;height:5px;border-radius:50%;background:#fff;box-shadow:inset 0 0 0 1px #0f172a}.csg-board.flash-correct .csg-cell.snake-body,.csg-board.flash-correct .csg-cell.snake-head{background:#22c55e;border-color:#16a34a}.csg-board.flash-wrong .csg-cell.snake-body,.csg-board.flash-wrong .csg-cell.snake-head{background:#ef4444;border-color:#dc2626}.csg-top10{background:#fff;border:1px solid #d9e3f1;border-radius:12px;padding:10px;display:grid;gap:6px}.csg-top10-title{font-size:15px;font-weight:800;color:#0f172a}.csg-top10-head,.csg-top10-row{display:grid;grid-template-columns:34px minmax(120px,1fr) 72px 72px 72px 82px;gap:6px;align-items:center;font-size:14px}.csg-top10-head{color:#64748b;font-weight:700;border-bottom:1px solid #e2e8f0;padding-bottom:6px}.csg-top10-row{color:#334155;padding:6px 0;border-bottom:1px dashed #e2e8f0}.csg-top10-row.me{background:#f0f9ff;border-radius:8px;padding-left:6px;padding-right:6px}.csg-top10-row.self-only{border-top:1px solid #cfe7ff;margin-top:2px}.csg-top10-empty{font-size:14px;color:#64748b;padding:8px 0}@media (max-width: 980px){.csg-board{width:min(100%,calc((100vh - 240px) * 22 / 12))}.csg-cell{font-size:13px}.csg-target-label{font-size:11px}.csg-cell.target-wide{padding-left:2px}.csg-top10-head,.csg-top10-row{grid-template-columns:28px minmax(86px,1fr) 54px 54px 54px 64px;font-size:13px}}.sep-pane .sep-sim-magnetic.phase-running .sep-magnet-container,.sep-pane .sep-sim-magnetic.phase-done .sep-magnet-container{transform:translate(-84px,32px)}.gas-laws-pane .gas-law-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.gas-laws-pane .gas-law-tab-btn{border:1px solid #cfe0f6;background:#fff;border-radius:999px;padding:7px 12px;font-size:14px}.gas-laws-pane .gas-law-tab-btn.active{background:#e8f2ff;outline:2px solid var(--accent)}.gas-laws-pane .gas-law-content{display:grid;gap:12px}.gas-laws-pane .gas-law-section p{margin-top:0;color:#334155}.gas-laws-pane .gas-law-grid{display:grid;grid-template-columns:minmax(240px,1fr) minmax(240px,1fr);gap:12px;align-items:stretch;margin-bottom:12px}.gas-laws-pane .gas-law-grid-boyle,.gas-laws-pane .gas-law-grid-three{grid-template-columns:minmax(220px,1fr) minmax(240px,1fr) minmax(300px,1.25fr)}.gas-laws-pane .gas-law-boyle-chart-stack{display:grid;gap:12px;align-content:start}.gas-laws-pane .gas-law-card{border:1px solid #d6e3f3;border-radius:12px;background:#f8fbff;padding:10px;display:grid;gap:8px;align-content:start}.gas-laws-pane .gas-law-card label{font-size:14px;font-weight:700;color:#0f172a}.gas-laws-pane .gas-law-card input,.gas-laws-pane .gas-law-card select{width:100%;box-sizing:border-box}.gas-laws-pane .gas-law-readout{font-size:14px;color:#334155}.gas-laws-pane .gas-law-button-row{display:flex;gap:8px;flex-wrap:wrap}.gas-laws-pane .gas-cylinder-wrap{display:grid;gap:10px}.gas-laws-pane .gas-gauge{display:grid;gap:6px}.gas-laws-pane .gas-gauge span{font-size:13px;color:#334155;font-weight:700}.gas-laws-pane .gas-gauge-bar{height:14px;border-radius:999px;background:#dbe9fb;overflow:hidden;border:1px solid #b7cde9}.gas-laws-pane .gas-gauge-fill{height:100%;background:linear-gradient(90deg,#22c55e,#f59e0b,#ef4444)}.gas-laws-pane .gas-cylinder{position:relative;height:220px;border:2px solid #97aecb;border-radius:10px;overflow:hidden;background:linear-gradient(180deg,#eef4ff,#e1ebfb)}.gas-laws-pane .gas-piston{position:absolute;left:0;right:0;height:18px;background:#94a3b8;border-top:1px solid #64748b;border-bottom:1px solid #64748b;z-index:2;transition:top .25s ease}.gas-laws-pane .gas-chamber{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#dcedff,#cae2ff);transition:height .25s ease}.gas-laws-pane .gas-particle{position:absolute;width:6px;height:6px;border-radius:50%;background:#1e3a8a;opacity:.75}.gas-laws-pane .gas-collision-box{position:relative;width:100%;height:100%;overflow:hidden}.gas-laws-pane .gas-collision-particle{position:absolute;left:0;top:0;border-radius:50%;background:#1d4ed8;opacity:.86;box-shadow:0 0 0 1px #ffffff40 inset}.gas-laws-pane .thermo-visual{display:grid;gap:8px}.gas-laws-pane .thermo-label{font-size:13px;color:#475569}.gas-laws-pane .thermo-bar{height:18px;border-radius:999px;background:#dbe7f7;overflow:hidden;border:1px solid #bfd1e9}.gas-laws-pane .thermo-bar>div{height:100%;background:linear-gradient(90deg,#38bdf8,#ef4444)}.gas-laws-pane .thermo-bar.pressure>div{background:linear-gradient(90deg,#22c55e,#f59e0b)}.gas-laws-pane .thermo-gas-box{height:140px;border:2px solid #97aecb;border-radius:10px;background:linear-gradient(180deg,#eef6ff,#dfeeff)}.gas-laws-pane .charles-box,.gas-laws-pane .avogadro-box{position:relative;border:2px solid #97aecb;border-radius:10px;background:linear-gradient(180deg,#edf5ff,#dbe9fb);min-height:145px;transition:height .25s ease}.gas-laws-pane .graham-lanes{display:grid;gap:16px}.gas-laws-pane .graham-lane{position:relative;height:42px;border:1px solid #bfd1e9;border-radius:999px;background:#ecf4ff;overflow:hidden}.gas-laws-pane .graham-name{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;font-weight:700;color:#334155;z-index:2;background:#ecf4ff;padding-right:6px}.gas-laws-pane .graham-dot{position:absolute;left:64px;top:50%;width:12px;height:12px;margin-top:-6px;border-radius:50%;animation:gasLaneMove linear infinite}.gas-laws-pane .graham-dot.a{background:#2563eb}.gas-laws-pane .graham-dot.b{background:#ea580c}.gas-laws-pane .gas-law-compare-wrap{margin-top:10px}.gas-laws-pane .gas-law-compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.gas-laws-pane .gas-law-compare-card{align-content:start}.gas-laws-pane .gas-law-equation-row{margin:4px 0 10px}.gas-laws-pane .gas-law-equation{font-size:24px;font-weight:700;color:#1e293b;line-height:1.15}.gas-laws-pane .gas-law-equation-fancy{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:600}.gas-laws-pane .eq-op{font-weight:700;color:#1e293b}.gas-laws-pane .eq-frac{display:inline-flex;flex-direction:column;align-items:center;line-height:1.05;min-width:34px}.gas-laws-pane .eq-frac>span:first-child{border-bottom:1.7px solid #23484a;padding:0 3px 2px}.gas-laws-pane .eq-frac>span:last-child{padding:2px 3px 0}.gas-laws-pane .eq-frac.compact{min-width:80px}.gas-laws-pane .eq-root-wrap{display:inline-flex;align-items:flex-start}.gas-laws-pane .eq-root-symbol{font-size:22px;line-height:1;transform:translateY(2px)}.gas-laws-pane .eq-radicand{display:inline-flex;align-items:center;gap:8px;border-top:1.7px solid #23484a;padding:5px 4px 0}.gas-laws-pane .gas-compare-diffusion-box{position:relative;height:170px;border:2px solid #97aecb;border-radius:10px;background:linear-gradient(90deg,#e0ecff 0,#e0ecff 50%,#ffe7db 50%,#ffe7db);overflow:hidden}.gas-laws-pane .gas-compare-effusion-box{position:relative;height:170px;border:2px solid #97aecb;border-radius:10px;background:#edf5ff;overflow:hidden}.gas-laws-pane .effusion-left{position:absolute;left:0;top:0;bottom:0;width:56%;background:#dbeafe}.gas-laws-pane .effusion-right{position:absolute;right:0;top:0;bottom:0;width:44%;background:#fff5eb}.gas-laws-pane .effusion-hole{position:absolute;left:56%;top:50%;width:4px;height:22px;margin-left:-2px;margin-top:-11px;background:#64748b;border-radius:999px;z-index:3}.gas-laws-pane .gas-law-chart-wrap{border:1px solid #d6e3f3;border-radius:12px;padding:10px;background:#fdfefe}.gas-laws-pane .gas-law-chart-title{font-size:14px;font-weight:700;color:#0f172a;margin-bottom:6px}.gas-laws-pane .gas-law-chart-legend{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:6px;font-size:12px;color:#334155}.gas-laws-pane .gas-law-chart-legend-item{display:inline-flex;align-items:center;gap:6px}.gas-laws-pane .gas-law-chart-legend-item i{width:12px;height:3px;border-radius:999px;display:inline-block}@keyframes gasLaneMove{0%{transform:translate(0)}to{transform:translate(260px)}}.polarity-pane .polarity-chooser{margin-top:12px}.polarity-pane .polarity-chooser-title{font-weight:700;margin-bottom:8px;color:#1f2937}.polarity-pane .polarity-chip-row{display:flex;flex-wrap:wrap;gap:8px}.polarity-pane .polarity-chip{border:1px solid #cbd5e1;border-radius:999px;background:#f8fafc;padding:7px 12px;font-size:13px}.polarity-pane .polarity-chip.active{background:#dbeafe;border-color:#60a5fa;color:#1e3a8a}.polarity-pane .polarity-note{margin-top:10px;font-size:13px;color:#475569}.polarity-pane .polarity-stage-title{font-weight:700;margin-bottom:8px;color:#1f2937}.polarity-pane .polarity-molecule-grid{margin-top:12px;display:grid;grid-template-columns:1.25fr .95fr;gap:14px}.polarity-pane .polarity-molecule-canvas{position:relative;height:275px;border:1px solid #dbe6f4;border-radius:12px;background:radial-gradient(circle at 20% 20%,#f7fbff 0,#eff5ff 45%,#e7f0fc);overflow:hidden}.polarity-pane .polarity-molecule-svg{width:100%;height:100%;display:block}.polarity-pane .polarity-svg-bond{stroke:#2c3e56;stroke-width:2.15;stroke-linecap:round;opacity:.99}.polarity-pane .polarity-svg-atom{stroke-width:.35}.polarity-pane .polarity-svg-atom-label{font-size:5px;font-weight:800;fill:#0f172a;pointer-events:none;paint-order:stroke;stroke:#fff;stroke-width:.45}.polarity-pane .polarity-svg-atom.atom-h{fill:#f8fafc;stroke:#94a3b8}.polarity-pane .polarity-svg-atom.atom-c{fill:#cfd5de;stroke:#7f8a9a}.polarity-pane .polarity-svg-atom.atom-o{fill:#fca5a5;stroke:#ef4444}.polarity-pane .polarity-svg-atom.atom-n{fill:#bfdbfe;stroke:#3b82f6}.polarity-pane .polarity-svg-atom.atom-s{fill:#fde68a;stroke:#f59e0b}.polarity-pane .polarity-svg-atom.atom-cl{fill:#bbf7d0;stroke:#22c55e}.polarity-pane .polarity-svg-badge{stroke-width:.34}.polarity-pane .polarity-svg-badge.badge-plus{fill:#fff5f5;stroke:#fca5a5}.polarity-pane .polarity-svg-badge.badge-minus{fill:#eff6ff;stroke:#93c5fd}.polarity-pane .polarity-svg-badge-text{font-size:5.2px;font-weight:900;fill:#0f172a;pointer-events:none;paint-order:stroke;stroke:#fff;stroke-width:.42}.polarity-pane .polarity-bond{position:absolute;height:3px;border-radius:999px;background:linear-gradient(90deg,#94a3b8,#64748b);transform-origin:left center}.polarity-pane .polarity-atom{position:absolute;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;transform:translate(-50%,-50%);box-shadow:0 4px 10px #0f172a1f,inset 0 0 0 1px #ffffff73;font-size:12px;font-weight:700;color:#0f172a}.polarity-pane .polarity-atom em{font-style:normal}.polarity-pane .polarity-atom i{position:absolute;right:-7px;top:-8px;font-style:normal;font-size:10px;font-weight:700;border-radius:999px;padding:2px 5px;background:#fff;border:1px solid #cbd5e1;color:#0f172a}.polarity-pane .polarity-atom.charge-plus i{color:#b91c1c;border-color:#fecaca;background:#fff5f5}.polarity-pane .polarity-atom.charge-minus i{color:#1d4ed8;border-color:#bfdbfe;background:#eff6ff}.polarity-pane .polarity-atom.atom-h{background:linear-gradient(180deg,#f8fafc,#e2e8f0)}.polarity-pane .polarity-atom.atom-c{background:linear-gradient(180deg,#d1d5db,#9ca3af)}.polarity-pane .polarity-atom.atom-o{background:linear-gradient(180deg,#fecaca,#f87171)}.polarity-pane .polarity-atom.atom-n{background:linear-gradient(180deg,#bfdbfe,#60a5fa)}.polarity-pane .polarity-atom.atom-s{background:linear-gradient(180deg,#fde68a,#f59e0b)}.polarity-pane .polarity-atom.atom-cl{background:linear-gradient(180deg,#bbf7d0,#34d399)}.polarity-pane .polarity-en-table{display:grid;gap:8px;margin-bottom:8px}.polarity-pane .polarity-en-row{display:flex;align-items:center;justify-content:space-between;border:1px solid #dbe6f4;border-radius:8px;padding:7px 10px;background:#f8fbff}.polarity-pane .polarity-sim-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:14px}.polarity-pane .polarity-container-card{padding:0;overflow:hidden}.polarity-pane .polarity-container-card.selected{box-shadow:0 0 0 2px #93c5fd inset,0 10px 18px #0f172a14}.polarity-pane .polarity-container-hit{width:100%;text-align:left;border:none;background:transparent;padding:12px;margin:0;cursor:pointer}.polarity-pane .polarity-container-head{display:grid;gap:2px;margin-bottom:8px;color:#334155}.polarity-pane .polarity-container-head span{font-size:12px;color:#64748b}.polarity-pane .polarity-beaker{position:relative;width:70%;margin:0 auto;height:172px;border-radius:14px;overflow:hidden;border:2px solid #a5b4c9;background:linear-gradient(180deg,#ffffffdb,#ebf3fce0)}.polarity-pane .polarity-liquid{position:absolute;left:0;right:0;bottom:0;height:74%;background:linear-gradient(180deg,color-mix(in srgb,var(--container-color) 70%,#ffffff 30%),color-mix(in srgb,var(--container-color) 85%,#0f172a 15%));opacity:.72}.polarity-pane .polarity-liquid:before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:#ffffffc7}.polarity-pane .polarity-particles{position:absolute;top:0;right:0;bottom:0;left:0}.polarity-pane .polarity-particles span{position:absolute;width:9px;height:9px;border-radius:50%;box-shadow:0 0 0 1px #0f172a14 inset}.polarity-pane .polarity-particles.dissolved span{background:#f8fafc;opacity:.86;animation:polarityDrift 1.35s ease-in-out infinite alternate}.polarity-pane .polarity-particles.separated span{background:#334155;opacity:.9;animation:polaritySurface 1.8s ease-in-out infinite alternate}.polarity-pane .polarity-surface-mol-svg{display:block;overflow:visible}.polarity-pane .polarity-surface-strip{position:absolute;left:2%;right:2%;bottom:70%;display:flex;justify-content:space-around;align-items:flex-end;pointer-events:none;z-index:3;overflow:visible}.polarity-pane .polarity-surface-strip .polarity-surface-mol-svg{width:46px;height:46px;filter:drop-shadow(0 2px 5px rgba(15,23,42,.34));animation:polaritySurfaceBob 1.6s ease-in-out infinite alternate}.polarity-pane .polarity-surface-strip .polarity-surface-mol-svg:nth-child(2){animation-delay:.44s}.polarity-pane .polarity-surface-strip .polarity-surface-mol-svg:nth-child(3){animation-delay:.88s}.polarity-pane .polarity-surface-strip .polarity-surface-mol-svg:nth-child(4){animation-delay:1.32s}.polarity-pane .polarity-bottom-strip{position:absolute;left:2%;right:2%;top:80%;display:flex;justify-content:space-around;align-items:flex-start;pointer-events:none;z-index:3;overflow:visible}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg{width:38px;height:38px;filter:drop-shadow(0 -2px 5px rgba(15,23,42,.34));animation:polarityBottomBob 1.6s ease-in-out infinite alternate}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg:nth-child(2){animation-delay:.28s}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg:nth-child(3){animation-delay:.56s}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg:nth-child(4){animation-delay:.84s}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg:nth-child(5){animation-delay:1.12s}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg:nth-child(6){animation-delay:1.4s}.polarity-pane .polarity-bottom-strip .polarity-surface-mol-svg:nth-child(7){animation-delay:1.68s}.polarity-pane .polarity-dissolved-ring{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg{position:absolute;width:36px;height:36px;transform:translate(-50%,-50%);opacity:.86}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(1){left:10%;top:44%;animation:polarityWander1 3.8s ease-in-out infinite}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(2){left:26%;top:65%;animation:polarityWander2 4.3s ease-in-out infinite}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(3){left:44%;top:50%;animation:polarityWander3 3.5s ease-in-out infinite}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(4){left:62%;top:70%;animation:polarityWander4 4.9s ease-in-out infinite}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(5){left:80%;top:47%;animation:polarityWander5 4.1s ease-in-out infinite}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(6){left:18%;top:80%;animation:polarityWander6 3.2s ease-in-out infinite}.polarity-pane .polarity-dissolved-ring .polarity-surface-mol-svg:nth-child(7){left:66%;top:58%;animation:polarityWander7 4.6s ease-in-out infinite}.polarity-pane .polarity-result-text{margin-top:8px;font-size:13px;color:#334155}.polarity-pane .polarity-summary-panel{margin-top:12px}.polarity-pane .polarity-mini-list{margin-top:8px;display:grid;gap:6px;font-size:13px;color:#475569}@keyframes polarityDrift{0%{transform:translateY(0)}to{transform:translateY(-4px)}}@keyframes polarityWander1{0%{transform:translate(-50%,-50%) translate(0)}18%{transform:translate(-50%,-50%) translate(16px,-12px)}36%{transform:translate(-50%,-50%) translate(-10px,18px)}54%{transform:translate(-50%,-50%) translate(22px,10px)}72%{transform:translate(-50%,-50%) translate(-8px,-14px)}90%{transform:translate(-50%,-50%) translate(14px,20px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityWander2{0%{transform:translate(-50%,-50%) translate(0)}20%{transform:translate(-50%,-50%) translate(-18px,10px)}40%{transform:translate(-50%,-50%) translate(12px,-16px)}60%{transform:translate(-50%,-50%) translate(-6px,22px)}80%{transform:translate(-50%,-50%) translate(20px,-8px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityWander3{0%{transform:translate(-50%,-50%) translate(0)}15%{transform:translate(-50%,-50%) translate(10px,14px)}35%{transform:translate(-50%,-50%) translate(-18px,-6px)}55%{transform:translate(-50%,-50%) translate(8px,-18px)}75%{transform:translate(-50%,-50%) translate(-14px,12px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityWander4{0%{transform:translate(-50%,-50%) translate(0)}25%{transform:translate(-50%,-50%) translate(-12px,-18px)}50%{transform:translate(-50%,-50%) translate(18px,8px)}75%{transform:translate(-50%,-50%) translate(-6px,20px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityWander5{0%{transform:translate(-50%,-50%) translate(0)}22%{transform:translate(-50%,-50%) translate(20px,12px)}44%{transform:translate(-50%,-50%) translate(-14px,-18px)}66%{transform:translate(-50%,-50%) translate(6px,22px)}88%{transform:translate(-50%,-50%) translate(-20px,4px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityWander6{0%{transform:translate(-50%,-50%) translate(0)}30%{transform:translate(-50%,-50%) translate(14px,-10px)}60%{transform:translate(-50%,-50%) translate(-16px,14px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityWander7{0%{transform:translate(-50%,-50%) translate(0)}20%{transform:translate(-50%,-50%) translate(-10px,16px)}42%{transform:translate(-50%,-50%) translate(18px,-8px)}64%{transform:translate(-50%,-50%) translate(-20px,-12px)}82%{transform:translate(-50%,-50%) translate(8px,18px)}to{transform:translate(-50%,-50%) translate(0)}}@keyframes polarityFloat{0%{transform:translateY(0) scale(1)}to{transform:translateY(-7px) scale(1.04)}}@keyframes polaritySurface{0%{transform:translateY(0)}to{transform:translateY(-3px)}}@keyframes polaritySurfaceBob{0%{transform:translateY(0)}to{transform:translateY(-7px)}}@keyframes polarityBottomBob{0%{transform:translateY(0)}to{transform:translateY(5px)}}@media (max-width: 980px){.gas-laws-pane .gas-law-grid,.gas-laws-pane .gas-law-grid-boyle,.gas-laws-pane .gas-law-grid-three,.gas-laws-pane .gas-law-compare-grid{grid-template-columns:1fr}}@media (max-width: 900px){.polarity-pane .polarity-molecule-grid,.polarity-pane .polarity-sim-grid{grid-template-columns:1fr}}.lewis-game-pane .lewis-toolbar{display:grid;gap:10px}.lewis-game-pane .lewis-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lewis-game-pane .lewis-label{font-size:13px;color:#334155;font-weight:700}.lewis-game-pane .lewis-element-list{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.lewis-game-pane .lewis-chip{min-width:42px;border-radius:999px;border:1px solid #c7d6ea;background:#f8fbff;text-align:center}.lewis-game-pane .lewis-chip.active{background:#dbeafe;border-color:#60a5fa;color:#1e3a8a}.lewis-game-pane .lewis-note-row{font-size:13px;color:#334155}.lewis-game-pane .lewis-goal-text{font-size:13px;color:#1f2937;font-weight:700}.lewis-game-pane .lewis-feedback{font-size:13px;color:#334155;background:#f8fbff;border:1px solid #dbe6f4;border-radius:8px;padding:7px 10px}.lewis-game-pane .lewis-goals-panel{margin-top:12px;display:grid;gap:6px}.lewis-game-pane .lewis-goals-title{font-weight:800;color:#1f2937}.lewis-game-pane .lewis-goal-item{font-size:13px;color:#475569}.lewis-game-pane .lewis-layout{margin-top:12px;display:grid;grid-template-columns:1.45fr .95fr;gap:14px}.lewis-game-pane .lewis-workspace-panel{min-height:420px}.lewis-game-pane .lewis-workspace{position:relative;height:380px;border:1px solid #cfdced;border-radius:12px;background:radial-gradient(circle at 25% 20%,#fbfdff 0,#eff6ff 45%,#e6eef9);overflow:hidden}.lewis-game-pane .lewis-bond-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.lewis-game-pane .lewis-bond-line{position:absolute;height:2.1px;background:#64748b;border-radius:999px;transform-origin:0 50%}.lewis-game-pane .lewis-bond-line.is-animating{animation:lewisBondDraw .48s ease-out}@keyframes lewisBondDraw{0%{transform:scaleX(0);opacity:.25}60%{opacity:1}to{transform:scaleX(1);opacity:1}}.lewis-game-pane .lewis-atom{position:absolute;width:54px;height:54px;margin-left:-27px;margin-top:-27px;border-radius:50%;border:1.4px solid #9fb4cd;background:linear-gradient(180deg,#fff,#edf3fb);box-shadow:0 6px 12px #0f172a1f;padding:0}.lewis-game-pane .lewis-atom.selected{box-shadow:0 0 0 2px #60a5fa,0 8px 16px #0f172a2e}.lewis-game-pane .lewis-workspace.bond-mode .lewis-atom.bond-first{box-shadow:0 0 0 3px #22c55e,0 8px 16px #0f172a2e;border-color:#16a34a}.lewis-game-pane .lewis-workspace.bond-mode .lewis-atom.bond-second{box-shadow:0 0 0 3px #f59e0b,0 8px 16px #0f172a2e;border-color:#d97706}.lewis-game-pane .lewis-bond-order-badge{position:absolute;top:-7px;right:-7px;width:18px;height:18px;border-radius:50%;background:#0f172a;color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;box-shadow:0 1px 5px #00000059}.lewis-game-pane .lewis-atom-symbol{font-size:17px;font-weight:800;color:#0f172a}.lewis-game-pane .lewis-dot{position:absolute;width:6px;height:6px;border-radius:50%;transform:translate(-50%,-50%);background:#0f172a}.lewis-game-pane .lewis-free-electron{position:absolute;width:14px;height:14px;margin-left:-7px;margin-top:-7px;border-radius:50%;border:1px solid #1e293b;background:#0f172a;box-shadow:0 0 0 2px #ffffffb8,0 2px 7px #0f172a33;padding:0}.lewis-game-pane .lewis-workspace.bond-mode .lewis-free-electron{pointer-events:none}.lewis-game-pane .lewis-editor-panel{min-height:420px}.lewis-game-pane .lewis-editor-title{font-weight:800;color:#1f2937;margin-bottom:8px}.lewis-game-pane .lewis-empty{color:#64748b;font-size:13px}.lewis-game-pane .lewis-selected-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;color:#334155}.lewis-game-pane .lewis-dot-editor{position:relative;width:220px;height:220px;margin:0 auto;border-radius:16px;border:1px solid #d8e3f3;background:linear-gradient(180deg,#fbfdff,#f2f7ff)}.lewis-game-pane .lewis-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;border:1px solid #9fb4cd;display:grid;place-items:center;font-size:22px;font-weight:800;background:#fff}.lewis-game-pane .lewis-slot{position:absolute;transform:translate(-50%,-50%);width:28px;height:28px;border-radius:50%;padding:0;line-height:1;text-align:center;border:1px solid #c9d8eb;background:#f7fbff;font-size:20px;color:#94a3b8}.lewis-game-pane .lewis-slot.on{border-color:#3b82f6;color:#0f172a;background:#dbeafe}.lewis-game-pane .lewis-help-text{margin-top:10px;font-size:13px;color:#475569}.lewis-game-pane .lewis-editor-caption{font-size:13px;color:#475569;margin-top:8px;padding:0 12px}.lewis-game-pane .lewis-dot-editor.lewis-dot-editor-readonly{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;padding:12px;min-height:220px;height:auto}.lewis-game-pane .lewis-dot-editor.lewis-dot-editor-readonly .lewis-center{position:static;transform:none;flex:0 0 auto}.lewis-game-pane .lewis-dot-editor.lewis-dot-editor-readonly .lewis-editor-caption{margin-top:0;text-align:center;line-height:1.35}@media (max-width: 980px){.lewis-game-pane .lewis-layout{grid-template-columns:1fr}}
