:root{--bg-color: #e0f7fa;--bg-gradient: linear-gradient(135deg, #e0f7fa 0%, #e6e6fa 100%);--artery-red: #ff4d6d;--vein-blue: #00b4d8;--organ-pink: #ffb3c6;--text-main: #333333;--text-muted: #666666;--glass-bg: rgba(255, 255, 255, .8);--glass-border: rgba(255, 255, 255, .9);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .1);--accent-glow: 0 0 20px rgba(255, 77, 109, .4);--font-family: "Outfit", "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif;--border-radius: 20px}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;padding:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:var(--bg-gradient);color:var(--text-main);font-family:var(--font-family);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:800;letter-spacing:-.02em}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;font-family:inherit;font-weight:600;transition:all .2s cubic-bezier(.25,.46,.45,.94)}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--glass-shadow)}.btn-primary{background:linear-gradient(90deg,var(--artery-red) 0%,#ff5c8a 100%);color:#fff;padding:12px 24px;border-radius:999px;font-size:1.1rem;box-shadow:0 4px 15px #f366}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f369;filter:brightness(1.1)}.btn-primary:active{transform:translateY(1px)}.btn-secondary{background:linear-gradient(90deg,var(--vein-blue) 0%,#4ae2ff 100%);color:#0d0415;padding:12px 24px;border-radius:999px;font-size:1.1rem;box-shadow:0 4px 15px #00d2ff4d}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00d2ff80;filter:brightness(1.1)}.app-header{position:absolute;top:0;left:0;right:0;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;z-index:100;pointer-events:none}.app-header>*{pointer-events:auto}.back-btn{display:flex;align-items:center;gap:.5rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);color:var(--text-main);padding:.5rem 1rem;border-radius:99px;font-size:1rem;transition:all .2s ease;box-shadow:0 2px 10px #0000000d}.back-btn:hover{background:#fffffff2;transform:translate(-3px)}.nav-title-container{background-color:#ffffffd9;padding:8px 24px;border-radius:20px;box-shadow:0 4px 12px #0000001a;border:1px solid rgba(255,255,255,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:auto}.nav-title-container h2{margin:0;color:#333;font-size:1.2rem;font-weight:800}@media(max-width:768px){.nav-title-container{display:none}}@keyframes pulseGlow{0%{box-shadow:0 0 10px #f366}50%{box-shadow:0 0 25px #ff3366b3}to{box-shadow:0 0 10px #f366}}.animate-pulse{animation:pulseGlow 2s infinite ease-in-out}#phaser-game-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center;overflow:hidden;border-radius:inherit}#phaser-game-container canvas{box-shadow:var(--glass-shadow);border-radius:var(--border-radius);max-width:100%;max-height:100%;object-fit:contain}.chapter-container{width:100%;height:100vh;position:relative;display:flex;flex-direction:column}.chapter-content{flex:1;position:relative;padding-top:5rem;display:flex;flex-direction:column}.instructions{text-align:center;gap:1.5rem;background:#fff;padding:.8rem 1.5rem;border-radius:20px;box-shadow:0 4px 15px #0000000d;flex-wrap:wrap}@media(max-width:768px){.chapter-container{height:auto;min-height:100vh}.chapter-content{padding-top:4rem;padding-left:1rem;padding-right:1rem;gap:1.5rem}.instructions{padding:1rem;margin:0 .5rem}.instructions h2{font-size:1.3rem}.instructions p{font-size:.95rem}.app-header{padding:.5rem 1rem}.back-btn{padding:.4rem .8rem;font-size:.9rem}}.home-container{width:100vw;height:100vh;position:relative;overflow:hidden;background:var(--bg-gradient);display:flex;justify-content:center}.city-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none}.grid-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-size:50px 50px;background-image:linear-gradient(to right,rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(to bottom,rgba(0,0,0,.03) 1px,transparent 1px)}.blood-vessel{position:absolute;height:4px;border-radius:4px;opacity:.2;z-index:2;box-shadow:0 0 10px currentColor}.vein-vessel{background:var(--vein-blue);color:var(--vein-blue);animation:flowVein 4s linear infinite}.artery-vessel{background:var(--artery-red);color:var(--artery-red);animation:flowArtery 4s linear infinite}.home-content{position:relative;z-index:10;width:100%;max-width:800px;height:100%;display:flex;flex-direction:column;padding:2rem;overflow-y:auto;scrollbar-width:none}.home-content::-webkit-scrollbar{display:none}.home-header{text-align:center;margin-bottom:2rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:30px;border:1px solid rgba(255,255,255,1);box-shadow:0 10px 30px #0000000d;flex-shrink:0}.home-header h1{font-size:3.5rem;margin-bottom:.5rem;background:linear-gradient(90deg,red,#ff7f00,#ff0,#0f0,#00f,indigo,#8b00ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:rainbow 5s linear infinite;background-size:200% auto}@keyframes rainbow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.home-header p{color:var(--text-muted);font-size:1.2rem;font-weight:500}.heart-chart-banner{max-width:400px;margin:1.5rem auto;padding:1.5rem;border:3px solid rgba(255,59,48,.3);background:#ffffffd9}.heart-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.heart-chart-header h3{margin:0;color:#ff3b30;font-size:1.4rem;font-weight:800}.heart-count-badge{background:#ff3b30;color:#fff;padding:.3rem .8rem;border-radius:20px;font-weight:700;font-size:1.1rem}.heart-collection{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.collected-heart{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform .3s}.collected-heart.earned{animation:bounceHeart 2s infinite ease-in-out}.collected-heart.locked{opacity:.5;filter:grayscale(100%) drop-shadow(0 0 0 transparent)}@keyframes bounceHeart{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.home-reset-btn{position:absolute;top:20px;right:20px;background:#ffffffb3;border:2px solid rgba(0,0,0,.1);color:#555;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.9rem;cursor:pointer;z-index:100;transition:all .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.home-reset-btn:hover{background:#fff;color:#ff3b30;border-color:#ff3b30;transform:scale(1.05)}.chapter-list{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:4rem}.chapter-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#fffffff2;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);border:2px solid transparent;border-left:8px solid var(--node-color);border-radius:20px;box-shadow:0 4px 15px #0000000d}.chapter-card:hover{transform:translateY(-5px);box-shadow:0 15px 30px #0000001a,0 0 20px #ffffff80;border-color:var(--node-color);background:#fff}.card-icon-wrapper{width:70px;height:70px;border-radius:50%;background:#f0f4f8;display:flex;justify-content:center;align-items:center;flex-shrink:0;box-shadow:inset 0 2px 5px #0000000d,0 5px 15px #0000000d}.card-info{flex:1;display:flex;flex-direction:column}.card-chapter{font-size:.9rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.3rem}.card-title{font-size:1.5rem;color:var(--text-main);margin:0;font-weight:800}.card-action{opacity:0;transform:translate(-10px);transition:all .3s ease}.chapter-card:hover .card-action{opacity:1;transform:translate(0)}.start-btn{color:#fff;padding:10px 24px;border-radius:99px;font-size:1.1rem;font-weight:700;box-shadow:0 4px 10px #0003;pointer-events:none}@keyframes flowVein{0%{transform:rotate(5deg) translate(-100px)}to{transform:rotate(5deg) translate(100px)}}@keyframes flowArtery{0%{transform:rotate(-5deg) translate(100px)}to{transform:rotate(-5deg) translate(-100px)}}@media(max-width:768px){.home-content{padding:1rem}.home-header{padding:1.5rem 1rem;margin-bottom:1.5rem}.home-header h1{font-size:2.2rem}.home-header p{font-size:1rem}.chapter-card{padding:1rem;gap:1rem}.card-icon-wrapper{width:50px;height:50px}.card-icon-wrapper svg{width:24px;height:24px}.card-title{font-size:1.2rem}.card-chapter{font-size:.8rem}.start-btn{padding:8px 16px;font-size:.9rem}.card-action{display:none}}.heart-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:99999;opacity:0;pointer-events:none;transition:opacity .3s ease}.heart-modal-overlay.visible{opacity:1;pointer-events:auto}.heart-modal-content{background:#fff;padding:3rem;border-radius:30px;box-shadow:0 20px 50px #00000026;text-align:center;max-width:500px;border:5px solid #ff3b30;transform:scale(.8) translateY(50px);transition:transform .5s cubic-bezier(.175,.885,.32,1.275)}.heart-modal-overlay.visible .heart-modal-content{transform:scale(1) translateY(0)}.heart-modal-icon{font-size:6rem;margin-bottom:1rem;line-height:1}.heart-modal-title{color:#ff3b30;font-size:2.5rem;margin-bottom:1rem;font-weight:900}.heart-modal-text{font-size:1.2rem;color:#555;margin-bottom:2rem}.heart-modal-actions{position:relative;z-index:100}.heart-modal-btn{font-size:1.2rem!important;padding:1rem 2.5rem!important;position:relative!important;z-index:999999!important;pointer-events:auto!important;cursor:pointer!important}@keyframes heartPulse{0%{transform:scale(1)}15%{transform:scale(1.2)}30%{transform:scale(1)}45%{transform:scale(1.2)}to{transform:scale(1)}}.confetti{position:absolute;top:-20px;width:15px;height:15px;transform-origin:center;animation:confettiFall 3s linear infinite;z-index:999}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.heart-modal-close-btn{position:absolute;top:-15px;right:-15px;background:#ff3b30;color:#fff;border:4px solid white;width:40px;height:40px;border-radius:50%;font-size:1.2rem;font-weight:700;display:flex;justify-content:center;align-items:center;cursor:pointer;z-index:1002;box-shadow:0 4px 10px #0003;transition:transform .2s ease,background .2s ease}.heart-modal-close-btn:hover{transform:scale(1.1);background:#d62820}.ch1-layout{display:flex;flex-direction:column;min-height:100vh;padding:5rem 3rem 2rem;box-sizing:border-box;gap:1rem;background:#f0f8ff;overflow-y:auto;position:relative;align-items:center}.game-content{display:flex;justify-content:center;align-items:flex-start;gap:1.5rem;width:100%;max-width:900px;margin:0 auto;flex:1;min-height:0}.game-column{flex:1;display:flex;flex-direction:column;justify-content:center;gap:1.5rem;width:100%}.phase-enter{animation:slideIn .8s cubic-bezier(.175,.885,.32,1.275) both}@keyframes slideIn{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}.transition-overlay{position:absolute;inset:0;background:#f0f8fff2;z-index:50;display:flex;justify-content:center;align-items:center;flex-direction:column}.transition-text{font-size:3rem;color:#0277bd;margin-bottom:2rem;animation:popIn .5s both}.truck-animation-container{width:100%;position:relative;height:200px}.moving-truck{position:absolute;width:200px;bottom:0;left:-200px;animation:driveAcross 3.5s linear forwards}@keyframes driveAcross{0%{left:-200px}20%{left:20%}40%{left:20%;transform:scale(1.1)}60%{left:20%;transform:scale(1)}to{left:120%}}.zone-half{flex:1;position:relative;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:#fff;border-radius:40px;box-shadow:0 10px 30px #00000014}.supply-zone{border:6px solid #fff9c4}.delivery-zone{border:6px solid #e1f5fe}.zone-title{text-align:center;font-size:1.6rem;font-weight:800;text-transform:uppercase;letter-spacing:2px}.supply-title{color:#f57f17}.delivery-title{color:#0277bd}.drop-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}.organ-slot{background:#ffffffb3;border-radius:20px;display:flex;flex-direction:column;align-items:center;padding:1rem;box-shadow:0 4px 10px #0000000d;transition:transform .2s;border:2px solid transparent}.organ-slot.drag-over{background:#fff;transform:scale(1.05);box-shadow:0 10px 20px #0000001a;border:2px solid #aaa}.organ-img-fixed{width:90px;height:90px;object-fit:contain;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.organ-slot:hover .organ-img-fixed{transform:scale(1.2)}.organ-name-tag{font-weight:900;margin-top:.5rem;color:#444;text-align:center;font-size:1rem;text-transform:uppercase}.func-pocket{margin-top:.5rem;width:60px;height:60px;border:3px dashed;border-radius:50%;display:flex;justify-content:center;align-items:center;background:#00000005}.pocket-hint{font-size:.8rem;color:#888;text-transform:uppercase;font-weight:800}.tray-wrapper{display:flex;justify-content:center;text-align:center;width:100%}.flashcard-tray{height:140px;background:#fff;border-radius:24px;border:3px solid rgba(0,0,0,.05);box-shadow:0 10px 30px #00000014;display:flex;align-items:center;justify-content:center;padding:0 1.5rem;gap:1.5rem;width:100%}.tray-title{writing-mode:vertical-rl;transform:rotate(180deg);font-weight:900;color:#ccc;font-size:1.2rem;letter-spacing:4px}.tray-card{border:5px solid var(--card-color);background:#fff;border-radius:20px;padding:.5rem;position:relative;cursor:grab;width:100px;height:100px;flex-shrink:0;transition:transform .3s;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.2rem}.tray-card:hover{transform:translateY(-10px) scale(1.1);box-shadow:0 10px 20px #0003;z-index:10}.tray-card:active{cursor:grabbing;transform:scale(.9)}.card-icon-emoji{font-size:2.5rem}.card-func-name{font-weight:800;color:#555;font-size:.8rem;margin-top:.2rem}.l-icon{font-size:2rem}.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes popIn{0%{transform:scale(.5) rotate(-10deg);opacity:0}80%{transform:scale(1.15) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}.success-message{flex:1;display:flex;justify-content:center;color:#0277bd;animation:popIn .8s cubic-bezier(.175,.885,.32,1.275) both}@media(max-width:600px){.ch1-layout{padding:4rem 1rem 6rem;gap:.75rem}.instructions{padding:.6rem 1rem;border-radius:16px}.instructions h2{font-size:1.1rem;margin:0 0 .2rem}.instructions p{font-size:.9rem;margin:0}.game-content{flex-direction:column;gap:.75rem;width:100%}.game-column{gap:.75rem}.zone-half{padding:.75rem;border-radius:20px}.zone-title{font-size:1rem;letter-spacing:1px}.drop-grid{gap:.75rem!important}.organ-slot{padding:.6rem .4rem;border-radius:14px}.organ-img-fixed{width:62px;height:62px}.organ-name-tag{font-size:.75rem;margin-top:.3rem}.func-pocket{width:48px;height:48px;margin-top:.3rem}.pocket-hint{font-size:.65rem}.l-icon{font-size:1.6rem}.flashcard-tray{height:auto;flex-wrap:wrap;padding:.75rem;gap:.75rem;border-radius:16px;justify-content:center}.tray-card{width:110px;height:auto;min-height:80px;border-width:3px;border-radius:14px;padding:.5rem .4rem;gap:.25rem}.card-icon-emoji{font-size:1.8rem;line-height:1}.card-func-name{font-size:.72rem;line-height:1.2;text-align:center}.func-pocket{min-width:52px;min-height:52px}}@media(min-width:601px)and (max-width:900px){.ch1-layout{padding:5rem 1.5rem 2rem}.organ-img-fixed{width:72px;height:72px}.zone-title{font-size:1.2rem}.flashcard-tray{height:auto;flex-wrap:wrap;padding:1rem;justify-content:center}.tray-card{width:90px;height:90px}}.ch2-layout{padding:6rem 3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.game-wrapper{display:flex;flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:1000px}.phaser-container{width:100%;height:500px;overflow:hidden;display:flex;justify-content:center;align-items:center;border-radius:30px;background:radial-gradient(circle at center,#00d2ff1a,#0006);border:4px solid rgba(0,210,255,.2);box-shadow:0 10px 30px #00000080,inset 0 0 20px #00d2ff1a}.phaser-container canvas{width:100%;height:100%}.control-panel{display:flex;justify-content:center;align-items:center;gap:3rem;width:100%}.energy-monitor{width:250px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;border-radius:20px}.energy-label{font-size:1.2rem;font-weight:800;color:var(--text-main);text-transform:uppercase;letter-spacing:1px}.energy-bar-container{width:100%;height:30px;background:#0000001a;border-radius:15px;border:2px solid rgba(0,0,0,.1);overflow:hidden;box-shadow:inset 0 2px 5px #0000001a}.energy-bar-fill{height:100%;width:0%;transition:width .1s linear,background .3s ease}.energy-bar-fill.warning{background:linear-gradient(90deg,#fc0,#ffea00)}.energy-bar-fill.good{background:linear-gradient(90deg,#34c759,#3ebd60)}.energy-bar-fill.danger{background:linear-gradient(90deg,#ff3b30,#ff5c5c)}.energy-status{font-size:.9rem;font-weight:700;color:var(--text-muted)}.giant-btn{background:linear-gradient(145deg,#f36,#ff5c8a);color:#fff;border:none;width:200px;height:200px;border-radius:50%;font-size:2rem;font-weight:800;cursor:pointer;box-shadow:0 10px 25px #ff336680,inset 0 -10px 20px #0003,inset 0 10px 20px #fff6;transition:all .1s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;justify-content:center;align-items:center;-webkit-user-select:none;user-select:none;animation:idle-heartbeat 2s infinite}.giant-btn:hover{animation:none;transform:scale(1.05);box-shadow:0 15px 35px #f369,inset 0 -10px 20px #0003,inset 0 10px 20px #ffffff80}.giant-btn:active{animation:none;transform:scale(.95);box-shadow:0 5px 15px #f366,inset 0 -5px 10px #0000004d,inset 0 5px 10px #fff3}@keyframes idle-heartbeat{0%{transform:scale(1)}5%{transform:scale(1.05)}10%{transform:scale(1)}15%{transform:scale(1.05)}50%{transform:scale(1)}to{transform:scale(1)}}.giant-btn .count{font-size:1.2rem;opacity:.8;margin-top:.5rem;font-weight:600}@media(max-width:768px){.ch2-layout{padding:4rem 1rem 1rem;gap:1rem}.phaser-container{height:300px;border-radius:15px}.control-panel{flex-direction:column;gap:1.5rem}.energy-monitor{width:100%;max-width:300px}.giant-btn{width:120px;height:120px;font-size:1.2rem}.giant-btn .count{font-size:.9rem}}.ch3-layout{padding:6rem 3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.body-map-container{width:100%;max-width:1200px;padding:2rem}.body-map-nodes{display:flex;justify-content:space-between;align-items:center;gap:2rem}.wide-layout{gap:3rem}.node-side{display:flex;flex-direction:column;align-items:center;gap:1rem;background:#ffffff80;padding:1.5rem;border-radius:20px;box-shadow:0 4px 15px #0000000d;width:200px}.frantic-pulse{animation:heartPulse .5s infinite}.leak-3{animation:bloodLeak 1.5s linear infinite .6s;top:80px;left:50px}.warning-text{color:#ff3b30;font-weight:900;text-transform:uppercase;animation:pulseWarn 1s infinite alternate}@keyframes pulseWarn{0%{color:#ff3b30;text-shadow:none}to{color:red;text-shadow:0 0 10px rgba(255,0,0,.5)}}.organ-stack{width:250px}.organ-list{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:.5rem}.mini-organ-icon{width:45px;height:45px;object-fit:contain;background:#fffc;border-radius:10px;padding:2px;border:1px solid rgba(0,0,0,.1)}.node-side h3{margin:0;color:var(--text-main);font-size:1.2rem;text-align:center}.vessel-connections{flex:1;display:flex;flex-direction:column;gap:3rem}.pathway{display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.path-label{font-size:.9rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;text-align:center;display:flex;justify-content:center;align-items:center;gap:.5rem}.direction-arrow{font-size:1.5rem;line-height:1}.direction-arrow.red{color:#f36;animation:bounceRight .8s infinite alternate ease-in-out}.direction-arrow.blue{color:#00d2ff;animation:bounceLeft .8s infinite alternate ease-in-out}@keyframes bounceRight{0%{transform:translate(0)}to{transform:translate(8px)}}@keyframes bounceLeft{0%{transform:translate(0)}to{transform:translate(-8px)}}.vessel-track{display:flex;gap:0;height:60px;width:100%}.vessel-chunk{flex:1;border-radius:0;display:flex;justify-content:center;align-items:center;position:relative;transition:transform .05s ease,background .05s ease;background:#0000000f}.vessel-chunk:not(:first-child){margin-left:-15px}.vessel-chunk.artery-slot{clip-path:polygon(0% 0%,85% 0%,100% 50%,85% 100%,0% 100%,15% 50%);background-color:#fdbacb}.vessel-chunk.vein-slot{clip-path:polygon(15% 0%,100% 0%,85% 50%,100% 100%,15% 100%,0% 50%);background-color:#cad8f7}.vessel-chunk.drag-over{background:#00000026;transform:scale(1.05);z-index:5}.vessel-chunk.filled{background:transparent}.placed-vessel{width:100%;height:100%;border-radius:0;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden;box-shadow:0 4px 10px #0003;animation:popInPipe .3s cubic-bezier(.175,.885,.32,1.275)}.vessel-label{color:#fff;font-weight:700;font-size:.8rem;position:relative;z-index:2;text-shadow:1px 1px 2px rgba(0,0,0,.5)}@keyframes popInPipe{0%{transform:scaleX(.5) scaleY(.5);opacity:0}80%{transform:scaleX(1.1) scaleY(1.1)}to{transform:scaleX(1) scaleY(1);opacity:1}}.artery-flow{background:#f36}.vein-flow{background:#00d2ff}.flow-particles{position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(90deg,#fff0,#fff9,#fff0);background-size:200% 100%;z-index:1}.artery-flow .flow-particles{animation:flowRight 1.5s linear infinite}.vein-flow .flow-particles{animation:flowLeft 1.5s linear infinite}@keyframes flowRight{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes flowLeft{0%{background-position:-200% 0}to{background-position:200% 0}}.slot-hint{color:#999;font-weight:700;font-size:.8rem;text-transform:uppercase}.artery-hint,.vein-hint{color:#555!important}.tray-container{width:100%;display:flex;justify-content:center}.wide-tray{max-width:1200px;flex-wrap:wrap;justify-content:center}.small-card{width:120px;height:60px;padding:0}.tray-card.chevron-piece{border:none!important;border-radius:0!important}.tray-card.artery-piece{background-color:#f36!important;clip-path:polygon(0% 0%,85% 0%,100% 50%,85% 100%,0% 100%,15% 50%)}.tray-card.vein-piece{background-color:#00d2ff!important;clip-path:polygon(15% 0%,100% 0%,85% 50%,100% 100%,15% 100%,0% 50%)}.tray-card.selected-card{transform:translateY(-15px) scale(1.15);filter:drop-shadow(0 15px 15px rgba(0,0,0,.2)) drop-shadow(0 0 10px var(--card-color));box-shadow:none!important;border-width:0!important;z-index:10}.vessel-chunk.ready-to-receive{animation:pulseReady 1.5s infinite;cursor:pointer;border-color:#666;background:#0000000d}@keyframes pulseReady{0%{box-shadow:0 0 #64646433}70%{box-shadow:0 0 0 15px #64646400}to{box-shadow:0 0 #64646400}}.slide-up{animation:slideUp .5s cubic-bezier(.25,.8,.25,1) forwards}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.success-overlay{background:#38b00033;border:1px solid rgba(56,176,0,.5);border-radius:20px;padding:1.5rem 3rem;text-align:center;box-shadow:0 10px 30px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.success-overlay h2{color:#a7c957;margin-bottom:.5rem}.reset-btn{background:#fff;color:#333;border:none;padding:.6rem 1.2rem;border-radius:99px;font-weight:700;cursor:pointer;box-shadow:0 4px 10px #0000001a;transition:transform .2s}.reset-btn:hover{transform:scale(1.05)}.top-reset-btn{margin-top:1rem;background:#fff9;color:#333;border:1px solid rgba(255,255,255,.8);box-shadow:0 2px 5px #0000000d}.top-reset-btn:hover{background:#ffffffe6}@media(max-width:768px){.ch3-layout{padding:4rem 1rem 2rem;gap:1.5rem;min-height:100vh;justify-content:flex-start}.body-map-container{padding:1rem}.body-map-nodes{flex-direction:column;gap:2rem}.node-side{width:100%;padding:1rem}.node-icon{width:80px;height:80px}.heart-wrapper{width:90px;height:90px}.organ-list{grid-template-columns:repeat(4,1fr)}.mini-organ-icon{width:35px;height:35px}.vessel-connections{width:100%;gap:2rem}.vessel-track{height:50px}.vessel-label{font-size:.9rem}.tray-container{padding:0 .5rem;margin-top:auto}.flashcard-tray{border-radius:15px;padding:.5rem}.small-card{width:100px;height:50px}.card-func-name{font-size:1.1rem!important}}.ch4-layout{padding:4.5rem 3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.slider-panel{width:100%;padding:1rem 2rem;display:flex;flex-direction:column;gap:.5rem}.slider-header{display:flex;justify-content:space-between;font-weight:700;font-size:1.2rem}.warning-text{color:#f36;text-shadow:0 0 10px rgba(255,51,102,.5)}.pinch-slider{-webkit-appearance:none;appearance:none;width:100%;height:20px;background:linear-gradient(90deg,#38b000,#ff5c8a,#f36);border-radius:10px;outline:none;box-shadow:inset 0 0 10px #00000080}.pinch-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:40px;height:40px;border-radius:50%;background:#fff;cursor:pointer;border:4px solid var(--text-main);box-shadow:0 0 15px #ffffff80;transition:transform .1s}.pinch-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.markers-container{position:relative;width:100%;height:25px;margin-top:5px}.spot-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:25px;height:25px;border-radius:50%;background:#e0e0e0;border:3px solid #ccc;transition:all .3s ease;box-shadow:0 2px 5px #0003}.spot-marker.visited{background:#4caf50;border-color:#fff;box-shadow:0 0 15px #4caf50;transform:translate(-50%,-50%) scale(1.2)}@media(max-width:768px){.ch4-layout{padding:4rem 1rem 1rem}.slider-panel{padding:1rem}.slider-header{font-size:1rem}.pinch-slider::-webkit-slider-thumb{width:30px;height:30px}.monitor-container h3{font-size:1rem!important}}.ch5-layout{padding:6rem 3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.instructions{text-align:center;max-width:600px}.tool-selector{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.tool-btn{background:#1a1a1a!important;border:2px solid rgba(255,255,255,.4)!important;color:#fff!important;padding:1rem 1.8rem!important;border-radius:99px!important;font-size:1.1rem!important;cursor:pointer!important;transition:all .2s ease!important;font-weight:700!important}.tool-btn:hover{background:#444!important;transform:translateY(-2px)!important}.tool-btn.active{background:linear-gradient(90deg,#00d2ff,#3a7bd5)!important;border-color:#4ae2ff!important}.ch5-game-wrapper{display:flex;gap:2rem;align-items:stretch;width:100%;max-width:1000px;margin-top:1rem}.puzzle-container{flex:1;position:relative;height:400px;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none;display:flex;justify-content:center;align-items:center}.node-side{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;border:1px solid rgba(255,255,255,.2);width:200px;box-shadow:0 4px 15px #0000001a}.node-icon{width:110px;height:110px;object-fit:contain;position:relative;z-index:2}.heart-wrapper{position:relative;width:120px;height:120px;display:flex;justify-content:center;align-items:center}.pulse-animation{animation:heartPulse 1.5s infinite}.frantic-pulse{animation:heartPulse .4s infinite}@keyframes heartPulse{0%{transform:scale(1)}15%{transform:scale(1.1)}30%{transform:scale(1)}45%{transform:scale(1.1)}to{transform:scale(1)}}.leak-drop{position:absolute;width:15px;height:15px;background:#f36;border-radius:50% 0 50% 50%;transform:rotate(-45deg);z-index:1;opacity:0}.leak-1{animation:bloodLeak 1.2s linear infinite .1s;bottom:10px;right:20px}.leak-2{animation:bloodLeak 1s linear infinite .4s;bottom:20px;left:15px}@keyframes bloodLeak{0%{transform:translateY(0) rotate(-45deg) scale(.5);opacity:1}to{transform:translateY(60px) rotate(-45deg) scale(1.2);opacity:0}}.vessel-track-svg{position:absolute;top:0;left:0;width:100%;height:100%}.safe-path{pointer-events:stroke}.balloon-tool{position:absolute;font-size:2rem;width:40px;height:40px;display:flex;justify-content:center;align-items:center;cursor:grab;transform:translate(-50%,-50%);z-index:10;transition:transform .2s ease,filter .2s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.balloon-tool.dragging{cursor:grabbing;pointer-events:none;transform:translate(-50%,-50%) scale(1.1)}.balloon-tool.inflated{transform:translate(-50%,-50%) scale(2.5);filter:drop-shadow(0 0 15px #00d2ff);transition:transform 1s ease}.scissors-tool-container{position:absolute;width:100px;height:100px;margin-left:-50px;margin-top:-50px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:grab;z-index:10;transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.scissors-tool-container.dragging{cursor:grabbing;transform:scale(1.1)}.scissors-tool-container.snapped{cursor:pointer;filter:drop-shadow(0 0 15px rgba(0,210,255,.6));animation:lockOnBounce 1s infinite alternate}@keyframes lockOnBounce{0%{transform:scale(1.15)}to{transform:scale(1.25)}}.click-prompt{position:absolute;top:-40px;background:#00d2ff;color:#fff;padding:6px 14px;border-radius:20px;font-weight:900;font-size:.85rem;white-space:nowrap;animation:floatUp .6s ease-out infinite alternate;pointer-events:none;box-shadow:0 4px 10px #00d2ff4d;text-transform:uppercase;letter-spacing:1px}@keyframes floatUp{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.vein-segment{position:absolute;height:60px;background:#f36;border-radius:30px;display:flex;justify-content:center;align-items:center;color:#fff;font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.5);box-shadow:inset 0 -5px 10px #0003,0 4px 6px #0003;transform:translateY(-50%);z-index:2;padding:0 1rem}.left-vein,.right-vein{width:150px}.pinch-segment{position:absolute;transform:translate(-50%,-50%);background:#f36;color:#fff;padding:12px 24px;border-radius:40px;font-weight:900;font-size:1.2rem;box-shadow:0 4px 15px #f366;z-index:5;pointer-events:none;transition:opacity .3s ease,transform .1s ease;text-transform:uppercase;letter-spacing:1px}.pinch-segment.shaking{animation:snipImpact .2s ease-out}@keyframes snipImpact{0%{transform:translate(-50%,-50%) scale(1.2)}50%{transform:translate(-50%,-50%) scale(.9) rotate(5deg)}to{transform:translate(-50%,-50%) scale(1)}}.status-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:2rem 3rem;border-radius:20px;text-align:center;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 30px #0000004d;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275);display:flex;flex-direction:column;align-items:center;gap:1rem;min-width:300px}.status-overlay.success{background:#38b00033;border:1px solid rgba(56,176,0,.5)}.status-overlay.success p{color:#a7c957;font-size:1.2rem;font-weight:700;margin:0}.status-overlay.failed{background:#ff3b3033;border:1px solid rgba(255,59,48,.5)}.status-overlay.failed p{color:#ff3b30;font-size:1.2rem;font-weight:700;margin:0}.reset-btn{background:#1a1a1a;color:#fff;border:2px solid rgba(255,255,255,.4);padding:.6rem 1.2rem;border-radius:99px;font-weight:700;cursor:pointer;box-shadow:0 4px 10px #0000004d;transition:transform .2s,background .2s}.reset-btn:hover{transform:scale(1.05);background:#333}.top-reset-btn{margin-top:1.5rem;background:#f36;color:#fff;border:none;padding:.8rem 2rem;font-size:1.1rem;box-shadow:0 4px 15px #ff33664d}.top-reset-btn:hover{background:#ff5c8a;transform:scale(1.05)}@keyframes popIn{0%{transform:translate(-50%,-40%) scale(.9);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.jigsaw-piece-wrapper{position:absolute;cursor:grab;transform:translate(-50%,-50%);transition:transform .2s,filter .2s;filter:drop-shadow(0 4px 6px rgba(0,0,0,.2))}.jigsaw-piece-wrapper.dragging{cursor:grabbing;transform:translate(-50%,-50%) scale(1.1);filter:drop-shadow(0 10px 15px rgba(0,0,0,.3));z-index:100!important}.jigsaw-piece-wrapper.snapped{cursor:default;filter:drop-shadow(0 0 5px rgba(255,77,109,.5));animation:pieceSnap .3s cubic-bezier(.175,.885,.32,1.275)}.jigsaw-piece-wrapper.selected-card{filter:drop-shadow(0 0 15px rgba(0,210,255,.8));transform:translate(-50%,-50%) scale(1.1)}.ready-to-receive-svg{animation:pulseSvg 1.5s infinite}@keyframes pulseSvg{0%{fill:#ff33660d;stroke:#f363}50%{fill:#ff336626;stroke:#f369}to{fill:#ff33660d;stroke:#f363}}@keyframes pieceSnap{0%{transform:translate(-50%,-50%) scale(1.2)}to{transform:translate(-50%,-50%) scale(1)}}.ch5-status-footer{width:100%;max-width:800px;margin-top:2rem;padding:1.5rem 2rem;text-align:center;font-size:1.25rem;font-weight:700;color:var(--text-main);min-height:80px;display:flex;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 40px #0000001a}.ch5-status-footer.success{background:#38b00026;border:2px solid rgba(56,176,0,.3);color:#1b4332;transform:translateY(-5px);box-shadow:0 15px 45px #38b00033}.ch5-status-footer.failed{background:#ff3b3026;border:2px solid rgba(255,59,48,.3);color:#660708}.warning-text{color:#f36;font-weight:900;font-size:.8rem;letter-spacing:2px}.blood-flow-anim{stroke-dasharray:20 60;animation:flowPath 2s linear infinite;filter:drop-shadow(0 0 5px rgba(255,255,255,.5))}.blood-flow-slow{stroke-dasharray:10 90;animation:flowPath 5s linear infinite;filter:drop-shadow(0 0 2px rgba(255,255,255,.3));opacity:.5}@keyframes flowPath{0%{stroke-dashoffset:240}to{stroke-dashoffset:0}}@media(max-width:768px){.ch5-layout{padding:4rem 1rem 1rem;gap:1rem}.tool-selector{flex-direction:column;align-items:center;gap:.5rem}.tool-btn{width:100%;max-width:300px;padding:.8rem 1.2rem!important;font-size:.9rem!important}.puzzle-container{height:250px}.pinch-segment{padding:8px 16px;font-size:.9rem}.ch5-status-footer{padding:1rem;font-size:1rem;min-height:60px;margin-top:1rem}.anatomic-label{font-size:.6rem!important;padding:1px 4px!important}}.ch6-layout{display:flex;flex-direction:column;width:100%;height:100%;position:relative}.ch6-game-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;height:calc(100% - 70px);margin-top:60px}.assembly-zone{width:100%;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:0;background:transparent;box-shadow:none}.word-meaning-bubble{background-color:#fff;padding:.5rem 1.5rem;border-radius:20px;font-weight:700;color:#333;font-size:1.2rem;box-shadow:0 4px 10px #0000001a;position:relative;border:3px solid #af52de}.word-slots-container{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap}.syllable-slot{width:100px;height:100px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;transition:all .3s ease;border:3px dashed #af52de;background:#af52de1a}.syllable-slot.filled{border-style:solid;background:#fff;color:#af52de;border-color:#af52de;box-shadow:0 8px 16px #af52de4d}.syllable-slot.drag-over{background:#af52de4d;transform:scale(1.05)}.slot-hint{color:#af52de80;font-size:1.5rem}.placed-syllable{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.heart-source-container{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;position:relative;min-height:140px}.central-heart{width:130px;height:130px;display:flex;align-items:center;justify-content:center;transition:transform .1s ease}.central-heart.pumping{animation:pump .4s ease-in-out}@keyframes pump{0%{transform:scale(1)}20%{transform:scale(1.3)}40%{transform:scale(.9)}60%{transform:scale(1.15)}80%{transform:scale(.95)}to{transform:scale(1)}}.heart-image{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(255,59,48,.4))}.bloodstream-tray{width:100%;padding:1.5rem;background:#ff3b301a;border-radius:20px 20px 0 0;border-top:5px solid #ff3b30;position:relative;overflow:hidden}.bloodstream-tray:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,59,48,.2) 10px,transparent 11px),radial-gradient(circle at 80% 30%,rgba(255,59,48,.15) 15px,transparent 16px),radial-gradient(circle at 50% 80%,rgba(255,59,48,.2) 8px,transparent 9px);background-size:200px 100%;animation:bloodFlow 8s linear infinite;z-index:0}@keyframes bloodFlow{0%{background-position:0 0}to{background-position:200px 0}}.syllables-container{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}.blood-cell{width:90px;height:90px;border-radius:50%;background:#fff;border:5px solid #ff3b30;color:#ff3b30;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:900;cursor:pointer;box-shadow:inset 0 -4px 10px #ff3b3033,0 5px 15px #0000001a;animation:cellBob 3s ease-in-out infinite alternate}.blood-cell:active{cursor:pointer;transform:scale(1.1)}.selected-card{transform:scale(1.15);border-color:#fc0!important;box-shadow:0 0 20px #fc0!important}.correct-choice{background:#a7c957!important;color:#fff!important;border-color:#38b000!important;transform:scale(1.15);animation:popIn .3s ease}.shake-error{animation:shake .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-2px,0,0)}20%,80%{transform:translate3d(4px,0,0)}30%,50%,70%{transform:translate3d(-8px,0,0)}40%,60%{transform:translate3d(8px,0,0)}}@keyframes cellBob{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.success-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:2rem;text-align:center}.large-heart{width:250px}.bounce-animation{animation:bounce 2s infinite ease-in-out}@keyframes bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}.transition-overlay{position:absolute;inset:0;background:#ffffffe6;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .3s ease}.transition-text{color:#af52de;font-size:2.5rem;font-weight:700;margin-bottom:2rem}.pop-in{animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
