/* ==========================================================================
   东北延边延健特产店 — 设计系统 style.css
   严格遵循 docs/design-contract.md（配色 / 字体 / yj- 命名 / header / footer）
   温暖自然质感 · 移动优先 · 系统字体 · 无外部 CDN · 内容红线合规
   断点：移动 ≤640 单列 / 平板 641–960 双列 / 桌面 ≥961 完整
   ========================================================================== */

/* --------------------------------------------------------------------------
   :root — 设计 token（来自契约 §3，原样保留）
   -------------------------------------------------------------------------- */
:root {
  /* ---- 配色 ---- */
  --color-bg: #FBF7EF;
  --color-surface: #FFFFFF;
  --color-text: #2B2521;
  --color-muted: #7A6F63;
  --color-primary: #5A3E2B;
  --color-accent: #E0A91B;
  --color-border: #E7DECF;
  --color-cool: #3FA796; /* 仅 noodles.html 局部点缀 */

  /* ---- 字体 ---- */
  --font-heading: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", "Source Han Sans SC",
    "Noto Sans CJK SC", sans-serif;
  --font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", "Source Han Sans SC",
    "Noto Sans CJK SC", sans-serif;

  /* ---- 字号尺度（rem，base 16px） ---- */
  --fs-xs: 0.8125rem;   /* 13px 标签/版权 */
  --fs-sm: 0.9375rem;   /* 15px 说明 */
  --fs-base: 1rem;      /* 16px 正文 */
  --fs-md: 1.125rem;    /* 18px 引导段 */
  --fs-lg: 1.375rem;    /* 22px 卡片标题 */
  --fs-xl: 1.75rem;     /* 28px 区块标题 */
  --fs-2xl: 2.25rem;    /* 36px hero 副标题 */
  --fs-3xl: 2.75rem;    /* 44px hero 主标题 */

  /* ---- 行高 ---- */
  --lh-tight: 1.25;     /* 标题 */
  --lh-base: 1.7;       /* 正文 */

  /* ---- 间距尺度（8px 基准） ---- */
  --space-1: 0.25rem;   /* 4px */
  --space-2: 0.5rem;    /* 8px */
  --space-3: 0.75rem;   /* 12px */
  --space-4: 1rem;      /* 16px */
  --space-5: 1.5rem;    /* 24px */
  --space-6: 2rem;      /* 32px */
  --space-7: 3rem;      /* 48px */
  --space-8: 4rem;      /* 64px */
  --space-9: 6rem;      /* 96px */

  /* ---- 内容最大宽度 ---- */
  --container-max: 1140px;  /* 主内容容器 */
  --measure-max: 68ch;      /* 长文段落可读宽度上限 */

  /* ---- 圆角 ---- */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-pill: 999px;     /* 胶囊按钮/标签 */

  /* ---- 阴影 ---- */
  --shadow-sm: 0 1px 2px rgba(43, 37, 33, 0.06);
  --shadow-md: 0 6px 18px rgba(43, 37, 33, 0.08);
  --shadow-lg: 0 16px 40px rgba(43, 37, 33, 0.12);

  /* ---- 其他 ---- */
  --header-h: 64px;         /* 固定/粘性头部高度 */
  --transition: 200ms ease;
}

/* --------------------------------------------------------------------------
   Reset / 基础
   -------------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 400;
  line-height: var(--lh-base);
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* 温暖自然质感：极淡的暖色光晕，增加可食用的柔和感 */
  background-image:
    radial-gradient(60rem 40rem at 110% -10%, rgba(224, 169, 27, 0.08), transparent 60%),
    radial-gradient(50rem 36rem at -10% 8%, rgba(90, 62, 43, 0.05), transparent 55%);
  background-attachment: fixed;
}

img,
svg {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition);
}

a:hover {
  color: var(--color-accent);
}

h1, h2, h3, h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: var(--lh-tight);
  margin: 0;
  color: var(--color-primary);
}

p {
  margin: 0;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
}

/* 深色描边在浅底上清晰，外侧稻谷金光晕在深底（footer/CTA）上也可辨 */
:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 2px;
  box-shadow: 0 0 0 6px rgba(224, 169, 27, 0.45);
  border-radius: var(--radius-sm);
}

/* --------------------------------------------------------------------------
   布局 / 容器
   -------------------------------------------------------------------------- */
.yj-container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-5);
  width: 100%;
}

.yj-section {
  padding-block: var(--space-7);
}

.yj-section--alt {
  background-color: var(--color-surface);
  border-block: 1px solid var(--color-border);
}

.yj-section__head {
  max-width: var(--measure-max);
  margin-inline: auto;
  margin-bottom: var(--space-6);
  text-align: center;
}

.yj-section__title {
  font-size: var(--fs-xl);
  color: var(--color-primary);
  /* 稻谷金小装饰下划线 */
  position: relative;
  display: inline-block;
  padding-bottom: var(--space-3);
}

.yj-section__title::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: var(--space-7);
  height: 3px;
  border-radius: var(--radius-pill);
  background: linear-gradient(90deg, var(--color-accent), #f0c451);
}

.yj-section__subtitle {
  margin-top: var(--space-4);
  font-size: var(--fs-md);
  color: var(--color-muted);
  line-height: var(--lh-base);
}

/* --------------------------------------------------------------------------
   Header / 导航
   移动优先：默认隐藏 nav，显示汉堡；≥961px 横排展开
   -------------------------------------------------------------------------- */
.yj-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: rgba(251, 247, 239, 0.92);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--color-border);
}

.yj-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: var(--header-h);
  gap: var(--space-4);
  position: relative;
}

/* 品牌 */
.yj-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-primary);
  font-family: var(--font-heading);
  font-weight: 700;
}

.yj-brand:hover {
  color: var(--color-primary);
}

.yj-brand__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  font-size: 1.25rem;
  line-height: 1;
  border-radius: var(--radius-pill);
  background: radial-gradient(circle at 30% 30%, #f5d98a, var(--color-accent));
  box-shadow: var(--shadow-sm);
}

.yj-brand__name {
  font-size: var(--fs-md);
  letter-spacing: 0.01em;
}

/* 汉堡按钮 */
.yj-nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-surface);
  transition: border-color var(--transition), background-color var(--transition);
}

.yj-nav-toggle:hover {
  border-color: var(--color-accent);
}

.yj-nav-toggle__bar {
  display: block;
  width: 1.25rem;
  height: 2px;
  border-radius: var(--radius-pill);
  background-color: var(--color-primary);
  transition: transform var(--transition), opacity var(--transition);
}

/* 展开状态时汉堡变叉（JS 同步切换 toggle 的 aria-expanded） */
.yj-nav-toggle[aria-expanded="true"] .yj-nav-toggle__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.yj-nav-toggle[aria-expanded="true"] .yj-nav-toggle__bar:nth-child(2) {
  opacity: 0;
}
.yj-nav-toggle[aria-expanded="true"] .yj-nav-toggle__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* 导航：移动端默认隐藏，.is-open 展开为竖直下拉 */
.yj-nav {
  display: none;
  position: absolute;
  top: calc(100% + 1px);
  left: 0;
  right: 0;
  background-color: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
}

.yj-nav.is-open {
  display: block;
}

.yj-nav__list {
  display: flex;
  flex-direction: column;
  padding: var(--space-3) var(--space-5);
  gap: var(--space-1);
}

.yj-nav__link {
  display: block;
  padding: var(--space-3) var(--space-3);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-weight: 500;
  transition: color var(--transition), background-color var(--transition);
}

.yj-nav__link:hover {
  color: var(--color-primary);
  background-color: var(--color-bg);
}

.yj-nav__link--active {
  color: var(--color-primary);
  background-color: rgba(224, 169, 27, 0.14);
}

.yj-nav__link--active::before {
  content: "";
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  margin-right: var(--space-2);
  border-radius: var(--radius-pill);
  background-color: var(--color-accent);
  vertical-align: middle;
}

/* --------------------------------------------------------------------------
   按钮
   -------------------------------------------------------------------------- */
.yj-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  font-family: var(--font-heading);
  font-size: var(--fs-base);
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
  transition: transform var(--transition), box-shadow var(--transition),
    background-color var(--transition), border-color var(--transition), color var(--transition);
}

.yj-btn:hover {
  transform: translateY(-2px);
}

.yj-btn:active {
  transform: translateY(0);
}

.yj-btn--primary {
  background-color: var(--color-primary);
  color: #FFFFFF;
  box-shadow: var(--shadow-sm);
}

.yj-btn--primary:hover {
  background-color: #4a3122;
  color: #FFFFFF;
  box-shadow: var(--shadow-md);
}

.yj-btn--accent {
  background-color: var(--color-accent);
  color: var(--color-text);
  box-shadow: var(--shadow-sm);
}

.yj-btn--accent:hover {
  background-color: #f0c451;
  color: var(--color-text);
  box-shadow: var(--shadow-md);
}

.yj-btn--ghost {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-border);
}

.yj-btn--ghost:hover {
  color: var(--color-primary);
  border-color: var(--color-accent);
  background-color: rgba(224, 169, 27, 0.08);
}

.yj-btn--block {
  display: flex;
  width: 100%;
}

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */
.yj-hero {
  position: relative;
  overflow: hidden;
  padding-block: var(--space-8);
  /* 温暖渐变底，承托稻谷金 */
  background:
    radial-gradient(40rem 30rem at 85% 20%, rgba(224, 169, 27, 0.16), transparent 60%),
    linear-gradient(180deg, var(--color-bg), var(--color-surface));
}

.yj-hero__inner {
  display: grid;
  gap: var(--space-7);
  align-items: center;
}

.yj-hero__title {
  font-size: var(--fs-3xl);
  color: var(--color-primary);
}

.yj-hero__subtitle {
  margin-top: var(--space-4);
  font-size: var(--fs-2xl);
  font-weight: 700;
  line-height: var(--lh-tight);
  color: var(--color-text);
}

.yj-hero__text {
  margin-top: var(--space-5);
  max-width: var(--measure-max);
  font-size: var(--fs-md);
  color: var(--color-muted);
  line-height: var(--lh-base);
}

.yj-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
}

/* Hero 媒体：纯抽象几何 / 色块装饰，禁止红线意象 */
.yj-hero__media {
  position: relative;
  min-height: 14rem;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 30% 30%, #f5d98a, var(--color-accent) 70%);
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  line-height: 1;
  isolation: isolate;
}

/* 抽象圆形 + 波浪几何装饰 */
.yj-hero__media::before {
  content: "";
  position: absolute;
  width: 9rem;
  height: 9rem;
  top: -2rem;
  right: -2rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.35);
  z-index: -1;
}

.yj-hero__media::after {
  content: "";
  position: absolute;
  width: 7rem;
  height: 7rem;
  bottom: -2.5rem;
  left: -2rem;
  border-radius: var(--radius-pill);
  background: rgba(90, 62, 43, 0.16);
  z-index: -1;
}

/* 大米页变体：更厚重的黑土暖金 */
.yj-hero--rice {
  background:
    radial-gradient(38rem 28rem at 80% 25%, rgba(224, 169, 27, 0.22), transparent 60%),
    linear-gradient(180deg, var(--color-bg), #f3ead8);
}

.yj-hero--rice .yj-hero__media {
  background: radial-gradient(circle at 35% 30%, #f5d98a, #d49a16 75%);
}

/* 冷面页变体：稻金 + 冷面青清凉点缀（仅此页） */
.yj-hero--noodles {
  background:
    radial-gradient(36rem 26rem at 18% 18%, rgba(63, 167, 150, 0.18), transparent 60%),
    radial-gradient(34rem 26rem at 86% 30%, rgba(224, 169, 27, 0.14), transparent 60%),
    linear-gradient(180deg, var(--color-bg), var(--color-surface));
}

.yj-hero--noodles .yj-hero__media {
  background:
    linear-gradient(135deg, var(--color-cool), #5cc4b3 60%, var(--color-accent));
}

/* 冷面波浪几何点缀 */
.yj-hero--noodles .yj-hero__media::before {
  background: rgba(255, 255, 255, 0.4);
}

.yj-hero--noodles .yj-hero__media::after {
  background: rgba(63, 167, 150, 0.3);
}

/* --------------------------------------------------------------------------
   网格 / 卡片 / 特性
   移动优先：默认单列；平板双列；桌面三列
   -------------------------------------------------------------------------- */
.yj-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}

/* 卡片 */
.yj-card {
  display: flex;
  flex-direction: column;
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.yj-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-accent);
}

.yj-card__media {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 9rem;
  font-size: 3.25rem;
  line-height: 1;
  background:
    radial-gradient(circle at 70% 25%, rgba(224, 169, 27, 0.28), transparent 60%),
    linear-gradient(135deg, #f7efdd, #f1e4cb);
  border-bottom: 1px solid var(--color-border);
}

.yj-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5);
  flex: 1;
}

.yj-card__title {
  font-size: var(--fs-lg);
  color: var(--color-primary);
}

.yj-card__text {
  font-size: var(--fs-base);
  color: var(--color-muted);
  line-height: var(--lh-base);
  flex: 1;
}

.yj-card__body .yj-btn {
  align-self: flex-start;
  margin-top: var(--space-2);
}

/* 特性项 */
.yj-feature {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
}

.yj-feature:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.yj-feature__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.25rem;
  height: 3.25rem;
  font-size: 1.75rem;
  line-height: 1;
  border-radius: var(--radius-md);
  background:
    radial-gradient(circle at 30% 30%, rgba(224, 169, 27, 0.3), rgba(224, 169, 27, 0.12));
  box-shadow: var(--shadow-sm);
}

.yj-feature__title {
  font-size: var(--fs-lg);
  color: var(--color-primary);
}

.yj-feature__text {
  font-size: var(--fs-base);
  color: var(--color-muted);
  line-height: var(--lh-base);
}

/* --------------------------------------------------------------------------
   产品详情辅助：prose / tag / cta
   -------------------------------------------------------------------------- */
.yj-prose {
  max-width: var(--measure-max);
  margin-inline: auto;
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  color: var(--color-text);
}

.yj-prose p {
  margin-bottom: var(--space-5);
}

.yj-prose p:last-child {
  margin-bottom: 0;
}

/* 标签 */
.yj-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  max-width: var(--measure-max);
  margin-inline: auto;
}

.yj-tag {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  background-color: var(--color-surface);
  color: var(--color-primary);
  font-size: var(--fs-sm);
  font-weight: 500;
  box-shadow: var(--shadow-sm);
}

.yj-tag::before {
  content: "";
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  margin-right: var(--space-2);
  border-radius: var(--radius-pill);
  background-color: var(--color-accent);
}

/* CTA 区块 */
.yj-cta {
  position: relative;
  overflow: hidden;
  margin-block: var(--space-7);
  padding: var(--space-8) var(--space-6);
  border-radius: var(--radius-lg);
  text-align: center;
  color: #FFFFFF;
  background:
    radial-gradient(30rem 20rem at 80% 10%, rgba(224, 169, 27, 0.4), transparent 60%),
    linear-gradient(135deg, var(--color-primary), #6e4d36);
  box-shadow: var(--shadow-lg);
}

.yj-cta__title {
  font-size: var(--fs-xl);
  color: #FFFFFF;
}

.yj-cta__text {
  max-width: var(--measure-max);
  margin: var(--space-4) auto 0;
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  color: rgba(255, 255, 255, 0.88);
}

.yj-cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
  margin-top: var(--space-6);
}

/* --------------------------------------------------------------------------
   联系页
   -------------------------------------------------------------------------- */
.yj-contact {
  max-width: var(--measure-max);
  margin-inline: auto;
}

.yj-contact__list {
  display: grid;
  gap: var(--space-4);
}

.yj-contact__item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-2) var(--space-4);
  padding: var(--space-5);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.yj-contact__label {
  min-width: 5rem;
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--color-primary);
}

.yj-contact__value {
  font-size: var(--fs-md);
  color: var(--color-text);
}

.yj-contact__note {
  margin-top: var(--space-5);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  background-color: rgba(224, 169, 27, 0.1);
  color: var(--color-muted);
  font-size: var(--fs-sm);
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.yj-footer {
  margin-top: var(--space-8);
  background-color: var(--color-primary);
  color: rgba(255, 255, 255, 0.82);
}

.yj-footer__inner {
  display: grid;
  gap: var(--space-6);
  padding-block: var(--space-7);
}

.yj-footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.yj-footer__name {
  font-family: var(--font-heading);
  font-size: var(--fs-lg);
  font-weight: 700;
  color: #FFFFFF;
}

.yj-footer__tagline {
  font-size: var(--fs-sm);
  color: rgba(255, 255, 255, 0.7);
}

.yj-footer__contact {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--fs-sm);
}

.yj-footer__contact a {
  color: var(--color-accent);
}

.yj-footer__contact a:hover {
  color: #f0c451;
}

.yj-footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-5);
}

.yj-footer__nav a {
  color: rgba(255, 255, 255, 0.82);
  font-size: var(--fs-sm);
}

.yj-footer__nav a:hover {
  color: var(--color-accent);
}

.yj-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  padding-block: var(--space-4);
  text-align: center;
}

.yj-footer__bottom small {
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.78);
}

/* --------------------------------------------------------------------------
   通用工具类
   -------------------------------------------------------------------------- */
.yj-u-center {
  text-align: center;
}

.yj-u-muted {
  color: var(--color-muted);
}

.yj-u-visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ==========================================================================
   响应式断点
   平板 641–960px：双列网格
   ========================================================================== */
@media (min-width: 641px) {
  .yj-grid--2 {
    grid-template-columns: repeat(2, 1fr);
  }

  .yj-grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .yj-hero__actions {
    margin-top: var(--space-7);
  }
}

/* ==========================================================================
   桌面 ≥961px：完整网格（三列特性区），导航横排展开，汉堡隐藏
   ========================================================================== */
@media (min-width: 961px) {
  .yj-section {
    padding-block: var(--space-8);
  }

  /* 导航横排，始终显示；隐藏汉堡 */
  .yj-nav-toggle {
    display: none;
  }

  .yj-nav {
    display: block;
    position: static;
    background-color: transparent;
    border-bottom: none;
    box-shadow: none;
  }

  .yj-nav__list {
    flex-direction: row;
    align-items: center;
    gap: var(--space-1);
    padding: 0;
  }

  .yj-nav__link {
    padding: var(--space-2) var(--space-4);
  }

  /* Hero 两栏：文案 + 媒体 */
  .yj-hero__inner {
    grid-template-columns: 1.15fr 0.85fr;
    gap: var(--space-8);
  }

  .yj-hero__media {
    min-height: 20rem;
    font-size: 5.5rem;
  }

  /* 完整网格 */
  .yj-grid--3 {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Footer 三栏 */
  .yj-footer__inner {
    grid-template-columns: 1.4fr 1fr 1fr;
    align-items: start;
    gap: var(--space-7);
  }

  .yj-footer__nav {
    flex-direction: column;
    gap: var(--space-3);
  }
}

/* 平板 hero 单列时媒体不至过高 */
@media (min-width: 641px) and (max-width: 960px) {
  .yj-hero__media {
    min-height: 16rem;
    font-size: 4.5rem;
  }
}

/* ==========================================================================
   真实产品图片接入（hero 媒体 / 卡片媒体 / 内容图）
   ========================================================================== */
/* Hero 媒体内有 <img> 时铺满媒体框（媒体框为 position:relative，min-height 给定高度） */
.yj-hero__media {
  overflow: hidden;
}

.yj-hero__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 卡片媒体内有 <img> 时按统一比例裁切，保证多卡片高度一致 */
.yj-card__media {
  overflow: hidden;
}

.yj-card__media img {
  width: 100%;
  aspect-ratio: 16 / 11;
  object-fit: cover;
}

/* 正文内的产品/产地实拍图 */
.yj-media {
  max-width: 760px;
  margin: var(--space-6) auto 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.yj-media img {
  width: 100%;
  height: auto;
}

.yj-media figcaption {
  padding: var(--space-3) var(--space-5);
  font-size: var(--fs-sm);
  color: var(--color-muted);
  text-align: center;
  background-color: var(--color-surface);
  border-top: 1px solid var(--color-border);
}

/* ==========================================================================
   跳到主内容（skip-link）：聚焦时从顶部滑入
   ========================================================================== */
.yj-skip-link {
  position: absolute;
  left: var(--space-4);
  top: -4rem;
  z-index: 200;
  padding: var(--space-3) var(--space-5);
  background-color: var(--color-primary);
  color: #ffffff;
  font-weight: 700;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  transition: top var(--transition);
}

.yj-skip-link:focus {
  top: var(--space-4);
  color: #ffffff;
}

/* ==========================================================================
   微信号一键复制按钮
   ========================================================================== */
.yj-copy-btn {
  margin-left: var(--space-3);
  padding: var(--space-1) var(--space-4);
  font-family: var(--font-heading);
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--color-primary);
  background-color: rgba(224, 169, 27, 0.16);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  transition: background-color var(--transition), border-color var(--transition), color var(--transition);
}

.yj-copy-btn:hover {
  background-color: rgba(224, 169, 27, 0.28);
  border-color: var(--color-accent);
}

.yj-copy-btn.is-copied,
.yj-btn.is-copied {
  background-color: var(--color-cool);
  border-color: var(--color-cool);
  color: #ffffff;
}

/* 尊重减少动效偏好 */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .yj-btn:hover,
  .yj-card:hover,
  .yj-feature:hover {
    transform: none;
  }
}
