/**
 * Software List 页面样式
 *
 * @package     block-canvas Child
 * @subpackage  Assets
 * @author      JoshuaWang2019
 * @version     1.0.0
 * @since       2025-07-03
 */

/* 软件网格容器样式 */
.software-grid-wrapper {
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: var(--spacing-lg) !important;
}

/* 搜索区域样式 */
.software-search-section {
  margin-bottom: var(--spacing-xl) !important;
  background: var(--card-bg) !important;
  border-radius: var(--card-radius) !important;
  padding: var(--spacing-xl) !important;
  box-shadow: var(--card-shadow) !important;
}

.search-container {
  text-align: center !important;
}

.page-title {
  font-size: var(--font-size-3xl) !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--theme-primary) !important;
  margin: 0 0 var(--spacing-lg) 0 !important;
  line-height: 1.2 !important;
}

.software-search-form {
  max-width: 600px !important;
  margin: 0 auto !important;
}

.search-input-wrapper {
  display: flex !important;
  gap: var(--spacing-sm) !important;
  margin-bottom: var(--spacing-md) !important;
}

.software-search-input {
  flex: 1 !important;
  padding: var(--spacing-md) var(--spacing-lg) !important;
  border: 2px solid var(--theme-gray-300) !important;
  border-radius: var(--border-radius) !important;
  font-size: var(--font-size-lg) !important;
  transition: all 0.3s ease !important;
  background: white !important;
  color: var(--theme-gray-900) !important;
}

.software-search-input:focus {
  outline: none !important;
  border-color: var(--theme-primary) !important;
  box-shadow: 0 0 0 3px rgba(72, 187, 120, 0.1) !important;
}

.search-results-info {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: var(--spacing-sm) var(--spacing-md) !important;
  background: var(--theme-primary-50) !important;
  border-radius: var(--border-radius) !important;
  font-size: var(--font-size-sm) !important;
}

.search-query {
  color: var(--theme-primary) !important;
  font-weight: var(--font-weight-semibold) !important;
}

.clear-search {
  color: var(--theme-gray-600) !important;
  text-decoration: none !important;
  font-weight: var(--font-weight-medium) !important;
  transition: color 0.3s ease !important;
}

.clear-search:hover {
  color: var(--theme-primary) !important;
  text-decoration: underline !important;
}

/* 软件网格样式 */
.software-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr)) !important;
  gap: var(--spacing-lg) !important;
  margin-top: var(--spacing-xl) !important;
}

.software-item {
  background: var(--card-bg) !important;
  border-radius: var(--card-radius) !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
  box-shadow: var(--card-shadow) !important;
  border: 1px solid var(--theme-gray-200) !important;
}

.software-item:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--card-shadow-hover) !important;
  border-color: var(--theme-primary-200) !important;
}

.software-card-link {
  display: flex !important;
  text-decoration: none !important;
  color: inherit !important;
  width: 100% !important;
  height: 100% !important;
  align-items: center !important;
  padding: var(--spacing-md) !important;
  gap: var(--spacing-md) !important;
  min-height: 100px !important;
}

/* 软件图标容器样式 - 改为左侧固定大小 */
.software-icon-container {
  flex-shrink: 0 !important;
  width: 64px !important;
  height: 64px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--theme-gray-50) !important;
  border-radius: var(--border-radius) !important;
  overflow: hidden !important;
}

.software-icon-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: var(--border-radius) !important;
  transition: transform 0.3s ease !important;
}

.software-item:hover .software-icon-img {
  transform: scale(1.05) !important;
}

/* 软件信息区域样式 - 右侧信息区域 */
.software-info {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: 64px !important;
}

.software-title {
  font-size: var(--font-size-2xl) !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--theme-gray-900) !important;
  margin: 0 0 var(--spacing-xs) 0 !important;
  line-height: 1.3 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: break-word !important;
}

.software-description {
  margin-bottom: var(--spacing-xs) !important;
}

.description-text {
  color: var(--theme-gray-600) !important;
  font-size: var(--font-size-base) !important;
  line-height: 1.4 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.software-date {
  color: var(--theme-gray-500) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-medium) !important;
  margin-top: auto !important;
}

/* 空状态样式 */
.software-empty-state {
  padding: var(--spacing-3xl) var(--spacing-xl) !important;
  text-align: center !important;
  background: var(--card-bg) !important;
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
}

.empty-content {
  max-width: 400px !important;
  margin: 0 auto !important;
}

.empty-icon {
  font-size: 4rem !important;
  margin-bottom: var(--spacing-lg) !important;
  opacity: 0.5 !important;
}

.empty-title {
  font-size: var(--font-size-2xl) !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--theme-gray-900) !important;
  margin: 0 0 var(--spacing-md) 0 !important;
}

.empty-description {
  color: var(--theme-gray-600) !important;
  font-size: var(--font-size-lg) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

.browse-all-link {
  color: var(--theme-primary) !important;
  text-decoration: none !important;
  font-weight: var(--font-weight-semibold) !important;
  transition: color 0.3s ease !important;
}

.browse-all-link:hover {
  color: var(--theme-primary-600) !important;
  text-decoration: underline !important;
}

/* 响应式设计 */
@media (max-width: 768px) {
  .software-grid-wrapper {
    padding: var(--spacing-md) !important;
  }

  .software-search-section {
    padding: var(--spacing-lg) !important;
    margin-bottom: var(--spacing-lg) !important;
  }

  .page-title {
    font-size: var(--font-size-2xl) !important;
  }

  .search-input-wrapper {
    flex-direction: column !important;
  }

  .software-search-input {
    font-size: var(--font-size-base) !important;
  }

  .software-grid {
    grid-template-columns: 1fr !important;
    gap: var(--spacing-lg) !important;
  }

  .software-card-link {
    padding: var(--spacing-md) !important;
    gap: var(--spacing-md) !important;
    min-height: 80px !important;
  }

  .software-icon-container {
    width: 56px !important;
    height: 56px !important;
  }

  .software-info {
    min-height: 56px !important;
  }

  .software-title {
    font-size: 1.1rem !important;
  }

  .search-results-info {
    flex-direction: column !important;
    gap: var(--spacing-xs) !important;
    text-align: center !important;
  }
}

@media (max-width: 480px) {
  .software-grid-wrapper {
    padding: var(--spacing-sm) !important;
  }

  .software-search-section {
    padding: var(--spacing-md) !important;
  }

  .page-title {
    font-size: var(--font-size-xl) !important;
  }

  .software-card-link {
    padding: var(--spacing-sm) !important;
    gap: var(--spacing-sm) !important;
    min-height: 72px !important;
  }

  .software-icon-container {
    width: 48px !important;
    height: 48px !important;
  }

  .software-info {
    min-height: 48px !important;
  }

  .software-title {
    font-size: 1.1rem !important;
  }

  .description-text {
    font-size: var(--font-size-base) !important;
  }

  .software-date {
    font-size: 0.7rem !important;
  }
}

/* ==========================================================================
   深色模式适配
   ========================================================================== */
@media (prefers-color-scheme: dark) {
  .software-grid-wrapper {
    background: var(--theme-gray-50) !important;
  }
  
  .software-search-section {
    background: var(--card-bg) !important;
    border-color: var(--theme-gray-200) !important;
  }

  .page-title {
    color: var(--theme-primary-light) !important;
  }

  .search-input {
    background: var(--input-bg) !important;
    color: var(--theme-gray-800) !important;
    border-color: var(--theme-gray-200) !important;
  }

  .search-input::placeholder {
    color: var(--theme-gray-400) !important;
  }

  .search-button {
    background: var(--theme-primary) !important;
  }

  /* 软件卡片深色模式 */
  .software-item {
    background: var(--card-bg) !important;
    border-color: var(--theme-gray-200) !important;
  }

  .software-title {
    color: var(--theme-gray-800) !important;
  }

  .software-version,
  .software-meta {
    color: var(--theme-gray-400) !important;
  }

  .software-description {
    color: var(--theme-gray-600) !important;
  }

  .software-category {
    background: var(--theme-primary-light) !important;
    color: var(--theme-primary-dark) !important;
  }

  .software-download-btn {
    background: var(--theme-primary) !important;
    border-color: var(--theme-primary) !important;
  }

  .software-download-btn:hover {
    background: var(--theme-primary-dark) !important;
  }

  /* 分页器深色模式 */
  .pagination-container {
    background: var(--card-bg) !important;
    border-color: var(--theme-gray-200) !important;
  }

  .pagination a {
    color: var(--theme-gray-600) !important;
    border-color: var(--theme-gray-200) !important;
  }

  .pagination a:hover {
    background: var(--theme-gray-100) !important;
    color: var(--theme-gray-800) !important;
  }

  .pagination .current {
    background: var(--theme-primary) !important;
    color: white !important;
  }
}
