/* =========================================================
   Bloomy Unlimited Max 専用LP（/unlimited-max/）
   白ベース・淡ブルー・ネイビー＋淡ゴールドのプレミアム感。
   クラスは bloomy-umax- に隔離。比較ページ/記事のトンマナに準拠。
   ========================================================= */
.bloomy-umax {
  --umax-navy: #0b1f44;
  --umax-ink: #17357d;
  --umax-blue: #1677f2;
  --umax-sub: #46546f;
  --umax-line: #e3ecfa;
  --umax-tint: #f3f8ff;
  --umax-gold: #e7b53e;
  background: #fff;
  color: var(--umax-navy);
  overflow-x: hidden;
}
.bloomy-umax-wrap { max-width: 920px; margin: 0 auto; padding: 0 20px; }
.bloomy-umax-section { padding: 46px 0; }
.bloomy-umax-section--tint { background: var(--umax-tint); }
.bloomy-umax-h2 {
  margin: 0 0 22px; font-size: clamp(20px, 3.2vw, 26px); font-weight: 800;
  letter-spacing: -0.02em; color: var(--umax-navy); line-height: 1.4;
}
.bloomy-umax-p { margin: 0 0 14px; font-size: 15.5px; line-height: 1.9; color: var(--umax-sub); }
.bloomy-umax-p strong { color: var(--umax-navy); }
.bloomy-umax-links { margin: 6px 0 0; font-size: 14px; }
.bloomy-umax-links a, .bloomy-umax-note a { color: var(--umax-blue); font-weight: 700; text-decoration: none; }
.bloomy-umax-note { margin: 14px 0 0; font-size: 12.5px; line-height: 1.7; color: #7a8499; }

/* Hero */
.bloomy-umax-hero { padding: 18px 0 8px; background: linear-gradient(180deg, #eef5ff, #ffffff 70%); }
.bloomy-umax-hero__card {
  margin: 8px 0 0; padding: 22px 22px 22px; text-align: center;
  background: #fff; border: 1px solid #e1ecfd; border-radius: 24px;
  box-shadow: 0 26px 60px -38px rgba(20, 45, 100, 0.45);
}
.bloomy-umax-hero__badge {
  display: inline-block; font-size: 12px; font-weight: 800; letter-spacing: 0.04em;
  color: #8a6a16; background: linear-gradient(135deg, #fdf3d4, #f6e2a4);
  border: 1px solid #efd89a; border-radius: 999px; padding: 5px 14px;
}
.bloomy-umax-hero__title {
  margin: 8px 0 6px; font-size: clamp(26px, 5.6vw, 38px); font-weight: 800;
  letter-spacing: -0.02em; line-height: 1.2; color: var(--umax-navy); white-space: nowrap;
}
.bloomy-umax-hero__title span { color: var(--umax-blue); }
.bloomy-umax-hero__copy { margin: 4px 0 10px; font-size: clamp(15px, 3.1vw, 18px); font-weight: 800; color: var(--umax-ink); letter-spacing: -0.01em; line-height: 1.5; }
.bloomy-umax-hero__lead { margin: 0 auto 8px; max-width: 620px; font-size: 15px; line-height: 1.8; color: var(--umax-sub); }
.bloomy-umax-hero__lead--close { margin: 10px auto 18px; }
/* ファーストビューの要点（背景なしの青い線チェック・ネイビー文字・広め行間）。 */
.bloomy-umax-hero__checks {
  list-style: none; margin: 2px auto 14px; padding: 0;
  display: inline-block; text-align: left;
}
.bloomy-umax-hero__checks li {
  position: relative; padding: 3px 0 3px 30px;
  font-size: 15px; line-height: 1.6; font-weight: 700; color: var(--umax-navy);
}
/* 背景なしの「青い線」チェック（border で描画）。 */
.bloomy-umax-hero__checks li::before {
  content: ""; position: absolute; left: 6px; top: 50%;
  width: 7px; height: 12px;
  border: solid var(--umax-blue); border-width: 0 2.5px 2.5px 0;
  transform: translateY(-62%) rotate(45deg);
}
.bloomy-umax-hero__cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.bloomy-umax-hero__note { margin: 12px 0 0; font-size: 12px; color: #8a93a5; line-height: 1.6; }

/* Buttons */
.bloomy-umax-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 50px; padding: 0 26px; border-radius: 999px;
  font-size: 15px; font-weight: 800; text-decoration: none; letter-spacing: 0.01em;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.bloomy-umax-btn--primary { background: var(--umax-blue); color: #fff; box-shadow: 0 12px 24px -10px rgba(22, 119, 242, 0.6); }
.bloomy-umax-btn--primary:hover { background: #1163d6; transform: translateY(-1px); }
.bloomy-umax-btn--ghost { background: #f1f6fd; color: var(--umax-ink); border: 1px solid #dbe6fb; }
.bloomy-umax-btn--ghost:hover { background: #e9f1fd; }
.bloomy-umax-btn--lg { min-height: 54px; padding: 0 22px; font-size: clamp(13px, 3.9vw, 16px); white-space: nowrap; }

/* 5つの価値 */
.bloomy-umax-values { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; }
.bloomy-umax-value { background: #fff; border: 1px solid var(--umax-line); border-radius: 16px; padding: 18px 16px; }
.bloomy-umax-value__mark {
  display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px;
  border-radius: 50%; background: #eaf3ff; color: var(--umax-blue); font-weight: 800; font-size: 15px;
}
.bloomy-umax-value__title { margin: 12px 0 6px; font-size: 15px; font-weight: 800; color: var(--umax-navy); line-height: 1.45; }
.bloomy-umax-value__text { margin: 0; font-size: 13px; line-height: 1.7; color: var(--umax-sub); }

/* テーブル */
.bloomy-umax-tablewrap { overflow-x: auto; border-radius: 16px; border: 1px solid var(--umax-line); }
.bloomy-umax-table { width: 100%; border-collapse: collapse; background: #fff; font-size: 13.5px; }
.bloomy-umax-table th, .bloomy-umax-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid #eef2f8; line-height: 1.6; vertical-align: top; }
.bloomy-umax-table thead th { background: #f5f9ff; font-weight: 800; color: var(--umax-navy); font-size: 13px; white-space: nowrap; }
.bloomy-umax-table th.is-bloomy, .bloomy-umax-table td.is-bloomy { background: #eef5ff; color: var(--umax-navy); font-weight: 700; }
.bloomy-umax-table thead th.is-bloomy { background: linear-gradient(135deg, #1677f2, #2f9bdf); color: #fff; }
.bloomy-umax-table td:first-child { font-weight: 700; color: var(--umax-ink); white-space: nowrap; }
.bloomy-umax-table tr:last-child td, .bloomy-umax-table tbody tr:last-child td { border-bottom: 0; }
.bloomy-umax-table .is-bloomy-row td { background: #eef5ff; font-weight: 700; }

/* 仕組み steps */
.bloomy-umax-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; }
.bloomy-umax-step { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--umax-line); border-radius: 16px; padding: 16px 18px; }
.bloomy-umax-step__num { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 50%; background: var(--umax-blue); color: #fff; font-weight: 800; display: inline-flex; align-items: center; justify-content: center; }
.bloomy-umax-step p { margin: 0; font-size: 14px; font-weight: 700; color: var(--umax-navy); line-height: 1.55; }

/* 注意点 list */
.bloomy-umax-list { margin: 0; padding-left: 1.2em; }
.bloomy-umax-list li { margin: 0 0 10px; font-size: 14.5px; line-height: 1.85; color: var(--umax-sub); }

/* FAQ */
.bloomy-umax-faq { display: flex; flex-direction: column; gap: 10px; }
.bloomy-umax-faq__item { background: #fff; border: 1px solid var(--umax-line); border-radius: 14px; overflow: hidden; }
.bloomy-umax-faq__q { list-style: none; cursor: pointer; padding: 15px 18px; font-size: 14.5px; font-weight: 800; color: var(--umax-navy); position: relative; padding-right: 42px; }
.bloomy-umax-faq__q::-webkit-details-marker { display: none; }
.bloomy-umax-faq__q::after { content: "+"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); font-size: 20px; font-weight: 700; color: var(--umax-blue); }
.bloomy-umax-faq__item[open] .bloomy-umax-faq__q::after { content: "−"; }
.bloomy-umax-faq__a { padding: 0 18px 16px; font-size: 14px; line-height: 1.85; color: var(--umax-sub); }

/* 最終CTA */
.bloomy-umax-finalcta { padding: 10px 0 56px; }
.bloomy-umax-finalcta__card {
  text-align: center; padding: 38px 26px; border-radius: 24px;
  background: linear-gradient(160deg, #0b1f44, #173a85);
  box-shadow: 0 26px 60px -34px rgba(11, 31, 68, 0.6);
}
.bloomy-umax-finalcta__copy { margin: 0 0 12px; font-size: clamp(14px, 4.3vw, 28px); font-weight: 800; color: #fff; letter-spacing: -0.02em; white-space: nowrap; }
.bloomy-umax-finalcta__lead { margin: 0 auto 22px; max-width: 560px; font-size: 14px; line-height: 1.8; color: #cdd9f0; }
.bloomy-umax-finalcta .bloomy-umax-btn--primary { background: #fff; color: var(--umax-navy); }
.bloomy-umax-finalcta .bloomy-umax-btn--primary:hover { background: #eef5ff; }

@media (max-width: 600px) {
  .bloomy-umax-section { padding: 34px 0; }
  .bloomy-umax-hero__card { padding: 20px 16px 18px; border-radius: 20px; }
  .bloomy-umax-values { grid-template-columns: 1fr 1fr; }
  /* タイトル「Bloomy Unlimited Max」をモバイルでも1行に収める（画面幅に追従＋折り返し禁止）。 */
  .bloomy-umax-hero__title { font-size: clamp(18px, 6.8vw, 30px); white-space: nowrap; }
  /* 最終CTAコピーをモバイルでも1行に収める（カード余白を詰めて確保）。 */
  .bloomy-umax-finalcta__card { padding: 30px 16px; }
}

/* === ブラッシュアップ追加（結論/定義/利用シーン/関連/更新日）＋比較表の幅修正 === */
/* 比較表: 列が潰れて「低速化」が縦に伸びるのを防ぐ。最小幅を確保し、狭い画面はラッパー内で横スクロール（ページははみ出さない）。 */
.bloomy-umax-table--2col { min-width: 480px; }
.bloomy-umax-table--brands { min-width: 680px; }
.bloomy-umax-table--brands th:first-child, .bloomy-umax-table--brands td:first-child { width: 18%; }
.bloomy-umax-table th, .bloomy-umax-table td { white-space: normal; }
.bloomy-umax-table td:first-child { white-space: nowrap; }
.bloomy-umax-tablewrap { position: relative; }
.bloomy-umax-tablewrap:focus { outline: 2px solid #bcd4fb; outline-offset: 2px; }

/* 更新日 */
.bloomy-umax-updated { margin: 12px 0 0; text-align: center; font-size: 12px; color: #8a93a5; }

/* 結論ブロック */
.bloomy-umax-conclusion { background: #eef5ff; border: 1px solid #dcebfd; border-radius: 18px; padding: 22px 22px 18px; }
.bloomy-umax-conclusion__title { margin: 0 0 12px; font-size: 16px; font-weight: 800; color: var(--umax-navy); }
.bloomy-umax-conclusion ul { margin: 0; padding-left: 1.2em; }
.bloomy-umax-conclusion li { margin: 0 0 9px; font-size: 14.5px; line-height: 1.8; color: #31506f; font-weight: 600; }

/* 定義カード */
.bloomy-umax-defs { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-top: 18px; }
.bloomy-umax-def { background: #fff; border: 1px solid var(--umax-line); border-radius: 14px; padding: 16px 16px; }
.bloomy-umax-def h3 { margin: 0 0 7px; font-size: 14px; font-weight: 800; color: var(--umax-ink); }
.bloomy-umax-def p { margin: 0; font-size: 13px; line-height: 1.75; color: var(--umax-sub); }

/* 利用シーン */
.bloomy-umax-usecases { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; }
.bloomy-umax-usecase { display: flex; align-items: flex-start; gap: 9px; background: #fff; border: 1px solid var(--umax-line); border-radius: 12px; padding: 13px 15px; font-size: 14px; font-weight: 700; color: var(--umax-navy); line-height: 1.55; }
.bloomy-umax-usecase span { color: var(--umax-blue); font-size: 11px; margin-top: 3px; flex: 0 0 auto; }

/* 関連リンク */
.bloomy-umax-related { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.bloomy-umax-related a { display: block; background: #fff; border: 1px solid var(--umax-line); border-radius: 12px; padding: 14px 16px; color: var(--umax-ink); font-weight: 700; font-size: 14px; text-decoration: none; transition: border-color .15s ease, background .15s ease; }
.bloomy-umax-related a:hover { border-color: #cfe0fb; background: #f5f9ff; }
