/* 隐患智能识别系统 - 共用样式
 * 设计系统：Minimal + Industrial grey + Safety orange
 * 参考 design-system/MASTER.md
 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  /* 设计系统色彩：工业灰 + 安全橙 */
  --color-primary: #64748B;
  --color-primary-hover: #475569;
  --color-primary-dark: #475569;
  --color-cta: #F97316;
  --color-cta-hover: #EA580C;
  --color-secondary: #94A3B8;
  --color-text: #334155;
  --color-text-weak: #64748B;
  --color-border: #d2d2d7;
  --color-border-light: #e5e5ea;
  --color-bg: #F8FAFC;
  --color-bg-alt: #F1F5F9;
  --color-card: #fff;
  --color-error: #ff3b30;
  --color-error-light: #ffe5e5;
  --color-notice-bg: #e8f4fc;
  --color-notice-border: #b3d9f5;
  --color-success: #34c759;
  --color-warning: #ff9500;
  --color-info: #5ac8fa;

  /* 圆角（优化：更圆滑的视觉效果） */
  --radius: 14px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;

  /* 阴影系统（多层次阴影效果） */
  --shadow-xs: 0 1px 3px rgba(0, 0, 0, 0.04);
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.05);
  --shadow-card: 0 2px 16px rgba(0, 0, 0, 0.06);
  --shadow-card-hover: 0 8px 32px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 12px 48px rgba(0, 0, 0, 0.12);
  --shadow-glow: 0 0 20px rgba(0, 113, 227, 0.3);

  /* 间距（更宽松） */
  --space-xs: 6px;
  --space-sm: 10px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;

  /* 字体（Inter 优先，设计系统推荐） */
  --font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;
  --font-size-base: 17px;
  --font-size-title: 32px;
  --font-size-section: 22px;
  --font-size-caption: 15px;
  /* 顶栏、账户下拉等与正文行内一致的字号字重 */
  --ui-text-sm: 16px;
  --ui-weight-body: 500;
  --ui-weight-em: 600;
  --ui-line-body: 1.5;

  /* 动效（增强过渡动画） */
  --transition-fast: 120ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-normal: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 400ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---------- 主题：简洁商务（默认，即 :root） ---------- */

/* ---------- 主题：科技深色 ---------- */
body[data-theme="tech"] {
  --color-primary: #38bdf8;
  --color-primary-hover: #7dd3fc;
  --color-secondary: #94a3b8;
  --color-text: #e2e8f0;
  --color-text-weak: #94a3b8;
  --color-border: #334155;
  --color-bg: #0f172a;
  --color-card: #1e293b;
  --color-error: #f87171;
  --color-notice-bg: #0f172a;
  --color-notice-border: #38bdf8;
  --shadow-card: 0 4px 12px rgba(0, 0, 0, 0.3);
}
body[data-theme="tech"] input[type="text"],
body[data-theme="tech"] input[type="number"],
body[data-theme="tech"] input[type="tel"],
body[data-theme="tech"] textarea,
body[data-theme="tech"] select {
  background: #334155;
  border-color: #475569;
  color: #e2e8f0;
}
body[data-theme="tech"] .result-block {
  background: #334155;
  border-color: #475569;
  color: #e2e8f0;
}
body[data-theme="tech"] .disclaimer {
  background: #422006;
  border-color: #b45309;
  color: #fde68a;
}
body[data-theme="tech"] button.secondary {
  background: #334155;
  color: #e2e8f0;
}
body[data-theme="tech"] button.secondary:hover:not(:disabled) {
  background: #475569;
}
body[data-theme="tech"] button:disabled {
  background: #475569;
  color: #64748b;
}

/* ---------- 主题：安全警示 ---------- */
body[data-theme="safety"] {
  --color-primary: #ea580c;
  --color-primary-hover: #f97316;
  --color-secondary: #78716c;
  --color-text: #292524;
  --color-text-weak: #57534e;
  --color-border: #e7e5e4;
  --color-bg: #fffbeb;
  --color-card: #fff;
  --color-error: #b91c1c;
  --color-notice-bg: #fff7ed;
  --color-notice-border: #fdba74;
  --shadow-card: 0 2px 8px rgba(234, 88, 12, 0.08);
}
body[data-theme="safety"] .disclaimer {
  background: #fef3c7;
  border-color: #f59e0b;
}

/* ---------- 主题：清新绿 ---------- */
body[data-theme="green"] {
  --color-primary: #059669;
  --color-primary-hover: #10b981;
  --color-secondary: #4b5563;
  --color-text: #111827;
  --color-text-weak: #6b7280;
  --color-border: #d1fae5;
  --color-bg: #f0fdf4;
  --color-card: #fff;
  --color-error: #b91c1c;
  --color-notice-bg: #d1fae5;
  --color-notice-border: #6ee7b7;
  --shadow-card: 0 2px 8px rgba(5, 150, 105, 0.08);
}
body[data-theme="green"] .disclaimer {
  background: #ecfdf5;
  border-color: #34d399;
}
body[data-theme="green"] .result-block {
  background: #ecfdf5;
  border-color: #a7f3d0;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: var(--space-xl) var(--space-lg);
  background: var(--color-bg);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  color: var(--color-text);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* 卡片（苹果风：大圆角、轻阴影、充足内边距 + 渐进式悬停效果） */
.card {
  max-width: 680px;
  margin: 0 auto var(--space-xl);
  background: var(--color-card);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) 28px;
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}

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

.card:last-of-type {
  margin-bottom: var(--space-xl);
}

h1 {
  font-size: var(--font-size-title);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-md);
  line-height: 1.2;
}

h2 {
  font-size: var(--font-size-section);
  font-weight: 600;
  margin: var(--space-lg) 0 var(--space-sm);
}

h3 {
  font-size: 19px;
  font-weight: 600;
  margin: var(--space-lg) 0 var(--space-sm);
}

/* 表单项（苹果风：圆角、柔和边框、焦点环） */
label {
  display: block;
  margin: var(--space-sm) 0 var(--space-xs);
  font-size: var(--font-size-base);
  font-weight: 500;
  color: var(--color-text);
}

input[type="text"],
input[type="number"],
input[type="tel"],
textarea,
select {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-base);
  font-family: inherit;
  background: var(--color-card);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.2);
  background: #fff;
}

textarea {
  min-height: 88px;
  resize: vertical;
}

/* 按钮（苹果风：圆角、过渡、可点击区域 + 渐变效果） */
button {
  padding: 12px 22px;
  margin-top: var(--space-sm);
  cursor: pointer;
  border-radius: var(--radius-md);
  border: none;
  font-size: var(--font-size-base);
  font-weight: 500;
  font-family: inherit;
  transition: all var(--transition-normal);
  position: relative;
  overflow: hidden;
}

button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, transparent 100%);
  pointer-events: none;
}

button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.35);
}

button.primary {
  background: linear-gradient(135deg, var(--color-cta) 0%, var(--color-cta-hover) 100%);
  color: #fff;
  box-shadow: var(--shadow-sm);
}

button.primary:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--color-cta-hover) 0%, var(--color-cta) 100%);
  box-shadow: var(--shadow-glow);
  transform: translateY(-1px);
}

button.primary:active:not(:disabled) {
  transform: translateY(0) scale(0.98);
}

button:disabled {
  background: #d2d2d7;
  cursor: not-allowed;
  color: #86868b;
  box-shadow: none;
}

button:disabled::before {
  display: none;
}

button.secondary {
  background: linear-gradient(135deg, #f5f5f7 0%, #e8e8ed 100%);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}

button.secondary:hover:not(:disabled) {
  background: linear-gradient(135deg, #e8e8ed 0%, #dcdce1 100%);
  border-color: var(--color-primary);
  transform: translateY(-1px);
}

/* 行间距 */
.row {
  margin-bottom: var(--space-lg);
}

/* 提示与免责（苹果风：柔和背景、圆角） */
.notice,
.disclaimer {
  font-size: var(--font-size-caption);
  color: var(--color-text-weak);
  background: var(--color-notice-bg);
  border: 1px solid var(--color-notice-border);
  border-radius: var(--radius-sm);
  padding: var(--space-md) var(--space-lg);
  margin: var(--space-md) 0;
  line-height: 1.5;
}

.disclaimer {
  background: #fff9e6;
  border-color: #f5d76e;
}

/* 错误信息 */
.error {
  color: var(--color-error);
  font-size: var(--font-size-caption);
  margin-top: var(--space-xs);
}

/* 结果区块（优化：浅灰底、圆角、微妙边框、卡片式阴影） */
.result-block {
  white-space: pre-wrap;
  background: linear-gradient(180deg, #f9fafb 0%, #f3f4f6 100%);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  font-size: var(--font-size-base);
  border: 1px solid var(--color-border-light);
  line-height: 1.65;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.03);
}

/* 额度等辅助信息 */
.quota,
.info {
  font-size: var(--font-size-caption);
  color: var(--color-text-weak);
  line-height: 1.5;
}

/* 结果区操作按钮组（复制、导出） */
.result-actions {
  margin-top: var(--space-md);
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

/* 进度提示 */
.progress-tip {
  font-size: var(--font-size-caption);
  color: var(--color-text-weak);
  margin-top: var(--space-sm);
  min-height: 1.2em;
  display: flex;
  align-items: center;
  gap: 8px;
}

.progress-tip:not(:empty)::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid var(--color-primary);
  border-top-color: transparent;
  border-radius: 50%;
  animation: progress-spin 0.8s linear infinite;
  flex-shrink: 0;
}

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

/* 链接（苹果风：主色、悬停不强调下划线） */
a {
  color: var(--color-primary);
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

a:hover {
  opacity: 0.85;
}

/* 页脚（苹果风：简洁、留白） */
.page-footer {
  text-align: center;
  font-size: var(--font-size-caption);
  color: var(--color-text-weak);
  margin-top: var(--space-xl);
  padding: var(--space-lg) var(--space-md);
}

.page-footer a {
  margin: 0 12px;
}

/* 主题切换按钮（页脚内） */
.theme-label {
  margin-right: var(--space-xs);
}
.theme-btn {
  margin: 0 6px;
  padding: 6px 12px;
  font-size: var(--font-size-caption);
  background: transparent;
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}
.theme-btn:hover {
  background: var(--color-notice-bg);
  border-color: var(--color-primary);
}
.theme-btn.active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.page-footer .theme-btn {
  margin-top: 0;
}

/* 上传图片 + 小游戏两列布局（仅桌面端显示小游戏） */
.analyze-layout {
  display: flex;
  gap: var(--space-lg);
  align-items: flex-start;
}

.analyze-left {
  flex: 1 1 0;
}

.analyze-right {
  flex: 1 1 0;
  max-width: 320px;
}

