*,:before,:after{box-sizing:border-box}:root{--black:#191919;--midnight:#01426a;--crimson:#900;--gold:#f1be48;--light-gray:#edebeb;--limestone:#aca39a;--dark-limestone:#83786f;--surface-0:#191919;--surface-1:#1f1f1f;--surface-card:#242424;--surface-inset:#161616;--border:#ffffff1a;--border-subtle:#ffffff0f;--gold-dim:#f1be481f;--species-a:#ef6c57;--species-b:#5ba4cf;--species-c:#7bc67e;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--text:var(--light-gray);--text-secondary:var(--limestone);--text-muted:var(--dark-limestone);--accent:var(--gold);--danger:var(--crimson);--r-sm:6px;--r-md:10px;--r-lg:14px;--shadow-card:0 2px 8px #0006, 0 0 0 1px var(--border);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-heading:"IBM Plex Sans", "Inter", -apple-system, system-ui, sans-serif;--font-mono:"SF Mono", "Fira Code", "Consolas", monospace;font-family:var(--font-sans);color:var(--text);background:var(--surface-0);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.55}body{min-height:100vh;margin:0;padding:0}#root{width:100%;max-width:100%;margin:0}h1,h2,h3,h4{font-family:var(--font-heading);letter-spacing:-.01em;margin:0;font-weight:600}p{margin:0}button{cursor:pointer;font-family:var(--font-sans)}select{font-family:var(--font-sans)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--dark-limestone);border-radius:3px}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--crimson);padding:var(--sp-4) var(--sp-8);justify-content:space-between;align-items:center;gap:var(--sp-6);border-bottom:1px solid var(--border);display:flex}.header-brand{align-items:center;gap:var(--sp-4);flex-shrink:0;display:flex}.header-logo{flex-shrink:0;width:48px;height:48px}.header-text{flex-direction:column;gap:2px;display:flex}.header-title-row{align-items:baseline;gap:var(--sp-2);display:flex}.brand-name{font-family:var(--font-heading);color:var(--light-gray);letter-spacing:-.01em;font-size:18px;font-weight:700}.brand-divider{color:var(--limestone);font-size:18px;font-weight:300}.module-name{font-family:var(--font-heading);color:var(--light-gray);letter-spacing:-.01em;font-size:18px;font-weight:500}.header-tagline{color:var(--limestone);letter-spacing:1.5px;text-transform:uppercase;font-size:12px;font-weight:500}.header-right{align-items:center;gap:var(--sp-5);display:flex}.header-description{color:var(--limestone);text-align:right;max-width:300px;font-size:13px;line-height:1.45}.header-controls{align-items:center;gap:var(--sp-3);flex-shrink:0;display:flex}.prediction-toggle{align-items:center;gap:var(--sp-2);color:var(--limestone);cursor:pointer;padding:var(--sp-2) var(--sp-4);border-radius:var(--r-sm);white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff26;font-size:13px;font-weight:500;transition:all .2s;display:flex}.prediction-toggle:hover{background:#ffffff1a}.prediction-toggle:has(input:checked){border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.prediction-toggle input{accent-color:var(--gold);width:14px;height:14px}.btn-challenge{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);font-size:13px;font-weight:600;font-family:var(--font-sans);color:var(--black);background:var(--gold);border:1px solid var(--gold);border-radius:var(--r-sm);white-space:nowrap;text-decoration:none;transition:all .2s;display:inline-flex}.btn-challenge:hover{background:#d4a63e;border-color:#d4a63e}.btn-challenge:active{transform:scale(.97)}.main-layout{gap:var(--sp-4);padding:var(--sp-4);flex:1;grid-template-columns:320px 1fr 320px;min-height:0;display:grid}.panel{background:var(--surface-1);border-radius:var(--r-lg);border:1px solid var(--border);overflow-y:auto}.panel-left,.panel-center{flex-direction:column;display:flex}.panel-right{gap:var(--sp-4);background:0 0;border:none;flex-direction:column;display:flex;overflow:visible}.panel-right>*{background:var(--surface-1);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden}.section-label{font-family:var(--font-heading);color:var(--limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-3);font-size:14px;font-weight:600}.vessel-panel{padding:var(--sp-5);flex-direction:column;align-items:center;display:flex}.vessel-panel h3{font-family:var(--font-heading);color:var(--limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-4);font-size:14px;font-weight:600}.vessel-canvas{border-radius:var(--r-md);background:var(--surface-inset);border:1px solid var(--border-subtle);width:100%;max-width:380px;height:auto}.vessel-info{gap:var(--sp-3);margin-top:var(--sp-3);font-size:14px;font-family:var(--font-mono);color:var(--limestone);display:flex}.vessel-info span{background:var(--surface-inset);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-sm);border:1px solid var(--border-subtle)}.graph-panel{padding:var(--sp-6);flex-direction:column;flex:1;display:flex}.reaction-header{text-align:center;margin-bottom:var(--sp-4)}.reaction-equation{font-family:var(--font-heading);letter-spacing:3px;color:var(--light-gray);font-size:30px;font-weight:500}.phase-label{color:var(--mid-gray);margin-left:1px;font-size:.6em;font-style:italic}.thermo-badge{font-size:14px;font-weight:500;font-family:var(--font-sans);padding:var(--sp-1) var(--sp-4);text-align:center;margin-top:var(--sp-2);letter-spacing:.3px;cursor:pointer;border:1px solid #0000;border-radius:100px;transition:border-color .2s,background .2s;display:inline-block}.thermo-badge:hover{border-color:#ffffff26}.thermo-badge.exo{color:#e06050;background:#99000026}.thermo-badge.endo{color:var(--gold);background:#f1be4814}.thermo-toggle-hint{display:none}.state-summary{justify-content:center;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4);display:flex}.state-chip{align-items:baseline;gap:var(--sp-2);background:var(--surface-inset);border:1px solid var(--border);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-4);font-family:var(--font-mono);font-size:15px;display:flex}.state-chip-label{color:var(--dark-limestone);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.state-chip-label sub{font-size:10px}.state-chip-value{color:var(--light-gray);font-weight:700}.state-chip-value.gold{color:var(--gold)}.shift-chip{border-width:1.5px}.state-chip-shift{font-size:14px;font-weight:600;font-family:var(--font-sans);letter-spacing:.2px}.expression-card{background:var(--surface-inset);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-4) var(--sp-5);margin-bottom:var(--sp-3)}.expression-card-header{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:1.2px;color:var(--dark-limestone);margin-bottom:var(--sp-3);font-size:12px;font-weight:600}.expression-row{align-items:baseline;gap:var(--sp-2);padding:var(--sp-2) 0;font-family:var(--font-mono);color:var(--limestone);font-size:15px;line-height:1.6;display:flex}.expression-label{color:var(--light-gray);min-width:36px;font-weight:700}.expression-label sub{color:var(--limestone);font-size:11px}.expression-eq{color:var(--dark-limestone)}.expression-formula{color:var(--limestone)}.expression-formula sub{color:var(--dark-limestone);font-size:10px}.expression-formula sup{color:var(--gold);font-size:11px;font-weight:600}.expression-divider,.expression-paren{color:var(--dark-limestone)}.expression-value{color:var(--light-gray);margin-left:auto;font-weight:600}.expression-value.gold{color:var(--gold)}.teaching-hint{color:var(--dark-limestone);text-align:center;margin-bottom:var(--sp-4);font-size:13px;font-style:italic;line-height:1.5}.chart-container{align-items:center;min-height:300px;display:flex;position:relative}.y-axis-label{writing-mode:vertical-rl;color:var(--limestone);padding-right:var(--sp-2);white-space:nowrap;flex-shrink:0;font-size:14px;transform:rotate(180deg)}.chart-inner{flex:1;min-width:0}.control-panel{padding:var(--sp-5)}.control-panel h3{font-family:var(--font-heading);color:var(--limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-4);font-size:14px;font-weight:600}.control-section{margin-bottom:var(--sp-5);overflow:hidden}.control-section .btn{white-space:normal;min-width:0;font-size:13px}.control-section h4{color:var(--limestone);letter-spacing:.02em;margin-bottom:var(--sp-2);font-size:14px;font-weight:500}.control-row{gap:var(--sp-2);margin-bottom:var(--sp-2);display:flex}.btn{padding:9px var(--sp-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--light-gray);white-space:nowrap;background:#ffffff0a;flex:1;font-size:14px;font-weight:500;transition:all .15s}.btn:hover{background:#ffffff14;border-color:#ffffff2e}.btn:active{background:#ffffff1a;transform:scale(.97)}.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.btn-add:hover{background:var(--gold-dim);color:var(--gold);border-color:#f1be484d}.btn-remove:hover{color:var(--light-gray);background:#9900001f;border-color:#9900004d}.btn-temp-up:hover{background:var(--gold-dim);color:var(--gold);border-color:#f1be484d}.btn-temp-down:hover{color:var(--light-gray);background:#ffffff0f;border-color:#fff3}.btn-reset{width:100%;color:var(--limestone);background:#99000014;border-color:#99000040;font-weight:500}.btn-reset:hover{color:var(--light-gray);background:#9900002e;border-color:#99000073}.k-slider-container{padding:var(--sp-1) 0}.k-slider{appearance:none;cursor:pointer;background:#ffffff14;border-radius:2px;outline:none;width:100%;height:4px}.k-slider::-webkit-slider-thumb{appearance:none;background:var(--gold);cursor:pointer;border:2px solid var(--surface-1);border-radius:50%;width:16px;height:16px;transition:box-shadow .2s;box-shadow:0 0 8px #f1be484d}.k-slider::-webkit-slider-thumb:hover{box-shadow:0 0 14px #f1be4880}.k-slider::-moz-range-thumb{background:var(--gold);cursor:pointer;border:2px solid var(--surface-1);border-radius:50%;width:16px;height:16px}.k-slider-labels{font-size:13px;font-family:var(--font-mono);color:var(--dark-limestone);margin-top:var(--sp-1);justify-content:space-between;display:flex}.k-slider-value{text-align:center;font-size:16px;font-family:var(--font-mono);color:var(--gold);margin-top:var(--sp-2);justify-content:center;align-items:center;gap:var(--sp-2);font-weight:600;display:flex}.k-reset-btn{border:1px solid var(--border);color:var(--dark-limestone);border-radius:var(--r-sm);cursor:pointer;font-size:12px;font-family:var(--font-mono);background:0 0;padding:2px 8px;transition:all .15s}.k-reset-btn:hover{color:var(--gold);border-color:#f1be484d}.prediction-prompt{color:var(--limestone);margin-bottom:var(--sp-3);font-size:15px}.prediction-buttons{gap:var(--sp-2);flex-direction:column;display:flex}.btn-forward{background:var(--gold-dim);color:var(--gold);border-color:#f1be4833}.btn-forward:hover{background:#f1be4833;border-color:#f1be4866}.btn-reverse{color:var(--limestone);background:#99000014;border-color:#9003}.btn-reverse:hover{background:#99000026;border-color:#9006}.btn-none{border-color:var(--border);color:var(--limestone);background:#ffffff08}.btn-none:hover{background:#ffffff12;border-color:#ffffff2e}.explanation-panel{padding:var(--sp-5);position:relative}.explanation-panel h3{font-family:var(--font-heading);color:var(--limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-3);font-size:14px;font-weight:600}.explanation-box{background:var(--surface-inset);border-radius:var(--r-md);padding:var(--sp-4);margin-bottom:var(--sp-4);border:1px solid var(--border-subtle)}.explanation-box p{color:var(--light-gray);font-size:15px;line-height:1.65}.explanation-placeholder{color:var(--dark-limestone);margin-bottom:var(--sp-4);font-size:15px;line-height:1.6}.btn-why{background:var(--gold-dim);color:var(--gold);padding:var(--sp-2) var(--sp-4);border-radius:var(--r-sm);margin-top:var(--sp-3);border:1px solid #f1be4833;font-size:14px;font-weight:500;transition:all .15s}.btn-why:hover{background:#f1be4833;border-color:#f1be4866}.detail-box{margin-top:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-sm);border-left:2px solid var(--gold);background:#0003}.detail-box p{color:var(--limestone);font-size:14px;line-height:1.7}.prediction-result{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);margin-bottom:var(--sp-4);border:1px solid;font-size:15px}.prediction-result.correct{background:var(--gold-dim);color:var(--gold);border-color:#f1be4840}.prediction-result.incorrect{color:var(--limestone);background:#9900001a;border-color:#99000040}.prediction-flash{z-index:1000;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-direction:column;justify-content:center;align-items:center;animation:.25s ease-out flashIn;display:flex;position:fixed;inset:0}.flash-correct{background:#01426af0}.flash-incorrect{background:#990000f0}.flash-icon{color:var(--gold);font-size:100px;font-weight:300;line-height:1}.flash-text{font-family:var(--font-heading);color:var(--light-gray);letter-spacing:8px;margin-top:var(--sp-2);font-size:44px;font-weight:700}@keyframes flashIn{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.misconceptions{margin-top:var(--sp-4)}.misconceptions h3{margin-bottom:var(--sp-3);font-size:14px}.misconception-cards{gap:var(--sp-2);grid-template-columns:1fr 1fr;display:grid}.misconception-card{background:var(--surface-inset);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);cursor:pointer;flex-direction:column;justify-content:center;min-height:52px;transition:all .2s;display:flex}.misconception-card:hover{background:var(--gold-dim);border-color:#f1be484d}.misconception-card.expanded{background:var(--gold-dim);border-color:#f1be4840;grid-column:1/-1}.misconception-card-header{align-items:center;gap:var(--sp-2);display:flex}.misconception-number{color:var(--gold);font-size:15px;font-weight:700;font-family:var(--font-mono);min-width:24px}.misconception-title{color:var(--limestone);font-size:14px;line-height:1.35}.misconception-card.expanded .misconception-title{color:var(--light-gray);font-weight:600}.misconception-card:not(.expanded) .misconception-title{color:var(--dark-limestone);font-size:14px}.misconception-card-text{color:var(--limestone);margin-top:var(--sp-2);padding-top:var(--sp-2);border-top:1px solid var(--border);font-size:14px;line-height:1.65}@media (width<=1200px){.main-layout{grid-template-rows:auto auto;grid-template-columns:1fr 1fr}.panel-left{grid-column:1}.panel-center{grid-column:2}.panel-right{grid-column:1/-1;grid-template-columns:1fr 1fr;display:grid}}@media (width<=768px){.main-layout,.panel-right{grid-template-columns:1fr}.app-header{text-align:center;flex-direction:column}.header-right{flex-direction:column;align-items:center}.header-description{text-align:center;max-width:100%}}.perturbation-card{margin-top:var(--sp-3);background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono,monospace);font-size:12px;line-height:1.6;overflow:hidden}.perturbation-card-toggle{width:100%;padding:var(--sp-3) var(--sp-4);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.perturbation-card-toggle:hover{background:#ffffff08}.perturbation-card-header{color:var(--gold);letter-spacing:1.2px;text-transform:uppercase;font-size:11px;font-family:var(--font-sans);font-weight:600}.perturbation-card-chevron{color:var(--limestone);margin-left:var(--sp-2);font-size:10px}.perturbation-card-body{padding:0 var(--sp-4) var(--sp-4);gap:var(--sp-3);flex-direction:column;display:flex}.perturbation-card-row{gap:var(--sp-4);align-items:baseline;display:flex}.perturbation-card-label{color:var(--limestone);min-width:48px;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.perturbation-card-value{font-size:13px;font-weight:600}.ice-table{border:1px solid #ffffff0f;border-radius:8px;overflow:hidden}.ice-table-header-label{font-family:var(--font-sans);letter-spacing:2px;text-transform:uppercase;color:var(--limestone);padding:var(--sp-2) var(--sp-3);background:#ffffff05;border-bottom:1px solid #ffffff0f;font-size:10px}.ice-table table{border-collapse:collapse;width:100%;font-family:var(--font-mono,monospace);font-size:13px}.ice-table th{padding:var(--sp-2) var(--sp-3);text-align:center;border-bottom:1px solid #ffffff0f;font-size:14px;font-weight:700}.ice-table td{padding:var(--sp-2) var(--sp-3);text-align:center;color:var(--light)}.ice-row-label{font-family:var(--font-sans);width:32px;font-weight:700;color:var(--gold)!important;text-align:left!important}.ice-row-eq td{border-top:1px solid var(--border);font-weight:700}.ice-algebra{padding:var(--sp-2) 0;flex-direction:column;gap:4px;display:flex}.ice-algebra-row{align-items:baseline;gap:var(--sp-2);font-family:var(--font-mono,monospace);color:var(--limestone);flex-wrap:wrap;font-size:12px;display:flex}.ice-algebra-label{color:var(--gold);min-width:40px;font-size:13px;font-weight:700}.ice-algebra-value{color:var(--light);font-weight:700}.ice-algebra-result{padding-top:var(--sp-2);border-top:1px solid #ffffff0f;font-size:14px}.ice-algebra-result .ice-algebra-value{color:var(--gold);font-size:15px}.vant-hoff-section{border:1px solid #ffffff0f;border-radius:8px;overflow:hidden}.vant-hoff-body{padding:var(--sp-3);flex-direction:column;gap:6px;display:flex}.vant-hoff-row{align-items:baseline;gap:var(--sp-2);font-family:var(--font-mono,monospace);color:var(--limestone);flex-wrap:wrap;font-size:12px;display:flex}.vant-hoff-equation{color:var(--light);padding-bottom:var(--sp-2);border-bottom:1px solid #ffffff0f;margin-bottom:2px;font-size:13px;font-weight:600}.vant-hoff-label{color:var(--gold);min-width:80px;font-size:12px;font-weight:700}.vant-hoff-value{color:var(--light)}.vant-hoff-result{padding-top:var(--sp-2);border-top:1px solid #ffffff0f;font-size:14px}.vant-hoff-result .ice-algebra-value{color:var(--gold);font-size:14px}.ice-summary{padding-top:var(--sp-2);border-top:1px solid #ffffff0f;flex-direction:column;gap:2px;display:flex}.species-dashboard{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-subtle)}.species-dashboard-title{font-family:var(--font-heading);color:var(--dark-limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-3);font-size:12px;font-weight:600}.species-bar-row{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2);display:flex}.species-bar-label{font-family:var(--font-mono);text-align:center;min-width:16px;font-size:14px;font-weight:700}.species-bar-track{background:var(--surface-inset);border:1px solid var(--border-subtle);border-radius:3px;flex:1;height:14px;overflow:hidden}.species-bar-fill{opacity:.85;border-radius:2px;height:100%;transition:width .3s}.species-bar-value{font-family:var(--font-mono);color:var(--limestone);text-align:right;min-width:58px;font-size:12px}.system-state-panel{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-subtle)}.system-state-title{font-family:var(--font-heading);color:var(--dark-limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-3);font-size:12px;font-weight:600}.system-state-grid{gap:var(--sp-2);grid-template-columns:1fr 1fr;display:grid}.system-state-item{background:var(--surface-inset);border:1px solid var(--border-subtle);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);flex-direction:column;gap:2px;display:flex}.system-state-label{font-family:var(--font-sans);color:var(--dark-limestone);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.system-state-label sub{font-size:9px}.system-state-value{font-family:var(--font-mono);color:var(--light-gray);font-size:14px;font-weight:600}.system-state-direction{align-items:center;gap:var(--sp-2);flex-direction:row;display:flex}.system-state-arrow{font-size:20px;font-weight:700;line-height:1}.system-state-direction-label{font-size:12px;font-weight:500}.reference-card{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-subtle)}.reference-card-title{font-family:var(--font-heading);color:var(--dark-limestone);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-3);font-size:12px;font-weight:600}.reference-section{margin-bottom:var(--sp-3)}.reference-section-label{color:var(--dark-limestone);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--sp-1);font-size:11px;font-weight:600}.reference-eq-row{background:var(--surface-inset);border:1px solid var(--border-subtle);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);margin-bottom:var(--sp-1);cursor:default;transition:border-color .3s,background .3s,box-shadow .3s;position:relative}.reference-eq-row:hover{background:#ffffff08;border-color:#ffffff26}.reference-eq-highlight{box-shadow:0 0 8px #f1be4826;background:var(--gold-dim)!important;border-color:#f1be4866!important}.reference-eq-formula{font-family:var(--font-mono);color:var(--limestone);letter-spacing:.3px;font-size:13px}.reference-eq-highlight .reference-eq-formula{color:var(--gold)}.reference-tooltip{z-index:20;background:var(--surface-card);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);font-family:var(--font-sans);color:var(--limestone);pointer-events:none;border:1px solid #f1be4840;font-size:12px;line-height:1.55;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 4px 16px #00000080}.recharts-tooltip-wrapper{pointer-events:none}
