.login-container[data-v-6adbffc7]{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card[data-v-6adbffc7]{width:100%;max-width:400px;margin:20px}.app-title[data-v-6adbffc7]{position:absolute;top:32px;left:50%;transform:translate(-50%);color:#fff;font-size:26px;font-weight:700;text-align:center;padding:4px 12px;text-shadow:0 1px 2px rgba(0,0,0,.35);max-width:90%;line-height:1.4}.login-container[data-v-c4922f47]{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card[data-v-c4922f47]{width:100%;max-width:420px;margin:20px}.app-title[data-v-c4922f47]{position:absolute;top:32px;left:50%;transform:translate(-50%);color:#fff;font-size:26px;font-weight:700;text-align:center;padding:4px 12px;text-shadow:0 1px 2px rgba(0,0,0,.35);max-width:90%;line-height:1.4}.form-select-multi[data-v-c4922f47]{width:100%;min-height:80px;padding:8px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.form-hint[data-v-c4922f47]{display:block;margin-top:4px;color:#6b7280;font-size:12px}.success[data-v-c4922f47]{background:#f0fff4;border:1px solid #c6f6d5;color:#22543d;padding:16px;border-radius:8px;text-align:center}.line-clamp-3[data-v-ddef6e06]{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.teacher-layout[data-v-bb262bc2]{min-height:100vh;background:#f8f9fa}.teacher-header[data-v-bb262bc2]{position:sticky;top:0;height:64px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:30}.header-brand[data-v-bb262bc2]{display:flex;align-items:center;gap:12px;text-decoration:none;color:#1a202c;font-weight:700;font-size:18px}.brand-icon[data-v-bb262bc2]{font-size:24px}.header-right[data-v-bb262bc2]{margin-left:auto}.user-menu[data-v-bb262bc2]{position:relative}.user-menu-btn[data-v-bb262bc2]{display:flex;align-items:center;gap:12px;padding:8px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:background .15s ease}.user-menu-btn[data-v-bb262bc2]:hover{background:#f8fafc}.user-avatar[data-v-bb262bc2]{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.user-info[data-v-bb262bc2]{text-align:left}.user-name[data-v-bb262bc2]{font-size:14px;font-weight:600;color:#1e293b;line-height:1.2}.user-role[data-v-bb262bc2]{font-size:12px;color:#64748b}.dropdown-icon[data-v-bb262bc2]{width:16px;height:16px;color:#94a3b8}.user-dropdown[data-v-bb262bc2]{position:absolute;right:0;top:100%;margin-top:8px;width:240px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:50}.dropdown-header[data-v-bb262bc2]{padding:12px 16px}.dropdown-user-name[data-v-bb262bc2]{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:2px}.dropdown-user-email[data-v-bb262bc2]{font-size:13px;color:#64748b}.dropdown-divider[data-v-bb262bc2]{height:1px;background:#e2e8f0}.dropdown-item[data-v-bb262bc2]{width:100%;display:flex;align-items:center;gap:12px;padding:10px 16px;border:none;background:none;text-align:left;font-size:14px;color:#475569;cursor:pointer;transition:background .15s ease}.dropdown-item[data-v-bb262bc2]:hover{background:#f8fafc}.dropdown-item svg[data-v-bb262bc2]{width:18px;height:18px}.logout-item[data-v-bb262bc2]{color:#dc2626}.logout-item[data-v-bb262bc2]:hover{background:#fef2f2}.teacher-content[data-v-bb262bc2]{padding:24px;max-width:1200px;margin:0 auto}@media (max-width: 768px){.user-info[data-v-bb262bc2]{display:none}.teacher-content[data-v-bb262bc2]{padding:16px}}.feed-shell[data-v-dadf29f1]{max-width:960px;margin:0 auto;padding:28px 16px 36px;display:flex;flex-direction:column;gap:16px}.feed-list[data-v-dadf29f1]{display:grid;gap:16px}.skeleton-stack[data-v-dadf29f1]{display:grid;gap:14px}.skeleton-card[data-v-dadf29f1]{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;box-shadow:0 10px 30px -15px #0f172a26}.skeleton-line[data-v-dadf29f1]{height:12px;background:linear-gradient(90deg,#f4f4f5,#e5e7eb,#f4f4f5);border-radius:8px;margin-bottom:10px;animation:shimmer-dadf29f1 1.4s ease infinite}.skeleton-w-33[data-v-dadf29f1]{width:33%}.skeleton-w-50[data-v-dadf29f1]{width:50%}.skeleton-w-83[data-v-dadf29f1]{width:83%}.skeleton-line[data-v-dadf29f1]:last-child{margin-bottom:0}.empty-state[data-v-dadf29f1]{text-align:center;background:#fff;border:1px dashed #e2e8f0;border-radius:14px;padding:32px;color:#475569}.empty-illustration[data-v-dadf29f1]{font-size:36px;margin-bottom:8px}.empty-title[data-v-dadf29f1]{font-weight:700;color:#0f172a;margin-bottom:4px}.empty-subtitle[data-v-dadf29f1]{color:#94a3b8;margin:0}@keyframes shimmer-dadf29f1{0%{background-position:-200px 0}to{background-position:200px 0}}@media (max-width: 640px){.feed-shell[data-v-dadf29f1]{padding:20px 14px 28px}}.block-renderer[data-v-4d320145]{width:100%}.rendered-content[data-v-4d320145],.legacy-content[data-v-4d320145]{line-height:1.8;color:#333}.empty-content[data-v-4d320145]{padding:40px;text-align:center;color:#999}[data-v-4d320145] .content-paragraph{margin-bottom:1em}[data-v-4d320145] .content-heading-1{font-size:2em;font-weight:700;margin:.67em 0;color:#1a1a1a}[data-v-4d320145] .content-heading-2{font-size:1.5em;font-weight:700;margin:.75em 0;color:#1a1a1a}[data-v-4d320145] .content-heading-3{font-size:1.17em;font-weight:700;margin:.83em 0;color:#1a1a1a}[data-v-4d320145] .content-list{margin-left:2em;margin-bottom:1em}[data-v-4d320145] .content-blockquote{border-left:4px solid #007bff;padding-left:1em;margin:1em 0;color:#666;font-style:italic}[data-v-4d320145] .content-image{max-width:100%;height:auto;border-radius:8px;margin:1em 0;display:block}[data-v-4d320145] .content-divider{border:none;border-top:2px solid #e0e0e0;margin:2em 0}[data-v-4d320145] .content-link{color:#007bff;text-decoration:underline}[data-v-4d320145] .content-link:hover{color:#0056b3}[data-v-4d320145] .video-container{margin:1.5em 0;max-width:600px}[data-v-4d320145] .content-video{max-width:600px;width:100%;height:auto;border-radius:8px;background:#000}[data-v-4d320145] table{border-collapse:collapse;table-layout:fixed;width:100%;margin:1em 0;overflow:hidden}[data-v-4d320145] td,[data-v-4d320145] th{min-width:1em;border:1px solid #ced4da;padding:8px;vertical-align:top;box-sizing:border-box}[data-v-4d320145] th{font-weight:700;text-align:left;background-color:#f8f9fa}.navbar[data-v-92a9da3d]{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100}.navbar-content[data-v-92a9da3d]{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.navbar-brand[data-v-92a9da3d]{font-size:20px;font-weight:700;color:#2563eb;text-decoration:none}.navbar-nav[data-v-92a9da3d]{display:flex;align-items:center;gap:24px}.nav-link[data-v-92a9da3d]{color:#374151;text-decoration:none;font-weight:500;transition:color .2s}.nav-link[data-v-92a9da3d]:hover{color:#2563eb}.text-gray[data-v-92a9da3d]{color:#6b7280;font-size:14px}.post-container[data-v-92a9da3d]{max-width:800px;margin:0 auto;padding:32px 24px;min-height:calc(100vh - 64px)}.loading-state[data-v-92a9da3d],.error-state[data-v-92a9da3d]{text-align:center;padding:64px 24px}.spinner[data-v-92a9da3d]{width:48px;height:48px;border:4px solid #f3f4f6;border-top-color:#2563eb;border-radius:50%;animation:spin-92a9da3d .8s linear infinite;margin:0 auto 16px}@keyframes spin-92a9da3d{to{transform:rotate(360deg)}}.loading-text[data-v-92a9da3d]{color:#6b7280;font-size:14px}.error-state h2[data-v-92a9da3d]{color:#dc2626;margin-bottom:12px}.error-state p[data-v-92a9da3d]{color:#6b7280;margin-bottom:24px}.post-card[data-v-92a9da3d]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px}.post-header[data-v-92a9da3d]{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.post-title[data-v-92a9da3d]{font-size:32px;font-weight:700;color:#111827;margin-bottom:12px;line-height:1.2}.post-meta[data-v-92a9da3d]{display:flex;gap:16px;font-size:14px;color:#6b7280}.video-section[data-v-92a9da3d]{margin-bottom:32px}.post-video[data-v-92a9da3d]{width:100%;border-radius:8px;background:#000;max-height:500px}.video-stats[data-v-92a9da3d]{margin-top:12px;display:flex;gap:16px;font-size:13px;color:#6b7280;padding:12px;background:#f9fafb;border-radius:6px}.completed-badge[data-v-92a9da3d]{color:#059669;font-weight:600}.media-grid[data-v-92a9da3d]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:32px}.post-image[data-v-92a9da3d]{width:100%;border-radius:8px;object-fit:cover}.post-body[data-v-92a9da3d]{font-size:16px;line-height:1.7;color:#374151;margin-bottom:32px}.post-body[data-v-92a9da3d] h1,.post-body[data-v-92a9da3d] h2,.post-body[data-v-92a9da3d] h3{color:#111827;margin-top:24px;margin-bottom:12px;font-weight:600}.post-body[data-v-92a9da3d] p{margin:16px 0}.post-body[data-v-92a9da3d] ul,.post-body[data-v-92a9da3d] ol{margin:16px 0;padding-left:24px}.post-body[data-v-92a9da3d] a{color:#2563eb;text-decoration:underline}.empty-content[data-v-92a9da3d]{padding:48px 24px;text-align:center;color:#9ca3af;font-style:italic;background:#f9fafb;border-radius:8px;margin-bottom:32px}.external-links[data-v-92a9da3d]{margin-bottom:32px;padding:20px;background:#f9fafb;border-radius:8px}.external-links h3[data-v-92a9da3d]{font-size:16px;font-weight:600;color:#111827;margin-bottom:12px}.external-link[data-v-92a9da3d]{display:flex;align-items:center;gap:8px;padding:12px;margin-bottom:8px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#2563eb;text-decoration:none;transition:all .2s}.external-link[data-v-92a9da3d]:hover{background:#eff6ff;border-color:#2563eb}.external-link svg[data-v-92a9da3d]{flex-shrink:0}.audio-section[data-v-92a9da3d]{margin-bottom:32px}.audio-section h3[data-v-92a9da3d]{font-size:18px;font-weight:600;margin-bottom:16px}.post-audio[data-v-92a9da3d]{width:100%;margin-bottom:12px}.post-footer[data-v-92a9da3d]{padding-top:24px;border-top:1px solid #e5e7eb}.btn-primary[data-v-92a9da3d],.btn-secondary[data-v-92a9da3d]{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.btn-primary[data-v-92a9da3d]{background:#2563eb;color:#fff}.btn-primary[data-v-92a9da3d]:hover{background:#1d4ed8}.btn-secondary[data-v-92a9da3d]{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary[data-v-92a9da3d]:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width: 768px){.post-container[data-v-92a9da3d]{padding:20px 16px}.post-card[data-v-92a9da3d]{padding:20px}.post-title[data-v-92a9da3d]{font-size:24px}}.admin-layout[data-v-9d9de583]{display:flex;min-height:100vh;background:#f8f9fa}.admin-sidebar[data-v-9d9de583]{position:fixed;left:0;top:0;bottom:0;width:240px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;z-index:40;transition:transform .3s ease}.sidebar-header[data-v-9d9de583]{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e2e8f0}.sidebar-brand[data-v-9d9de583]{display:flex;align-items:center;gap:12px;text-decoration:none;color:#1a202c;font-weight:700;font-size:18px}.brand-icon[data-v-9d9de583]{font-size:24px}.sidebar-close-btn[data-v-9d9de583]{display:none;background:none;border:none;font-size:24px;cursor:pointer;color:#64748b;padding:4px}.sidebar-nav[data-v-9d9de583]{flex:1;padding:16px;overflow-y:auto}.nav-item[data-v-9d9de583]{display:flex;align-items:center;gap:12px;padding:10px 12px;margin-bottom:4px;border-radius:8px;text-decoration:none;color:#475569;font-size:14px;font-weight:500;transition:all .15s ease}.nav-item[data-v-9d9de583]:hover{background:#f1f5f9;color:#1e293b}.nav-item-active[data-v-9d9de583]{background:#eff6ff;color:#2563eb;border-left:3px solid #2563eb;padding-left:9px}.nav-icon[data-v-9d9de583]{width:20px;height:20px;flex-shrink:0}.admin-main[data-v-9d9de583]{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh}.admin-topbar[data-v-9d9de583]{position:sticky;top:0;height:64px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:30}.hamburger-btn[data-v-9d9de583]{display:none;background:none;border:none;cursor:pointer;padding:8px;color:#475569}.hamburger-btn svg[data-v-9d9de583]{width:24px;height:24px}.topbar-right[data-v-9d9de583]{margin-left:auto}.user-menu[data-v-9d9de583]{position:relative}.user-menu-btn[data-v-9d9de583]{display:flex;align-items:center;gap:12px;padding:8px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:background .15s ease}.user-menu-btn[data-v-9d9de583]:hover{background:#f8fafc}.user-avatar[data-v-9d9de583]{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.user-info[data-v-9d9de583]{text-align:left}.user-name[data-v-9d9de583]{font-size:14px;font-weight:600;color:#1e293b;line-height:1.2}.user-role[data-v-9d9de583]{font-size:12px;color:#64748b}.dropdown-icon[data-v-9d9de583]{width:16px;height:16px;color:#94a3b8}.user-dropdown[data-v-9d9de583]{position:absolute;right:0;top:100%;margin-top:8px;width:240px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:50}.dropdown-header[data-v-9d9de583]{padding:12px 16px}.dropdown-user-name[data-v-9d9de583]{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:2px}.dropdown-user-email[data-v-9d9de583]{font-size:13px;color:#64748b}.dropdown-divider[data-v-9d9de583]{height:1px;background:#e2e8f0}.dropdown-item[data-v-9d9de583]{width:100%;display:flex;align-items:center;gap:12px;padding:10px 16px;border:none;background:none;text-align:left;font-size:14px;color:#475569;cursor:pointer;transition:background .15s ease}.dropdown-item[data-v-9d9de583]:hover{background:#f8fafc}.dropdown-item svg[data-v-9d9de583]{width:18px;height:18px}.logout-item[data-v-9d9de583]{color:#dc2626}.logout-item[data-v-9d9de583]:hover{background:#fef2f2}.admin-content[data-v-9d9de583]{flex:1;padding:24px;min-height:calc(100vh - 64px)}.sidebar-overlay[data-v-9d9de583]{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:35}@media (max-width: 768px){.admin-sidebar[data-v-9d9de583]{transform:translate(-100%)}.admin-sidebar.sidebar-open[data-v-9d9de583]{transform:translate(0)}.sidebar-overlay[data-v-9d9de583],.sidebar-close-btn[data-v-9d9de583]{display:block}.admin-main[data-v-9d9de583]{margin-left:0}.hamburger-btn[data-v-9d9de583]{display:block}.user-info[data-v-9d9de583]{display:none}}.dashboard-container[data-v-39813cea]{max-width:1400px;margin:0 auto;padding:32px 24px;background:#f9fafb;min-height:calc(100vh - 64px)}.loading-state[data-v-39813cea]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.loading-text[data-v-39813cea]{margin-top:16px;color:#6b7280;font-size:14px}.dashboard-header[data-v-39813cea]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.dashboard-title[data-v-39813cea]{font-size:28px;font-weight:700;color:#111827;margin:0 0 4px}.dashboard-subtitle[data-v-39813cea]{font-size:14px;color:#6b7280;margin:0}.dashboard-actions[data-v-39813cea]{display:flex;gap:12px}.kpi-grid[data-v-39813cea]{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px}.kpi-card[data-v-39813cea]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.kpi-card[data-v-39813cea]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:#d1d5db}.kpi-icon[data-v-39813cea]{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:10px;flex-shrink:0}.kpi-content[data-v-39813cea]{flex:1}.kpi-value[data-v-39813cea]{font-size:32px;font-weight:700;color:#111827;line-height:1;margin-bottom:4px}.kpi-label[data-v-39813cea]{font-size:13px;color:#6b7280;font-weight:500;margin-bottom:2px}.kpi-hint[data-v-39813cea]{font-size:11px;color:#9ca3af;font-weight:400;margin-top:2px}.section-card[data-v-39813cea]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:28px;margin-bottom:24px;box-shadow:0 1px 3px #0000000d}.section-header[data-v-39813cea]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.section-title[data-v-39813cea]{font-size:18px;font-weight:600;color:#111827;margin:0 0 4px}.section-subtitle[data-v-39813cea]{font-size:13px;color:#6b7280;margin:0}.data-table[data-v-39813cea]{overflow-x:auto}.data-table table[data-v-39813cea]{width:100%;border-collapse:collapse}.data-table th[data-v-39813cea]{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid #e5e7eb;background:#f9fafb}.data-table td[data-v-39813cea]{padding:16px;border-bottom:1px solid #f3f4f6;font-size:14px;color:#374151;vertical-align:middle}.data-table tbody tr[data-v-39813cea]{transition:background .15s ease}.data-table tbody tr.table-row-clickable[data-v-39813cea]{cursor:pointer}.data-table tbody tr.table-row-clickable[data-v-39813cea]:hover{background:#f9fafb}.text-center[data-v-39813cea]{text-align:center!important}.text-right[data-v-39813cea]{text-align:right!important}.text-secondary[data-v-39813cea]{color:#6b7280}.metric-cell[data-v-39813cea]{font-weight:600;color:#111827}.post-title-cell[data-v-39813cea]{max-width:300px}.post-title[data-v-39813cea]{font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audience-badge[data-v-39813cea]{display:inline-block;padding:4px 10px;font-size:12px;font-weight:500;background:#f3f4f6;color:#6b7280;border-radius:6px}.completion-bar[data-v-39813cea]{position:relative;width:100px;height:24px;background:#f3f4f6;border-radius:6px;overflow:hidden;margin:0 auto}.completion-fill[data-v-39813cea]{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .3s}.completion-text[data-v-39813cea]{position:relative;z-index:1;font-size:12px;font-weight:600;color:#111827;line-height:24px}.teacher-name-cell[data-v-39813cea]{min-width:200px}.teacher-name[data-v-39813cea]{font-weight:500;color:#111827;margin-bottom:2px}.teacher-email[data-v-39813cea]{font-size:12px;color:#9ca3af}.empty-state[data-v-39813cea]{text-align:center;padding:64px 24px}.empty-icon[data-v-39813cea]{font-size:56px;margin-bottom:20px;opacity:.6}.empty-title[data-v-39813cea]{font-size:17px;font-weight:600;color:#111827;margin:0 0 10px}.empty-text[data-v-39813cea]{font-size:14px;color:#6b7280;max-width:480px;margin:0 auto;line-height:1.6}.system-health-panel[data-v-39813cea]{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px 24px;display:flex;justify-content:space-around;gap:32px;flex-wrap:wrap}.health-item[data-v-39813cea]{text-align:center}.health-label[data-v-39813cea]{font-size:12px;color:#6b7280;font-weight:500;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.health-value[data-v-39813cea]{font-size:14px;color:#111827;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px}.status-dot[data-v-39813cea]{width:8px;height:8px;border-radius:50%;background:#9ca3af}.status-dot.active[data-v-39813cea]{background:#10b981;box-shadow:0 0 0 3px #10b98133}.text-link[data-v-39813cea]{color:#2563eb;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s ease;cursor:pointer}.text-link[data-v-39813cea]:hover{color:#1d4ed8;text-decoration:underline}.btn-text[data-v-39813cea]{background:none;border:none;color:#2563eb;font-size:14px;font-weight:500;cursor:pointer;padding:6px 12px;transition:all .2s ease;border-radius:6px}.btn-text[data-v-39813cea]:hover{color:#1d4ed8;background:#eff6ff}.btn-icon[data-v-39813cea]{font-size:16px;margin-right:4px}.btn-primary[data-v-39813cea]{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;background:#2563eb;color:#fff;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;text-decoration:none;transition:all .2s ease;box-shadow:0 1px 3px #2563eb33}.btn-primary[data-v-39813cea]:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.btn-primary[data-v-39813cea]:active{transform:translateY(0);box-shadow:0 1px 3px #2563eb33}.btn-secondary[data-v-39813cea]{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background:#fff;color:#374151;font-size:14px;font-weight:500;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;text-decoration:none;transition:all .2s ease}.btn-secondary[data-v-39813cea]:hover{background:#f9fafb;border-color:#9ca3af}.mt-3[data-v-39813cea]{margin-top:12px}@media (max-width: 768px){.dashboard-container[data-v-39813cea]{padding:20px 16px}.kpi-grid[data-v-39813cea]{grid-template-columns:1fr}.dashboard-header[data-v-39813cea]{flex-direction:column;gap:16px}.section-card[data-v-39813cea]{padding:20px}.data-table[data-v-39813cea]{overflow-x:auto}.system-health-panel[data-v-39813cea]{flex-direction:column;gap:16px}}.editor-toolbar[data-v-1bb11fff]{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:#f8f9fa;border:1px solid #e0e0e0;border-bottom:none;border-radius:8px 8px 0 0;align-items:center}.toolbar-group[data-v-1bb11fff]{display:flex;gap:4px}.toolbar-divider[data-v-1bb11fff]{width:1px;height:24px;background:#ddd}.toolbar-btn[data-v-1bb11fff]{padding:6px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;color:#333}.toolbar-btn[data-v-1bb11fff]:hover:not(:disabled){background:#e9ecef;border-color:#999}.toolbar-btn[data-v-1bb11fff]:disabled{opacity:.5;cursor:not-allowed}.toolbar-btn.is-active[data-v-1bb11fff]{background:#007bff;color:#fff;border-color:#0056b3}.toolbar-select[data-v-1bb11fff]{padding:6px 8px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:14px}.toolbar-select[data-v-1bb11fff]:focus{outline:2px solid #007bff;outline-offset:2px}.color-picker-wrapper[data-v-1bb11fff]{position:relative;display:inline-block}.color-picker-wrapper .toolbar-btn[data-v-1bb11fff]{position:relative;cursor:pointer}.color-input[data-v-1bb11fff]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}@media (max-width: 768px){.editor-toolbar[data-v-1bb11fff]{padding:8px;gap:6px}.toolbar-btn[data-v-1bb11fff]{padding:4px 8px;font-size:13px}.toolbar-select[data-v-1bb11fff]{font-size:13px}}.post-settings-sidebar[data-v-20cc4aac]{width:320px;background:#fff;border-left:1px solid #e0e0e0;height:100%;overflow-y:auto;padding:20px;display:flex;flex-direction:column}.sidebar-section[data-v-20cc4aac]{padding:16px 0;flex-shrink:0}.sidebar-title[data-v-20cc4aac]{font-size:16px;font-weight:600;margin-bottom:16px;color:#1a1a1a}.sidebar-divider[data-v-20cc4aac]{height:1px;background:#e0e0e0;margin:0}.form-group[data-v-20cc4aac]{margin-bottom:16px}.form-group label[data-v-20cc4aac]{display:block;font-weight:500;margin-bottom:6px;color:#333;font-size:14px}.form-select[data-v-20cc4aac],.form-input[data-v-20cc4aac]{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff}.form-select[data-v-20cc4aac]:focus,.form-input[data-v-20cc4aac]:focus{outline:2px solid #007bff;outline-offset:2px;border-color:#007bff}.group-checkboxes[data-v-20cc4aac]{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;padding:8px;border:1px solid #e0e0e0;border-radius:4px;background:#f8f9fa}.checkbox-label[data-v-20cc4aac]{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer;font-size:14px}.checkbox-label input[type=checkbox][data-v-20cc4aac]{cursor:pointer}.text-error[data-v-20cc4aac]{color:#dc3545;font-size:12px;margin-top:4px;display:block}.sidebar-actions[data-v-20cc4aac]{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:20px;padding-bottom:8px;flex-shrink:0;position:sticky;bottom:0;background:#fff;z-index:10}.btn-block[data-v-20cc4aac]{width:100%;padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary[data-v-20cc4aac]{background:#007bff;color:#fff}.btn-primary[data-v-20cc4aac]:hover:not(:disabled){background:#0056b3}.btn-primary[data-v-20cc4aac]:disabled{background:#ccc;cursor:not-allowed}.btn-secondary[data-v-20cc4aac]{background:#fff;color:#333;border:1px solid #ddd}.btn-secondary[data-v-20cc4aac]:hover:not(:disabled){background:#f8f9fa;border-color:#999}.btn-secondary[data-v-20cc4aac]:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 968px){.post-settings-sidebar[data-v-20cc4aac]{width:100%;border-left:none;border-top:1px solid #e0e0e0;max-height:400px}}.admin-post-editor[data-v-1b04902c]{display:flex;flex-direction:column;min-height:600px;max-height:calc(100vh - 150px);background:#fff}.editor-header[data-v-1b04902c]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;z-index:10}.btn-back[data-v-1b04902c]{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.btn-back[data-v-1b04902c]:hover{background:#f8f9fa;border-color:#999}.editor-status[data-v-1b04902c]{font-size:14px;color:#666}.status-saving[data-v-1b04902c]{color:#007bff}.status-saved[data-v-1b04902c]{color:#28a745}.editor-layout[data-v-1b04902c]{display:flex;flex:1;overflow:hidden;max-width:100%;margin:0 auto;width:100%}.editor-main[data-v-1b04902c]{flex:1;display:flex;flex-direction:column;overflow-y:auto}.title-section[data-v-1b04902c]{padding:24px;border-bottom:1px solid #e0e0e0}.title-input[data-v-1b04902c]{width:100%;font-size:32px;font-weight:700;border:none;outline:none;padding:8px 0;font-family:inherit}.title-input[data-v-1b04902c]::placeholder{color:#ccc}.media-upload-section[data-v-1b04902c]{padding:16px 24px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;gap:12px;align-items:center}.media-upload-section h4[data-v-1b04902c]{margin:0;font-size:16px}.editor-content-wrapper[data-v-1b04902c]{flex:1;padding:24px 24px 80px;overflow-y:auto}[data-v-1b04902c] .editor-content{min-height:400px;outline:none;margin-bottom:60px}[data-v-1b04902c] .ProseMirror{outline:none;min-height:400px;padding-bottom:40px}[data-v-1b04902c] .ProseMirror p.is-editor-empty:first-child:before{color:#adb5bd;content:attr(data-placeholder);float:left;height:0;pointer-events:none}[data-v-1b04902c] .ProseMirror p{margin-bottom:1em}[data-v-1b04902c] .ProseMirror h1{font-size:2em;font-weight:700;margin:.67em 0}[data-v-1b04902c] .ProseMirror h2{font-size:1.5em;font-weight:700;margin:.75em 0}[data-v-1b04902c] .ProseMirror h3{font-size:1.17em;font-weight:700;margin:.83em 0}[data-v-1b04902c] .ProseMirror ul,[data-v-1b04902c] .ProseMirror ol{margin-left:2em;margin-bottom:1em}[data-v-1b04902c] .ProseMirror blockquote{border-left:4px solid #007bff;padding-left:1em;margin:1em 0;color:#666;font-style:italic}[data-v-1b04902c] .ProseMirror img{max-width:100%;height:auto;border-radius:8px;margin:1em 0}[data-v-1b04902c] .ProseMirror video{max-width:600px;width:100%;height:auto;border-radius:8px;margin:1em 0;background:#000}[data-v-1b04902c] .ProseMirror hr{border:none;border-top:2px solid #e0e0e0;margin:2em 0}[data-v-1b04902c] .ProseMirror a{color:#007bff;text-decoration:underline}[data-v-1b04902c] .ProseMirror table{border-collapse:collapse;table-layout:fixed;width:100%;margin:1em 0;overflow:hidden}[data-v-1b04902c] .ProseMirror td,[data-v-1b04902c] .ProseMirror th{min-width:1em;border:1px solid #ced4da;padding:8px;vertical-align:top;box-sizing:border-box;position:relative}[data-v-1b04902c] .ProseMirror th{font-weight:700;text-align:left;background-color:#f8f9fa}[data-v-1b04902c] .ProseMirror .selectedCell{background-color:#e3f2fd}.preview-overlay[data-v-1b04902c]{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.preview-modal[data-v-1b04902c]{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.preview-header[data-v-1b04902c]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.preview-header h2[data-v-1b04902c]{margin:0;font-size:20px}.btn-close[data-v-1b04902c]{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.btn-close[data-v-1b04902c]:hover{background:#f8f9fa}.preview-content[data-v-1b04902c]{padding:32px;overflow-y:auto}.preview-content h1[data-v-1b04902c]{font-size:36px;font-weight:700;margin-bottom:16px;color:#1a1a1a}.preview-meta[data-v-1b04902c]{display:flex;gap:12px;font-size:14px;color:#666;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}@media (max-width: 968px){.editor-layout[data-v-1b04902c]{flex-direction:column}.title-input[data-v-1b04902c]{font-size:24px}.preview-modal[data-v-1b04902c]{max-width:100%;margin:0;border-radius:0;max-height:100vh}}.posts-management-container[data-v-6fef53f7]{max-width:1400px;margin:0 auto;padding:32px 24px;background:#f9fafb;min-height:calc(100vh - 64px)}.page-header[data-v-6fef53f7]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.header-content[data-v-6fef53f7]{flex:1}.page-title[data-v-6fef53f7]{font-size:28px;font-weight:700;color:#111827;margin:0 0 6px;letter-spacing:-.02em}.page-subtitle[data-v-6fef53f7]{font-size:15px;color:#6b7280;margin:0;font-weight:400}.header-actions[data-v-6fef53f7]{display:flex;gap:12px;align-items:center}.alert[data-v-6fef53f7]{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:8px;margin-bottom:24px;font-size:14px;font-weight:500}.alert-error[data-v-6fef53f7]{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert svg[data-v-6fef53f7]{flex-shrink:0}.control-bar[data-v-6fef53f7]{display:flex;gap:16px;margin-bottom:20px;background:#fff;padding:16px;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.search-box[data-v-6fef53f7]{position:relative;flex:1;max-width:400px}.search-input[data-v-6fef53f7]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#111827;transition:all .2s ease}.search-input[data-v-6fef53f7]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.search-input[data-v-6fef53f7]::placeholder{color:#9ca3af}.search-clear[data-v-6fef53f7]{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#2563eb;font-size:12px;font-weight:600;padding:4px 6px;border-radius:4px}.search-clear[data-v-6fef53f7]:hover{background:#eff6ff}.filter-group[data-v-6fef53f7]{display:inline-flex;align-items:center;gap:10px}.filter-label[data-v-6fef53f7]{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.filter-select-inline[data-v-6fef53f7]{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#374151;background:#fff;cursor:pointer;transition:all .2s ease;min-width:160px}.filter-select-inline[data-v-6fef53f7]:hover{border-color:#9ca3af}.filter-select-inline[data-v-6fef53f7]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.results-summary[data-v-6fef53f7]{display:flex;align-items:center;gap:16px;margin-bottom:16px;font-size:14px}.results-count[data-v-6fef53f7]{color:#6b7280;font-weight:500}.btn-link[data-v-6fef53f7]{background:none;border:none;color:#2563eb;font-size:14px;font-weight:500;cursor:pointer;padding:0;text-decoration:underline}.btn-link[data-v-6fef53f7]:hover{color:#1d4ed8}.loading-state[data-v-6fef53f7]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.skeleton-row[data-v-6fef53f7]{height:72px;background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:shimmer-6fef53f7 1.5s infinite;border-radius:8px;margin-bottom:12px}.skeleton-row[data-v-6fef53f7]:last-child{margin-bottom:0}@keyframes shimmer-6fef53f7{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state[data-v-6fef53f7]{text-align:center;padding:80px 24px;background:#fff;border:1px solid #e5e7eb;border-radius:12px}.empty-icon[data-v-6fef53f7]{margin:0 auto 24px;color:#d1d5db;display:inline-block}.empty-title[data-v-6fef53f7]{font-size:18px;font-weight:600;color:#111827;margin:0 0 12px}.empty-text[data-v-6fef53f7]{font-size:15px;color:#6b7280;max-width:480px;margin:0 auto;line-height:1.6}.mt-3[data-v-6fef53f7]{margin-top:20px}.posts-table-wrapper[data-v-6fef53f7]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.posts-table[data-v-6fef53f7]{width:100%;border-collapse:collapse}.posts-table thead[data-v-6fef53f7]{background:#f9fafb;border-bottom:2px solid #e5e7eb}.posts-table th[data-v-6fef53f7]{padding:14px 16px;text-align:left;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.8px}.posts-table tbody tr[data-v-6fef53f7]{border-bottom:1px solid #f3f4f6;transition:background .15s ease}.posts-table tbody tr[data-v-6fef53f7]:hover{background:#f9fafb}.posts-table tbody tr[data-v-6fef53f7]:last-child{border-bottom:none}.posts-table td[data-v-6fef53f7]{padding:16px;vertical-align:middle}.col-status[data-v-6fef53f7]{width:130px}.col-title[data-v-6fef53f7]{width:auto;min-width:300px}.col-audience[data-v-6fef53f7]{width:150px}.col-date[data-v-6fef53f7],.col-metrics[data-v-6fef53f7]{width:140px}.col-actions[data-v-6fef53f7]{width:280px}.status-badge[data-v-6fef53f7]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.status-dot[data-v-6fef53f7]{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-published[data-v-6fef53f7]{background:#d1fae5;color:#065f46}.status-published .status-dot[data-v-6fef53f7]{background:#10b981}.status-draft[data-v-6fef53f7]{background:#f3f4f6;color:#4b5563}.status-draft .status-dot[data-v-6fef53f7]{background:#6b7280}.status-scheduled[data-v-6fef53f7]{background:#fef3c7;color:#92400e}.status-scheduled .status-dot[data-v-6fef53f7]{background:#f59e0b}.title-cell[data-v-6fef53f7]{display:flex;flex-direction:column;gap:4px}.post-title-text[data-v-6fef53f7]{font-size:15px;font-weight:600;color:#111827;margin:0;display:flex;align-items:center;gap:8px}.important-badge[data-v-6fef53f7]{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fef3c7;color:#92400e;border-radius:6px;font-size:11px;font-weight:600}.post-metadata[data-v-6fef53f7]{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.separator[data-v-6fef53f7]{color:#d1d5db}.audience-text[data-v-6fef53f7]{font-size:14px;color:#374151}.date-text[data-v-6fef53f7]{font-size:14px;color:#6b7280}.metrics-cell[data-v-6fef53f7]{display:flex;flex-direction:column;gap:6px}.metric-item[data-v-6fef53f7]{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280}.metric-icon[data-v-6fef53f7]{color:#9ca3af;flex-shrink:0}.actions-cell[data-v-6fef53f7]{display:flex;gap:6px;justify-content:flex-end}.btn-action[data-v-6fef53f7]{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-action[data-v-6fef53f7]:hover{background:#f9fafb;border-color:#9ca3af}.btn-action svg[data-v-6fef53f7]{flex-shrink:0}.btn-action-view[data-v-6fef53f7]:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.btn-action-edit[data-v-6fef53f7]:hover{border-color:#059669;color:#059669;background:#d1fae5}.btn-action-publish[data-v-6fef53f7]{border-color:#2563eb;color:#2563eb}.btn-action-publish[data-v-6fef53f7]:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.btn-action-share[data-v-6fef53f7]:hover{border-color:#0ea5e9;color:#0369a1;background:#e0f2fe}.btn-action-delete[data-v-6fef53f7]{color:#dc2626}.btn-action-delete[data-v-6fef53f7]:hover{border-color:#dc2626;background:#fef2f2}.toast[data-v-6fef53f7]{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:12px;padding:14px 20px;background:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026;font-size:14px;font-weight:500;z-index:1000}.toast-success[data-v-6fef53f7]{border-left:4px solid #10b981;color:#065f46}.toast svg[data-v-6fef53f7]{flex-shrink:0;color:#10b981}.toast-enter-active[data-v-6fef53f7],.toast-leave-active[data-v-6fef53f7]{transition:all .3s ease}.toast-enter-from[data-v-6fef53f7]{transform:translate(400px);opacity:0}.toast-leave-to[data-v-6fef53f7]{transform:translateY(100px);opacity:0}.editor-wrapper[data-v-6fef53f7]{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-top:20px}@media (max-width: 1024px){.control-bar[data-v-6fef53f7]{flex-direction:column}.search-box[data-v-6fef53f7]{max-width:none}.filters[data-v-6fef53f7]{width:100%}.filter-select[data-v-6fef53f7]{flex:1;min-width:0}.posts-table-wrapper[data-v-6fef53f7]{overflow-x:auto}.posts-table[data-v-6fef53f7]{min-width:900px}}@media (max-width: 768px){.posts-management-container[data-v-6fef53f7]{padding:20px 16px}.page-header[data-v-6fef53f7]{flex-direction:column;gap:16px}.actions-cell[data-v-6fef53f7]{flex-direction:column;align-items:stretch}.btn-action[data-v-6fef53f7]{justify-content:center}}.dashboard-container[data-v-142037db]{max-width:1400px;margin:0 auto;padding:32px 24px;background:#f9fafb;min-height:calc(100vh - 64px)}.dashboard-header[data-v-142037db]{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:32px}.dashboard-title[data-v-142037db]{font-size:28px;font-weight:700;color:#111827;margin:0 0 6px;letter-spacing:-.02em}.dashboard-subtitle[data-v-142037db]{font-size:15px;color:#6b7280;margin:0}.dashboard-actions[data-v-142037db]{display:flex;align-items:center;gap:12px;flex-shrink:0}.teacher-selection-list[data-v-142037db]{max-height:320px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px;padding:8px;background:#fff}.teacher-checkbox-item[data-v-142037db]{display:flex;align-items:center;gap:16px;padding:14px 16px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .15s ease}.teacher-checkbox-item[data-v-142037db]:last-child{border-bottom:none}.teacher-checkbox-item[data-v-142037db]:hover{background:#f9fafb}.teacher-row[data-v-142037db]{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.teacher-checkbox-wrapper[data-v-142037db]{margin-left:auto;display:flex;align-items:center;justify-content:center;min-width:32px}.teacher-checkbox[data-v-142037db]{width:20px;height:20px;border:2px solid #cfd8ec;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;flex-shrink:0;appearance:none;-webkit-appearance:none;-moz-appearance:none}.teacher-checkbox[data-v-142037db]:focus-visible{outline:3px solid rgba(79,70,229,.25);outline-offset:2px}.teacher-checkbox[data-v-142037db]:checked{background:#4f46e5;border-color:#4f46e5;box-shadow:0 6px 12px #4f46e540}.teacher-checkbox[data-v-142037db]:checked:after{content:"";width:10px;height:6px;border-left:2px solid #ffffff;border-bottom:2px solid #ffffff;transform:rotate(-45deg);margin-top:-1px;display:block}.two-column-layout[data-v-142037db]{display:grid;grid-template-columns:480px 1fr;gap:24px;align-items:start}@media (max-width: 1200px){.two-column-layout[data-v-142037db]{grid-template-columns:1fr}}.section-card[data-v-142037db]{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-header[data-v-142037db]{display:flex;justify-content:space-between;align-items:flex-start}.section-title[data-v-142037db]{font-size:18px;font-weight:700;color:#111827;margin:0 0 4px}.section-subtitle[data-v-142037db]{font-size:14px;color:#6b7280;margin:0}.search-box[data-v-142037db]{position:relative}.search-input[data-v-142037db]{width:100%;padding:10px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.search-input[data-v-142037db]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.empty-state[data-v-142037db]{text-align:center;padding:48px 24px}.empty-icon[data-v-142037db]{font-size:48px;margin-bottom:16px}.empty-title[data-v-142037db]{font-size:18px;font-weight:600;color:#111827;margin:0 0 8px}.empty-text[data-v-142037db]{font-size:14px;color:#6b7280;margin:0}.department-cards[data-v-142037db]{display:flex;flex-direction:column;gap:16px}.department-card[data-v-142037db]{border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:box-shadow .2s}.department-card[data-v-142037db]:hover{box-shadow:0 2px 8px #00000014}.department-header[data-v-142037db]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.department-info[data-v-142037db]{flex:1}.department-name[data-v-142037db]{font-size:16px;font-weight:600;color:#111827;margin:0 0 6px}.type-badge[data-v-142037db]{display:inline-flex;align-items:center;padding:2px 8px;background:#e0e7ff;color:#3730a3;font-size:12px;font-weight:500;border-radius:8px;margin-right:8px}.member-badge[data-v-142037db]{display:inline-flex;align-items:center;padding:4px 10px;background:#f3f4f6;color:#6b7280;font-size:13px;font-weight:500;border-radius:12px}.department-actions[data-v-142037db]{display:flex;gap:8px}.ghost-btn[data-v-142037db]{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.ghost-btn svg[data-v-142037db]{color:currentColor}.ghost-btn[data-v-142037db]:hover{background:#f9fafb;border-color:#9ca3af;color:#1f2937}.ghost-btn.danger[data-v-142037db]{color:#dc2626;border-color:#fecaca}.ghost-btn.danger[data-v-142037db]:hover{background:#fef2f2;border-color:#f87171;color:#b91c1c}.department-members[data-v-142037db]{border-top:1px solid #e5e7eb;padding-top:12px}.expand-btn[data-v-142037db]{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;width:100%;transition:all .2s}.expand-btn[data-v-142037db]:hover{background:#f3f4f6}.members-list[data-v-142037db]{margin-top:12px}.loading-members[data-v-142037db]{display:flex;align-items:center;gap:12px;padding:16px;color:#6b7280;font-size:14px}.spinner-small[data-v-142037db]{border:2px solid #f3f4f6;border-top:2px solid #4f46e5;border-radius:50%;width:20px;height:20px;animation:spin 1s linear infinite}.no-members[data-v-142037db]{padding:16px;text-align:center;color:#9ca3af;font-size:14px}.member-rows[data-v-142037db]{display:flex;flex-direction:column;gap:8px}.member-row[data-v-142037db]{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px}.member-avatar[data-v-142037db]{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.member-details[data-v-142037db]{flex:1;min-width:0}.member-name[data-v-142037db]{font-size:14px;font-weight:500;color:#111827;margin-bottom:2px}.member-email[data-v-142037db]{font-size:13px;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-btn[data-v-142037db]{padding:6px 12px;font-size:13px;font-weight:500;color:#dc2626;background:#fff;border:1px solid #fca5a5;border-radius:6px;cursor:pointer;transition:all .2s;flex-shrink:0}.remove-btn[data-v-142037db]:hover{background:#fef2f2;border-color:#dc2626}.data-table[data-v-142037db]{overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px}.data-table table[data-v-142037db]{width:100%;border-collapse:collapse;font-size:14px}.data-table thead[data-v-142037db]{background:#f9fafb;border-bottom:1px solid #e5e7eb}.data-table th[data-v-142037db]{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;text-transform:uppercase;letter-spacing:.03em}.data-table td[data-v-142037db]{padding:16px;border-bottom:1px solid #f3f4f6;color:#111827}.data-table tbody tr:last-child td[data-v-142037db]{border-bottom:none}.data-table tbody tr[data-v-142037db]:hover{background:#f9fafb}.teacher-cell[data-v-142037db]{display:flex;align-items:center;gap:12px}.teacher-avatar[data-v-142037db]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.teacher-name[data-v-142037db]{font-weight:500;color:#111827}.text-secondary[data-v-142037db]{color:#6b7280}.text-gray[data-v-142037db]{color:#9ca3af;font-style:italic}.department-badges[data-v-142037db]{display:flex;flex-wrap:wrap;gap:6px}.dept-badge[data-v-142037db]{display:inline-flex;align-items:center;padding:4px 10px;background:#eff6ff;color:#1e40af;font-size:12px;font-weight:500;border-radius:12px;border:1px solid #bfdbfe}.table-actions[data-v-142037db]{display:flex;gap:12px;justify-content:flex-end}.role-tabs[data-v-142037db]{display:flex;gap:8px;align-items:center}.role-tab[data-v-142037db]{padding:6px 10px;border-radius:999px;border:1px solid #e5e7eb;background:#f9fafb;color:#4b5563;font-size:12px;cursor:pointer;transition:all .15s ease}.role-tab[data-v-142037db]:hover{background:#e5e7eb}.role-tab.active[data-v-142037db]{background:#2563eb;border-color:#2563eb;color:#fff}.btn-text[data-v-142037db]{padding:6px 12px;font-size:13px;font-weight:500;color:#4f46e5;background:transparent;border:none;cursor:pointer;transition:all .2s}.btn-text[data-v-142037db]:hover{color:#4338ca;text-decoration:underline}.btn-text-danger[data-v-142037db]{padding:6px 12px;font-size:13px;font-weight:500;color:#dc2626;background:transparent;border:none;cursor:pointer;transition:all .2s}.btn-text-danger[data-v-142037db]:hover{color:#b91c1c;text-decoration:underline}.text-right[data-v-142037db]{text-align:right}.modal-overlay[data-v-142037db]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card[data-v-142037db]{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideIn-142037db .2s ease-out}.modal-card.modal-sm[data-v-142037db]{max-width:440px}@keyframes modalSlideIn-142037db{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-142037db]{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 20px;border-bottom:1px solid #e5e7eb}.modal-title[data-v-142037db]{font-size:20px;font-weight:700;color:#111827;margin:0}.modal-close[data-v-142037db]{width:32px;height:32px;border:none;background:transparent;color:#9ca3af;font-size:28px;line-height:1;cursor:pointer;transition:color .2s;padding:0}.modal-close[data-v-142037db]:hover{color:#374151}.modal-body[data-v-142037db]{padding:24px;overflow-y:auto;flex:1}.modal-footer[data-v-142037db]{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb}.form-group[data-v-142037db]{margin-bottom:20px}.form-group label[data-v-142037db]{display:block;margin-bottom:8px;font-weight:600;font-size:14px;color:#374151}.form-group input[data-v-142037db],.form-group select[data-v-142037db]{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input[data-v-142037db]:focus,.form-group select[data-v-142037db]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.text-sm[data-v-142037db]{font-size:13px}.info-box[data-v-142037db]{padding:12px 16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;color:#0c4a6e;font-size:14px}.teacher-info[data-v-142037db]{flex:1}.teacher-avatar-small[data-v-142037db]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#818cf8,#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.teacher-name[data-v-142037db]{font-size:14px;font-weight:500;color:#111827;margin-bottom:2px}.teacher-email[data-v-142037db]{font-size:13px;color:#6b7280}.selection-summary[data-v-142037db]{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#2563eb;font-size:14px;font-weight:500}.checkbox-group[data-v-142037db]{display:flex;flex-direction:column;gap:10px}.checkbox-label[data-v-142037db]{display:flex;align-items:center;gap:10px;font-weight:400;cursor:pointer;padding:10px;border-radius:6px;transition:background .2s}.checkbox-label[data-v-142037db]:hover{background:#f9fafb}.checkbox-label input[type=checkbox][data-v-142037db]{width:18px;height:18px;cursor:pointer;accent-color:#4f46e5}@media (max-width: 768px){.dashboard-header[data-v-142037db]{flex-direction:column;align-items:stretch}.dashboard-actions[data-v-142037db]{flex-direction:column}.modal-card[data-v-142037db]{max-width:100%}}.back-nav[data-v-f876bc3f]{margin-bottom:24px}.back-link[data-v-f876bc3f]{display:inline-flex;align-items:center;gap:12px;padding:10px 16px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;color:#1f2937;font-weight:600;font-size:14px;transition:all .2s ease;box-shadow:0 2px 8px #0f172a14}.back-link[data-v-f876bc3f]:hover{border-color:#c7d2fe;background:#eef2ff;color:#4338ca;box-shadow:0 4px 14px #4f46e526}.back-icon[data-v-f876bc3f]{width:40px;height:40px;border-radius:999px;background:#eef2ff;display:inline-flex;align-items:center;justify-content:center;color:#4f46e5;border:1px solid #c7d2fe}.back-icon svg[data-v-f876bc3f]{width:20px;height:20px}.back-copy[data-v-f876bc3f]{display:flex;flex-direction:column;line-height:1.1}.back-label[data-v-f876bc3f]{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#6b7280}.back-destination[data-v-f876bc3f]{font-size:14px;font-weight:600;color:#111827}.modal-overlay[data-v-a6003444]{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px;overflow-y:auto}.modal-container[data-v-a6003444]{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;position:relative;outline:none}.modal-header[data-v-a6003444]{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:32px 32px 24px;border-bottom:1px solid #e5e7eb}.modal-header-content[data-v-a6003444]{flex:1;min-width:0}.modal-eyebrow[data-v-a6003444]{display:inline-block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6366f1;margin-bottom:8px}.modal-title[data-v-a6003444]{font-size:24px;font-weight:700;color:#111827;margin:0 0 12px;line-height:1.3}.modal-meta[data-v-a6003444]{display:flex;flex-wrap:wrap;gap:12px}.meta-badge[data-v-a6003444]{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;padding:4px 10px;background:#f3f4f6;border-radius:6px}.meta-badge svg[data-v-a6003444]{color:#9ca3af}.modal-close-btn[data-v-a6003444]{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;transition:all .2s ease}.modal-close-btn[data-v-a6003444]:hover{background:#e5e7eb;color:#111827}.modal-close-btn[data-v-a6003444]:active{transform:scale(.95)}.modal-body[data-v-a6003444]{flex:1;overflow-y:auto;padding:32px}.content-section[data-v-a6003444]{margin-bottom:32px}.content-body[data-v-a6003444]{font-size:15px;line-height:1.7;color:#374151}.content-body[data-v-a6003444] h1,.content-body[data-v-a6003444] h2,.content-body[data-v-a6003444] h3{font-weight:700;color:#111827;margin-top:24px;margin-bottom:12px}.content-body[data-v-a6003444] h1{font-size:28px}.content-body[data-v-a6003444] h2{font-size:22px}.content-body[data-v-a6003444] h3{font-size:18px}.content-body[data-v-a6003444] p{margin-bottom:16px}.content-body[data-v-a6003444] ul,.content-body[data-v-a6003444] ol{margin-left:24px;margin-bottom:16px}.content-body[data-v-a6003444] a{color:#6366f1;text-decoration:underline}.content-body[data-v-a6003444] a:hover{color:#4f46e5}.content-body[data-v-a6003444] img{max-width:100%;height:auto;border-radius:8px;margin:16px 0}.media-section[data-v-a6003444]{border-top:1px solid #e5e7eb;padding-top:32px;display:flex;flex-direction:column;gap:28px}.media-item[data-v-a6003444]{display:flex;flex-direction:column;gap:12px}.media-heading[data-v-a6003444]{font-size:16px;font-weight:600;color:#111827;margin:0}.video-wrapper[data-v-a6003444]{background:#000;border-radius:8px;overflow:hidden}.video-player[data-v-a6003444]{width:100%;height:auto;max-height:480px;display:block}.audio-player[data-v-a6003444]{width:100%;height:48px;border-radius:8px}.image-gallery[data-v-a6003444]{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.image-thumbnail[data-v-a6003444]{display:block;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#f3f4f6;border:2px solid #e5e7eb;transition:all .2s ease}.image-thumbnail[data-v-a6003444]:hover{border-color:#6366f1;transform:scale(1.05)}.image-thumbnail img[data-v-a6003444]{width:100%;height:100%;object-fit:cover}.links-list[data-v-a6003444]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.link-item[data-v-a6003444]{display:block}.link-anchor[data-v-a6003444]{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;color:#374151;text-decoration:none;transition:all .2s ease}.link-anchor[data-v-a6003444]:hover{background:#f3f4f6;border-color:#6366f1;color:#6366f1}.link-text[data-v-a6003444]{flex:1;font-size:14px;word-break:break-all}.external-icon[data-v-a6003444]{flex-shrink:0;color:#9ca3af}.modal-footer[data-v-a6003444]{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:20px 32px;border-top:1px solid #e5e7eb;background:#f9fafb}.modal-loading[data-v-a6003444]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;gap:16px}.spinner[data-v-a6003444]{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin-a6003444 .8s linear infinite}@keyframes spin-a6003444{to{transform:rotate(360deg)}}.loading-text[data-v-a6003444]{font-size:15px;color:#6b7280;margin:0}.modal-error[data-v-a6003444]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;gap:16px;text-align:center}.modal-error svg[data-v-a6003444]{color:#ef4444}.error-title[data-v-a6003444]{font-size:20px;font-weight:600;color:#111827;margin:0}.error-message[data-v-a6003444]{font-size:15px;color:#6b7280;margin:0 0 24px;max-width:400px}.btn-primary[data-v-a6003444],.btn-secondary[data-v-a6003444]{padding:10px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.btn-primary[data-v-a6003444]{background:#6366f1;color:#fff}.btn-primary[data-v-a6003444]:hover{background:#4f46e5}.btn-secondary[data-v-a6003444]{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary[data-v-a6003444]:hover{background:#f9fafb;border-color:#9ca3af}.modal-enter-active[data-v-a6003444],.modal-leave-active[data-v-a6003444]{transition:opacity .2s ease}.modal-enter-from[data-v-a6003444],.modal-leave-to[data-v-a6003444]{opacity:0}.modal-enter-active .modal-container[data-v-a6003444],.modal-leave-active .modal-container[data-v-a6003444]{transition:transform .2s ease,opacity .2s ease}.modal-enter-from .modal-container[data-v-a6003444],.modal-leave-to .modal-container[data-v-a6003444]{transform:scale(.95);opacity:0}@media (max-width: 768px){.modal-overlay[data-v-a6003444]{padding:0;align-items:flex-end}.modal-container[data-v-a6003444]{max-height:95vh;border-radius:12px 12px 0 0;max-width:100%}.modal-header[data-v-a6003444],.modal-body[data-v-a6003444],.modal-footer[data-v-a6003444]{padding-left:20px;padding-right:20px}.modal-title[data-v-a6003444]{font-size:20px}.image-gallery[data-v-a6003444]{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.report-container[data-v-ce19ab7a]{max-width:1400px;margin:0 auto;padding:32px 24px;background:#f9fafb;min-height:calc(100vh - 64px)}.loading-state[data-v-ce19ab7a]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 24px}.spinner[data-v-ce19ab7a]{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin-ce19ab7a 1s linear infinite}@keyframes spin-ce19ab7a{to{transform:rotate(360deg)}}.loading-text[data-v-ce19ab7a]{margin-top:20px;font-size:15px;color:#6b7280}.error-state[data-v-ce19ab7a]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}.error-state svg[data-v-ce19ab7a]{color:#ef4444;margin-bottom:24px}.error-title[data-v-ce19ab7a]{font-size:20px;font-weight:600;color:#111827;margin:0 0 12px}.error-text[data-v-ce19ab7a]{font-size:15px;color:#6b7280;margin:0 0 24px;max-width:500px}.report-header[data-v-ce19ab7a]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.header-content[data-v-ce19ab7a]{flex:1}.report-eyebrow[data-v-ce19ab7a]{font-size:13px;font-weight:600;color:#2563eb;text-transform:uppercase;letter-spacing:.8px;margin:0 0 12px}.report-title[data-v-ce19ab7a]{font-size:28px;font-weight:700;color:#111827;margin:0 0 16px;line-height:1.3}.meta-row[data-v-ce19ab7a]{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.meta-item[data-v-ce19ab7a]{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:#6b7280}.meta-item svg[data-v-ce19ab7a]{color:#9ca3af}.header-actions[data-v-ce19ab7a]{display:flex;gap:12px;flex-shrink:0}.kpi-section[data-v-ce19ab7a]{margin-bottom:24px}.kpi-grid[data-v-ce19ab7a]{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:12px}.kpi-card[data-v-ce19ab7a]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease}.kpi-card[data-v-ce19ab7a]:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000d}.kpi-header[data-v-ce19ab7a]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.kpi-label[data-v-ce19ab7a]{font-size:13px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.kpi-icon[data-v-ce19ab7a]{color:#9ca3af;flex-shrink:0}.kpi-value[data-v-ce19ab7a]{font-size:32px;font-weight:700;color:#111827;margin-bottom:6px;line-height:1}.kpi-helper[data-v-ce19ab7a]{font-size:13px;color:#9ca3af}.kpi-note[data-v-ce19ab7a]{font-size:12px;color:#9ca3af;text-align:center;margin:0}.card[data-v-ce19ab7a]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;margin-bottom:24px}.section-header[data-v-ce19ab7a]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.section-title[data-v-ce19ab7a]{font-size:18px;font-weight:600;color:#111827;margin:0 0 4px}.section-subtitle[data-v-ce19ab7a]{font-size:14px;color:#6b7280;margin:0}.chart-container[data-v-ce19ab7a]{margin-top:24px}.chart-placeholder[data-v-ce19ab7a]{padding:24px;background:#f9fafb;border-radius:8px}.engagement-chart[data-v-ce19ab7a]{width:100%;height:200px}.chart-legend[data-v-ce19ab7a]{display:flex;justify-content:center;gap:24px;margin-top:16px}.legend-item[data-v-ce19ab7a]{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.legend-dot[data-v-ce19ab7a]{width:12px;height:12px;border-radius:2px}.empty-hint[data-v-ce19ab7a]{text-align:center;padding:60px 24px;background:#f9fafb;border-radius:8px}.empty-hint svg[data-v-ce19ab7a]{color:#d1d5db;margin-bottom:16px}.empty-hint p[data-v-ce19ab7a]{font-size:14px;color:#6b7280;max-width:400px;margin:0 auto}.search-box-inline[data-v-ce19ab7a]{flex-shrink:0}.search-input-small[data-v-ce19ab7a]{width:240px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#111827;transition:all .2s ease}.search-input-small[data-v-ce19ab7a]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.teacher-table-wrapper[data-v-ce19ab7a]{overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px}.teacher-table[data-v-ce19ab7a]{width:100%;border-collapse:collapse}.teacher-table thead[data-v-ce19ab7a]{background:#f9fafb;border-bottom:2px solid #e5e7eb}.teacher-table th[data-v-ce19ab7a]{padding:12px 16px;text-align:left;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.8px}.teacher-table tbody tr[data-v-ce19ab7a]{border-bottom:1px solid #f3f4f6;transition:background .15s ease}.teacher-table tbody tr[data-v-ce19ab7a]:hover{background:#f9fafb}.teacher-table tbody tr[data-v-ce19ab7a]:last-child{border-bottom:none}.teacher-table td[data-v-ce19ab7a]{padding:14px 16px;vertical-align:middle;font-size:14px}.teacher-name-cell[data-v-ce19ab7a]{display:flex;flex-direction:column;gap:2px}.teacher-name[data-v-ce19ab7a]{font-weight:500;color:#111827}.teacher-email[data-v-ce19ab7a]{font-size:13px;color:#6b7280}.text-center[data-v-ce19ab7a]{text-align:center}.text-secondary[data-v-ce19ab7a]{color:#6b7280}.status-badge[data-v-ce19ab7a]{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}.status-yes[data-v-ce19ab7a]{background:#d1fae5;color:#065f46}.status-no[data-v-ce19ab7a]{background:#f3f4f6;color:#6b7280}.completion-badge[data-v-ce19ab7a]{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}.completion-completed[data-v-ce19ab7a]{background:#d1fae5;color:#065f46}.completion-in_progress[data-v-ce19ab7a]{background:#fef3c7;color:#92400e}.completion-not_started[data-v-ce19ab7a]{background:#f3f4f6;color:#6b7280}.kpi-grid.has-video[data-v-ce19ab7a]{grid-template-columns:repeat(4,1fr) repeat(4,1fr)}.video-kpi[data-v-ce19ab7a]{border-left:3px solid #8b5cf6}.video-kpi .kpi-icon[data-v-ce19ab7a]{color:#8b5cf6}.video-note[data-v-ce19ab7a]{color:#8b5cf6;font-weight:500}.teacher-table.has-video-columns[data-v-ce19ab7a]{min-width:900px}.video-column[data-v-ce19ab7a]{background:#f8fafc!important;border-left:2px solid #e0e7ff;font-size:12px}.video-progress-cell[data-v-ce19ab7a]{display:flex;flex-direction:column;align-items:center;gap:4px}.video-position[data-v-ce19ab7a]{font-size:11px;color:#6b7280;font-weight:400}.content-toggle[data-v-ce19ab7a]{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;padding:0;cursor:pointer;text-align:left}.toggle-icon[data-v-ce19ab7a]{color:#6b7280;transition:transform .2s ease;flex-shrink:0}.toggle-icon.rotated[data-v-ce19ab7a]{transform:rotate(180deg)}.content-body[data-v-ce19ab7a]{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.content-meta[data-v-ce19ab7a]{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280;margin-bottom:16px}.separator[data-v-ce19ab7a]{color:#d1d5db}.content-text[data-v-ce19ab7a]{font-size:15px;line-height:1.7;color:#374151}.content-text[data-v-ce19ab7a] h1,.content-text[data-v-ce19ab7a] h2,.content-text[data-v-ce19ab7a] h3{color:#111827;margin-top:24px;margin-bottom:12px}.content-text[data-v-ce19ab7a] p{margin:12px 0}.content-text[data-v-ce19ab7a] ul,.content-text[data-v-ce19ab7a] ol{margin:12px 0;padding-left:24px}.content-text[data-v-ce19ab7a] a{color:#2563eb;text-decoration:underline}@media (max-width: 1200px){.kpi-grid[data-v-ce19ab7a]{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.report-container[data-v-ce19ab7a]{padding:20px 16px}.report-header[data-v-ce19ab7a]{flex-direction:column}.kpi-grid[data-v-ce19ab7a]{grid-template-columns:repeat(2,1fr)}.header-actions[data-v-ce19ab7a]{width:100%;flex-direction:column}.header-actions button[data-v-ce19ab7a]{width:100%}.section-header[data-v-ce19ab7a]{flex-direction:column;gap:16px}.search-input-small[data-v-ce19ab7a]{width:100%}}@media (max-width: 480px){.kpi-grid[data-v-ce19ab7a]{grid-template-columns:1fr}.meta-row[data-v-ce19ab7a]{flex-direction:column;align-items:flex-start;gap:8px}}.tasks-container[data-v-b96acb1a]{padding:24px}.page-header[data-v-b96acb1a]{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:20px}.page-title[data-v-b96acb1a]{font-size:24px;font-weight:700;margin:0 0 6px}.page-subtitle[data-v-b96acb1a]{color:#6b7280;margin:0}.header-actions[data-v-b96acb1a]{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-bar[data-v-b96acb1a]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.filter-label[data-v-b96acb1a]{color:#6b7280;font-size:14px}.filter-select[data-v-b96acb1a]{padding:8px 12px;border:1px solid #e5e7eb;border-radius:8px;min-width:160px}.table-wrapper[data-v-b96acb1a]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.data-table[data-v-b96acb1a]{width:100%;border-collapse:collapse}.data-table th[data-v-b96acb1a],.data-table td[data-v-b96acb1a]{padding:12px 16px;text-align:left;border-bottom:1px solid #f3f4f6}.data-table th[data-v-b96acb1a]{background:#f9fafb;font-weight:600;color:#374151}.empty-state[data-v-b96acb1a]{text-align:center;padding:48px 24px;color:#6b7280}.empty-state button[data-v-b96acb1a]{margin-top:16px}.loading-state[data-v-b96acb1a]{padding:24px;text-align:center;color:#6b7280}.alert[data-v-b96acb1a]{padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-error[data-v-b96acb1a]{background:#fef2f2;color:#991b1b}.modal-overlay[data-v-b96acb1a]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal-card[data-v-b96acb1a]{background:#fff;border-radius:12px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto}.modal-card.modal-sm[data-v-b96acb1a]{max-width:400px}.modal-header[data-v-b96acb1a]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb}.modal-title[data-v-b96acb1a]{font-size:18px;font-weight:600;margin:0}.modal-close[data-v-b96acb1a]{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280}.modal-body[data-v-b96acb1a]{padding:20px}.modal-footer[data-v-b96acb1a]{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #e5e7eb}.form-group[data-v-b96acb1a]{margin-bottom:16px}.form-group label[data-v-b96acb1a]{display:block;margin-bottom:6px;font-weight:500;color:#374151}.form-group input[type=text][data-v-b96acb1a],.form-group input[type=datetime-local][data-v-b96acb1a],.form-select[data-v-b96acb1a]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px}.checkbox-list[data-v-b96acb1a]{display:flex;flex-wrap:wrap;gap:12px}.checkbox-item[data-v-b96acb1a]{display:flex;align-items:center;gap:8px;cursor:pointer}.group-search-input[data-v-b96acb1a]{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;margin-bottom:10px}.checkbox-label[data-v-b96acb1a]{display:flex;align-items:center;gap:8px;cursor:pointer}.btn-text[data-v-b96acb1a]{background:none;border:none;color:#4f46e5;cursor:pointer;font-size:14px;margin-right:8px}.btn-text-danger[data-v-b96acb1a]{background:none;border:none;color:#dc2626;cursor:pointer;font-size:14px}.btn-primary[data-v-b96acb1a],.btn-secondary[data-v-b96acb1a],.btn-danger[data-v-b96acb1a]{padding:8px 16px;border-radius:8px;font-weight:500;cursor:pointer;border:none}.btn-primary[data-v-b96acb1a]{background:#4f46e5;color:#fff}.btn-secondary[data-v-b96acb1a]{background:#f3f4f6;color:#374151}.btn-danger[data-v-b96acb1a]{background:#dc2626;color:#fff}.import-article-container[data-v-50c2498e]{padding:24px;max-width:900px}.page-header[data-v-50c2498e]{margin-bottom:24px}.page-title[data-v-50c2498e]{font-size:24px;font-weight:700;margin:0 0 6px}.page-subtitle[data-v-50c2498e]{color:#6b7280;margin:0}.form-card[data-v-50c2498e]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;margin-bottom:20px}.form-label[data-v-50c2498e]{display:block;font-weight:600;margin-bottom:8px;color:#374151}.input-row[data-v-50c2498e]{display:flex;gap:12px;align-items:center}.form-input[data-v-50c2498e]{flex:1;padding:10px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px}.form-input[data-v-50c2498e]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.form-hint[data-v-50c2498e]{margin:10px 0 0;font-size:13px;color:#6b7280}.btn-primary[data-v-50c2498e]{padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.btn-primary[data-v-50c2498e]:hover:not(:disabled){background:#1d4ed8}.btn-primary[data-v-50c2498e]:disabled{opacity:.6;cursor:not-allowed}.btn-secondary[data-v-50c2498e]{padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:8px;font-weight:500;cursor:pointer}.btn-secondary[data-v-50c2498e]:hover{background:#e5e7eb}.alert[data-v-50c2498e]{padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-error[data-v-50c2498e]{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.loading-state[data-v-50c2498e]{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px}.spinner[data-v-50c2498e]{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin-50c2498e .8s linear infinite}@keyframes spin-50c2498e{to{transform:rotate(360deg)}}.loading-state p[data-v-50c2498e]{color:#6b7280;margin:0}.result-header[data-v-50c2498e]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.result-title[data-v-50c2498e]{font-size:18px;font-weight:700;margin:0}.result-actions[data-v-50c2498e]{display:flex;gap:8px}.preview-wrapper[data-v-50c2498e]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;min-height:200px}.preview-content[data-v-50c2498e]{font-size:15px;line-height:1.6;color:#374151}.preview-content[data-v-50c2498e] div{margin-bottom:.5em}.preview-content[data-v-50c2498e] h1,.preview-content[data-v-50c2498e] h2,.preview-content[data-v-50c2498e] h3{margin-top:1em;margin-bottom:.5em}.video-extract-container[data-v-f73bcaa4]{padding:24px;max-width:900px}.page-header[data-v-f73bcaa4]{margin-bottom:24px}.page-title[data-v-f73bcaa4]{font-size:24px;font-weight:700;margin:0 0 6px}.page-subtitle[data-v-f73bcaa4]{color:#6b7280;margin:0}.form-card[data-v-f73bcaa4]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;margin-bottom:20px}.form-label[data-v-f73bcaa4]{display:block;font-weight:600;margin-bottom:8px;color:#374151}.input-row[data-v-f73bcaa4]{display:flex;gap:12px;align-items:center}.form-input[data-v-f73bcaa4]{flex:1;padding:10px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px}.form-input[data-v-f73bcaa4]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.form-hint[data-v-f73bcaa4]{margin:10px 0 0;font-size:13px;color:#6b7280}.btn-primary[data-v-f73bcaa4]{padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block}.btn-primary[data-v-f73bcaa4]:hover:not(:disabled){background:#1d4ed8}.btn-primary[data-v-f73bcaa4]:disabled{opacity:.6;cursor:not-allowed}.btn-secondary[data-v-f73bcaa4]{padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:8px;font-weight:500;cursor:pointer}.btn-secondary[data-v-f73bcaa4]:hover{background:#e5e7eb}.alert[data-v-f73bcaa4]{padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-error[data-v-f73bcaa4]{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.loading-state[data-v-f73bcaa4]{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px}.spinner[data-v-f73bcaa4]{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin-f73bcaa4 .8s linear infinite}@keyframes spin-f73bcaa4{to{transform:rotate(360deg)}}.loading-state p[data-v-f73bcaa4]{color:#6b7280;margin:0}.result-header[data-v-f73bcaa4]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.result-title[data-v-f73bcaa4]{font-size:18px;font-weight:700;margin:0}.result-source[data-v-f73bcaa4]{font-size:13px;color:#6b7280}.result-card[data-v-f73bcaa4]{display:flex;gap:20px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:20px}.result-thumb[data-v-f73bcaa4]{flex-shrink:0;width:160px;height:90px;border-radius:8px;overflow:hidden;background:#f3f4f6}.thumb-img[data-v-f73bcaa4]{width:100%;height:100%;object-fit:cover}.result-meta[data-v-f73bcaa4]{flex:1;min-width:0}.result-name[data-v-f73bcaa4]{font-size:16px;font-weight:600;margin:0 0 8px;line-height:1.3}.result-duration[data-v-f73bcaa4]{font-size:14px;color:#6b7280;margin:0 0 12px}.result-actions[data-v-f73bcaa4]{display:flex;gap:10px;flex-wrap:wrap}.preview-video[data-v-f73bcaa4]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.preview-label[data-v-f73bcaa4]{font-weight:600;margin:0 0 12px}.video-player[data-v-f73bcaa4]{width:100%;max-height:400px;border-radius:8px;background:#000}.preview-note[data-v-f73bcaa4]{font-size:14px;color:#6b7280;margin:0}.storage-container[data-v-87d1015e]{padding:24px}.page-header[data-v-87d1015e]{margin-bottom:20px}.page-title[data-v-87d1015e]{font-size:24px;font-weight:700;margin:0 0 6px}.page-subtitle[data-v-87d1015e]{color:#6b7280;margin:0}.summary-card[data-v-87d1015e]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:16px}.summary-item[data-v-87d1015e]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.summary-label[data-v-87d1015e]{font-size:14px;color:#6b7280}.summary-value[data-v-87d1015e]{font-size:15px;font-weight:600}.summary-grid[data-v-87d1015e]{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-top:8px}.filters-card[data-v-87d1015e]{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:16px 20px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;margin-bottom:16px}.filter-group[data-v-87d1015e]{display:flex;align-items:center;gap:8px}.filter-label[data-v-87d1015e]{font-size:13px;color:#6b7280}.filter-select[data-v-87d1015e]{padding:6px 10px;border-radius:8px;border:1px solid #e5e7eb}.actions[data-v-87d1015e]{margin-left:auto}.btn-secondary[data-v-87d1015e]{padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:8px;font-weight:500;cursor:pointer}.btn-secondary[data-v-87d1015e]:disabled{opacity:.5;cursor:not-allowed}.alert[data-v-87d1015e]{padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-error[data-v-87d1015e]{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.loading-state[data-v-87d1015e]{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px}.spinner[data-v-87d1015e]{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin-87d1015e .8s linear infinite}@keyframes spin-87d1015e{to{transform:rotate(360deg)}}.files-table-wrapper[data-v-87d1015e]{background:#fff;border-radius:12px;border:1px solid #e5e7eb;overflow:hidden}.files-table[data-v-87d1015e]{width:100%;border-collapse:collapse}.files-table th[data-v-87d1015e],.files-table td[data-v-87d1015e]{padding:10px 14px;border-bottom:1px solid #f3f4f6;font-size:14px}.files-table th[data-v-87d1015e]{background:#f9fafb;text-align:left}.file-link[data-v-87d1015e]{color:#2563eb;text-decoration:none}.file-link[data-v-87d1015e]:hover{text-decoration:underline}.empty-state[data-v-87d1015e]{padding:24px;text-align:center;color:#6b7280}.settings-container[data-v-60e5d7e8]{max-width:600px;margin:0 auto;padding:32px 24px}.settings-card[data-v-60e5d7e8]{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:32px}.page-title[data-v-60e5d7e8]{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px}.page-subtitle[data-v-60e5d7e8]{font-size:14px;color:#6b7280;margin:0 0 32px}.settings-form[data-v-60e5d7e8]{display:flex;flex-direction:column;gap:24px}.form-group[data-v-60e5d7e8]{display:flex;flex-direction:column;gap:8px}.form-group label[data-v-60e5d7e8]{font-weight:600;font-size:14px;color:#374151}.form-group input[data-v-60e5d7e8]{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input[data-v-60e5d7e8]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.readonly-input[data-v-60e5d7e8]{background:#f9fafb;color:#6b7280;cursor:not-allowed}.error-text[data-v-60e5d7e8]{font-size:12px;color:#dc2626}.alert-error[data-v-60e5d7e8]{padding:12px 16px;background:#fef2f2;color:#991b1b;border-radius:8px;border:1px solid #fecaca;font-size:14px}.alert-success[data-v-60e5d7e8]{padding:12px 16px;background:#f0fdf4;color:#166534;border-radius:8px;border:1px solid #bbf7d0;font-size:14px}.form-actions[data-v-60e5d7e8]{display:flex;justify-content:flex-end;padding-top:8px}.btn-primary[data-v-60e5d7e8]{padding:10px 24px;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary[data-v-60e5d7e8]:hover:not(:disabled){background:#4338ca}.btn-primary[data-v-60e5d7e8]:disabled{background:#9ca3af;cursor:not-allowed}.loading[data-v-60e5d7e8]{text-align:center;padding:60px 20px}.spinner[data-v-60e5d7e8]{border:3px solid #f3f4f6;border-top:3px solid #4f46e5;border-radius:50%;width:40px;height:40px;animation:spin-60e5d7e8 1s linear infinite;margin:0 auto 16px}@keyframes spin-60e5d7e8{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.settings-container[data-v-f3bcad3e]{max-width:600px;margin:0 auto;padding:32px 24px}.settings-card[data-v-f3bcad3e]{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:32px}.page-title[data-v-f3bcad3e]{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px}.page-subtitle[data-v-f3bcad3e]{font-size:14px;color:#6b7280;margin:0 0 32px}.settings-form[data-v-f3bcad3e]{display:flex;flex-direction:column;gap:24px}.form-group[data-v-f3bcad3e]{display:flex;flex-direction:column;gap:8px}.form-group label[data-v-f3bcad3e]{font-weight:600;font-size:14px;color:#374151}.password-input-wrapper[data-v-f3bcad3e]{position:relative}.password-input-wrapper input[data-v-f3bcad3e]{width:100%;padding:10px 40px 10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.password-input-wrapper input[data-v-f3bcad3e]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.toggle-password-btn[data-v-f3bcad3e]{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;padding:4px;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:color .2s}.toggle-password-btn[data-v-f3bcad3e]:hover{color:#4f46e5}.toggle-password-btn svg[data-v-f3bcad3e]{width:20px;height:20px}.error-text[data-v-f3bcad3e]{font-size:12px;color:#dc2626}.help-text[data-v-f3bcad3e]{font-size:12px;color:#6b7280}.alert-error[data-v-f3bcad3e]{padding:12px 16px;background:#fef2f2;color:#991b1b;border-radius:8px;border:1px solid #fecaca;font-size:14px}.alert-success[data-v-f3bcad3e]{padding:12px 16px;background:#f0fdf4;color:#166534;border-radius:8px;border:1px solid #bbf7d0;font-size:14px}.form-actions[data-v-f3bcad3e]{display:flex;justify-content:flex-end;padding-top:8px}.btn-primary[data-v-f3bcad3e]{padding:10px 24px;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary[data-v-f3bcad3e]:hover:not(:disabled){background:#4338ca}.btn-primary[data-v-f3bcad3e]:disabled{background:#9ca3af;cursor:not-allowed}.ai-settings-container[data-v-73ea6662]{padding:24px;max-width:900px;margin:0 auto}.page-header[data-v-73ea6662]{margin-bottom:24px}.page-title[data-v-73ea6662]{font-size:24px;font-weight:700;margin:0 0 6px}.page-subtitle[data-v-73ea6662]{color:#6b7280;margin:0}.card[data-v-73ea6662]{background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:24px}.card-title[data-v-73ea6662]{font-size:18px;font-weight:600;margin:0 0 8px}.card-text[data-v-73ea6662]{margin:4px 0 16px;color:#4b5563}.status-ok[data-v-73ea6662]{color:#16a34a;font-weight:500}.status-warn[data-v-73ea6662]{color:#b45309;font-weight:500}.steps[data-v-73ea6662]{list-style:none;padding:0;margin:0}.steps li[data-v-73ea6662]{display:flex;gap:12px;margin-bottom:12px}.step-index[data-v-73ea6662]{width:24px;height:24px;border-radius:999px;background:#eef2ff;color:#4f46e5;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.step-body[data-v-73ea6662]{flex:1}.step-title[data-v-73ea6662]{font-size:14px;font-weight:600;margin-bottom:2px}.step-text[data-v-73ea6662]{font-size:14px;color:#4b5563}a[data-v-73ea6662]{color:#2563eb;text-decoration:underline}a[data-v-73ea6662]:hover{color:#1d4ed8}code[data-v-73ea6662]{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-size:12px}.card-footer-text[data-v-73ea6662]{margin-top:16px;font-size:13px;color:#6b7280}:root{--bg: #f5f7fa;--surface: #ffffff;--card: #ffffff;--border: #e5e7eb;--text: #1f2937;--muted: #6b7280;--accent: #4f46e5;--accent-strong: #4338ca;--danger: #ef4444;--success: #10b981}.dark{color-scheme:dark;--bg: #0b1220;--surface: #0f172a;--card: #111827;--border: #1f2937;--text: #e5e7eb;--muted: #94a3b8;--accent: #8b5cf6;--accent-strong: #7c3aed;--danger: #f87171;--success: #34d399}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}#app{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:20px}.container-wide{max-width:1400px;margin:0 auto;padding:20px}button{cursor:pointer;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;transition:all .2s;color:var(--text)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-strong)}.btn-secondary{background:var(--muted);color:#fff}.btn-secondary:hover{background:#4b5563}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}input,textarea,select{width:100%;padding:10px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;background:var(--surface);color:var(--text)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f46e526}label{display:block;margin-bottom:5px;font-weight:500;font-size:14px;color:var(--text)}.form-group{margin-bottom:16px}.card{background:var(--card);border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px;margin-bottom:20px;border:1px solid var(--border)}.card-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.card-title{font-size:20px;font-weight:700;color:var(--text);margin-bottom:16px}.navbar{background:var(--surface);box-shadow:0 1px 3px #0000001a;padding:16px 0;margin-bottom:24px;border-bottom:1px solid var(--border)}.navbar-content{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:20px;font-weight:700;color:#4f46e5;text-decoration:none}.navbar-nav{display:flex;gap:20px;align-items:center}.nav-link{text-decoration:none;color:var(--muted);font-weight:500;transition:color .2s}.nav-link:hover,.nav-link.active{color:var(--accent)}.loading{text-align:center;padding:40px;color:#6b7280}.spinner{border:3px solid #f3f4f6;border-top:3px solid #4f46e5;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:#fef2f2;color:#991b1b;padding:12px 16px;border-radius:6px;margin-bottom:16px;border:1px solid #fecaca}.success{background:#f0fdf4;color:#166534;padding:12px 16px;border-radius:6px;margin-bottom:16px;border:1px solid #bbf7d0}.post-content{line-height:1.8}.post-content h1{font-size:24px;margin:16px 0}.post-content h2{font-size:20px;margin:14px 0}.post-content h3{font-size:18px;margin:12px 0}.post-content p{margin:12px 0}.post-content ul,.post-content ol{margin:12px 0;padding-left:24px}.post-content li{margin:6px 0}.media-player{margin:16px 0}.media-player img{max-width:100%;height:auto;border-radius:8px}.media-player video,.media-player audio{width:100%;border-radius:8px}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.gap-2{gap:16px}.text-sm{font-size:14px}.text-gray{color:#6b7280}.dark body{background:var(--bg);color:var(--text)}.dark .card,.dark .navbar,.dark .user-dropdown,.dark .settings-card,.dark .admin-sidebar,.dark .admin-topbar,.dark .teacher-header{background:var(--card);border-color:var(--border);color:var(--text)}.dark .dropdown-item,.dark .dropdown-user-email,.dark .dropdown-user-name,.dark .user-menu-btn,.dark .nav-link{color:var(--text)}.dark .dropdown-item:hover,.dark .user-menu-btn:hover{background:#1f2937}.dark .admin-layout,.dark .teacher-layout,.dark .admin-main,.dark .teacher-content,.dark #app{background:var(--bg);color:var(--text)}.dark .brand-text,.dark .brand-icon,.dark .user-role,.dark .user-name,.dark .page-title,.dark .page-subtitle,.dark label,.dark .text-gray{color:var(--text)}.bg-white{background-color:#fff}.bg-slate-50{background-color:#f8fafc}.bg-slate-100{background-color:#f1f5f9}.bg-slate-200{background-color:#e2e8f0}.bg-blue-50\/30{background-color:#eff6ff4d}.bg-indigo-600{background-color:#4f46e5}.bg-amber-100{background-color:#fef3c7}.bg-orange-100{background-color:#ffedd5}.bg-cyan-100{background-color:#cffafe}.text-slate-900{color:#0f172a}.text-slate-800{color:#1e293b}.text-slate-700{color:#334155}.text-slate-600{color:#475569}.text-slate-500{color:#64748b}.text-slate-400{color:#94a3b8}.text-slate-300{color:#cbd5e1}.text-blue-600{color:#2563eb}.text-indigo-700{color:#4338ca}.text-amber-700{color:#b45309}.text-amber-800{color:#92400e}.text-orange-700{color:#c2410c}.text-cyan-700{color:#0e7490}.text-white{color:#fff}.border{border-width:1px}.border-2{border-width:2px}.border-l-4{border-left-width:4px}.border-slate-200{border-color:#e2e8f0}.border-slate-300{border-color:#cbd5e1}.border-blue-200{border-color:#bfdbfe}.border-indigo-300{border-color:#a5b4fc}.border-amber-500{border-color:#f59e0b}.border-l-amber-500{border-left-color:#f59e0b}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pl-5{padding-left:1.25rem}.pl-9{padding-left:2.25rem}.pr-3{padding-right:.75rem}.pr-8{padding-right:2rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-4{gap:1rem}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.min-h-screen{min-height:100vh}.min-w-0{min-width:0px}.max-w-4xl{max-width:56rem}.mx-auto{margin-left:auto;margin-right:auto}.flex{display:flex}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-between{justify-content:space-between}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-6{height:1.5rem}.h-10{height:2.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-full{width:100%}.w-2\/5{width:40%}.w-3\/5{width:60%}.w-4\/5{width:80%}.cursor-pointer{cursor:pointer}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.hover\:border-indigo-300:hover{border-color:#a5b4fc}.hover\:bg-indigo-700:hover{background-color:#4338ca}.hover\:scale-105:hover{transform:scale(1.05)}.active\:scale-95:active{transform:scale(.95)}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.leading-relaxed{line-height:1.625}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}
