@charset "UTF-8";

/* ページ全体を白背景に */
html,
body {
  background-color: #ffffff !important;
  margin: 0;
  padding: 0;
  font-family: "Poppins", "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium",
               "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3,
               "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro",
               "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "Helvetica Neue", HelveticaNeue,
               Helvetica, Arial, "Segoe UI", sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
               "Segoe UI Symbol", "Noto Color Emoji";
}

/* PC最小幅制限 */
@media screen and (min-width: 768px) {
  body { min-width: 1000px; }
}

/* ヘッダー背景を白に */
header { background-color: #ffffff !important; }

/* ▼▼ メインコンテンツ ▼▼ */
.main-contents { background-color: transparent; position: relative; }
.main-contents img { max-width: 100%; height: auto; }

/* セクション内部の背景解除（透明） */
.main-contents__inner { background-color: transparent !important; }

/* セクションレイアウト */
.sakura-beauty-section { padding: 50px 20px; display: flex; justify-content: center; }
.sakura-beauty-inner { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-start; max-width: 900px; width: 100%; gap: 20px; }

/* 左カラム */
.sakura-left { flex: 1; min-width: 250px; text-align: left; padding-right: 20px; }
.sakura-title { font-size: 18px; margin: 0 0 8px; color: #333; }
.sakura-highlight { font-size: 22px; font-weight: bold; color: #333; margin: 0; }
.sakura-line { width: 40px; height: 2px; background-color: #14747d; margin-top: 12px; }

/* 右カラム */
.sakura-right { flex: 1; min-width: 280px; text-align: right; font-size: 14px; line-height: 2; color: #333; }

/* 商品セクション（共通） */
.product-section { width: 100%; padding: 50px 20px; font-family: sans-serif; overflow: hidden; }

/* ===== セクション背景色：ラッパーから強制上書き（ここだけで管理） ===== */
#section01 .product-section { background-color: #FBF49F !important; } /* 薄い黄色 */
#section02 .product-section { background-color: #b6e9f3 !important; } /* 薄い水色 */
#section03 .product-section { background-color: #ffffff !important; } /* 白 */

/* 商品ブロック（PC横並び） */
.product-row {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  max-width: 960px;
  margin: 0 auto 60px auto;
  background-color: transparent;
  padding: 20px;
}
.product-row.reverse { flex-direction: row-reverse; }

/* 商品画像 */
.product-image { flex: 1; display: flex; justify-content: flex-start; align-items: flex-start; }
.product-image img { width: 100%; height: auto; max-width: 800px; display: block; border-radius: 8px; margin: 0 auto; }

/* 商品テキスト */
.product-text { flex: 1; min-width: 280px; text-align: left; }
.product-brand { color: #14747d; font-size: 12px; font-weight: bold; margin: 0; }
.product-title { color: #14747d; font-size: 20px; margin: 5px 0 10px; }
.product-price { font-size: 16px; font-weight: bold; margin-bottom: 10px; }
.product-desc { font-size: 14px; line-height: 1.6; color: #333; }

/* Product Detail ボタンのデフォルト */
.product-btn {
  display: inline-block;
  margin-top: 12px;
  padding: 8px 16px;
  background-color: #bcebf4;    /* デフォルトは薄い水色 */
  color: #333 !important;
  font-size: 13px;
  font-weight: bold;
  text-decoration: none;
  border-radius: 5px;
}

/* セクション2内のボタンは白背景＋枠なし（Product Detail / ピックアップ / 検索ボタン） */
#section02 .product-btn,
#section02 .pickup-btn,
#section02 a[href*="search?tag=sale"] {
  background-color: #fff !important;
  color: #333 !important;
  border: none !important;
  box-shadow: none !important;
}

/* Pick up ボタン画像（使ってなければ削除可） */
.pickup-button-wrapper img { display: block; margin: 0 auto; max-width: 100%; }

/* スマホ対応 */
@media screen and (max-width: 767px) {
  .product-row { flex-direction: column; align-items: center; text-align: center; }
  .product-row.reverse { flex-direction: column; }
  .product-image, .product-text { width: 100%; }
  .product-text { padding: 0 16px; text-align: center; }
  .product-image img { max-width: 100%; }
}

/* セクション間スペーサー */
.section-gap { height: 50px; background-color: transparent; }

/* セクション見出し（h1） */
.product-section h1 {
  font-size: 42px !important;
  font-weight: 700 !important;
  line-height: 1.3;
  margin: 0 0 24px;
  text-align: center;
}

/* Pick up item ボタン（HTML版） */
.pickup-btn {
  display: inline-block;
  background-color: #bcebf4;
  color: #fff;
  padding: 15px 40px;
  font-size: 20px;
  font-weight: bold;
  text-decoration: none;
  border-radius: 8px;
  transition: background-color 0.3s ease;
}
.pickup-btn:hover { background-color: #9fd6e2; }

<style>
/* 画像のはみ出し防止＆にじみ対策 */
img{max-width:100%;height:auto;display:block}

/* ナビの横スクロール（小画面で折り返し/はみ出し対策） */
.nav-scroller{overflow:auto;-webkit-overflow-scrolling:touch}
.nav-scroller .page_link{white-space:nowrap}

/* CTAボタン（旧：固定幅テーブル） */
.cta-wrap{background:#e6f6fa;padding:24px 4vw}
.cta-btn{display:block;max-width:990px;margin:0 auto;padding:16px 10px;text-align:center;
  font-weight:700;font-size:clamp(16px,4.3vw,22px);color:#fff;background:#F2A9A9;
  border-radius:8px;text-decoration:none}

/* セール導入ブロックの文字サイズを可変に（見出し・本文だけ調整） */
.haircare-title{font-size:clamp(28px,6vw,56px)}
.haircare-lead{font-size:clamp(18px,4.5vw,28px)}
.haircare-body{font-size:clamp(14px,3.8vw,18px)}


.cta-wrap {
  background:#e6f6fa;
  padding:24px 4vw;
  text-align:center; /* 親で中央寄せ */
}
.cta-btn {
  display:inline-block; /* blockからinline-blockに変更 */
  max-width:990px;
  padding:16px 10px;
  text-align:center;
  font-weight:700;
  font-size:clamp(16px,4.3vw,22px);
  color:#fff;
  background:#F2A9A9;
  border-radius:8px;
  text-decoration:none;
}
</style>

