/* =========================================================
   サインポスト通販：FutureShop用 カスタムCSS最適化版
   目的：
   - body / h2 / table / ul など全ページに効く指定を削除
   - 購入前の安心情報ブロックを見やすく装飾
   - カテゴリーページ簡易版にも背景・枠・リンク色を適用
   - FutureShop本体レイアウトへの影響を最小化
========================================================= */

/* =========================================================
   1. サインポスト共通カラー
========================================================= */
:root {
  --sp-color-text: #3f342d;
  --sp-color-muted: #62554d;
  --sp-color-brown: #8a5a32;
  --sp-color-brown-dark: #6f4523;
  --sp-color-accent: #c98d58;
  --sp-color-bg: #fff8f1;
  --sp-color-bg-2: #f8efe6;
  --sp-color-border: #ead8c8;
  --sp-color-link: #006f9f;
  --sp-color-link-dark: #004e73;
  --sp-color-line: #06c755;
  --sp-color-white: #ffffff;
}

/* =========================================================
   2. トップページ・共通：購入前の安心情報ブロック
   対象HTML class：sp-purchase-trust-v2
========================================================= */
.sp-purchase-trust-v2 {
  margin: 32px auto;
  padding: 0 14px;
  font-family: inherit;
  color: var(--sp-color-text);
}

.sp-purchase-trust-v2 * {
  box-sizing: border-box;
}

.sp-purchase-trust-v2__inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 30px 24px;
  background: linear-gradient(135deg, #fff8f1 0%, #f8efe6 48%, #f2e5d8 100%);
  border: 1px solid var(--sp-color-border);
  border-radius: 18px;
  box-shadow: 0 8px 24px rgba(92, 69, 51, 0.08);
}

.sp-purchase-trust-v2__eyebrow {
  display: inline-block;
  margin: 0 0 10px;
  padding: 6px 14px;
  color: var(--sp-color-brown);
  background: var(--sp-color-white);
  border: 1px solid #e6c9ad;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.04em;
}

.sp-purchase-trust-v2__title {
  margin: 0 0 12px;
  color: #4a3327;
  font-size: clamp(22px, 3vw, 30px);
  line-height: 1.45;
  font-weight: 800;
}

.sp-purchase-trust-v2__lead {
  margin: 0 0 22px;
  color: #5f5149;
  font-size: 15px;
  line-height: 1.9;
}

.sp-purchase-trust-v2__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0;
}

.sp-purchase-trust-v2__card {
  position: relative;
  padding: 20px 18px 18px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid #ecdccc;
  border-radius: 16px;
  box-shadow: 0 4px 14px rgba(92, 69, 51, 0.06);
}

.sp-purchase-trust-v2__card::before {
  content: "";
  display: block;
  width: 42px;
  height: 4px;
  margin-bottom: 12px;
  background: var(--sp-color-accent);
  border-radius: 999px;
}

.sp-purchase-trust-v2__card-title {
  margin: 0 0 8px;
  color: #4f3527;
  font-size: 16px;
  line-height: 1.55;
  font-weight: 800;
}

.sp-purchase-trust-v2__card p {
  margin: 0 0 10px;
  color: var(--sp-color-muted);
  font-size: 14px;
  line-height: 1.8;
}

.sp-purchase-trust-v2__card p:last-child {
  margin-bottom: 0;
}

/* 本文内リンク：青＋下線で視認性を上げる */
.sp-purchase-trust-v2 a {
  color: var(--sp-color-link) !important;
  font-weight: 700;
  text-decoration: underline !important;
  text-underline-offset: 3px;
}

.sp-purchase-trust-v2 a:hover {
  color: var(--sp-color-link-dark) !important;
  text-decoration-thickness: 2px;
}

/* 下部リンク：ボタン表示 */
.sp-purchase-trust-v2__button-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid rgba(143, 102, 69, 0.22);
}

.sp-purchase-trust-v2__button-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 15px;
  color: var(--sp-color-white) !important;
  background: var(--sp-color-brown);
  border: 1px solid var(--sp-color-brown);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.4;
  text-decoration: none !important;
  box-shadow: 0 4px 10px rgba(92, 69, 51, 0.12);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.sp-purchase-trust-v2__button-links a:hover {
  color: var(--sp-color-white) !important;
  background: var(--sp-color-brown-dark);
  border-color: var(--sp-color-brown-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(92, 69, 51, 0.18);
}

.sp-purchase-trust-v2__button-links a.sp-purchase-trust-v2__line,
.sp-purchase-trust-v2__button-links a[href*="lin.ee"] {
  background: var(--sp-color-line);
  border-color: var(--sp-color-line);
}

.sp-purchase-trust-v2__button-links a.sp-purchase-trust-v2__line:hover,
.sp-purchase-trust-v2__button-links a[href*="lin.ee"]:hover {
  background: #05a947;
  border-color: #05a947;
}

.sp-purchase-trust-v2__note {
  margin: 18px 0 0;
  padding: 13px 15px;
  color: #5b4e46;
  background: #fffdf9;
  border-left: 5px solid var(--sp-color-accent);
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.8;
}

/* =========================================================
   3. カテゴリーページ用：購入前の安心情報ブロック 簡易版
   対象HTML class：sp-category-trust
========================================================= */
.sp-category-trust {
  max-width: 1120px;
  margin: 24px auto 28px;
  padding: 22px 20px;
  color: var(--sp-color-text);
  background: linear-gradient(135deg, #fffaf5 0%, #f8efe6 100%);
  border: 1px solid var(--sp-color-border);
  border-radius: 16px;
  box-shadow: 0 6px 18px rgba(92, 69, 51, 0.07);
}

.sp-category-trust * {
  box-sizing: border-box;
}

.sp-category-trust h2,
.sp-category-trust__title {
  margin: 0 0 12px;
  color: #4a3327;
  font-size: clamp(19px, 2.5vw, 24px);
  line-height: 1.45;
  font-weight: 800;
}

.sp-category-trust__lead {
  margin: 0 0 14px;
  color: #5f5149;
  font-size: 14px;
  line-height: 1.8;
}

.sp-category-trust__list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
}

.sp-category-trust__list li {
  position: relative;
  margin: 0;
  padding: 12px 12px 12px 40px;
  min-height: 48px;
  color: var(--sp-color-muted);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid #ecdccc;
  border-radius: 12px;
  font-size: 14px;
  line-height: 1.75;
}

.sp-category-trust__list li::before {
  content: "✓";
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  color: var(--sp-color-white);
  background: var(--sp-color-accent);
  border-radius: 50%;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
}

.sp-category-trust__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0 0;
  padding-top: 16px;
  border-top: 1px solid rgba(143, 102, 69, 0.2);
}

.sp-category-trust__links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 13px;
  color: var(--sp-color-white) !important;
  background: var(--sp-color-brown);
  border: 1px solid var(--sp-color-brown);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.4;
  text-decoration: none !important;
  box-shadow: 0 3px 8px rgba(92, 69, 51, 0.1);
}

.sp-category-trust__links a:hover {
  color: var(--sp-color-white) !important;
  background: var(--sp-color-brown-dark);
  border-color: var(--sp-color-brown-dark);
}

.sp-category-trust__links a[href*="lin.ee"] {
  background: var(--sp-color-line);
  border-color: var(--sp-color-line);
}

.sp-category-trust__links a[href*="lin.ee"]:hover {
  background: #05a947;
  border-color: #05a947;
}

/* 旧HTMLの p.sp-category-trust__links に「／」が残っている場合の崩れを軽減 */
p.sp-category-trust__links {
  line-height: 2.4;
}

/* =========================================================
   4. 旧版の購入前安心ブロックが残っている場合の最低限補正
   対象HTML class：sp-purchase-trust
========================================================= */
.sp-purchase-trust {
  margin: 32px auto;
  padding: 28px 18px;
  color: var(--sp-color-text);
  background: linear-gradient(135deg, #fff8f1 0%, #f8efe6 100%);
  border: 1px solid var(--sp-color-border);
  border-radius: 16px;
}

.sp-purchase-trust * {
  box-sizing: border-box;
}

.sp-purchase-trust__inner {
  max-width: 1120px;
  margin: 0 auto;
}

.sp-purchase-trust__eyebrow {
  display: inline-block;
  margin: 0 0 8px;
  padding: 5px 12px;
  color: var(--sp-color-brown);
  background: var(--sp-color-white);
  border: 1px solid #e6c9ad;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}

.sp-purchase-trust__title {
  margin: 0 0 12px;
  color: #4a3327;
  font-size: 24px;
  line-height: 1.4;
  font-weight: 800;
}

.sp-purchase-trust__lead {
  margin: 0 0 20px;
  color: #5f5149;
  line-height: 1.8;
}

.sp-purchase-trust__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.sp-purchase-trust__card {
  padding: 18px;
  background: var(--sp-color-white);
  border: 1px solid #ecdccc;
  border-radius: 12px;
}

.sp-purchase-trust__card-title {
  margin: 0 0 8px;
  color: #4f3527;
  font-size: 16px;
  line-height: 1.45;
  font-weight: 800;
}

.sp-purchase-trust__card p {
  margin: 0 0 8px;
  color: var(--sp-color-muted);
  line-height: 1.75;
}

.sp-purchase-trust__card p:last-child {
  margin-bottom: 0;
}

.sp-purchase-trust__links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.sp-purchase-trust__links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 13px;
  color: var(--sp-color-white) !important;
  background: var(--sp-color-brown);
  border: 1px solid var(--sp-color-brown);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none !important;
}

/* =========================================================
   5. 商品一覧：会員価格の表示調整
   FutureShop商品一覧にだけ効くように限定
========================================================= */
.fs-c-productListItem .fs-c-productPrice {
  display: block;
  margin: 0;
  text-align: center;
  line-height: 1.5;
}

.fs-c-productListItem .fs-c-productPrice + .fs-c-productPrice {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #d8d1ca;
}

.fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__main {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__main__label {
  display: inline-block !important;
  padding: 0 !important;
  margin: 0 !important;
  background: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4;
  color: #6f675f !important;
}

.fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__main__price,
.fs-c-productListItem .fs-c-productPrice .fs-c-price__value,
.fs-c-productListItem .fs-c-productPrice .fs-c-price__currencyMark {
  font-size: 22px;
  line-height: 1.2;
  font-weight: 500;
  color: #222 !important;
}

.fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__addon {
  display: inline-block;
  margin-left: 4px;
}

.fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__addon__label {
  font-size: 14px;
  line-height: 1.4;
  color: #6f675f;
}

.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__main__price,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-price__value,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-price__currencyMark {
  color: #b98780 !important;
}

/* 緑の「会員価格対象」等、FutureShop側の補助ラベルを非表示 */
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__memberPriceLabel,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__memberPriceLabel *,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__label,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__label *,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__notice,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__notice *,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__text,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__text *,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__message,
.fs-c-productListItem .fs-c-productPrice--member .fs-c-productPrice__message * {
  display: none !important;
}

.fs-c-productListItem .fs-c-productPrice--member::after {
  content: "※ログインで適用";
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.4;
  color: #7c746c;
}

/* =========================================================
   6. 横スクロール・動画・Instagramなど、使用中パーツのみ維持
========================================================= */
.side-scroll {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  margin: 0 auto;
}

.side-scroll-container {
  display: flex;
  flex-wrap: nowrap;
  gap: 16px;
}

.side-scroll-box {
  flex: 0 0 auto;
  width: 200px;
  box-sizing: border-box;
}

.side-scroll-box .img img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 4px;
  background: #eee;
}

.side-scroll-box p {
  margin: 6px 0 0;
  font-size: 14px;
  line-height: 1.6;
  text-align: center;
}

.bgListBox {
  background: #f0f8ff;
  border: 1px solid #b0c4de;
  border-radius: 10px;
  padding: 10px 15px;
  margin: 10px 0;
}

.bgListBox ul,
.bgListBox ol {
  margin: 0 0 0 20px;
  padding: 0;
}

.listing {
  list-style-type: disc;
}

/* 表は table 全体ではなく、table-wrap 内だけに限定 */
.table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.table-wrap table {
  width: 100%;
  min-width: 640px;
  border: 1px solid #d8d1ca;
  border-collapse: collapse;
  margin-bottom: 20px;
  table-layout: fixed;
}

.table-wrap table th,
.table-wrap table td {
  border: 1px solid #d8d1ca;
  padding: 8px;
  word-wrap: break-word;
  vertical-align: top;
  line-height: 1.7;
}

.table-wrap table th {
  background: #f8efe6;
  font-weight: 700;
}

.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.youtube iframe {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  border: 0;
}

.instagram-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.instagram-media {
  flex: 1 1 350px;
  max-width: 450px;
}

/* =========================================================
   7. 任意：フリーページ本文だけに見出し・表装飾を効かせたい場合
   親要素に class="sp-free-content" を付けた時だけ有効
========================================================= */
.sp-free-content {
  line-height: 1.9;
  color: var(--sp-color-text);
}

.sp-free-content h2,
.sp-free-content h3 {
  color: #222;
  margin-top: 0;
  line-height: 1.5;
}

.sp-free-content h3 {
  font-weight: 700;
}

.sp-free-content ul,
.sp-free-content ol {
  margin: 0 0 1em 1.4em;
  padding: 0;
}

.sp-free-content strong {
  font-weight: 700 !important;
  color: #000;
}

.sp-free-content .highlight {
  color: #d6336c;
  font-weight: 700;
}

.sp-free-content .section {
  margin-bottom: 20px;
  padding: 15px;
  border-radius: 8px;
}

.sp-free-content .section1 { background-color: #fef9f3; }
.sp-free-content .section2 { background-color: #f4f9f0; }
.sp-free-content .section3 { background-color: #f3f9fe; }
.sp-free-content .section4 { background-color: #f9f3fe; }
.sp-free-content .section5 { background-color: #fef3f9; }
.sp-free-content .section6 { background-color: #f3fef9; }
.sp-free-content .section7 { background-color: #fff9f3; }

.sp-free-content .footer {
  font-style: italic;
  text-align: center;
  margin-top: 20px;
}

/* =========================================================
   8. スマホ調整
========================================================= */
@media screen and (max-width: 900px) {
  .sp-purchase-trust-v2__grid,
  .sp-purchase-trust__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sp-category-trust__list {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .sp-purchase-trust-v2 {
    margin: 24px auto;
    padding: 0 10px;
  }

  .sp-purchase-trust-v2__inner {
    padding: 24px 16px;
    border-radius: 16px;
  }

  .sp-purchase-trust-v2__grid,
  .sp-purchase-trust__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .sp-purchase-trust-v2__button-links,
  .sp-purchase-trust__links,
  .sp-category-trust__links {
    display: grid;
    grid-template-columns: 1fr;
  }

  .sp-purchase-trust-v2__button-links a,
  .sp-purchase-trust__links a,
  .sp-category-trust__links a {
    width: 100%;
  }

  .sp-category-trust {
    margin: 20px auto 24px;
    padding: 20px 14px;
    border-radius: 14px;
  }

  .sp-category-trust__list li {
    padding: 12px 12px 12px 38px;
    font-size: 13px;
  }

  .fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__main__label {
    font-size: 12px;
  }

  .fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__main__price,
  .fs-c-productListItem .fs-c-productPrice .fs-c-price__value,
  .fs-c-productListItem .fs-c-productPrice .fs-c-price__currencyMark {
    font-size: 19px;
  }

  .fs-c-productListItem .fs-c-productPrice .fs-c-productPrice__addon__label {
    font-size: 12px;
  }

  .fs-c-productListItem .fs-c-productPrice--member::after {
    font-size: 11px;
  }
}
