/* ==========================================================================
   「鶏と生姜のまぜる釜めしの素」キャンペーンページ専用
   情緒演出セクション用 追加CSS
   ========================================================================== */
.fs-p-productDescription {
  --su-wine: #6b1f2a;
  --su-wine-light: #8b2c3a;
  --su-cream: #f6efe3;
  --su-gold: #d7a35a;
  --su-text: #333;
  --su-muted: #666;
  --su-border: #e8e1d6;
}
/* ---------- 共通：明朝の見出し（書道風） ---------- */
.fs-p-productDescription .su-section__title--script {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  letter-spacing: 0.12em;
}
.fs-p-productDescription .su-section__title--script span::after {
  content: "";
  display: block;
  width: 36px;
  height: 1px;
  background: var(--su-gold);
  margin: 14px auto 0;
}

/* ---------- ヒーロー（縦書きキャッチ＋シズル画像） ---------- */
.fs-p-productDescription .su-hero--vertical {
  position: relative;
  padding: 0;
  background: #0e0e10;
  border-radius: 12px;
  overflow: hidden;
  color: #fff;
  text-align: left;
}
/* シズル画像コンテナ：固定アスペクト比＋オーバーフロー隠し */
.fs-p-productDescription .su-hero--vertical .su-hero__media {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: #000;
  overflow: hidden;
}
@supports not (aspect-ratio: 1 / 1) {
  .fs-p-productDescription .su-hero--vertical .su-hero__media {
    height: 0;
    padding-top: 100%;
  }
}
/* シズル画像：object-fit + object-position + !important で確実にトリミング
   ※ バッジ画像（.su-mediaBadge）は除外し、シズル写真のみに適用
   ※ object-position: center 70% で被写体（茶碗）をフレーム上方に寄せる
     （フレーム/写真自体は動かさず、トリミング窓内の見え方だけ調整） */
.fs-p-productDescription .su-hero--vertical .su-hero__media > img:not(.su-mediaBadge) {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center 70% !important;
  display: block !important;
  opacity: 1;
}
/* ---------- 写真下の横書きキャッチコピー ---------- */
.fs-p-productDescription .su-hero__caption {
  background: #0e0e10;
  color: #fff;
  text-align: center;
  padding: 22px 16px 26px;
}
.fs-p-productDescription .su-hero__captionCopy {
  margin: 0 0 10px;
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: #fff;
}
.fs-p-productDescription .su-hero__captionCopy span {
  display: inline-block;
  margin-left: 0.2em;
  color: var(--su-gold);
  font-size: 1.2em;
  font-weight: 700;
  letter-spacing: 0.12em;
}
.fs-p-productDescription .su-hero__captionBrand {
  margin: 0;
  color: var(--su-gold);
  font-size: 12px;
  letter-spacing: 0.25em;
  font-family: "Yu Mincho", serif;
}
.fs-p-productDescription .su-hero__tag {
  position: absolute;
  left: 14px;
  bottom: 14px;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-family: "Yu Mincho", serif;
  background: rgba(20, 20, 20, 0.72);
  border-left: 2px solid var(--su-gold);
  color: #fff;
  font-size: 18px;
  letter-spacing: 0.18em;
  padding: 10px 8px;
}

/*ここをPCのみにしたい*/
@media (min-width: 992px) {
  .fs-p-productDescription .su-hero__tag {
    position: absolute;
    right: 14px;
    top: 14px;
    left: auto;
    bottom: auto;
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-family: "Yu Mincho", serif;
    background: rgba(20, 20, 20, 0.72);
    border-left: 2px solid var(--su-gold);
    color: #fff;
    font-size: 35px;
    letter-spacing: 0.18em;
    padding: 55px 18px 55px 10px;
  }
}
/*ここまで*/
.fs-p-productDescription .su-hero__tag small {
  display: block;
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: 0.15em;
  color: var(--su-cream);
}

/* ---------- RCC「元就。」太鼓判バッジ（画像版） ---------- */
.fs-p-productDescription .su-mediaBadge {
  position: absolute;
  top: 16px;
  left: 16px;
  width: 110px;
  height: 110px;
  max-width: none;
  z-index: 2;
  object-fit: contain;
  transform: rotate(-8deg);
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.35));
  pointer-events: none;
}

/* ---------- ブランドリード（情緒コピー） ---------- */
.fs-p-productDescription .su-lead {
  margin: 28px 0;
  padding: 28px 20px;
  text-align: center;
  background:
    linear-gradient(180deg, #fdfaf2 0%, #f7eedd 100%);
  border-radius: 12px;
  position: relative;
}
.fs-p-productDescription .su-lead::before,
.fs-p-productDescription .su-lead::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 1px;
  background: var(--su-gold);
}
.fs-p-productDescription .su-lead::before { top: 14px; }
.fs-p-productDescription .su-lead::after { bottom: 14px; }
.fs-p-productDescription .su-lead__copy {
  font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  font-size: 18px;
  line-height: 2;
  color: var(--su-wine);
  margin: 0 0 16px;
  letter-spacing: 0.05em;
}
.fs-p-productDescription .su-lead__hl {
  color: var(--su-gold);
  font-weight: 700;
  border-bottom: 1px dotted var(--su-gold);
}
.fs-p-productDescription .su-lead__sub {
  margin: 0;
  font-family: "Yu Mincho", serif;
  font-size: 14px;
  line-height: 2;
  color: var(--su-text);
  letter-spacing: 0.05em;
}

/* ---------- こだわりの広島素材（その1／その2 ストーリーカード） ---------- */
.fs-p-productDescription .su-materials {
  background:
    linear-gradient(180deg, #f4ead4 0%, #e8dcbe 100%);
  padding: 32px 16px 28px;
  border-radius: 12px;
  margin: 28px 0;
}
.fs-p-productDescription .su-materials .su-section__title {
  color: #6a4912;
}
.fs-p-productDescription .su-material {
  position: relative;
  background: #fff;
  border-radius: 14px;
  padding: 24px 20px;
  margin: 24px 0;
  box-shadow: 0 4px 18px rgba(80, 50, 0, 0.08);
}
.fs-p-productDescription .su-material__no {
  position: absolute;
  top: -22px;
  z-index: 3; /* 画像の上に重ねる */
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #e9d8b3;
  color: #6a4912;
  font-family: "Yu Mincho", serif;
  font-size: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 10px rgba(80, 50, 0, 0.18);
}
.fs-p-productDescription .su-material__no em {
  font-style: normal;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  margin-top: 2px;
}
.fs-p-productDescription .su-material--left .su-material__no  { left: 16px; }
.fs-p-productDescription .su-material--right .su-material__no { right: 16px; }
.fs-p-productDescription .su-material__img {
  position: relative;
  margin: 8px 0 18px;
  border-radius: 12px;
  overflow: hidden;
  background: #f0e6cd;
  aspect-ratio: 16 / 10;
}
@supports not (aspect-ratio: 16 / 10) {
  .fs-p-productDescription .su-material__img {
    height: 0;
    padding-top: 62.5%;
  }
}
.fs-p-productDescription .su-material__img > img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}
.fs-p-productDescription .su-material__title {
  font-family: "Yu Mincho", serif;
  font-size: 22px;
  letter-spacing: 0.08em;
  color: var(--su-wine);
  margin: 0 0 8px;
  line-height: 1.4;
}
.fs-p-productDescription .su-material__lead {
  font-family: "Yu Mincho", serif;
  font-size: 14px;
  color: var(--su-gold);
  margin: 0 0 12px;
  letter-spacing: 0.06em;
}
.fs-p-productDescription .su-material__desc {
  font-size: 14px;
  line-height: 2;
  color: var(--su-text);
  margin: 0;
}
.fs-p-productDescription .su-material__hl {
  color: var(--su-wine);
  font-weight: 700;
}
.fs-p-productDescription .su-materials__footnote {
  margin: 24px 0 0;
  text-align: center;
  font-family: "Yu Mincho", serif;
  font-size: 13px;
  color: #6a4912;
  line-height: 1.9;
  letter-spacing: 0.05em;
}

/* ---------- お召し上がり方 ---------- */
.fs-p-productDescription .su-howto__main {
  background: #fff;
  border: 1px solid var(--su-border);
  border-radius: 14px;
  padding: 16px;
  margin: 16px 0 22px;
}
.fs-p-productDescription .su-howto__img {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 16px;
  aspect-ratio: 16 / 9;
  background: #f0e6cd;
}
@supports not (aspect-ratio: 16 / 9) {
  .fs-p-productDescription .su-howto__img {
    height: 0;
    padding-top: 56.25%;
  }
}
.fs-p-productDescription .su-howto__img > img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}
.fs-p-productDescription .su-howto__lead {
  font-family: "Yu Mincho", serif;
  font-size: 17px;
  line-height: 1.8;
  margin: 0 0 14px;
  color: var(--su-wine);
}
.fs-p-productDescription .su-howto__yield {
  margin: 0 0 14px;
  text-align: center;
}
.fs-p-productDescription .su-howto__yield span {
  display: inline-block;
  padding: 6px 18px;
  background: var(--su-wine);
  color: #fff;
  font-family: "Yu Mincho", serif;
  letter-spacing: 0.12em;
  border-radius: 999px;
  font-size: 14px;
}
.fs-p-productDescription .su-howto__note {
  margin: 0;
  font-size: 13px;
  line-height: 1.9;
  color: var(--su-muted);
}
.fs-p-productDescription .su-howto__variations {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.fs-p-productDescription .su-howto__variations li {
  background: #fff;
  border: 1px solid var(--su-border);
  border-left: 4px solid var(--su-gold);
  border-radius: 6px;
  padding: 14px 16px;
}
.fs-p-productDescription .su-howto__variations li h4 {
  margin: 0 0 4px;
  font-family: "Yu Mincho", serif;
  font-size: 16px;
  color: var(--su-wine);
  letter-spacing: 0.06em;
}
.fs-p-productDescription .su-howto__variations li p {
  margin: 0;
  font-size: 13px;
  line-height: 1.8;
  color: var(--su-text);
}
.fs-p-productDescription .su-howto__vIcon {
  display: none;
}

/* ---------- ブランドストーリー ---------- */
.fs-p-productDescription .su-story {
  background:
    radial-gradient(ellipse at top, #fdfaf2 0%, #f3ead4 100%);
  border-radius: 12px;
  padding: 28px 16px;
}
.fs-p-productDescription .su-story__img {
  position: relative;
  margin: 0 0 18px;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: #f0e6cd;
}
@supports not (aspect-ratio: 16 / 9) {
  .fs-p-productDescription .su-story__img {
    height: 0;
    padding-top: 56.25%;
  }
}
.fs-p-productDescription .su-story__img > img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  filter: sepia(0.05) saturate(0.95);
}
.fs-p-productDescription .su-story__body p {
  font-family: "Yu Mincho", serif;
  font-size: 14px;
  line-height: 2;
  color: var(--su-text);
  margin: 0 0 14px;
  letter-spacing: 0.04em;
  text-align: center;
}
.fs-p-productDescription .su-story__sign {
  text-align: right !important;
  color: var(--su-wine);
  font-size: 13px !important;
  letter-spacing: 0.1em;
  margin-top: 10px !important;
}

/* ---------- PC（min-width: 992px） ---------- */
@media (min-width: 992px) {
  .fs-p-productDescription .su-hero--vertical .su-hero__media {
    aspect-ratio: 4 / 3;
  }
  @supports not (aspect-ratio: 4 / 3) {
    .fs-p-productDescription .su-hero--vertical .su-hero__media {
      padding-top: 75%;
    }
  }
  .fs-p-productDescription .su-hero__caption {
    padding: 32px 24px 36px;
  }
  .fs-p-productDescription .su-hero__captionCopy {
    font-size: 26px;
    letter-spacing: 0.1em;
  }
  .fs-p-productDescription .su-hero__captionBrand {
    font-size: 14px;
    letter-spacing: 0.3em;
    margin-top: 4px;
  }
  .fs-p-productDescription .su-mediaBadge {
    width: 140px;
    height: 140px;
    top: 24px;
    left: 24px;
  }

  .fs-p-productDescription .su-lead {
    padding: 40px 24px;
  }
  .fs-p-productDescription .su-lead__copy {
    font-size: 24px;
  }
  .fs-p-productDescription .su-lead__sub {
    font-size: 16px;
  }

  .fs-p-productDescription .su-materials {
    padding: 48px 24px 40px;
  }
  .fs-p-productDescription .su-material {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    align-items: stretch; /* テキスト列の高さに画像を合わせる */
    padding: 32px;
  }
  .fs-p-productDescription .su-material--right {
    direction: rtl;
  }
  .fs-p-productDescription .su-material--right > * {
    direction: ltr;
  }
  /* PC：画像エリアはアスペクト比解除＋テキスト列の高さいっぱいに伸ばす */
  .fs-p-productDescription .su-material__img {
    margin: 0;
    aspect-ratio: auto;
    height: 100%;
    min-height: 220px;
  }
  @supports not (aspect-ratio: 16 / 10) {
    .fs-p-productDescription .su-material__img {
      padding-top: 0;
    }
  }
  /* テキスト列は中央寄せで配置（伸ばされた領域内で中央配置） */
  .fs-p-productDescription .su-material__body {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .fs-p-productDescription .su-material__title {
    font-size: 28px;
  }
  .fs-p-productDescription .su-material__lead {
    font-size: 16px;
  }
  .fs-p-productDescription .su-material__desc {
    font-size: 15px;
  }

  .fs-p-productDescription .su-howto__main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    align-items: stretch; /* テキスト列の高さに画像を合わせる */
    padding: 28px;
  }
  .fs-p-productDescription .su-howto__img {
    margin: 0;
    aspect-ratio: auto;
    height: 100%;
    min-height: 240px;
  }
  @supports not (aspect-ratio: 16 / 9) {
    .fs-p-productDescription .su-howto__img {
      padding-top: 0;
    }
  }
  .fs-p-productDescription .su-howto__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .fs-p-productDescription .su-howto__lead {
    font-size: 22px;
  }
  .fs-p-productDescription .su-howto__variations {
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }

  .fs-p-productDescription .su-story {
    padding: 48px 32px;
  }
  .fs-p-productDescription .su-story__inner {
    display: grid;
    grid-template-columns: 5fr 6fr;
    gap: 36px;
    align-items: stretch; /* テキスト列の高さに画像を合わせる */
  }
  .fs-p-productDescription .su-story__img {
    margin: 0;
    aspect-ratio: auto;
    height: 100%;
    min-height: 240px;
  }
  @supports not (aspect-ratio: 16 / 9) {
    .fs-p-productDescription .su-story__img {
      padding-top: 0;
    }
  }
  .fs-p-productDescription .su-story__body {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .fs-p-productDescription .su-story__body p {
    font-size: 16px;
    text-align: left;
  }
}