@charset "UTF-8";

/* =====================================================
   birthflower LP（想いを届ける花選び）
   基本設定・色変数
   ※ヘッダー（グローバルナビ）は既存のため本CSSには含めない
===================================================== */
#birthflower-lp {
  --bf-bg: #fdf3f5;
  /* 必要な箇所で使う淡いピンク背景 */
  --bf-bg-2: #fbeef1;
  /* セクション区切りの淡ピンク */
  --bf-white: #ffffff;
  --bf-pink-wash: #fbe9ed;
  /* ヒーローの水彩ピンク */
  --bf-main: #d6557a;
  /* メインのローズ（CTA・リンク） */
  --bf-main-dark: #c03c64;
  /* 濃いローズ（ホバー等） */
  --bf-text: #4d4543;
  /* 本文テキスト */
  --bf-subtext: #5e5a58;
  /* 補足テキスト */
  --bf-muted: #9a8f8c;
  /* 薄いテキスト */
  --bf-line: #f0dde2;
  /* 罫線・カード枠 */
  /* 月ごとのテーマカラー（バッジ・テーマ見出し・ブレット・タグ） */
  --m1: #d9411f;
  --m1-bg: #fbe8e2;
  /* 1月 正月：赤 */
  --m2: #1f6fa3;
  --m2-bg: #e5f0f7;
  /* 2月：青 */
  --m3: #e96f75;
  --m3-bg: #fde8ea;
  /* 3月 桜：ピンク */
  --m4: #78aa1d;
  --m4-bg: #edf5dd;
  /* 4月 春・新芽：黄緑 */
  --m5: #2aa69b;
  --m5-bg: #e1f4f2;
  /* 5月：青緑 */
  --m6: #9b3f93;
  --m6-bg: #f3e5f1;
  /* 6月 梅雨・あじさい：紫 */
  --m7: #35a5d8;
  --m7-bg: #e3f3fb;
  /* 7月 海：水色 */
  --m8: #e9861a;
  --m8-bg: #fdf0df;
  /* 8月 太陽・真夏：オレンジ */
  --m9: #2f7329;
  --m9-bg: #e5f0e3;
  /* 9月：深緑 */
  --m10: #b68708;
  --m10-bg: #f7efd9;
  /* 10月：黄土 */
  --m11: #8b431f;
  --m11-bg: #f1e5df;
  /* 11月 紅葉：茶 */
  --m12: #50519f;
  --m12-bg: #e8e8f4;
  /* 12月：青紫 */
  --bf-width: 956px;
  /* コンテンツ最大幅 */
  --bf-pad: 50px;
  --bf-pad-sp: 20px;
  color: var(--bf-text);
  font-family: "Noto Sans JP", "Hiragino Sans", "ヒラギノ角ゴ ProN", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 15px;
  line-height: 1.9;
  letter-spacing: 0.02em;
  background: var(--bf-white);
  max-width: var(--bf-width);
  margin: 0 auto;
}

#birthflower-lp *,
#birthflower-lp *::before,
#birthflower-lp *::after {
  box-sizing: border-box;
}

#birthflower-lp img {
  display: block;
  max-width: 100%;
  height: auto;
}

#birthflower-lp a {
  color: inherit;
  text-decoration: none;
}

#birthflower-lp p {
  margin: 0 0 1em;
}

#birthflower-lp p:last-child {
  margin-bottom: 0;
}

/* =====================================================
   レイアウト共通
===================================================== */
#birthflower-lp .bf-inner {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 64px var(--bf-pad);
}

#birthflower-lp .bf-section--bg2 {
  background: var(--bf-bg-2);
}

#birthflower-lp .bf-section--white {
  background: var(--bf-white);
}

/* セクション大見出し */
#birthflower-lp .bf-h2 {
  margin: 0 0 12px;
  color: var(--bf-text);
  font-size: 30px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

/* セクションリード文 */
#birthflower-lp .bf-lead {
  margin: 0 0 36px;
  color: var(--bf-subtext);
  font-size: 15px;
  line-height: 2;
}

/* 共通CTAボタン（塗り） */
#birthflower-lp .bf-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 30px;
  border-radius: 999px;
  background: var(--bf-main);
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.04em;
  box-shadow: 0 6px 16px rgba(214, 85, 122, 0.25);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

#birthflower-lp .bf-btn::after {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.25) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='12' viewBox='0 0 8 12'%3E%3Cpath d='M1 1l5 5-5 5' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") calc(50% + 1px) center / 9px no-repeat;
}

#birthflower-lp .bf-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(214, 85, 122, 0.32);
}

/* 共通CTAボタン（白抜き・枠線） */
#birthflower-lp .bf-btn--outline {
  background: #fff;
  color: var(--bf-main);
  border: 1.5px solid var(--bf-main);
  box-shadow: none;
}

#birthflower-lp .bf-btn--outline::after {
  background: var(--bf-main) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='12' viewBox='0 0 8 12'%3E%3Cpath d='M1 1l5 5-5 5' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") calc(50% + 1px) center / 9px no-repeat;
}

/* =====================================================
   01. ヒーロー（想いを届ける花選び）
   PC：左にテキスト、右に今月の誕生花カード
   SP：縦並びにして、読みやすさを優先
===================================================== */
/* ヒーロー全体：背景画像を敷く */
#birthflower-lp .bf-hero {
  background:
    url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-hero-bg_pink.jpg") center / cover no-repeat,
    var(--bf-pink-wash);
}

/* ヒーロー内側：左を広めにした2カラム */
#birthflower-lp .bf-hero__inner {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 50px var(--bf-pad) 52px;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 0.95fr);
  gap: 34px;
  align-items: center;
}

/* 左側テキスト */
#birthflower-lp .bf-hero__text {
  position: relative;
  text-align: center;
}

/* メインタイトル */
#birthflower-lp .bf-hero__title {
  margin: 0 0 14px;
  color: #923752;
  font-family: "Shippori Mincho", "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-size: 54px;
  font-weight: 600;
  line-height: 1.42;
  letter-spacing: 0.05em;
  text-align: center;
}

/* タイトル〜サブコピー全体の左右に花あしらいを配置 */
#birthflower-lp .bf-hero__text::before,
#birthflower-lp .bf-hero__text::after {
  content: "";
  position: absolute;
  top: 10px;
  width: 140px;
  height: 215px;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  pointer-events: none;
}

/* 左側の花あしらい */
#birthflower-lp .bf-hero__text::before {
  left: 10px;
  background-image: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-hero-point_l.png");
}

/* 右側の花あしらい */
#birthflower-lp .bf-hero__text::after {
  right: 10px;
  background-image: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-hero-point_r.png");
}

/* サブコピー */
#birthflower-lp .bf-hero__subtitle {
  margin: 0 0 28px;
  color: #923752;
  font-family: "Shippori Mincho", "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-size: 17px;
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}

/* リード文 */
#birthflower-lp .bf-hero__body {
  max-width: 470px;
  margin: 0 auto 10px;
  color: var(--bf-text);
  font-size: 15px;
  line-height: 2;
  text-align: left;
}

/* 「クラフトキットとは？」の開閉ボタン */
#birthflower-lp .bf-hero__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 22px;
  padding: 0;
  border: none;
  background: none;
  color: var(--bf-main);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

/* 開閉ボタン右の丸矢印 */
#birthflower-lp .bf-hero__link::after {
  content: "";
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--bf-main) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='6' viewBox='0 0 8 6'%3E%3Cpath d='M1 1l3 3 3-3' fill='none' stroke='white' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center calc(50% + 1px) / 8px no-repeat;
  transition: transform 0.25s ease;
}

/* 開いているときは矢印を反転 */
#birthflower-lp .bf-hero__link.is-open::after {
  transform: rotate(180deg);
}

/* クラフトキットとは？の補足パネル */
#birthflower-lp .bf-hero__kitnote {
  max-width: 470px;
  margin: -8px auto 22px;
  padding: 16px 18px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid var(--bf-line);
  text-align: left;
}

#birthflower-lp .bf-hero__kitnote p {
  margin: 0;
  color: var(--bf-subtext);
  font-size: 13px;
  line-height: 1.8;
}

#birthflower-lp .bf-hero__kitnote[hidden] {
  display: none;
}

/* CTAボタン行 */
#birthflower-lp .bf-hero__btns {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  justify-content: center;
}

/* ヒーロー内CTAだけ少し小さめにする */
#birthflower-lp .bf-hero__btns .bf-btn {
  padding: 12px 24px;
  font-size: 14px;
  white-space: nowrap;
}

/* 右側カード */
#birthflower-lp .bf-hero__card {
  position: relative;
  border: 12px solid #fff;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 18px 36px rgba(180, 120, 135, 0.16);
}

/* 写真エリア */
#birthflower-lp .bf-hero__photo {
  aspect-ratio: 4 / 5.5;
  border-radius: 8px;
  overflow: hidden;
}

/* 写真をカードいっぱいに表示 */
#birthflower-lp .bf-hero__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

/* 写真下部の情報ボックス */
#birthflower-lp .bf-hero__overlay {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  padding: 18px 16px;
  border: 1px solid rgba(120, 100, 100, 0.28);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
}

#birthflower-lp .bf-hero__tag {
  margin: 0 0 8px;
  color: var(--bf-main);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: center;
}

#birthflower-lp .bf-hero__flowers {
  margin: 0 0 8px;
  color: var(--bf-text);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-align: center;
}

#birthflower-lp .bf-hero__note {
  margin: 0;
  color: var(--bf-subtext);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.7;
  text-align: center;
}

/* SP時：1カラムにする */
@media screen and (max-width: 900px) {
  #birthflower-lp .bf-hero__inner {
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 40px var(--bf-pad-sp) 44px;
  }

  #birthflower-lp .bf-hero__title {
    font-size: 35px;
    line-height: 1.45;
    letter-spacing: 0.07em;
  }

  #birthflower-lp .bf-hero__text::before,
  #birthflower-lp .bf-hero__text::after {
    top: 35px;
    width: 80px;
    height: 123px;
  }

  #birthflower-lp .bf-hero__text::before {
    left: 0;
  }

  #birthflower-lp .bf-hero__text::after {
    right: 0;
  }

  #birthflower-lp .bf-hero__body {
    font-size: 14px;
    line-height: 1.9;
  }

  #birthflower-lp .bf-hero__subtitle {
    font-size: 16px;
    line-height: 1.75;
    letter-spacing: 0;
  }

  #birthflower-lp .bf-hero__btns {
    flex-wrap: wrap;
    gap: 12px;
  }

  #birthflower-lp .bf-hero__btns .bf-btn {
    justify-content: center;
    width: 100%;
    max-width: 280px;
  }

  #birthflower-lp .bf-hero__card {
    max-width: 420px;
    margin: 0 auto;
    border-width: 10px;
  }
}

/* =====================================================
   02. 誕生花を月別で探す（プルダウン）
   ヒーロー下の月選択エリア
===================================================== */
/* 月別検索ブロック全体 */
#birthflower-lp .bf-finder {
  background: var(--bf-white);
}

/* 月別検索ブロック内側 */
#birthflower-lp .bf-finder__inner {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 48px var(--bf-pad) 52px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
}

/* 見出し */
#birthflower-lp .bf-finder__title {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 12px;
  color: var(--bf-text);
  font-size: 28px;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

/* 月別検索見出しアイコン */
#birthflower-lp .bf-finder__title-icon {
  width: 48px;
  height: auto;
  flex-shrink: 0;
}

/* 説明文 */
#birthflower-lp .bf-finder__text {
  margin: 0;
  color: var(--bf-subtext);
  font-size: 16px;
  line-height: 1.9;
}

#birthflower-lp .bf-finder__note {
  color: var(--bf-subtext);
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.8;
}

/* セレクトボックスの外枠 */
#birthflower-lp .bf-finder__select {
  position: relative;
}

/* セレクトボックス本体 */
#birthflower-lp .bf-finder__select select {
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  padding: 20px 56px 20px 28px;
  border: 1px solid var(--bf-line);
  border-radius: 14px;
  background: #fdeef2;
  color: var(--bf-text);
  font-family: inherit;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.5;
  cursor: pointer;
}

/* セレクトボックス右側の矢印 */
#birthflower-lp .bf-finder__select::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 26px;
  width: 16px;
  height: 16px;
  transform: translateY(-60%) rotate(45deg);
  border-right: 2px solid var(--bf-main);
  border-bottom: 2px solid var(--bf-main);
  pointer-events: none;
}

/* SP時：1カラムにする */
@media screen and (max-width: 900px) {
  #birthflower-lp .bf-finder__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 36px var(--bf-pad-sp) 40px;
  }

  #birthflower-lp .bf-finder__title {
    display: flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin: 0 auto 12px;
    gap: 10px;
    font-size: 24px;
    text-align: center;
  }

  #birthflower-lp .bf-finder__text {
    font-size: 15px;
  }

  #birthflower-lp .bf-finder__title,
  #birthflower-lp .bf-finder__lead {
    text-align: center;
  }

  #birthflower-lp .bf-finder__note {
    text-align: left;
  }

  #birthflower-lp .bf-finder__select select {
    padding: 18px 52px 18px 22px;
    font-size: 18px;
  }

  #birthflower-lp .bf-finder__select::after {
    right: 24px;
    width: 14px;
    height: 14px;
  }
}

/* =====================================================
   03. 12ヶ月分の誕生花一覧
===================================================== */
/* 見出し・リード文を中央寄せ */
#birthflower-lp #months .bf-h2,
#birthflower-lp #months .bf-lead {
  text-align: center;
}

#birthflower-lp #months .bf-lead {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

/* SP時：リード文は読みやすさ優先で左寄せ */
@media screen and (max-width: 900px) {
  #birthflower-lp #months .bf-lead {
    text-align: left;
  }
}

#birthflower-lp .bf-months {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-top: 40px;
}

/* 月カード */
#birthflower-lp .bf-mcard {
  position: relative;
  margin-top: 28px;
  /* バッジ分の余白 */
  padding: 48px 32px 28px;
  border: 1px solid var(--bf-line);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(190, 150, 160, 0.10);
}

/* 月バッジ（水彩の丸）。「1月」を横読みで表示 */
#birthflower-lp .bf-mcard__badge {
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #fff;
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

#birthflower-lp .bf-mcard__badge small {
  font-size: 14px;
  margin-left: 2px;
}

/* 3枚の花写真 */
#birthflower-lp .bf-mcard__photos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 10px;
}

#birthflower-lp .bf-mcard__photo {
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
}

#birthflower-lp .bf-mcard__photo img,
#birthflower-lp .bf-hero__photo img,
#birthflower-lp .bf-note__photo img,
#birthflower-lp .bf-craftrow__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

#birthflower-lp .bf-hero__photo,
#birthflower-lp .bf-note__photo {
  overflow: hidden;
}

#birthflower-lp .bf-craftrow__photo {
  overflow: hidden;
}

#birthflower-lp .bf-mcard__names {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}

#birthflower-lp .bf-mcard__name {
  text-align: center;
  font-size: 15px;
  font-weight: 500;
  color: var(--bf-text);
}

/* テーマ罫線 */
#birthflower-lp .bf-mcard__rule {
  height: 1px;
  margin: 0 0 18px;
  background: var(--bf-line);
}

/* 花言葉テーマ見出し（ここだけ明朝体） */
#birthflower-lp .bf-mcard__theme {
  margin: 0 0 16px;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* 花言葉リスト */
#birthflower-lp .bf-mcard__list {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
}

#birthflower-lp .bf-mcard__list li {
  position: relative;
  margin-bottom: 10px;
  padding-left: 28px;
  font-size: 16px;
  font-weight: 500;
  color: var(--bf-text);
}

#birthflower-lp .bf-mcard__list li::before {
  content: "✾";
  position: absolute;
  left: 4px;
  top: -10px;
  font-size: 26px;
}

/* 花のガーランド（装飾の区切り） */
#birthflower-lp .bf-garland {
  height: 22px;
  margin: 0 0 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='22' viewBox='0 0 120 22'%3E%3Cpath d='M0 12 H120' stroke='%23cdbf9a' stroke-width='1'/%3E%3Cg%3E%3Ccircle cx='14' cy='9' r='4' fill='%23f3b6c6'/%3E%3Ccircle cx='30' cy='13' r='4' fill='%23f6c98a'/%3E%3Ccircle cx='46' cy='8' r='4' fill='%23e58aa6'/%3E%3Ccircle cx='62' cy='13' r='4' fill='%23f6c98a'/%3E%3Ccircle cx='78' cy='9' r='4' fill='%23f3b6c6'/%3E%3Ccircle cx='94' cy='13' r='4' fill='%23e58aa6'/%3E%3Ccircle cx='110' cy='9' r='4' fill='%23f6c98a'/%3E%3C/g%3E%3C/svg%3E") repeat-x left center;
  background-size: auto 22px;
}

/* 説明文 */
#birthflower-lp .bf-mcard__desc {
  margin: 0 0 18px;
  color: var(--bf-subtext);
  font-size: 15px;
  line-height: 1.95;
}

/* タグ */
#birthflower-lp .bf-mcard__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}

#birthflower-lp .bf-tag {
  padding: 2px 10px;
  border-radius: 5px;
  font-size: 13px;
  font-weight: 500;
}

/* 関連商品リンク */
#birthflower-lp .bf-mcard__more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 15px;
  font-weight: 600;
}

/* --- 月テーマカラーの適用 --- */
#birthflower-lp .bf-mcard[data-m="1"] .bf-mcard__badge {
  background: var(--m1);
}

#birthflower-lp .bf-mcard[data-m="1"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="1"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="1"] .bf-mcard__more {
  color: var(--m1);
}

#birthflower-lp .bf-mcard[data-m="1"] .bf-tag {
  background: var(--m1-bg);
  color: var(--m1);
}

#birthflower-lp .bf-mcard[data-m="2"] .bf-mcard__badge {
  background: var(--m2);
}

#birthflower-lp .bf-mcard[data-m="2"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="2"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="2"] .bf-mcard__more {
  color: var(--m2);
}

#birthflower-lp .bf-mcard[data-m="2"] .bf-tag {
  background: var(--m2-bg);
  color: var(--m2);
}

#birthflower-lp .bf-mcard[data-m="3"] .bf-mcard__badge {
  background: var(--m3);
}

#birthflower-lp .bf-mcard[data-m="3"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="3"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="3"] .bf-mcard__more {
  color: var(--m3);
}

#birthflower-lp .bf-mcard[data-m="3"] .bf-tag {
  background: var(--m3-bg);
  color: var(--m3);
}

#birthflower-lp .bf-mcard[data-m="4"] .bf-mcard__badge {
  background: var(--m4);
}

#birthflower-lp .bf-mcard[data-m="4"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="4"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="4"] .bf-mcard__more {
  color: var(--m4);
}

#birthflower-lp .bf-mcard[data-m="4"] .bf-tag {
  background: var(--m4-bg);
  color: var(--m4);
}

#birthflower-lp .bf-mcard[data-m="5"] .bf-mcard__badge {
  background: var(--m5);
}

#birthflower-lp .bf-mcard[data-m="5"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="5"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="5"] .bf-mcard__more {
  color: var(--m5);
}

#birthflower-lp .bf-mcard[data-m="5"] .bf-tag {
  background: var(--m5-bg);
  color: var(--m5);
}

#birthflower-lp .bf-mcard[data-m="6"] .bf-mcard__badge {
  background: var(--m6);
}

#birthflower-lp .bf-mcard[data-m="6"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="6"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="6"] .bf-mcard__more {
  color: var(--m6);
}

#birthflower-lp .bf-mcard[data-m="6"] .bf-tag {
  background: var(--m6-bg);
  color: var(--m6);
}

#birthflower-lp .bf-mcard[data-m="7"] .bf-mcard__badge {
  background: var(--m7);
}

#birthflower-lp .bf-mcard[data-m="7"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="7"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="7"] .bf-mcard__more {
  color: var(--m7);
}

#birthflower-lp .bf-mcard[data-m="7"] .bf-tag {
  background: var(--m7-bg);
  color: var(--m7);
}

#birthflower-lp .bf-mcard[data-m="8"] .bf-mcard__badge {
  background: var(--m8);
}

#birthflower-lp .bf-mcard[data-m="8"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="8"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="8"] .bf-mcard__more {
  color: var(--m8);
}

#birthflower-lp .bf-mcard[data-m="8"] .bf-tag {
  background: var(--m8-bg);
  color: var(--m8);
}

#birthflower-lp .bf-mcard[data-m="9"] .bf-mcard__badge {
  background: var(--m9);
}

#birthflower-lp .bf-mcard[data-m="9"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="9"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="9"] .bf-mcard__more {
  color: var(--m9);
}

#birthflower-lp .bf-mcard[data-m="9"] .bf-tag {
  background: var(--m9-bg);
  color: var(--m9);
}

#birthflower-lp .bf-mcard[data-m="10"] .bf-mcard__badge {
  background: var(--m10);
}

#birthflower-lp .bf-mcard[data-m="10"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="10"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="10"] .bf-mcard__more {
  color: var(--m10);
}

#birthflower-lp .bf-mcard[data-m="10"] .bf-tag {
  background: var(--m10-bg);
  color: var(--m10);
}

#birthflower-lp .bf-mcard[data-m="11"] .bf-mcard__badge {
  background: var(--m11);
}

#birthflower-lp .bf-mcard[data-m="11"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="11"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="11"] .bf-mcard__more {
  color: var(--m11);
}

#birthflower-lp .bf-mcard[data-m="11"] .bf-tag {
  background: var(--m11-bg);
  color: var(--m11);
}

#birthflower-lp .bf-mcard[data-m="12"] .bf-mcard__badge {
  background: var(--m12);
}

#birthflower-lp .bf-mcard[data-m="12"] .bf-mcard__theme,
#birthflower-lp .bf-mcard[data-m="12"] .bf-mcard__list li::before,
#birthflower-lp .bf-mcard[data-m="12"] .bf-mcard__more {
  color: var(--m12);
}

#birthflower-lp .bf-mcard[data-m="12"] .bf-tag {
  background: var(--m12-bg);
  color: var(--m12);
}

@media screen and (max-width: 900px) {

  /* 外側余白をSP共通余白に揃える */
  #birthflower-lp #months .bf-inner {
    padding-left: var(--bf-pad-sp);
    padding-right: var(--bf-pad-sp);
  }

  #birthflower-lp .bf-mcard {
    padding: 48px 20px 28px;
  }

  #birthflower-lp .bf-months {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  #birthflower-lp .bf-h2 {
    font-size: 24px;
  }
}

/* =====================================================
   04. 誕生花をもっと楽しむ、月ごとの読み物
===================================================== */
/* 読み物ブロック内側：PCでは左に説明、右にコラムリンク */
#birthflower-lp .bf-reading__inner {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 64px var(--bf-pad);
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 48px;
  align-items: center;
}

/* 左側カラム */
#birthflower-lp .bf-reading__left {
  min-width: 0;
}

/* 左側の見出し */
#birthflower-lp .bf-reading__title {
  margin: 0 0 18px;
  color: var(--bf-text);
  font-size: 28px;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.06em;
}

/* 左側の説明文 */
#birthflower-lp .bf-reading__text {
  margin: 0 0 28px;
  color: var(--bf-subtext);
  font-size: 15px;
  line-height: 1.95;
}

/* 右側カラム */
#birthflower-lp .bf-reading__right {
  min-width: 0;
}

/* 右側：月別コラムの小見出し */
#birthflower-lp .bf-reading__head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 12px;
}

/* 月別コラム見出しのアイコン */
#birthflower-lp .bf-reading__head-icon {
  width: 42px;
  height: auto;
  flex-shrink: 0;
}

/* 月別コラム見出しのテキスト部分 */
#birthflower-lp .bf-reading__head-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.4;
}

/* 「月別コラム」 */
#birthflower-lp .bf-reading__head-text span {
  color: var(--bf-main);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

/* 「気になる月の記事へ〜」 */
#birthflower-lp .bf-reading__head-text small {
  color: var(--bf-subtext);
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.02em;
}

/* 右側：コラムリンク一覧 */
#birthflower-lp .bf-reading__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* コラムリンク：角丸の白カード風 */
#birthflower-lp .bf-readlink {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 52px 10px 22px;
  border: 2px solid #e7cbd2;
  border-radius: 10px;
  background: #fff;
  color: var(--bf-text);
  box-shadow: 0 2px 6px rgba(120, 80, 90, 0.08);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.5;
  transition: transform 0.15s ease;
}

/* ホバー時：少し右に動かす */
#birthflower-lp .bf-readlink:hover {
  transform: translateX(3px);
}

/* コラムリンク右側の矢印 */
#birthflower-lp .bf-readlink::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 10px;
  height: 10px;
  transform: translateY(-50%) rotate(45deg);
  border-top: 3px solid var(--bf-main);
  border-right: 3px solid var(--bf-main);
}

/* SP時：1カラムにして、見出しとボタンを中央寄せ */
@media screen and (max-width: 900px) {
  #birthflower-lp .bf-reading__inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 44px var(--bf-pad-sp);
  }

  /* SP時：左側の見出しとボタンを中央寄せ */
  #birthflower-lp .bf-reading__left {
    text-align: center;
  }

  /* SP時：見出しサイズを調整 */
  #birthflower-lp .bf-reading__title {
    font-size: 24px;
    text-align: center;
  }

  /* SP時：説明文は読みやすさ優先で左寄せ */
  #birthflower-lp .bf-reading__text {
    text-align: left;
  }

  #birthflower-lp .bf-reading__head {
    margin-bottom: 12px;
  }

  #birthflower-lp .bf-reading__head-icon {
    width: 38px;
  }

  #birthflower-lp .bf-readlink {
    padding: 10px 46px 10px 18px;
    font-size: 13px;
  }

  #birthflower-lp .bf-readlink::after {
    right: 18px;
  }
}

/* =====================================================
   05. 花言葉から選ぶ
===================================================== */
#birthflower-lp .bf-lang__head {
  text-align: center;
  margin-bottom: 8px;
}

#birthflower-lp .bf-lang__title {
  margin: 0 0 16px;
  font-size: 30px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-align: center;
}

#birthflower-lp .bf-lang__lead {
  max-width: 860px;
  margin: 0 auto 40px;
  color: var(--bf-subtext);
  font-size: 15px;
  line-height: 2;
  text-align: center;
}

/* カード一覧 */
#birthflower-lp .bf-lang__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* 花言葉カード */
#birthflower-lp .bf-lcard {
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(190, 150, 160, 0.10);
}

/* カード上部：背景画像エリア */
#birthflower-lp .bf-lcard__visual {
  position: relative;
  min-height: 150px;
  padding: 18px 18px;
  display: flex;
  align-items: flex-end;
  background-image:
    linear-gradient(180deg,
      rgba(0, 0, 0, 0.00) 0%,
      rgba(0, 0, 0, 0.10) 35%,
      rgba(0, 0, 0, 0.30) 100%),
    var(--lc-bg);
  background-size: cover;
  background-position: center;
}

/* カードの背景画像 */
#birthflower-lp .bf-lcard--kansha {
  --lc-bg: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-lang-kansha.jpg");
}

#birthflower-lp .bf-lcard--kofuku {
  --lc-bg: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-lang-kofuku.jpg");
}

#birthflower-lp .bf-lcard--kibo {
  --lc-bg: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-lang-kibo.jpg");
}

#birthflower-lp .bf-lcard--omoiyari {
  --lc-bg: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-lang-omoiyari.jpg");
}

#birthflower-lp .bf-lcard--johin {
  --lc-bg: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-lang-johin.jpg");
}

#birthflower-lp .bf-lcard--seijitsu {
  --lc-bg: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-lang-seijitsu.jpg");
}

/* 右上タグ */
#birthflower-lp .bf-lcard__tags {
  position: absolute;
  top: 14px;
  right: 14px;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  max-width: calc(100% - 28px);
}

/* タグ1つずつ */
#birthflower-lp .bf-lcard__tags span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
  color: #7d253f;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.3;
}

/* 花言葉キーワード */
#birthflower-lp .bf-lcard__kw {
  margin: 0;
  color: #fff;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45);
}

/* カード下部：白エリア */
#birthflower-lp .bf-lcard__body {
  padding: 22px 22px 24px;
}

/* 代表的な花の囲み */
#birthflower-lp .bf-lcard__flowerbox {
  margin: 0 0 18px;
  padding: 8px 18px;
  border-radius: 12px;
  background: #fdf3f5;
}

/* 代表的な花ラベル */
#birthflower-lp .bf-lcard__flowerlabel {
  margin: 0 0 6px;
  color: var(--bf-main);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

/* 花の名前 */
#birthflower-lp .bf-lcard__flowers {
  margin: 0;
  color: var(--bf-text);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.6;
}

/* アドバイス文 */
#birthflower-lp .bf-lcard__desc {
  margin: 0 0 22px;
  color: var(--bf-subtext);
  font-size: 14px;
  line-height: 1.85;
}

/* ボタン行 */
#birthflower-lp .bf-lcard__cta-row {
  text-align: center;
}

/* 関連商品を見るボタン */
#birthflower-lp .bf-lcard__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 180px;
  padding: 5px 24px;
  border-radius: 999px;
  background: var(--bf-main);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

#birthflower-lp .bf-lcard__cta::after {
  content: "";
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.28) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='7' height='10' viewBox='0 0 7 10'%3E%3Cpath d='M1 1l4 4-4 4' fill='none' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") calc(50% + 1px) center / 7px no-repeat;
}

#birthflower-lp .bf-lcard__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(214, 85, 122, 0.30);
}

/* SP時 */
@media screen and (max-width: 900px) {

  /* 外側余白をSP共通余白に揃える */
  #birthflower-lp #lang .bf-inner {
    padding-left: var(--bf-pad-sp);
    padding-right: var(--bf-pad-sp);
  }

  #birthflower-lp .bf-lang__grid {
    grid-template-columns: 1fr;
  }

  #birthflower-lp .bf-lang__title {
    font-size: 24px;
  }

  #birthflower-lp .bf-lang__lead {
    text-align: left;
  }

  #birthflower-lp .bf-lcard__visual {
    min-height: 140px;
  }

  #birthflower-lp .bf-lcard__kw {
    font-size: 38px;
  }
}

/* =====================================================
   06. もっと深く知りたい方へ（公式note誘導）
===================================================== */
#birthflower-lp .bf-note {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 0 var(--bf-pad) 64px;
}

#birthflower-lp .bf-note__box {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 40px;
  align-items: center;
  padding: 40px;
  border-radius: 18px;
  /* background: #fdeef2; */
}

#birthflower-lp .bf-note__photo {
  /* aspect-ratio: 4 / 3; */
  border-radius: 12px;
}

#birthflower-lp .bf-note__title {
  margin: 0 0 18px;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

#birthflower-lp .bf-note__text {
  margin: 0 0 26px;
  color: var(--bf-subtext);
  font-size: 15px;
  line-height: 1.95;
}

@media screen and (max-width: 900px) {
  #birthflower-lp .bf-note {
    padding: 44px var(--bf-pad-sp);
  }

  #birthflower-lp .bf-note__box {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 28px;
  }

  #birthflower-lp .bf-note__title {
    font-size: 24px;
  }
}

/* =====================================================
   07. 誕生花だけじゃない、花を楽しむ手作り時間
===================================================== */
#birthflower-lp .bf-craft__inner {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 64px var(--bf-pad);
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 48px;
  align-items: center;
}

/* 左側テキスト */
#birthflower-lp .bf-craft__left {
  min-width: 0;
}

/* 左側タイトル：少し小さめ・字間広めで上品に */
#birthflower-lp .bf-craft__title {
  margin: 0 0 22px;
  color: var(--bf-text);
  font-size: 27px;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: 0.09em;
}

/* 左側説明文 */
#birthflower-lp .bf-craft__text {
  margin: 0 0 28px;
  color: var(--bf-subtext);
  font-size: 15px;
  line-height: 1.95;
}

/* 右側カード一覧 */
#birthflower-lp .bf-craft__list {
  display: flex;
  flex-direction: column;
  /*gap: 16px;*/
}

/* 横長背景画像カード */
#birthflower-lp .bf-craftrow {
  position: relative;
  display: block;
  min-height: 156px;
  overflow: hidden;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  box-shadow: 0 10px 26px rgba(190, 150, 160, 0.10);
}

/* 各カードの背景画像 */
#birthflower-lp .bf-craftrow--sakura {
  background-image: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-craft_sakura.jpg");
}

#birthflower-lp .bf-craftrow--hasu {
  background-image: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-craft_hasu.jpg");
}

#birthflower-lp .bf-craftrow--tsubaki {
  background-image: url("https://sakura.itembox.cloud/item/img/birth-flower/birthflower-craft_tsubaki.jpg");
}

/* 左側の透過色パネル */
#birthflower-lp .bf-craftrow__panel {
  width: 43%;
  min-height: 156px;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: rgba(207, 91, 128, 0.80);
  color: #fff;
}

/* カードごとに少し色味を変える */
#birthflower-lp .bf-craftrow--sakura .bf-craftrow__panel {
  background: rgba(229, 113, 165, 0.80);
}

#birthflower-lp .bf-craftrow--hasu .bf-craftrow__panel {
  background: rgba(136, 98, 183, 0.80);
}

#birthflower-lp .bf-craftrow--tsubaki .bf-craftrow__panel {
  background: rgba(165, 18, 33, 0.80);
}

/* カードタイトル */
#birthflower-lp .bf-craftrow__title {
  margin: 0 0 8px;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

/* カード説明文 */
#birthflower-lp .bf-craftrow__desc {
  margin: 0 0 12px;
  color: #fff;
  font-size: 13.5px;
  line-height: 1.7;
}

/* カード内リンク */
#birthflower-lp .bf-craftrow__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #fff;
  font-size: 13.5px;
  font-weight: 700;
}

#birthflower-lp .bf-craftrow__link::after {
  content: "›";
  position: relative;
  top: -2px;
  font-size: 18px;
  line-height: 1;
}

/* SP時 */
@media screen and (max-width: 900px) {
  #birthflower-lp .bf-craft__inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 44px var(--bf-pad-sp);
  }

  #birthflower-lp .bf-craft__left {
    text-align: center;
  }

  #birthflower-lp .bf-craft__title {
    font-size: 23px;
    line-height: 1.65;
    text-align: center;
  }

  #birthflower-lp .bf-craft__text {
    text-align: left;
  }

  #birthflower-lp .bf-craftrow {
    min-height: 180px;
  }

  #birthflower-lp .bf-craftrow__panel {
    width: 58%;
    min-height: 180px;
    padding: 20px;
  }

  #birthflower-lp .bf-craftrow__title {
    font-size: 19px;
  }

  #birthflower-lp .bf-craftrow__desc {
    font-size: 13px;
  }
}

/* =====================================================
   08. 花の商品一覧を見る
===================================================== */
#birthflower-lp .bf-flower-cta {
  background: var(--bf-white);
}

#birthflower-lp .bf-flower-cta__inner {
  max-width: var(--bf-width);
  margin: 0 auto;
  padding: 32px var(--bf-pad) 64px;
  text-align: center;
}

/* SP時 */
@media screen and (max-width: 900px) {
  #birthflower-lp .bf-flower-cta__inner {
    padding: 28px var(--bf-pad-sp) 52px;
  }
}
