/* ============================================
   Design System - 统一设计规范
   参考欧美电子书网站（Kindle、Apple Books、Amazon Books）设计
   ============================================ */

/* ============================================
   1. 设计令牌（Design Tokens）
   ============================================ */

:root {
  /* 间距系统 - 基于8px网格系统 */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 12px;
  --spacing-lg: 16px;
  --spacing-xl: 20px;
  --spacing-2xl: 24px;
  --spacing-3xl: 32px;
  --spacing-4xl: 40px;
  --spacing-5xl: 48px;
  
  /* 圆角系统 */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;
  
  /* 阴影系统 - 更柔和的阴影，符合现代设计趋势 */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 2px 4px rgba(0, 0, 0, 0.06), 0 4px 8px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 4px 8px rgba(0, 0, 0, 0.08), 0 8px 16px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 8px 16px rgba(0, 0, 0, 0.1), 0 16px 32px rgba(0, 0, 0, 0.12);
  
  /* 颜色系统 - 基于现有紫色主题 */
  --color-primary: #6A0DAD;
  --color-primary-dark: #580A94;
  --color-primary-light: #7B1FA2;
  --color-primary-lighter: #9B5DE5;
  --color-primary-alpha-10: rgba(106, 13, 173, 0.1);
  --color-primary-alpha-05: rgba(106, 13, 173, 0.05);
  
  /* 文本颜色 */
  --color-text-primary: #222222;
  --color-text-secondary: #32343A;
  --color-text-tertiary: #84848A;
  --color-text-quaternary: #8E8E93;
  --color-text-disabled: #C7C7CC;
  
  /* 背景颜色 */
  --color-bg-primary: #FFFFFF;
  --color-bg-secondary: #F6F6F6;
  --color-bg-tertiary: #F2F2F7;
  --color-bg-hover: #E5E5EA;
  
  /* 边框颜色 */
  --color-border-light: #F7F7F7;
  --color-border-medium: #E5E5EA;
  --color-border-dark: #D1D1D6;
  
  /* 字体系统：与 common.css body 一致，避免页面内 SFPro/SFProText 未加载时回退不一致 */
  --font-family-primary: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'PingFang SC', 'Hiragino Sans GB', sans-serif;
  --font-family-secondary: var(--font-family-primary);
  
  /* 字体大小 - 更清晰的层次 */
  --font-size-xs: 11px;
  --font-size-sm: 12px;
  --font-size-base: 14px;
  --font-size-md: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 28px;
  
  /* 字体权重 */
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  
  /* 行高 */
  --line-height-tight: 1.2;
  --line-height-normal: 1.4;
  --line-height-relaxed: 1.6;
  --line-height-loose: 1.8;
  
  /* 过渡动画 */
  --transition-fast: 0.15s ease;
  --transition-base: 0.2s ease;
  --transition-slow: 0.3s ease;
  
  /* Z-index 层级 */
  --z-index-dropdown: 1000;
  --z-index-sticky: 1010;
  --z-index-fixed: 1020;
  --z-index-modal-backdrop: 1030;
  --z-index-modal: 1040;
  --z-index-tooltip: 1050;
}

/* ============================================
   2. 通用组件优化
   ============================================ */

/* 卡片组件 - 统一卡片样式 */
.card,
.book-item,
.category_item,
.search-result .book-item,
.book-list .book-item {
  background: var(--color-bg-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
}

.card:hover,
.book-item:hover,
.category_item:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.card:active,
.book-item:active,
.category_item:active {
  box-shadow: var(--shadow-sm);
  transform: translateY(0);
}

/* 按钮组件 - 统一按钮样式 */
.btn,
.unlock_btn,
.pay_now_btn,
.topup_pay_btn,
.recharge-btn,
.paypal_pay_btn,
.my_wallet_btn,
.book-read-btn {
  background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-primary-lighter) 100%);
  border-radius: var(--radius-full);
  color: var(--color-bg-primary);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-md);
  padding: var(--spacing-md) var(--spacing-xl);
  border: none;
  cursor: pointer;
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px; /* 符合触摸目标最小尺寸 */
}

.btn:hover,
.unlock_btn:hover,
.pay_now_btn:hover,
.topup_pay_btn:hover,
.recharge-btn:hover,
.paypal_pay_btn:hover,
.my_wallet_btn:hover,
.book-read-btn:hover {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary-light) 100%);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.btn:active,
.unlock_btn:active,
.pay_now_btn:active,
.topup_pay_btn:active,
.recharge-btn:active,
.paypal_pay_btn:active,
.my_wallet_btn:active,
.book-read-btn:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn:disabled,
.btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

/* 输入框组件 */
.input,
.search-input-wrapper input {
  background: var(--color-bg-tertiary);
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  padding: var(--spacing-md) var(--spacing-lg);
  font-size: var(--font-size-md);
  color: var(--color-text-primary);
  transition: all var(--transition-base);
  outline: none;
  width: 100%;
}

.input:focus,
.search-input-wrapper:focus-within input {
  background: var(--color-bg-primary);
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-alpha-10);
}

.input::placeholder {
  color: var(--color-text-quaternary);
}

/* 标签组件 */
.tag,
.book-tag,
.books_tag_box .tag,
.category_item_tag {
  display: inline-flex;
  align-items: center;
  padding: var(--spacing-xs) var(--spacing-md);
  background: var(--color-primary-alpha-10);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  color: var(--color-primary);
  line-height: var(--line-height-normal);
  transition: all var(--transition-fast);
}

.tag:hover,
.book-tag:hover {
  background: var(--color-primary-alpha-05);
  transform: scale(1.02);
}

/* 标题组件 */
.title-box p {
  font-family: var(--font-family-secondary);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  line-height: var(--line-height-tight);
  margin: 0;
}

.title-box .right {
  font-size: var(--font-size-sm);
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  transition: all var(--transition-fast);
}

.title-box .right:hover {
  opacity: 0.8;
}

/* ============================================
   3. 布局优化
   ============================================ */

/* 页面容器 */
.page-container,
.home_container,
.library_container,
.book-list-container,
.search-result-container,
.category_container,
.book-detail-container {
  background: var(--color-bg-secondary);
  min-height: 100vh;
  padding-bottom: 80px; /* 为底部标签栏留出空间 */
}

/* 内容区域统一间距 */
.book-list,
.search-result,
.category_list,
.book-detail-content {
  padding: var(--spacing-xl) var(--spacing-lg);
}

/* 书籍列表项 - 统一间距和样式 */
.book-item {
  margin-bottom: var(--spacing-xl);
  padding: var(--spacing-md);
  gap: var(--spacing-md);
}

.book-item > img {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}

/* 头部统一样式 */
.header-box,
.book-detail-header {
  background: var(--color-bg-primary);
  border-bottom: 1px solid var(--color-border-light);
  box-shadow: var(--shadow-sm);
}

/* ============================================
   4. 空状态优化
   ============================================ */

.empty-box,
.search-result-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-5xl) var(--spacing-xl);
  text-align: center;
  color: var(--color-text-tertiary);
  font-size: var(--font-size-md);
  line-height: var(--line-height-relaxed);
}

.empty-box img {
  width: 120px;
  height: 120px;
  opacity: 0.6;
  margin-bottom: var(--spacing-lg);
}

.empty-box p {
  margin-top: var(--spacing-lg);
  color: var(--color-text-tertiary);
  font-size: var(--font-size-md);
}

/* ============================================
   5. 加载状态优化
   ============================================ */

.loading,
.search-loading,
.book-detail-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3xl) var(--spacing-xl);
  color: var(--color-text-tertiary);
  font-size: var(--font-size-base);
  gap: var(--spacing-md);
}

.loading::before,
.search-loading::before,
.book-detail-loading::before {
  content: '';
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border-medium);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ============================================
   6. 底部标签栏优化
   ============================================ */

.tabBar_box {
  background: var(--color-bg-primary);
  border-top: 1px solid var(--color-border-light);
  box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.04);
}

.tabBar_item {
  transition: all var(--transition-fast);
}

.tabBar_item:active {
  transform: scale(0.95);
}

.tabBar_item span.active {
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
}

/* ============================================
   7. 响应式优化
   ============================================ */

@media screen and (min-width: 768px) {
  /* 桌面端增加悬停效果 */
  .book-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
  }
  
  .btn:hover {
    box-shadow: var(--shadow-md);
  }
  
  /* 桌面端增加内边距 */
  .book-list,
  .search-result,
  .category_list {
    padding: var(--spacing-2xl) var(--spacing-3xl);
  }
}

/* ============================================
   8. 可访问性优化
   ============================================ */

/* 确保所有交互元素有足够的触摸目标 */
button,
.btn,
.tabBar_item,
.book-item,
.category_item {
  min-height: 44px;
  min-width: 44px;
}

/* 焦点状态 */
button:focus-visible,
.btn:focus-visible,
.input:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   9. 动画优化
   ============================================ */

/* 平滑滚动 */
html {
  scroll-behavior: smooth;
}

/* 减少动画（尊重用户偏好） */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================
   10. 文本优化
   ============================================ */

/* 改进文本渲染 */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* 标题文本 */
h1, h2, h3, h4, h5, h6,
.title-box p,
.book-title {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  line-height: var(--line-height-tight);
}

/* 正文文本 */
p,
.book-description-content,
.book-item .book_info > p {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

/* 辅助文本 */
small,
.book-meta,
.book-item .book_info > p:not(:first-child) {
  font-size: var(--font-size-sm);
  color: var(--color-text-tertiary);
  line-height: var(--line-height-normal);
}
