@charset "utf-8";

.lp-tablet {
  text-align: center;
  font-size: 14px;
  line-height: 1.8;
}

@media screen and (max-width: 979px) {
  .lp-tablet {
    margin-top: 0px;
  }
}

.lp-tablet img {
  width: auto;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 769px) {
  .lp-tablet img {
    width: 100%;
  }
}

.lp-tablet .ranking img {
  width: 100%;
}

.table-simple th {
  width: 40%;
}

.lineup-img img {
  width: 100%;
}

.table-simple td {
  width: 60%;
}

.box-question .box-question-title {
  display: flex;
  gap: 10px;
}
.box-question .box-question-title img {
  margin: 0;
}

.variation-catch img:last-of-type {
  right: 0;
}

.example-list-lg .img img {
  width: 128px;
}

.feature-point-list li img {
  width: 100%;
}

@media screen and (max-width: 769px) {
  .example-list li {
  }
  .example-list li img {
    width: 40%;
  }

  .about-individual_inner img {
    max-width: 100%;
  }

  .point-image img {
    width: 100%;
  }

  .point-list img {
    width: 100%;
  }

  .howto .heading-img {
    display: flex;
    gap: 10px;
    justify-content: center;
  }

  .howto .heading-img img {
    max-width: 130px;
    margin: 0;
  }

  .box-question .box-question-title img {
    width: auto;
  }
  .variation-catch img {
    width: auto;
  }

  .tablet-variation .content-inner .img.arrow img {
    width: auto;
  }
  .voice-box h3 span img {
    width: auto;
    display: inline;
  }
}

.lp-tablet .has-arrow-bottom::after {
  display: block;
  content: "";
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(135deg);
  position: absolute;
  top: 50%;
  right: 10%;
  width: 10px;
  height: 10px;
  margin-top: -8px;
}

/* ===================================================================
   Fix: SP版で .content-inner.tab-lifeguard が最上部に表示される問題
   - .content-wrap は SP で display:flex;flex-wrap:wrap のため、
     直接の子要素に order が未設定だと order:0 になり最上部に来る
   - .sc202203 .sc { order:17 } と同値を設定して正しい位置に表示
   =================================================================== */
@media screen and (max-width: 769px) {
  .sc202203 .content-inner.tab-lifeguard {
    order: 17;
    width: 100%;
  }
  /* anchor divs (#anchor-link1, #anchor-link2) も同様に順序を揃える */
  .sc202203 #anchor-link1,
  .sc202203 #anchor-link2 {
    order: 17;
    width: 100%;
  }
}

/* ===================================================================
   以下、tablet.html のインラインCSSを移行 (2026-06-08)
   インラインstyleはsc.cssの非同期読み込みより後に適用されるため常に優先されていた。
   外部ファイル化により同等の保証が失われるため、#container_ IDで詳細度を上げて担保。
   =================================================================== */

/* product-highlight.bg (ベーシックガード用) */
#container_ .product-highlight.bg {
  background: #e8f3ff !important;
  margin-top: 60px;
  box-shadow: 0;
}
#container_ .product-highlight.bg .highlight-label {
  font-size: 18px;
  font-weight: bold;
  color: #377dc4;
  margin-bottom: 10px;
}
#container_ .product-highlight.bg h3 {
  font-size: 18px;
  font-weight: bold;
  color: #377dc4;
  margin: 10px 0;
}
#container_ .product-highlight.bg p {
  font-size: 14px;
  color: #333;
  line-height: 1.6;
}
#container_ .product-highlight.bg .highlight-text {
  text-align: left;
}
#container_ .product-highlight.bg small {
  font-size: 0.7em;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  #container_ .product-highlight.bg {
    flex-direction: column-reverse;
  }
  #container_ .product-highlight.bg .highlight-text,
  #container_ .product-highlight.bg .highlight-image {
    width: 100%;
    max-width: 100%;
  }
  #container_ .product-highlight.bg .highlight-image {
    margin-bottom: 20px;
    text-align: center;
  }
  #container_ .product-highlight.bg h3 {
    margin: 0 30px;
  }
  #container_ .product-highlight.bg p {
    margin: 0 30px;
  }
  #container_ .product-highlight.bg .variation-btn {
    margin: 20px auto 0 auto;
    max-width: 90%;
  }
}

@media screen and (min-width: 769px) {
  #container_ .product-highlight.bg {
    justify-content: center;
    gap: 60px;
  }
  #container_ .product-highlight.bg .highlight-text,
  #container_ .product-highlight.bg .highlight-image {
    max-width: 40%;
  }
}

#container_ .tablet-variation-navi{
  padding-top: 0;
}

/* 並び替え後: navi-item 3番目がVD3になるため背景色を上書き */
#container_ ul.tablet-variation-navi-item li:nth-child(3) {
  background: #fff8e8 !important;
}

/* navi-item内の画像をカード幅に収める */
#container_ ul.tablet-variation-navi-item li img {
  max-width: 100%;
}

/* === ナビカード要素縦位置揃え (PC): ボタンを各カード最下部に固定 === */
@media screen and (min-width: 769px) {
  #container_ ul.tablet-variation-navi-item li {
    display: flex;
    flex-direction: column;
  }
  #container_ ul.tablet-variation-navi-item li .variation-btn {
    margin-top: auto;
  }
  /* 商品画像の高さを統一して商品名・説明文の縦位置を揃える */
  #container_ ul.tablet-variation-navi-item li img:not(.taishou-logo) {
    height: 220px;
    width: auto !important;
    object-fit: contain;
    display: block;
    margin: 0 auto 8px;
  }
}

/* === .sc .lineup ブロック間隔の明示的統一 === */
@media screen and (min-width: 769px) {
  #container_ .sc .lineup .content-inner {
    padding-top: 75px;
  }
}
@media screen and (max-width: 768px) {
  #container_ .sc .lineup .content-inner {
    padding-top: 40px;
  }
}

/* 定期購入ガイド表示 */
#container_ .teiki-guide {
  display: block !important;
}

/* --- テキストカラー (sc.css干渉回避) --- */
#container_ .tablet-color-blue {
  color: #377dc4;
}

#container_ .tablet-color-pink {
  color: #d80e64;
}

#container_ .tablet-color-orange {
  color: #fe671d;
}

#container_ .tablet-color-citrus {
  color: #f8bd77;
}

/* ===================================================================
   ナビゲーションカード グリッドレイアウト (2026-06-08)
   sc.css 干渉を回避するため .navi-grid + .navi-card 構造を採用。
   =================================================================== */

/* --- コンテナ & エリア配置 (PC: BG全幅 + SG/LG/VD3 横並び3列) --- */
#container_ .navi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-areas:
    "bg bg bg"
    "sg lg vd";
  gap: 20px;
  margin: 20px 0;
}

#container_ .navi-card--bg { grid-area: bg; background: #e8f3ff; }
#container_ .navi-card--sg { grid-area: sg; background: #fff0f8; }
#container_ .navi-card--lg { grid-area: lg; background: #fff2eb; }
#container_ .navi-card--vd { grid-area: vd; background: #fff8e8; }

/* --- カード共通 --- */
#container_ .navi-card {
  border-radius: 14px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

#container_ .navi-card--has-badge {
  position: relative;
}

/* --- バッジ --- */
#container_ .navi-card__badge {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background: #e5005a;
  line-height: 1.15;
  z-index: 2;
}

#container_ .navi-card__badge--pink {
  background: #e5005a;
}

/* --- 画像 --- */
#container_ .navi-card img {
  width: 100%;
  max-width: 100%;
}

#container_ .navi-card img.taishou-logo {
  width: auto;
}

/* --- ボタン --- */
#container_ .navi-card .variation-btn {
  margin: 1em auto 20px;
  width: 100%;
  max-width: 220px;
}

#container_ .navi-card .variation-btn .basic-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 42px;
  white-space: nowrap;
}

/* .navi-grid内の「詳細を見る」ボタン専用 右矢印 */
#container_ .navi-grid .variation-btn .basic-button.has-arrow-right {
  position: relative;
}

#container_ .navi-grid .variation-btn .basic-button.has-arrow-right::after {
  content: "";
  position: absolute;
  right: 0.95em;
  top: calc(50% + 5px);
  width: 0.42em;
  height: 0.42em;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}

/* --- テキスト要素ベース (メディアクエリより前に置き、MQ上書きを保証) --- */
#container_ .navi-card__catch {
  font-size: 16px;
  font-weight: bold;
  margin-top: 1em;
  margin-bottom: 0;
}

#container_ .navi-card__name {
  font-size: 20px;
  font-weight: bold;
  margin: 6px 0 0;
  line-height: 1.2;
}

#container_ .navi-card__name-ja {
  font-size: 0.75em;
}

/* --- PC (min-width: 769px) --- */
@media screen and (min-width: 769px) {
  /* BG カード: 左右2カラムレイアウト */
  #container_ .navi-card--bg {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px 40px;
  }

  #container_ .navi-card--bg .navi-card__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "content image";
    align-items: center;
    column-gap: 40px;
    width: 100%;
    max-width: 640px;
  }

  #container_ .navi-card--bg .navi-card__content {
    grid-area: content;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    gap: 0;
  }

  #container_ .navi-card--bg .navi-card__image {
    grid-area: image;
    align-self: center;
    justify-self: center;
    width: 100%;
    max-width: 320px;
    text-align: center;
  }

  #container_ .navi-card--bg .navi-card__image img {
    height: 330px;
    width: auto !important;
    max-width: none;
    object-fit: contain;
    display: block;
    margin: 0 auto;
  }

  /* BG テキスト上書き */
  #container_ .navi-card--bg .navi-card__catch {
    font-size: 16px;
    text-align: center;
    margin-top: 0;
    margin-bottom: 0;
  }

  #container_ .navi-card--bg .navi-card__name {
    font-size: 30px;
    text-align: center;
    margin: 0;
  }

  #container_ .navi-card--bg .variation-btn {
    text-align: center;
    width: 100%;
    max-width: 220px;
  }

  /* SG / LG / VD3 画像高さ統一 */
  #container_ .navi-card--sg .navi-card__image img,
  #container_ .navi-card--lg .navi-card__image img,
  #container_ .navi-card--vd .navi-card__image img {
    height: 220px;
    width: auto !important;
    object-fit: contain;
    display: block;
    margin: 0 auto 8px;
  }
}

/* --- SP (max-width: 768px) --- */
@media screen and (max-width: 768px) {
  /* 2列グリッド */
  #container_ .navi-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "bg sg"
      "lg vd";
    gap: 10px;
  }

  /* カード共通 */
  #container_ .navi-card {
    padding: 14px 12px;
    min-height: 100%;
  }

  #container_ .navi-card .variation-btn {
    margin: 10px auto 0;
  }

  #container_ .navi-card__catch {
    font-size: 10px;
    line-height: 1.35;
    margin-top: 1em;
  }

  #container_ .navi-card__name {
    font-size: 16px;
    line-height: 1.25;
    margin: 6px 0 0;
    white-space: nowrap;
  }

  #container_ .navi-card .navi-card__image {
    width: 100%;
    max-width: 220px;
    padding: 0;
    margin: 0 auto 8px;
    box-sizing: border-box;
    text-align: center;
  }

  #container_ .navi-card .navi-card__image img {
    height: 120px;
    width: auto !important;
    max-width: 100%;
    object-fit: contain;
    display: block;
    margin: 0 auto;
  }

  /* バッジ SP サイズ */
  #container_ .navi-card--has-badge .navi-card__badge {
    top: 8px;
    left: 8px;
    width: 64px;
    height: 64px;
    font-size: 14px;
  }

  /* BG カード SP 縦並び */
  #container_ .navi-card--bg {
    display: flex;
    flex-direction: column;
    padding: 14px 12px;
  }

  #container_ .navi-card--bg .navi-card__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
  }

  #container_ .navi-card--bg .navi-card__content {
    width: 100%;
    text-align: center;
    padding-top: 0;
  }

}

