
.portal-logo img {
  max-height: 100px !important;
  -o-object-fit: contain;
     object-fit: contain;
}


/* 使用CSS变量应用主题色 */
.login-container[data-v-73f25ddf] {
  --theme-color: #007bff;
  --background-image: none;
}

/* 右侧背景区域 */
.login-right[data-v-73f25ddf] {
  background-color: var(--theme-color);
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.login-right.has-background[data-v-73f25ddf] {
  background-color: transparent;
}

/* LOGO样式 */
.portal-logo[data-v-73f25ddf] {
  margin-bottom: 20px;
}

/* 标题样式 */
.portal-title[data-v-73f25ddf] {
  color: white;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-align: center;
  margin: 0;
}

/* 主题按钮样式 */
.themed-button[data-v-73f25ddf] {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
}
.themed-button[data-v-73f25ddf]:hover {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
  opacity: 0.8;
}

/* 主题链接样式 */
.themed-link[data-v-73f25ddf] {
  color: var(--theme-color) !important;
}
.themed-link[data-v-73f25ddf]:hover {
  color: var(--theme-color) !important;
  opacity: 0.8;
}
.themed-link-span[data-v-73f25ddf] {
  color: var(--theme-color);
  cursor: pointer;
}
.themed-link-span[data-v-73f25ddf]:hover {
  opacity: 0.8;
}

/* 忘记密码链接 */
.forgot-password a[data-v-73f25ddf] {
  color: var(--theme-color);
  text-decoration: none;
}
.forgot-password a[data-v-73f25ddf]:hover {
  opacity: 0.8;
}

/* 验证码按钮 */
.verification-button[data-v-73f25ddf] {
  background-color: var(--theme-color);
  border: 1px solid var(--theme-color);
  color: white;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
}
.verification-button[data-v-73f25ddf]:hover:not(:disabled) {
  opacity: 0.8;
}
.verification-button[data-v-73f25ddf]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Vue 过渡动画的类名 */
.slide-fade-enter-active[data-v-73f25ddf] {
  animation: slideIn-73f25ddf 0.5s ease forwards;
}
.slide-fade-leave-active[data-v-73f25ddf] {
  animation: slideOut-73f25ddf 0.5s ease forwards;
}
.below-gauge[data-v-73f25ddf] {
  margin-bottom: 10px;
}

/* 动画效果 */
@keyframes slideIn-73f25ddf {
from {
    transform: translateX(100%);
    opacity: 0;
}
to {
    transform: translateX(0);
    opacity: 1;
}
}
@keyframes slideOut-73f25ddf {
from {
    transform: translateX(0);
    opacity: 1;
}
to {
    transform: translateX(-100%);
    opacity: 0;
}
}

/* 通用样式 */
.google-btn[data-v-73f25ddf] {
  margin-bottom: 20px;
  width: 100%;
}
.or-text[data-v-73f25ddf] {
  text-align: center;
  margin: 20px 0;
}
.forgot-password[data-v-73f25ddf] {
  text-align: right;
  margin-top: 10px;
  cursor: pointer;
}
.login-btn[data-v-73f25ddf] {
  margin-top: 20px;
  width: 100%;
}
.secure-code-btn[data-v-73f25ddf] {
  margin-top: 10px;
  width: 100%;
}
.signup-link[data-v-73f25ddf] {
  text-align: center;
  margin-top: 15px;
}
.verification-container[data-v-73f25ddf] {
  display: flex;
  position: relative;
  margin: 10px 0;
}


/* 使用CSS变量应用主题色 */
.login-container[data-v-10e61731] {
  --theme-color: #007bff;
  --background-image: none;
}

/* 左侧LOGO样式 - 左上角显示 */
.portal-logo-left img[data-v-10e61731] {
  max-width: 120px;
  max-height: 60px;
  -o-object-fit: contain;
     object-fit: contain;
}

/* 右侧背景区域 */
.login-right[data-v-10e61731] {
  background-color: var(--theme-color);
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.login-right.has-background[data-v-10e61731] {
  background-color: transparent;
}

/* LOGO样式 */
.portal-logo[data-v-10e61731] {
  margin-bottom: 20px;
}
.portal-logo img[data-v-10e61731] {
  max-width: 150px;
  max-height: 80px;
  -o-object-fit: contain;
     object-fit: contain;
}

/* 标题样式 */
.portal-title[data-v-10e61731] {
  color: white;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-align: center;
  margin: 0;
}

/* 主题按钮样式 */
.themed-button[data-v-10e61731] {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
}
.themed-button[data-v-10e61731]:hover {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
  opacity: 0.8;
}

/* 主题链接样式 */
.themed-link-span[data-v-10e61731] {
  color: var(--theme-color);
  cursor: pointer;
}
.themed-link-span[data-v-10e61731]:hover {
  opacity: 0.8;
}

/* 验证码按钮 */
.verification-button[data-v-10e61731] {
  background-color: var(--theme-color);
  border: 1px solid var(--theme-color);
  color: white;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
}
.verification-button[data-v-10e61731]:hover:not(:disabled) {
  opacity: 0.8;
}
.verification-button[data-v-10e61731]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Vue 过渡动画的类名 */
.slide-fade-enter-active[data-v-10e61731] {
  animation: slideIn-10e61731 0.5s ease forwards;
}
.slide-fade-leave-active[data-v-10e61731] {
  animation: slideOut-10e61731 0.5s ease forwards;
}
@keyframes slideIn-10e61731 {
from {
    transform: translateX(100%);
    opacity: 0;
}
to {
    transform: translateX(0);
    opacity: 1;
}
}
@keyframes slideOut-10e61731 {
from {
    transform: translateX(0);
    opacity: 1;
}
to {
    transform: translateX(-100%);
    opacity: 0;
}
}

/* 通用样式 */
.or-text[data-v-10e61731] {
  text-align: center;
  margin: 20px 0;
}
.login-btn[data-v-10e61731] {
  margin-top: 20px;
  width: 100%;
}
.signup-link[data-v-10e61731] {
  text-align: center;
  margin-top: 15px;
}
.verification-container[data-v-10e61731] {
  display: flex;
  margin-top: 10px;
}
.input-error[data-v-10e61731] {
  border-color: red !important;
}
.error-message[data-v-10e61731] {
  color: red;
  font-size: 12px;
  margin-bottom: 10px;
  display: block;
}
@media screen and (max-width: 768px) {
.login-container[data-v-10e61731] {
    flex-direction: column;
}
.login-right[data-v-10e61731] {
    flex: 1;
    width: 100%;
    height: 100vh;
    font-size: 2rem;
    display: flex;
    align-items: center;
    align-items: flex-start;
}
.login-left[data-v-10e61731] {
    flex: 1;
    background: none;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 95%;
}
.form-container[data-v-10e61731] {
    background: white;
    padding: 20px;
    width: 90%;
    max-width: 400px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}
}


/* 使用CSS变量应用主题色 */
.login-container[data-v-524e7639] {
  --theme-color: #007bff;
  --background-image: none;
}

/* 右侧背景区域 */
.login-right[data-v-524e7639] {
  background-color: var(--theme-color);
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.login-right.has-background[data-v-524e7639] {
  background-color: transparent;
}

/* LOGO样式 */
.portal-logo[data-v-524e7639] {
  margin-bottom: 20px;
}
.portal-logo img[data-v-524e7639] {
  max-width: 150px;
  max-height: 80px;
  -o-object-fit: contain;
     object-fit: contain;
}

/* 标题样式 */
.portal-title[data-v-524e7639] {
  color: white;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-align: center;
  margin: 0;
}

/* 主题按钮样式 */
.themed-button[data-v-524e7639] {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
}
.themed-button[data-v-524e7639]:hover {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
  opacity: 0.8;
}

/* 主题链接样式 */
.themed-link-span[data-v-524e7639] {
  color: var(--theme-color);
  cursor: pointer;
}
.themed-link-span[data-v-524e7639]:hover {
  opacity: 0.8;
}

/* 通用样式 */
.or-text[data-v-524e7639] {
  text-align: center;
  margin: 20px 0;
}
.login-btn[data-v-524e7639] {
  width: 100%;
  margin-top: 20px;
}
.signup-link[data-v-524e7639] {
  text-align: center;
  margin-top: 15px;
}


/* 使用CSS变量应用主题色 */
.login-container[data-v-565b9011] {
  --theme-color: #007bff;
  --background-image: none;
}

/* 左侧LOGO样式 - 左上角显示 */

/* 右侧背景区域 */
.login-right[data-v-565b9011] {
  background-color: var(--theme-color);
  background-image: var(--background-image);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.login-right.has-background[data-v-565b9011] {
  background-color: transparent;
}

/* LOGO样式 */
.portal-logo[data-v-565b9011] {
  margin-bottom: 20px;
}
.portal-logo img[data-v-565b9011] {
  max-width: 150px;
  max-height: 80px;
  -o-object-fit: contain;
     object-fit: contain;
}

/* 标题样式 */
.portal-title[data-v-565b9011] {
  color: white;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-align: center;
  margin: 0;
}

/* 主题按钮样式 */
.themed-button[data-v-565b9011] {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
}
.themed-button[data-v-565b9011]:hover {
  background-color: var(--theme-color) !important;
  border-color: var(--theme-color) !important;
  opacity: 0.8;
}

/* 主题链接样式 */
.themed-link-span[data-v-565b9011] {
  color: var(--theme-color);
  cursor: pointer;
}
.themed-link-span[data-v-565b9011]:hover {
  opacity: 0.8;
}

/* 通用样式 */
.or-text[data-v-565b9011] {
  text-align: center;
  margin: 20px 0;
}
.login-btn[data-v-565b9011] {
  width: 100%;
  margin-top: 20px;
}
.signup-link[data-v-565b9011] {
  text-align: center;
  margin-top: 15px;
}
.brim[data-v-565b9011] {
  margin-bottom: 10px;
}


.set-password-container[data-v-a3531328] {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background-color: #f5f7fa;
}
.password-card[data-v-a3531328] {
  width: 400px;
  max-width: 90%;
}
.card-header[data-v-a3531328] {
  text-align: center;
}
.card-header h2[data-v-a3531328] {
  margin-bottom: 10px;
}
.card-header p[data-v-a3531328] {
  color: #909399;
  font-size: 14px;
}
.strength-meter[data-v-a3531328] {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.strength-meter .bars[data-v-a3531328] {
  display: flex;
  flex: 1;
  gap: 4px;
}
.strength-meter .bars span[data-v-a3531328] {
  height: 6px;
  flex: 1;
  background: #ebeef5;
  border-radius: 3px;
}
.strength-meter .label[data-v-a3531328] {
  min-width: 64px;
  text-align: right;
  font-size: 12px;
  color: #606266;
}
.strength-meter.level-weak .bars span.active[data-v-a3531328] {
  background: #f56c6c;
}
.strength-meter.level-medium .bars span.active[data-v-a3531328] {
  background: #e6a23c;
}
.strength-meter.level-strong .bars span.active[data-v-a3531328] {
  background: #67c23a;
}


.change-password-page[data-v-69f53efc] {
  max-width: 520px;
  margin: 0 auto;
}
.password-card[data-v-69f53efc] {
  width: 100%;
}
.card-header[data-v-69f53efc] {
  text-align: center;
}
.strength-meter[data-v-69f53efc] {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.strength-meter .bars[data-v-69f53efc] {
  display: flex;
  flex: 1;
  gap: 4px;
}
.strength-meter .bars span[data-v-69f53efc] {
  height: 6px;
  flex: 1;
  background: #ebeef5;
  border-radius: 3px;
}
.strength-meter .label[data-v-69f53efc] {
  min-width: 64px;
  text-align: right;
  font-size: 12px;
  color: #606266;
}
.strength-meter.level-weak .bars span.active[data-v-69f53efc] {
  background: #f56c6c;
}
.strength-meter.level-medium .bars span.active[data-v-69f53efc] {
  background: #e6a23c;
}
.strength-meter.level-strong .bars span.active[data-v-69f53efc] {
  background: #67c23a;
}


/* General Styles */
.content-card[data-v-0cc39b68] {
  padding: 20px;
  border-radius: 8px;
  background-color: white;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* 使用公共样式类，移除重复的 content-card 和 section-header 样式 */

/* Section Styles */
.section[data-v-0cc39b68] {
  margin-bottom: 20px;
}
.section-body p[data-v-0cc39b68] {
  margin: 10px 0;
  font-size: 14px;
  color: #333;
}
.section-footer[data-v-0cc39b68] {
  text-align: right;
  font-size: 14px;
}

/* Links */
.link[data-v-0cc39b68] {
  color: #007bff;
  text-decoration: none;
}
.link[data-v-0cc39b68]:hover {
  text-decoration: underline;
}
.edit-link[data-v-0cc39b68] {
  font-size: 14px;
  color: #007bff;
  cursor: pointer;
}
.edit-link[data-v-0cc39b68]:hover {
  text-decoration: underline;
}

/* Drawer Styles */
.profile-update-page[data-v-0cc39b68] {
  padding: 20px;
  background-color: #f6f6f6;
  font-family: Arial, sans-serif;
}

/* Header */
.header[data-v-0cc39b68] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
.header h2[data-v-0cc39b68] {
  font-size: 20px;
  font-weight: bold;
  margin: 0;
  color: #333;
}

/* Content Layout */
.content[data-v-0cc39b68] {
  display: flex;
  gap: 20px;
}

/* Left Panel */
.left-panel[data-v-0cc39b68] {
  flex: 1;
  max-width: 200px;
}
.left-panel h3[data-v-0cc39b68] {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 10px;
  color: #333;
}
.left-panel p[data-v-0cc39b68] {
  font-size: 14px;
  color: #666;
}

/* Right Panel - 使用公共 form-card 样式类 */
.form-card[data-v-0cc39b68] {
  flex: 3;
}

/* Avatar */
.avatar[data-v-0cc39b68] {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* 使用公共 avatar-circle 样式类 */


.profile-update-page[data-v-7297cd8f] {
  padding: 20px;
  background-color: #f6f6f6;
  font-family: Arial, sans-serif;
}
.header[data-v-7297cd8f] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 10px;
}
.header h2[data-v-7297cd8f] {
  font-size: 20px;
  font-weight: bold;
  margin: 0;
  color: #333;
}
.actions[data-v-7297cd8f] {
  display: flex;
  gap: 10px;
}
.content[data-v-7297cd8f] {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  width: 100%;
}
.form-card[data-v-7297cd8f] {
  padding: 20px;
  border-radius: 8px;
  background-color: #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  width: 100%;
}

/* 头像上传按钮样式 */
.avatar-uploader[data-v-7297cd8f] {
  display: inline-block;
}
.avatar-tip-box[data-v-7297cd8f] {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  max-width: 560px;
  margin-top: 10px;
  padding: 8px 12px;
  border: 1px solid #d9ecff;
  border-radius: 6px;
  background: #f4faff;
  color: #5f6c7b;
  font-size: 12px;
  line-height: 1.5;
}
.avatar-tip-box i[data-v-7297cd8f] {
  margin-top: 2px;
  color: #409eff;
}

/* 如果还没上传头像，显示一个带 + 号的占位符 */
.avatar-placeholder[data-v-7297cd8f] {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: #f5f7fa;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: 2px dashed #ccc;
}
.avatar-icon[data-v-7297cd8f] {
  font-size: 24px;
  color: #909399;
}

/* 自定义头像容器 */
.avatar-wrapper[data-v-7297cd8f] {
  position: relative;
  display: inline-block;
}

/* 头像样式 */
.avatar-img[data-v-7297cd8f] {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  cursor: pointer;
  border: 2px solid #ddd;
  transition: 0.3s;
}
.avatar-img[data-v-7297cd8f]:hover {
  border-color: #409eff;
}

/* 删除按钮：X */
.avatar-delete[data-v-7297cd8f] {
  position: absolute;
  top: -5px;
  right: -5px;
  width: 20px;
  height: 20px;
  font-size: 14px;
  line-height: 20px;
  text-align: center;
  color: #fff;
  background-color: #f56c6c;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* 预览图片 */
.preview-img[data-v-7297cd8f] {
  width: 100%;
  display: block;
  border-radius: 8px;
}


/* 使用公共样式类，移除重复的 content-card, section-header 样式 */
.el-table th[data-v-e27f5722] {
  font-weight: bold;
  color: #666;
  text-align: left;
}
.el-table td[data-v-e27f5722] {
  color: #333;
}

/* Status Colors for Mobile View */
.status-active[data-v-e27f5722] {
  color: #67c23a;
  font-weight: 500;
}
.status-pending[data-v-e27f5722] {
  color: #e6a23c;
  font-weight: 500;
}
.status-canceled[data-v-e27f5722] {
  color: #f56c6c;
  font-weight: 500;
}
.billing-paid[data-v-e27f5722] {
  color: #67c23a;
  font-weight: 500;
}
.billing-unpaid[data-v-e27f5722] {
  color: #f56c6c;
  font-weight: 500;
}
.billing-refunded[data-v-e27f5722] {
  color: #909399;
  font-weight: 500;
}


.course-container[data-v-f1a1da2e] {
  padding: 20px;
  background-color: #f5f5f5;
  /* min-height: 100vh; */
}
.title[data-v-f1a1da2e] {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
}
.course-list[data-v-f1a1da2e] {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.course-card[data-v-f1a1da2e] {
  background: white;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  padding: 16px;
  width: 240px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}
.course-card[data-v-f1a1da2e]:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  border-color: #409eff;
}
.course-card.selected[data-v-f1a1da2e] {
  border-color: #409eff;
  background-color: #ecf5ff;
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(64, 158, 255, 0.2);
}
.course-image[data-v-f1a1da2e] {
  width: 100%;
  height: 260px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 6px;
  cursor: pointer;
}
.progress-bar[data-v-f1a1da2e] {
  margin: 12px 0;
}
.course-title[data-v-f1a1da2e] {
  font-size: 16px;
  font-weight: bold;
  margin-top: 6px;
}
.course-progress[data-v-f1a1da2e] {
  font-size: 14px;
  color: #666;
}
.bold-text[data-v-f1a1da2e] {
  font-weight: bold;
}
.course-image-container[data-v-f1a1da2e] {
  width: 100%;
  text-align: center;
  margin-bottom: 8px;
}
@media (max-width: 1024px) {
.course-container[data-v-f1a1da2e] {
    padding: 15px;
}
.title[data-v-f1a1da2e] {
    font-size: 22px;
    margin-bottom: 15px;
}
.course-list[data-v-f1a1da2e] {
    justify-content: center;
    gap: 12px;
}
.course-card[data-v-f1a1da2e] {
    width: 100%;
    max-width: 320px;
    padding: 12px;
}
.course-image[data-v-f1a1da2e] {
    height: 200px;
}
.course-card[data-v-f1a1da2e]:hover {
    transform: translateY(-2px);
}
.course-card.selected[data-v-f1a1da2e] {
    transform: translateY(-1px);
}
}
@media (max-width: 480px) {
.course-container[data-v-f1a1da2e] {
    padding: 10px;
}
.title[data-v-f1a1da2e] {
    font-size: 20px;
    margin-bottom: 12px;
}
.course-list[data-v-f1a1da2e] {
    gap: 10px;
}
.course-card[data-v-f1a1da2e] {
    max-width: 280px;
    padding: 10px;
}
.course-image[data-v-f1a1da2e] {
    height: 180px;
}
.course-title[data-v-f1a1da2e] {
    font-size: 14px;
}
.course-progress[data-v-f1a1da2e] {
    font-size: 12px;
}
}


.section-container[data-v-568c2276] {
  padding-left: 0;
}
.custom-collapse-item[data-v-568c2276] {
  border: none;
  border-radius: 6px;
  margin-bottom: 8px;
  background: #fff;
  /* box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05); */
}
.module-header[data-v-568c2276] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 90%;
  padding: 4px 0;
}
.module-title-wrapper[data-v-568c2276] {
  flex: 1;
  min-width: 0;
  margin-right: 12px;
}
.module-title[data-v-568c2276] {
  font-size: 14px;
  font-weight: 500;
  color: #303133;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
  line-height: 1.4;
}
.module-status-wrapper[data-v-568c2276] {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  gap: 6px;
}
.module-status[data-v-568c2276] {
  font-size: 12px;
  color: #409eff;
  font-weight: 500;
}
.completed-section-icon[data-v-568c2276] {
  color: #67c23a;
  font-size: 14px;
}

/* 课程列表 */
.lesson-list[data-v-568c2276] {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0 8px;
}

/* 课程项 */
.lesson-item[data-v-568c2276] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  border-radius: 6px;
  background: #fafafa;
  border: 1px solid #f0f0f0;
  cursor: pointer;
  transition: all 0.2s ease;
  min-height: 44px;
  margin-top: 5px;
}
.lesson-item[data-v-568c2276]:hover:not(.disabled) {
  background-color: #ecf5ff;
  border-color: #b3d8ff;
  transform: translateY(-1px);
}
.lesson-item.completed[data-v-568c2276] {
  background-color: #f0f9ff;
  border-color: #67c23a;
}
.lesson-item.active[data-v-568c2276] {
  background-color: #ecf5ff;
  border-color: #b3d8ff;
}
.lesson-item.disabled[data-v-568c2276] {
  background-color: #f5f7fa;
  color: #c0c4cc;
  cursor: not-allowed;
  opacity: 0.6;
}
.lesson-content[data-v-568c2276] {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
  gap: 8px;
}
.lesson-icon[data-v-568c2276] {
  color: #409eff;
  font-size: 14px;
  flex-shrink: 0;
}
.lesson-text[data-v-568c2276] {
  font-size: 13px;
  color: #606266;
  font-weight: 400;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  line-height: 1.4;
}
.lesson-item.completed .lesson-text[data-v-568c2276] {
  color: #67c23a;
}
.lesson-item.disabled .lesson-icon[data-v-568c2276],
.lesson-item.disabled .lesson-text[data-v-568c2276] {
  color: #c0c4cc;
}
.completed-icon[data-v-568c2276] {
  color: #67c23a;
  font-size: 16px;
  flex-shrink: 0;
}

/* 嵌套章节样式 */
.section-container .section-container[data-v-568c2276] {
  padding-left: 10px;
  /* margin-top: 8px; */
}
.section-container .section-container .custom-collapse-item[data-v-568c2276] {
  background: #f8f9fa;
  border-top: 1px solid #e9ecef;
}

/* 响应式设计 */
@media (max-width: 768px) {
.lesson-item[data-v-568c2276] {
    padding: 0 12px;
}
.lesson-text[data-v-568c2276] {
    font-size: 12px;
}
.module-title[data-v-568c2276] {
    font-size: 13px;
}
.module-status[data-v-568c2276] {
    font-size: 11px;
}
}


.no-lesson-placeholder[data-v-e60f0528] {
  width: 100%;
  height: 65vh;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f5f7fa;
  border-radius: 4px;
  color: #909399;
}
.no-permission-container[data-v-e60f0528] {
  width: 100%;
  height: 65vh;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #f5f7fa;
  border-radius: 4px;
}
.lock-icon[data-v-e60f0528] {
  margin-bottom: 16px;
}
.no-permission-text[data-v-e60f0528] {
  color: #909399;
  font-size: 16px;
  margin: 0;
}


.course-title[data-v-e3828bee] {
  font-size: 16px;
  font-weight: 600;
  color: #303133;
  margin: 0 0 12px 0;
  line-height: 1.4;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  cursor: default;
}
.course-container[data-v-e3828bee] {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 20px;
  background-color: #f5f7fa;
  min-height: 100vh;
}

/* 悬浮开关按钮，默认桌面端隐藏 */
.floating-toggle[data-v-e3828bee] {
  display: none;
}

/* 左侧课程进度 */
.course-sidebar[data-v-e3828bee] {
  width: 320px;
  min-width: 320px;
}
.course-card[data-v-e3828bee] {
  padding: 20px;
  border-radius: 8px;
  /* box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); */
}
.course-header[data-v-e3828bee] {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}
.progress-circle[data-v-e3828bee] {
  flex-shrink: 0;
}
.course-lessons[data-v-e3828bee] {
  font-size: 14px;
  color: #606266;
  margin: 0 0 20px 0;
  text-align: center;
}
.module-collapse[data-v-e3828bee] {
  border: none;
}

/* 右侧课程内容 */
.course-content[data-v-e3828bee] {
  flex: 1;
  /* min-width: 400px; */
}
.lesson-card[data-v-e3828bee] {
  padding: 24px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.lesson-title-box[data-v-e3828bee] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  gap: 16px;
}
.lesson-title[data-v-e3828bee] {
  font-size: 20px;
  font-weight: 600;
  color: #303133;
  margin: 0;
  line-height: 1.4;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.no-permission-container[data-v-e3828bee] {
  width: 100%;
  height: 65vh;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #f5f7fa;
  border-radius: 4px;
}
.lock-icon[data-v-e3828bee] {
  margin-bottom: 16px;
}
.no-permission-text[data-v-e3828bee] {
  color: #909399;
  font-size: 16px;
  margin: 0;
}

/* 响应式设计 */
@media (max-width: 1024px) {
.lesson-card[data-v-e3828bee] {
    padding: 0;
}
.lesson-title-box[data-v-e3828bee] {
    padding: 8px;
    flex-direction: row;
}
.el-card[data-v-e3828bee] {
    padding: 0;
}
.main-content[data-v-e3828bee] {
    padding: 0 !important;
}
.course-container[data-v-e3828bee] {
    flex-direction: column;
    padding: 10px;
    gap: 15px;
}
.course-sidebar[data-v-e3828bee] {
    display: none;
}
.course-content[data-v-e3828bee] {
    width: 100%;
}

  /* 悬浮菜单容器 */
.floating-menu-container[data-v-e3828bee] {
    position: fixed;
    left: 2px;
    top: 75px;
    width: 60px;
    height: 60px;
    z-index: 9;
}

  /* 悬浮按钮基础样式 */
.floating-toggle[data-v-e3828bee] {
    display: inline-flex;
    position: absolute;
    align-items: center;
    justify-content: center;
    left: 0;
    /* 初始状态部分隐藏在屏幕左边缘（与尺寸无关） */
    top: 0;
    width: 60px;
    height: 60px;
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    transform: translateX(-70%);
}

  /* 滑出状态 */
.floating-toggle.slide-out[data-v-e3828bee] {
    transform: translateX(0);
}

  /* 抽屉主体内边距优化 */
.mobile-course-drawer .el-drawer__body[data-v-e3828bee] {
    padding: 12px 12px 20px;
    background: #fff;
}
.mobile-course-drawer .drawer-inner[data-v-e3828bee] {
    padding: 30px 20px;
}
.mobile-course-drawer .el-drawer__title[data-v-e3828bee] {
    margin-bottom: 0 !important;
}
.el-drawer__header[data-v-e3828bee] {
    margin-bottom: 0 !important;
}

  /* Ensure no margin on title as well */
#el-drawer__title[data-v-e3828bee] {
    margin-bottom: 0 !important;
}
}
@media (max-width: 480px) {
.course-container[data-v-e3828bee] {
    padding: 8px;
    gap: 10px;
}
.lesson-title-box[data-v-e3828bee] {
    padding: 6px;
    /* flex-direction: column; */
    align-items: flex-start;
    gap: 8px;
}
.lesson-title[data-v-e3828bee] {
    font-size: 18px;
}
.floating-menu-container[data-v-e3828bee] {
    top: 65px;
}
.floating-toggle[data-v-e3828bee] {
    width: 50px;
    height: 50px;
}
.mobile-course-drawer .drawer-inner[data-v-e3828bee] {
    padding: 20px 15px;
}
}


/* 使用公共样式类，移除重复的 content-card, section-header, loading-container, pagination-container 样式 */

/* Mobile card list */
.orders-list-mobile[data-v-620cd42f] {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.order-item-card[data-v-620cd42f] {
  background: #fff;
  border: 1px solid #ebeef5;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}
.order-row[data-v-620cd42f] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  font-size: 14px;
}
.order-row + .order-row[data-v-620cd42f] {
  border-top: 1px dashed #f0f0f0;
}
.label[data-v-620cd42f] {
  color: #909399;
}
.no-wrap[data-v-620cd42f] {
  white-space: nowrap;
  min-width: 80px;
}
.value[data-v-620cd42f] {
  color: #303133;
  word-break: break-all;
}


.content-card[data-v-755ca78c] {
  background: #fff;
  border-radius: 8px;
  padding: 20px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
}
.section-header h4[data-v-755ca78c] {
  margin: 0;
  font-size: 18px;
  color: #303133;
}


.course-container[data-v-13418f4e] {
  padding: 20px;
  background-color: #f5f5f5;
  /* min-height: 100vh; */
}
.title[data-v-13418f4e] {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
}
.course-list[data-v-13418f4e] {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.course-card[data-v-13418f4e] {
  background: white;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  padding: 16px;
  width: 240px;
  text-align: center;
}
.course-image[data-v-13418f4e] {
  width: 100%;
  height: 230px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 6px;
  cursor: pointer;
}
.progress-bar[data-v-13418f4e] {
  margin: 12px 0;
}
.course-title[data-v-13418f4e] {
  font-size: 16px;
  font-weight: bold;
  margin-top: 6px;
}
.course-progress[data-v-13418f4e] {
  font-size: 14px;
  color: #666;
}
.bold-text[data-v-13418f4e] {
  font-weight: bold;
}


/* Custom form styles that extend the base modal styles */


/* 使用公共样式类，移除重复的 content-card, section-header 样式 */

/* Header */
.add-address[data-v-3d4ab1a4] {
  font-size: 14px;
  color: #409eff;
  text-decoration: none;
}
.add-address[data-v-3d4ab1a4]:hover {
  text-decoration: underline;
}

/* Table */
.el-table th[data-v-3d4ab1a4] {
  font-weight: bold;
  color: #666;
  text-align: left;
}
.el-table td[data-v-3d4ab1a4] {
  color: #333;
}

/* Primary Address Star */
.primary-star[data-v-3d4ab1a4] {
  color: #f7ba2a;
  margin-left: 5px;
}

/* Action Icons */
.action-icon[data-v-3d4ab1a4] {
  font-size: 18px;
  margin-right: 10px;
  color: #606266;
  cursor: pointer;
}
.action-icon[data-v-3d4ab1a4]:hover {
  color: #409eff;
}
.delete-icon[data-v-3d4ab1a4] {
  color: #f56c6c;
}
.delete-icon[data-v-3d4ab1a4]:hover {
  color: #ff0000;
}


/* 使用公共样式类，移除重复的 content-card, section-header, loading-container, pagination-container 样式 */

/* Filters Section - Responsive Layout */
.filters-section[data-v-24e3acb8] {
  margin-bottom: 20px;
}
.filter-form .el-form-item[data-v-24e3acb8] {
  margin-bottom: 15px;
  width: 100%;
}
.filter-form .el-form-item__label[data-v-24e3acb8] {
  font-weight: 500;
  color: #606266;
  padding-bottom: 5px;
}

/* Button items alignment for desktop */
.button-item[data-v-24e3acb8] {
  display: flex;
  align-items: flex-end;
}

/* Desktop: align buttons to bottom */
@media (min-width: 1200px) {
.filter-form .el-row[data-v-24e3acb8] {
    align-items: flex-end;
}
.button-item .el-form-item__content[data-v-24e3acb8] {
    margin-top: 22px !important;
}
}

/* 移动端响应式 */
@media (max-width: 767px) {
.content-card[data-v-24e3acb8] {
    padding: 15px;
}
}


.modal-test-page[data-v-77e89dd0] {
  padding: 20px;
  max-width: 1200px;
  margin: 0 auto;
}
.test-header[data-v-77e89dd0] {
  text-align: center;
  margin-bottom: 40px;
  padding: 20px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  border-radius: 12px;
}
.test-header h1[data-v-77e89dd0] {
  margin: 0 0 10px 0;
  font-size: 28px;
}
.test-header p[data-v-77e89dd0] {
  margin: 0;
  opacity: 0.9;
}
.test-sections[data-v-77e89dd0] {
  display: grid;
  gap: 30px;
}
.test-section[data-v-77e89dd0] {
  padding: 25px;
  border: 1px solid #e1e8ed;
  border-radius: 12px;
  background: white;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.test-section h2[data-v-77e89dd0] {
  margin: 0 0 20px 0;
  color: #333;
  font-size: 20px;
  border-bottom: 2px solid #667eea;
  padding-bottom: 10px;
}
.button-group[data-v-77e89dd0] {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
}
.button-group .el-button[data-v-77e89dd0] {
  min-width: 120px;
}
.modal-content[data-v-77e89dd0] {
  padding: 10px 0;
}
.modal-content ul[data-v-77e89dd0] {
  margin: 15px 0;
  padding-left: 20px;
}
.modal-content li[data-v-77e89dd0] {
  margin: 8px 0;
  color: #666;
}
.test-results[data-v-77e89dd0] {
  margin-top: 40px;
  padding: 20px;
  background: #f8f9fa;
  border-radius: 12px;
  border: 1px solid #e9ecef;
}
.test-results h3[data-v-77e89dd0] {
  margin: 0 0 15px 0;
  color: #333;
}
.test-results ul[data-v-77e89dd0] {
  list-style: none;
  padding: 0;
  margin: 0;
}
.test-results li[data-v-77e89dd0] {
  padding: 8px 12px;
  margin: 5px 0;
  border-radius: 6px;
  font-family: "Courier New", monospace;
  font-size: 14px;
}
.test-results li.success[data-v-77e89dd0] {
  background: #d4edda;
  color: #155724;
  border-left: 4px solid #28a745;
}
.test-results li.warning[data-v-77e89dd0] {
  background: #fff3cd;
  color: #856404;
  border-left: 4px solid #ffc107;
}
.test-results li.danger[data-v-77e89dd0] {
  background: #f8d7da;
  color: #721c24;
  border-left: 4px solid #dc3545;
}
.test-results li.info[data-v-77e89dd0] {
  background: #d1ecf1;
  color: #0c5460;
  border-left: 4px solid #17a2b8;
}

/* 响应式设计 */
@media (max-width: 768px) {
.modal-test-page[data-v-77e89dd0] {
    padding: 15px;
}
.test-header[data-v-77e89dd0] {
    padding: 15px;
}
.test-header h1[data-v-77e89dd0] {
    font-size: 24px;
}
.test-section[data-v-77e89dd0] {
    padding: 20px;
}
.button-group[data-v-77e89dd0] {
    flex-direction: column;
}
.button-group .el-button[data-v-77e89dd0] {
    width: 100%;
}
}

