:root{--bg-primary: hsl(35, 100%, 96%);--bg-secondary: hsl(35, 100%, 91%);--glass-bg: rgba(255, 253, 246, .94);--glass-border: rgba(139, 90, 43, .2);--accent-cyan: hsl(38, 100%, 55%);--accent-cyan-glow: rgba(255, 152, 0, .25);--accent-pink: hsl(355, 100%, 65%);--accent-pink-glow: rgba(255, 107, 107, .25);--text-primary: #3d271d;--text-secondary: #7a584a;--text-muted: #a08477;--destructive: #e53935;--font-display: "Fredoka", "Nunito", system-ui, sans-serif;--font-body: "Nunito", system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}button,.ui-element,.mode-option-card,.training-node-card,.map-node-circle,.icon-toggle{touch-action:manipulation}body,html{width:100%;height:100%;overflow:hidden;position:fixed;background-color:#040509;font-family:var(--font-body);color:var(--text-primary);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}body:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(white,rgba(255,255,255,.2) 2px,transparent 40px),radial-gradient(white,rgba(255,255,255,.15) 1px,transparent 30px),radial-gradient(white,rgba(255,255,255,.1) 2px,transparent 40px);background-size:550px 550px,350px 350px,250px 250px;background-position:0 0,40px 60px,130px 270px;opacity:.15;z-index:0;pointer-events:none}#app-container{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden;background-color:var(--bg-primary);z-index:1;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}#app-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(white,rgba(255,255,255,.2) 2px,transparent 40px),radial-gradient(white,rgba(255,255,255,.15) 1px,transparent 30px),radial-gradient(white,rgba(255,255,255,.1) 2px,transparent 40px);background-size:550px 550px,350px 350px,250px 250px;background-position:0 0,40px 60px,130px 270px;opacity:.12;z-index:0;pointer-events:none}#game-container{width:100%;height:100%;position:absolute;top:0;left:0;z-index:1;touch-action:none;-webkit-tap-highlight-color:transparent}canvas,#game-container canvas{touch-action:none!important;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}#ui-container{width:100%;height:100%;position:absolute;top:0;left:0;z-index:10;pointer-events:none}.ui-element{pointer-events:auto}.glass-card{background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:2px solid var(--glass-border);border-bottom:8px solid #a05c30;border-radius:20px;box-shadow:0 12px #00000040,0 20px 30px #00000059,inset 0 2px #ffffff1a,inset 0 -2px #0003;padding:30px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;transition:transform .15s cubic-bezier(.175,.885,.32,1.275),box-shadow .15s ease,border-color .15s ease}.glass-card:hover{transform:translateY(-2px);border-color:#fdf6e24d;box-shadow:0 14px #00000040,0 24px 35px #0006,inset 0 2px #ffffff1a,inset 0 -2px #0003}.glass-card:active{transform:translateY(4px);border-bottom-width:4px;box-shadow:0 4px #00000040,0 8px 15px #0000004d,inset 0 2px #ffffff1a,inset 0 -2px #0003}.neon-text-cyan{font-family:var(--font-display);color:var(--accent-cyan);text-shadow:1px 1px 0px rgba(0,0,0,.15)}.neon-text-pink{font-family:var(--font-display);color:var(--accent-pink);text-shadow:1px 1px 0px rgba(0,0,0,.15)}.btn-neon{font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:2px;color:#2c1e1b;background:#ffb347;border:none;border-radius:20px;padding:16px 32px;min-height:52px;cursor:pointer;position:relative;outline:none;box-shadow:0 4px #d35400,0 6px 15px #00000059;transition:transform .08s ease,box-shadow .08s ease}.btn-neon:hover{background:#ffa326;transform:translateY(1px);box-shadow:0 3px #d35400,0 4px 10px #00000059}.btn-neon:active{transform:translateY(3px) scale(.97);box-shadow:0 1px #d35400,0 2px 5px #00000059;background:#e89b30}.btn-secondary{font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--text-secondary);background:#2c1e1bf2;border:2px solid var(--glass-border);border-bottom:5px solid #1c1210;border-radius:16px;padding:12px 28px 14px;min-height:48px;cursor:pointer;transition:transform .1s cubic-bezier(.175,.885,.32,1.275),box-shadow .1s ease,border-color .1s ease;outline:none;box-shadow:0 4px #0003,0 6px 12px #00000040}.btn-secondary:hover{background:#fdf6e214;border-color:#fdf6e24d;color:var(--text-primary);transform:translateY(-2px);box-shadow:0 6px #0003,0 8px 16px #0000004d}.btn-secondary:active{transform:translateY(3px);border-bottom-width:2px;box-shadow:0 1px #0003,0 2px 4px #0003}.icon-toggle{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#2c1e1bf2;border:2px solid var(--glass-border);border-bottom:5px solid #1c1210;cursor:pointer;color:var(--text-secondary);transition:transform .1s cubic-bezier(.175,.885,.32,1.275),box-shadow .1s ease,border-color .1s ease;outline:none;box-shadow:0 4px #0003,0 6px 12px #00000040}.icon-toggle:hover{background:#fdf6e214;border-color:var(--accent-cyan);color:var(--accent-cyan);transform:translateY(-2px);box-shadow:0 6px #0003,0 8px 16px #0000004d}.icon-toggle:active{transform:translateY(3px);border-bottom-width:2px;box-shadow:0 1px #0003,0 2px 4px #0003}.icon-toggle.active{background:var(--accent-cyan);color:var(--bg-primary);border-color:var(--accent-cyan);transform:scale(1.05)}.menu-overlay-wrapper{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at center,#fff5e466,#ffd6a5d9);padding:20px}.menu-card{width:100%;max-width:420px;min-height:480px;text-align:center}.game-title-container{margin-bottom:40px}.game-logo-container{position:relative;width:80px;height:80px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}.game-logo-glow{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,var(--accent-cyan) 0%,rgba(255,179,71,0) 70%);filter:blur(12px);animation:logo-pulsate 3s ease-in-out infinite alternate;z-index:1}.game-logo-icon{position:relative;z-index:2;width:76px;height:76px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 4px 6px rgba(0,0,0,.3))}@keyframes logo-pulsate{0%{transform:scale(.9);opacity:.7}to{transform:scale(1.1);opacity:1}}.game-title{font-family:var(--font-display);font-size:38px;font-weight:900;letter-spacing:4px;line-height:1.1;text-transform:uppercase;margin-bottom:8px}.game-subtitle{font-size:14px;letter-spacing:5px;color:var(--text-muted);text-transform:uppercase;font-weight:600}.menu-button-group{display:flex;flex-direction:column;gap:16px;width:100%;margin-bottom:35px}.menu-footer{display:flex;justify-content:space-between;align-items:center;width:100%}.volume-container{display:flex;align-items:center;gap:12px}.footer-text{font-size:12px;color:var(--text-muted);letter-spacing:1px}.pilot-badge{position:absolute;top:20px;left:20px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:8px;padding:6px 12px;font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text-secondary);box-shadow:0 4px 15px #00000040;pointer-events:auto;max-width:45%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pilot-badge-value{color:var(--accent-cyan)}.connection-pill{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:6px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid var(--glass-border);border-radius:12px;padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:1.5px;box-shadow:0 4px 15px #00000040;pointer-events:auto;transition:all .3s ease}.play-hud-container .connection-pill{position:static;top:auto;right:auto}.connection-pill-dot{width:8px;height:8px;border-radius:50%;transition:all .3s ease}.connection-pill.online{color:var(--accent-cyan);border-color:#ffb3474d}.connection-pill.online .connection-pill-dot{background-color:var(--accent-cyan);animation:dot-pulse-cyan 1.5s infinite alternate}.connection-pill.offline{color:var(--accent-pink);border-color:#ff8b944d}.connection-pill.offline .connection-pill-dot{background-color:var(--accent-pink);animation:dot-pulse-pink 1.5s infinite alternate}@keyframes dot-pulse-cyan{0%{opacity:.6;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}@keyframes dot-pulse-pink{0%{opacity:.6;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}.pilot-badge.interactive{display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .25s ease;-webkit-user-select:none;user-select:none}.pilot-badge.interactive:hover{transform:scale(1.02);border-color:var(--accent-cyan);box-shadow:0 4px 20px #00000059}.avatar-container{position:relative;width:32px;height:32px;border-radius:50%;overflow:hidden;border:1px solid var(--glass-border);background:#0000004d;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pilot-avatar-img{width:100%;height:100%;object-fit:cover}.avatar-upload-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0b0d19b3;display:flex;align-items:center;justify-content:center;color:var(--accent-cyan);opacity:0;transition:opacity .2s ease}.pilot-badge.interactive:hover .avatar-upload-overlay{opacity:1}.avatar-spinner{position:absolute;width:20px;height:20px;border:2px solid rgba(255,179,71,.2);border-top:2px solid var(--accent-cyan);border-radius:50%;animation:spinner-spin .8s linear infinite;box-sizing:border-box}@keyframes spinner-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pilot-badge-text{display:flex;flex-direction:column;gap:2px}.pilot-label{font-size:8px;letter-spacing:1px;color:var(--text-muted)}.connection-pill.online-presence{border-color:#ffb34766}.leaderboard-modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff5e4a6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease,visibility .3s ease;padding:20px;box-sizing:border-box}.leaderboard-modal-overlay.active{opacity:1;visibility:visible;pointer-events:auto}.leaderboard-card{width:100%;max-width:440px;padding:30px;display:flex;flex-direction:column;box-shadow:0 10px 30px #00000080;transform:translateY(20px);transition:transform .3s cubic-bezier(.16,1,.3,1);box-sizing:border-box}.leaderboard-modal-overlay.active .leaderboard-card{transform:translateY(0)}.leaderboard-header{text-align:center;margin-bottom:25px}.leaderboard-title{font-family:var(--font-display);font-size:24px;font-weight:900;letter-spacing:3px;text-transform:uppercase;margin-bottom:6px}.leaderboard-subtitle{font-size:11px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;font-weight:600}.leaderboard-table-container{max-height:280px;overflow-y:auto;border:1px solid var(--glass-border);border-radius:8px;background:#0003;-webkit-overflow-scrolling:touch}.leaderboard-table-container::-webkit-scrollbar{width:6px}.leaderboard-table-container::-webkit-scrollbar-track{background:transparent}.leaderboard-table-container::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.leaderboard-table-container::-webkit-scrollbar-thumb:hover{background:#ffffff26}.leaderboard-table{width:100%;border-collapse:collapse;font-size:13px;font-weight:600}.leaderboard-table th{position:sticky;top:0;background:#121426f2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;padding:12px 16px;font-size:10px;letter-spacing:2px;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--glass-border)}.leaderboard-table td{padding:12px 16px;vertical-align:middle;border-bottom:1px solid rgba(255,255,255,.03)}.leaderboard-table tr:last-child td{border-bottom:none}.leaderboard-table tr:nth-child(2n){background:#ffffff04}.leaderboard-row.current-user{background:#ffb3470f!important;border:1px dashed rgba(255,179,71,.4)}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:11px;font-weight:900;background:#ffffff0d;color:var(--text-secondary)}.rank-badge.gold{background:radial-gradient(circle,gold,#b8860b);color:#0b0d19;box-shadow:0 0 10px #ffd70066}.rank-badge.silver{background:radial-gradient(circle,#e0e0e0,#9e9e9e);color:#0b0d19;box-shadow:0 0 10px #e0e0e04d}.rank-badge.bronze{background:radial-gradient(circle,#cd7f32,#8b4513);color:#0b0d19;box-shadow:0 0 10px #cd7f324d}.pilot-row-info{display:flex;align-items:center;gap:10px}.row-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid var(--glass-border);background:#ffffff0d}.pause-modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0b0d1999;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease,visibility .25s ease;padding:20px;box-sizing:border-box}.pause-modal-overlay.active{opacity:1;visibility:visible;pointer-events:auto}.mode-option-card{position:relative;overflow:hidden;min-height:72px;background:#2c1e1be6!important;border:2px solid var(--glass-border)!important;border-bottom:6px solid #1c1210!important;border-radius:16px!important;box-shadow:0 6px #0003,0 12px 20px #0000004d,inset 0 1px #ffffff14,inset 0 -1px #00000026;transition:transform .15s cubic-bezier(.175,.885,.32,1.275),box-shadow .15s ease,border-color .15s ease!important}.mode-option-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#ffb3470d,#ffb34700);opacity:0;transition:opacity .3s ease}.mode-option-card:hover{transform:translateY(-2px);border-color:var(--accent-cyan)!important;box-shadow:0 8px #0003,0 16px 24px #00000059,inset 0 1px #ffffff14,inset 0 -1px #00000026}.mode-option-card:active{transform:translateY(4px)!important;border-bottom-width:2px!important;box-shadow:0 2px #0003,0 4px 8px #00000040,inset 0 1px #ffffff14,inset 0 -1px #00000026!important;background:#241815f2!important}.mode-option-card:hover:before{opacity:1}.jigsaw-shelf-backdrop{position:absolute;bottom:270px;left:60px;width:600px;height:280px;background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:24px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:5;pointer-events:none;box-shadow:0 4px 15px #00000059}.play-hud-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:20px;padding-bottom:max(96px,env(safe-area-inset-bottom,96px));box-sizing:border-box;gap:12px}.hud-top-bar{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:620px}.hud-level-bar{margin-top:12px;display:flex;justify-content:flex-start;align-items:center;width:100%;max-width:620px}.hud-bottom-bar{margin-top:12px;display:flex;justify-content:space-between;align-items:center;width:100%;max-width:620px}.hud-item{display:flex;flex-direction:column;gap:4px}.hud-label{font-size:11px;letter-spacing:2px;color:var(--text-muted);font-weight:700;text-transform:uppercase}.hud-value{font-size:24px;font-weight:900;color:var(--text-primary);font-family:var(--font-display)}.pilot-card{align-items:flex-start}.pilot-card .hud-value{font-size:16px}.time-card{align-items:flex-end;min-width:100px}.score-card{align-items:flex-start}.progress-card{align-items:flex-end}.hud-bottom-panel{display:flex;flex-direction:column;gap:12px;background:var(--glass-bg);border:2px solid var(--glass-border);border-bottom:5px solid #8b5a2b;border-radius:20px;padding:16px 20px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 8px 32px #00000040;width:100%;max-width:620px;box-sizing:border-box;pointer-events:auto}.tilematch-tray-panel{position:absolute;bottom:80px;left:60px;width:600px;height:110px;background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:24px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:5;display:flex;align-items:center;justify-content:flex-start;padding:0 16px;gap:8px;box-shadow:0 4px 15px #00000059;pointer-events:none}.tilematch-tray-slot{width:74px;height:74px;border-radius:10px;background:#ffffff05;border:1px dashed rgba(255,255,255,.08);box-sizing:border-box}.mathlogic-hud-wrapper{justify-content:flex-start;padding:40px 50px 20px;height:calc(100% - 96px);overflow-y:auto;pointer-events:auto!important;box-sizing:border-box}.mathlogic-hud-wrapper::-webkit-scrollbar{width:8px}.mathlogic-hud-wrapper::-webkit-scrollbar-track{background:transparent}.mathlogic-hud-wrapper::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:4px}.mathlogic-hud-wrapper::-webkit-scrollbar-thumb:hover{background:#8b5a2b66}.glass-select{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:8px;color:var(--text-primary);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:1.5px;padding:8px 16px;outline:none;cursor:pointer;box-shadow:0 4px 15px #00000040;max-width:320px;text-transform:uppercase}.glass-select:focus{border-color:var(--accent-cyan);box-shadow:0 4px 15px #00000040}.glass-select option{background:var(--bg-secondary);color:var(--text-primary)}.mathlogic-main-grid{display:flex;flex-direction:column;gap:20px;width:100%;max-width:620px;margin-top:15px;flex:1}.equations-card{width:100%;flex:1.3;padding:24px;align-items:stretch;justify-content:flex-start;min-height:380px}.mathlogic-right-column{display:flex;flex-direction:column;gap:20px;flex:1.7}.digits-card{width:100%;padding:20px;align-items:stretch;justify-content:flex-start}.assignments-card{width:100%;padding:24px;align-items:stretch;justify-content:flex-start}.card-header{border-bottom:1px solid var(--glass-border);padding-bottom:10px;margin-bottom:15px;width:100%}.card-title{font-size:22px;font-weight:900;letter-spacing:2px;text-transform:uppercase}.equations-list-container{display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1;padding-right:4px;-webkit-overflow-scrolling:touch}.equations-list-container::-webkit-scrollbar{width:6px}.equations-list-container::-webkit-scrollbar-track{background:transparent}.equations-list-container::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.equation-row{display:flex;align-items:center;gap:12px;background:#ffffff04;border:1px solid var(--glass-border);border-radius:10px;padding:10px 14px;transition:all .3s ease}.equation-row.satisfied{border-color:#39ff1466;background:#39ff140a;box-shadow:0 0 10px #39ff141a}.equation-row.failed{border-color:#ff073a66;background:#ff073a0a;box-shadow:0 0 10px #ff073a1a}.equation-text{font-size:17px;font-weight:700;letter-spacing:.5px;color:var(--text-secondary);display:flex;align-items:center;flex-wrap:wrap;gap:8px}.equation-sym-badge{display:inline-flex;align-items:center;gap:6px;border:2px solid;border-radius:8px;padding:4px 10px;font-size:14px;font-weight:800;background:#0003}.eq-status-indicator{font-size:20px;font-weight:900;flex-shrink:0}.eq-status-indicator.satisfied-tick{color:#39ff14;text-shadow:0 0 6px rgba(57,255,20,.8)}.eq-status-indicator.failed-cross{color:#ff073a;text-shadow:0 0 6px rgba(255,7,58,.8)}.digits-deck-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:8px;width:100%}.digit-badge{aspect-ratio:1;border-radius:50%;background:#ffffff08;border:1px solid var(--glass-border);color:var(--text-secondary);font-family:var(--font-display);font-size:20px;font-weight:900;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0003;outline:none;padding:0}.digit-badge:hover{border-color:var(--accent-cyan);color:var(--accent-cyan);transform:scale(1.1)}.digit-badge.active{background:var(--accent-cyan);color:var(--bg-primary);border-color:var(--accent-cyan);transform:scale(1.05)}.digit-badge.assigned{opacity:.3;pointer-events:none}.assignments-list-container{display:flex;flex-direction:column;gap:10px;width:100%}.assignment-row{display:flex;align-items:center;justify-content:space-between;width:100%;background:#ffffff03;border:1px solid var(--glass-border);border-radius:12px;padding:12px 20px;transition:all .25s ease}.assignment-symbol-info{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:800;letter-spacing:1px;text-transform:uppercase}.assignment-symbol-emoji{font-size:22px}.assignment-divider{color:var(--text-muted);font-family:var(--font-display);font-weight:900;font-size:18px}.assignment-slot{width:48px;height:48px;border-radius:50%;background:#0000004d;border:2px dashed var(--glass-border);color:var(--text-muted);font-family:var(--font-display);font-weight:900;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;box-sizing:border-box}.assignment-slot.filled{color:var(--text-primary);border-style:solid;font-size:20px;background:#ffffff08}.assignment-slot:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.verify-feedback-msg{width:100%;font-size:10px;font-weight:700;letter-spacing:1.5px;text-align:center;padding:8px 12px;border-radius:8px;margin-bottom:12px;box-sizing:border-box;text-transform:uppercase;animation:fade-in-up .3s ease}.verify-feedback-msg.warning{background:#fdec6e14;border:1px solid rgba(253,236,110,.4);color:#fdec6e}.verify-feedback-msg.error{background:#ff073a14;border:1px solid rgba(255,7,58,.4);color:#ff073a}@keyframes fade-in-up{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.shake-element{animation:shake .35s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.scenario-map-card{width:100%;max-width:580px;padding:30px;display:flex;flex-direction:column;box-shadow:0 10px 30px #00000080;transform:translateY(20px);transition:transform .3s cubic-bezier(.16,1,.3,1);box-sizing:border-box}.leaderboard-modal-overlay.active .scenario-map-card{transform:translateY(0)}.scenario-map-scroll{flex:1;min-height:0;overflow-y:auto;padding-right:8px;margin-top:10px;-webkit-overflow-scrolling:touch}.scenario-map-scroll::-webkit-scrollbar{width:6px}.scenario-map-scroll::-webkit-scrollbar-track{background:#ffffff05;border-radius:3px}.scenario-map-scroll::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.map-section-title{font-family:var(--font-display);font-size:14px;color:var(--accent-cyan);letter-spacing:1.5px;text-transform:uppercase;margin:15px 0 10px;text-align:left;border-left:3px solid var(--accent-cyan);padding-left:8px}.training-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.training-node-card{background:#ffffff05;border:1px solid var(--glass-border);border-radius:12px;padding:12px;text-align:center;cursor:pointer;transition:all .25s ease;display:flex;flex-direction:column;align-items:center;gap:6px;box-sizing:border-box}.training-node-card:hover{background:#fdf6e214;border-color:var(--accent-cyan);transform:translateY(-2px)}.training-node-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fdf6e20d;border-radius:8px}.training-node-title{font-size:11px;font-weight:800;font-family:var(--font-display);text-transform:uppercase;color:var(--text-primary);letter-spacing:.5px}.campaign-trail{display:flex;flex-wrap:wrap;justify-content:center;gap:18px 24px;padding:20px 10px;background:#00000026;border-radius:16px;border:1px dashed var(--glass-border);position:relative}.map-node-wrapper{display:flex;flex-direction:column;align-items:center;width:75px;position:relative}.map-node-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;font-weight:900;cursor:pointer;transition:all .25s cubic-bezier(.175,.885,.32,1.275);position:relative;box-sizing:border-box}.map-node-circle.node-locked{background:#3c2f2c;border:3px solid #5a4541;color:#7a625e;cursor:not-allowed}.map-node-circle.node-unlocked{background:#ffb347;border:3px solid #8b5a2b;color:#2c1e1b;box-shadow:0 4px #d35400}.map-node-circle.node-unlocked:hover{transform:scale(1.1);box-shadow:0 6px #d35400}.map-node-circle.node-unlocked:active{transform:translateY(2px);box-shadow:0 2px #d35400}.map-node-circle.node-active{background:#ffb347;border:3px solid #fdf6e2;color:#2c1e1b;box-shadow:0 4px #d35400,0 0 12px #ffb34799;animation:node-pulse 1.8s infinite ease-in-out}@keyframes node-pulse{0%{box-shadow:0 4px #d35400,0 0 #ffb34766}50%{box-shadow:0 4px #d35400,0 0 15px #ffb347cc}to{box-shadow:0 4px #d35400,0 0 #ffb34766}}.map-node-circle.node-completed{background:#a8e6cf;border:3px solid #8b5a2b;color:#2c1e1b;box-shadow:0 4px #57bfa1}.map-node-circle.node-completed:hover{transform:scale(1.1);box-shadow:0 6px #57bfa1}.map-node-circle.node-completed:active{transform:translateY(2px);box-shadow:0 2px #57bfa1}.map-node-label{font-size:10px;color:var(--text-muted);font-weight:700;text-align:center;margin-top:6px;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.map-node-wrapper:hover .map-node-label{color:var(--text-primary)}.hideseek-target-bar{display:flex;flex-direction:column;align-items:flex-start;gap:10px;background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:20px;padding:16px 20px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 8px 32px #00000059;width:100%;max-width:620px;box-sizing:border-box;pointer-events:auto}.hideseek-target-title{font-family:var(--font-display);font-size:12px;font-weight:900;letter-spacing:1.5px;color:var(--accent-cyan);text-transform:uppercase;white-space:nowrap}.hideseek-target-list{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;width:100%}.hideseek-target-card{display:flex;align-items:center;justify-content:center;gap:6px;background:#ffffff08;border:1px solid var(--glass-border);border-radius:10px;padding:8px 10px;min-height:44px;font-size:11px;font-weight:700;color:var(--text-secondary);transition:all .25s ease;min-width:0}.hideseek-target-card .item-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:75px}.hideseek-target-card.found{opacity:.3;border-color:#a8e6cf4d;text-decoration:line-through}.hideseek-target-card .checkmark{color:#a8e6cf;font-weight:900;display:none}.hideseek-target-card.found .checkmark{display:inline}.btn-back-safe{position:fixed;bottom:max(28px,env(safe-area-inset-bottom,28px));left:24px;border-radius:50%;width:52px;height:52px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--glass-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:2px solid var(--glass-border);color:var(--text-secondary);pointer-events:auto;cursor:pointer;transition:all .12s ease;outline:none;z-index:20}.btn-back-safe:active{transform:scale(.9);background:#fdf6e226}.btn-abandon-safe{position:absolute;bottom:max(28px,env(safe-area-inset-bottom,28px));left:50%;transform:translate(-50%);letter-spacing:2px;font-family:var(--font-display);font-size:13px;font-weight:700;min-height:48px;padding:14px 28px;background:#7a584af2;border:2px solid var(--glass-border);border-bottom:4px solid #5a3c31;color:#fdf6e2;box-shadow:0 4px 10px #0003;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:14px;pointer-events:auto}.btn-abandon-safe:active{transform:translate(-50%) scale(.95)}.training-node-card:active{transform:scale(.95);background:#fdf6e21f;border-color:var(--accent-cyan)}.map-node-circle.node-unlocked:active,.map-node-circle.node-active:active,.map-node-circle.node-completed:active{transform:scale(.9)}@media (max-width: 480px),(max-height: 920px){.mathlogic-hud-wrapper{padding:24px 16px 20px!important;overflow-y:auto!important;pointer-events:auto!important;height:calc(100% - 96px)!important;max-height:calc(100vh - 96px)!important;box-sizing:border-box}.mathlogic-main-grid{gap:12px;margin-top:8px;flex:none}.equations-card{min-height:auto!important;padding:16px!important}.equations-list-container{max-height:160px}.digits-card{padding:14px!important}.digits-deck-grid{gap:6px}.assignments-card{padding:16px!important}.assignments-list-container{gap:8px}.assignment-row{padding:8px 12px!important}.assignment-slot{width:40px!important;height:40px!important;font-size:16px!important}.equation-text{font-size:14px!important}.equation-sym-badge{font-size:12px!important;padding:3px 6px!important}.assignment-symbol-info{font-size:14px!important}.assignment-symbol-emoji{font-size:18px!important}.digit-badge{font-size:16px!important}.verify-action-bar{margin-top:12px!important;margin-bottom:24px!important}.verify-action-bar .btn-neon{height:48px!important;font-size:15px!important}}.bottom-nav-bar{position:absolute;bottom:0;left:0;width:100%;height:calc(76px + env(safe-area-inset-bottom,0px));background:#231714;border-top:3px solid #8b5a2b;border-radius:24px 24px 0 0;display:flex;justify-content:space-around;align-items:center;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -8px 24px #0006;z-index:100;pointer-events:auto;box-sizing:border-box}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:100%;color:#a08477;cursor:pointer;transition:all .25s cubic-bezier(.175,.885,.32,1.275);gap:3px;font-family:var(--font-body);font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;position:relative}.nav-item svg{width:22px;height:22px;stroke:#a08477;stroke-width:2.2;fill:none;transition:transform .25s cubic-bezier(.175,.885,.32,1.275),stroke .25s ease}.nav-item:hover{color:#fdf6e2}.nav-item:hover svg{stroke:#fdf6e2;transform:translateY(-2px)}.nav-item.active{color:var(--accent-cyan)}.nav-item.active svg{stroke:var(--accent-cyan);transform:scale(1.1) translateY(-2px)}.nav-item.active:after{content:"";position:absolute;bottom:6px;width:5px;height:5px;border-radius:50%;background-color:var(--accent-cyan);box-shadow:0 0 6px var(--accent-cyan)}.nav-fab-center{position:relative;top:-24px;width:68px;height:68px;background:var(--accent-cyan);border:3px solid #fdf6e2;border-bottom:6px solid #d35400;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#2c1e1b;box-shadow:0 8px 20px #00000073;cursor:pointer;transition:all .2s cubic-bezier(.175,.885,.32,1.275);z-index:110;flex-shrink:0}.nav-fab-center svg{width:28px;height:28px;stroke:#2c1e1b;stroke-width:2.8;fill:none;transition:transform .25s cubic-bezier(.175,.885,.32,1.275)}.nav-fab-center:hover{transform:translateY(-28px) scale(1.06);background:#ffa326;box-shadow:0 10px 24px #00000080}.nav-fab-center:active{transform:translateY(-18px) scale(.94);border-bottom-width:2px;box-shadow:0 4px 8px #0000004d}.nav-fab-center.active{background:#ff8b94;border-bottom-color:#d1565e}.nav-fab-center.active svg{stroke:#2c1e1b}.menu-tab-container{width:100%;height:calc(100% - 76px - env(safe-area-inset-bottom,0px));position:absolute;top:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;overflow:hidden;box-sizing:border-box;pointer-events:auto}.menu-tab-content{display:none;width:100%;flex-direction:column;align-items:center;justify-content:center;opacity:0;transform:scale(.96);transition:opacity .2s ease,transform .25s cubic-bezier(.16,1,.3,1);box-sizing:border-box}.menu-tab-content.active{display:flex;opacity:1;transform:scale(1);flex:1;min-height:0}.tab-card{width:100%;height:100%;background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:2px solid var(--glass-border);border-bottom:8px solid #a05c30;border-radius:24px;box-shadow:0 8px #00000026,0 15px 25px #00000040;padding:24px;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;pointer-events:auto}.tab-card-header{text-align:center;margin-bottom:16px;flex-shrink:0;border-bottom:2px solid var(--glass-border);padding-bottom:12px;width:100%}.tab-card-body{flex:1;overflow-y:auto;padding-right:4px;width:100%;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.tab-card-body::-webkit-scrollbar{width:6px}.tab-card-body::-webkit-scrollbar-track{background:transparent}.tab-card-body::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.home-welcome-badge{display:flex;align-items:center;gap:16px;background:#2c1e1b0a;border:2px dashed var(--glass-border);border-radius:16px;padding:16px;width:100%;margin-top:16px;box-sizing:border-box}.home-welcome-badge .avatar-container{width:48px;height:48px;border:2px solid var(--glass-border)}.home-welcome-text{display:flex;flex-direction:column;gap:4px;text-align:left}.home-welcome-title{font-size:11px;font-weight:800;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase}.home-welcome-name{font-family:var(--font-display);font-size:18px;color:var(--text-primary)}.home-quick-actions{display:flex;width:100%;gap:12px;margin-top:20px}.home-quick-card{flex:1;background:#fff6;border:2px solid var(--glass-border);border-radius:16px;padding:12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.home-quick-val{font-family:var(--font-display);font-size:20px;color:var(--accent-cyan)}.home-quick-lbl{font-size:10px;color:var(--text-secondary);font-weight:700;text-transform:uppercase}.profile-edit-container{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;margin-top:12px}.profile-avatar-large{position:relative;width:100px;height:100px;border-radius:50%;overflow:hidden;border:4px solid var(--glass-border);background:#0003;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #00000026}.profile-avatar-large:hover{transform:scale(1.05);border-color:var(--accent-cyan)}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-name-input-wrapper{display:flex;flex-direction:column;gap:6px;width:100%;max-width:320px}.profile-input-label{font-size:10px;font-weight:800;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;text-align:left}.profile-name-input{background:#ffffff80;border:2px solid var(--glass-border);border-radius:12px;padding:10px 14px;color:var(--text-primary);font-family:var(--font-body);font-size:14px;font-weight:700;outline:none;transition:all .2s ease;text-align:center}.profile-name-input:focus{border-color:var(--accent-cyan);background:#fdf6e2}.profile-save-status{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;height:14px;margin-top:-6px}.mode-option-card-inline{width:100%;margin-bottom:12px}.tab-card .campaign-trail{flex-wrap:wrap;overflow-y:auto}@media (max-height: 800px){.menu-tab-container{padding:10px}.tab-card{padding:16px}.tab-card-header{margin-bottom:12px;padding-bottom:8px}.game-title-container{margin-bottom:20px}.game-title{font-size:30px}}.btn-google{display:flex;align-items:center;justify-content:center;gap:12px;background:#fffffff2;border:2px solid var(--glass-border);border-bottom:5px solid #bdc3c7;border-radius:14px;padding:12px 20px;color:#2c1e1b;font-family:var(--font-body);font-size:14px;font-weight:800;cursor:pointer;transition:all .2s cubic-bezier(.175,.885,.32,1.275);width:100%;max-width:320px;box-shadow:0 6px 15px #00000026;text-transform:uppercase;letter-spacing:.5px;box-sizing:border-box}.btn-google:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #0003}.btn-google:active{transform:translateY(2px);border-bottom-width:2px;box-shadow:0 3px 6px #0000001a}.google-icon{width:20px;height:20px;display:block}.btn-logout{display:flex;align-items:center;justify-content:center;gap:12px;background:#ff8b9426;border:2px solid rgba(255,139,148,.3);border-bottom:5px solid #d1565e;border-radius:14px;padding:12px 20px;color:#ff8b94;font-family:var(--font-body);font-size:13px;font-weight:800;cursor:pointer;transition:all .2s cubic-bezier(.175,.885,.32,1.275);width:100%;max-width:320px;text-transform:uppercase;letter-spacing:.5px;box-sizing:border-box}.btn-logout:hover{background:#ff8b9440;border-color:#ff8b9480;color:#fff;transform:translateY(-2px)}.btn-logout:active{transform:translateY(2px);border-bottom-width:2px}
