.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}.mode-btn[data-astro-cid-j26jfnak]{display:flex;background-color:var(--border-color);border-radius:var(--radius-md);padding:2px}.mode-btn[data-astro-cid-j26jfnak].settings{width:100%;max-width:300px}.mode-btn[data-astro-cid-j26jfnak].sidebar{width:100%;margin-bottom:12px}.mode-label[data-astro-cid-j26jfnak]{display:flex;align-items:center;justify-content:center;gap:6px;border-radius:6px;color:var(--text-muted);transition:background-color .2s,color .2s;cursor:pointer;user-select:none}.mode-btn[data-astro-cid-j26jfnak].navbar .mode-label[data-astro-cid-j26jfnak]{padding:.25rem .5rem;font-size:.85rem;font-weight:500}.mode-btn[data-astro-cid-j26jfnak].settings .mode-label[data-astro-cid-j26jfnak]{padding:.5rem .8rem;font-size:.95rem;flex:1}.mode-btn[data-astro-cid-j26jfnak].sidebar .mode-label[data-astro-cid-j26jfnak]{padding:.4rem .5rem;font-size:.7rem;flex:1;text-align:center;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.mode-label[data-astro-cid-j26jfnak].active{background-color:var(--card-bg);color:var(--primary-color);font-weight:600;box-shadow:0 1px 2px #0000001a}.script-btn[data-astro-cid-hyxkdzhr]{display:flex;background-color:var(--border-color);border-radius:var(--radius-md);padding:2px}.script-btn[data-astro-cid-hyxkdzhr].settings{width:100%;max-width:300px}.script-btn[data-astro-cid-hyxkdzhr].sidebar{width:100%;margin-bottom:12px}.script-label[data-astro-cid-hyxkdzhr]{display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-muted);transition:background-color .2s,color .2s;cursor:pointer;user-select:none}.script-btn[data-astro-cid-hyxkdzhr].navbar .script-label[data-astro-cid-hyxkdzhr]{padding:.25rem .5rem;font-size:.85rem;font-weight:500}.script-btn[data-astro-cid-hyxkdzhr].settings .script-label[data-astro-cid-hyxkdzhr]{padding:.5rem .8rem;font-size:.95rem;flex:1}.script-btn[data-astro-cid-hyxkdzhr].sidebar .script-label[data-astro-cid-hyxkdzhr]{padding:.4rem .5rem;font-size:.7rem;flex:1;text-align:center;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.script-label[data-astro-cid-hyxkdzhr].active{background-color:var(--card-bg);color:var(--primary-color);font-weight:600;box-shadow:0 1px 2px #0000001a}.sidebar-backdrop[data-astro-cid-urvxohhw]{display:none;position:fixed;inset:0;background:#00000080;z-index:10000}.sidebar-container[data-astro-cid-urvxohhw]{display:flex;flex-direction:column;width:var(--sidebar-width, 280px);background:var(--card-bg);border-right:1px solid var(--border-color);height:calc(100vh - 60px);position:fixed;top:60px;left:0;z-index:10001;overflow-y:auto;transition:transform .3s ease}.sidebar-mobile-header[data-astro-cid-urvxohhw]{display:none}.sidebar-nav[data-astro-cid-urvxohhw]{display:flex;flex-direction:column;padding:var(--spacing-lg) 0}.nav-link[data-astro-cid-urvxohhw]{display:flex;align-items:center;gap:12px;padding:var(--spacing-sm) var(--spacing-xl);text-decoration:none;color:var(--text-main);font-weight:500;font-size:1rem;transition:background .2s}.nav-link[data-astro-cid-urvxohhw]:hover{background:var(--bg-color);color:var(--primary-color)}.sidebar-settings[data-astro-cid-urvxohhw]{padding:var(--spacing-lg) var(--spacing-xl);margin-top:auto;border-top:1px solid var(--border-color)}.radio-group[data-astro-cid-urvxohhw] h4[data-astro-cid-urvxohhw]{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);margin:0;letter-spacing:.05em}.compact-controls[data-astro-cid-urvxohhw]{display:flex;flex-direction:column}.shortcut-item[data-astro-cid-urvxohhw]{display:flex;user-select:none;justify-content:space-between;align-items:center;padding:6px 0;cursor:pointer;border-bottom:1px solid transparent}.shortcut-item[data-astro-cid-urvxohhw]:hover .sb-val-window[data-astro-cid-urvxohhw]{background:#2563eb1a}.shortcut-item[data-astro-cid-urvxohhw]:hover .sb-val[data-astro-cid-urvxohhw]{color:var(--primary-color)}.sb-lbl[data-astro-cid-urvxohhw]{font-size:.85rem;color:var(--text-main);font-weight:400}.sb-val-window[data-astro-cid-urvxohhw]{display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;width:3.2rem;height:1.6rem;background:#0000000d;border-radius:999px;padding:0 4px;overflow:hidden;transition:background .2s}:root.dark .sb-val-window[data-astro-cid-urvxohhw]{background:#ffffff14;border:1px solid rgba(255,255,255,.1)}.sb-val-track[data-astro-cid-urvxohhw]{display:flex;flex-direction:column;transition:transform .08s ease-in-out;margin:0;padding:0}.sb-val[data-astro-cid-urvxohhw]{color:var(--text-main);line-height:1.6rem;height:1.6rem;text-align:center;white-space:nowrap;transition:color .2s;font-weight:700}.btn-primary[data-astro-cid-urvxohhw]{width:100%;display:flex;align-items:center;justify-content:center;padding:10px;border-radius:9999px;background:var(--primary-color);color:#fff;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem;user-select:none;border:1px solid var(--primary-color)}.btn-primary[data-astro-cid-urvxohhw]:hover{background:var(--primary-hover)}.btn-premium[data-astro-cid-urvxohhw]{width:100%;display:flex;align-items:center;justify-content:center;padding:10px;border-radius:9999px;background:linear-gradient(135deg,#eab308,#d97706);color:#fff;font-weight:700;cursor:pointer;transition:all .2s;font-size:.95rem;user-select:none;border:1px solid rgba(217,119,6,.8);text-shadow:0 1px 2px rgba(0,0,0,.2)}.btn-premium[data-astro-cid-urvxohhw]:hover{opacity:.9}.btn-outline[data-astro-cid-urvxohhw]{width:100%;display:flex;align-items:center;justify-content:center;padding:10px;border-radius:9999px;background:transparent;color:var(--text-main);font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem;user-select:none;border:1px solid var(--border-color)}.btn-outline[data-astro-cid-urvxohhw]:hover{border-color:var(--text-muted);background:var(--bg-color)}.hidden[data-astro-cid-urvxohhw]{display:none!important}@media(max-width:899px){.sidebar-container[data-astro-cid-urvxohhw]{top:0;height:100vh;transform:translate(-100%);width:280px}.sidebar-container[data-astro-cid-urvxohhw].open{transform:translate(0)}.sidebar-backdrop[data-astro-cid-urvxohhw].open{display:block}.sidebar-mobile-header[data-astro-cid-urvxohhw]{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-xl);border-bottom:1px solid var(--border-color)}.sidebar-mobile-header[data-astro-cid-urvxohhw] .logo[data-astro-cid-urvxohhw]{font-size:1.2rem;font-weight:700;color:var(--primary-color)}.close-sidebar-btn[data-astro-cid-urvxohhw]{background:none;border:none;font-size:1.8rem;color:var(--text-muted);cursor:pointer;line-height:1}}.toast-wrapper[data-astro-cid-oozri3xh]{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:100000;pointer-events:none;align-items:center;justify-content:flex-end}.toast-item{background:#0f172a;color:#f8fafc;padding:12px 24px;border-radius:8px;font-weight:500;font-size:.95rem;box-shadow:0 4px 12px #00000026;pointer-events:auto;min-width:320px;max-width:500px;text-align:center;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);opacity:0;transform:translateY(20px) scale(.95);display:flex;align-items:center;justify-content:center;gap:12px}:root.dark .toast-item{background:#1e293b;color:#f8fafc;border:1px solid #334155;box-shadow:0 4px 20px #0006}.toast-item.show{opacity:1;transform:translateY(0) scale(1)}.toast-item.fade-out{opacity:0;transform:translateY(-20px) scale(.95);margin-top:-40px}.toast-progress{position:absolute;bottom:0;right:0;height:3px;background:#fff6;width:100%;transform-origin:right}.toast-item.theme-xp{background:#7c3aed;color:#fff;border:1px solid #6d28d9;box-shadow:0 4px 12px #7c3aed4d}.toast-item.theme-streak{background:#ea580c;color:#fff;border:1px solid #c2410c;box-shadow:0 4px 12px #ea580c4d}:root.dark .toast-item.theme-xp{background:#7c3aede6;border-color:#8b5cf6}:root.dark .toast-item.theme-streak{background:#ea580ce6;border-color:#f97316}.loading-theme[data-astro-cid-oozri3xh]{background:var(--primary-color)!important;color:#fff!important;box-shadow:0 6px 16px #2563eb40!important;border:none!important}.spinner-small[data-astro-cid-oozri3xh]{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.hidden[data-astro-cid-oozri3xh]{display:none!important}.premium-modal[data-astro-cid-tkdcxr6t]{border:none;border-radius:var(--radius-lg);box-shadow:0 20px 40px #0000004d;padding:0;max-width:420px;width:90vw;background:var(--card-bg);color:var(--text-main);margin:auto;overflow:hidden;border:1px solid rgba(234,179,8,.3)}.premium-modal[data-astro-cid-tkdcxr6t]::backdrop{background:#0f172acc;backdrop-filter:blur(4px)}.premium-header[data-astro-cid-tkdcxr6t]{display:flex;justify-content:space-between;align-items:flex-start;padding:16px}.pm-icon[data-astro-cid-tkdcxr6t]{font-size:2.5rem;line-height:1;background:#eab30826;padding:12px;border-radius:50%;border:2px solid rgba(234,179,8,.5);margin:0 auto}.close-btn[data-astro-cid-tkdcxr6t]{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);transition:color .2s}.close-btn[data-astro-cid-tkdcxr6t]:hover{color:var(--text-main)}.premium-body[data-astro-cid-tkdcxr6t]{padding:0 24px 32px;text-align:center;display:flex;flex-direction:column;gap:16px}.premium-body[data-astro-cid-tkdcxr6t] h2[data-astro-cid-tkdcxr6t]{font-size:1.5rem;color:var(--text-main);margin:0}.premium-body[data-astro-cid-tkdcxr6t] p[data-astro-cid-tkdcxr6t]{font-size:.95rem;color:var(--text-muted);line-height:1.5;margin:0}.premium-features[data-astro-cid-tkdcxr6t]{list-style:none;padding:0;margin:16px 0;text-align:left;display:flex;flex-direction:column;gap:12px}.premium-features[data-astro-cid-tkdcxr6t] li[data-astro-cid-tkdcxr6t]{display:flex;align-items:flex-start;gap:10px;font-size:.95rem;color:var(--text-main);font-weight:500}.check[data-astro-cid-tkdcxr6t]{color:#eab308;font-weight:700}.cta-group[data-astro-cid-tkdcxr6t]{display:flex;flex-direction:column;gap:12px;align-items:center}.btn-premium[data-astro-cid-tkdcxr6t]{width:100%;background:linear-gradient(135deg,#eab308,#d97706);color:#fff;border:none;padding:14px;border-radius:999px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:opacity .2s,transform .1s;text-shadow:0 1px 2px rgba(0,0,0,.2)}.btn-premium[data-astro-cid-tkdcxr6t]:active{transform:scale(.98)}.tell-me-more[data-astro-cid-tkdcxr6t]{color:var(--primary-color);font-size:.85rem;font-weight:600;text-decoration:none}.tell-me-more[data-astro-cid-tkdcxr6t]:hover{text-decoration:underline}.auth-modal[data-astro-cid-ke56sdij]{border:none;border-radius:var(--radius-lg);box-shadow:0 10px 25px #0003;padding:0;max-width:400px;width:90vw;background:var(--card-bg);color:var(--text-main);margin:auto}.auth-modal[data-astro-cid-ke56sdij]::backdrop{background:#0009;backdrop-filter:blur(2px)}.auth-content[data-astro-cid-ke56sdij]{display:flex;flex-direction:column}.auth-header[data-astro-cid-ke56sdij]{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-color)}.auth-header[data-astro-cid-ke56sdij] h3[data-astro-cid-ke56sdij]{font-size:1.2rem;margin:0}.close-btn[data-astro-cid-ke56sdij]{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted)}.auth-body[data-astro-cid-ke56sdij]{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-error[data-astro-cid-ke56sdij]{background:#ef44441a;color:#dc2626;padding:8px 12px;border-radius:var(--radius-md);font-size:.9rem;text-align:center;border:1px solid rgba(239,68,68,.2)}.auth-error[data-astro-cid-ke56sdij].hidden{display:none}.auth-form[data-astro-cid-ke56sdij]{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group[data-astro-cid-ke56sdij]{display:flex;flex-direction:column;gap:4px}.form-group[data-astro-cid-ke56sdij] label[data-astro-cid-ke56sdij]{font-size:.85rem;font-weight:600;color:var(--text-muted)}.form-group[data-astro-cid-ke56sdij] input[data-astro-cid-ke56sdij]{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-color);color:var(--text-main);font-size:1rem}.form-group[data-astro-cid-ke56sdij] input[data-astro-cid-ke56sdij]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb1a}.form-group-check[data-astro-cid-ke56sdij]{display:flex;align-items:flex-start;gap:8px;margin-top:4px}.form-group-check[data-astro-cid-ke56sdij].hidden{display:none}.form-group-check[data-astro-cid-ke56sdij] input[data-astro-cid-ke56sdij]{margin-top:3px}.form-group-check[data-astro-cid-ke56sdij] label[data-astro-cid-ke56sdij]{font-size:.8rem;font-weight:400;line-height:1.4;cursor:pointer;color:var(--text-main)}.form-group-check[data-astro-cid-ke56sdij] label[data-astro-cid-ke56sdij] a[data-astro-cid-ke56sdij]{color:var(--primary-color);text-decoration:none;font-weight:500}.form-group-check[data-astro-cid-ke56sdij] label[data-astro-cid-ke56sdij] a[data-astro-cid-ke56sdij]:hover{text-decoration:underline}.btn-primary[data-astro-cid-ke56sdij]{background:var(--primary-color);color:#fff;border:none;padding:10px;border-radius:var(--radius-md);font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s;margin-top:8px}.btn-primary[data-astro-cid-ke56sdij]:hover{background:var(--primary-hover)}.btn-primary[data-astro-cid-ke56sdij]:disabled{opacity:.6;cursor:not-allowed}.auth-footer[data-astro-cid-ke56sdij]{margin-top:8px;text-align:center;font-size:.9rem;color:var(--text-muted);border-top:1px solid var(--border-color);padding-top:var(--spacing-md)}.btn-text[data-astro-cid-ke56sdij]{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;font-size:.9rem;padding:0;margin-left:4px}.btn-text[data-astro-cid-ke56sdij]:hover{text-decoration:underline}.pwa-modal[data-astro-cid-yj6utcte]{border:none;border-radius:var(--radius-lg);box-shadow:0 10px 30px #0003;padding:0;max-width:400px;width:90vw;background:var(--card-bg);color:var(--text-main);margin:auto;overflow:hidden}.pwa-modal[data-astro-cid-yj6utcte]::backdrop{background:#00000080;backdrop-filter:blur(2px)}.pwa-header[data-astro-cid-yj6utcte]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-color)}.pwa-header[data-astro-cid-yj6utcte] h3[data-astro-cid-yj6utcte]{font-size:1.25rem;margin:0}.close-btn[data-astro-cid-yj6utcte]{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--text-muted);line-height:1}.close-btn[data-astro-cid-yj6utcte]:hover{color:var(--text-main)}.pwa-body[data-astro-cid-yj6utcte]{padding:32px 24px}.step-row[data-astro-cid-yj6utcte]{display:flex;align-items:center;gap:12px}.step-num[data-astro-cid-yj6utcte]{font-size:1.25rem;font-weight:800;color:var(--primary-color)}.step-text[data-astro-cid-yj6utcte]{font-size:1.05rem;color:var(--text-main);line-height:1.4;flex:1}.step-icon-box[data-astro-cid-yj6utcte]{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);flex-shrink:0;box-shadow:0 2px 4px #0000000d}.mock-menu[data-astro-cid-yj6utcte]{background:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;margin-top:16px;padding:8px;box-shadow:0 4px 12px #0000000d}.mock-row[data-astro-cid-yj6utcte]{display:flex;align-items:center;gap:16px;padding:12px 16px;border-radius:8px}.mock-row[data-astro-cid-yj6utcte].highlight{background:var(--card-bg);border:2px solid var(--primary-color);color:var(--primary-color)}.mock-icon[data-astro-cid-yj6utcte]{width:20px;height:20px;border-radius:4px;background:var(--border-color)}.mock-text-line[data-astro-cid-yj6utcte]{height:10px;border-radius:4px;background:var(--border-color);width:60%}.btn-primary[data-astro-cid-yj6utcte]{background:var(--primary-color);color:#fff;border:none;border-radius:9999px;font-weight:700;cursor:pointer;transition:background .2s;font-size:1.05rem}.btn-primary[data-astro-cid-yj6utcte]:hover{background:var(--primary-hover)}.lang-info-modal[data-astro-cid-3lrbdnw7]{border:none;border-radius:var(--radius-lg);box-shadow:0 10px 30px #0003;padding:0;max-width:550px;width:90vw;background:var(--card-bg);color:var(--text-main);margin:auto;overflow:hidden}.lang-info-modal[data-astro-cid-3lrbdnw7]::backdrop{background:#00000080;backdrop-filter:blur(2px)}.modal-header[data-astro-cid-3lrbdnw7]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-color)}.modal-header[data-astro-cid-3lrbdnw7] h3[data-astro-cid-3lrbdnw7]{font-size:1.25rem;margin:0}.close-btn[data-astro-cid-3lrbdnw7]{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--text-muted);line-height:1;margin:-10px 0}.close-btn[data-astro-cid-3lrbdnw7]:hover{color:var(--text-main)}.modal-body[data-astro-cid-3lrbdnw7]{padding:24px;max-height:70vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.info-section[data-astro-cid-3lrbdnw7] h4[data-astro-cid-3lrbdnw7]{font-size:.9rem;margin-bottom:6px;color:var(--text-main)}.info-section[data-astro-cid-3lrbdnw7] p[data-astro-cid-3lrbdnw7]{font-size:.95rem;color:var(--text-muted);line-height:1.5;margin:0}.info-section[data-astro-cid-3lrbdnw7].highlight{background:#2563eb0d;padding:16px;border-radius:var(--radius-md);border:1px solid rgba(37,99,235,.15)}:root.dark .info-section[data-astro-cid-3lrbdnw7].highlight{background:#60a5fa1a;border-color:#60a5fa33}.quick-set-actions[data-astro-cid-3lrbdnw7]{display:flex;flex-direction:column;gap:12px;margin-top:8px;border-top:1px solid var(--border-color);padding-top:24px}@media(min-width:600px){.quick-set-actions[data-astro-cid-3lrbdnw7]{flex-direction:row}.quick-set-actions[data-astro-cid-3lrbdnw7] button[data-astro-cid-3lrbdnw7]{flex:1}}.btn-primary[data-astro-cid-3lrbdnw7]{background:var(--primary-color);color:#fff;border:none;padding:14px 20px;border-radius:9999px;font-weight:700;cursor:pointer;transition:background .2s;font-size:.95rem;display:inline-flex;align-items:center;justify-content:center}.btn-primary[data-astro-cid-3lrbdnw7]:hover{background:var(--primary-hover)}.xp-modal[data-astro-cid-fb2j7reu]{border:none;border-radius:var(--radius-lg);box-shadow:0 20px 40px #00000040;padding:0;max-width:480px;width:95vw;background:transparent;color:var(--text-main);margin:auto;overflow:visible}.xp-modal[data-astro-cid-fb2j7reu]::backdrop{background:#0f172acc;backdrop-filter:blur(4px)}.xp-content[data-astro-cid-fb2j7reu]{display:flex;flex-direction:column;background:var(--card-bg);border-radius:var(--radius-lg)}.anon-warning[data-astro-cid-fb2j7reu]{background:#9333ea1a;border:1px solid rgba(147,51,234,.3);padding:12px;border-radius:var(--radius-md);margin-bottom:20px;font-size:.9rem;color:var(--text-main)}.anon-warning[data-astro-cid-fb2j7reu] a[data-astro-cid-fb2j7reu]{color:var(--primary-color);font-weight:700;text-decoration:none}.anon-warning[data-astro-cid-fb2j7reu] a[data-astro-cid-fb2j7reu]:hover{text-decoration:underline}.xp-header[data-astro-cid-fb2j7reu]{background:linear-gradient(135deg,#9333ea1a,#2563eb0d);border-bottom:1px solid var(--border-color);padding:20px 24px 28px;position:relative;border-radius:var(--radius-lg) var(--radius-lg) 0 0}:root.dark .xp-header[data-astro-cid-fb2j7reu]{background:linear-gradient(135deg,#9333ea26,#2563eb1a)}.header-info[data-astro-cid-fb2j7reu]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.user-display[data-astro-cid-fb2j7reu]{font-size:1.1rem;font-weight:700;margin:0;color:var(--text-muted)}.close-btn[data-astro-cid-fb2j7reu]{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--text-muted);line-height:1;transition:color .2s}.close-btn[data-astro-cid-fb2j7reu]:hover{color:var(--text-main)}.rank-hero[data-astro-cid-fb2j7reu]{display:flex;align-items:center;gap:20px}.rank-icon-wrapper[data-astro-cid-fb2j7reu]{position:relative;width:64px;height:64px;display:flex;align-items:center;justify-content:center;color:#9333ea}:root.dark .rank-icon-wrapper[data-astro-cid-fb2j7reu]{color:#c084fc}.rank-shield[data-astro-cid-fb2j7reu]{width:100%;height:100%;fill:#9333ea1a}.rank-tier-num[data-astro-cid-fb2j7reu]{position:absolute;font-size:1.5rem;font-weight:900;font-family:monospace;margin-top:-4px}.rank-title-box[data-astro-cid-fb2j7reu]{display:flex;flex-direction:column}.rank-name[data-astro-cid-fb2j7reu]{font-size:1.6rem;font-weight:800;margin:0;color:var(--text-main);letter-spacing:-.02em}.rank-sub[data-astro-cid-fb2j7reu]{font-size:.95rem;color:var(--primary-color);font-weight:600;margin-top:2px}.rank-info-container[data-astro-cid-fb2j7reu]{position:relative;display:inline-flex;align-items:center}.rank-info-btn[data-astro-cid-fb2j7reu]{background:#9333ea1a;border:1px solid rgba(147,51,234,.3);color:#9333ea;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;margin-top:3px}:root.dark .rank-info-btn[data-astro-cid-fb2j7reu]{color:#c084fc}.rank-info-btn[data-astro-cid-fb2j7reu]:hover{background:#9333ea;color:#fff}.rank-info-tooltip[data-astro-cid-fb2j7reu]{position:fixed;background:#1e293b;color:#f8fafc;border:1px solid #334155;padding:12px;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;line-height:1.5;z-index:100000;box-shadow:0 10px 25px #0000004d;text-align:center;pointer-events:none;width:250px;transform:translate(-50%,10px);opacity:0;transition:opacity .2s,transform .2s}.rank-info-tooltip[data-astro-cid-fb2j7reu].show{opacity:1;transform:translate(-50%);pointer-events:auto}.rank-info-tooltip[data-astro-cid-fb2j7reu].hidden{display:none}.rank-info-tooltip[data-astro-cid-fb2j7reu]:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:transparent transparent #1e293b transparent}:root.dark .rank-info-tooltip[data-astro-cid-fb2j7reu]{background:#0f172a;border-color:#1e293b}:root.dark .rank-info-tooltip[data-astro-cid-fb2j7reu]:after{border-color:transparent transparent #0f172a transparent}.xp-body[data-astro-cid-fb2j7reu]{padding:24px;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.progress-section[data-astro-cid-fb2j7reu]{margin-bottom:32px}.progress-labels[data-astro-cid-fb2j7reu]{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:8px}#xp-current-val[data-astro-cid-fb2j7reu]{font-size:1.2rem;font-weight:700;color:var(--text-main)}.progress-bar-bg[data-astro-cid-fb2j7reu]{width:100%;height:12px;background:var(--border-color);border-radius:6px;overflow:hidden}.progress-bar-fill[data-astro-cid-fb2j7reu]{height:100%;width:0%;background:linear-gradient(90deg,#9333ea,#c084fc);border-radius:6px;transition:width .8s cubic-bezier(.34,1.56,.64,1)}.breakdown-section[data-astro-cid-fb2j7reu] h4[data-astro-cid-fb2j7reu],.stats-section[data-astro-cid-fb2j7reu] h4[data-astro-cid-fb2j7reu]{font-size:1rem;color:var(--text-main);margin-bottom:16px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.chart-layout[data-astro-cid-fb2j7reu]{display:flex;align-items:center;gap:24px}.chart-wrapper[data-astro-cid-fb2j7reu]{position:relative;width:120px;height:120px;flex-shrink:0}.donut-chart[data-astro-cid-fb2j7reu]{width:100%;height:100%;transform:rotate(-90deg)}.donut-bg[data-astro-cid-fb2j7reu]{fill:none;stroke:var(--border-color);stroke-width:3.5}.donut-segment[data-astro-cid-fb2j7reu]{fill:none;stroke-width:3.5;stroke-linecap:round;transition:stroke-dasharray 1s ease}.seg-learning[data-astro-cid-fb2j7reu]{stroke:#3b82f6}.seg-review[data-astro-cid-fb2j7reu]{stroke:#10b981}.seg-interaction[data-astro-cid-fb2j7reu]{stroke:#f59e0b}.chart-center[data-astro-cid-fb2j7reu]{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}#chart-total-xp[data-astro-cid-fb2j7reu]{font-size:1.25rem;font-weight:800;color:var(--text-main);line-height:1;margin-bottom:2px}.chart-lbl[data-astro-cid-fb2j7reu]{font-size:.75rem;color:var(--text-muted);font-weight:600;text-transform:uppercase}.chart-legend[data-astro-cid-fb2j7reu]{display:flex;flex-direction:column;gap:12px;flex:1}.legend-row[data-astro-cid-fb2j7reu]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.legend-item[data-astro-cid-fb2j7reu]{display:flex;align-items:flex-start;gap:8px}.legend-dot[data-astro-cid-fb2j7reu]{width:12px;height:12px;border-radius:50%;margin-top:4px;flex-shrink:0}.legend-text[data-astro-cid-fb2j7reu]{display:flex;flex-direction:column}.leg-lbl[data-astro-cid-fb2j7reu]{font-size:.85rem;color:var(--text-muted);font-weight:500}.leg-val[data-astro-cid-fb2j7reu]{font-size:1rem;font-weight:700;color:var(--text-main)}.stats-section[data-astro-cid-fb2j7reu]{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color)}.stats-grid[data-astro-cid-fb2j7reu]{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;text-align:center}.stat-box[data-astro-cid-fb2j7reu]{background:var(--bg-color);padding:12px 8px;border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;border:1px solid var(--border-color)}.sb-val[data-astro-cid-fb2j7reu]{font-size:1.3rem;font-weight:700;color:var(--text-main);line-height:1.2}.sb-lbl[data-astro-cid-fb2j7reu]{font-size:.7rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:4px;line-height:1.3}.streak-modal{border:none;border-radius:var(--radius-lg);box-shadow:0 20px 40px #00000040;padding:0;max-width:650px;width:95vw;background:transparent;color:var(--text-main);margin:auto;overflow:visible}.streak-modal::backdrop{background:#0f172acc;backdrop-filter:blur(4px)}.sm-content{display:flex;flex-direction:column;position:relative;background:var(--card-bg);border-radius:var(--radius-lg);overflow:hidden}.anon-warning{background:#ea580c1a;border:1px solid rgba(234,88,12,.3);padding:12px;border-radius:var(--radius-md);margin-bottom:20px;font-size:.9rem;color:var(--text-main)}.anon-warning a{color:var(--primary-color);font-weight:700;text-decoration:none}.anon-warning a:hover{text-decoration:underline}.sm-header{background:linear-gradient(135deg,#ea580c1a,#2563eb0d);border-bottom:1px solid var(--border-color);padding:20px 24px 24px}:root.dark .sm-header{background:linear-gradient(135deg,#ea580c26,#2563eb1a)}.header-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-info h3{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-main)}.close-btn{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--text-muted);line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-main)}.streak-stats-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.streak-stat-box{display:flex;align-items:center;gap:12px;background:var(--card-bg);padding:16px;border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:0 2px 8px #00000005}.streak-stat-box.active{border-color:#f9731666;box-shadow:0 4px 12px #f973161a}.sm-stat-icon{font-size:2rem;line-height:1}.sm-stat-col{display:flex;flex-direction:column}.sm-stat-val{font-size:1.8rem;font-weight:800;color:var(--text-main);line-height:1.1;margin-bottom:2px}.sm-stat-lbl{font-size:.8rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.sm-stat-sub{font-size:.75rem;color:var(--text-muted);margin-top:4px}.sm-body{padding:24px;position:relative}.chart-section h4{font-size:1rem;color:var(--text-main);margin-bottom:16px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.bar-chart-wrapper{display:flex;height:180px;align-items:stretch;margin-top:16px;margin-bottom:32px}.y-axis-labels{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding-right:8px;font-size:.75rem;color:var(--text-muted);font-weight:600;width:40px;flex-shrink:0;border-right:2px solid var(--border-color);padding-bottom:24px}.chart-graph-area{flex:1;display:flex;align-items:flex-end;justify-content:space-around;border-bottom:2px solid var(--border-color);padding-bottom:0;margin-bottom:24px;position:relative}.sm-empty-chart{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text-muted)}.bc-col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;position:relative;cursor:pointer;transition:opacity .2s}.bc-col:hover{opacity:.8}.bc-bars-inner{width:100%;max-width:45px;display:flex;align-items:flex-end;justify-content:center;gap:2px;height:100%}.bc-bar-wrap{flex:1;display:flex;flex-direction:column;justify-content:flex-end;height:100%;border-radius:4px 4px 0 0;overflow:hidden;background:#00000008}:root.dark .bc-bar-wrap{background:#ffffff08}.bc-seg{width:100%;transition:height .5s ease-out;min-height:4px;border-radius:2px 2px 0 0}.bc-seg-l{background:#3b82f6}.bc-seg-v{background:#10b981}.bc-seg-d{background:#f59e0b}.bc-lbl{position:absolute;bottom:-22px;font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;width:100%;text-align:center}.heatmap-container{width:100%;overflow-x:auto;padding-bottom:8px}.hm-grid{display:grid;grid-template-rows:repeat(7,12px);grid-auto-columns:12px;grid-auto-flow:column;gap:3px}.hm-cell{width:12px;height:12px;border-radius:2px;cursor:pointer;transition:transform .1s}.hm-cell:hover{transform:scale(1.2);box-shadow:0 0 4px #0003;z-index:10}.hm-cell.first-of-month{border:1px solid #22c55e!important}.lvl-0{background:#00000005;border:1px solid rgba(0,0,0,.05)}.lvl-1{background:#fed7aa;border:1px solid #fdba74}.lvl-2{background:#fb923c;border:1px solid #f97316}.lvl-3{background:#ea580c;border:1px solid #c2410c}.lvl-4{background:#9a3412;border:1px solid #7c2d12}:root.dark .lvl-0{background:#ffffff05;border:1px solid rgba(255,255,255,.05)}:root.dark .lvl-1{background:#7c2d12;border-color:#9a3412}:root.dark .lvl-2{background:#c2410c;border-color:#ea580c}:root.dark .lvl-3{background:#f97316;border-color:#fb923c}:root.dark .lvl-4{background:#fdba74;border-color:#fed7aa}.heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:12px}.hm-scale{display:flex;gap:3px}.hm-tooltip{position:fixed;background:var(--text-main);color:var(--card-bg);padding:8px 12px;border-radius:6px;font-size:.85rem;font-weight:500;pointer-events:none;z-index:1000000;box-shadow:0 4px 12px #0003;transform:translate(-50%,-100%);margin-top:-8px;white-space:pre-line;text-align:center}.hm-tooltip.hidden{display:none}.countdown-section{margin-top:32px;display:flex;justify-content:center;align-items:center;border-top:1px dashed var(--border-color);padding-top:24px;opacity:.8}.cd-lbl{font-size:.85rem;color:var(--text-muted);font-weight:400}.countdown-timer{font-family:monospace;font-size:.95rem;font-weight:500;color:var(--text-muted);letter-spacing:1px;margin-left:8px;transition:color .2s}.countdown-timer.urgent{color:#f97316!important;font-weight:700!important;opacity:1}@media(max-width:600px){.streak-stats-row{grid-template-columns:1fr}}@font-face{font-family:UseYuBrand;src:url(/fonts/useyu.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}html.i18n-loading body{opacity:0!important;visibility:hidden!important}body{transition:opacity .2s ease-in}#page-loader{position:fixed;top:0;left:0;height:3px;background:var(--primary-color);z-index:999999;width:0%;transition:width .2s ease,opacity .2s ease;opacity:0;pointer-events:none}.profile-wrapper{position:relative;margin-left:12px;display:flex;align-items:center}.profile-circle{width:36px;height:36px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;cursor:pointer;border:none;transition:transform .1s;position:relative}.profile-circle:active{transform:scale(.95)}.offline-indicator{position:absolute;top:-2px;left:-2px;width:14px;height:14px;background:#ef4444;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--card-bg);z-index:10;box-shadow:0 1px 3px #0003}.offline-indicator svg{width:8px;height:8px}.offline-indicator.hidden{display:none}.premium-crown{position:absolute;bottom:-6px;right:-6px;width:18px;height:18px;color:#eab308;background:var(--card-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #00000026;border:1px solid var(--border-color)}.premium-crown svg{width:12px;height:12px;fill:currentColor}.premium-crown.hidden{display:none}.profile-menu{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 10px 25px #0000001a;display:flex;flex-direction:column;z-index:1000;overflow:hidden}.profile-menu.hidden{display:none}.profile-menu a,.profile-menu button{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:none;border:none;cursor:pointer;color:var(--text-main);font-size:.95rem;text-decoration:none;font-family:inherit;width:100%;transition:background .2s}.profile-menu a:hover,.profile-menu button:hover{background:var(--bg-color);color:var(--primary-color)}.menu-divider{height:1px;background:var(--border-color);margin:4px 0;width:100%}.menu-icon-wrap{display:flex;align-items:center;gap:10px}.menu-val{font-size:.8rem;color:var(--text-muted);font-weight:500}.lang-badge{display:inline-flex;align-items:center;justify-content:center;background:#2563eb1a;color:var(--primary-color);font-size:.6rem;font-weight:700;border-radius:4px;padding:2px 4px;text-transform:lowercase}:root.dark .lang-badge{background:#60a5fa26;color:#93c5fd}.so-timer{width:20px;height:20px;position:relative;flex-shrink:0;transform:rotate(-90deg)}.so-bg{fill:none;stroke:var(--border-color);stroke-width:3}.so-fill{fill:none;stroke:#ef4444;stroke-width:3;stroke-dasharray:63;stroke-dashoffset:0;transition:stroke-dashoffset 6s linear}.so-timer.animating .so-fill{stroke-dashoffset:63}.so-text{color:#ef4444;font-weight:600}.so-text.idle{color:var(--text-main);font-weight:400}.so-btn:hover .so-text.idle{color:#ef4444}.lock-icon{font-size:.8rem;opacity:.5;display:none}html:not(.is-authenticated) .auth-req-link .lock-icon{display:inline-block}:root.dark .xp-badge,:root.dark .streak-badge{background:#0003}.xp-badge:hover,.streak-badge:hover{background:var(--bg-color);transform:scale(1.05)}.xp-badge.active{border-color:#9333ea4d;background:#9333ea0d}.streak-badge.active{border-color:#f973164d;background:#f973160d}.xp-icon-text{font-size:.55rem;font-weight:800;text-transform:uppercase;color:#a855f7;letter-spacing:.05em;margin-bottom:-1px}.xp-count,.streak-count{font-size:.8rem;font-weight:700;color:var(--text-main);display:inline-flex;overflow:hidden}.streak-icon{font-size:.6rem;margin-top:-1px}.xp-badge.hidden,.streak-badge.hidden{display:none}.lang-modal{border:none;border-radius:var(--radius-lg);box-shadow:0 10px 30px #0003;padding:0;max-width:400px;width:90vw;background:var(--card-bg);color:var(--text-main);margin:auto;overflow:hidden}.lang-modal::backdrop{background:#00000080;backdrop-filter:blur(2px)}.lm-header{padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-color);display:flex;justify-content:space-between;align-items:center}.lm-header h3{font-size:1.15rem;margin:0;font-weight:600}.lm-body{padding:16px 20px;max-height:50vh;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.lm-opt{appearance:none;-webkit-appearance:none;display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-size:1rem;font-weight:500;background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-main);font-family:inherit}.lm-opt:hover{background:var(--bg-color);border-color:var(--primary-color)}.lm-opt.selected{background:#2563eb0d;color:var(--primary-color);border:1px solid rgba(37,99,235,.3);box-shadow:0 2px 8px #2563eb1a}:root.dark .lm-opt.selected{background:#60a5fa1a;border-color:#60a5fa4d;box-shadow:0 2px 8px #0003}.lm-check{opacity:0;color:var(--primary-color);font-weight:700}.lm-opt.active-lang .lm-check{opacity:1}.lm-actions{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px;background:var(--bg-color)}.close-btn{appearance:none;background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);transition:color .2s,background .2s;padding:4px;display:flex;align-items:center;justify-content:center;line-height:1;border-radius:4px}.close-btn:hover{color:var(--text-main);background:#64748b1a}.info-btn{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--border-color);color:var(--text-muted);border:none;font-size:.75rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.info-btn:hover{background:var(--primary-color);color:#fff}.btn-cancel{appearance:none;background:transparent;border:none;color:var(--text-muted);font-weight:600;cursor:pointer;padding:10px 16px;font-size:.95rem;transition:color .2s,background .2s;font-family:inherit;border-radius:var(--radius-md)}.btn-cancel:hover{color:var(--text-main);background:#64748b1a}.btn-submit{appearance:none;background:var(--primary-color);color:#fff;border:none;padding:10px 24px;border-radius:9999px;font-weight:600;cursor:pointer;transition:background .2s,box-shadow .2s;font-size:.95rem;font-family:inherit;box-shadow:0 2px 4px #2563eb33}.btn-submit:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2563eb4d}.pwa-update-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#1e293b;color:#f8fafc;padding:16px 24px;border-radius:var(--radius-lg);font-weight:500;font-size:.95rem;box-shadow:0 10px 25px #0000004d;z-index:100000;display:flex;align-items:center;justify-content:space-between;gap:16px;min-width:320px;animation:slideUp .3s ease forwards;border:1px solid #334155}.pwa-update-toast button{background:var(--primary-color);color:#fff;border:none;padding:8px 16px;border-radius:999px;font-weight:700;cursor:pointer;transition:background .2s}.pwa-update-toast button:hover{background:var(--primary-hover)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--bg-color: #f1f5f9;--text-main: #0f172a;--text-muted: #64748b;--border-color: #e2e8f0;--card-bg: #ffffff;--bg-hl-f1: #fce7f3;--text-hl-f1: #9d174d;--bg-hl-f2: #fef9c3;--text-hl-f2: #854d0e;--bg-hl-f3: #f3e8ff;--text-hl-f3: #6b21a8;--bg-hl-m1: #dbeafe;--text-hl-m1: #1e40af;--bg-hl-m2: #dcfce7;--text-hl-m2: #166534;--bg-hl-m3: #ffedd5;--text-hl-m3: #9a3412;--bg-hl-n1: #ccfbf1;--text-hl-n1: #0f766e;--bg-hl-n2: #cffafe;--text-hl-n2: #155e75;--bg-hl-n3: #e0e7ff;--text-hl-n3: #3730a3;--bg-hl-default: #f1f5f9;--text-hl-default: #475569;--bg-hl-narrator: transparent;--text-hl-narrator: #64748b;--border-hl-narrator: #e2e8f0;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-md: .5rem;--radius-lg: .75rem;--sidebar-width: 280px}:root.dark{--primary-color: #3b82f6;--primary-hover: #60a5fa;--bg-color: #0a1225;--text-main: #f8fafc;--text-muted: #94a3b8;--border-color: #1e293b;--card-bg: #10192c;--bg-hl-f1: rgba(236, 72, 153, .25);--text-hl-f1: #fbcfe8;--bg-hl-f2: rgba(234, 179, 8, .25);--text-hl-f2: #fef08a;--bg-hl-f3: rgba(168, 85, 247, .25);--text-hl-f3: #e9d5ff;--bg-hl-m1: rgba(59, 130, 246, .25);--text-hl-m1: #bfdbfe;--bg-hl-m2: rgba(34, 197, 94, .25);--text-hl-m2: #bbf7d0;--bg-hl-m3: rgba(249, 115, 22, .25);--text-hl-m3: #fed7aa;--bg-hl-n1: rgba(20, 184, 166, .25);--text-hl-n1: #99f6e4;--bg-hl-n2: rgba(6, 182, 212, .25);--text-hl-n2: #a5f3fc;--bg-hl-n3: rgba(99, 102, 241, .25);--text-hl-n3: #c7d2fe;--bg-hl-default: rgba(100, 116, 139, .25);--text-hl-default: #cbd5e1;--bg-hl-narrator: transparent;--text-hl-narrator: #94a3b8;--border-hl-narrator: #334155;color-scheme:dark}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-color);color:var(--text-main);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden}@media(max-width:899px){.hide-mobile{display:none!important}}.mobile-only{display:none!important}@media(max-width:899px){.mobile-only{display:flex!important}}rt,.sm-pinyin,.fc-pinyin,.fc-jyutping,.mfc-rom,.tt-rom{user-select:none;-webkit-user-select:none}.brand-text{font-family:UseYuBrand,sans-serif;font-size:1.6rem;font-weight:400;color:var(--primary-color);transition:color .3s,text-shadow .3s;letter-spacing:-.02em}:root.dark .brand-text{color:#60a5fa;text-shadow:0 0 12px rgba(96,165,250,.3)}.footer-brand-text{font-family:UseYuBrand,sans-serif;font-size:2.5rem;color:var(--text-muted);filter:grayscale(100%);opacity:.6;transition:opacity .3s,text-shadow .3s}:root.dark .footer-brand-text{color:#475569;text-shadow:0 0 10px rgba(255,255,255,.05);opacity:.8}.app-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--card-bg);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:60;height:60px;box-shadow:0 1px 3px #00000005}.nav-toggle-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:color .2s}.nav-toggle-btn:hover{color:var(--primary-color)}.logo a{display:flex;align-items:center;gap:8px;text-decoration:none}.header-left{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0;padding-right:8px}.persistent-controls{display:flex;align-items:center;gap:4px;margin-left:auto}.xp-badge,.streak-badge{display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 6px;gap:4px;border-radius:16px;background:#ffffff0d;border:1px solid var(--border-color);cursor:pointer;transition:all .2s;font-family:system-ui,sans-serif}@media(min-width:600px){.header-left{gap:var(--spacing-md);padding-right:16px}.persistent-controls{gap:12px}.xp-badge,.streak-badge{padding:0 10px}}.app-layout{display:flex;flex:1;position:relative;width:100vw}.app-sidebar-wrapper{width:0;transition:width .3s ease;flex-shrink:0;position:relative}.pull-tab-wrapper{position:absolute;z-index:55;height:100%;pointer-events:none}.pull-tab{display:none;position:fixed;top:50%;left:var(--sidebar-width);transform:translateY(-50%);width:24px;height:48px;background:var(--card-bg);border:1px solid var(--border-color);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;transition:left .3s ease;box-shadow:2px 0 4px #0000000d;color:var(--text-muted);pointer-events:auto}.pull-tab:hover{color:var(--primary-color)}body.sidebar-closed .pull-tab{left:0}body.sidebar-closed .pull-tab .pt-icon{transform:rotate(180deg)}.main-wrapper{flex:1;display:flex;flex-direction:column;min-height:calc(100vh - 60px);min-width:0}.app-content{flex:1 0 auto;padding:var(--spacing-md);width:100%;max-width:100%;min-height:100vh;margin:0 auto;transition:max-width .3s ease}.app-footer{flex-shrink:0;padding:40px 20px 20px;border-top:1px solid var(--border-color);background:var(--bg-color);width:100%}.footer-content{display:flex;flex-direction:column;gap:2rem;max-width:850px;margin:0 auto}@media(min-width:600px){.footer-content{flex-direction:row;justify-content:space-between}}.footer-brand{flex:1;max-width:400px}.footer-desc{font-size:.9rem;color:var(--text-muted);margin-top:1rem;line-height:1.6}.footer-links{display:flex;flex-direction:column;gap:.75rem}.footer-links a{color:var(--text-muted);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s}.footer-links a:hover{color:var(--primary-color)}.footer-bottom{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:3rem;padding-top:1rem;border-top:1px dashed var(--border-color)}@media(min-width:900px){.app-sidebar-wrapper{width:var(--sidebar-width)}.pull-tab{display:flex;align-items:center;justify-content:center}.nav-toggle-btn{display:none!important}.app-content{max-width:850px;padding-top:var(--spacing-xl)}body.sidebar-closed .app-sidebar-wrapper{width:0;overflow:visible}body.sidebar-closed #sidebar-container{transform:translate(-100%)}}.tts-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-color);border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;border-radius:50%;transition:all .2s;width:36px;height:36px;padding:7px}.tts-btn.btn-md{width:40px;height:40px;padding:8px}.tts-btn.btn-sm{width:30px;height:30px;padding:6px}.tts-btn:hover{background:var(--border-color);color:var(--text-main)}.tts-btn:active{transform:scale(.95)}.tts-btn svg{width:100%;height:100%;transition:opacity .2s}.tts-btn.playing{background:#2563eb1a;color:var(--primary-color);border-color:#2563eb4d;animation:pulse-ring 2s infinite}.tts-btn.loading svg{opacity:0}.tts-btn.loading:after{content:"";position:absolute;width:20px;height:20px;border:2px solid var(--primary-color);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.hw-spinner{position:absolute;top:50%;left:50%;margin-top:-12px;margin-left:-12px;width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;z-index:5}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-ring{0%{box-shadow:0 0 #2563eb66}70%{box-shadow:0 0 0 6px #2563eb00}to{box-shadow:0 0 #2563eb00}}.hidden{display:none!important}#mobile-console-wrapper{position:fixed;bottom:20px;right:20px;z-index:999999}.mc-toggle{width:48px;height:48px;border-radius:50%;background:#0f172a;color:#fff;font-size:1.5rem;border:2px solid rgba(255,255,255,.2);cursor:pointer;box-shadow:0 4px 12px #0000004d;display:flex;align-items:center;justify-content:center}.mc-panel{position:absolute;bottom:60px;right:0;width:90vw;max-width:400px;height:50vh;background:#0f172a;border:1px solid #334155;border-radius:8px;box-shadow:0 10px 25px #00000080;display:flex;flex-direction:column;overflow:hidden}.mc-header{background:#1e293b;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #334155;color:#f8fafc;font-size:.85rem;font-weight:700}.mc-btn{background:#334155;border:none;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;cursor:pointer;margin-left:6px}.mc-logs{flex:1;overflow:scroll;padding:8px;font-family:monospace;font-size:.8rem;color:#e2e8f0;display:flex;flex-direction:column;gap:4px}.mc-log-entry{padding:4px;border-bottom:1px solid rgba(255,255,255,.05);word-break:break-all}.mc-warn{color:#fcd34d}.mc-error{color:#fca5a5}.persistent-loading-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%) translateY(20px) scale(.95);background:var(--primary-color);color:#fff;padding:12px 24px;border-radius:999px;font-weight:600;font-size:.95rem;box-shadow:0 10px 25px #2563eb66;display:flex;align-items:center;gap:12px;z-index:2147483647;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.persistent-loading-toast.show{opacity:1;transform:translate(-50%) translateY(0) scale(1)}.plt-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
