/* 引入统一的CSS变量 */
@import url('./variables.css');

/* 文件下载页面样式 */
body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 0;
  background-color: hsl(var(--color-bg-secondary));
}

.fullscreen-content {
  width: 100%;
  max-width: 600px;
  padding: 0 var(--space-6);
}

@media (min-width: 1024px) {
  .fullscreen-content {
    max-width: 600px;
  }
}

header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.title {
  font-size: var(--text-4xl);
  font-weight: 700;
  color: hsl(var(--color-primary));
  margin-bottom: var(--space-4);
  line-height: var(--leading-tight);
}

.subtitle {
  font-size: var(--text-lg);
  color: hsl(var(--color-text-muted));
  opacity: 0.8;
  margin-bottom: var(--space-3);
}

main {
  width: 100%;
}

.download-section {
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}

.section-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.section-header h2 {
  font-size: var(--text-3xl);
  font-weight: 600;
  color: hsl(var(--color-text-primary));
  margin-bottom: var(--space-3);
}

.form-group {
  margin-bottom: var(--space-6);
  display: block;
}

label {
  display: block;
  margin-bottom: var(--space-2);
  font-weight: 500;
  color: hsl(var(--color-text-primary));
  font-size: var(--text-base);
}

.form-control {
  width: 100%;
  height: 60px;
  padding: 0 var(--space-5);
  border: var(--border-width) solid hsl(var(--color-text-primary));
  border-radius: var(--radius-md);
  font-size: var(--text-lg);
  transition: all var(--transition-normal);
  background: hsl(var(--color-white));
  font-family: var(--font-family-sans);
  line-height: var(--leading-tight);
  box-shadow: var(--shadow-sm);
  font-weight: 500;
}

.form-control:focus {
  border-color: hsl(var(--color-primary));
  outline: 0;
  box-shadow: 0 0 15px hsl(var(--color-primary), 0.2);
}

/* 按钮样式扩展 */
.btn {
  width: 100%;
  height: 65px;
  background: hsl(var(--color-primary));
  color: hsl(var(--color-white));
  border: var(--border-width) solid hsl(var(--color-text-primary));
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: var(--text-lg);
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  transition: all var(--transition-fast);
  margin: var(--space-5) 0 var(--space-8);
  text-decoration: none;
  font-family: var(--font-family-sans);
  line-height: var(--leading-tight);
  box-shadow: var(--shadow-md);
  text-shadow: 1px 1px 0px hsl(var(--color-text-primary));
  position: relative;
  overflow: hidden;
}

.btn:hover:not(:disabled) {
  background: hsl(var(--color-primary-light));
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn-secondary {
  background: hsl(var(--color-gray-600));
}

.btn-secondary:hover {
  background: hsl(var(--color-gray-700));
}

.btn-success {
  background: hsl(var(--color-success));
}

.btn-success:hover {
  background: hsl(var(--color-success), 0.9);
}

.btn:disabled {
  background: hsl(var(--color-gray-300));
  color: hsl(var(--color-gray-500));
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.files-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin-bottom: var(--space-8);
}

.file-card {
  background: rgba(255, 255, 255, 0.9);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  border: 2px solid hsl(var(--color-primary-light));
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-normal);
}

.file-card:hover {
  border-color: hsl(var(--color-primary));
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.file-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
  gap: var(--space-4);
}

.file-name {
  font-size: var(--text-lg);
  font-weight: 600;
  color: hsl(var(--color-text-primary));
  flex: 1;
  min-width: 0;
  line-height: var(--leading-relaxed);
  word-wrap: break-word;
}

.file-version {
  background: hsl(var(--color-primary));
  color: hsl(var(--color-white));
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 500;
  white-space: nowrap;
  flex-shrink: 0;
}

.file-description {
  color: hsl(var(--color-text-secondary));
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
}

.file-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: hsl(var(--color-text-muted));
}

.actions {
  text-align: center;
  margin-top: var(--space-8);
}

.empty-state {
  text-align: center;
  padding: var(--space-16) var(--space-6);
  color: hsl(var(--color-text-muted));
}

.empty-state p {
  font-size: var(--text-base);
  margin-bottom: 0;
}

@media (max-width: 768px) {
  .title {
    font-size: var(--text-3xl);
  }
  
  .subtitle {
    font-size: var(--text-base);
  }
  
  .btn,
  .form-control {
    height: 55px;
    font-size: var(--text-base);
  }
  
  .file-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }
  
  .file-meta {
    gap: var(--space-2);
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 480px) {
  .fullscreen-content {
    padding: 0 var(--space-4);
  }
  
  .title {
    font-size: var(--text-2xl);
  }
  
  .subtitle {
    font-size: var(--text-sm);
  }
  
  .section-header h2 {
    font-size: var(--text-xl);
  }
  
  .btn,
  .form-control {
    height: 50px;
  }
  
  header {
    margin-bottom: var(--space-8);
  }
}

.result-container {
  margin-bottom: var(--space-8);
  animation: fadeIn var(--transition-normal);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.alert {
  padding: var(--space-5);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  margin-bottom: var(--space-8);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.alert-success {
  background: hsl(var(--color-success), 0.1);
  border: 1px solid hsl(var(--color-success));
  color: hsl(var(--color-success));
}

.alert-danger {
  background: hsl(var(--color-danger), 0.1);
  border: 1px solid hsl(var(--color-danger));
  color: hsl(var(--color-danger));
}

.alert i {
  font-size: var(--text-xl);
}

/* 确保与统一设计系统的兼容性 */
input[type="text"],
input[type="password"],
input[type="email"],
textarea,
select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid hsl(var(--color-border));
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  transition: all var(--transition-normal);
  background-color: hsl(var(--color-white));
  font-family: var(--font-family-sans);
  line-height: var(--leading-tight);
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
textarea:focus,
select:focus {
  border-color: hsl(var(--color-primary));
  box-shadow: 0 0 0 3px hsl(var(--color-primary), 0.1);
  outline: none;
}

/* 卡片样式扩展 */
.card {
  background-color: hsl(var(--color-white));
  border: 1px solid hsl(var(--color-border));
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-normal);
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* 动画效果 */
.fade-in {
  animation: fadeIn var(--transition-normal);
}

.slide-up {
  animation: slideUp var(--transition-normal);
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
