.header[data-v-65976c1c]{display:flex;align-items:center;justify-content:space-between;gap:12px}.header h3[data-v-65976c1c]{margin:0}.close[data-v-65976c1c]{border:none;background:transparent;cursor:pointer}.form[data-v-65976c1c]{display:flex;flex-direction:column;gap:12px;padding:4px 0 6px}.tabs[data-v-65976c1c]{display:flex;gap:8px;padding:0 0 8px}.tabs button[data-v-65976c1c]{border:1px solid #e5e7eb;background:#fff;padding:8px 12px;border-radius:10px;cursor:pointer;font-weight:700;color:#475569}.tabs button.active[data-v-65976c1c]{border-color:var(--vg-primary);color:var(--vg-primary);background:#eef2ff}.method-toggle[data-v-65976c1c]{display:flex;gap:8px}.method-toggle button[data-v-65976c1c]{border:1px solid #e5e7eb;background:#fff;padding:6px 10px;border-radius:10px;cursor:pointer;font-weight:700;color:#475569;font-size:12px}.method-toggle button.active[data-v-65976c1c]{border-color:var(--vg-primary);color:var(--vg-primary);background:#eef2ff}.link[data-v-65976c1c]{border:none;background:transparent;color:var(--vg-primary);cursor:pointer;font-weight:600}.small-link[data-v-65976c1c]{font-size:12px}.switch[data-v-65976c1c]{text-align:center;color:#6b7280;font-size:12px}.sms-row[data-v-65976c1c]{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.sms-btn[data-v-65976c1c]{height:48px}.field[data-v-65976c1c] .t-input__inner{height:44px;border-radius:12px}.error[data-v-65976c1c]{color:#dc2626;font-size:12px;font-weight:600}@media (max-width: 520px){.sms-row[data-v-65976c1c]{grid-template-columns:1fr}.sms-btn[data-v-65976c1c]{width:100%}}.shell[data-v-b392ab62]{--topbar-offset: 68px;min-height:100vh;background:var(--color-bg);color:var(--color-text);padding-top:var(--topbar-offset)}.shell.shell--fullscreen[data-v-b392ab62]{background:#020617;padding-top:0}.topbar[data-v-b392ab62]{position:fixed;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;gap:16px;padding:10px 24px;background:#fff;border-bottom:1px solid var(--color-border);overflow-x:clip}.brand[data-v-b392ab62]{display:inline-flex;align-items:center;gap:10px;font-weight:800;cursor:pointer}.brand-mark[data-v-b392ab62]{width:32px;height:32px;border-radius:10px;background:var(--color-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:.5px}.brand-name[data-v-b392ab62]{font-size:16px;letter-spacing:.2px}.nav[data-v-b392ab62]{display:flex;align-items:center;gap:16px;font-size:13px;font-weight:600}.nav a[data-v-b392ab62]{color:#475569}.nav a.router-link-active[data-v-b392ab62]{color:var(--color-primary)}.spacer[data-v-b392ab62]{flex:1}.actions[data-v-b392ab62]{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}button[data-v-b392ab62]{border:1px solid var(--color-border);background:#fff;padding:8px 14px;border-radius:12px;cursor:pointer;font-weight:600}button.primary[data-v-b392ab62]{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}button.ghost[data-v-b392ab62]{background:#fff;color:#334155}.user-chip[data-v-b392ab62]{display:inline-flex;align-items:center;gap:10px;background:#f8fafc;border:1px solid var(--color-border);border-radius:18px;padding:4px 10px 4px 4px;min-width:0}.avatar[data-v-b392ab62]{width:32px;height:32px;border-radius:50%;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#0f172a}.user-meta[data-v-b392ab62]{display:flex;flex-direction:column;gap:2px;font-size:12px}.muted[data-v-b392ab62]{color:#64748b;font-size:11px}.content[data-v-b392ab62]{padding-bottom:40px}.content.content--fullscreen[data-v-b392ab62]{padding-bottom:0;min-height:100vh;width:100%;overflow:hidden}@media (max-width: 900px){.shell[data-v-b392ab62]{--topbar-offset: 108px}.topbar[data-v-b392ab62]{padding:10px 16px;flex-wrap:wrap}.nav[data-v-b392ab62]{order:3;width:100%;flex-wrap:wrap}}@media (max-width: 640px){.shell[data-v-b392ab62]{--topbar-offset: 156px}.topbar[data-v-b392ab62]{align-items:stretch;gap:10px}.brand[data-v-b392ab62],.actions[data-v-b392ab62],.nav[data-v-b392ab62]{width:100%}.nav[data-v-b392ab62]{justify-content:flex-start}.actions[data-v-b392ab62]{justify-content:stretch}.actions>button[data-v-b392ab62]{flex:1 1 0}.actions .user-chip[data-v-b392ab62]{width:100%}.user-meta[data-v-b392ab62]{min-width:0}}.home[data-v-f352c0a8]{background:var(--color-bg)}.container[data-v-f352c0a8]{max-width:1180px;margin:0 auto;padding:12px 16px 40px}.hero[data-v-f352c0a8]{margin-top:8px;margin-bottom:16px}.hero-inner[data-v-f352c0a8]{background:linear-gradient(145deg,#0b3a9e,#0f4fcf);color:#fff;border-radius:var(--radius-card);padding:26px 28px;box-shadow:var(--shadow-md)}.hero-layout[data-v-f352c0a8]{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,360px);gap:24px;align-items:start}.hero-copy[data-v-f352c0a8],.hero-availability[data-v-f352c0a8]{min-width:0}.hero-title[data-v-f352c0a8]{margin:0;font-size:20px;font-weight:700;line-height:28px}.hero-sub[data-v-f352c0a8]{margin:6px 0 12px;font-size:14px;opacity:.9}.hero-search[data-v-f352c0a8]{display:grid;grid-template-columns:1fr auto;gap:10px;max-width:520px}.hero-tags[data-v-f352c0a8]{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.offline-banner[data-v-f352c0a8]{margin-top:10px;display:inline-flex;align-items:center;gap:10px;font-size:12px;color:var(--accent-gold);font-weight:700;background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);padding:6px 10px;border-radius:999px}.retry[data-v-f352c0a8]{border:none;background:#fff;color:#92400e;padding:4px 10px;border-radius:999px;font-size:11px;cursor:pointer;font-weight:700}.offline-detail[data-v-f352c0a8]{margin-top:6px;font-size:11px;color:#fde68a}.chip[data-v-f352c0a8]{background:#eef2ff;border:1px solid #d6ddff;color:var(--brand-blue);padding:6px 10px;border-radius:9px;font-size:12px;font-weight:600}.card[data-v-f352c0a8]{padding:16px;margin-bottom:14px;border-radius:var(--radius-card);box-shadow:var(--shadow-sm);background:#fff}.section-head[data-v-f352c0a8]{display:flex;justify-content:space-between;align-items:center}.muted.small[data-v-f352c0a8]{font-size:12px}.standby[data-v-f352c0a8]{background:#f4f6fd;border:1px solid #e6e9f5}.standby-row[data-v-f352c0a8]{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(210px,1fr);gap:12px;overflow-x:auto;padding:10px 2px}.standby-swiper[data-v-f352c0a8]{display:none;padding-top:10px}.standby-swiper-slide[data-v-f352c0a8]{padding:2px 2px 20px}.schedule-panel[data-v-f352c0a8]{width:100%}.schedule-picker-shell[data-v-f352c0a8]{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:10px;padding:18px;border-radius:16px;border:1px solid rgba(219,230,255,.55);background:#f8fbfff5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.schedule-title[data-v-f352c0a8]{margin:0;font-size:18px;font-weight:800;color:#0f172a}.schedule-class-select[data-v-f352c0a8],.schedule-picker[data-v-f352c0a8]{width:100%}.schedule-actions[data-v-f352c0a8]{width:100%;display:flex;justify-content:flex-end}.schedule-locked-inner[data-v-f352c0a8]{justify-content:center;gap:12px}.schedule-locked-inner .muted.small[data-v-f352c0a8]{color:#475569}.schedule-empty[data-v-f352c0a8]{margin-top:10px}.teachers .grid[data-v-f352c0a8]{margin-top:12px}.link[data-v-f352c0a8]{border:none;background:transparent;color:var(--color-primary);font-weight:600;cursor:pointer;font-size:13px}.refresh[data-v-f352c0a8]{border:1px solid #e2e8f0;padding:6px 10px;border-radius:999px;background:#fff}.hint[data-v-f352c0a8]{margin-top:8px;font-size:12px;color:#b45309;background:#fff7ed;border:1px solid #fed7aa;padding:8px 10px;border-radius:10px}.dots[data-v-f352c0a8]{display:flex;gap:6px}.dots span[data-v-f352c0a8]{width:6px;height:6px;background:#cbd5e1;border-radius:50%}.footer[data-v-f352c0a8]{text-align:center;padding:22px 0 40px;background:#f6f8ff}.logo[data-v-f352c0a8]{font-weight:800;font-size:16px}.footer-links[data-v-f352c0a8]{display:flex;justify-content:center;gap:12px;margin:10px 0;font-size:12px}.social[data-v-f352c0a8]{display:flex;gap:10px;justify-content:center;margin:8px 0}.copyright[data-v-f352c0a8]{margin-top:4px;font-size:12px}.available-modal-overlay[data-v-f352c0a8]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:16px}.available-modal[data-v-f352c0a8]{width:min(820px,100%);max-height:92vh;display:flex;flex-direction:column;background:#fff;border-radius:18px;border:1px solid #e2e8f0;box-shadow:0 24px 70px #0f172a3d;overflow:hidden}.available-modal-head[data-v-f352c0a8]{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 20px;border-bottom:1px solid #eef2ff}.available-modal-head h3[data-v-f352c0a8]{margin:0;font-size:24px;line-height:1.2}.available-modal-head p[data-v-f352c0a8]{margin:6px 0 0;font-size:13px;color:#475569}.available-close[data-v-f352c0a8]{border:none;background:#f8fafc;color:#334155;border-radius:10px;font-size:24px;width:36px;height:36px;cursor:pointer}.available-modal-body[data-v-f352c0a8]{padding:16px 20px;overflow-y:auto;display:grid;gap:12px}.available-error[data-v-f352c0a8]{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;padding:10px 12px;border-radius:12px;margin:0}.available-list[data-v-f352c0a8]{display:grid;gap:12px}.available-item[data-v-f352c0a8]{border:1px solid #e2e8f0;border-radius:14px;padding:14px;background:#fff;display:grid;gap:14px;grid-template-columns:auto 1fr auto;align-items:center}.available-avatar-wrap[data-v-f352c0a8]{width:76px;height:76px;border-radius:999px;overflow:hidden;border:2px solid #e2e8f0}.available-avatar[data-v-f352c0a8]{width:100%;height:100%;object-fit:cover}.available-avatar.fallback[data-v-f352c0a8]{display:flex;align-items:center;justify-content:center;background:#dbeafe;color:#1e40af;font-weight:800;font-size:22px}.available-name-row[data-v-f352c0a8]{display:flex;align-items:center;gap:8px}.available-name-row h4[data-v-f352c0a8]{margin:0;font-size:18px}.available-rating[data-v-f352c0a8]{font-size:12px;font-weight:700;background:#eef2ff;color:#1e3a8a;border-radius:999px;padding:4px 8px}.available-price[data-v-f352c0a8]{margin:8px 0 0;font-size:13px;color:#334155}.available-cta[data-v-f352c0a8]{display:flex;align-items:center;justify-content:flex-end}.available-modal-foot[data-v-f352c0a8]{border-top:1px solid #eef2ff;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}.pager[data-v-f352c0a8]{display:flex;align-items:center;gap:10px}.pager button[data-v-f352c0a8],.cancel-btn[data-v-f352c0a8]{border:1px solid #e2e8f0;background:#fff;border-radius:10px;padding:7px 12px;cursor:pointer;font-weight:600}.pager button[data-v-f352c0a8]:disabled{opacity:.45;cursor:not-allowed}@media (max-width: 768px){.container[data-v-f352c0a8]{padding:8px 10px 32px}.hero-inner[data-v-f352c0a8]{padding:18px}.hero-layout[data-v-f352c0a8]{grid-template-columns:1fr;gap:16px}.hero-search[data-v-f352c0a8]{grid-template-columns:1fr}.card[data-v-f352c0a8]{padding:12px}.standby-row-desktop[data-v-f352c0a8]{display:none}.standby-swiper[data-v-f352c0a8]{display:block}.standby-swiper[data-v-f352c0a8] .t-swiper{width:100%}.standby-swiper[data-v-f352c0a8] .t-swiper__container{overflow:visible}.standby-swiper[data-v-f352c0a8] .t-swiper__navigation{bottom:0}.standby-swiper[data-v-f352c0a8] .t-swiper__navigation-dots-bar,.standby-swiper[data-v-f352c0a8] .t-swiper__navigation-dots{justify-content:center}.standby-swiper[data-v-f352c0a8] .t-swiper__navigation-item{background:#cbd5e1}.standby-swiper[data-v-f352c0a8] .t-swiper__navigation-item--active{background:#2563eb}.teachers .grid[data-v-f352c0a8]{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.available-item[data-v-f352c0a8]{grid-template-columns:1fr}.available-avatar-wrap[data-v-f352c0a8]{width:64px;height:64px}.available-cta[data-v-f352c0a8]{justify-content:flex-start}.available-modal-foot[data-v-f352c0a8]{flex-direction:column;gap:10px;align-items:stretch}}@media (min-width: 769px){.standby-row-desktop[data-v-f352c0a8]{display:grid}}.teachers-page[data-v-b5d7e681]{background:var(--color-bg);color:var(--color-text)}.container[data-v-b5d7e681]{max-width:1200px;margin:0 auto;padding:16px 18px 40px}.header[data-v-b5d7e681]{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.eyebrow[data-v-b5d7e681]{margin:0 0 6px;text-transform:uppercase;font-size:11px;letter-spacing:1px;color:#64748b}.actions[data-v-b5d7e681]{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ghost[data-v-b5d7e681]{border:1px solid #e2e8f0;padding:8px 12px;border-radius:10px;background:#fff;font-weight:600;cursor:pointer}.hint[data-v-b5d7e681]{margin-top:8px;font-size:12px;color:#b45309;background:#fff7ed;border:1px solid #fed7aa;padding:8px 10px;border-radius:10px}@media (max-width: 768px){.container[data-v-b5d7e681]{padding:12px 12px 32px}}.page[data-v-3b4f7109]{padding:24px}.profile-page[data-v-4395c0e7]{max-width:980px;margin:0 auto;display:flex;flex-direction:column;gap:20px;color:#0f172a}.page-header h1[data-v-4395c0e7]{margin:0;font-size:clamp(1.7rem,2vw,2.2rem);letter-spacing:-.02em}.page-header p[data-v-4395c0e7]{margin:8px 0 0;color:#64748b}.card[data-v-4395c0e7]{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:22px;box-shadow:var(--shadow-sm)}.card h2[data-v-4395c0e7]{margin:0 0 14px;font-size:1.1rem}.section-photo .photo-wrap[data-v-4395c0e7]{display:flex;align-items:center;justify-content:center}.avatar[data-v-4395c0e7]{width:110px;height:110px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#fff;background:linear-gradient(140deg,#3b82f6,#0f4fcf);box-shadow:0 10px 30px #0f4fcf4d}.grid[data-v-4395c0e7]{display:grid;gap:14px}.two-col[data-v-4395c0e7]{grid-template-columns:repeat(2,minmax(0,1fr))}.field[data-v-4395c0e7]{display:grid;gap:6px}.field span[data-v-4395c0e7]{font-size:.82rem;font-weight:700;color:#334155}.field.full[data-v-4395c0e7]{grid-column:1 / -1}input[data-v-4395c0e7],textarea[data-v-4395c0e7]{width:100%;border:1px solid #dbe3ef;border-radius:10px;padding:10px 12px;font-size:.95rem;font-family:inherit;color:#0f172a;background:#fff}input[data-v-4395c0e7]:focus,textarea[data-v-4395c0e7]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}input[readonly][data-v-4395c0e7]{color:#64748b;background:#f8fafc}textarea[data-v-4395c0e7]{resize:vertical}.actions[data-v-4395c0e7]{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding-bottom:12px}.btn[data-v-4395c0e7]{border-radius:12px;border:1px solid transparent;padding:10px 16px;font-weight:700;cursor:pointer}.btn.primary[data-v-4395c0e7]{background:#0f4fcf;color:#fff}.btn.primary[data-v-4395c0e7]:hover:not(:disabled){background:#0b3a9e}.btn.ghost[data-v-4395c0e7]{border-color:#dbe3ef;background:#fff;color:#334155}.btn[data-v-4395c0e7]:disabled{opacity:.65;cursor:not-allowed}.error[data-v-4395c0e7]{margin-right:auto;color:#dc2626;font-size:.82rem;font-weight:700}@media (max-width: 860px){.two-col[data-v-4395c0e7]{grid-template-columns:1fr}.actions[data-v-4395c0e7]{flex-wrap:wrap;justify-content:flex-start}.error[data-v-4395c0e7]{width:100%;margin-right:0}}.calendar-page[data-v-7551f967]{display:grid;grid-template-columns:1fr 280px;gap:18px}.calendar-panel[data-v-7551f967]{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow-sm)}.header[data-v-7551f967]{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.eyebrow[data-v-7551f967]{margin:0 0 6px;text-transform:uppercase;font-size:11px;letter-spacing:1px;color:#64748b}.nav[data-v-7551f967]{display:flex;gap:8px}.nav-btn[data-v-7551f967]{border:1px solid #e2e8f0;background:#fff;padding:6px 10px;border-radius:10px;font-weight:600;cursor:pointer}.nav-btn.ghost[data-v-7551f967]{background:#f3f4f6}.grid[data-v-7551f967]{display:grid;grid-template-columns:70px 1fr;gap:8px;margin-top:12px;overflow-x:auto}.time-col[data-v-7551f967]{display:grid;grid-template-rows:40px repeat(auto-fill,minmax(32px,1fr))}.time-head[data-v-7551f967]{height:40px}.time-cell[data-v-7551f967]{font-size:12px;color:#6b7280;padding:6px 4px;border-bottom:1px solid #f3f4f6}.day-cols[data-v-7551f967]{display:grid;grid-template-rows:40px auto}.day-heads[data-v-7551f967]{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));border-bottom:1px solid #e5e7eb;gap:6px}.day-head[data-v-7551f967]{padding:6px 4px;text-align:center}.day-name[data-v-7551f967]{font-weight:700;font-size:12px;color:#0f172a}.day-date[data-v-7551f967]{font-size:12px;color:#6b7280}.day-rows[data-v-7551f967]{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:6px}.day-col[data-v-7551f967]{display:grid;grid-template-rows:repeat(auto-fill,minmax(32px,1fr));border-right:1px solid #f1f5f9}.day-col[data-v-7551f967]:last-child{border-right:none}.slot-cell[data-v-7551f967]{min-height:32px;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;justify-content:center;padding:2px}.slot[data-v-7551f967]{width:100%;border-radius:8px;padding:4px 6px;font-size:11px;font-weight:600;text-align:center}.slot.upcoming[data-v-7551f967]{background:#e0f2fe;color:#0369a1}.slot.finished[data-v-7551f967]{background:#e5e7eb;color:#6b7280}.upcoming .card[data-v-7551f967]{background:#fff;border-radius:16px;padding:16px;box-shadow:var(--shadow-sm);display:grid;gap:12px}.lesson[data-v-7551f967]{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px;border-radius:12px;background:#f8fafc}.name[data-v-7551f967]{margin:0;font-weight:700}.muted[data-v-7551f967]{color:#64748b}.small[data-v-7551f967]{font-size:12px}.status[data-v-7551f967]{font-size:11px;font-weight:700;text-transform:uppercase;padding:4px 8px;border-radius:999px}.status.upcoming[data-v-7551f967]{background:#dcfce7;color:#166534}.status.finished[data-v-7551f967]{background:#e2e8f0;color:#475569}.note[data-v-7551f967]{font-size:12px;color:#64748b}@media (max-width: 980px){.calendar-page[data-v-7551f967]{grid-template-columns:1fr}}.student-classes[data-v-93bedb69]{max-width:1120px;margin:0 auto;padding:10px 8px 28px;display:grid;gap:20px}.hero[data-v-93bedb69]{display:flex;justify-content:space-between;gap:16px;align-items:end;flex-wrap:wrap}.hero h1[data-v-93bedb69]{margin:0;font-size:34px;font-weight:800;color:#0f172a}.hero p[data-v-93bedb69]{margin:8px 0 0;color:#64748b}.tabs[data-v-93bedb69]{display:inline-flex;gap:6px;background:#94a3b838;padding:6px;border-radius:14px}.qr-section[data-v-93bedb69]{display:flex;justify-content:center}.qr-card[data-v-93bedb69]{width:min(100%,340px);padding:18px;border:1px solid #dbeafe;border-radius:20px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 18px 40px #2563eb14;text-align:center}.qr-eyebrow[data-v-93bedb69]{margin:0;color:#2563eb;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.qr-card h2[data-v-93bedb69]{margin:8px 0 4px;color:#0f172a;font-size:22px;line-height:1.15}.qr-copy[data-v-93bedb69]{margin:0;color:#64748b;font-weight:600;font-size:14px}.qr-frame[data-v-93bedb69]{margin:16px auto 0;width:min(100%,220px);padding:10px;border-radius:18px;background:#fff;box-shadow:inset 0 0 0 1px #e2e8f0}.qr-frame img[data-v-93bedb69]{display:block;width:100%;height:auto;border-radius:12px}.qr-state[data-v-93bedb69]{margin-top:16px;padding:14px;border-radius:14px;background:#f8fafc;color:#64748b;font-weight:700;font-size:14px}.tab[data-v-93bedb69]{border:none;background:transparent;border-radius:10px;padding:10px 14px;color:#475569;font-weight:700;cursor:pointer}.tab.active[data-v-93bedb69]{background:#fff;color:#135bec;box-shadow:0 8px 20px #0f172a14}.cards-wrap[data-v-93bedb69]{display:grid;gap:14px}.class-card[data-v-93bedb69]{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:18px;display:grid;grid-template-columns:minmax(240px,280px) 1fr auto;align-items:center;gap:20px}.instructor-block[data-v-93bedb69]{display:flex;align-items:center;gap:12px}.instructor-block img[data-v-93bedb69]{width:58px;height:58px;object-fit:cover;border-radius:16px;border:3px solid #f1f5f9}.avatar-fallback[data-v-93bedb69]{width:58px;height:58px;border-radius:16px;background:#dbeafe;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center;font-size:20px;font-weight:800}.eyebrow[data-v-93bedb69]{margin:0;color:#94a3b8;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.instructor-block h3[data-v-93bedb69]{margin:2px 0 0;color:#0f172a;font-size:18px}.title-row[data-v-93bedb69]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.title-row h2[data-v-93bedb69]{margin:0;color:#0f172a;font-size:22px;line-height:1.25}.badge[data-v-93bedb69]{border-radius:999px;padding:5px 10px;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#1e40af;background:#2563eb1f}.badge-upcoming[data-v-93bedb69]{color:#1e40af;background:#2563eb1f}.badge-live[data-v-93bedb69]{color:#047857;background:#10b9812e}.badge-completed[data-v-93bedb69]{color:#0369a1;background:#0ea5e92e}.badge-canceled[data-v-93bedb69]{color:#b91c1c;background:#ef444429}.class-meta p[data-v-93bedb69]{margin:6px 0 0;color:#64748b;font-weight:600}.class-meta .time-lines[data-v-93bedb69]{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px}.class-meta .time-lines span[data-v-93bedb69]{line-height:1.2}.actions[data-v-93bedb69]{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.refund-btn[data-v-93bedb69]{border:none;background:transparent;color:#94a3b8;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}.refund-btn[data-v-93bedb69]:hover:not(:disabled){color:#dc2626}.refund-btn[data-v-93bedb69]:disabled{opacity:.5;cursor:not-allowed}.join-btn[data-v-93bedb69]{border:none;border-radius:14px;padding:12px 18px;font-weight:800;color:#fff;background:#135bec;cursor:pointer;min-width:138px}.join-btn[data-v-93bedb69]:hover:not(:disabled){background:#0f4cc8}.join-btn.disabled[data-v-93bedb69],.join-btn[data-v-93bedb69]:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.state-card[data-v-93bedb69]{border:1px solid #e2e8f0;border-radius:16px;background:#fff;padding:20px;color:#475569}.retry-btn[data-v-93bedb69]{margin-top:10px;border:none;border-radius:10px;background:#0f172a;color:#fff;padding:8px 12px;font-weight:700;cursor:pointer}.completed-section[data-v-93bedb69]{display:grid;gap:12px}.section-head[data-v-93bedb69]{display:flex;justify-content:space-between;align-items:center;gap:12px}.section-head h4[data-v-93bedb69]{margin:0;font-size:24px;color:#0f172a}.section-head p[data-v-93bedb69]{margin:4px 0 0;color:#64748b}.link-btn[data-v-93bedb69]{border:none;background:transparent;color:#135bec;font-weight:700;cursor:pointer}.completed-grid[data-v-93bedb69]{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.completed-card[data-v-93bedb69]{border:1px solid #e2e8f0;border-radius:16px;background:#fff;padding:16px}.completed-chip[data-v-93bedb69]{display:inline-flex;border-radius:999px;border:1px solid #bbf7d0;background:#f0fdf4;color:#16a34a;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px}.completed-card h5[data-v-93bedb69]{margin:12px 0 10px;color:#0f172a;font-size:18px}.teacher-row[data-v-93bedb69]{display:flex;align-items:center;gap:8px;margin-bottom:8px}.teacher-row img[data-v-93bedb69],.mini-avatar-fallback[data-v-93bedb69]{width:28px;height:28px;border-radius:999px}.mini-avatar-fallback[data-v-93bedb69]{background:#dbeafe;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}.teacher-row p[data-v-93bedb69],.completed-card p[data-v-93bedb69]{margin:0;color:#64748b;font-size:13px;font-weight:600}@media (max-width: 980px){.class-card[data-v-93bedb69]{grid-template-columns:1fr;gap:12px}.actions[data-v-93bedb69]{justify-content:flex-start}}.style-check[data-v-c281a501]{max-width:980px;margin:0 auto;padding:24px 16px 40px;display:grid;gap:20px}.card[data-v-c281a501]{background:#fff;border-radius:var(--radius-card);border:1px solid var(--color-border);padding:20px;box-shadow:var(--shadow-sm);display:grid;gap:14px}.row[data-v-c281a501]{display:flex;gap:12px;flex-wrap:wrap}button.ghost[data-v-c281a501]{border:1px solid var(--color-border);background:#fff;padding:8px 14px;border-radius:12px;cursor:pointer;font-weight:600}button.primary[data-v-c281a501]{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;padding:8px 14px;border-radius:12px;cursor:pointer;font-weight:600}
