.drop-zone{border:3px dashed #0003;border-radius:16px;justify-content:center;align-items:center;width:88px;height:88px;display:flex}html,body{min-height:100%;margin:0;padding:0}#app{height:auto;min-height:100vh}body{color:#333;margin:0;font-family:Quicksand,sans-serif}:root{--pastel-pink:#ff9ecb;--pastel-peach:#ffbfa3;--pastel-yellow:#ffe59e;--pastel-mint:#b8f5c7;--brand-teal:#4cc9d9;--pastel-lavender:#d8b4fe}.mascot-placeholder{color:#fff;background:#d8b4fe;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;font-weight:700;display:flex}#drag-root{pointer-events:none;z-index:5000;position:absolute;inset:0}#dashboard{margin-left:1in}#sticker-sheet{z-index:999999;background:#0006;justify-content:center;align-items:center;padding:40px;display:none;position:fixed;inset:0}#sticker-sheet .sticker-slot{aspect-ratio:1;background:#fff;border-radius:16px;justify-content:center;align-items:center;width:100%;display:flex}#sticker-sheet .sticker-slot img{object-fit:contain!important;width:70%!important;height:70%!important}#global-progress{position:relative;top:-20px}#sticker-sheet::-webkit-scrollbar{display:none}#sticker-sheet ::-webkit-scrollbar{display:none}#sticker-sheet>div::-webkit-scrollbar{display:none}#header-actions{position:absolute;top:50%;right:20px;transform:translateY(-50%)}.pill-button{color:#fff;cursor:pointer;letter-spacing:.5px;background:#4cc9d9;border:none;border-radius:999px;padding:10px 22px;font-family:Quicksand,sans-serif;font-size:1rem;font-weight:700;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 10px #4cc9d966}.pill-button:hover{transform:translateY(-2px);box-shadow:0 6px 14px #4cc9d980}.pill-button:active{transform:translateY(0);box-shadow:0 3px 8px #4cc9d94d}.login-wrapper{background:#fff;border-radius:16px;max-width:360px;margin:40px auto;padding:20px;box-shadow:0 4px 12px #0000001a}.login-title{text-align:center;margin-bottom:20px;font-family:Quicksand,sans-serif;font-size:1.6rem}.login-form{flex-direction:column;gap:12px;display:flex}.login-form label{font-family:Quicksand,sans-serif;font-weight:600}.login-form input{border:1px solid #ddd;border-radius:8px;padding:10px;font-size:1rem}.login-submit{width:100%;margin-top:10px}.login-error{color:#d9534f;text-align:center;margin-top:10px;font-weight:600}.teacher-tabs{justify-content:center;gap:12px;margin-top:20px;margin-bottom:20px;font-weight:700;display:flex}.teacher-tab{color:#333;cursor:pointer;background:#b8f5c747;border:2px solid #4cc9d9;border-radius:999px;padding:12px 26px;font-family:Quicksand,sans-serif;font-size:1.05rem;font-weight:400;transition:transform .18s,background .18s,box-shadow .18s,color .18s}.teacher-tab:hover{background:#b8f5c761;transform:translateY(-2px)}.teacher-tab.active{color:#fff;background:#4cc9d9;transform:none;box-shadow:0 0 10px 3px #d8b4fe38}.empty-msg{color:#777;padding:10px;font-family:Quicksand,sans-serif;font-size:.9rem}.profile-wrapper{align-items:center;gap:12px;display:flex}.profile-name{color:#333;font-family:Quicksand,sans-serif;font-weight:700}.game-row{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.game-btn{cursor:pointer;background:#fff;border:none;border-radius:12px;align-items:center;gap:10px;padding:10px 14px;font-family:Quicksand,sans-serif;font-size:1rem;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 3px 6px #0000001f}.game-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000029}.switch{width:46px;height:24px;display:inline-block;position:relative}.switch input{display:none}.slider{cursor:pointer;background-color:#ccc;border-radius:24px;transition:all .3s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:#4cc9d9}input:checked+.slider:before{transform:translate(22px)}.teacher-welcome{text-align:center;color:#555;width:100%;padding:20px;font-family:Quicksand,sans-serif;font-size:1.1rem}.celebration-overlay{z-index:200;background:#ffffffd9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.celebration-card{text-align:center;background:#fff;border-radius:24px;padding:50px 70px;font-family:Quicksand,sans-serif;animation:.4s celebrationPop;box-shadow:0 8px 20px #0000001f,0 20px 40px #00000014}.celebration-card h2{margin:0;font-size:44px}@keyframes celebrationPop{0%{opacity:0;transform:scale(.7)}60%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.confetti-fountain-piece{pointer-events:none;z-index:999999;border-radius:2px;width:10px;height:14px;animation:2.5s ease-out forwards confettiFountain;position:fixed;bottom:40px;left:50%;transform:translate(-50%)}@keyframes confettiFountain{0%{opacity:1;transform:translate(-50%)rotate(0)}to{transform:translate(calc(-50% + var(--fx)), var(--fy)) rotate(720deg);opacity:0}}.confetti-piece{z-index:999999;width:10px;height:14px}.celebration-sparkle{pointer-events:none;z-index:999999;border-radius:50%;width:8px;height:8px;animation:1.2s ease-out forwards sparkleBurst;position:fixed}@keyframes sparkleBurst{0%{opacity:0;transform:scale(.4)}40%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.2)}}.progress-page{max-width:1200px;margin-left:2in;padding:0 20px}.progress-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.progress-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 6px #0000001a}.progress-page h2{margin-bottom:20px}.progress-card h3{margin-top:0}.skill-row{grid-template-columns:120px 1fr 50px;align-items:center;gap:10px;margin-bottom:10px;display:grid}.skill-bar{background:#eee;border-radius:6px;height:12px;overflow:hidden}.skill-fill{background:#4caf50;height:100%}.deficit-row{border-bottom:1px solid #eee;padding:6px 0}.heatmap-table td{text-align:center;border-radius:8px;padding:8px;font-weight:700;position:relative}.heat-green{color:#fff;background:#4caf50}.heat-orange{color:#fff;background:#ff9800}.heat-red{color:#fff;background:#f44336}.heat-empty{color:#888;background:#e0e0e0}.heat-sub{opacity:.75;margin-top:2px;font-size:10px}.progress-tabs{border-bottom:1px solid #e5e5e5;gap:8px;margin:20px 0 0;display:flex}.progress-tab{cursor:pointer;background:#f3f3f3;border:1px solid #0000;border-radius:6px 6px 0 0;padding:8px 16px;font-size:14px;transition:all .15s}.progress-tab:hover{background:#e8e8e8}.progress-tab.active{background:#fff;border:1px solid #e5e5e5;border-bottom-color:#fff;font-weight:600}.progress-tab{cursor:pointer;background:#eee;border:none;border-bottom:1px solid #e5e5e5;margin-bottom:18px;margin-right:6px;padding:8px 16px 10px}.progress-tab.active{background:#4cc9d9}.sort-icon{width:10px;display:inline-block}.sort-icon:after{content:"↕";opacity:.35;margin-left:6px;font-size:10px;font-weight:400}.sortable-name:hover .sort-icon:after,.sortable-skill:hover .sort-icon:after{opacity:.8}.progress-workspace{background:#fff;border-radius:12px;margin-top:20px;margin-left:1.5in;margin-right:1in;padding:24px;box-shadow:0 8px 18px #00000014}.progress-title{margin-bottom:18px;font-size:28px;font-weight:600}.progress-panel{border:1px solid #e5e5e5;border-top:none;border-radius:0 8px 8px;padding:20px}.activity-table-wrapper{border-radius:10px;margin-top:12px;overflow:hidden;box-shadow:0 8px 18px #00000014}.activity-table{border-collapse:collapse;background:#fff;width:100%}.activity-table th{color:#fff;text-align:left;background:#2f3a45;padding:10px;font-weight:600}.activity-table td{border-bottom:1px solid #eee;padding:10px}.activity-row{transition:all .15s}.activity-row:hover{background:#f7f9fb;transform:translateY(-1px)}.accuracy-high{color:#2e7d32;font-weight:700}.accuracy-mid{color:#f57c00;font-weight:700}.accuracy-low{color:#c62828;font-weight:700}.error-tag{color:#c62828;background:#ffe6e6;border-radius:4px;margin:2px;padding:3px 6px;font-size:12px;display:inline-block}.activity-header{justify-content:space-between;align-items:center;display:flex}.activity-filters select{border-radius:5px;margin-left:8px;padding:5px 8px}.last-session.up{color:#2e7d32;font-weight:700}.last-session.down{color:#c62828;font-weight:700}.last-session.same{color:#555}.intervention-row{background:linear-gradient(90deg,#f443361f,#f443360a);border-left:5px solid #e53935}.intervention-row:hover{background:linear-gradient(90deg,#f443362e,#f4433614)}#global-header{grid-template-columns:auto 1fr auto;align-items:center;padding:10px 16px;display:grid;position:relative}.header-left{justify-self:start}#page-title{justify-self:center;margin:0}#header-actions{justify-self:end;align-items:center;gap:10px;display:flex}.dashboard-btn{cursor:pointer;background:#fff;border:none;border-radius:14px;padding:6px 10px;font-size:22px;transition:all .2s;position:absolute;top:50%;left:16px;transform:translateY(-50%);box-shadow:0 2px 6px #00000026}.dashboard-btn:hover{background:#f5f5f5;transform:scale(1.08)}.dashboard-btn:active{transform:scale(.95)}.landing-container{text-align:center;flex-direction:column;align-items:center;padding-top:60px;display:flex}.landing-title{color:#4cc9d9;margin-bottom:40px;font-family:Lexend,sans-serif;font-size:48px}.login-options{align-content:flex-start;align-items:flex-start;gap:60px;display:flex}.login-column{flex-direction:column;align-items:center;padding-bottom:40px;display:flex}.student-graphic{width:170px;height:auto;margin:16px 0 20px}.teacher-graphic{width:100px;height:auto;margin:16px 0 20px;display:block}.landing-container .login-card{background:var(--card-color);box-sizing:border-box;text-align:center;border:3px solid #ffffffb3;border-radius:32px;flex-direction:column;align-items:center;width:280px;padding:14px;transition:transform .25s,box-shadow .25s;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 14px #00000014}.landing-container .login-card:after{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg width='300' height='300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23grain)' opacity='0.08'/%3E%3C/svg%3E");position:absolute;inset:0}.landing-container .login-card:hover{transform:translateY(-4px);box-shadow:0 10px 22px #0000001f}.landing-container .login-card>*{z-index:1;position:relative}.landing-container .teacher-card{--card-color:#ff9ecb}.landing-container .student-card{--card-color:#b8f5c7}.login-btn{cursor:pointer;color:#fff;border:none;border-radius:16px;width:100%;margin-top:20px;padding:16px 0;font-family:Lexend,sans-serif;font-size:20px;font-weight:600;position:relative;overflow:visible}.teacher-graphic-btn{cursor:pointer;background:0 0;border:none;padding:0;transition:transform .25s,filter .25s;display:inline-block;position:relative}.teacher-graphic-btn:hover{filter:brightness(1.15);transform:translateY(-6px)scale(1.03)}.teacher-btn-graphic{width:180px;height:auto;display:block}.teacher-btn-text{color:#fff;pointer-events:none;font-family:Lexend,sans-serif;font-size:28px;font-weight:600;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.student-graphic-btn{cursor:pointer;background:0 0;border:none;padding:0;transition:transform .25s,filter .25s;animation:2.2s ease-in-out infinite studentPop;display:inline-block;position:relative}.student-graphic-btn:hover{filter:brightness(1.15);animation-play-state:paused;transform:translateY(-6px)scale(1.03)}.student-btn-graphic{width:180px;height:auto;display:block}.student-btn-text{color:#fff;pointer-events:none;font-family:Lexend,sans-serif;font-size:32px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes studentPop{0%{transform:scale(1)}50%{transform:scale(1.06)}to{transform:scale(1)}}.student-login-wrapper{width:100%;max-width:380px;margin:0 auto;transform:translate(-40px)}#qr-reader__dashboard{display:none!important}#qr-reader__scan_region{animation:2.5s ease-in-out infinite scanPulse;box-shadow:0 0 24px #4cc9d973;border:6px solid #4cc9d9!important;border-radius:24px!important}@keyframes scanPulse{0%{box-shadow:0 0 20px #4cc9d966}50%{box-shadow:0 0 32px #4cc9d9b3}to{box-shadow:0 0 20px #4cc9d966}}.qr-reader-styled{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff59;border:6px solid #4cc9d9;border-radius:24px;width:360px;margin:0 auto;padding:16px;position:relative}.qr-reader-styled:before{content:"";filter:blur(60px);z-index:-1;background:#4cc9d926;border-radius:50%;width:420px;height:420px;position:absolute;top:-40px;left:50%;transform:translate(-50%)}.student-login-title{text-align:center;color:#4cc9d9;margin-top:10px;font-family:Lexend,sans-serif;font-size:36px;font-weight:700}.student-login-subtitle{text-align:center;color:#7acbd6;margin-bottom:20px;font-family:Lexend,sans-serif;font-size:20px}.student-login-note{text-align:center;color:#4cc9d9;width:100%;margin-top:16px;font-family:Lexend,sans-serif;font-size:18px;display:block}#qr-reader video{object-fit:cover;border-radius:20px;width:100%!important;height:auto!important}.student-dashboard-new{gap:24px;max-width:1100px;margin-top:30px;margin-left:180px;display:flex}.student-dashboard-new .left-panel{flex:none;width:700px}.student-dashboard-new .right-panel{flex:1}.student-dashboard-new .zone{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffe6;border-radius:20px;margin-bottom:28px;padding:20px;box-shadow:0 10px 25px #00000014}.student-dashboard-new .game-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px;display:grid}.student-dashboard-new .game-tile{aspect-ratio:1;cursor:pointer;color:#fff;border-radius:18px;justify-content:center;align-items:center;padding:10px;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 6px #00000026}.student-dashboard-new .game-tile:active{transform:translateY(4px);box-shadow:0 2px #0003}.student-dashboard-new .game-tile:hover{transform:translateY(-4px)scale(1.05)}.student-dashboard-new .game-tile:hover .tile-icon{transition:transform .2s;transform:translateY(-4px)scale(1.1)}.student-dashboard-new .tile-inner{flex-direction:column;justify-content:center;align-items:center;display:flex}.student-dashboard-new .tile-icon{filter:drop-shadow(0 4px 2px #0003);width:50px;height:50px;margin-bottom:6px}.student-dashboard-new .tile-name{text-align:center;font-size:14px}.student-dashboard-new .zone-header{align-items:center;gap:8px;margin-bottom:14px;font-size:20px;font-weight:700;display:flex}.student-dashboard-new .empty-msg{opacity:.6;padding:10px;font-size:14px}.student-dashboard-new .stars-card{text-align:center;background:linear-gradient(135deg,#fff176,#ffd54f);border-radius:24px;padding:24px;font-size:32px;transform:rotate(-2deg);box-shadow:0 10px 25px #00000026}.student-dashboard-new .stars-label{opacity:.7;margin-top:4px;font-size:14px}.student-dashboard-new .shop-item{background:#fff;border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:12px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 6px 14px #00000014}.student-dashboard-new .shop-item:hover{transform:translateY(-2px);box-shadow:0 10px 18px #0000001f}.student-dashboard-new .shop-left{align-items:center;gap:12px;display:flex}.student-dashboard-new .shop-icon{font-size:26px}.student-dashboard-new .shop-name{font-size:15px;font-weight:600}.student-dashboard-new .shop-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#81d4fa,#4fc3f7);border:none;border-radius:10px;padding:6px 14px;font-size:14px;transition:transform .1s,box-shadow .1s;box-shadow:0 4px #00000026}.student-dashboard-new .shop-btn:active{transform:translateY(3px);box-shadow:0 1px #0003}.student-dashboard-new .shop-btn:disabled{cursor:not-allowed;box-shadow:none;background:#ccc}.student-dashboard-new .shop-card{background:#ffffffe6;border-radius:24px;padding:18px;box-shadow:0 10px 25px #00000014}.student-dashboard-new .shop-card .zone-header{margin-bottom:10px;font-size:18px;font-weight:700}.student-dashboard-new .shop-header-msg{opacity:.75;margin-bottom:12px;font-size:14px}.student-dashboard-new .stars-unlock{animation:.8s starPop}@keyframes starPop{0%{transform:scale(1)}30%{transform:scale(1.2)rotate(-2deg)}60%{transform:scale(.95)}to{transform:scale(1)}}.student-dashboard-new .shop-unlock{animation:1s shopGlow}@keyframes shopGlow{0%{box-shadow:0 0 #ffd70000}50%{box-shadow:0 0 25px #ffd70099}to{box-shadow:0 0 #ffd70000}}#global-end-overlay{z-index:99999;background:#ffffffd9;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.global-end-inner{flex-direction:column;align-items:center;gap:20px;display:flex}.global-end-label{color:#4cc9d9;font-family:Quicksand,sans-serif;font-size:2.2rem;font-weight:700}.global-end-replay{cursor:pointer;background:#fff url(/global/images/ui/replay.svg) 50%/60% no-repeat;border:4px solid #4cc9d9;border-radius:50%;width:90px;height:90px;animation:1.2s ease-in-out infinite globalReplayPulse;box-shadow:0 0 12px #4cc9d999,inset 0 0 10px #fffc}@keyframes globalReplayPulse{0%{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.12)}to{opacity:1;transform:scale(1)}}body{background-color:#fff;background-image:radial-gradient(circle at 20% 30%,#ff9ecb0d 0%,#0000 55%),radial-gradient(circle at 80% 25%,#ffbfa30d 0%,#0000 55%),radial-gradient(circle at 30% 75%,#ffe59e0d 0%,#0000 55%),radial-gradient(circle at 70% 70%,#b8f5c70d 0%,#0000 55%),radial-gradient(circle,#7fdde90d 0%,#0000 55%),radial-gradient(circle at 85% 60%,#d3b4ff0d 0%,#0000 55%),none;background-position:0 0,0 0,0 0,0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat,repeat,repeat,repeat;background-size:cover;background-attachment:scroll,scroll,scroll,scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box,border-box,border-box}#mascot-band{background:#f3e8ff;border-bottom:2px solid #0000000d;justify-content:center;align-items:center;height:140px;display:flex}#letter-layer{z-index:5;pointer-events:none;position:absolute;inset:0}.game-frame{box-sizing:border-box;z-index:3;background:#fff;border-radius:24px;flex-direction:column-reverse;align-items:center;gap:0;width:100%;max-width:1050px;height:100%;max-height:100vh;margin:0 auto;padding:0;font-family:Quicksand,sans-serif;display:flex;position:relative;overflow:visible;box-shadow:0 4px 10px #00000014,0 8px 24px #0000000f;padding-top:20px!important;padding-bottom:16px!important}.game-header{text-align:center;font-size:24px;font-weight:600}#game-body{box-sizing:border-box;flex-direction:column;flex:1;justify-content:flex-start;align-items:center;gap:0;margin:0;padding:0;display:flex}.game-frame-wrapper{justify-content:center;width:100%;display:flex;position:relative}#game-container.game-card{width:calc(100vw - 288px);height:calc(100vh - 120x);box-sizing:border-box;background:#fff;border-radius:32px;flex-direction:column;align-items:center;gap:32px;max-width:1100px;max-height:700px;margin:10px auto 80px;padding:40px 32px 80px;display:flex;box-shadow:0 6px 10px #0000000f,0 14px 28px #0000000d,0 28px 56px #0000000a}.game-footer{justify-content:center;align-items:center;height:60px;display:flex}#global-header{background:var(--brand-teal);z-index:10;border-bottom-right-radius:18px;border-bottom-left-radius:18px;justify-content:center;align-items:center;height:56px;display:flex;position:relative;box-shadow:0 4px 8px #0000001f,0 10px 20px #00000014}#global-header h1{color:#fff;letter-spacing:.4px;text-shadow:0 2px 4px #0000002e;z-index:2;margin:0;font-size:28px;font-weight:700}#back-btn{color:var(--brand-teal);cursor:pointer;background:#fff;border:2px solid #ffffffe6;border-radius:14px;margin-right:12px;padding:10px 16px;font-size:22px;font-weight:700;transition:transform .15s,box-shadow .15s;position:relative;top:50%;left:20px;transform:translateY(-50%);box-shadow:0 3px 6px #00000026,0 6px 14px #0000001a}#back-btn:hover{transform:translateY(-50%)scale(1.08);box-shadow:0 4px 8px #0000002e,0 8px 18px #0000001f}#game-container{box-sizing:border-box;width:100%;max-width:100%;height:80vh;margin:10vh auto;padding:0;position:relative;overflow:visible;transform:translateY(-40px)}.game-card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:2px solid #fff6}.game-frame-v2{flex-direction:column;width:100%;height:100vh;display:flex;overflow:hidden}.game-content-v2{flex:1;justify-content:center;align-items:center;min-height:0;display:flex}.game-inner-v2{box-sizing:border-box;flex-direction:column;width:100%;max-width:900px;height:100%;max-height:100%;padding:16px;display:flex}.legacy-adapter{justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.legacy-inner{transform-origin:top}#mascot-container{pointer-events:none;z-index:9999;will-change:transform;justify-content:center;align-items:center;width:280px;height:280px;display:flex;position:fixed;bottom:20px;right:20px;overflow:visible;transform:translateZ(0)}#liv-svg{width:100%;height:100%;overflow:visible}#liv-confetti-back{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:visible}#liv{opacity:1;transition:opacity .4s}#liv.hidden{opacity:0}#liv-eye-left,#liv-eye-right{fill:#2d2d2d}#liv-eye-left-highlight1,#liv-eye-right-highlight1{fill:#fff;opacity:.9}#liv-eye-left-highlight2,#liv-eye-right-highlight2{fill:#fff;opacity:.6}#liv-smile{stroke:#2d2d2d;stroke-width:6px;stroke-linecap:round;fill:none}#liv-blush-left,#liv-blush-right{fill:#ffb7c5;opacity:.35}#liv-star{fill:gold;stroke:gold;stroke-width:30px;stroke-linejoin:round;pointer-events:none;z-index:3;width:28px;height:28px;position:absolute;top:38px;left:42px}#liv-glow{fill:url(#confettiGlow);filter:url(#blurGlow);opacity:1}.liv-idleFloat{transform-origin:50%;animation:4s ease-in-out infinite livFloat}@keyframes livFloat{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}.liv-breathe{transform-origin:50%;animation:5s ease-in-out infinite livBreathe}@keyframes livBreathe{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.liv-blink #liv-eye-left,.liv-blink #liv-eye-right{transform-origin:50%;animation:.18s ease-in-out forwards livBlink}@keyframes livBlink{0%{transform:scaleY(1)}50%{transform:scaleY(.1)}to{transform:scaleY(1)}}#liv-eye-left-squint,#liv-eye-right-squint{stroke:#2d2d2d;stroke-width:6px;stroke-linecap:round;fill:none;opacity:0;transition:opacity .2s}#liv-inner{transform:translate(28px,20px)}.liv-bounce{animation:.9s ease-out livBounce}@keyframes livBounce{0%{transform:translateY(0)}20%{transform:translateY(-22px)}40%{transform:translateY(0)}55%{transform:translateY(-12px)}70%{transform:translateY(0)}85%{transform:translateY(-6px)}to{transform:translateY(0)}}.liv-sparkle{opacity:0;pointer-events:none;filter:blur(1px);width:8px;height:8px;animation:livSparkleFloat var(--sparkle-duration) ease-out forwards;border-radius:50%;position:absolute}@keyframes livSparkleFloat{0%{opacity:.9;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-40px)scale(.6)}}.confetti-piece{pointer-events:none;background:var(--confetti-color);width:8px;height:14px;animation:confettiNatural var(--duration) ease-out forwards;z-index:9999;border-radius:2px;position:absolute}@keyframes confettiNatural{0%{opacity:1;transform:translate(0, 0) rotate(var(--start-rot)) scale(1)}to{opacity:0;transform:translate(var(--fx), var(--fy)) rotate(var(--end-rot)) scale(.9)}}#liv-confetti-front{pointer-events:none;z-index:5;width:0;height:0;position:absolute;top:50%;left:50%}@media (width<=600px){#mascot-container{width:130px;height:130px;top:100px;right:10px}}@keyframes livEntranceFade{0%{opacity:0;filter:blur(6px);transform:scale(.85)}60%{opacity:1;filter:blur();transform:scale(1.03)}to{opacity:1;transform:scale(1)}}.liv-entrance{animation:.9s ease-out livEntranceFade}.game-btn{background:var(--brand-purple);color:#8b5cf6;border-radius:12px;padding:12px 24px;font-size:18px;font-weight:600;text-decoration:none;transition:transform .2s,background .2s;display:inline-block;box-shadow:0 3px #0000001a}.game-btn:hover{background:#8b5cf6;transform:scale(1.05)}#back-btn{background:"white";cursor:pointer;border:none;border-radius:12px;padding:10px 14px;font-size:20px;position:absolute;top:50%;left:20px;transform:translateY(-50%)}.game-card{box-sizing:border-box;background:#fff;border-radius:32px;flex-direction:column;align-items:center;gap:32px;width:calc(100vw - 288px);max-width:900px;height:calc(100vh - 96px);max-height:700px;margin:48px auto;padding:40px 32px;display:flex;overflow:hidden;box-shadow:0 6px 10px #0000000f,0 14px 28px #0000000d,0 28px 56px #0000000a}.game-card:before{content:"";border-radius:inherit;pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 0 22px #ffffffa6}.game-card:after{content:"";pointer-events:none;background:#ffffffe6;border-top-left-radius:32px;border-top-right-radius:32px;width:100%;height:4px;position:absolute;top:0;left:0}.letter-card{background:var(--brand-blue);color:#fff;cursor:pointer;border-radius:16px;justify-content:center;align-items:center;width:80px;height:80px;font-size:36px;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px #0000001a}.letter-card:active{transform:translateY(3px);box-shadow:0 1px #0000001a}.cards-row{justify-content:center;gap:10px;margin-bottom:30px;display:flex}.celebration-layer{pointer-events:none;position:fixed;inset:0;overflow:hidden}.glow{animation:1.2s ease-in-out infinite glowPulse}@keyframes glowPulse{0%{box-shadow:0 0 0px var(--brand-yellow)}50%{box-shadow:0 0 16px var(--brand-yellow)}to{box-shadow:0 0 0px var(--brand-yellow)}}.letter-bubble{color:#2d2d2d;background:var(--bubble-color);touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab;pointer-events:auto;z-index:20;border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;font-family:Quicksand,sans-serif;font-size:48px;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 4px 6px #ffffff80,inset 0 -8px 12px #0000001a,0 6px 12px #0000001f,0 10px 20px #00000014}.letter-bubble.dragging{z-index:500}.letter-bubble[data-color=pink]{background:var(--pastel-pink)}.letter-bubble[data-color=peach]{background:var(--pastel-peach)}.letter-bubble[data-color=yellow]{background:var(--pastel-yellow)}.letter-bubble[data-color=mint]{background:var(--pastel-mint)}.letter-bubble[data-color=teal]{background:var(--brand-teal)}.letter-bubble[data-color=lavender]{background:var(--pastel-lavender)}.letter-bubble:hover{transform:translateY(-4px);box-shadow:inset 0 4px 6px #ffffff80,inset 0 -8px 12px #0000001a,0 10px 18px #0000002e}.letter-bubble:disabled{opacity:.4;box-shadow:none;cursor:default;transform:none}.dragging{opacity:.9;pointer-events:none;transform:scale(1.1);box-shadow:0 12px 24px #0003}.letter-bubble{touch-action:none}#game-container{position:relative}#letter-layer{position:absolute;inset:0}#letter-shelf{pointer-events:auto;z-index:100;flex-direction:column;gap:16px;display:flex;position:absolute;top:50%;right:60px;transform:translateY(-50%)}.polka-panel{pointer-events:none;z-index:1;background-color:#0000;background-image:radial-gradient(circle,#ffb6db73 12%,#0000 12%),radial-gradient(circle,#ffdd9973 12%,#0000 12%),radial-gradient(circle,#ffe68073 12%,#0000 12%),radial-gradient(circle,#b8f5c773 12%,#0000 12%),radial-gradient(circle,#7fdde973 12%,#0000 12%);background-position:0 0,30px 30px,60px 0,0 60px,60px 60px;background-repeat:repeat,repeat,repeat,repeat,repeat;background-size:90px 90px;background-attachment:scroll,scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;flex:none;width:280px;height:100vh;max-height:100vh;position:absolute;top:0;left:0;-webkit-mask-image:linear-gradient(90deg,#000 0% 40%,#0000 100%);mask-image:linear-gradient(90deg,#000 0% 40%,#0000 100%)}#progress-bar{z-index:10;background:#4cc9d9;border:3px solid #4cc9d9;border-radius:16px;flex-direction:row;justify-content:center;align-items:center;gap:10px;padding:14px 20px;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:inset 0 4px 6px #fff6,inset 0 -4px 6px #0000001a,0 4px 10px #0000001f}.progress-segment{opacity:1;background:#dcdcdc;border-radius:8px;width:40px;height:14px;transition:background .25s,box-shadow .25s;box-shadow:inset 0 2px 3px #ffffffb3,inset 0 -3px 4px #0000001f,0 2px 4px #0000001a}.progress-segment.done{background:#fc3}#slots-row{box-sizing:border-box;flex-direction:row;align-items:center;gap:20px;width:100%;margin-bottom:4px;padding:10px;display:flex}.spelling-slot{color:#333;z-index:1;background:#fff;border:3px solid #000;border-radius:16px;justify-content:center;align-items:center;width:120px;height:120px;margin-top:-8px;font-family:Quicksand,sans-serif;font-size:48px;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;position:relative}#start-overlay{z-index:9999;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff0;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}#start-star{filter:drop-shadow(0 4px 6px #00000026);font-size:90px;animation:2s ease-in-out infinite floatStar}@keyframes floatStar{0%{transform:translateY(0)}50%{transform:translateY(-18px)}to{transform:translateY(0)}}#start-finger{opacity:.9;transform-origin:bottom;margin-top:20px;font-size:60px;animation:1.2s ease-in-out infinite floatFinger}@keyframes floatFinger{0%{transform:translateY(0)scale(1)}50%{transform:translateY(8px)scale(1.1)}to{transform:translateY(0)scale(1)}}#teacher-dashboard-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:10px;width:100%;max-width:1100px;margin-left:220px;padding:10px 20px;display:grid}@media (width<=1100px){#teacher-dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){#teacher-dashboard-grid{grid-template-columns:1fr}}#tab-games.first-grade-dashboard .objective-card{background:var(--card-color);box-sizing:border-box;border:3px solid #ffffffb3;border-radius:32px;width:100%;padding:14px;transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden;box-shadow:0 6px 14px #00000014}#tab-games.first-grade-dashboard .objective-card:after{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg width='300' height='300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23grain)' opacity='0.08'/%3E%3C/svg%3E");position:absolute;inset:0}#tab-games.first-grade-dashboard .objective-card:hover{transform:translateY(-4px);box-shadow:0 10px 22px #0000001f}#tab-games.first-grade-dashboard .objective-card>*{z-index:1;position:relative}.objective-title{margin-bottom:6px;font-size:20px;font-weight:700}#teacher-content .game-row{border-radius:8px;grid-template-columns:1fr 70px 80px;align-items:center;gap:6px;margin-bottom:4px;padding:2px 4px;transition:background .15s;display:grid}#teacher-content .game-row>:nth-child(2),#teacher-content .game-row>:nth-child(3){justify-self:center}#teacher-content .game-row:hover{background:#0000000a}#tab-games.first-grade-dashboard .game-btn{color:#333;text-align:left;cursor:pointer;background:#fff;border:2px solid #0000001a;border-radius:12px;width:100%;padding:8px 10px;font-size:15px;transition:transform .15s,background .15s,box-shadow .15s,border-color .15s;display:block}#tab-games.first-grade-dashboard .game-btn:hover{background:#fffd;border-color:#4cc9d9;transform:translateY(-2px);box-shadow:0 5px 12px #0000001f}#tab-games.first-grade-dashboard .game-btn:hover .game-name{text-decoration:underline}.game-emoji{font-size:18px}.game-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}#tab-games.first-grade-dashboard .switch{flex-shrink:0;width:48px;height:26px;display:inline-block;position:relative}#tab-games.first-grade-dashboard .switch input{opacity:0;width:0;height:0}#tab-games.first-grade-dashboard .slider{background-color:#ddd;border-radius:26px;transition:all .25s;position:absolute;inset:0}#tab-games.first-grade-dashboard .slider:before{content:"";background-color:#fff;border-radius:50%;width:20px;height:20px;transition:all .25s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #00000026}#tab-games.first-grade-dashboard .switch input:checked+.slider{background-color:#4cc9d9}#tab-games.first-grade-dashboard .switch input:checked+.slider:before{transform:translate(22px)}.assign-students-btn{justify-content:center;align-items:center;width:36px;height:30px;padding:0;font-size:16px;display:flex}.assign-students-btn:hover{background:#fffd;transform:translateY(-1px)}.objective-cvc{--card-color:#c8f7d7}.objective-magic-e{--card-color:#e6d4ff}.objective-vowel-teams{--card-color:#b8ecf2}.objective-digraphs{--card-color:#ffd2bf}.objective-blends{--card-color:#ffe9a8}.objective-r-controlled{--card-color:#ffc1dd}.objective-sight-words{--card-color:#cfeef2}#assign-modal-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}#assign-modal-overlay.hidden{display:none!important}#assign-modal{background:#fff;border-radius:22px;width:420px;max-height:70vh;padding:26px;overflow-y:auto;box-shadow:0 12px 30px #0000002e}#student-checkbox-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin:16px 0;display:grid}.student-check{background:#f7f7f7;border-radius:8px;align-items:center;gap:6px;padding:6px 8px;display:flex}.student-check:hover{background:#ececec}.card-header{grid-template-columns:1fr 70px 80px;align-items:center;margin-bottom:8px;display:grid}.column-title{text-align:center;color:#666;font-size:16px;font-weight:800}.card-header .column-title:nth-child(2){transform:translate(-9px)}.spell-cvc .game-frame{align-items:stretch!important}.spelling-slot.pink{background:#ffb3d9}.spelling-slot.peach{background:#ffc999}.spelling-slot.yellow{background:#ffe680}.spelling-slot.mint{background:#b8f5c7}.spelling-slot.teal{background:#7fdde9}#picture-container{background:#fff;border-radius:16px;justify-content:center;align-items:center;width:280px;height:260px;margin:4px auto 12px;padding:0;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 10px #00000014}#picture-container img{object-fit:contain;object-position:center;max-width:90%;max-height:90%;display:block}.game-body{box-sizing:border-box;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;max-width:900px;min-height:0;margin:0 auto;padding:0;display:flex;gap:0!important;margin-top:0!important;margin-bottom:0!important;padding-top:0!important;padding-bottom:0!important}.spelling-slot{box-sizing:border-box;background:#fff;border:3px solid #000;border-radius:14px;justify-content:center;align-items:center;width:100px;height:100px;font-family:Quicksand,sans-serif;font-size:48px;font-weight:700;transition:background-color .25s,border-color .25s,box-shadow .25s;display:flex;box-shadow:0 2px 3px #0000001f,0 4px 6px #0000001a,inset 0 1px 2px #fff9}.spelling-slot.active-slot{border:3px solid #000;animation:1.6s ease-in-out infinite breathe;position:relative}@keyframes breathe{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.spelling-slot.active-slot:after{content:"";filter:blur(10px);z-index:-1;pointer-events:none;background:#ffe67859;border-radius:18px;position:absolute;inset:-8px}@keyframes sparkle{0%,92%{opacity:0;transform:scale(.4)rotate(0)}96%{opacity:1;transform:scale(1)rotate(20deg)}to{opacity:0;transform:scale(.4)rotate(0)}}.spelling-slot.active-slot:before{content:"✦";color:#ffd84d;opacity:0;pointer-events:none;font-size:22px;animation:2.8s ease-in-out infinite sparkle;position:absolute;top:-14px;right:-14px}.spelling-slot.filled{color:#000;transform:scale(1.05);box-shadow:0 3px 5px #0000002e,0 6px 10px #00000024,inset 0 1px 2px #fff6}.spelling-slot.slot-hover{transition:box-shadow .15s,transform .15s;transform:scale(1.08);box-shadow:0 0 18px 6px #ffdc00bf}.spelling-slot.phoneme-highlight{outline:4px solid #ffc800e6;transition:all .2s;transform:scale(1.06);box-shadow:0 0 18px #ffc800cc}.letter-style{color:#000;justify-content:center;align-items:center;display:flex}.slots-row{justify-content:center;align-items:center;gap:3px;height:80px;display:flex;margin-top:4px!important;margin-bottom:0!important;padding-bottom:0!important}.slots-row-wrapper{margin-bottom:0!important;padding-bottom:5px!important}.letter-placeholder{visibility:hidden}.speaker-btn{color:#4cc9d9;cursor:pointer;background:#e8faff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:20px;font-size:32px;display:flex;box-shadow:0 4px 10px #0000002e}.speaker-btn:active{transform:scale(.9);box-shadow:0 2px 5px #00000040}.speaker-btn:hover{background:#4cc9d9}.speaker-btn.disabled{opacity:.5;pointer-events:none}.spell-cvc #letter-layer{pointer-events:auto!important}#letter-shelf{z-index:40;flex-direction:column;gap:16px;display:flex;position:absolute;top:50%;right:60px;transform:translateY(-50%)}#letter-layer{pointer-events:none}#letter-shelf,.letter-bubble{pointer-events:auto}.game-frame{position:relative;overflow:hidden}.bubble-hunt{z-index:1;width:100%;height:100%;font-family:Quicksand,sans-serif;position:relative}.bubble-hunt .bubble-hunt-slots{z-index:10;justify-content:center;gap:24px;margin-top:40px;display:flex;position:relative;top:10px;left:50%;translate:-50%}.bubble-hunt .bubble-hunt-slot{color:#444;background:#fff;border:4px solid #7fdde9;border-radius:20px;justify-content:center;align-items:center;width:110px;height:110px;font-size:48px;font-weight:700;transition:all .25s;display:flex}.bubble-hunt .bubble-hunt-slot.filled{background:#e8faff;border-color:#4cc9d9}.bubble-hunt .bubble-hunt-slot.glow,.bubble-hunt .bubble-hunt-slot.active{box-shadow:0 0 14px 6px #ffc800cc}.bubble-hunt .speaker-btn{z-index:10;position:absolute;top:5px;right:20px}.bubble-hunt .bubble-grid{z-index:5;touch-action:none;grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(7,1fr);place-items:center;gap:5px;width:92%;height:260px;margin-bottom:50px;margin-left:-46%;display:grid;position:absolute;bottom:20px;left:50%}.bubble-hunt .bubble-grid.disabled{pointer-events:none;opacity:.6}.bubble-hunt .bubble-hunt-bubble{aspect-ratio:1;background:var(--bubble-color);text-transform:lowercase;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none;width:80%;height:80%;animation:gentleFloat var(--float-speed) ease-in-out infinite;touch-action:none;background-image:radial-gradient(circle at 30% 30%,#ffffffb3 0%,#fff0 40%);border-radius:50%;justify-content:center;align-items:center;font-family:Quicksand,sans-serif;font-size:clamp(24px,3vw,48px);font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 6px 10px #00000040,0 0 0 3px #ffffffe6}.bubble-hunt .bubble-hunt-bubble.dragging{animation:none!important;transform:none!important}.bubble-hunt .bubble-hunt-bubble.bubble-used{opacity:.3;pointer-events:none;transform:scale(.8)}.bubble-hunt .bubble-hunt-bubble.bubble-wrong{animation:.25s bubbleShake}.bubble-hunt .bubble-hunt-bubble.correct-pop{animation:.25s ease-out bubblePop}@keyframes gentleFloat{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}@keyframes bubbleShake{0%{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}to{transform:translate(0)}}@keyframes bubblePop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(.9)}}.bubble-hunt .celebration-layer{pointer-events:none;z-index:20;position:absolute;inset:0;overflow:hidden}.bubble-hunt .sparkle{opacity:0;background:radial-gradient(circle,#fff,#ffeaa7);border-radius:50%;width:16px;height:16px;animation:.7s ease-out forwards sparkleBurst;position:absolute}.bubble-hunt .bubble-hunt-slots.word-complete{animation:.6s ease-out slotsCelebrate}@keyframes slotsCelebrate{0%{transform:scale(1)}40%{transform:scale(1.05)}to{transform:scale(1)}}.bubble-hunt-slot.glow{box-shadow:0 0 14px 6px #ffc800cc;animation:.45s ease-out forwards slotGlow!important;transform:scale(1.1)!important}@keyframes slotGlow{0%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}to{opacity:.6;transform:scale(1)}}.bubble-hunt-bubble:hover{transform:scale(1.08);box-shadow:0 0 12px #00000026}.bubble-hunt #letter-layer{z-index:1;position:relative}#picture-container{width:220px;height:220px;margin:0 auto 10px;position:relative}#picture-circle{background:#fff;border-radius:50%;width:100%;height:100%;position:relative;overflow:hidden}.bubble-hunt-speaker{cursor:pointer;background:linear-gradient(#fff,#e6e6e6);border:2px solid #d0d0d0;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;margin:20px auto 0;font-size:32px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 6px 10px #00000026,inset 0 3px 4px #ffffffe6,inset 0 -3px 4px #0000001a}.bubble-hunt-speaker:active{transform:translateY(2px);box-shadow:0 3px 6px #0000001f,inset 0 1px 2px #0003}.bh-end-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:999;background:#ffffffbf;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.bh-end-overlay.hidden{display:none}.bh-end-card{text-align:center;background:#fff;border-radius:24px;padding:32px 40px;font-family:Quicksand,sans-serif;box-shadow:0 6px 16px #0000001f,0 12px 32px #0000001a}#bh-end-restart{background:var(--pastel-mint);color:#2d2d2d;cursor:pointer;border:none;border-radius:16px;margin-top:20px;padding:14px 28px;font-size:24px;font-weight:700;transition:transform .15s;box-shadow:0 4px 10px #00000026}#bh-end-restart:active{transform:scale(.92)}.bh-progress-bar{z-index:10;background:#4cc9d9;border:3px solid #4cc9d9;border-radius:16px;flex-direction:row;justify-content:center;align-items:center;gap:10px;padding:14px 20px;display:flex;position:absolute;bottom:5px;left:50%;transform:translate(-50%);box-shadow:inset 0 4px 6px #fff6,inset 0 -4px 6px #0000001a,0 4px 10px #0000001f}.bh-progress-segment{opacity:1;background:#dcdcdc;border-radius:8px;width:40px;height:14px;transition:background .25s,box-shadow .25s;box-shadow:inset 0 2px 3px #ffffffb3,inset 0 -3px 4px #0000001f,0 2px 4px #0000001a}.bh-progress-segment.done{background:#fc3}.bh-review-banner{color:#4cc9d9;opacity:0;z-index:9999;background:#fff;border-radius:20px;padding:20px 40px;font-size:2rem;font-weight:700;transition:opacity .4s;position:absolute;top:35%;left:50%;transform:translate(-50%);box-shadow:0 6px 20px #00000026}.bh-review-banner.show{opacity:1}.bh-review-banner.hidden{display:none}.legacy-inner,.legacy-adapter{height:100%}#unscramble-cvc-root{-webkit-user-select:none;user-select:none;flex:1;width:100%;height:100%;font-family:Quicksand,sans-serif;position:relative}.game-frame.ucvc-frame{display:flex;position:relative;overflow:hidden}#unscramble-cvc-game #game-screen{width:100%;height:100vh;position:relative;overflow:hidden}.ucvc-frame{padding:0!important}.ucvc-scale-wrapper{width:800px;margin:80px auto 0;position:relative;overflow:visible}.ucvc-pipe-wrapper{z-index:10;justify-content:center;margin-top:80px;display:flex;position:relative}.ucvc-pipe-horizontal{align-items:center;display:flex;position:relative}.ucvc-pipe-cap-left,.ucvc-pipe-cap-right{background:linear-gradient(90deg,#2ecc71,#27ae60);border:4px solid #145a32;border-radius:8px;width:26px;height:70px}.ucvc-pipe-cap-right{background:linear-gradient(90deg,#27ae60,#2ecc71);position:relative}.ucvc-pipe-body{z-index:1;background:linear-gradient(90deg,#27ae60,#1e8449);border:4px solid #145a32;justify-content:center;align-items:center;gap:60px;width:800px;height:60px;display:flex;position:relative;overflow:visible}.ucvc-pipe-body:after{content:"";background:#0000002e;width:100%;height:12px;position:absolute;top:0;right:0;transform:translateY(50%)}.ucvc-pipe-body,.ucvc-pipe-cap-left,.ucvc-pipe-cap-right{z-index:1;position:relative}.ucvc-mount-points{pointer-events:none;z-index:20;justify-content:space-around;width:800px;margin:0 auto;display:flex;position:absolute;top:30px;left:0;right:0;transform:translateY(-40%)}.ucvc-mount-point{opacity:1;filter:none;pointer-events:none;background-position:50%;background-repeat:no-repeat;background-size:contain;width:190px;height:190px;transition:transform .25s,opacity .25s,filter .25s,box-shadow .25s;position:relative}.ucvc-mount-point.locked{animation:.35s ucvc-mountPulse}@keyframes ucvc-mountPulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.ucvc-mount-point.magnetic{filter:brightness(1.2);transform:scale(1.15)}.ucvc-cup-zone{pointer-events:none;z-index:20;width:150px;height:210px;position:fixed;bottom:20px;left:calc(50% + 430px);transform:translate(-50%)}.ucvc-cup-ledge{pointer-events:none;z-index:0;width:320px;position:absolute;bottom:-18px;left:50%;transform:translate(-50%)}.ucvc-cup-wrapper{z-index:2;width:150px;height:200px;position:relative}.ucvc-heavy-cup{filter:drop-shadow(0 12px 18px #0000002e);z-index:3;background:linear-gradient(#ff9ecb59,#4cc9d926);border:3px solid #d8b4fe73;border-radius:22px 22px 70px 70px;width:150px;height:200px;position:absolute;box-shadow:inset 0 0 25px #ffffff80,inset 0 -25px 50px #ffbfa359,inset 0 0 40px #00000014}.ucvc-heavy-cup.ucvc-flash{border-color:#ff7878e6}.ucvc-heavy-cup:before{content:"";background:linear-gradient(#fffc,#fff0);border-radius:22px 22px 0 0;width:100%;height:12px;position:absolute;top:0}.ucvc-heavy-cup:after{content:"";filter:blur(3px);background:linear-gradient(#ffffff40,#ffffff0d);border-radius:20px;width:18px;height:70%;position:absolute;top:30px;left:20px}.ucvc-water-mask{z-index:1;border-radius:22px 22px 70px 70px;width:150px;height:200px;position:absolute;bottom:0;left:4px;right:0;overflow:hidden}.ucvc-water{background:linear-gradient(#1e90ff8c,#1e90ffbf);width:100%;height:0%;transition:height .6s ease-out;position:absolute;bottom:0}.ucvc-water-surface{clip-path:ellipse(90% 40% at 50% 0);transform-origin:bottom;background:linear-gradient(#1e90ff8c,#1e90ffbf);width:100%;height:18px;position:absolute;top:0;left:0}#ucvc-global-water.bob{animation:.6s ease-out ucvc-bob}@keyframes ucvc-bob{0%{transform:translateY(0)}40%{transform:translateY(-3px)}to{transform:translateY(0)}}#ucvc-ripple,#ucvc-ripple-2{opacity:0;transform-origin:bottom;pointer-events:none;z-index:10;background:#ffffff59;border-radius:50%/100%;width:100%;height:24px;position:absolute;bottom:0;left:0;transform:scaleY(.2)}@keyframes ucvc-ripple-expand-1{0%{opacity:1;transform:scaleY(.2)}40%{opacity:.9;transform:scaleY(1)}70%{opacity:.6;transform:scaleY(1.4)}to{opacity:0;transform:scaleY(2)}}@keyframes ucvc-ripple-expand-2{0%{opacity:.9;transform:scaleY(.2)}40%{opacity:.7;transform:scaleY(1.2)}80%{opacity:.4;transform:scaleY(1.8)}to{opacity:0;transform:scaleY(2.4)}}#ucvc-global-water-surface{animation:3s ease-in-out infinite ucvc-wave}@keyframes ucvc-wave{0%{transform:translate(0)}50%{transform:translate(-12px,-3px)}to{transform:translate(0)}}#ucvc-global-water.slosh{animation:.6s ease-out ucvc-slosh}@keyframes ucvc-slosh{0%{transform:rotate(0)}30%{transform:rotate(1.2deg)}60%{transform:rotate(-1deg)}to{transform:rotate(0)}}.ucvc-drip-origin{position:absolute;bottom:-50px;left:100%;transform:translate(-50%)}.ucvc-drop{background:#1e90ff;border-radius:20px;width:20px;height:20px;margin:0 auto;position:relative;transform:translateY(0)}#ucvc-drop{--fall-distance:300px}.ucvc-drop:before{content:"";border-bottom:30px solid #1e90ff;border-left:10px solid #0000;border-right:10px solid #0000;width:0;height:0;position:absolute;top:-22px}@keyframes ucvc-drip{0%{transform:translateY(0)}to{transform:translateY(var(--fall-distance))}}.ucvc-spinner-container{pointer-events:none;z-index:30;flex-direction:column;justify-content:center;align-items:center;width:800px;margin-top:-10px;display:flex;position:absolute;top:0;left:0;transform:translate(-50%)}.ucvc-spinner-row{pointer-events:none;justify-content:center;width:800px;height:80px;margin:0 auto;display:flex;position:relative;left:0;right:0}.ucvc-gear{aspect-ratio:1;filter:drop-shadow(0 6px 8px #00000040);touch-action:none;cursor:grab;-webkit-tap-highlight-color:transparent;-webkit-user-drag:none;user-drag:none;z-index:10;transform-origin:50%;pointer-events:auto;outline:none;justify-content:center;align-items:center;width:180px;display:flex;position:absolute;top:0;left:0}.ucvc-gear:focus{outline:none}.ucvc-gear:before{content:"";z-index:-1;pointer-events:none;border-radius:50%;width:88%;height:88%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 10px 18px #00000047,0 4px 8px #00000038}.ucvc-gear:focus-visible{outline:none}.ucvc-gear.dragging{cursor:grabbing;z-index:30;box-shadow:0 0 22px 10px white (255, 229, 158, .85);border-radius:20%}.ucvc-gear-img{-webkit-tap-highlight-color:transparent;pointer-events:none;user-drag:none;-webkit-user-drag:none;object-fit:contain;outline:none;width:100%;height:100%}.ucvc-gear.locked{cursor:default;transition:transform .25s,box-shadow .25s}.ucvc-letter-bg{opacity:0;text-transform:lowercase;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:60px;font-weight:700;transition:opacity .6s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ucvc-pink-bg{background:#ff9ecb;box-shadow:inset 0 4px 6px #00000038,inset 0 -5px 8px #00000047,0 2px 4px #0000002e}.ucvc-peach-bg{background:#ffbfa3;box-shadow:inset 0 4px 6px #00000038,inset 0 -5px 8px #00000047,0 2px 4px #0000002e}.ucvc-lavender-bg{background:#d8b4fe;box-shadow:inset 0 4px 6px #00000038,inset 0 -5px 8px #00000047,0 2px 4px #0000002e}.ucvc-mint-bg{background:#b8f5c7;box-shadow:inset 0 4px 6px #00000038,inset 0 -5px 8px #00000047,0 2px 4px #0000002e}.ucvc-blue-bg{background:#7fdde9;box-shadow:inset 0 4px 6px #00000038,inset 0 -5px 8px #00000047,0 2px 4px #0000002e}@keyframes ucvc-spin-fast{to{transform:rotate(1turn)}}@keyframes ucvc-spin-slow{to{transform:rotate(1turn)}}@keyframes ucvc-tinyShake{0%{transform:rotate(0)}25%{transform:rotate(-1.2deg)}50%{transform:rotate(1.2deg)}75%{transform:rotate(-.6deg)}to{transform:rotate(0)}}#ucvc-global-water{z-index:9999;pointer-events:none;background:linear-gradient(#1e90ff8c,#1e90ffbf);width:2000px;height:0%;margin:0 auto;position:absolute;bottom:0;left:50%;right:0;overflow:hidden;transform:translate(-50%)}#ucvc-global-water-surface{opacity:0;clip-path:ellipse(90% 40% at 50% 0);z-index:9999;pointer-events:none;background:linear-gradient(#1e90ff8c,#1e90ffbf);height:18px;transition:opacity .4s;position:absolute;top:0;left:0}#ucvc-bubble-layer{pointer-events:none;width:100%;height:100%;position:absolute;bottom:0;left:0;overflow:hidden}.ucvc-bubble{opacity:.8;background:#ffffff80;border-radius:50%;width:12px;height:12px;animation:3s linear forwards ucvc-bubble-rise;position:absolute;bottom:0}@keyframes ucvc-bubble-rise{0%{opacity:.8;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-120px)scale(.6)}}.ucvc-ripple-sparkle{opacity:.9;filter:blur(1px);pointer-events:none;background:#fff;border-radius:50%;width:10px;height:10px;animation:.8s ease-out forwards ucvc-sparkle-pop;position:absolute;bottom:20px}@keyframes ucvc-sparkle-pop{0%{opacity:1;transform:translateY(0)scale(.4)}60%{opacity:.9;transform:translateY(-12px)scale(1.4)}to{opacity:0;transform:translateY(-20px)scale(.8)}}.ucvc-mount-spinner{pointer-events:none;background-image:url(/global/images/ui/gear.svg);background-position:50%;background-repeat:no-repeat;background-size:contain;animation:1s linear infinite ucvc-mount-spin;position:absolute;inset:0}@keyframes ucvc-mount-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ucvc-mount-point.locked .ucvc-mount-spinner{animation:none}.ucvc-mount-core{background:radial-gradient(circle at 30% 30%,#fff 0%,#d9dde4 40%,#a4a9b3 70%,#7b808a 100%);border:3px solid #fffc;border-radius:50%;width:82px;height:82px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 4px #00000059,inset 0 2px 3px #ffffffb3,inset 0 -3px 5px #00000059}.ucvc-mount-core:after{content:"";border:2px solid #fff9;border-radius:50%;position:absolute;inset:18%;box-shadow:inset 0 0 4px #00000059}.ucvc-brick-bg{background-image:url(/global/images/ui/red-brick.png);background-position:50%;background-repeat:repeat;background-size:260px;position:relative;overflow:hidden}.ucvc-brick-bg:before{content:"";pointer-events:none;z-index:0;background:#fff5eb8c;position:absolute;inset:0}.ucvc-brick-bg:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#0000 40%,#00000026 100%);position:absolute;inset:0}.ucvc-mount-point.active-slot{outline-offset:6px;border-radius:12px;outline:4px solid #ffe59e;transition:outline .2s,box-shadow .2s;box-shadow:0 0 12px #ffe59ee6}.ucvc-mount-point.intro-highlight{outline-offset:10px;border-radius:14px;outline:6px solid #ffe59e;transition:outline .2s,box-shadow .2s;box-shadow:0 0 18px #ffe59ee6}.ucvc-chaos-drop{pointer-events:none;background:#fffc;border-radius:50%;width:12px;height:12px;animation:1.2s ease-out forwards chaosBurst;position:absolute;bottom:0}@keyframes chaosBurst{0%{opacity:1;transform:translateY(0)scale(1)}40%{transform:translateY(calc(-1 * var(--burst-height))) scale(.9)}to{opacity:0;transform:translateY(20px)scale(.6)}}.ambient-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;z-index:999999999;pointer-events:auto;isolation:isolate;background:#ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:box-shadow .25s,background .25s;display:flex;position:absolute;top:12px;right:12px}.ambient-toggle .icon{z-index:2;background-image:url(/global/images/ui/music-note.svg);background-repeat:no-repeat;background-size:contain;width:24px;height:24px}.ambient-toggle .slash{opacity:0;z-index:3;background:red;border-radius:2px;width:36px;height:4px;transition:opacity .25s;position:absolute;transform:rotate(-45deg)}.ambient-toggle.on{background:#c8ffc8cc;box-shadow:0 0 12px #0f09}.ambient-toggle.off{background:#ffc8c8cc;box-shadow:0 0 12px #f009}.ambient-toggle.off .slash{opacity:1}#ucvc-replay-btn .icon{background-image:url(/global/images/ui/speaker.svg);background-position:50% 65%;background-repeat:no-repeat;background-size:contain;width:90%;height:90%;margin:auto}#ucvc-replay-btn{background:#add8e6;justify-content:center;align-items:center;margin-top:60px;display:flex;box-shadow:0 0 12px #4169e1}.ucvc-review-banner{color:#4cc9d9;opacity:0;z-index:9999;background:#fff;border-radius:20px;padding:20px 40px;font-size:2rem;font-weight:700;transition:opacity .4s;position:absolute;top:35%;left:50%;transform:translate(-50%);box-shadow:0 6px 20px #00000026}.ucvc-review-banner.show{opacity:1}.ucvc-review-banner.hidden{display:none}.ucvc-replay-overlay{z-index:9999;background:#ffffffb3;justify-content:center;align-items:center;display:none;position:absolute;inset:0}.ucvc-replay-overlay.show{animation:.4s forwards fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ucvc-replay-button{cursor:pointer;flex-direction:column;align-items:center;display:flex}.ucvc-replay-text{color:#4cc9d9;margin-bottom:10px;font-family:Quicksand,sans-serif;font-size:1.6rem;font-weight:600}.ucvc-replay-icon{background:#fff;border:4px solid #4cc9d9;border-radius:50%;width:80px;height:80px;padding-top:15px;animation:1.2s ease-in-out infinite replayPulse;position:relative;box-shadow:0 0 14px #4cc9d999}.ucvc-replay-icon:before{content:"";filter:drop-shadow(0 0 4px #4cc9d9cc);background-image:url(/global/images/ui/replay.svg);background-position:50%;background-repeat:no-repeat;background-size:60%;position:absolute;inset:0}@keyframes replayPulse{0%{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}to{opacity:1;transform:scale(1)}}#ucvc-burst-layer{pointer-events:none;z-index:999999;position:absolute;inset:0;overflow:visible}.ucvc-burst-wrapper{animation:.4s ease-out forwards ucvc-burst-appear;position:absolute;bottom:0;left:0}.ucvc-burst-bubble{opacity:.9;background:#ffffff80;border-radius:50%;width:45px;height:45px;animation:.35s ease-out forwards ucvc-burst-appear,3.5s ease-out forwards ucvc-burst-rise,2.8s ease-in-out infinite ucvc-burst-glow,2.2s ease-in-out infinite ucvc-bubble-shine,3.5s ease-in-out forwards ucvc-burst-drift;position:absolute;bottom:0}@keyframes ucvc-burst-rise{0%{opacity:.9;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-260px)scale(.7)}}.ucvc-burst-bubble:after{content:"";filter:blur(3px);opacity:.8;background:#ffffffe6;border-radius:50%;width:40%;height:40%;animation:2s ease-in-out infinite ucvc-bubble-shine;position:absolute;top:6px;left:6px}@keyframes ucvc-burst-glow{0%{box-shadow:0 0 10px #fff6,0 0 20px #ffffff4d}50%{box-shadow:0 0 22px #ffffffe6,0 0 40px #ffffffb3}to{box-shadow:0 0 10px #fff6,0 0 20px #ffffff4d}}.ucvc-burst-bubble:before{content:"";opacity:0;background:#fff;border-radius:50%;width:100%;height:100%;animation:.45s ease-out forwards ucvc-burst-flash;position:absolute;top:0;left:0}@keyframes ucvc-burst-flash{0%{opacity:1;filter:blur(3px);transform:scale(1.4)}40%{opacity:.6;filter:blur(2px);transform:scale(1)}to{opacity:0;filter:blur(1px);transform:scale(.6)}}@keyframes ucvc-burst-drift{0%{transform:translate(0)}25%{transform:translate(-8px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}to{transform:translate(0)}}@keyframes ucvc-burst-appear{0%{opacity:0;transform:scale(.1)}60%{opacity:.9;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.ucvc-pipe-wrapper,.ucvc-mount-points,.ucvc-spinner-row{width:800px;margin:0 auto}#ambient-toggle-btn,#ucvc-replay-btn{z-index:50;position:absolute;left:auto;right:-70px}#tab-games.first-grade-dashboard{box-sizing:border-box;margin:0;padding:24px 20px;font-family:Quicksand,sans-serif;display:block}#tab-games.first-grade-dashboard #student-dashboard-grid{box-sizing:border-box;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));justify-content:start;place-items:start;gap:28px;width:100%;display:grid}@media (width<=1100px){#tab-games.first-grade-dashboard #student-dashboard-grid{grid-template-columns:repeat(2,minmax(260px,1fr));grid-auto-flow:row}}@media (width<=700px){#tab-games.first-grade-dashboard #student-dashboard-grid{grid-template-columns:1fr;grid-auto-flow:row}}#tab-games.first-grade-dashboard .game-list{flex-direction:column;gap:12px;display:flex}.dashboard-header{margin-bottom:20px;font-size:28px;font-weight:700}.sticker-picker{background:#fff;border-radius:20px 20px 0 0;height:300px;transition:transform .3s;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -4px 12px #0000001a}.sticker-picker.open{transform:translateY(0)}
