/* =========================================================================
 * 白色极简: 新增模块样式 (首页快捷入口/商品流广告位/商品详情/看广告得积分/分销)
 * 全部基于 css/variables.css 设计令牌, 不含硬编码品牌色.
 * ========================================================================= */

.card {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}

/* ---- 首页 快捷功能入口 ---- */
.home-quick {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-sm);
  margin: var(--space-md) var(--space-lg) 0;
  padding: var(--space-md) var(--space-sm);
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.home-quick-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  min-height: 44px;
  cursor: pointer;
}
.home-quick-icon {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-primary-soft);
  color: var(--color-primary);
}
.home-quick-icon svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.home-quick-label { font-size: var(--font-size-xs); color: var(--color-text-body); }

/* ---- 商品流 广告位: 占据与普通商品卡相同的网格单元 (§15) ---- */
.ad-card { position: relative; }
.ad-card-media { position: relative; }
.ad-card-flag {
  position: absolute;
  top: 8px;
  left: 8px;
  font-size: 11px;
  line-height: 1;
  color: var(--color-text-white);
  background: rgba(17, 24, 39, 0.55);
  border-radius: var(--radius-sm);
  padding: 3px 6px;
}
.ad-card-cta { font-size: var(--font-size-sm); color: var(--color-primary); }

/* ---- 通用 详情/子页 顶栏 ---- */
.detail-topbar {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  height: 48px;
  padding: 0 var(--space-md);
  background: var(--color-bg-white);
  border-bottom: 1px solid var(--color-border);
}
.detail-back {
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer;
  color: var(--color-text-title);
}
.detail-back svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.detail-topbar-title { font-size: var(--font-size-md); font-weight: 600; color: var(--color-text-title); }
.detail-section-title { font-size: var(--font-size-lg); font-weight: 600; color: var(--color-text-title); margin-bottom: var(--space-sm); }

/* ---- 商品详情 ---- */
.detail-page { background: var(--color-bg); padding-bottom: calc(64px + var(--tab-bar-height) + var(--safe-area-bottom)); }
.detail-skeleton, .detail-empty { padding: 64px var(--space-lg); text-align: center; color: var(--color-text-secondary); }
.detail-empty .btn { margin-top: var(--space-lg); }
.detail-gallery { width: 100%; aspect-ratio: 1 / 1; background: var(--color-bg-white); }
.detail-gallery img { width: 100%; height: 100%; object-fit: cover; display: block; }
.detail-info { margin: var(--space-md); padding: var(--space-lg); }
.detail-price-row { display: flex; align-items: baseline; gap: var(--space-sm); }
.detail-price { font-size: var(--font-size-xxl); font-weight: 700; color: var(--color-price); }
.detail-price em { font-size: var(--font-size-md); font-style: normal; }
.detail-origin { font-size: var(--font-size-sm); color: var(--color-price-original); text-decoration: line-through; }
.detail-title { font-size: var(--font-size-lg); font-weight: 600; color: var(--color-text-title); margin: var(--space-sm) 0 0; line-height: 1.4; }
.detail-subtitle { font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-top: 4px; }
.detail-meta { display: flex; justify-content: space-between; margin-top: var(--space-md); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.detail-stock-out { color: var(--color-danger); }
.detail-specs { margin: var(--space-md); padding: var(--space-lg); }
.detail-spec { margin-bottom: var(--space-md); }
.detail-spec:last-child { margin-bottom: 0; }
.detail-spec-title { font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-bottom: var(--space-sm); }
.detail-spec-values { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.detail-spec-value {
  min-height: 36px; padding: 6px 14px;
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg-white); color: var(--color-text-body);
  font-size: var(--font-size-sm); cursor: pointer;
}
.detail-spec-value.active { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-soft); }
.detail-promo { margin: var(--space-md); padding: var(--space-md) var(--space-lg); display: flex; align-items: center; gap: var(--space-sm); font-size: var(--font-size-sm); color: var(--color-text-body); }
.detail-promo-tag { font-size: 11px; color: var(--color-primary); border: 1px solid var(--color-primary); border-radius: var(--radius-sm); padding: 1px 6px; }
.detail-promo-link { margin-left: auto; background: none; border: none; color: var(--color-primary); font-size: var(--font-size-sm); cursor: pointer; }
.detail-rich { padding: var(--space-md); }
.detail-rich img { width: 100%; display: block; border-radius: var(--radius-md); margin-bottom: var(--space-sm); }
.detail-actionbar {
  position: fixed; left: 0; right: 0;
  bottom: calc(var(--tab-bar-height) + var(--safe-area-bottom));
  display: flex; align-items: center; gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-bg-white); border-top: 1px solid var(--color-border);
  z-index: var(--z-fixed);
}
.detail-action { display: flex; flex-direction: column; align-items: center; justify-content: center; min-width: 48px; min-height: 44px; background: none; border: none; color: var(--color-text-secondary); cursor: pointer; }
.detail-action svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.7; }
.detail-action.active { color: var(--color-primary); }
.detail-action.active svg { fill: currentColor; stroke: currentColor; }
.detail-action-label { font-size: 11px; }
.detail-btn { flex: 1; min-height: 44px; border-radius: var(--radius-round); border: none; font-size: var(--font-size-md); font-weight: 600; cursor: pointer; }
.detail-btn-cart { background: var(--color-primary-soft); color: var(--color-primary); }
.detail-btn-buy { background: var(--color-primary); color: var(--color-text-white); }
.detail-btn:disabled { opacity: .5; }

/* ---- 看广告得积分 ---- */
.reward-page, .distribution-page { background: var(--color-bg); min-height: 100vh; padding-bottom: calc(var(--tab-bar-height) + var(--space-xl)); }
.reward-hero { margin: var(--space-md); padding: var(--space-xl); text-align: center; }
.reward-hero-label { font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.reward-hero-points { font-size: var(--font-size-xxl); font-weight: 700; color: var(--color-primary); margin: 4px 0; }
.reward-hero-sub { font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.reward-tip { margin: 0 var(--space-lg) var(--space-sm); font-size: var(--font-size-xs); color: var(--color-text-secondary); line-height: 1.6; }
.reward-list { padding: 0 var(--space-md); display: flex; flex-direction: column; gap: var(--space-sm); }
.reward-card { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-sm); }
.reward-card-img { width: 88px; height: 56px; object-fit: cover; border-radius: var(--radius-md); background: var(--color-bg); flex-shrink: 0; }
.reward-card-body { flex: 1; min-width: 0; }
.reward-card-title { font-size: var(--font-size-sm); color: var(--color-text-title); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.reward-card-reward { font-size: var(--font-size-sm); color: var(--color-primary); margin-top: 4px; }
.reward-card-btn { min-width: 64px; min-height: 36px; padding: 0 16px; border-radius: var(--radius-round); }
.reward-flow { margin: var(--space-md); padding: var(--space-lg); }
.reward-flow-item { display: flex; justify-content: space-between; align-items: center; padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-divider); }
.reward-flow-item:last-child { border-bottom: none; }
.reward-flow-title { font-size: var(--font-size-sm); color: var(--color-text-title); }
.reward-flow-time { font-size: var(--font-size-xs); color: var(--color-text-placeholder); margin-top: 2px; }
.reward-flow-amount { font-size: var(--font-size-md); font-weight: 600; }
.reward-flow-amount.plus { color: var(--color-success); }
.reward-flow-amount.minus { color: var(--color-danger); }

/* ---- 分销推广 ---- */
.dist-hero { margin: var(--space-md); padding: var(--space-lg); }
.dist-hero-level { display: inline-block; font-size: var(--font-size-xs); color: var(--color-primary); background: var(--color-primary-soft); border-radius: var(--radius-round); padding: 3px 10px; margin-bottom: var(--space-md); }
.dist-hero-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-md); }
.dist-stat { display: flex; flex-direction: column; gap: 4px; }
.dist-stat strong { font-size: var(--font-size-xl); color: var(--color-text-title); }
.dist-stat span { font-size: var(--font-size-xs); color: var(--color-text-secondary); }
.dist-share, .dist-withdraw { margin: var(--space-md); padding: var(--space-lg); }
.dist-code { font-size: var(--font-size-xl); font-weight: 700; letter-spacing: 2px; color: var(--color-text-title); }
.dist-link { font-size: var(--font-size-xs); color: var(--color-text-secondary); word-break: break-all; margin: var(--space-sm) 0 var(--space-md); }
.dist-actions { display: flex; gap: var(--space-sm); }
.dist-actions .btn { flex: 1; min-height: 44px; }
.dist-withdraw-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-md); font-size: var(--font-size-sm); color: var(--color-text-body); }
.dist-withdraw-row strong { font-size: var(--font-size-lg); color: var(--color-primary); }
.dist-note { font-size: var(--font-size-xs); color: var(--color-text-placeholder); margin-top: var(--space-sm); line-height: 1.6; }
.dist-login-tip { margin: var(--space-md) var(--space-lg); font-size: var(--font-size-xs); color: var(--color-text-secondary); text-align: center; }
.dist-login-link { background: none; border: none; color: var(--color-primary); cursor: pointer; font-size: var(--font-size-xs); }

/* ---- 核销中心 ---- */
.verify-page { background: var(--color-bg); min-height: 100vh; padding-bottom: calc(var(--tab-bar-height) + var(--space-xl)); }
.verify-consume, .verify-my { margin: var(--space-md); padding: var(--space-lg); }
.verify-input-row { display: flex; gap: var(--space-sm); }
.verify-input {
  flex: 1; min-height: 44px; padding: 0 var(--space-md);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg-white); color: var(--color-text-title);
  font-size: var(--font-size-md); letter-spacing: 2px; text-transform: uppercase;
}
.verify-input:focus { outline: none; border-color: var(--color-primary); }
.verify-input-row .btn { min-width: 72px; min-height: 44px; }
.verify-my .btn-block { margin-bottom: var(--space-md); }
.verify-code-item { display: flex; justify-content: space-between; align-items: center; padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-divider); }
.verify-code-item:last-child { border-bottom: none; }
.verify-code-value { font-size: var(--font-size-md); font-weight: 700; letter-spacing: 2px; color: var(--color-text-title); }
.verify-code-meta { font-size: var(--font-size-xs); color: var(--color-text-secondary); margin-top: 2px; }
.verify-status { font-size: var(--font-size-xs); padding: 2px 8px; border-radius: var(--radius-round); }
.verify-status-0 { color: var(--color-primary); background: var(--color-primary-soft); }
.verify-status-1 { color: var(--color-text-secondary); background: var(--color-bg-subtle); }
.verify-status-2 { color: var(--color-danger); background: rgba(239, 68, 68, 0.1); }
