/*
 * Element Plus 主题覆盖
 * 通过覆盖 Element Plus CSS 变量实现全局定制
 * 不使用 !important，通过变量继承
 */

/* ========================================
 * Element Plus 颜色变量覆盖
 * ======================================== */
:root {
  /* 主色 */
  --el-color-primary: var(--color-primary);
  --el-color-primary-light-3: var(--color-primary);
  --el-color-primary-light-5: var(--color-primary);
  --el-color-primary-light-7: var(--color-primary-light);
  --el-color-primary-light-8: var(--color-primary-light);
  --el-color-primary-light-9: var(--color-primary-light);
  --el-color-primary-dark-2: var(--color-primary-hover);

  /* 状态色 */
  --el-color-success: var(--color-success);
  --el-color-warning: var(--color-warning);
  --el-color-danger: var(--color-danger);
  --el-color-info: var(--color-text-muted);

  /* 背景 */
  --el-bg-color: var(--color-surface);
  --el-bg-color-page: var(--color-background);
  --el-bg-color-overlay: var(--modal-overlay);

  /* 文字 */
  --el-text-color-primary: var(--color-text);
  --el-text-color-regular: var(--color-text-secondary);
  --el-text-color-secondary: var(--color-text-muted);
  --el-text-color-placeholder: var(--color-text-disabled);
  --el-text-color-disabled: var(--color-text-disabled);

  /* 边框 */
  --el-border-color: var(--color-border);
  --el-border-color-light: var(--color-border);
  --el-border-color-lighter: var(--color-border);
  --el-border-color-dark: var(--color-border-hover);
  --el-border-color-extra-light: var(--color-border);

  /* 填充 */
  --el-fill-color: var(--color-primary-light);
  --el-fill-color-light: var(--color-primary-light);
  --el-fill-color-lighter: var(--color-primary-light);
  --el-fill-color-blank: transparent;

  /* 圆角 */
  --el-border-radius-base: var(--radius-md);
  --el-border-radius-small: var(--radius-sm);
  --el-border-radius-round: var(--radius-full);

  /* 阴影 */
  --el-box-shadow: var(--shadow-md);
  --el-box-shadow-light: var(--shadow-sm);
  --el-box-shadow-lighter: var(--shadow-sm);
  --el-box-shadow-dark: var(--shadow-lg);

  /* 遮罩 */
  --el-mask-color: var(--modal-overlay);
  --el-mask-color-extra-light: var(--modal-overlay);
}

/* ========================================
 * Element Plus 组件样式覆盖
 * ======================================== */

/* el-menu 导航菜单 */
.el-menu {
  background: transparent !important;
  border: none !important;
}

.el-menu-item {
  color: var(--color-text-muted) !important;
  transition: all var(--transition-fast) !important;
  border-radius: var(--radius-md) !important;
  margin: 0 2px !important;
}

.el-menu-item:hover {
  background: var(--color-primary-light) !important;
  color: var(--color-text) !important;
}

.el-menu-item.is-active {
  color: var(--color-primary) !important;
  background: var(--color-primary-light) !important;
}

.el-menu--horizontal > .el-menu-item {
  border-bottom: none !important;
  height: 60px !important;
  line-height: 60px !important;
}

.el-menu--horizontal > .el-menu-item.is-active {
  border-bottom: 2px solid var(--color-primary) !important;
}

/* el-card 卡片 */
.el-card {
  background: var(--glass-card-bg) !important;
  backdrop-filter: var(--glass-card-blur) !important;
  -webkit-backdrop-filter: var(--glass-card-blur) !important;
  border: var(--glass-card-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--glass-card-shadow) !important;
  transition: all var(--transition-base) !important;
}

.el-card:hover {
  background: var(--glass-bg-hover) !important;
  border: var(--glass-border-hover) !important;
  box-shadow: var(--shadow-lg), var(--shadow-glow) !important;
  transform: translateY(-2px) !important;
}

/* card header 左侧蓝色竖线装饰 - 与 demo 风格一致 */
.el-card__header {
  display: flex !important;
  align-items: center !important;
  gap: var(--spacing-sm) !important;
}

.el-card__header::before {
  content: '' !important;
  width: 4px !important;
  height: 20px !important;
  background: var(--color-primary) !important;
  border-radius: 2px !important;
  flex-shrink: 0 !important;
}

/* el-button 按钮 */
.el-button {
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-fast) !important;
  font-weight: var(--font-weight-medium) !important;
}

.el-button--primary {
  background: var(--gradient-primary) !important;
  border: none !important;
  color: white !important;
  box-shadow: 0 4px 14px var(--color-primary-glow) !important;
}

.el-button--primary:hover {
  background: var(--color-primary-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px var(--color-primary-glow) !important;
}

.el-button--primary:active {
  transform: translateY(0) !important;
}

.el-button--success {
  background: var(--gradient-cta) !important;
  border: none !important;
  color: white !important;
  box-shadow: var(--shadow-cta) !important;
}

.el-button--success:hover {
  background: var(--color-cta-hover) !important;
  transform: translateY(-1px) !important;
}

.el-button--danger {
  box-shadow: var(--shadow-danger) !important;
}

.el-button--danger:hover {
  transform: translateY(-1px) !important;
}

.el-button--default {
  background: transparent !important;
  color: var(--color-text-secondary) !important;
  border: 1px solid var(--color-border) !important;
}

.el-button--default:hover {
  background: var(--color-primary-light) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-primary) !important;
}

/* el-input 输入框 */
.el-input__wrapper {
  background: var(--input-bg) !important;
  border: 1px solid var(--input-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  transition: all var(--transition-fast) !important;
  padding: 4px 12px !important;
}

.el-input__wrapper:hover {
  border-color: var(--color-border-hover) !important;
}

.el-input__wrapper.is-focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
  background: var(--input-focus-bg) !important;
}

.el-input__inner {
  color: var(--color-text) !important;
}

.el-input__inner::-moz-placeholder {
  color: var(--color-text-disabled) !important;
}

.el-input__inner::placeholder {
  color: var(--color-text-disabled) !important;
}

.el-textarea__inner {
  background: var(--input-bg) !important;
  border: 1px solid var(--input-border) !important;
  border-radius: var(--radius-md) !important;
  color: var(--color-text) !important;
  transition: all var(--transition-fast) !important;
}

.el-textarea__inner:focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

/* el-select 选择器 */
.el-select__wrapper {
  background: var(--input-bg) !important;
  border: 1px solid var(--input-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  transition: all var(--transition-fast) !important;
  padding: 4px 12px !important;
  min-height: 32px !important;
}

.el-select__wrapper:hover {
  border-color: var(--color-border-hover) !important;
}

.el-select__wrapper.is-focused {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

.el-select-dropdown {
  background: var(--modal-bg) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  backdrop-filter: var(--glass-blur) !important;
}

.el-select-dropdown__item {
  color: var(--color-text-secondary) !important;
  transition: all var(--transition-fast) !important;
}

.el-select-dropdown__item:hover,
.el-select-dropdown__item.is-hovering {
  background: var(--color-primary-light) !important;
  color: var(--color-primary) !important;
}

.el-select-dropdown__item.is-selected {
  color: var(--color-primary) !important;
  font-weight: var(--font-weight-bold) !important;
}

/* el-select popper 容器 */
.el-select__popper {
  background: var(--modal-bg) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* popper 箭头 - 去除 Element Plus 默认颜色 */
.el-popper__arrow::before {
  background: var(--modal-bg) !important;
  border: var(--glass-border) !important;
}

/* el-popper 暗色/亮色变体统一覆盖 */
.el-popper.is-dark,
.el-popper.is-light {
  background: var(--modal-bg) !important;
  border: var(--glass-border) !important;
  box-shadow: var(--shadow-lg) !important;
}

.el-popper.is-dark > .el-popper__arrow::before,
.el-popper.is-light > .el-popper__arrow::before {
  background: var(--modal-bg) !important;
  border: var(--glass-border) !important;
}

/* el-dropdown-menu 下拉菜单 */
.el-dropdown__popper.el-popper {
  background: var(--modal-bg) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

.el-dropdown-menu {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: none !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: none !important;
  padding: 4px !important;
}

.el-dropdown-menu__item {
  color: var(--color-text-secondary) !important;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-fast) !important;
  padding: 8px 16px !important;
}

.el-dropdown-menu__item:hover,
.el-dropdown-menu__item:focus {
  background: var(--color-primary-light) !important;
  color: var(--color-primary) !important;
}

.el-dropdown-menu__item.is-disabled {
  color: var(--color-text-disabled) !important;
}

.el-dropdown-menu__item--divided {
  border-top: 1px solid var(--color-border) !important;
  margin-top: 4px !important;
  padding-top: 8px !important;
}

/* el-table 表格 */
.el-table {
  --el-table-border-color: var(--table-border) !important;
  --el-table-header-bg-color: var(--table-header-bg) !important;
  --el-table-header-text-color: var(--color-text) !important;
  --el-table-text-color: var(--color-text) !important;
  --el-table-row-hover-bg-color: var(--table-row-hover) !important;
  background: var(--glass-bg) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  color: var(--color-text) !important;
  overflow: visible !important;
}

.el-table__inner-wrapper {
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
}

.el-table th.el-table__cell {
  background: var(--table-header-bg) !important;
  color: var(--color-text) !important;
  font-weight: var(--font-weight-bold) !important;
  font-size: var(--font-size-sm) !important;
  border-bottom: 1px solid var(--table-border) !important;
}

.el-table td.el-table__cell {
  border-bottom: 1px solid var(--table-border) !important;
  font-size: var(--font-size-sm) !important;
}

.el-table--striped .el-table__body tr.el-table__row--striped td.el-table__cell {
  background: var(--color-primary-light) !important;
}

.el-table__empty-text {
  color: var(--color-text-muted) !important;
}

.el-table__header-wrapper {
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
  overflow: hidden !important;
}

/* el-form 表单 */
.el-form-item__label {
  color: var(--color-text-secondary) !important;
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-sm) !important;
}

.el-form-item__error {
  color: var(--color-danger) !important;
  font-size: var(--font-size-xs) !important;
}

.el-form-item.is-error .el-input__wrapper {
  border-color: var(--color-danger) !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

/* el-tag 标签 */
.el-tag {
  border-radius: var(--radius-full) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: var(--font-weight-medium) !important;
  padding: 2px 10px !important;
  border: none !important;
}

.el-tag--success {
  background: var(--tag-success-bg) !important;
  color: var(--color-success) !important;
}

.el-tag--warning {
  background: var(--tag-warning-bg) !important;
  color: var(--color-warning) !important;
}

.el-tag--danger {
  background: var(--tag-danger-bg) !important;
  color: var(--color-danger) !important;
}

.el-tag--info {
  background: var(--tag-info-bg) !important;
  color: var(--color-text-muted) !important;
}

.el-tag--primary {
  background: var(--tag-info-bg) !important;
  color: var(--color-primary) !important;
}

/* el-dialog 弹窗 - 现代化样式 */
.el-dialog {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 16px !important;
  box-shadow: 0 20px 40px -10px rgba(0, 0, 0, 0.15), 0 8px 16px -6px rgba(0, 0, 0, 0.1) !important;
  overflow: hidden !important;
  backdrop-filter: none !important;
}

.el-dialog__header {
  border-bottom: 1px solid var(--color-border) !important;
  padding: 20px 28px !important;
  margin-right: 0 !important;
  background: var(--color-bg-elevated) !important;
}

.el-dialog__title {
  color: var(--color-text) !important;
  font-weight: 600 !important;
  font-size: 18px !important;
}

.el-dialog__headerbtn {
  background: var(--color-bg-deep) !important;
  border-radius: 8px !important;
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.2s ease !important;
}

.el-dialog__headerbtn:hover {
  background: var(--color-danger) !important;
  transform: scale(1.05) !important;
}

.el-dialog__headerbtn .el-dialog__close {
  color: var(--color-text-muted) !important;
  font-size: 16px !important;
}

.el-dialog__headerbtn:hover .el-dialog__close {
  color: white !important;
}

.el-dialog__body {
  color: var(--color-text) !important;
  padding: 28px !important;
  max-height: 70vh !important;
  overflow-y: auto !important;
}

.el-dialog__footer {
  border-top: 1px solid var(--color-border) !important;
  padding: 16px 28px !important;
  background: var(--color-bg-deep) !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 12px !important;
}

.el-dialog__footer .el-button {
  height: 40px !important;
  padding: 0 24px !important;
  border-radius: 10px !important;
  font-weight: 500 !important;
}

/* el-message 消息提示 - 现代化样式 */
.el-message {
  background: #ffffff !important;
  border: none !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05) !important;
  padding: 16px 20px !important;
  min-width: 320px !important;
  max-width: 420px !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  backdrop-filter: none !important;
}

.el-message .el-message__icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 20px !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
}

.el-message--success .el-message__icon {
  background: #ecfdf5 !important;
  color: #10b981 !important;
}

.el-message--error .el-message__icon {
  background: #fef2f2 !important;
  color: #ef4444 !important;
}

.el-message--warning .el-message__icon {
  background: #fff7ed !important;
  color: #f97316 !important;
}

.el-message--info .el-message__icon {
  background: #eff6ff !important;
  color: #3b82f6 !important;
}

.el-message .el-message__content {
  font-size: 15px !important;
  color: #1f2937 !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.el-message .el-message__closeBtn {
  position: static !important;
  color: #9ca3af !important;
  font-size: 16px !important;
  margin-left: auto !important;
  padding: 0 !important;
}

.el-message .el-message__closeBtn:hover {
  color: #4b5563 !important;
}

/* el-notification 通知 */
.el-notification {
  background: var(--glass-bg) !important;
  backdrop-filter: var(--glass-blur) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* el-pagination 分页 */
.el-pagination {
  --el-pagination-bg-color: transparent !important;
  --el-pagination-text-color: var(--color-text-muted) !important;
  --el-pagination-button-bg-color: transparent !important;
}

.el-pagination button,
.el-pager li {
  background: transparent !important;
  color: var(--color-text-muted) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-fast) !important;
  min-width: 36px !important;
  min-height: 36px !important;
}

.el-pagination button:hover,
.el-pager li:hover {
  background: var(--color-primary-light) !important;
  color: var(--color-primary) !important;
}

.el-pager li.is-active {
  background: var(--color-primary) !important;
  color: white !important;
  border-color: var(--color-primary) !important;
  box-shadow: 0 4px 12px var(--color-primary-glow) !important;
}

/* el-loading 加载 */
.el-loading-mask {
  background: transparent !important;
}

.el-loading-spinner .circular {
  color: var(--color-primary) !important;
}

/* el-overlay 遮罩 */
.el-overlay {
  background-color: var(--modal-overlay) !important;
  backdrop-filter: blur(4px) !important;
}

/* el-message-box 消息弹窗 - 现代化样式 */
.el-message-box {
  background: #ffffff !important;
  border: none !important;
  border-radius: 16px !important;
  box-shadow: 0 20px 40px -10px rgba(0, 0, 0, 0.15), 0 8px 16px -6px rgba(0, 0, 0, 0.1) !important;
  max-width: 420px !important;
  width: 90% !important;
  padding: 32px 28px !important;
  backdrop-filter: none !important;
  overflow: hidden !important;
}

.el-message-box__header {
  border-bottom: none !important;
  padding: 0 !important;
  margin-bottom: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.el-message-box__header .el-message-box__status {
  display: none !important;
}

.el-message-box__title {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #1f2937 !important;
  text-align: center !important;
  line-height: 1.4 !important;
  padding: 0 !important;
  margin: 0 !important;
}

.el-message-box__content {
  font-size: 15px !important;
  color: #6b7280 !important;
  text-align: center !important;
  line-height: 1.6 !important;
  padding: 0 !important;
  margin: 0 0 28px 0 !important;
}

.el-message-box__content p {
  margin: 0 !important;
}

.el-message-box__btns {
  display: flex !important;
  gap: 12px !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
}

.el-message-box__btns .el-button {
  flex: 1 !important;
  height: 44px !important;
  border-radius: 10px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  margin: 0 !important;
  transition: all 0.2s ease !important;
}

.el-message-box__btns .el-button--default {
  background: #f3f4f6 !important;
  border: none !important;
  color: #374151 !important;
}

.el-message-box__btns .el-button--default:hover {
  background: #e5e7eb !important;
  transform: translateY(-1px) !important;
}

.el-message-box__btns .el-button--primary {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
  border: none !important;
  color: #ffffff !important;
  box-shadow: 0 2px 8px 0 rgba(59, 130, 246, 0.35) !important;
}

.el-message-box__btns .el-button--primary:hover {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px 0 rgba(59, 130, 246, 0.4) !important;
}

.el-message-box__headerbtn {
  top: 16px !important;
  right: 16px !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: #f3f4f6 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.el-message-box__headerbtn:hover {
  background: #e5e7eb !important;
}

.el-message-box__headerbtn .el-message-box__close {
  color: #9ca3af !important;
  font-size: 14px !important;
}

.el-message-box__headerbtn:hover .el-message-box__close {
  color: #4b5563 !important;
}

/* el-checkbox 复选框 */
.el-checkbox__input.is-checked .el-checkbox__inner {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.el-checkbox__input.is-checked + .el-checkbox__label {
  color: var(--color-primary) !important;
}

/* el-radio 单选框 */
.el-radio__input.is-checked .el-radio__inner {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.el-radio__input.is-checked + .el-radio__label {
  color: var(--color-primary) !important;
}

/* el-link 链接 */
.el-link {
  color: var(--color-primary) !important;
}

.el-link:hover {
  color: var(--color-primary-hover) !important;
}

/* el-descriptions 描述列表 */
.el-descriptions__label {
  color: var(--color-text) !important;
  font-weight: var(--font-weight-medium) !important;
  background: var(--table-header-bg) !important;
}

.el-descriptions__content {
  color: var(--color-text-secondary) !important;
}

.el-descriptions__cell {
  border-color: var(--table-border) !important;
}

/* el-empty 空状态 */
.el-empty__description p {
  color: var(--color-text-muted) !important;
}

/* el-alert 警告 */
.el-alert {
  border-radius: var(--radius-md) !important;
}

/* el-divider 分割线 */
.el-divider {
  border-color: var(--color-border) !important;
}

/* el-image 图片 */
.el-image__error {
  color: var(--color-text-muted) !important;
  background: var(--color-bg-elevated) !important;
}

/* el-upload 上传 */
.el-upload-dragger {
  background: var(--input-bg) !important;
  border-color: var(--input-border) !important;
  border-radius: var(--radius-lg) !important;
}

.el-upload-dragger:hover {
  border-color: var(--color-primary) !important;
}

/* el-tabs 标签页 */
.el-tabs__item {
  color: var(--color-text-muted) !important;
}

.el-tabs__item:hover {
  color: var(--color-primary) !important;
}

.el-tabs__item.is-active {
  color: var(--color-primary) !important;
  font-weight: var(--font-weight-bold) !important;
}

.el-tabs__active-bar {
  background-color: var(--color-primary) !important;
}

.el-tabs__nav-wrap::after {
  background-color: var(--color-border) !important;
}

/* el-tabs--border-card 卡片式标签页 */
.el-tabs--border-card {
  background: transparent !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: none !important;
}

.el-tabs--border-card > .el-tabs__header {
  background: var(--table-header-bg) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

.el-tabs--border-card > .el-tabs__header .el-tabs__item {
  color: var(--color-text-muted) !important;
  border: none !important;
}

.el-tabs--border-card > .el-tabs__header .el-tabs__item.is-active {
  color: var(--color-primary) !important;
  background: var(--color-bg-elevated) !important;
  border-bottom: 2px solid var(--color-primary) !important;
}

.el-tabs--border-card > .el-tabs__content {
  background: transparent !important;
}

/* el-popover 弹出框 */
.el-popover {
  background: var(--modal-bg) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* el-tooltip 提示 */
.el-tooltip__popper {
  background: var(--color-bg-surface) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-md) !important;
}

/* el-picker-panel 日期选择器面板 */
.el-picker-panel {
  background: var(--modal-bg) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border: var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  color: var(--color-text) !important;
}

.el-picker-panel__body {
  background: transparent !important;
}

.el-date-table th {
  color: var(--color-text-muted) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

.el-date-table td {
  color: var(--color-text) !important;
}

.el-date-table td.available:hover {
  color: var(--color-primary) !important;
}

.el-date-table td.current:not(.disabled) .el-date-table-cell__text {
  background-color: var(--color-primary) !important;
  color: #fff !important;
}

.el-date-table td.today .el-date-table-cell__text {
  color: var(--color-primary) !important;
}

.el-picker-panel__icon-btn {
  color: var(--color-text-muted) !important;
}

.el-picker-panel__icon-btn:hover {
  color: var(--color-primary) !important;
}

.el-month-table td .cell:hover,
.el-year-table td .cell:hover {
  color: var(--color-primary) !important;
}

.el-month-table td.current .cell,
.el-year-table td.current .cell {
  color: var(--color-primary) !important;
}

/* el-input-number 数字输入框 */
.el-input-number__decrease,
.el-input-number__increase {
  background: var(--color-primary-light) !important;
  color: var(--color-text-muted) !important;
  border-color: var(--color-border) !important;
}

.el-input-number__decrease:hover,
.el-input-number__increase:hover {
  color: var(--color-primary) !important;
}

/* el-alert 消息条 */
.el-alert {
  background: var(--color-bg-elevated) !important;
  border-radius: var(--radius-md) !important;
}

.el-alert__title {
  color: var(--color-text) !important;
}

.el-alert__description {
  color: var(--color-text-secondary) !important;
}

/* ========================================
 * 现代化弹窗动画
 * ======================================== */

/* Toast (el-message) 进出场动画 */
.el-message-fade-enter-active {
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

.el-message-fade-leave-active {
  transition: all 0.25s ease-in !important;
}

.el-message-fade-enter-from {
  opacity: 0 !important;
  transform: translate3d(0, -20px, 0) scale(0.9) !important;
}

.el-message-fade-leave-to {
  opacity: 0 !important;
  transform: translate3d(0, -10px, 0) scale(0.95) !important;
}

/* MessageBox (el-message-box) 进出场动画 */
.el-overlay-dialog {
  transition: opacity 0.3s ease !important;
}

.el-message-box-enter-active {
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

.el-message-box-leave-active {
  transition: all 0.2s ease-in !important;
}

.el-message-box-enter-from {
  opacity: 0 !important;
  transform: scale(0.85) translateY(20px) !important;
}

.el-message-box-leave-to {
  opacity: 0 !important;
  transform: scale(0.9) translateY(10px) !important;
}

/* el-dialog 弹窗动画 */
.el-overlay-dialog {
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.v-dialog-enter-active,
.v-dialog-leave-active {
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.v-dialog-enter-from {
  opacity: 0 !important;
  transform: scale(0.96) translateY(10px) !important;
}

.v-dialog-leave-to {
  opacity: 0 !important;
  transform: scale(0.96) translateY(10px) !important;
}

/* el-overlay 遮罩层动画 */
.v-overlay-enter-active,
.v-overlay-leave-active {
  transition: opacity 0.3s ease !important;
}

.v-overlay-enter-from,
.v-overlay-leave-to {
  opacity: 0 !important;
}

/* ========================================
 * 分段选择器样式（商品类型）
 * ======================================== */

.type-radio-group {
  width: 100% !important;
  display: flex !important;
  gap: 8px !important;
}

.type-radio-group .el-radio-button {
  flex: 1 !important;
}

.type-radio-group .el-radio-button__inner {
  width: 100% !important;
  border-radius: 10px !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-bg-deep) !important;
  color: var(--color-text-muted) !important;
  box-shadow: none !important;
  transition: all 0.2s ease !important;
  font-weight: 500 !important;
  padding: 10px 16px !important;
}

.type-radio-group .el-radio-button__inner:hover {
  color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  background: var(--color-primary-light) !important;
}

.type-radio-group .el-radio-button.is-active .el-radio-button__inner {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.3) !important;
}

/* 移除默认的 radio-button 连接样式 */
.type-radio-group .el-radio-button:first-child .el-radio-button__inner {
  border-radius: 10px !important;
}

.type-radio-group .el-radio-button:last-child .el-radio-button__inner {
  border-radius: 10px !important;
}

.type-radio-group .el-radio-button .el-radio-button__inner {
  border-left: 1px solid var(--color-border) !important;
}

.type-radio-group .el-radio-button.is-active .el-radio-button__inner {
  border-left: 1px solid var(--color-primary) !important;
}
/* 引入设计系统 */
/*
 * 设计 Token - HMW 发卡系统
 * 双主题系统：暗色 / 亮色
 * 通用变量在 :root，主题变量在 [data-theme]
 */
/* ========================================
 * 通用变量（主题无关）
 * ======================================== */
:root {
  /* 圆角 */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --radius-full: 9999px;

  /* 字体 */
  --font-sans: "HarmonyOS Sans SC", "PingFang SC", "Microsoft YaHei", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: "HarmonyOS Sans Mono", "JetBrains Mono", "Fira Code", "SF Mono", "Consolas", monospace;

  /* 字体层级 */
  --font-size-h1: 2rem;
  --font-size-h2: 1.5rem;
  --font-size-h3: 1.125rem;
  --font-size-body: 1rem;
  --font-size-sm: 0.875rem;
  --font-size-xs: 0.75rem;

  /* 字重 */
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;

  /* 间距 */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-2xl: 48px;
  --spacing-3xl: 64px;

  /* 页面布局间距 */
  --spacing-page-mobile: 12px;
  --spacing-page-tablet: 20px;
  --spacing-page-desktop: 24px;

  /* 卡片内边距 */
  --spacing-card-mobile: 12px;
  --spacing-card-desktop: 20px;

  /* 区块间距 */
  --spacing-section-mobile: 24px;
  --spacing-section-desktop: 48px;

  /* 动效 */
  --transition-fast: 150ms;
  --transition-base: 250ms;
  --transition-slow: 350ms;
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);

  /* z-index */
  --z-base: 0;
  --z-hover: 10;
  --z-sticky: 100;
  --z-backtop: 200;
  --z-overlay: 900;
  --z-dialog: 1000;
  --z-dialog-child: 1001;
  --z-notification: 2000;
}
/* ========================================
 * 暗色主题
 * ======================================== */
[data-theme="dark"] {
  /* 背景 */
  --color-bg-deep: #020617;
  --color-bg-base: #0F172A;
  --color-bg-elevated: #1E293B;
  --color-bg-surface: #334155;
  --color-background: #020617;
  --color-surface: #1E293B;

  /* 主色 */
  --color-primary: #3B82F6;
  --color-primary-hover: #2563EB;
  --color-primary-light: rgba(59, 130, 246, 0.1);
  --color-primary-glow: rgba(59, 130, 246, 0.3);
  --color-secondary: #60A5FA;

  /* CTA */
  --color-cta: #22C55E;
  --color-cta-hover: #16A34A;
  --color-cta-glow: rgba(34, 197, 94, 0.3);

  /* 文字 */
  --color-text: #F1F5F9;
  --color-text-secondary: #CBD5E1;
  --color-text-muted: #94A3B8;
  --color-text-disabled: #475569;

  /* 边框 */
  --color-border: rgba(255, 255, 255, 0.08);
  --color-border-hover: rgba(255, 255, 255, 0.15);

  /* 状态色 */
  --color-danger: #EF4444;
  --color-warning: #EAB308;
  --color-success: #22C55E;
  --color-footer: #0F172A;

  /* 渐变 */
  --gradient-primary: linear-gradient(135deg, #3B82F6 0%, #2563EB 100%);
  --gradient-cta: linear-gradient(135deg, #22C55E 0%, #16A34A 100%);

  /* 玻璃态 */
  --glass-bg: rgba(30, 41, 59, 0.6);
  --glass-bg-hover: rgba(30, 41, 59, 0.8);
  --glass-border: 1px solid rgba(255, 255, 255, 0.08);
  --glass-border-hover: 1px solid rgba(59, 130, 246, 0.3);
  --glass-blur: blur(20px);
  --glass-nav-bg: rgba(15, 23, 42, 0.8);
  --glass-nav-border: 1px solid rgba(255, 255, 255, 0.06);
  --glass-card-bg: rgba(30, 41, 59, 0.6);
  --glass-card-blur: blur(20px);
  --glass-card-border: 1px solid rgba(255, 255, 255, 0.08);
  --glass-card-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
  --glass-dialog-bg: rgba(30, 41, 59, 0.95);
  --glass-dialog-blur: blur(20px);
  --glass-dialog-overlay: rgba(2, 6, 23, 0.7);

  /* 阴影 */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.4);
  --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.5);
  --shadow-cta: 0 4px 14px rgba(34, 197, 94, 0.3);
  --shadow-danger: 0 4px 14px rgba(239, 68, 68, 0.3);
  --shadow-glow: 0 0 30px rgba(59, 130, 246, 0.15);

  /* 背景装饰 */
  --gradient-glow: radial-gradient(ellipse at 50% 0%, rgba(59, 130, 246, 0.12) 0%, transparent 60%);
  --gradient-mesh: radial-gradient(at 40% 20%, rgba(59, 130, 246, 0.08) 0px, transparent 50%),
                   radial-gradient(at 80% 0%, rgba(34, 197, 94, 0.06) 0px, transparent 50%),
                   radial-gradient(at 0% 50%, rgba(139, 92, 246, 0.06) 0px, transparent 50%);

  /* 表单 */
  --input-bg: rgba(255, 255, 255, 0.05);
  --input-border: rgba(255, 255, 255, 0.1);
  --input-focus-bg: rgba(255, 255, 255, 0.08);

  /* 表格 */
  --table-header-bg: rgba(59, 130, 246, 0.08);
  --table-row-hover: rgba(255, 255, 255, 0.02);
  --table-border: rgba(255, 255, 255, 0.04);

  /* 标签 */
  --tag-success-bg: rgba(34, 197, 94, 0.15);
  --tag-warning-bg: rgba(234, 179, 8, 0.15);
  --tag-danger-bg: rgba(239, 68, 68, 0.15);
  --tag-info-bg: rgba(59, 130, 246, 0.15);

  /* 卡密 */
  --secret-bg: rgba(59, 130, 246, 0.08);
  --secret-border: rgba(59, 130, 246, 0.3);

  /* 弹窗 */
  --modal-overlay: rgba(2, 6, 23, 0.7);
  --modal-bg: rgba(30, 41, 59, 0.95);
}
/* ========================================
 * 亮色主题
 * ======================================== */
[data-theme="light"] {
  /* 背景 */
  --color-bg-deep: #F8FAFC;
  --color-bg-base: #FFFFFF;
  --color-bg-elevated: #FFFFFF;
  --color-bg-surface: #F1F5F9;
  --color-background: #F8FAFC;
  --color-surface: #FFFFFF;

  /* 主色 */
  --color-primary: #2563EB;
  --color-primary-hover: #1D4ED8;
  --color-primary-light: rgba(37, 99, 235, 0.08);
  --color-primary-glow: rgba(37, 99, 235, 0.2);
  --color-secondary: #3B82F6;

  /* CTA */
  --color-cta: #16A34A;
  --color-cta-hover: #15803D;
  --color-cta-glow: rgba(22, 163, 74, 0.2);

  /* 文字 */
  --color-text: #0F172A;
  --color-text-secondary: #334155;
  --color-text-muted: #64748B;
  --color-text-disabled: #CBD5E1;

  /* 边框 */
  --color-border: rgba(0, 0, 0, 0.08);
  --color-border-hover: rgba(0, 0, 0, 0.15);

  /* 状态色 */
  --color-danger: #DC2626;
  --color-warning: #D97706;
  --color-success: #16A34A;
  --color-footer: #0F172A;

  /* 渐变 */
  --gradient-primary: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%);
  --gradient-cta: linear-gradient(135deg, #16A34A 0%, #15803D 100%);

  /* 玻璃态 */
  --glass-bg: rgba(255, 255, 255, 0.7);
  --glass-bg-hover: rgba(255, 255, 255, 0.85);
  --glass-border: 1px solid rgba(0, 0, 0, 0.06);
  --glass-border-hover: 1px solid rgba(37, 99, 235, 0.2);
  --glass-blur: blur(20px);
  --glass-nav-bg: rgba(255, 255, 255, 0.85);
  --glass-nav-border: 1px solid rgba(0, 0, 0, 0.06);
  --glass-card-bg: rgba(255, 255, 255, 0.7);
  --glass-card-blur: blur(20px);
  --glass-card-border: 1px solid rgba(0, 0, 0, 0.06);
  --glass-card-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  --glass-dialog-bg: rgba(255, 255, 255, 0.95);
  --glass-dialog-blur: blur(20px);
  --glass-dialog-overlay: rgba(0, 0, 0, 0.4);

  /* 阴影 */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.12);
  --shadow-cta: 0 4px 14px rgba(22, 163, 74, 0.2);
  --shadow-danger: 0 4px 14px rgba(220, 38, 38, 0.2);
  --shadow-glow: 0 0 30px rgba(37, 99, 235, 0.1);

  /* 背景装饰 */
  --gradient-glow: radial-gradient(ellipse at 50% 0%, rgba(37, 99, 235, 0.06) 0%, transparent 60%);
  --gradient-mesh: radial-gradient(at 40% 20%, rgba(37, 99, 235, 0.04) 0px, transparent 50%),
                   radial-gradient(at 80% 0%, rgba(22, 163, 74, 0.03) 0px, transparent 50%),
                   radial-gradient(at 0% 50%, rgba(124, 58, 237, 0.03) 0px, transparent 50%);

  /* 表单 */
  --input-bg: rgba(0, 0, 0, 0.03);
  --input-border: rgba(0, 0, 0, 0.1);
  --input-focus-bg: rgba(0, 0, 0, 0.01);

  /* 表格 */
  --table-header-bg: rgba(37, 99, 235, 0.05);
  --table-row-hover: rgba(0, 0, 0, 0.02);
  --table-border: rgba(0, 0, 0, 0.05);

  /* 标签 */
  --tag-success-bg: rgba(22, 163, 74, 0.1);
  --tag-warning-bg: rgba(217, 119, 6, 0.1);
  --tag-danger-bg: rgba(220, 38, 38, 0.1);
  --tag-info-bg: rgba(37, 99, 235, 0.1);

  /* 卡密 */
  --secret-bg: rgba(37, 99, 235, 0.05);
  --secret-border: rgba(37, 99, 235, 0.2);

  /* 弹窗 */
  --modal-overlay: rgba(0, 0, 0, 0.4);
  --modal-bg: rgba(255, 255, 255, 0.95);
}
/*
 * 鸿蒙字体 - HMW 发卡系统
 * 基于设计方案 v1.1 第 2.2 节
 *
 * 使用 npm 包 harmonyos-sans-sc-webfont-splitted
 * font-display: swap 确保无阻塞加载
 */
/* 鸿蒙字体 - Regular (400) */
@font-face {
  font-family: 'HarmonyOS Sans SC';
  src: local('HarmonyOS Sans SC Regular'), local('HarmonyOS Sans SC'), url('/assets/Regular_ac4458-Co6x8DhR.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
/* 鸿蒙字体 - Medium (500) */
@font-face {
  font-family: 'HarmonyOS Sans SC';
  src: local('HarmonyOS Sans SC Medium'), url('/assets/Medium_26fb9a-R6p4Xd7y.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
/* 鸿蒙字体 - Bold (700) */
@font-face {
  font-family: 'HarmonyOS Sans SC';
  src: local('HarmonyOS Sans SC Bold'), url('/assets/Bold_53d21e-BC7KtEL5.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
/* 等宽字体 - 使用系统等宽字体作为 fallback */
@font-face {
  font-family: 'HarmonyOS Sans Mono';
  src: local('Consolas'), local('SF Mono'), local('Monaco'), local('Menlo');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
/* 全局样式 */
:root {
  font-family: var(--font-sans);
  line-height: 1.5;
  font-weight: 400;

  color: var(--color-text);
  background-color: var(--color-background);

  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: transparent;

  transition: color 0.4s ease, background-color 0.4s ease;
}
* {
  box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
}
/* 触摸优化 */
a, button, input, select, textarea, [role="button"] {
  touch-action: manipulation;
}
a:active, button:active, [role="button"]:active {
  opacity: 0.8;
}
a {
  font-weight: 500;
  color: var(--color-primary);
  text-decoration: inherit;
  transition: color var(--transition-fast);
}
a:hover {
  color: var(--color-primary-hover);
}
body {
  margin: 0;
  padding: 0;
  min-width: 320px;
  min-height: 100vh;
  overflow-x: hidden;
}
h1 {
  font-size: clamp(1.8rem, 5vw, 3.2rem);
  line-height: 1.1;
}
#app {
  width: 100%;
  margin: 0;
  padding: 0;
}
/* 移动端适配 */
@media (max-width: 768px) {
  #app {
    padding: 0;
  }

  h1 {
    font-size: 1.8rem;
  }
}
/* Element Plus 移动端优化 */
@media (max-width: 768px) {
  .el-dialog {
    width: 90% !important;
    margin: 5vh auto !important;
  }

  .el-form-item {
    margin-bottom: 18px;
  }

  .el-table {
    font-size: 12px;
  }

  .el-table .hidden-sm-and-down {
    display: none;
  }

  .el-button {
    padding: 10px 15px;
  }

  .el-pagination {
    padding: 10px 0;
  }

  .el-pagination.is-background .el-pager li {
    min-width: 28px;
    height: 28px;
    line-height: 28px;
  }
}
/* 平板适配 */
@media (min-width: 769px) and (max-width: 1024px) {
  #app {
    padding: 0;
  }

  .el-dialog {
    width: 70% !important;
  }
}
/*
 * 全局动画和通用样式
 * 组件级样式已移至 element-theme.css
 */

/* ========================================
 * 全局重置
 * ======================================== */
* {
  scroll-behavior: smooth !important;
}

/* 全局 cursor-pointer */
.el-button,
.el-link,
.el-menu-item,
.el-pagination button,
.el-pager li,
.el-select,
.el-checkbox,
.el-radio,
.el-switch,
.el-upload,
a[href],
button,
[role="button"],
[onclick] {
  cursor: pointer !important;
}

/* 触摸目标最小尺寸 */
.el-pagination button,
.el-pager li {
  min-width: 36px !important;
  min-height: 36px !important;
}

/* ========================================
 * 动画 Keyframes
 * ======================================== */

/* 下拉框滑入 */
@keyframes dropdownSlide {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 消息滑入 */
@keyframes messageSlide {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(-100%);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

/* 通知滑入 */
@keyframes notificationSlide {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* 弹窗缩放 */
@keyframes dialogZoom {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* 消息弹窗弹跳 */
@keyframes messageBoxBounce {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* 遮罩淡入 */
@keyframes overlayFade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* 加载淡入 */
@keyframes loadingFade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* 加载脉冲 */
@keyframes spinnerPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}

/* 淡入 */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* 淡入上移 */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 骨架屏闪烁 */
@keyframes skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* 浮动 */
@keyframes float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

/* 脉冲 */
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

/* ========================================
 * Element Plus 动画应用
 * ======================================== */
.el-select-dropdown {
  animation: dropdownSlide 0.3s ease-out !important;
}

.el-message {
  animation: messageSlide 0.4s var(--ease-in-out) !important;
}

.el-notification {
  animation: notificationSlide 0.5s var(--ease-in-out) !important;
}

.el-dialog {
  animation: dialogZoom 0.4s var(--ease-in-out) !important;
}

.el-message-box {
  animation: messageBoxBounce 0.5s var(--ease-bounce) !important;
}

.el-overlay {
  animation: overlayFade 0.3s ease-out !important;
}

.el-loading-mask {
  animation: loadingFade 0.3s ease-out !important;
}

/* ========================================
 * 减少动画
 * ======================================== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* --- 遮罩层 --- */
.global-confirm-overlay[data-v-73316993] {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

/* --- 弹窗容器 --- */
.global-confirm-container[data-v-73316993] {
  background: #ffffff;
  width: 90%;
  max-width: 400px;
  padding: 32px 24px;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12), 0 4px 16px rgba(0, 0, 0, 0.06);
  text-align: center;
  outline: none;
}

/* --- 图标区域 --- */
.confirm-icon[data-v-73316993] {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 20px auto;
}
.confirm-icon-info[data-v-73316993] {
  background-color: #eff6ff;
  color: #3b82f6;
}
.confirm-icon-success[data-v-73316993] {
  background-color: #f0fdf4;
  color: #22c55e;
}
.confirm-icon-warning[data-v-73316993],
.confirm-icon-confirm[data-v-73316993] {
  background-color: #fff7ed;
  color: #f97316;
}
.confirm-icon-danger[data-v-73316993],
.confirm-icon-error[data-v-73316993] {
  background-color: #fef2f2;
  color: #ef4444;
}

/* --- 文本区域 --- */
.confirm-title[data-v-73316993] {
  font-size: 20px;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 8px;
}
.confirm-desc[data-v-73316993] {
  font-size: 15px;
  color: #6b7280;
  line-height: 1.5;
  margin-bottom: 32px;
}

/* --- 按钮区域 --- */
.confirm-actions[data-v-73316993] {
  display: flex;
  gap: 12px;
  justify-content: center;
}

/* --- 按钮基础样式 --- */
.btn[data-v-73316993] {
  flex: 1;
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 500;
  cursor: pointer;
  border: none;
  outline: none;
  transition: all 0.2s ease;
}

/* --- 次级按钮 --- */
.btn-secondary[data-v-73316993] {
  background-color: #f3f4f6;
  color: #1f2937;
}
.btn-secondary[data-v-73316993]:hover {
  background-color: #e5e7eb;
}

/* --- 主按钮类型 --- */
.btn-info[data-v-73316993] {
  background-color: #3b82f6;
  color: white;
  box-shadow: 0 1px 2px 0 rgba(59, 130, 246, 0.5);
}
.btn-info[data-v-73316993]:hover {
  background-color: #2563eb;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(59, 130, 246, 0.4);
}
.btn-success[data-v-73316993] {
  background-color: #22c55e;
  color: white;
  box-shadow: 0 1px 2px 0 rgba(34, 197, 94, 0.5);
}
.btn-success[data-v-73316993]:hover {
  background-color: #16a34a;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(34, 197, 94, 0.4);
}
.btn-warning[data-v-73316993] {
  background-color: #f97316;
  color: white;
  box-shadow: 0 1px 2px 0 rgba(249, 115, 22, 0.5);
}
.btn-warning[data-v-73316993]:hover {
  background-color: #ea580c;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(249, 115, 22, 0.4);
}
.btn-danger[data-v-73316993],
.btn-error[data-v-73316993] {
  background-color: #ef4444;
  color: white;
  box-shadow: 0 1px 2px 0 rgba(239, 68, 68, 0.5);
}
.btn-danger[data-v-73316993]:hover,
.btn-error[data-v-73316993]:hover {
  background-color: #dc2626;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(239, 68, 68, 0.4);
}
.btn-confirm[data-v-73316993] {
  background-color: #f97316;
  color: white;
  box-shadow: 0 1px 2px 0 rgba(249, 115, 22, 0.5);
}
.btn-confirm[data-v-73316993]:hover {
  background-color: #ea580c;
  transform: translateY(-1px);
  box-shadow: 0 4px 6px -1px rgba(249, 115, 22, 0.4);
}

/* --- Vue Transition 动画 --- */

/* 遮罩层淡入淡出 */
.confirm-fade-enter-active[data-v-73316993],
.confirm-fade-leave-active[data-v-73316993] {
  transition: opacity 0.3s ease;
}
.confirm-fade-enter-from[data-v-73316993],
.confirm-fade-leave-to[data-v-73316993] {
  opacity: 0;
}

/* 弹窗缩放动画 */
.confirm-scale-enter-active[data-v-73316993],
.confirm-scale-leave-active[data-v-73316993] {
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.confirm-scale-enter-from[data-v-73316993],
.confirm-scale-leave-to[data-v-73316993] {
  opacity: 0;
  transform: scale(0.9) translateY(10px);
}

/* --- 响应式 --- */
@media (max-width: 540px) {
.global-confirm-container[data-v-73316993] {
    width: 95%;
    padding: 28px 20px;
}
}
@media (prefers-reduced-motion: reduce) {
.confirm-fade-enter-active[data-v-73316993],
  .confirm-fade-leave-active[data-v-73316993],
  .confirm-scale-enter-active[data-v-73316993],
  .confirm-scale-leave-active[data-v-73316993] {
    transition: none;
}
}

html {
  overflow-y: scroll;
}
body {
  font-family: var(--font-sans);
  background-color: var(--color-background);
  background-image: var(--gradient-mesh);
  background-attachment: fixed;
  transition: background-color 0.4s ease;
}

/* 顶部渐变光晕 - 与 demo 一致 */
body::before {
  content: '';
  position: fixed;
  top: -200px;
  left: 50%;
  transform: translateX(-50%);
  width: 800px;
  height: 600px;
  background: var(--gradient-glow);
  pointer-events: none;
  z-index: 0;
  transition: background 0.4s ease;
}
#app {
  min-height: 100vh;
  width: 100%;
  overflow-x: hidden;
  position: relative;
  z-index: 1;
}

/* 路由过渡动画 - 淡入淡出 250ms */
.fade-enter-active,
.fade-leave-active {
  transition: opacity var(--transition-base) var(--ease-in-out);
}
.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}

/* 减少动画 */
@media (prefers-reduced-motion: reduce) {
.fade-enter-active,
  .fade-leave-active {
    transition: none;
}
}
