/* 宠物星球App 色彩设计规范 CSS变量 */

:root {
  /* ===== 基础色彩 ===== */
  --color-background: #f8f8f8;
  --color-white: #FFFFFF;
  
  /* ===== 主题色系 ===== */
  --color-primary: #60a5fa;
  --color-primary-light: #93c5fd;
  --color-primary-dark: #3b82f6;
  
  /* ===== 辅助色系 ===== */
  --color-warm-light: #fbe9c6;
  --color-warm: #f6ce67;
  --color-natural: #dff2c3;
  
  /* ===== 点缀色 ===== */
  --color-accent: #fbeeef;
  
  /* ===== 文字色系 ===== */
  --color-text-primary: #111827;
  --color-text-secondary: #6b7280;
  --color-text-tertiary: #9ca3af;
  
  /* ===== 状态色彩 ===== */
  --color-success-bg: #dff2c3;
  --color-success-text: #166534;
  --color-warning-bg: #fbe9c6;
  --color-warning-text: #92400e;
  --color-error-bg: #fbeeef;
  --color-error-text: #991b1b;
  --color-info-bg: #dbeafe;
  --color-info-text: #1e40af;
  
  /* ===== 边框和分割线 ===== */
  --color-border: #e5e7eb;
  --color-border-light: #f3f4f6;
  
  /* ===== 阴影 ===== */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  
  /* ===== 渐变色 ===== */
  --gradient-primary: linear-gradient(135deg, #60a5fa, #3b82f6);
  --gradient-warm: linear-gradient(135deg, #f6ce67, #fbe9c6);
  --gradient-natural: linear-gradient(135deg, #dff2c3, #bbf7d0);
}

/* ===== 深色模式适配 ===== */
@media (prefers-color-scheme: dark) {
  :root {
    --color-background: #1f2937;
    --color-white: #374151;
    
    --color-text-primary: #f9fafb;
    --color-text-secondary: #d1d5db;
    --color-text-tertiary: #9ca3af;
    
    --color-border: #4b5563;
    --color-border-light: #374151;
  }
}

/* ===== 高对比度模式 ===== */
@media (prefers-contrast: high) {
  :root {
    --color-background: #000000;
    --color-white: #FFFFFF;
    
    --color-text-primary: #FFFFFF;
    --color-text-secondary: #e5e7eb;
    --color-text-tertiary: #d1d5db;
    
    --color-border: #6b7280;
    --color-border-light: #4b5563;
  }
}

/* ===== 实用工具类 ===== */

/* 背景色 */
.bg-primary { background-color: var(--color-primary); }
.bg-primary-light { background-color: var(--color-primary-light); }
.bg-primary-dark { background-color: var(--color-primary-dark); }
.bg-warm-light { background-color: var(--color-warm-light); }
.bg-warm { background-color: var(--color-warm); }
.bg-natural { background-color: var(--color-natural); }
.bg-accent { background-color: var(--color-accent); }
.bg-success { background-color: var(--color-success-bg); }
.bg-warning { background-color: var(--color-warning-bg); }
.bg-error { background-color: var(--color-error-bg); }
.bg-info { background-color: var(--color-info-bg); }

/* 文字色 */
.text-primary { color: var(--color-primary); }
.text-primary-light { color: var(--color-primary-light); }
.text-primary-dark { color: var(--color-primary-dark); }
.text-warm { color: var(--color-warm); }
.text-natural { color: var(--color-natural); }
.text-success { color: var(--color-success-text); }
.text-warning { color: var(--color-warning-text); }
.text-error { color: var(--color-error-text); }
.text-info { color: var(--color-info-text); }

/* 边框色 */
.border-primary { border-color: var(--color-primary); }
.border-warm { border-color: var(--color-warm); }
.border-natural { border-color: var(--color-natural); }
.border-success { border-color: var(--color-success-text); }
.border-warning { border-color: var(--color-warning-text); }
.border-error { border-color: var(--color-error-text); }

/* 渐变色 */
.gradient-primary { background: var(--gradient-primary); }
.gradient-warm { background: var(--gradient-warm); }
.gradient-natural { background: var(--gradient-natural); }

/* 状态样式 */
.status-success {
  background-color: var(--color-success-bg);
  color: var(--color-success-text);
}

.status-warning {
  background-color: var(--color-warning-bg);
  color: var(--color-warning-text);
}

.status-error {
  background-color: var(--color-error-bg);
  color: var(--color-error-text);
}

.status-info {
  background-color: var(--color-info-bg);
  color: var(--color-info-text);
}

/* 按钮样式 */
.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border: none;
  transition: background-color 0.2s ease;
}

.btn-primary:hover {
  background-color: var(--color-primary-dark);
}

.btn-secondary {
  background-color: var(--color-background);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  transition: all 0.2s ease;
}

.btn-secondary:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
}

/* 卡片样式 */
.card {
  background-color: var(--color-white);
  border-radius: 12px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
}

.card-pet {
  background-color: var(--color-white);
  border: 2px solid var(--color-warm);
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
}

/* 导航样式 */
.nav-primary {
  background-color: var(--color-white);
  color: var(--color-primary);
  border-bottom: 1px solid var(--color-border);
}

/* 输入框样式 */
.input-primary {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  color: var(--color-text-primary);
  border-radius: 8px;
  transition: border-color 0.2s ease;
}

.input-primary:focus {
  border-color: var(--color-primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.1);
}

/* 标签样式 */
.tag {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 16px;
  font-size: 0.875rem;
  font-weight: 500;
}

.tag-success {
  background-color: var(--color-success-bg);
  color: var(--color-success-text);
}

.tag-warning {
  background-color: var(--color-warning-bg);
  color: var(--color-warning-text);
}

.tag-error {
  background-color: var(--color-error-bg);
  color: var(--color-error-text);
}

.tag-info {
  background-color: var(--color-info-bg);
  color: var(--color-info-text);
}

/* 动画效果 */
@keyframes sparkle {
  0% { opacity: 0.3; }
  50% { opacity: 0.8; }
  100% { opacity: 0.3; }
}

.sparkle {
  animation: sparkle 3s ease-in-out infinite;
}

/* 响应式断点 */
@media (max-width: 768px) {
  .card {
    border-radius: 8px;
    box-shadow: var(--shadow-sm);
  }
  
  .btn-primary,
  .btn-secondary {
    padding: 12px 20px;
    font-size: 0.9rem;
  }
}

/* 打印样式 */
@media print {
  :root {
    --color-background: #FFFFFF;
    --color-white: #FFFFFF;
    --color-text-primary: #000000;
    --color-text-secondary: #333333;
  }
  
  .card {
    box-shadow: none;
    border: 1px solid #000000;
  }
} 