*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: var(--tg-theme-bg-color, #0f0f23);--bg-card: var(--tg-theme-secondary-bg-color, #1a1a35);--text: var(--tg-theme-text-color, #e8e8f0);--text-dim: var(--tg-theme-subtitle-text-color, #8888aa);--accent: var(--tg-theme-button-color, #7c6fff);--accent-text: var(--tg-theme-button-text-color, #fff);--success: #34d399;--error: #f87171;--warning: #fbbf24}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overflow-x:hidden;overscroll-behavior:none}.layout{min-height:100%;display:flex;flex-direction:column}.layout-content{flex:1}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #7c6fff80}50%{transform:scale(1.08);box-shadow:0 0 0 10px #7c6fff00}}@keyframes spin{to{transform:rotate(360deg)}}.feedback-trigger{background:none;border:none;color:var(--text-dim);font-size:13px;cursor:pointer;padding:8px 0;font-family:inherit}.feedback-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.feedback-card{background:var(--bg-card);border-radius:20px;padding:24px;width:100%;max-width:360px}.feedback-card h3{font-size:18px;margin-bottom:16px}.feedback-types{display:flex;gap:8px;margin-bottom:12px}.feedback-type-btn{flex:1;padding:8px;background:#ffffff0f;border:2px solid transparent;border-radius:10px;color:var(--text-dim);font-size:12px;cursor:pointer;font-family:inherit}.feedback-type-btn.active{border-color:var(--accent);color:var(--text)}.feedback-textarea{width:100%;padding:12px;background:#ffffff0f;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:var(--text);font-size:14px;resize:none;outline:none;font-family:inherit}.feedback-textarea:focus{border-color:var(--accent)}.feedback-form-actions{display:flex;gap:10px;margin-top:12px}.feedback-cancel{flex:1;padding:12px;background:#ffffff0f;border:none;border-radius:12px;color:var(--text-dim);cursor:pointer;font-family:inherit}.feedback-submit{flex:1;padding:12px;background:var(--accent);color:var(--accent-text);border:none;border-radius:12px;font-weight:600;cursor:pointer;font-family:inherit}.feedback-submit:disabled{opacity:.4}.back-btn-fixed{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent);font-size:15px;font-weight:600;cursor:pointer;padding:12px 16px;font-family:inherit}.page-header{display:flex;align-items:center;padding:4px 0}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--bg-card);padding:6px 0 calc(6px + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(255,255,255,.06);z-index:100}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px;color:var(--text-dim);font-size:11px;text-decoration:none;transition:color .15s}.tab.active{color:var(--accent)}.tab-icon{font-size:22px}.spinner{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner:after{content:"";width:28px;height:28px;border:3px solid var(--bg-card);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.error-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--error)}.submit-btn,.continue-btn{display:block;width:100%;padding:16px;margin-top:24px;background:var(--accent);color:var(--accent-text);border:none;border-radius:14px;font-size:17px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:inherit}.submit-btn:active:not(:disabled),.continue-btn:active{opacity:.85}.submit-btn:disabled{opacity:.4;cursor:default}.feedback-overlay{position:fixed;bottom:0;left:0;right:0;padding:16px 20px calc(16px + env(safe-area-inset-bottom,0px));text-align:center;font-weight:700;font-size:15px;z-index:50}.feedback-overlay.with-buttons{padding:20px 20px calc(20px + env(safe-area-inset-bottom,0px))}.feedback-text{font-size:14px;line-height:1.4;max-height:120px;overflow-y:auto;word-break:break-word;white-space:pre-wrap}.feedback-overlay.correct{background:#34d399f2;color:#fff}.feedback-overlay.wrong{background:#f87171f2;color:#fff}.feedback-actions{display:flex;gap:10px;margin-top:12px}.feedback-btn{flex:1;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}.feedback-btn.retry{background:#ffffff40;color:#fff}.feedback-btn.skip{background:#0003;color:#fffc}.map-page{padding:16px 16px 80px}.track-selector{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.track-selector::-webkit-scrollbar{display:none}.track-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:14px;color:var(--text-dim);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:inherit;transition:all .15s;flex-shrink:0}.track-btn.active{border-color:var(--accent);color:var(--text);background:#7c6fff1a}.track-icon{font-size:18px}.track-premium{font-size:12px}.map-header{display:flex;justify-content:space-between;align-items:center;padding:8px 4px 20px;font-weight:700;font-size:15px}.lives-timer{font-size:12px;color:var(--text-dim);font-weight:600;font-family:SF Mono,monospace}.shield-active{color:var(--accent);font-weight:700;font-family:SF Mono,monospace;animation:shield-pulse 2s ease-in-out infinite}@keyframes shield-pulse{0%,to{opacity:1}50%{opacity:.7}}.module-section{margin-bottom:16px}.module-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);border-radius:16px;margin-bottom:8px;transition:opacity .15s}.module-header.module-complete{opacity:.6}.module-chevron{color:var(--text-dim);font-size:16px;margin-left:4px}.module-icon{font-size:24px}.module-header h2{flex:1;font-size:17px;font-weight:700}.module-progress{color:var(--text-dim);font-size:13px}.lessons-path{display:flex;flex-direction:column;align-items:center;gap:2px}.node-connector{width:2px;height:14px;background:#ffffff14}.lesson-node{display:flex;flex-direction:column;align-items:center;gap:4px;transition:transform .2s;cursor:pointer}.lesson-node.locked{opacity:.35;cursor:default}.node-circle{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;transition:all .3s}.node-circle.completed{background:var(--success);color:#fff}.node-circle.current{background:var(--accent);color:#fff;animation:pulse 2s ease-in-out infinite}.node-circle.locked{background:#ffffff12;color:var(--text-dim)}.node-label{font-size:11px;color:var(--text-dim);text-align:center;max-width:110px;line-height:1.3}.level-section{margin-bottom:32px;padding:16px;border-radius:20px}.level-bg-intern{background:linear-gradient(180deg,#34d3990f,#34d39905);border:1px solid rgba(52,211,153,.1)}.level-bg-junior{background:linear-gradient(180deg,#60a5fa0f,#60a5fa05);border:1px solid rgba(96,165,250,.1)}.level-bg-middle{background:linear-gradient(180deg,#a78bfa0f,#a78bfa05);border:1px solid rgba(167,139,250,.1)}.level-bg-senior{background:linear-gradient(180deg,#f472b60f,#f472b605);border:1px solid rgba(244,114,182,.1)}.level-section.level-locked{opacity:.4}.level-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border-radius:16px;margin-bottom:16px;border-left:4px solid}.level-icon{font-size:28px}.level-info{flex:1}.level-info h2{font-size:18px;font-weight:800;margin:0}.level-count{font-size:12px;color:var(--text-dim)}.level-lock{font-size:22px}.node-circle.boss{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.lesson-page{min-height:100vh;display:flex;flex-direction:column}.lesson-header{display:flex;align-items:center;gap:10px;padding:12px 16px}.back-btn{background:none;border:none;color:var(--text-dim);font-size:22px;cursor:pointer;padding:4px 8px}.lives-display{font-size:15px;font-weight:700;white-space:nowrap}.progress-bar{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .35s ease}.task{padding:20px 16px}.task-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:700;background:#7c6fff26;color:var(--accent);margin-bottom:14px}.task .question,.task .description{font-size:17px;font-weight:600;line-height:1.4;margin:12px 0 16px}.fill-instruction{font-size:14px;color:var(--text-dim);margin:12px 0 4px}.fill-instruction code{background:#ffffff14;padding:2px 6px;border-radius:4px;font-size:13px}.order-instruction{font-size:14px;color:var(--text-dim);margin:-4px 0 12px}.code-block{background:#0d1117;color:#e6edf3;padding:14px 16px;border-radius:12px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:14px;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.options{margin-top:16px}.option-letter{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#ffffff0f;font-size:13px;font-weight:700;margin-right:12px;flex-shrink:0}.option{display:flex;align-items:center;width:100%;padding:14px 16px;margin:8px 0;background:var(--bg-card);color:var(--text);border:2px solid rgba(255,255,255,.06);border-radius:12px;font-size:16px;text-align:left;cursor:pointer;transition:all .15s;font-family:inherit}.option:active:not(:disabled){transform:scale(.98)}.option:disabled{cursor:default}.option.selected{border-color:var(--accent);background:#7c6fff1f}.boss-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:700;background:#fbbf2426;color:#fbbf24;margin-left:auto}.boss-fail{text-align:center}.trace-table{margin-top:16px;display:flex;flex-direction:column;gap:8px}.trace-row{display:flex;align-items:center;gap:12px}.trace-label{font-family:SF Mono,Fira Code,monospace;font-size:14px;color:var(--text-dim);min-width:100px;white-space:nowrap}.trace-input{flex:1;padding:10px 14px;background:var(--bg-card);border:2px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text);font-family:SF Mono,Fira Code,monospace;font-size:16px;outline:none;text-align:center}.trace-input:focus{border-color:var(--accent)}.multifill-inputs{margin-top:16px;display:flex;flex-direction:column;gap:10px}.multifill-row{display:flex;align-items:center;gap:10px}.multifill-label{font-size:14px;color:var(--text-dim);min-width:80px;white-space:nowrap}.multifill-input{flex:1;padding:10px 14px;background:var(--bg-card);border:2px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text);font-family:SF Mono,Fira Code,monospace;font-size:15px;outline:none}.multifill-input:focus{border-color:var(--accent)}.theory-task{text-align:left}.theory-badge{display:inline-block;padding:4px 14px;border-radius:20px;font-size:13px;font-weight:700;background:#34d39926;color:var(--success);margin-bottom:14px}.theory-title{font-size:20px;font-weight:800;margin-bottom:12px;line-height:1.3}.theory-text{font-size:16px;line-height:1.6;color:var(--text);margin-bottom:16px;white-space:pre-line}.order-selected{min-height:60px;padding:12px;background:var(--bg-card);border:2px dashed rgba(255,255,255,.1);border-radius:12px;margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.order-placeholder{color:var(--text-dim);font-size:14px;text-align:center;padding:8px}.order-pool{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.order-block{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:12px;cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text);text-align:left;width:100%}.order-block:active:not(:disabled){transform:scale(.98)}.order-block:disabled{cursor:default}.order-block.selected{border-color:var(--accent);background:#7c6fff14}.order-block code{font-family:SF Mono,Fira Code,monospace;font-size:14px}.order-remove{color:var(--text-dim);font-size:14px;margin-left:8px}.swipe-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:16px 16px 80px}.swipe-wrapper{display:flex;flex-direction:column;align-items:center}.swipe-card{width:280px;min-height:180px;background:var(--bg-card);border-radius:20px;padding:28px 24px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:17px;line-height:1.5;box-shadow:0 8px 40px #00000059;touch-action:pan-y}.swipe-hints{display:flex;justify-content:space-between;width:280px;margin-bottom:12px;font-size:13px;font-weight:700}.hint-false{color:var(--error)}.hint-true{color:var(--success)}.swipe-counter{margin-top:24px;color:var(--text-dim);font-size:14px}.swipe-score{font-size:28px;font-weight:800;margin-bottom:32px}.swipe-done{text-align:center}.swipe-done h2{font-size:28px;margin-bottom:12px}.swipe-buttons{display:flex;gap:12px;margin-top:20px;width:280px}.swipe-btn{flex:1;padding:14px;border:2px solid rgba(255,255,255,.1);border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;background:transparent}.swipe-btn:disabled{opacity:.3;cursor:default}.swipe-btn-false{color:var(--error);border-color:#f871714d}.swipe-btn-false:active:not(:disabled){background:#f8717126}.swipe-btn-true{color:var(--success);border-color:#34d3994d}.swipe-btn-true:active:not(:disabled){background:#34d39926}.bug-lines{margin-top:16px}.bug-line{display:flex;align-items:center;gap:10px;padding:10px 14px;margin:4px 0;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:10px;cursor:pointer;font-family:SF Mono,Fira Code,monospace;font-size:14px;transition:all .15s;width:100%;color:var(--text);text-align:left}.bug-line:active:not(:disabled){transform:scale(.98)}.bug-line:disabled{cursor:default}.bug-line.selected{border-color:var(--accent);background:#7c6fff1f}.bug-line-num{color:var(--text-dim);font-size:12px;min-width:20px}.input-field{display:flex;gap:10px;margin-top:16px}.input-field input{flex:1;padding:14px 16px;background:var(--bg-card);border:2px solid rgba(255,255,255,.1);border-radius:12px;color:var(--text);font-family:SF Mono,Fira Code,monospace;font-size:18px;outline:none}.input-field input:focus{border-color:var(--accent)}.tokens-assembly{min-height:52px;padding:12px 16px;background:var(--bg-card);border:2px dashed rgba(255,255,255,.1);border-radius:12px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:8px}.tokens-pool{display:flex;flex-wrap:wrap;gap:8px}.token-chip{padding:8px 14px;background:#7c6fff26;color:var(--accent);border:none;border-radius:8px;font-family:SF Mono,Fira Code,monospace;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.token-chip:active{transform:scale(.95)}.token-chip.assembled{background:var(--accent);color:var(--accent-text)}.tokens-placeholder{color:var(--text-dim);font-size:14px}.leaderboard-page{padding:20px 16px 80px}.lb-title{font-size:24px;font-weight:800;text-align:center;margin-bottom:16px}.lb-tabs{display:flex;gap:8px;margin-bottom:20px}.lb-tab{flex:1;padding:10px;border:2px solid rgba(255,255,255,.08);background:transparent;color:var(--text-dim);border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.lb-tab.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.lb-empty{text-align:center;color:var(--text-dim);padding:40px 0;font-size:15px}.lb-list{display:flex;flex-direction:column;gap:8px}.lb-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-card);border-radius:14px;transition:background .15s}.lb-row.lb-me{border:2px solid var(--accent);background:#7c6fff14}.lb-rank{width:32px;text-align:center;font-weight:800;font-size:16px;color:var(--text-dim)}.lb-rank.top-1,.lb-rank.top-2,.lb-rank.top-3{font-size:22px}.lb-avatar{width:40px;height:40px;border-radius:50%;background:#ffffff0f;display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden;flex-shrink:0}.lb-avatar.lb-cat-avatar{border-radius:0;overflow:visible;background:transparent;image-rendering:pixelated;display:flex;align-items:center;justify-content:center}.lb-avatar img{width:100%;height:100%;object-fit:cover}.lb-info{flex:1;min-width:0}.lb-name{display:block;font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-level{font-size:12px;color:var(--text-dim)}.lb-xp{font-weight:700;font-size:15px;white-space:nowrap;color:var(--warning)}.achievements-page{padding:20px 16px 80px}.ach-title{font-size:24px;font-weight:800;text-align:center;margin-bottom:4px}.ach-subtitle{text-align:center;color:var(--text-dim);font-size:14px;margin-bottom:20px}.ach-new-banner{text-align:center;padding:12px;background:#34d39926;color:var(--success);border-radius:12px;font-weight:700;margin-bottom:20px}.ach-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ach-card{background:var(--bg-card);border-radius:16px;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:all .2s}.ach-card.locked{opacity:.35}.ach-card.new{border:2px solid var(--success);box-shadow:0 0 16px #34d3994d}.ach-icon{font-size:32px}.ach-card-title{font-size:14px;font-weight:700;line-height:1.2}.ach-desc{font-size:11px;color:var(--text-dim);line-height:1.3}.league-page{padding:20px 16px 80px}.league-title{font-size:24px;font-weight:800;text-align:center;margin-bottom:16px}.league-tier-badge{text-align:center;margin-bottom:20px}.league-tier-badge h1{font-size:24px;font-weight:800}.league-week{font-size:13px;color:var(--text-dim);margin-top:4px}.league-join{text-align:center;padding:40px 20px}.league-join p{margin-bottom:8px;font-size:16px}.league-join-desc{color:var(--text-dim);font-size:14px;margin-bottom:24px!important}.league-info-bar{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);margin-bottom:12px;padding:0 4px}.lb-row.promote{border-left:3px solid var(--success)}.lb-row.demote{border-left:3px solid var(--error)}.duel-page{padding:20px 16px 80px;min-height:100dvh}.duel-title{font-size:22px;font-weight:800;text-align:center;margin-bottom:24px}.duel-error{text-align:center;color:var(--error);font-size:14px;margin-bottom:16px;padding:12px;background:#f871711a;border-radius:12px}.duel-setup{max-width:360px;margin:0 auto}.duel-card{background:var(--bg-card);border-radius:20px;padding:24px 20px;margin-bottom:16px}.duel-card-title{font-size:14px;font-weight:600;color:var(--text-dim);margin-bottom:14px;text-align:center}.duel-task-counts{display:flex;gap:10px;justify-content:center;margin-bottom:20px}.duel-count-btn{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:2px solid rgba(255,255,255,.08);border-radius:16px;color:var(--text);font-size:22px;font-weight:800;cursor:pointer;font-family:inherit;transition:all .15s}.duel-count-btn.active{border-color:var(--accent);color:var(--accent);background:#7c6fff1a;box-shadow:0 0 20px #7c6fff26}.duel-create-btn{width:100%;padding:16px;background:var(--accent);color:var(--accent-text);border:none;border-radius:14px;font-size:17px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}.duel-create-btn:active{opacity:.85}.duel-divider{display:flex;align-items:center;gap:14px;color:var(--text-dim);font-size:13px;margin:4px 0}.duel-divider:before,.duel-divider:after{content:"";flex:1;height:1px;background:#ffffff0f}.duel-join-row{display:flex;gap:10px}.duel-join-row input{flex:1;padding:14px 16px;background:#ffffff0a;border:2px solid rgba(255,255,255,.08);border-radius:12px;color:var(--text);font-size:15px;font-family:inherit;outline:none}.duel-join-row input:focus{border-color:var(--accent)}.duel-join-btn{padding:14px 20px;background:#7c6fff26;color:var(--accent);border:2px solid rgba(124,111,255,.3);border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}.duel-join-btn:disabled{opacity:.3}.duel-waiting{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center}.duel-waiting h2{font-size:18px;margin-bottom:20px;color:var(--text-dim)}.duel-waiting-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.08);border-top-color:var(--accent);border-radius:50%;animation:duel-spin .8s linear infinite;margin-bottom:24px}@keyframes duel-spin{to{transform:rotate(360deg)}}.duel-code-label{font-size:13px;color:var(--text-dim);margin-bottom:6px}.duel-code{font-family:SF Mono,Fira Code,monospace;font-size:28px;font-weight:800;color:var(--accent);letter-spacing:6px;margin-bottom:24px;cursor:pointer;padding:12px 24px;background:#7c6fff14;border-radius:14px}.duel-share-btn{padding:14px 32px;background:var(--accent);color:var(--accent-text);border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;font-family:inherit}.duel-vs{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;margin-bottom:12px;background:var(--bg-card);border-radius:16px}.duel-player{text-align:center;flex:1}.duel-player-name{font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.duel-player-score{font-size:15px;font-weight:800;margin-top:8px;color:var(--accent)}.duel-dots{display:flex;gap:5px;justify-content:center}.duel-dot{width:10px;height:10px;border-radius:50%;background:#ffffff14;transition:all .3s}.duel-dot.correct{background:var(--success);box-shadow:0 0 6px #34d39966}.duel-dot.wrong{background:var(--error);box-shadow:0 0 6px #f8717166}.duel-vs-label{font-size:14px;font-weight:800;color:#ffffff26;padding:0 12px;flex-shrink:0}.duel-progress-bar{height:4px;background:#ffffff0f;border-radius:2px;margin-bottom:16px;overflow:hidden}.duel-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.duel-result{text-align:center;padding:50px 20px;display:flex;flex-direction:column;align-items:center}.duel-result-icon{font-size:64px;margin-bottom:8px}.duel-result h2{font-size:26px;font-weight:800}.duel-scores{display:flex;gap:32px;margin:28px 0;padding:20px 24px;background:var(--bg-card);border-radius:16px}.duel-score{text-align:center;min-width:80px}.duel-score-label{font-size:12px;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:1px}.duel-score-value{font-size:24px;font-weight:800}.duel-score-time{font-size:13px;color:var(--text-dim);margin-top:4px;font-family:SF Mono,monospace}.duel-xp-earned{font-size:20px;font-weight:700;color:var(--warning);margin-bottom:16px}.duel-actions{display:flex;gap:12px;width:100%;max-width:320px}.duel-actions .continue-btn{flex:1}.duel-actions .share-btn{flex:1;font-size:15px;padding:14px}.result-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:60px 24px 32px;text-align:center}.result-page h2{font-size:28px;margin:20px 0}.stars{display:flex;gap:8px;font-size:40px}.star{opacity:.15;filter:grayscale(1)}.star.filled{opacity:1;filter:none}.stats{display:flex;gap:36px;margin:20px 0 32px}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:22px;font-weight:800;color:var(--accent)}.stat-label{font-size:12px;color:var(--text-dim);margin-top:4px}.profile-page{display:flex;flex-direction:column;align-items:center;padding:40px 16px 80px}.avatar{width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:44px;margin-bottom:16px}.avatar img{width:100%;height:100%;object-fit:cover}.profile-page h2{font-size:24px}.username{color:var(--text-dim);margin:2px 0 24px;font-size:15px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:320px}.stat-card{background:var(--bg-card);border-radius:16px;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:2px}.stat-card .stat-icon{font-size:26px}.stat-card .stat-value{font-size:22px;font-weight:800}.stat-card .stat-label{font-size:11px;color:var(--text-dim)}.rank-badge{display:inline-block;padding:6px 18px;border-radius:20px;background:#7c6fff26;color:var(--accent);font-weight:700;font-size:14px}.profile-section{width:100%;max-width:320px;margin-top:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-header h3{font-size:16px;font-weight:700}.link-btn{background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.section-empty{color:var(--text-dim);font-size:14px;text-align:center;padding:12px 0}.ach-preview{display:flex;gap:8px;flex-wrap:wrap}.ach-mini{width:44px;height:44px;border-radius:12px;background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:24px}.ach-mini.more{font-size:13px;font-weight:700;color:var(--text-dim)}.share-btn{display:block;width:100%;max-width:320px;padding:14px;margin-top:24px;background:transparent;color:var(--accent);border:2px solid var(--accent);border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.share-btn:active{background:#7c6fff1a}.referral-stats{font-size:13px;color:var(--text-dim);margin-bottom:12px}.referral-tiers{display:flex;flex-direction:column;gap:6px}.referral-tier{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border-radius:12px;opacity:.5}.referral-tier.achieved{opacity:1}.referral-tier-icon{font-size:18px}.referral-tier-text{font-size:14px;font-weight:600}.daily-page{padding:20px 16px 80px}.daily-title{font-size:24px;font-weight:800;text-align:center;margin-bottom:12px}.daily-meta{display:flex;justify-content:center;gap:12px;margin-bottom:16px}.daily-diff{padding:4px 12px;border-radius:12px;font-size:13px;font-weight:700;background:#34d39926;color:var(--success)}.daily-diff.medium{background:#fbbf2426;color:var(--warning)}.daily-diff.hard{background:#f8717126;color:var(--error)}.daily-xp{font-size:14px;font-weight:700;color:var(--accent)}.daily-challenge-title{font-size:18px;font-weight:700;margin-bottom:8px}.daily-desc{font-size:15px;color:var(--text-dim);line-height:1.5;margin-bottom:16px}.code-editor{width:100%;padding:14px 16px;background:#0d1117;color:#e6edf3;border:2px solid rgba(255,255,255,.06);border-radius:12px;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6;resize:vertical;outline:none}.code-editor:focus{border-color:var(--accent)}.daily-actions{display:flex;align-items:center;gap:12px;margin-top:12px}.daily-attempts{font-size:14px;color:var(--text-dim);white-space:nowrap}.daily-result{margin-top:16px;padding:14px 16px;border-radius:12px}.daily-result.success{background:#34d3991a;border:1px solid rgba(52,211,153,.3)}.daily-result.fail{background:#f871711a;border:1px solid rgba(248,113,113,.3)}.daily-result pre{font-family:SF Mono,monospace;font-size:13px;white-space:pre-wrap;word-break:break-word}.daily-xp-earned{font-weight:700;color:var(--success);margin-top:8px}.daily-solved{text-align:center;padding:40px}.daily-solved h3{font-size:20px;margin-top:12px}.daily-empty{text-align:center;color:var(--text-dim);padding:40px}.store-page{padding:20px 16px 80px}.store-title{font-size:24px;font-weight:800;text-align:center;margin-bottom:20px}.store-items{display:flex;flex-direction:column;gap:12px}.store-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-card);border-radius:16px}.store-icon{font-size:32px}.store-item-info{flex:1}.store-item-info h3{font-size:16px;font-weight:700;margin-bottom:2px}.store-item-info p{font-size:13px;color:var(--text-dim)}.store-buy{padding:10px 16px;background:var(--accent);color:var(--accent-text);border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:inherit}.store-buy:disabled{opacity:.4;cursor:default}.premium-item{border:2px solid rgba(251,191,36,.3)}.premium-buy{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.store-note{text-align:center;color:var(--text-dim);font-size:13px;margin-top:20px}.speedrun-timer{font-family:SF Mono,monospace;font-weight:700;font-size:15px;color:var(--warning)}.review-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:700;background:#7c6fff26;color:var(--accent);margin-left:auto}.quick-actions{display:flex;gap:10px;margin-bottom:20px}.quick-btn{flex:1;padding:14px;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:14px;color:var(--text);font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.quick-btn:active{transform:scale(.98)}.onboarding{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 20px;background:var(--bg)}.onb-content{text-align:center;max-width:360px;width:100%}.onb-emoji{font-size:72px;margin-bottom:12px}.onb-title{font-size:32px;font-weight:800;margin-bottom:8px}.onb-subtitle{font-size:16px;color:var(--text-dim);line-height:1.5;margin-bottom:28px}.onb-step-label{font-size:13px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.onb-task-title{font-size:20px;font-weight:700;margin-bottom:4px}.onb-features{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.onb-feature{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-card);border-radius:14px;font-size:16px;font-weight:600;text-align:left}.onb-feature span:first-child{font-size:24px;flex-shrink:0}.onb-options{display:flex;flex-direction:column;gap:10px;margin:20px 0}.onb-option{padding:16px 20px;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:14px;color:var(--text);font-size:17px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;text-align:left}.onb-option:active:not(:disabled){transform:scale(.98)}.onb-option:disabled{cursor:default}.onb-option.correct{border-color:var(--success);background:#34d3991f}.onb-option.wrong{border-color:var(--error);background:#f871711f}.onb-feedback{padding:14px;border-radius:12px;font-weight:700;font-size:15px;margin-bottom:16px}.onb-feedback.correct{background:#34d3991f;color:var(--success)}.onb-feedback.wrong{background:#f871711f;color:var(--error)}.onb-rocket{font-size:64px;margin-bottom:16px;transition:all 1s ease-in}.onb-rocket.gone{transform:translateY(-200px) scale(.3);opacity:0}.onb-code-assembly{min-height:60px;padding:14px;background:var(--bg-card);border:2px dashed rgba(255,255,255,.1);border-radius:14px;margin-bottom:14px;display:flex;flex-direction:column;gap:8px;align-items:center}.onb-code-pool{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.onb-code-block{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 18px;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:12px;color:var(--text);font-family:inherit;cursor:pointer;transition:all .15s;text-align:left}.onb-code-block:active{transform:scale(.98)}.onb-code-block.assembled{border-color:var(--accent);background:#7c6fff14}.onb-code-block code{font-family:SF Mono,Fira Code,monospace;font-size:14px}.onb-output-text{font-family:SF Mono,Fira Code,monospace;font-size:16px;color:var(--success);font-weight:600;margin-top:6px;animation:onb-fade-in .5s ease both}@keyframes onb-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.onb-name-input{width:100%;padding:16px 20px;background:var(--bg-card);border:2px solid rgba(255,255,255,.1);border-radius:14px;color:var(--text);font-size:18px;font-weight:600;text-align:center;outline:none;font-family:inherit;margin-bottom:12px}.onb-name-input:focus{border-color:var(--accent)}.onb-name-input::placeholder{color:var(--text-dim);font-weight:400}.onb-run-btn{width:100%;padding:16px;background:var(--success);color:#fff;border:none;border-radius:14px;font-size:17px;font-weight:700;cursor:pointer;font-family:inherit;margin-bottom:12px}.onb-run-btn:active{opacity:.85}.onb-output{padding:16px;background:#0d1117;border-radius:12px;text-align:left;margin-bottom:16px}.onb-output-label{display:block;font-size:11px;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:1px}.onb-output-text{font-family:SF Mono,Fira Code,monospace;font-size:18px;color:var(--success);font-weight:600}.onb-stats{display:flex;justify-content:center;gap:24px;margin:24px 0}.onb-stat{display:flex;flex-direction:column;align-items:center}.onb-stat-value{font-size:28px;font-weight:800;color:var(--accent)}.onb-stat-label{font-size:12px;color:var(--text-dim);margin-top:2px}.onb-tracks{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:28px}.onb-track{padding:8px 16px;background:var(--bg-card);border-radius:10px;font-size:14px;font-weight:600}.onb-btn{width:100%;padding:18px;background:var(--accent);color:var(--accent-text);border:none;border-radius:16px;font-size:18px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}.onb-btn:active{opacity:.85}.pet-page{padding:20px 16px 100px;display:flex;flex-direction:column;align-items:center;min-height:100vh;overflow:hidden}.pet-streak{display:flex;align-items:center;justify-content:center;gap:8px;font-size:32px;font-weight:800;color:var(--warning);margin:8px 0 4px;font-family:Courier New,monospace}.pet-streak-label{font-size:13px;color:var(--text-dim);text-transform:uppercase;letter-spacing:2px}.pet-stage-name{font-size:14px;color:var(--accent);font-weight:600;margin:12px 0 16px;padding:6px 16px;background:#7c6fff1f;border-radius:20px}.pixel-cat-wrap{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;cursor:pointer;-webkit-tap-highlight-color:transparent;user-select:none}.pixel-cat-glow{position:absolute;width:120px;height:120px;border-radius:50%;filter:blur(40px);opacity:.3;animation:glow-pulse 3s ease-in-out infinite}@keyframes glow-pulse{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.4;transform:scale(1.15)}}.pixel-cat-group{position:relative;transform:scale(8);image-rendering:pixelated;transition:transform .15s ease}.pixel-cat-wrap[data-mood=idle] .pixel-cat-group{animation:cat-idle 2s ease-in-out infinite}.pixel-cat-wrap[data-mood=happy] .pixel-cat-group{animation:cat-happy .6s ease-in-out infinite}.pixel-cat-wrap[data-mood=sad] .pixel-cat-group{animation:cat-sad 3s ease-in-out infinite}.pixel-cat-group.pet-bounce{animation:pet-bounce .2s ease-out!important}@keyframes pet-bounce{0%{transform:scale(8)}50%{transform:scale(8.8)}to{transform:scale(8)}}@keyframes cat-idle{0%,to{transform:scale(8) translateY(0)}50%{transform:scale(8) translateY(-1px)}}@keyframes cat-happy{0%,to{transform:scale(8) translateY(0) rotate(0)}25%{transform:scale(8) translateY(-2px) rotate(-2deg)}75%{transform:scale(8) translateY(-2px) rotate(2deg)}}@keyframes cat-sad{0%,to{transform:scale(8) translateY(0)}50%{transform:scale(8) translateY(1px)}}.pixel-cat{width:1px;height:1px}.pixel-cat-acc{position:absolute;width:1px;height:1px;pointer-events:none;image-rendering:pixelated}.binary-particle{position:absolute;font-family:Courier New,monospace;font-size:16px;font-weight:900;color:var(--success);pointer-events:none;text-shadow:0 0 8px var(--success),0 0 16px rgba(52,211,153,.4);animation:binary-fly .9s ease-out forwards;z-index:20}@keyframes binary-fly{0%{opacity:1;transform:translate(0) scale(1.2)}to{opacity:0;transform:translate(var(--px),var(--py)) scale(.4)}}.happy-hearts{position:absolute;inset:0;pointer-events:none}.happy-heart{position:absolute;font-size:16px;animation:heart-float 2s ease-out infinite}.happy-heart:nth-child(1){left:20%;animation-delay:0s}.happy-heart:nth-child(2){left:50%;animation-delay:.5s}.happy-heart:nth-child(3){left:75%;animation-delay:1s}@keyframes heart-float{0%{opacity:1;transform:translateY(0) scale(.5)}to{opacity:0;transform:translateY(-60px) scale(1)}}.pet-platform{width:200px;height:4px;background:#7c6fff26;border-radius:2px;margin-bottom:8px}.pet-hint{font-size:12px;color:var(--text-dim);margin-bottom:16px;opacity:.5}.pet-progress-section{width:100%;max-width:320px;background:var(--bg-card);border-radius:16px;padding:16px;margin-bottom:12px}.pet-progress-label{display:flex;justify-content:space-between;font-size:13px;color:var(--text-dim);margin-bottom:8px}.pet-progress-bar{width:100%;height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden}.pet-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:4px;transition:width .5s ease}.pet-sad-msg{text-align:center;padding:10px 16px;background:#f871711a;border-radius:12px;color:var(--error);font-size:13px;width:100%;max-width:320px;margin-bottom:12px}.pet-shop-toggle{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;max-width:320px;padding:14px;background:var(--bg-card);border:2px solid rgba(124,111,255,.2);border-radius:14px;color:var(--text);font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:border-color .2s;margin-bottom:12px}.pet-shop-toggle:active{border-color:var(--accent)}.pet-xp-badge{font-size:12px;padding:3px 10px;background:#7c6fff26;border-radius:12px;color:var(--accent);font-weight:700}.pet-shop{width:100%;max-width:320px;background:var(--bg-card);border-radius:16px;padding:16px;margin-bottom:16px}.pet-shop h3{font-size:14px;color:var(--text-dim);margin-bottom:10px}.pet-shop h3:not(:first-child){margin-top:16px}.pet-shop-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pet-shop-item{background:#ffffff0a;border:2px solid rgba(255,255,255,.06);border-radius:12px;padding:12px 8px;text-align:center;transition:border-color .2s,transform .15s}.pet-shop-item:active{transform:scale(.97)}.pet-shop-item.owned{border-color:#7c6fff33;cursor:pointer}.pet-shop-item.equipped{border-color:var(--accent);background:#7c6fff14}.pet-shop-item.locked{opacity:.4}.pet-shop-item.locked:active{transform:none}.pet-shop-item.stage-locked{opacity:.35}.pet-shop-item.stage-locked:active{transform:none}.pet-shop-item-locked{font-size:11px;color:var(--text-dim);font-weight:600;margin-top:2px}.pet-shop-item.previewing{border-color:var(--warning);background:#fbbf240f}.pet-shop-item-icon{font-size:28px;margin-bottom:4px}.pet-shop-item-name{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px}.pet-shop-item-price{font-size:11px;color:var(--accent);font-weight:700;margin-bottom:6px}.pet-shop-item-status{font-size:11px;color:var(--text-dim);font-weight:600}.pet-shop-item.equipped .pet-shop-item-status{color:var(--success)}.pet-shop-item-actions{display:flex;gap:4px;margin-top:6px}.pet-btn-preview{flex:1;padding:6px;background:#ffffff14;border:none;border-radius:8px;color:var(--text-dim);font-size:13px;cursor:pointer;font-family:inherit}.pet-btn-preview:active{background:#ffffff26}.pet-btn-buy{flex:2;padding:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit}.pet-btn-buy:disabled{opacity:.4;cursor:default}.pet-btn-buy:active:not(:disabled){opacity:.85}.pet-name-section{margin:-8px 0 8px;width:100%;max-width:280px;text-align:center}.pet-name-display{cursor:pointer;padding:6px 12px;border-radius:12px;background:#7c6fff0f;border:1px dashed rgba(124,111,255,.2);transition:background .2s;display:inline-flex;align-items:center;gap:6px}.pet-name-display:active{background:#7c6fff1f}.pet-name-text{font-size:16px;font-weight:700;color:var(--text)}.pet-name-edit-icon{font-size:12px;opacity:.5}.pet-name-edit{display:flex;gap:6px;align-items:center;justify-content:center}.pet-name-input{flex:1;padding:8px 12px;border-radius:10px;border:1.5px solid var(--accent);background:#7c6fff0f;color:var(--text);font-size:15px;font-weight:600;font-family:inherit;outline:none;text-align:center;max-width:200px}.pet-name-save,.pet-name-cancel{width:34px;height:34px;border-radius:10px;border:none;font-size:16px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center}.pet-name-save{background:var(--accent);color:#fff}.pet-name-save:disabled{opacity:.4}.pet-name-cancel{background:#ffffff14;color:var(--text-dim)}
