*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f7fa;color:#333}#app{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.app-header{background:#fff;border-bottom:1px solid #e8e8e8;padding:0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px #0000000a}.container{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.logo{font-size:20px;font-weight:700;cursor:pointer;color:#1a1a1a;transition:color .3s;-webkit-user-select:none;user-select:none}.logo:hover{color:#667eea}.header-right{display:flex;align-items:center;gap:20px}.user-info{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#fafafa;border-radius:8px;transition:all .3s}.user-info:hover{background:#f0f0f0}.user-avatar{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:15px;font-weight:600;flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:3px}.user-name{font-size:14px;font-weight:600;color:#1a1a1a;line-height:1}.user-meta{font-size:12px;color:#8c8c8c;display:flex;gap:8px;line-height:1}.user-meta span:not(:last-child):after{content:"·";margin-left:8px;color:#d9d9d9}.logout-btn{padding:8px 16px;background:#fff;border:1px solid #e8e8e8;border-radius:6px;font-size:13px;color:#595959;cursor:pointer;transition:all .3s;font-weight:500}.logout-btn:hover{background:#fff1f0;border-color:#ff4d4f;color:#ff4d4f}.app-main{flex:1;padding:0}@media (max-width: 768px){.container{padding:12px 16px}.logo{font-size:18px}.user-details{display:none}.user-info{padding:8px}}.login-container[data-v-0007386e]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card[data-v-0007386e]{width:100%;max-width:450px;background:#fff;border-radius:16px;padding:40px;box-shadow:0 20px 60px #0000004d}.login-header[data-v-0007386e]{text-align:center;margin-bottom:32px}.login-header h1[data-v-0007386e]{font-size:28px;font-weight:600;color:#333;margin-bottom:8px}.subtitle[data-v-0007386e]{font-size:14px;color:#666}.login-form[data-v-0007386e]{display:flex;flex-direction:column;gap:20px}.form-group[data-v-0007386e]{display:flex;flex-direction:column;gap:8px}.form-group label[data-v-0007386e]{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:500;color:#333}.required[data-v-0007386e]{color:#f5222d}.form-input[data-v-0007386e]{padding:12px 16px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:all .3s;outline:none}.form-input[data-v-0007386e]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input[data-v-0007386e]::placeholder{color:#bbb}.error-message[data-v-0007386e]{background:#fff2f0;border:1px solid #ffccc7;color:#cf1322;padding:12px 16px;border-radius:8px;font-size:14px}.submit-btn[data-v-0007386e]{padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.submit-btn[data-v-0007386e]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.submit-btn[data-v-0007386e]:active:not(:disabled){transform:translateY(0)}.submit-btn[data-v-0007386e]:disabled{opacity:.6;cursor:not-allowed}.help-text[data-v-0007386e]{text-align:center;padding-top:8px}.help-text p[data-v-0007386e]{font-size:13px;color:#999}.modal-overlay[data-v-0007386e]{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content[data-v-0007386e]{background:#fff;border-radius:16px;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn-0007386e .3s ease-out}@keyframes modalSlideIn-0007386e{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-0007386e]{padding:24px 24px 16px;border-bottom:1px solid #f0f0f0}.modal-header h3[data-v-0007386e]{font-size:20px;font-weight:600;color:#1a1a1a;margin:0}.modal-body[data-v-0007386e]{padding:24px}.modal-desc[data-v-0007386e]{font-size:15px;color:#595959;margin:0 0 20px;line-height:1.6}.modal-hint[data-v-0007386e]{font-size:13px;color:#999;margin:12px 0 0}.modal-footer[data-v-0007386e]{padding:16px 24px 24px}.modal-btn[data-v-0007386e]{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.modal-btn[data-v-0007386e]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.modal-btn[data-v-0007386e]:active:not(:disabled){transform:translateY(0)}.modal-btn[data-v-0007386e]:disabled{opacity:.6;cursor:not-allowed}.notice-banner[data-v-f4daf7d9]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 24px;border-radius:12px;margin-bottom:24px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #667eea4d;animation:slideDown-f4daf7d9 .3s ease-out}@keyframes slideDown-f4daf7d9{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notice-icon[data-v-f4daf7d9]{font-size:24px;flex-shrink:0}.notice-scroll-container[data-v-f4daf7d9]{flex:1;overflow:hidden;position:relative}.notice-text[data-v-f4daf7d9]{font-size:15px;line-height:1.6;white-space:nowrap;display:inline-block}.notice-text.scrolling[data-v-f4daf7d9]{animation:scroll-f4daf7d9 20s linear infinite}.notice-text.scrolling.paused[data-v-f4daf7d9]{animation-play-state:paused}@keyframes scroll-f4daf7d9{0%{transform:translate(0)}to{transform:translate(-100%)}}.notice-text[data-v-f4daf7d9] a{color:#fff;text-decoration:underline;font-weight:600;transition:opacity .3s}.notice-text[data-v-f4daf7d9] a:hover{opacity:.8}.notice-close[data-v-f4daf7d9]{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:24px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notice-close[data-v-f4daf7d9]:hover{background:#ffffff4d;transform:scale(1.1)}.course-list-page[data-v-f4daf7d9]{min-height:calc(100vh - 100px);background:#f8f9fa}.page-container[data-v-f4daf7d9]{max-width:1400px;margin:0 auto;padding:32px 24px}.page-title-section[data-v-f4daf7d9]{margin-bottom:32px;display:flex;justify-content:space-between;align-items:center}.title-content[data-v-f4daf7d9]{display:flex;align-items:baseline;gap:16px}.page-title[data-v-f4daf7d9]{font-size:32px;font-weight:700;color:#1a1a1a;margin:0}.page-subtitle[data-v-f4daf7d9]{font-size:15px;color:#8c8c8c;margin:0}.usage-info[data-v-f4daf7d9]{background:linear-gradient(135deg,#667eea,#764ba2);padding:12px 20px;border-radius:12px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #667eea33}.usage-label[data-v-f4daf7d9]{color:#ffffffe6;font-size:14px}.usage-count[data-v-f4daf7d9]{color:#fff;font-size:18px;font-weight:600}.loading-state[data-v-f4daf7d9]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 20px;gap:16px}.spinner[data-v-f4daf7d9]{width:48px;height:48px;border:4px solid #e8e8e8;border-top-color:#667eea;border-radius:50%;animation:spin-f4daf7d9 .8s linear infinite}@keyframes spin-f4daf7d9{to{transform:rotate(360deg)}}.loading-state p[data-v-f4daf7d9]{font-size:15px;color:#8c8c8c}.error-state[data-v-f4daf7d9]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 20px;gap:16px}.error-icon[data-v-f4daf7d9]{font-size:64px}.error-text[data-v-f4daf7d9]{font-size:16px;color:#ff4d4f;margin:0}.retry-btn[data-v-f4daf7d9]{margin-top:8px;padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s}.retry-btn[data-v-f4daf7d9]:hover{background:#5568d3;transform:translateY(-1px)}.courses-container[data-v-f4daf7d9]{width:100%}.course-grid[data-v-f4daf7d9]{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.course-card[data-v-f4daf7d9]{background:#fff;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0}.course-card[data-v-f4daf7d9]:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#667eea}.card-image[data-v-f4daf7d9]{position:relative;width:100%;height:180px;overflow:hidden;background:#f5f5f5}.card-image img[data-v-f4daf7d9]{width:100%;height:100%;object-fit:cover;transition:transform .3s}.course-card:hover .card-image img[data-v-f4daf7d9]{transform:scale(1.05)}.status-tag[data-v-f4daf7d9]{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.status-tag.active[data-v-f4daf7d9]{background:#52c41ae6}.status-tag.completed[data-v-f4daf7d9]{background:#52c41af2;box-shadow:0 2px 8px #52c41a4d}.status-tag.upcoming[data-v-f4daf7d9]{background:#1890ffe6}.status-tag.ended[data-v-f4daf7d9]{background:#00000080}.card-body[data-v-f4daf7d9]{padding:20px}.course-name[data-v-f4daf7d9]{font-size:17px;font-weight:600;color:#1a1a1a;margin:0 0 16px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:48px}.course-info[data-v-f4daf7d9]{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding:12px;background:#fafafa;border-radius:8px}.info-row[data-v-f4daf7d9]{display:flex;justify-content:space-between;align-items:center;font-size:13px}.info-label[data-v-f4daf7d9]{color:#8c8c8c}.info-value[data-v-f4daf7d9]{color:#1a1a1a;font-weight:500}.progress-section[data-v-f4daf7d9]{margin-bottom:16px}.progress-header[data-v-f4daf7d9]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-label[data-v-f4daf7d9]{font-size:13px;color:#8c8c8c}.progress-percent[data-v-f4daf7d9]{font-size:14px;font-weight:600;color:#667eea}.progress-track[data-v-f4daf7d9]{height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.progress-bar[data-v-f4daf7d9]{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .6s ease}.recent-learn[data-v-f4daf7d9]{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f6f8ff;border-radius:8px;font-size:13px;color:#595959}.recent-icon[data-v-f4daf7d9]{font-size:14px;flex-shrink:0}.recent-text[data-v-f4daf7d9]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state[data-v-f4daf7d9]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 20px;gap:12px}.empty-icon[data-v-f4daf7d9]{font-size:64px;opacity:.3}.empty-text[data-v-f4daf7d9]{font-size:18px;font-weight:500;color:#595959;margin:0}.empty-hint[data-v-f4daf7d9]{font-size:14px;color:#8c8c8c;margin:0}@media (max-width: 768px){.course-grid[data-v-f4daf7d9]{grid-template-columns:1fr;gap:16px}.page-title[data-v-f4daf7d9]{font-size:24px}.title-content[data-v-f4daf7d9]{flex-direction:column;gap:8px}}.course-detail-page[data-v-9c029096]{min-height:calc(100vh - 100px);background:#f8f9fa}.page-container[data-v-9c029096]{max-width:1200px;margin:0 auto;padding:32px 24px}.back-btn[data-v-9c029096]{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;color:#595959;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;margin-bottom:24px}.back-btn[data-v-9c029096]:hover{background:#fafafa;border-color:#667eea;color:#667eea;transform:translate(-2px)}.back-icon[data-v-9c029096]{font-size:16px;transition:transform .3s}.back-btn:hover .back-icon[data-v-9c029096]{transform:translate(-2px)}.course-info-card[data-v-9c029096]{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0}.course-title-section[data-v-9c029096]{display:flex;flex-direction:column;gap:20px}.course-title[data-v-9c029096]{font-size:28px;font-weight:700;color:#1a1a1a;margin:0;line-height:1.3}.course-meta-row[data-v-9c029096]{display:flex;gap:12px;flex-wrap:wrap}.meta-badge[data-v-9c029096]{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fafafa;border-radius:8px;border:1px solid #f0f0f0}.meta-badge.highlight[data-v-9c029096]{background:#f0f5ff;border-color:#d6e4ff}.meta-label[data-v-9c029096]{font-size:13px;color:#8c8c8c}.meta-value[data-v-9c029096]{font-size:16px;font-weight:600;color:#1a1a1a}.meta-badge.highlight .meta-value[data-v-9c029096]{color:#667eea}.stats-grid[data-v-9c029096]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-box[data-v-9c029096]{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0;transition:all .3s}.stat-box[data-v-9c029096]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon[data-v-9c029096]{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;background:#fafafa;flex-shrink:0}.stat-box.success .stat-icon[data-v-9c029096]{background:#f6ffed}.stat-box.warning .stat-icon[data-v-9c029096]{background:#fff7e6}.stat-box.info .stat-icon[data-v-9c029096]{background:#e6f7ff}.stat-box.danger .stat-icon[data-v-9c029096]{background:#fff1f0}.stat-content[data-v-9c029096]{display:flex;flex-direction:column;gap:4px}.stat-number[data-v-9c029096]{font-size:28px;font-weight:700;color:#1a1a1a}.stat-box.success .stat-number[data-v-9c029096]{color:#52c41a}.stat-box.warning .stat-number[data-v-9c029096]{color:#fa8c16}.stat-box.info .stat-number[data-v-9c029096]{color:#1890ff}.stat-box.danger .stat-number[data-v-9c029096]{color:#ff4d4f}.stat-text[data-v-9c029096]{font-size:13px;color:#8c8c8c}.stat-detail[data-v-9c029096]{font-size:12px;color:#bfbfbf;margin-top:2px}.stat-box.loading[data-v-9c029096]{opacity:.6}.section-header[data-v-9c029096]{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.section-title-group[data-v-9c029096]{display:flex;align-items:baseline;gap:12px}.section-title[data-v-9c029096]{font-size:20px;font-weight:600;color:#1a1a1a;margin:0}.section-count[data-v-9c029096]{font-size:14px;color:#8c8c8c}.header-actions[data-v-9c029096]{display:flex;gap:10px;align-items:center}.view-assignments-btn[data-v-9c029096]{padding:6px 14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s;white-space:nowrap}.view-assignments-btn[data-v-9c029096]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.complete-all-btn[data-v-9c029096]{padding:6px 14px;background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f;border-radius:12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s;white-space:nowrap}.complete-all-btn[data-v-9c029096]:hover:not(:disabled){background:#d9f7be;border-color:#95de64;transform:translateY(-1px)}.complete-all-btn[data-v-9c029096]:disabled{opacity:.6;cursor:not-allowed}.error-state[data-v-9c029096]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:20px;background:#fff;border-radius:12px;border:2px solid #ff4d4f;box-shadow:0 2px 8px #ff4d4f1a}.error-icon[data-v-9c029096]{font-size:64px}.error-content[data-v-9c029096]{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.error-title[data-v-9c029096]{font-size:20px;font-weight:600;color:#ff4d4f;margin:0}.error-message[data-v-9c029096]{font-size:15px;color:#595959;margin:0;white-space:pre-line;line-height:1.6}.error-actions[data-v-9c029096]{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;justify-content:center}.retry-btn[data-v-9c029096]{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px}.retry-btn[data-v-9c029096]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.retry-btn[data-v-9c029096]:active{transform:translateY(0)}.update-cookie-btn[data-v-9c029096]{padding:10px 24px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px}.update-cookie-btn[data-v-9c029096]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.update-cookie-btn[data-v-9c029096]:active{transform:translateY(0)}.loading-state[data-v-9c029096]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;background:#fff;border-radius:12px;border:1px solid #f0f0f0}.spinner[data-v-9c029096]{width:48px;height:48px;border:4px solid #e8e8e8;border-top-color:#667eea;border-radius:50%;animation:spin-9c029096 .8s linear infinite}@keyframes spin-9c029096{to{transform:rotate(360deg)}}.loading-state p[data-v-9c029096]{font-size:15px;color:#8c8c8c;margin:0}.chapters-container[data-v-9c029096]{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0;overflow:hidden}.chapter-list[data-v-9c029096]{display:flex;flex-direction:column}.chapter-row[data-v-9c029096]{display:flex;gap:16px;padding:20px 24px;border-bottom:1px solid #f5f5f5;transition:all .3s;background:#fff}.chapter-row[data-v-9c029096]:last-child{border-bottom:none}.chapter-row[data-v-9c029096]:hover{background:#fafafa}.chapter-row.is-completed[data-v-9c029096]{background:#f6ffed}.chapter-row.is-completed[data-v-9c029096]:hover{background:#f0f9e8}.chapter-index[data-v-9c029096]{flex-shrink:0}.index-badge[data-v-9c029096]{width:40px;height:40px;border-radius:10px;background:#fafafa;border:2px solid #e8e8e8;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#595959;transition:all .3s}.index-badge.is-completed[data-v-9c029096]{background:#52c41a;border-color:#52c41a;color:#fff}.check-icon[data-v-9c029096]{font-size:18px;font-weight:700}.chapter-content[data-v-9c029096]{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.chapter-header-row[data-v-9c029096]{display:flex;align-items:center;justify-content:space-between;gap:16px}.chapter-name[data-v-9c029096]{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.type-icon[data-v-9c029096]{font-size:20px;flex-shrink:0}.name-text[data-v-9c029096]{font-size:15px;font-weight:500;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chapter-badge[data-v-9c029096]{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;flex-shrink:0}.chapter-badge.completed[data-v-9c029096]{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.chapter-badge.pending[data-v-9c029096]{background:#fff7e6;color:#fa8c16;border:1px solid #ffd591}.chapter-footer[data-v-9c029096]{display:flex;align-items:center;justify-content:space-between;gap:16px}.chapter-footer-left[data-v-9c029096]{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.duration-text[data-v-9c029096]{font-size:13px;color:#8c8c8c}.chapter-complete-btn[data-v-9c029096]{padding:5px 12px;background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f;border-radius:12px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0}.chapter-complete-btn[data-v-9c029096]:hover:not(:disabled){background:#d9f7be;border-color:#95de64}.chapter-complete-btn[data-v-9c029096]:disabled{opacity:.6;cursor:not-allowed}.chapter-meta[data-v-9c029096]{font-size:12px;color:#8c8c8c;padding:4px 10px;background:#fafafa;border-radius:6px;display:inline-flex;align-items:center;gap:4px}.chapter-meta.duration[data-v-9c029096]{background:#e6f4ff;color:#0958d9;font-weight:500}.empty-state[data-v-9c029096]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:12px;background:#fff;border-radius:12px;border:1px solid #f0f0f0}.empty-icon[data-v-9c029096]{font-size:64px;opacity:.3}.empty-text[data-v-9c029096]{font-size:18px;font-weight:500;color:#595959;margin:0}.empty-hint[data-v-9c029096]{font-size:14px;color:#8c8c8c;margin:0}.modal-overlay[data-v-9c029096]{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-content[data-v-9c029096]{background:#fff;border-radius:12px;width:100%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn-9c029096 .3s ease-out}@keyframes modalSlideIn-9c029096{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-9c029096]{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #f0f0f0}.modal-header h3[data-v-9c029096]{font-size:20px;font-weight:600;color:#1a1a1a;margin:0}.modal-close[data-v-9c029096]{width:32px;height:32px;border:none;background:#f5f5f5;border-radius:8px;font-size:24px;color:#8c8c8c;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;line-height:1}.modal-close[data-v-9c029096]:hover{background:#e8e8e8;color:#595959}.modal-body[data-v-9c029096]{padding:24px}.modal-form-group[data-v-9c029096]{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.modal-form-group label[data-v-9c029096]{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:500;color:#333}.modal-label[data-v-9c029096]{color:#1a1a1a}.modal-required[data-v-9c029096]{color:#f5222d}.modal-input[data-v-9c029096]{padding:12px 16px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:all .3s;outline:none;font-family:monospace}.modal-input[data-v-9c029096]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-hint[data-v-9c029096]{background:#f0f5ff;border:1px solid #d6e4ff;border-radius:8px;padding:12px;font-size:13px;color:#595959;line-height:1.5}.modal-error[data-v-9c029096]{background:#fff2f0;border:1px solid #ffccc7;color:#cf1322;padding:12px;border-radius:8px;font-size:13px;margin-top:12px}.modal-footer[data-v-9c029096]{display:flex;gap:12px;padding:16px 24px 24px;justify-content:flex-end}.modal-cancel-btn[data-v-9c029096]{padding:10px 24px;background:#fff;color:#595959;border:1px solid #e8e8e8;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.modal-cancel-btn[data-v-9c029096]:hover{background:#fafafa;border-color:#d9d9d9}.modal-confirm-btn[data-v-9c029096]{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.modal-confirm-btn[data-v-9c029096]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.modal-confirm-btn[data-v-9c029096]:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.stats-grid[data-v-9c029096]{grid-template-columns:1fr;gap:12px}.course-title[data-v-9c029096]{font-size:22px}.chapter-row[data-v-9c029096]{padding:16px}.index-badge[data-v-9c029096]{width:36px;height:36px;font-size:14px}.chapter-name[data-v-9c029096]{flex-direction:column;align-items:flex-start;gap:4px}.modal-content[data-v-9c029096]{margin:20px}}.admin-container[data-v-e6e98636]{min-height:100vh;background:#f5f5f5}.admin-login[data-v-e6e98636]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card[data-v-e6e98636]{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-card h1[data-v-e6e98636]{font-size:28px;margin:0 0 8px;text-align:center}.subtitle[data-v-e6e98636]{text-align:center;color:#666;margin:0 0 24px}.login-form[data-v-e6e98636]{display:flex;flex-direction:column;gap:16px}.form-group[data-v-e6e98636]{display:flex;flex-direction:column;gap:8px}.form-group label[data-v-e6e98636]{font-size:14px;font-weight:500;color:#333}.form-group input[data-v-e6e98636],.form-group select[data-v-e6e98636]{padding:12px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:all .3s}.form-group input[data-v-e6e98636]:focus,.form-group select[data-v-e6e98636]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message[data-v-e6e98636]{background:#fff2f0;border:1px solid #ffccc7;color:#cf1322;padding:12px;border-radius:8px;font-size:14px}.success-message[data-v-e6e98636]{background:#f6ffed;border:1px solid #b7eb8f;color:#52c41a;padding:12px;border-radius:8px;font-size:14px}button[data-v-e6e98636]{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}button[data-v-e6e98636]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}button[data-v-e6e98636]:disabled{opacity:.6;cursor:not-allowed}.admin-dashboard[data-v-e6e98636]{min-height:100vh;padding:24px;animation:fadeIn-e6e98636 .3s ease-out}.admin-dashboard.fade-out[data-v-e6e98636]{animation:fadeOut-e6e98636 .3s ease-out forwards}@keyframes fadeIn-e6e98636{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut-e6e98636{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.admin-header[data-v-e6e98636]{background:#fff;padding:24px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.header-left h1[data-v-e6e98636]{margin:0 0 4px;font-size:24px}.admin-info[data-v-e6e98636]{margin:0;color:#666;font-size:14px}.logout-btn[data-v-e6e98636]{padding:10px 20px;background:#ff4d4f;font-size:14px}.admin-content[data-v-e6e98636]{max-width:1200px;margin:0 auto}.section[data-v-e6e98636]{background:#fff;padding:24px;border-radius:12px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.section h2[data-v-e6e98636]{margin:0 0 20px;font-size:20px}.section-header[data-v-e6e98636]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2[data-v-e6e98636]{margin:0}.refresh-btn[data-v-e6e98636]{padding:8px 16px;font-size:14px}.notice-form[data-v-e6e98636]{display:flex;flex-direction:column;gap:16px}.notice-form textarea[data-v-e6e98636]{padding:12px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;font-family:inherit;transition:all .3s;resize:vertical}.notice-form textarea[data-v-e6e98636]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.save-notice-btn[data-v-e6e98636]{padding:10px 20px;font-size:14px;background:linear-gradient(135deg,#52c41a,#73d13d)}.save-notice-btn[data-v-e6e98636]:hover:not(:disabled){box-shadow:0 4px 12px #52c41a66}.password-form[data-v-e6e98636]{display:flex;flex-direction:column;gap:16px}.change-password-btn[data-v-e6e98636]{padding:10px 20px;font-size:14px;background:linear-gradient(135deg,#faad14,#ffc53d);max-width:200px}.change-password-btn[data-v-e6e98636]:hover:not(:disabled){box-shadow:0 4px 12px #faad1466}.login-tip[data-v-e6e98636]{text-align:center;color:#999;font-size:13px;margin-top:-8px}.generate-form[data-v-e6e98636]{display:flex;flex-direction:column;gap:16px}.form-row[data-v-e6e98636]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.checkbox-group[data-v-e6e98636]{display:flex;align-items:center}.checkbox-group label[data-v-e6e98636]{display:flex;align-items:center;gap:8px;cursor:pointer}.generate-btn[data-v-e6e98636]{max-width:200px}.invites-list[data-v-e6e98636]{display:flex;flex-direction:column;gap:16px}.invite-card[data-v-e6e98636]{border:1px solid #e8e8e8;border-radius:8px;padding:16px;transition:all .3s}.invite-card[data-v-e6e98636]:hover{box-shadow:0 2px 8px #0000001a}.invite-header[data-v-e6e98636]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.invite-code[data-v-e6e98636]{font-size:18px;font-weight:600;font-family:monospace}.invite-status[data-v-e6e98636]{padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.invite-status.active[data-v-e6e98636]{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.invite-status.used[data-v-e6e98636]{background:#e6f4ff;color:#1890ff;border:1px solid #91d5ff}.invite-status.expired[data-v-e6e98636]{background:#fff2e8;color:#fa8c16;border:1px solid #ffd591}.invite-info[data-v-e6e98636]{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.invite-info>div[data-v-e6e98636]{display:flex;gap:8px;font-size:14px}.label[data-v-e6e98636]{color:#999;min-width:80px}.value[data-v-e6e98636]{color:#333}.bound-info .value[data-v-e6e98636]{font-weight:500;color:#1890ff}.delete-btn[data-v-e6e98636]{padding:8px 16px;background:#ff4d4f;font-size:14px;max-width:100px}.loading[data-v-e6e98636],.empty[data-v-e6e98636]{text-align:center;color:#999;padding:40px 20px}.assignment-list[data-v-78b93c67]{max-width:1200px;margin:0 auto;padding:20px}.stats-header[data-v-78b93c67]{margin-bottom:30px}.stats-header h2[data-v-78b93c67]{font-size:28px;font-weight:600;margin-bottom:20px;color:#1a1a1a}.stats-cards[data-v-78b93c67]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.stat-card[data-v-78b93c67]{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:12px;color:#fff;text-align:center}.stat-card.submitted[data-v-78b93c67]{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-card.unsubmitted[data-v-78b93c67]{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-card.avg-score[data-v-78b93c67]{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-value[data-v-78b93c67]{font-size:36px;font-weight:700;margin-bottom:5px}.stat-label[data-v-78b93c67]{font-size:14px;opacity:.9}.loading[data-v-78b93c67]{text-align:center;padding:60px 20px}.spinner[data-v-78b93c67]{width:50px;height:50px;margin:0 auto 20px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin-78b93c67 1s linear infinite}@keyframes spin-78b93c67{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message[data-v-78b93c67]{text-align:center;padding:40px 20px;color:#e53e3e}.retry-btn[data-v-78b93c67]{margin-top:15px;padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.retry-btn[data-v-78b93c67]:hover{background:#5568d3}.assignments-container[data-v-78b93c67]{display:grid;gap:20px}.assignment-card[data-v-78b93c67]{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s}.assignment-card[data-v-78b93c67]:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.assignment-card.locked[data-v-78b93c67]{opacity:.6}.card-header[data-v-78b93c67]{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #f0f0f0}.assignment-title[data-v-78b93c67]{font-size:20px;font-weight:600;color:#1a1a1a;margin:0}.status-badge[data-v-78b93c67]{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.locked[data-v-78b93c67]{background:#e2e8f0;color:#64748b}.status-badge.unsubmitted[data-v-78b93c67]{background:#fef3c7;color:#d97706}.status-badge.submitted[data-v-78b93c67]{background:#dbeafe;color:#2563eb}.status-badge.graded[data-v-78b93c67]{background:#d1fae5;color:#059669}.card-body[data-v-78b93c67]{padding:20px}.assignment-info[data-v-78b93c67]{display:grid;gap:10px;margin-bottom:15px}.info-row[data-v-78b93c67]{display:flex;font-size:14px}.info-row .label[data-v-78b93c67]{color:#6b7280;min-width:80px}.info-row .value[data-v-78b93c67]{color:#1a1a1a}.submission-info[data-v-78b93c67]{display:flex;gap:20px;padding:15px;background:#f9fafb;border-radius:8px;margin-bottom:15px}.score-circle[data-v-78b93c67]{width:80px;height:80px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;border:4px solid}.score-circle.excellent[data-v-78b93c67]{border-color:#10b981;background:#d1fae5;color:#059669}.score-circle.good[data-v-78b93c67]{border-color:#3b82f6;background:#dbeafe;color:#2563eb}.score-circle.medium[data-v-78b93c67]{border-color:#f59e0b;background:#fef3c7;color:#d97706}.score-circle.pass[data-v-78b93c67]{border-color:#8b5cf6;background:#ede9fe;color:#7c3aed}.score-circle.fail[data-v-78b93c67]{border-color:#ef4444;background:#fee2e2;color:#dc2626}.score-circle.no-score[data-v-78b93c67]{border-color:#9ca3af;background:#f3f4f6;color:#6b7280}.score[data-v-78b93c67]{font-size:24px}.total[data-v-78b93c67]{font-size:12px;opacity:.7}.submission-details[data-v-78b93c67]{flex:1;display:flex;flex-direction:column;gap:8px}.detail-row[data-v-78b93c67]{display:flex;font-size:14px}.detail-row .label[data-v-78b93c67]{color:#6b7280;margin-right:8px}.late-badge[data-v-78b93c67]{background:#fee2e2;color:#dc2626;padding:2px 8px;border-radius:4px;font-size:12px}.assignment-body[data-v-78b93c67],.grading-standard[data-v-78b93c67]{margin-top:15px}details[data-v-78b93c67]{cursor:pointer}summary[data-v-78b93c67]{padding:10px;background:#f9fafb;border-radius:6px;font-size:14px;color:#667eea;font-weight:500;-webkit-user-select:none;user-select:none}summary[data-v-78b93c67]:hover{background:#f3f4f6}.body-content[data-v-78b93c67],.standard-content[data-v-78b93c67]{padding:15px;margin-top:10px;border-left:3px solid #667eea;background:#f9fafb;font-size:14px;line-height:1.6}.body-content[data-v-78b93c67] a,.standard-content[data-v-78b93c67] a{color:#667eea;text-decoration:none}.body-content[data-v-78b93c67] a:hover,.standard-content[data-v-78b93c67] a:hover{text-decoration:underline}.card-footer[data-v-78b93c67]{padding:15px 20px;border-top:1px solid #f0f0f0;display:flex;gap:10px;justify-content:flex-end}.action-btn[data-v-78b93c67]{padding:8px 20px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.submit-btn[data-v-78b93c67]{background:#667eea;color:#fff}.submit-btn[data-v-78b93c67]:hover{background:#5568d3}.view-btn[data-v-78b93c67]{background:#f3f4f6;color:#1a1a1a}.view-btn[data-v-78b93c67]:hover{background:#e5e7eb}.back-btn[data-v-78b93c67]{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s;margin-bottom:20px}.back-btn[data-v-78b93c67]:hover{background:#f9fafb;border-color:#d1d5db}.back-icon[data-v-78b93c67]{font-size:18px;font-weight:700}.modal-overlay[data-v-78b93c67]{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-content[data-v-78b93c67]{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 50px #0000004d}.modal-header[data-v-78b93c67]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h3[data-v-78b93c67]{font-size:20px;font-weight:600;color:#1a1a1a;margin:0}.close-btn[data-v-78b93c67]{width:32px;height:32px;border:none;background:#f3f4f6;border-radius:8px;font-size:24px;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn[data-v-78b93c67]:hover{background:#e5e7eb;color:#374151}.modal-body[data-v-78b93c67]{flex:1;overflow-y:auto;padding:24px}.detail-section[data-v-78b93c67]{margin-bottom:24px}.detail-section[data-v-78b93c67]:last-child{margin-bottom:0}.detail-section h4[data-v-78b93c67]{font-size:16px;font-weight:600;color:#1a1a1a;margin:0 0 12px;display:flex;align-items:center;gap:8px}.detail-grid[data-v-78b93c67]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.detail-item[data-v-78b93c67]{display:flex;align-items:center;gap:8px}.detail-label[data-v-78b93c67]{font-size:14px;color:#6b7280;white-space:nowrap}.detail-value[data-v-78b93c67]{font-size:14px;color:#1a1a1a;font-weight:500}.score-highlight[data-v-78b93c67]{font-size:18px;color:#667eea;font-weight:600}.late-warning[data-v-78b93c67]{background:#fee2e2;color:#dc2626;padding:4px 12px;border-radius:6px;font-size:13px;font-weight:500}.detail-content[data-v-78b93c67]{background:#f9fafb;padding:16px;border-radius:8px;border-left:3px solid #667eea;font-size:14px;line-height:1.6;color:#374151}.detail-content[data-v-78b93c67] a{color:#667eea;text-decoration:none}.detail-content[data-v-78b93c67] a:hover{text-decoration:underline}.detail-content[data-v-78b93c67] p{margin:8px 0}.peer-review-list[data-v-78b93c67]{display:flex;flex-direction:column;gap:12px}.peer-review-item[data-v-78b93c67]{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:all .2s}.peer-review-item.self[data-v-78b93c67]{background:#fef3c7;border-color:#fbbf24}.peer-review-item[data-v-78b93c67]:hover{box-shadow:0 2px 8px #00000014}.review-header-detail[data-v-78b93c67]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.reviewer-name-detail[data-v-78b93c67]{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#374151}.review-type-badge[data-v-78b93c67]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500;background:#dbeafe;color:#1d4ed8}.review-type-badge.self[data-v-78b93c67]{background:#fef3c7;color:#92400e}.review-score-detail[data-v-78b93c67]{font-size:16px;font-weight:600;color:#667eea}.review-comment-detail[data-v-78b93c67]{font-size:14px;line-height:1.6;color:#4b5563;background:#fff;padding:12px;border-radius:6px}.review-comment-detail[data-v-78b93c67] p{margin:4px 0}.review-comment-detail[data-v-78b93c67] p:first-child{margin-top:0}.review-comment-detail[data-v-78b93c67] p:last-child{margin-bottom:0}.review-assets[data-v-78b93c67]{margin-top:10px;background:#f3f4f6;border-radius:6px;padding:8px 10px}.asset-title[data-v-78b93c67]{font-size:13px;color:#6b7280;margin-bottom:6px}.asset-list[data-v-78b93c67]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.asset-link[data-v-78b93c67]{color:#2563eb;text-decoration:none;font-size:14px}.asset-link[data-v-78b93c67]:hover{text-decoration:underline}.asset-empty[data-v-78b93c67]{font-size:13px;color:#9ca3af}.modal-footer[data-v-78b93c67]{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb}.modal-btn[data-v-78b93c67]{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.modal-btn.secondary[data-v-78b93c67]{background:#f3f4f6;color:#374151}.modal-btn.secondary[data-v-78b93c67]:hover{background:#e5e7eb}.modal-btn.primary[data-v-78b93c67]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-btn.primary[data-v-78b93c67]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.peer-review-modal[data-v-78b93c67]{max-width:900px}.peer-stats[data-v-78b93c67]{display:flex;gap:20px;padding:16px;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:12px;border:1px solid #667eea30}.stat-item[data-v-78b93c67]{display:flex;align-items:center;gap:8px}.stat-item .stat-label[data-v-78b93c67]{font-size:14px;color:#6b7280}.stat-item .stat-value[data-v-78b93c67]{font-size:18px;font-weight:600;color:#667eea}.peer-review-container[data-v-78b93c67]{display:flex;flex-direction:column;gap:24px}.peer-status-banner[data-v-78b93c67]{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:16px}.status-badge[data-v-78b93c67]{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500;margin-bottom:8px}.status-badge.active[data-v-78b93c67]{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669;border:1px solid #10b981}.status-badge.ended[data-v-78b93c67]{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border:1px solid #ef4444}.status-badge.not-started[data-v-78b93c67]{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;border:1px solid #3b82f6}.status-icon[data-v-78b93c67]{font-size:16px}.time-info[data-v-78b93c67]{font-size:13px;color:#6b7280;padding-left:28px}.review-section[data-v-78b93c67]{display:flex;flex-direction:column;gap:12px}.section-title[data-v-78b93c67]{font-size:16px;font-weight:600;color:#1a1a1a;margin:0;padding-bottom:8px;border-bottom:2px solid #f0f0f0}.review-card[data-v-78b93c67]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;transition:all .2s}.review-card[data-v-78b93c67]:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.review-card.self-review[data-v-78b93c67]{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.review-header[data-v-78b93c67]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.reviewer-info[data-v-78b93c67]{display:flex;align-items:center;gap:8px}.reviewer-name[data-v-78b93c67]{font-size:15px;font-weight:600;color:#1a1a1a}.self-badge[data-v-78b93c67]{background:#f59e0b;color:#fff;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.review-score[data-v-78b93c67]{font-size:20px;font-weight:700;color:#667eea}.review-card.self-review .review-score[data-v-78b93c67]{color:#d97706}.review-comment[data-v-78b93c67]{background:#f9fafb;padding:12px;border-radius:8px;font-size:14px;line-height:1.6;color:#374151;min-height:60px}.review-card.self-review .review-comment[data-v-78b93c67]{background:#fff}.review-comment[data-v-78b93c67] p{margin:4px 0}.review-meta[data-v-78b93c67]{margin-top:8px;padding-top:8px;border-top:1px solid #e5e7eb;display:flex;gap:12px}.meta-item[data-v-78b93c67]{font-size:12px;color:#9ca3af}.empty-state[data-v-78b93c67]{text-align:center;padding:40px 20px;color:#9ca3af}.loading-state[data-v-78b93c67]{text-align:center;padding:40px 20px}.error-state[data-v-78b93c67]{text-align:center;padding:40px 20px;color:#ef4444}.review-editor[data-v-78b93c67]{margin:12px 0}.score-input[data-v-78b93c67]{width:80px;padding:6px 10px;border:2px solid #e5e7eb;border-radius:6px;font-size:16px;font-weight:600;text-align:center;color:#667eea;transition:border-color .2s}.score-input[data-v-78b93c67]:focus{outline:none;border-color:#667eea}.score-display[data-v-78b93c67]{font-size:20px;font-weight:700;color:#667eea}.review-card.self-review .score-display[data-v-78b93c67]{color:#d97706}.comment-textarea[data-v-78b93c67]{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;line-height:1.6;resize:vertical;font-family:inherit;transition:border-color .2s}.comment-textarea[data-v-78b93c67]:focus{outline:none;border-color:#667eea}.editor-actions[data-v-78b93c67]{display:flex;justify-content:flex-end;margin-top:8px}.save-btn[data-v-78b93c67]{padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.save-btn[data-v-78b93c67]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.save-btn[data-v-78b93c67]:disabled{opacity:.6;cursor:not-allowed}.current-comment[data-v-78b93c67]{margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.comment-label[data-v-78b93c67]{font-size:13px;color:#6b7280;margin-bottom:8px;font-weight:500}
