.loading-indicator[data-v-fbc92018]{display:inline-flex;align-items:center;justify-content:center;gap:8px}.loading-indicator__dot[data-v-fbc92018]{width:12px;height:12px;border-radius:999px;background:linear-gradient(135deg,#ffab8e,#ff7f63);box-shadow:0 10px 18px #ff7f6333;animation:loading-indicator-bounce-fbc92018 .9s ease-in-out infinite}@keyframes loading-indicator-bounce-fbc92018{0%,to{transform:translateY(0) scale(.9);opacity:.56}50%{transform:translateY(-5px) scale(1);opacity:1}}.page-loading-overlay[data-v-48ebb5f1]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:20px;border-radius:inherit;background:#fffcf9b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.page-loading-overlay__panel[data-v-48ebb5f1]{min-width:min(240px,100%);display:grid;justify-items:center;gap:14px;padding:24px 28px;border-radius:24px;background:#ffffffe6;box-shadow:0 24px 48px #70594a1f;text-align:center}.page-loading-overlay__text[data-v-48ebb5f1]{margin:0;color:#6a7488;font-weight:700;line-height:1.5}.page-loading-fade-enter-active[data-v-48ebb5f1],.page-loading-fade-leave-active[data-v-48ebb5f1]{transition:opacity .2s ease}.page-loading-fade-enter-from[data-v-48ebb5f1],.page-loading-fade-leave-to[data-v-48ebb5f1]{opacity:0}.auth-dialog-body[data-v-b180db1f]{position:relative;display:grid;gap:14px;padding-top:12px}.auth-copy[data-v-b180db1f],.auth-hint[data-v-b180db1f],.auth-status[data-v-b180db1f]{margin:0;line-height:1.6}.auth-copy[data-v-b180db1f],.auth-hint[data-v-b180db1f]{color:var(--muted)}.auth-field[data-v-b180db1f]{display:grid;gap:8px}.auth-field span[data-v-b180db1f]{font-size:14px;font-weight:700;color:var(--ink)}.code-row[data-v-b180db1f]{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.auth-input[data-v-b180db1f]{width:100%;min-height:44px;padding:0 14px;border:1px solid rgba(255,143,107,.22);border-radius:14px;background:#ffffffe6;color:var(--ink);outline:none}.auth-input[data-v-b180db1f]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ff8f6b1f}.send-code-button[data-v-b180db1f],.dialog-button[data-v-b180db1f]{border:none;cursor:pointer;font-weight:700;flex:0 0 auto}.send-code-button[data-v-b180db1f]{min-width:120px;min-height:44px;padding:0 16px;border-radius:999px;background:#fff1e8;color:var(--accent-dark)}.send-code-button[data-v-b180db1f]:disabled,.dialog-button[data-v-b180db1f]:disabled{cursor:not-allowed;opacity:.7}.auth-status[data-v-b180db1f]{color:#2d7d6a}.auth-status.error[data-v-b180db1f]{color:#d65f45}.auth-actions[data-v-b180db1f]{display:flex;justify-content:flex-end;gap:10px;width:100%}.dialog-button[data-v-b180db1f]{min-width:110px;height:42px;border-radius:999px}.ghost-button[data-v-b180db1f]{background:#fff3ec;color:#9a5c40}.primary-button[data-v-b180db1f]{background:linear-gradient(135deg,#ff936f,#ff775a);color:#fff;box-shadow:0 12px 22px #ff775a33}@media (max-width: 560px){.code-row[data-v-b180db1f]{grid-template-columns:1fr}.send-code-button[data-v-b180db1f]{width:100%}}.login-entry[data-v-c788d2de],.logout-button[data-v-c788d2de],.band-chip[data-v-c788d2de],.arrow-btn[data-v-c788d2de]{border:none;cursor:pointer;font-weight:700;flex:0 0 auto}.login-entry[data-v-c788d2de]{min-height:42px;padding:0 18px;border-radius:999px;background:linear-gradient(135deg,#ff9d7b,#ff7e63);color:#fff;box-shadow:0 10px 24px #ff7f6333}.user-tools[data-v-c788d2de]{display:flex;align-items:center;gap:10px}.help-entry[data-v-c788d2de]{width:28px;height:28px;border:none;display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;color:#8f776b;cursor:pointer}.help-entry[data-v-c788d2de]:hover{color:var(--accent-dark)}.logout-copy[data-v-c788d2de],.target-band-copy[data-v-c788d2de]{margin:0;color:#42526a;line-height:1.7}.help-title[data-v-c788d2de],.help-copy[data-v-c788d2de],.help-section-title[data-v-c788d2de],.help-warning[data-v-c788d2de],.help-confirm-copy[data-v-c788d2de]{margin:0}.help-dialog[data-v-c788d2de]{display:grid;gap:14px;padding-top:12px}.help-card[data-v-c788d2de],.help-more-panel[data-v-c788d2de]{display:grid;gap:12px}.help-section-head[data-v-c788d2de]{display:flex;align-items:center;justify-content:space-between;gap:12px}.help-title[data-v-c788d2de],.help-section-title[data-v-c788d2de]{font-size:16px;font-weight:700;color:#20313f}.help-copy[data-v-c788d2de],.help-warning[data-v-c788d2de],.help-confirm-copy[data-v-c788d2de]{color:#5f6f7d;line-height:1.7}.help-qr[data-v-c788d2de]{width:min(240px,100%);justify-self:center;border-radius:20px;background:#fff;border:1px solid rgba(255,143,107,.14)}.help-more-link[data-v-c788d2de],.help-back-link[data-v-c788d2de]{justify-self:start;padding:0;border:none;background:transparent;color:#8f776b;font-size:13px;text-decoration:underline;cursor:pointer}.help-back-link[data-v-c788d2de]{justify-self:auto;flex:0 0 auto}.help-actions[data-v-c788d2de]{display:flex;justify-content:flex-end;gap:10px;width:100%}.help-danger-button[data-v-c788d2de],.help-secondary-button[data-v-c788d2de],.help-cancel-button[data-v-c788d2de]{min-width:124px;min-height:42px;padding:0 16px;border:none;border-radius:999px;font-weight:700;cursor:pointer}.help-danger-button[data-v-c788d2de]{background:linear-gradient(135deg,#cf6a56,#b94e4a);color:#fff}.help-secondary-button[data-v-c788d2de]{background:#fff3ec;color:#9a5c40}.help-cancel-button[data-v-c788d2de]{background:linear-gradient(135deg,#e38d29,#cb6d16);color:#fff;box-shadow:0 12px 22px #cb6d162e}.logout-copy[data-v-c788d2de],.target-band-dialog[data-v-c788d2de]{padding-top:12px}.target-band-dialog[data-v-c788d2de]{display:grid;gap:16px}.band-carousel[data-v-c788d2de]{display:grid;grid-template-columns:34px minmax(0,1fr) 34px;gap:6px;align-items:center}.arrow-btn[data-v-c788d2de]{width:34px;height:34px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;background:#fff2eb;color:var(--accent-dark)}.arrow-btn[data-v-c788d2de]:disabled,.band-chip[data-v-c788d2de]:disabled{cursor:not-allowed;opacity:.62}.band-grid[data-v-c788d2de]{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;scroll-behavior:smooth}.band-grid[data-v-c788d2de]::-webkit-scrollbar{display:none}.band-chip[data-v-c788d2de]{min-width:50px;height:32px;padding:0 8px;border:1px solid rgba(255,143,107,.2);border-radius:10px;background:#fff;color:var(--accent-dark);font-size:12px;font-weight:800}.band-chip.active[data-v-c788d2de]{background:var(--accent);border-color:transparent;color:#fff}.logout-actions[data-v-c788d2de]{display:flex;justify-content:flex-end;gap:10px;width:100%}.logout-button[data-v-c788d2de]{min-width:110px;height:42px;border-radius:999px}.ghost-button[data-v-c788d2de]{background:#fff3ec;color:#9a5c40}.primary-button[data-v-c788d2de]{background:linear-gradient(135deg,#ff936f,#ff775a);color:#fff;box-shadow:0 12px 22px #ff775a33}.logout-button[data-v-c788d2de]:disabled{cursor:not-allowed;opacity:.62;box-shadow:none}.session-banner[data-v-c788d2de]{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:12px 16px;border-radius:18px;background:#fff4e8;border:1px solid rgba(255,143,107,.24);color:#9a5c40}.session-banner-copy[data-v-c788d2de]{min-width:0;line-height:1.6}.session-banner-dismiss[data-v-c788d2de]{border:none;border-radius:999px;padding:8px 14px;background:#ffd8c7;color:#8e5037;font-weight:700;cursor:pointer;flex:0 0 auto}@media (max-width: 640px){.session-banner[data-v-c788d2de]{align-items:flex-start;flex-wrap:wrap}}[data-v-c788d2de] .n-dialog__close{display:none}:root{--ink: #243042;--muted: #72809a;--paper: #fbf7f3;--surface: rgba(255, 255, 255, .92);--surface-strong: #ffffff;--accent: #ff8f6b;--accent-dark: #d96946;--accent-soft: #fff0e8;--mint: #7cc8b6;--mint-soft: #eaf8f4;--line: rgba(146, 134, 120, .18);--shadow: 0 24px 60px rgba(66, 44, 31, .12);--shadow-soft: 0 14px 36px rgba(66, 44, 31, .08)}*{box-sizing:border-box}html{background:#f8efe8}body{margin:0;min-width:320px;color:var(--ink);font-family:Inter,Segoe UI,PingFang SC,Microsoft YaHei,Arial,sans-serif}button,input,textarea,select{font:inherit}a{color:inherit}#app{min-height:100vh;padding:14px;display:flex;background:linear-gradient(180deg,#f8fbff80,#fff7f1ad),url(/assets/practice_bg-Bfae61Rj.webp) center / cover no-repeat fixed}.app-shell{width:100%;max-width:1080px;margin:0 auto;min-height:calc(100vh - 28px);display:flex;flex-direction:column;gap:18px;flex:1}.app-header{top:14px;z-index:20;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:22px;background:#ffffffc2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-soft);min-width:0}.brand-link{min-width:0;text-decoration:none}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),#ffb283);color:#fff;font-size:18px;font-weight:700;letter-spacing:.08em;box-shadow:inset 0 1px #ffffff47}.brand-meta{display:grid;min-width:0}.brand-title{font-size:clamp(17px,2vw,20px);font-weight:700;color:var(--ink)}.brand-subtitle{font-size:13px;color:var(--muted)}.user-entry{border:none;background:var(--surface-strong);border-radius:999px;padding:8px 10px 8px 8px;display:flex;align-items:center;gap:10px;cursor:pointer;box-shadow:0 8px 22px #422c1f1a;min-width:0}.user-avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),#ffba92);color:#fff;font-weight:800}.user-copy{display:grid;text-align:left;line-height:1.15}.user-copy strong{font-size:14px;color:var(--ink)}.user-copy small{font-size:12px;color:var(--muted)}.app-main{display:flex;flex-direction:column;gap:20px;flex:1;min-width:0;min-height:0;overflow:visible}.app-main>*{width:100%;min-width:0}.app-page{min-width:0;width:100%}.app-page>*{min-width:0}.app-page-fill{flex:1 1 auto;min-height:0;display:flex}.app-page-fill>*{flex:1 1 auto;min-height:0}.app-footer{display:grid;gap:8px;padding:18px 20px 26px;color:var(--muted);border-top:1px solid var(--line)}.app-footer strong{color:var(--ink)}.app-footer p{margin:6px 0 0}.footer-meta{display:flex;flex-wrap:wrap;gap:12px 18px;font-size:13px}@media (max-width: 720px){#app{padding:10px}.app-shell{gap:14px}.app-header{top:10px;padding:12px;border-radius:18px}.brand-subtitle,.user-copy small{display:none}.user-entry{padding-right:8px}.app-footer{padding-inline:8px}}@media (max-width: 560px){.app-header{padding:10px}.brand{gap:10px}.brand-mark{width:38px;height:38px;border-radius:14px;font-size:15px}.brand-title{font-size:15px}.user-entry{padding:6px;gap:0}.user-copy strong{display:none}.user-avatar{width:34px;height:34px}}
