/** Shopify CDN: Minification failed

Line 46:0 All "@import" rules must come first

**/
/* =====================================================
   page-soundcore-speaker-lineup
   Faithful to Figma (1440 base width)
   ===================================================== */

/* parent overflow override (sticky を機能させるため) ===== */
.page-container:has(.soundcore-speaker-lineup),
.themeV2:has(.soundcore-speaker-lineup),
.page-container:has(.soundcore-speaker-lineup) .main-content,
.page-container:has(.soundcore-speaker-lineup) .content__body,
.page-container:has(.soundcore-speaker-lineup) .page-width {
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
}

/* lp-soundcore-foot snippet override — タイトル白 + 親 .soundcore-speaker-lineup の color 継承を打ち消す */
.themeV2:has(.soundcore-speaker-lineup) .lp-soundcore-foot .lineup-list .lineup-item-title,
.themeV2:has(.soundcore-speaker-lineup) .lp-soundcore-foot .lineup-list a {
  color: #fff;
}
.themeV2:has(.soundcore-speaker-lineup) .lp-soundcore-foot .lineup-list .lineup-item-desc {
  color: rgba(255, 255, 255, 0.85);
}
.themeV2:has(.soundcore-speaker-lineup) .lp-soundcore-foot .lineup-list .view-more-link {
  color: #fff;
  background: rgba(0, 0, 0, 0.35);
}
/* 念のため bg img が読めない場合のフォールバック */
.themeV2:has(.soundcore-speaker-lineup) .lp-soundcore-foot .lineup-list li {
  background: linear-gradient(135deg, #2a3b4f 0%, #4a5d75 100%);
}
/* Lineup snippet: タイトルとカードを同じ max-width で中央寄せ */
@media screen and (min-width: 960px) {
  .themeV2:has(.soundcore-speaker-lineup) .lp-soundcore-foot .Lineup .lineup-inner {
    max-width: 1400px;
    margin-inline: auto;
  }
}

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap");

@font-face {
  font-family: "Mont For Anker";
  src: url("/cdn/shop/files/MontForAnker-Regular.woff2?v=1736241676") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Mont For Anker";
  src: url("/cdn/shop/files/MontForAnker-Book.woff?v=1736241662") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

/* base ============================================== */
.soundcore-speaker-lineup {
  --c-black: #1a1a1a;
  --c-text-gray: #666;
  --c-award-text: #413c3c;
  --c-brand-cyan: #00a9e0;
  --c-link-cyan: #00abea;
  --c-amazon: #ffa600;
  --c-light-bg: #ced5e2;
  --c-section-bg: #d7dfec;
  --c-new-bg: #d7e9f4;
  --c-feat-bg: #c8e4f1;
  --c-divider: rgba(26, 26, 26, 0.1);

  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
  font-feature-settings: "palt" 1;
  color: var(--c-black);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  background: var(--c-section-bg);
  isolation: isolate;
}
.soundcore-speaker-lineup .lp-soundcore-foot .lineup-list .bg { z-index: 0; }
.soundcore-speaker-lineup .lp-soundcore-foot .lineup-list a { position: absolute; z-index: 1; }
.soundcore-speaker-lineup * { box-sizing: border-box; }
.soundcore-speaker-lineup h1, .soundcore-speaker-lineup h2, .soundcore-speaker-lineup h3 { margin: 0; padding: 0; font-size: inherit; font-weight: inherit; line-height: inherit; }
.soundcore-speaker-lineup p { margin: 0; }
.soundcore-speaker-lineup ul, .soundcore-speaker-lineup ol { margin: 0; padding: 0; list-style: none; }
.soundcore-speaker-lineup img, .soundcore-speaker-lineup picture { display: block; max-width: 100%; height: auto; }
.soundcore-speaker-lineup button { font-family: inherit; cursor: pointer; border: none; background: none; padding: 0; }
.soundcore-speaker-lineup a { color: inherit; text-decoration: none; }
.soundcore-speaker-lineup sup { font-size: 0.7em; vertical-align: super; }

/* shared pill button */
.soundcore-speaker-lineup .m-pillbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 20px;
  border-radius: 100px;
  font-size: 13px;
  letter-spacing: 0.04em;
  line-height: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt" 1;
  white-space: nowrap;
  transition: opacity 0.2s ease;
}
.soundcore-speaker-lineup .m-pillbtn:hover { opacity: 0.85; }
.soundcore-speaker-lineup .m-pillbtn.-primary { background: var(--c-black); color: #fff; }
.soundcore-speaker-lineup .m-pillbtn.-amazon { background: rgba(255,255,255,0.7); color: var(--c-black); border: 1px solid var(--c-amazon); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); }

/* shared text link */
.soundcore-speaker-lineup .m-textlink {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--c-link-cyan);
  font-size: 12px;
  line-height: normal;
}
.soundcore-speaker-lineup .m-textlink img { width: 4px; height: 8px; }

/* shared stars (Unicode ★) */
.soundcore-speaker-lineup .m-stars {
  display: flex;
  gap: 2px;
  color: #f5b800;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.04em;
}
.soundcore-speaker-lineup .m-stars li { width: auto; height: auto; }
.soundcore-speaker-lineup .m-stars img { display: none; }

/* =====================================================
   1. Kv (KV)
   Figma 64:803 - 1440 × 842
   ===================================================== */
.soundcore-speaker-lineup .Kv {
  position: relative;
  width: 100%;
  background: #d7dfec;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.soundcore-speaker-lineup .Kv .Kv-inner {
  display: flex;
  flex-direction: column;
  gap: 40px;
  position: relative;
  z-index: 2;
}
.soundcore-speaker-lineup .Kv .Kv-bg {
  display: block;
  width: 100%;
}
.soundcore-speaker-lineup .Kv .Kv-bg-img { display: block; width: 100%; height: auto; }
.soundcore-speaker-lineup .Kv .Kv-logo {
  display: block;
  margin: 0 0 0 20px;
  width: 71px;
  height: auto;
  z-index: 3;
}
.soundcore-speaker-lineup .Kv .Kv-no1 {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 72px;
  height: auto;
  z-index: 2;
}
.soundcore-speaker-lineup .Kv .Kv-text {
  position: relative;
  z-index: 2;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-start;
}
.soundcore-speaker-lineup .Kv .Kv-title {
  display: flex;
  flex-direction: column;
  gap: 12px;
  line-height: 1;
  color: var(--c-black);
}
.soundcore-speaker-lineup .Kv .Kv-title-row {
  display: inline-flex;
  align-items: flex-end;
  gap: 4px;
  white-space: nowrap;
}
.soundcore-speaker-lineup .Kv .Kv-title-en {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 23px;
  letter-spacing: 0.05em;
  line-height: 1;
  transform: translateY(0.18em);
}
.soundcore-speaker-lineup .Kv .Kv-title-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 1;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .Kv .Kv-cta { display: flex; gap: 10px; flex-wrap: nowrap; }
.soundcore-speaker-lineup .Kv .Kv-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  border-radius: 100px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  letter-spacing: 0.04em;
  line-height: 1;
  font-feature-settings: "palt" 1;
  white-space: nowrap;
  transition: opacity 0.2s ease;
}
.soundcore-speaker-lineup .Kv .Kv-btn:hover { opacity: 0.85; }
.soundcore-speaker-lineup .Kv .Kv-btn.-primary { background: var(--c-black); color: #fff; }
.soundcore-speaker-lineup .Kv .Kv-btn.-outline { background: transparent; color: var(--c-black); border: 0.75px solid var(--c-black); }
.soundcore-speaker-lineup .Kv .Kv-gradient {
  display: none;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 80px;
  background: linear-gradient(180deg, rgba(215, 223, 236, 0) 0%, #d7dfec 100%);
  pointer-events: none;
  z-index: 1;
}
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Kv { height: 842px; max-height: 842px; display: block; gap: 0; }
  .soundcore-speaker-lineup .Kv .Kv-inner { position: relative; max-width: 1440px; height: 100%; margin-inline: auto; }
  .soundcore-speaker-lineup .Kv .Kv-gradient { display: block; }
  .soundcore-speaker-lineup .Kv .Kv-logo { position: absolute; margin: 0; }
  .soundcore-speaker-lineup .Kv .Kv-bg { position: absolute; top: -290px; left: 50%; transform: translateX(-50%); right: auto; width: 2032px; max-width: none; height: 1132px; margin-left: 0; }
  .soundcore-speaker-lineup .Kv .Kv-bg-img { width: 100%; height: 100%; object-fit: cover; }
  .soundcore-speaker-lineup .Kv .Kv-logo { top: 0; left: 40px; width: 152px; z-index: 3; }
  .soundcore-speaker-lineup .Kv .Kv-no1 { top: 40px; right: 40px; width: 125px; }
  .soundcore-speaker-lineup .Kv .Kv-text { position: absolute; top: 180px; left: 40px; padding: 0; gap: 25px; }
  .soundcore-speaker-lineup .Kv .Kv-title { gap: 25px; }
  .soundcore-speaker-lineup .Kv .Kv-title-en { font-size: 40px; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .Kv .Kv-title-jp { font-size: 31.25px; letter-spacing: 0.1em; }
  .soundcore-speaker-lineup .Kv .Kv-btn { padding: 16px 24px; font-size: 14px; }
  .soundcore-speaker-lineup .Kv .Kv-gradient { height: 160px; }
}

/* =====================================================
   2. BrandBar
   Figma 64:818 - 1440 × 419
   ===================================================== */
.soundcore-speaker-lineup .BrandBar { background: transparent; padding: 40px 20px; }
.soundcore-speaker-lineup .BrandBar-inner { max-width: 1440px; margin-inline: auto; display: flex; flex-direction: column; gap: 20px; align-items: center; }
.soundcore-speaker-lineup .BrandBar-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.45;
  color: var(--c-black);
  text-align: center;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .BrandBar-stats {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
  align-items: center;
}
.soundcore-speaker-lineup .BrandBar-divider {
  display: block;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.1);
}
.soundcore-speaker-lineup .m-stat {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  flex: 1;
}
.soundcore-speaker-lineup .m-stat.-no1 { display: flex; flex-direction: row; gap: 14px; align-items: center; padding: 10px 0; }
.soundcore-speaker-lineup .m-stat .m-stat-icon { width: 124.5px; height: auto; flex-shrink: 0; }
.soundcore-speaker-lineup .m-stat .m-stat-body { display: flex; flex-direction: column; gap: 10px; align-items: center; }
.soundcore-speaker-lineup .m-stat .m-stat-label {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.3;
  color: #111;
  text-align: center;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-stat .m-stat-value {
  display: inline-flex;
  align-items: baseline;
  gap: 0;
  position: relative;
  color: var(--c-black);
}
.soundcore-speaker-lineup .m-stat .m-stat-value {
  display: flex;
  align-items: flex-end;
  gap: 0;
}
.soundcore-speaker-lineup .m-stat .m-stat-mark {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 80px;
  line-height: 1;
  transform: translateY(0.18em);
}
.soundcore-speaker-lineup .m-stat .m-stat-mark-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 60px;
  line-height: 1;
  margin-left: 2px;
}
.soundcore-speaker-lineup .m-stat .m-stat-unit {
  display: inline-flex;
  flex-direction: column;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 22px;
  line-height: 1.1;
  margin-left: 2px;
}
.soundcore-speaker-lineup .m-stat .m-stat-sup { font-size: 11.37px; opacity: 0.4; margin-left: 2px; }
.soundcore-speaker-lineup .m-stat.-world { padding: 30px 0; }
.soundcore-speaker-lineup .m-stat.-world .m-stat-label { font-size: 18px; }
.soundcore-speaker-lineup .m-stat.-world .m-stat-mark { font-size: 79px; }
.soundcore-speaker-lineup .m-stat.-world .m-stat-bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 333px;
  max-width: none;
  height: auto;
  z-index: -1;
  opacity: 0.6;
}
.soundcore-speaker-lineup .m-stat.-awards { width: 100%; gap: 10px; padding: 10px 0; }
.soundcore-speaker-lineup .m-stat.-awards .m-stat-label { font-size: 18px; }
.soundcore-speaker-lineup .m-stat.-awards .m-awards { display: flex; gap: 7.732px; width: 100%; justify-content: center; align-items: flex-start; }
.soundcore-speaker-lineup .m-award { display: flex; flex-direction: column; align-items: center; gap: 15px; flex: 1 1 0; min-width: 0; }
.soundcore-speaker-lineup .m-award-img-wrap { height: 70px; display: flex; align-items: center; justify-content: center; }
.soundcore-speaker-lineup .m-award-img { width: auto; height: 100%; max-width: 100%; }
.soundcore-speaker-lineup .m-award-name {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  line-height: 1.35;
  color: var(--c-award-text);
  text-align: center;
}
.soundcore-speaker-lineup .BrandBar-caption {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  line-height: 1.4;
  color: var(--c-text-gray);
  text-align: center;
  font-feature-settings: "palt" 1;
  margin-top: 4px;
}
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .BrandBar { padding: 60px 40px; }
  .soundcore-speaker-lineup .BrandBar-heading { font-size: 24px; line-height: 1; }
  .soundcore-speaker-lineup .BrandBar-stats { flex-direction: row; gap: 40px; align-items: stretch; justify-content: center; }
  .soundcore-speaker-lineup .BrandBar-divider { width: 1px; height: auto; background: var(--c-divider); align-self: stretch; }
  .soundcore-speaker-lineup .m-stat { padding: 24px 0; }
  .soundcore-speaker-lineup .m-stat.-no1 { padding: 24px 0; }
  .soundcore-speaker-lineup .m-stat .m-stat-label { font-size: 16px; }
  .soundcore-speaker-lineup .m-stat .m-stat-mark { font-size: 106px; }
  .soundcore-speaker-lineup .m-stat .m-stat-mark-jp { font-size: 78px; }
  .soundcore-speaker-lineup .m-stat.-world { padding: 24px 0; }
  .soundcore-speaker-lineup .m-stat.-world .m-stat-mark { font-size: 106px; }
  .soundcore-speaker-lineup .m-stat.-awards { width: auto; padding: 24px 0; }
  .soundcore-speaker-lineup .m-award-name { font-size: 12px; }
}

/* =====================================================
   3. New (Boom Go 3i) — Figma 85:2937 (660h × full-w card)
   ===================================================== */
.soundcore-speaker-lineup .New {
  position: relative;
  /* 画面の右端まで card と同じ水色グラデで埋める (card 外周に黒や
     ぼかし lifestyle 画像が見えないように)。 */
  background: linear-gradient(180deg, #e8f1f8 0%, #d7e9f4 100%);
  padding: 10px;
  overflow: hidden;
  isolation: isolate;
}
.soundcore-speaker-lineup .New::before { content: none; }
/* PC でも装飾用のぼかし lifestyle 画像は使わない (右端まで水色で
   塗りつぶしたいので不要)。 */
.soundcore-speaker-lineup .New-section-bg { display: none !important; }
.soundcore-speaker-lineup .New-card {
  position: relative;
  z-index: 1;
  background: #d7e9f4;
  border-radius: 8px;
  padding: 80px 10px 40px;
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow: visible;
  isolation: isolate;
}
.soundcore-speaker-lineup .New-bg {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  z-index: 1;
  pointer-events: none;
  aspect-ratio: 360 / 268;
  margin-top: -214px;
}
/* lifestyle 画像のトリミング — PC/SP とも右寄せ (object-position: right) で
   cover crop し、被写体 (手元の本体) を右側に寄せる。 */
.soundcore-speaker-lineup .New-bg-img { width: 100%; height: 100%; object-fit: cover; object-position: right center; display: block; }
.soundcore-speaker-lineup .New-features { margin-top: 0; }
.soundcore-speaker-lineup .New-buybar { margin-top: 20px; }

.soundcore-speaker-lineup .New-badge {
  position: absolute;
  top: -10px;
  left: -10px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(255,255,255,0.5);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 13px;
  line-height: 1.15;
  letter-spacing: 0.05em;
  color: var(--c-black);
  text-align: center;
  font-feature-settings: "palt" 1;
}

.soundcore-speaker-lineup .New-text {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  z-index: 2;
}
.soundcore-speaker-lineup .New-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}

.soundcore-speaker-lineup .New-variants {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  width: 180px;
  position: relative;
  z-index: 2;
}
.soundcore-speaker-lineup .New-variants li {
  flex: 0 0 90px;
  width: 90px;
  height: 130px;
  margin: 0;
}
.soundcore-speaker-lineup .New-variants li:last-child { margin-right: 0; }
.soundcore-speaker-lineup .New-variants img { width: 100%; height: 100%; object-fit: cover; display: block; }

.soundcore-speaker-lineup .New-features { display: block; }
.soundcore-speaker-lineup .New-features img { display: block; width: 100%; height: auto; }
.soundcore-speaker-lineup .New-caption {
  position: relative;
  z-index: 2;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  margin-top: 12px;
  padding: 0 10px;
}
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .New-caption { font-size: 11px; padding: 0 40px; margin-top: 16px; max-width: 1440px; margin-inline: auto; }
}

.soundcore-speaker-lineup .New-awards { position: absolute; top: 24px; right: 20px; bottom: auto; z-index: 4; display: flex; gap: 10px; }
.soundcore-speaker-lineup .New-awards li { height: 32px; width: 60.7px; }
.soundcore-speaker-lineup .New-awards img { height: 100%; width: 100%; object-fit: contain; }

/* Buybar */
.soundcore-speaker-lineup .New-buybar {
  position: relative;
  z-index: 2;
  background: transparent;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  border-top: none;
}
.soundcore-speaker-lineup .New-buybar-info { display: flex; flex-direction: column; gap: 10px; width: 248px; max-width: 100%; }
.soundcore-speaker-lineup .New-buybar-name {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .New-buybar-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.soundcore-speaker-lineup .New-buybar-price {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 16px;
  letter-spacing: 0.05em;
  color: var(--c-black);
}
.soundcore-speaker-lineup .New-buybar-price .product-price-v2-default { font-family: inherit; font-size: inherit; letter-spacing: inherit; color: inherit; }
.soundcore-speaker-lineup .New-buybar-divider {
  display: block;
  width: 100%;
  height: 1px;
  background: rgba(26,26,26,0.1);
}

/* image-style color swatches (24×24 product images, white border on selected) */
.soundcore-speaker-lineup .m-color-swatches.-img {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
}
.soundcore-speaker-lineup .m-color-swatches.-img li {
  padding: 2px;
  border: 1px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 0.2s ease;
  outline: none;
}
.soundcore-speaker-lineup .m-color-swatches.-img li.is-selected { border-color: var(--c-black); }
.soundcore-speaker-lineup .m-color-swatches.-img li:focus-visible { border-color: var(--c-anker, #00a9e0); }
.soundcore-speaker-lineup .m-detail-card-overlay .m-color-swatches.-img li.is-selected { border-color: #fff; }
.soundcore-speaker-lineup .m-color-swatches.-img li > span {
  display: block;
  width: 24px;
  height: 24px;
  border-radius: 2px;
  overflow: hidden;
  background: #fff;
}
.soundcore-speaker-lineup .m-color-swatches.-img li img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* lp-btns wrapping → pill-style buttons inside New-buybar */
.soundcore-speaker-lineup .New-buybar-actions { display: flex; flex-direction: column; gap: 10px; width: 258px; max-width: 100%; align-items: center; }
.soundcore-speaker-lineup .New-buybar-actions .lp-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.soundcore-speaker-lineup .New-buybar-actions .lp-btns > li:not(.is-more) { flex: 1 1 0; min-width: 0; }
.soundcore-speaker-lineup .New-buybar-actions .lp-btns > li.is-more { flex: 1 1 100%; }
.soundcore-speaker-lineup .New-buybar-actions .lp-btn,
.soundcore-speaker-lineup .New-buybar-actions .lp-btn-amazon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 16px 20px;
  border-radius: 100px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.04em;
  text-decoration: none;
  white-space: nowrap;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .New-buybar-actions .lp-btn { background: var(--c-brand-cyan); color: #fff; }
.soundcore-speaker-lineup .New-buybar-actions .lp-btn.-inactive { background: #999; pointer-events: none; }
.soundcore-speaker-lineup .New-buybar-actions .lp-btn-amazon {
  background: rgba(255,255,255,0.7);
  color: var(--c-black);
  border: 1px solid #ffa600;
  backdrop-filter: blur(5.5px);
  -webkit-backdrop-filter: blur(5.5px);
}
.soundcore-speaker-lineup .New-buybar-actions .lp-txtLink {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #00abea;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  text-decoration: none;
}
.soundcore-speaker-lineup .New-buybar-actions .lp-txtLink svg,
.soundcore-speaker-lineup .New-buybar-actions .lp-txtLink img { width: 4px; height: 8px; }
.soundcore-speaker-lineup .lp-txtLink .icon-svg-arrow svg,
.soundcore-speaker-lineup .lp-txtLink .icon-svg-arrow svg path { fill: #fff; }

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .New { padding: 40px; }
  .soundcore-speaker-lineup .New-card { max-width: 1360px; margin-inline: auto; }
  .soundcore-speaker-lineup .New-card { height: 660px; display: block; background: var(--c-new-bg); border-radius: 16px; padding: 0; gap: 0; overflow: visible; }
  .soundcore-speaker-lineup .New-bg { position: absolute; bottom: 0; right: 0; width: 979px; height: 660px; aspect-ratio: auto; margin-top: 0; }
  .soundcore-speaker-lineup .New-badge { top: -10px; left: -10px; width: 90px; height: 90px; font-family: "Mont For Anker", "Noto Sans JP", sans-serif; font-weight: 500; font-size: 14px; letter-spacing: 0.08em; background: rgba(255,255,255,0.85); }
  .soundcore-speaker-lineup .New-text { display: flex; flex-direction: column; padding: 100px 40px 0; gap: 16px; width: 1000px; position: relative; z-index: 2; }
  .soundcore-speaker-lineup .New-features { margin-top: 0; }
  .soundcore-speaker-lineup .New-buybar { margin-top: 0; }
  .soundcore-speaker-lineup .New-heading { font-size: 32px; letter-spacing: 0.05em; line-height: 1.5; }

  .soundcore-speaker-lineup .New-variants { height: 180px; padding-right: 11px; width: 628px; flex-wrap: nowrap; margin-bottom: 0; }
  .soundcore-speaker-lineup .New-variants li { height: 100%; width: 140px; flex: none; margin-right: -11px; box-shadow: none; }
  .soundcore-speaker-lineup .New-variants img { object-fit: contain; }

  .soundcore-speaker-lineup .New-features { width: 920px; position: relative; z-index: 2; padding-left: 40px; }

  .soundcore-speaker-lineup .New-awards { bottom: 26px; right: 20px; top: auto; gap: 8px; }
  .soundcore-speaker-lineup .New-awards li { height: 40px; width: auto; }
  .soundcore-speaker-lineup .New-awards img { width: auto; }

  .soundcore-speaker-lineup .New-buybar {
    /* なだらかな S 字フェード（ease-in-out）。急に濃くならないよう多段化。
       購入バー本体と右側の継ぎ足し ::before で共通利用する。 */
    --new-fade: linear-gradient(180deg,
      rgba(215, 233, 244, 0) 0%,
      rgba(215, 233, 244, 0.03) 9%,
      rgba(215, 233, 244, 0.10) 16%,
      rgba(215, 233, 244, 0.21) 23%,
      rgba(215, 233, 244, 0.36) 30%,
      rgba(215, 233, 244, 0.53) 37%,
      rgba(215, 233, 244, 0.69) 44%,
      rgba(215, 233, 244, 0.82) 51%,
      rgba(215, 233, 244, 0.92) 58%,
      rgba(215, 233, 244, 0.98) 65%,
      var(--c-new-bg) 72%
    );
    position: absolute;
    bottom: 0;
    left: 0;
    width: 778px;
    padding: 30px 40px;
    flex-direction: row;
    gap: 30px;
    align-items: center;
    background: var(--new-fade);
    border-top: none;
    z-index: 3;
  }
  /* 購入バー(左 778px)の同じフェードを、その右側＝lifestyle 写真の下端まで
     カード右端 (1360px) まで継ぎ足す。高さは購入バーと同一 (top/bottom:0)。
     コンテンツ(ボタン等)の配置は 778px のまま変えない。 */
  .soundcore-speaker-lineup .New-buybar::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 100%;
    width: 582px;
    background: var(--new-fade);
    border-radius: 0 0 16px 0;
    pointer-events: none;
    z-index: -1;
  }
  .soundcore-speaker-lineup .New-buybar-info { gap: 10px; flex: 1; min-width: 0; width: auto; }
  .soundcore-speaker-lineup .New-buybar-name { font-size: 20px; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .New-buybar-divider { width: 1px; height: auto; align-self: stretch; }
  .soundcore-speaker-lineup .New-buybar-actions { width: 258px; flex: 0 0 258px; align-items: stretch; }
}

/* =====================================================
   4. Lineup
   Figma 64:1000 - 1440 × 1259
   ===================================================== */
.soundcore-speaker-lineup .Lineup { background: #d7dfec; padding: 60px 20px; }
.soundcore-speaker-lineup .Lineup-inner { max-width: 1440px; margin-inline: auto; display: flex; flex-direction: column; gap: 40px; }
.soundcore-speaker-lineup .Lineup-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .Lineup-heading .sp-only { display: inline; }
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Lineup-heading .sp-only { display: none; }
}
.soundcore-speaker-lineup .Lineup-cols {
  display: flex;
  flex-direction: row;
  gap: 20px;
  align-items: stretch;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 20px;
  scrollbar-width: none;
  margin: 0 -20px;
  padding: 0 20px;
  -webkit-overflow-scrolling: touch;
}
.soundcore-speaker-lineup .Lineup-cols::before {
  content: "";
  flex: 0 0 0;
}
.soundcore-speaker-lineup .Lineup-cols::-webkit-scrollbar { display: none; }
.soundcore-speaker-lineup .Lineup-divider { display: block; width: 1px; flex: 0 0 1px; background: rgba(26,26,26,0.1); align-self: stretch; }
.soundcore-speaker-lineup .m-col {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 40px 0;
  flex: 0 0 calc(100vw - 80px);
  width: calc(100vw - 80px);
  max-width: 320px;
  scroll-snap-align: start;
}
.soundcore-speaker-lineup .m-col-num {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 48px;
  line-height: 1;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-col-desc {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-col-products { display: flex; flex-wrap: wrap; gap: 15px; }
.soundcore-speaker-lineup .m-col-products > li { width: calc((100% - 15px) / 2); max-width: 152.5px; }

.soundcore-speaker-lineup .m-product {
  position: relative;
  display: block;
  background: #ced5e2;
  border-radius: 9px;
  aspect-ratio: 1 / 1;
  overflow: visible;
  padding: 8px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1),
              box-shadow 0.3s ease;
}
.soundcore-speaker-lineup .Lineup .m-product:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px -10px rgba(0,0,0,0.18);
}
.soundcore-speaker-lineup .m-product-img {
  position: absolute;
  top: -7.5px;
  left: 50%;
  transform: translateX(-50%);
  width: 110%;
  height: 110%;
  object-fit: contain;
  filter: drop-shadow(8px 10px 25px rgba(0,0,0,0.24));
}
.soundcore-speaker-lineup .m-product-name {
  position: absolute;
  bottom: 14px;
  left: 8px;
  font-family: "Mont For Anker", sans-serif;
  font-weight: 300;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--c-black);
  z-index: 2;
}
.soundcore-speaker-lineup .m-product-flag {
  position: absolute;
  top: -7.5px;
  right: -7.5px;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #69707b;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 9.8px;
  line-height: 1.15;
  letter-spacing: 0.05em;
  text-align: center;
}

.soundcore-speaker-lineup .Lineup-features-wrap {
  width: 100%;
  border-top: 1px solid rgba(26,26,26,0.1);
  padding: 10px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: stretch;
}
.soundcore-speaker-lineup .Lineup-features-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  margin: 0;
}
.soundcore-speaker-lineup .Lineup-features-toggle { align-self: flex-end; }
.soundcore-speaker-lineup .Lineup-features-caption {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-text-gray);
  font-feature-settings: "palt" 1;
  margin-top: 12px;
}
.soundcore-speaker-lineup .Lineup-features-toggle {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: none;
  background: transparent;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-decoration: none;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  cursor: pointer;
}
.soundcore-speaker-lineup .Lineup-features-toggle-arrow {
  width: 6px;
  height: 6px;
  border-right: 1.5px solid var(--c-black);
  border-bottom: 1.5px solid var(--c-black);
  transform: rotate(45deg) translate(-2px, -2px);
  transition: transform 0.3s ease;
}
.soundcore-speaker-lineup .Lineup-features-wrap.is-expanded .Lineup-features-toggle-arrow {
  transform: rotate(-135deg) translate(-2px, -2px);
}
.soundcore-speaker-lineup .m-feat-desc { display: none; }
.soundcore-speaker-lineup .Lineup-features-wrap.is-expanded .m-feat-desc { display: block; }
.soundcore-speaker-lineup .Lineup-features { display: flex; flex-wrap: wrap; gap: 10px; width: 100%; }
.soundcore-speaker-lineup .m-feat {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 8px;
  background: rgba(255,255,255,0.15);
  border-radius: 8px;
  flex: 1 1 calc(50% - 5px);
  min-width: 0;
}
.soundcore-speaker-lineup .m-feat-icon { width: 40px; height: 40px; }
.soundcore-speaker-lineup .m-feat-title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-feat-desc {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-text-gray);
  font-feature-settings: "palt" 1;
}

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Lineup { padding: 60px 40px; }
  .soundcore-speaker-lineup .Lineup-inner { gap: 40px; }
  .soundcore-speaker-lineup .Lineup-heading { font-size: 28px; line-height: 1.5; letter-spacing: 0.05em; }
  /* gap / padding を詰めて product image にできるだけ広い面積を割く */
  .soundcore-speaker-lineup .Lineup-cols { gap: 24px; overflow-x: visible; margin: 0 -40px; padding: 0; scroll-snap-type: none; }
  .soundcore-speaker-lineup .Lineup-divider { background: var(--c-divider); }
  .soundcore-speaker-lineup .m-col { gap: 20px; padding: 24px 0; flex: 1; width: auto; max-width: none; min-width: 0; }
  .soundcore-speaker-lineup .m-col-desc { font-size: 14px; letter-spacing: 0.05em; }
  /* grid は col 幅いっぱいに広げ、cell は minmax(0, 1fr) で伸縮。 */
  .soundcore-speaker-lineup .m-col-products { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .soundcore-speaker-lineup .m-col-products > li { width: auto !important; min-width: 0; }
  /* grid cell 幅に合わせて素直に伸縮。aspect-ratio 1:1 で正方形を保つ。 */
  .soundcore-speaker-lineup .m-product { width: 100%; height: auto; aspect-ratio: 1 / 1; padding: 8px; }
  .soundcore-speaker-lineup .m-product-img { width: 110%; height: 110%; top: 0; transform: translate(-50%, -12px); }
  .soundcore-speaker-lineup .m-product-name { font-size: 14px; bottom: 10px; left: 10px; }
  .soundcore-speaker-lineup .m-product-flag { width: 64px; height: 64px; font-size: 13px; top: -10px; right: -10px; }

  .soundcore-speaker-lineup .Lineup-features-wrap { border-top: 1px solid var(--c-divider); padding: 24px 0 0; align-items: stretch; gap: 16px; }
  .soundcore-speaker-lineup .Lineup-features-heading { font-size: 24px; }
  .soundcore-speaker-lineup .Lineup-features-toggle { display: none; }
  .soundcore-speaker-lineup .Lineup-features-caption { font-size: 11px; margin-top: 16px; }
  .soundcore-speaker-lineup .m-feat-desc { display: block; }
  .soundcore-speaker-lineup .Lineup-features { display: grid; grid-template-columns: repeat(6, 1fr); gap: 40px; flex-wrap: nowrap; }
  .soundcore-speaker-lineup .m-feat { padding: 20px 0; gap: 10px; background: transparent; border-radius: 0; flex: none; }
  .soundcore-speaker-lineup .m-feat-icon { width: 40px; height: 40px; }
  .soundcore-speaker-lineup .m-feat-title { font-size: 18px; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .m-feat-desc { font-size: 14px; letter-spacing: 0.05em; }
}

/* =====================================================
   5. Scene
   Figma 64:1075 - 1440 × 1917 (PC: absolute collage)
   ===================================================== */
.soundcore-speaker-lineup .Scene {
  background: linear-gradient(180deg, #d7dfec 0%, #fff 100%);
  padding: 0;
}
.soundcore-speaker-lineup .Scene-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 400 / 1124;
  max-width: 500px;
  margin: 0 auto;
}
.soundcore-speaker-lineup .Scene-heading {
  position: absolute;
  left: 5%;
  top: 0;
  width: auto;
  padding: 11px 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  white-space: nowrap;
}
.soundcore-speaker-lineup .m-scene {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin: 0;
  will-change: transform;
}
.soundcore-speaker-lineup .m-scene-imgwrap { overflow: hidden; border-radius: 2.2px; width: 100%; }
.soundcore-speaker-lineup .m-scene-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 2.2px;
  transform: scale(1.18);
  transform-origin: center;
  will-change: transform;
  transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.soundcore-speaker-lineup .m-scene-cap {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-scene-dot { display: inline-block; width: 4px; height: 4px; background: var(--c-black); border-radius: 50%; flex-shrink: 0; }
.soundcore-speaker-lineup .m-scene.-living { left: 5%; top: 11.7%; width: 55%; }
.soundcore-speaker-lineup .m-scene.-living .m-scene-img { aspect-ratio: 220 / 254; }
.soundcore-speaker-lineup .m-scene.-outdoor { left: 51.5%; top: 40%; width: 43.5%; }
.soundcore-speaker-lineup .m-scene.-outdoor .m-scene-img { aspect-ratio: 174 / 148; }
.soundcore-speaker-lineup .m-scene.-bath { left: 5%; top: 58.8%; width: 43.5%; }
.soundcore-speaker-lineup .m-scene.-bath .m-scene-img { aspect-ratio: 174 / 102; }
.soundcore-speaker-lineup .m-scene.-kitchen { left: 39.25%; top: 75.27%; width: 55.25%; }
.soundcore-speaker-lineup .m-scene.-kitchen .m-scene-img { aspect-ratio: 221 / 170; }
.soundcore-speaker-lineup .m-scene.-living .m-scene-cap,
.soundcore-speaker-lineup .m-scene.-bath .m-scene-cap { justify-content: flex-end; }

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Scene { padding: 60px 40px; }
  /* Figma 1440 × 1917 のキャンバスを viewport 幅に合わせて等比縮小。
     px 固定だと 1440 未満で右にはみ出すので、すべて % に変換する。 */
  .soundcore-speaker-lineup .Scene-stage { position: relative; width: 100%; max-width: 1440px; margin-inline: auto; aspect-ratio: 1440 / 1917; height: auto; }
  .soundcore-speaker-lineup .Scene-heading { right: 0; left: auto; top: 5.43%; padding: 40px clamp(40px, 7.99vw, 115px) 40px 0; width: clamp(280px, 32.43vw, 467px); font-size: clamp(20px, 2.22vw, 32px); line-height: 1.5; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .m-scene { gap: 8px; }
  .soundcore-speaker-lineup .m-scene-imgwrap { border-radius: 8px; }
  .soundcore-speaker-lineup .m-scene-img { width: 100%; height: auto; aspect-ratio: auto; border-radius: 8px; transform: scale(1.18); will-change: transform; transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1); }
  /* living: 544×629 @ left 40 top 0 */
  .soundcore-speaker-lineup .m-scene.-living { left: 2.78%; top: 0; width: 37.78%; }
  .soundcore-speaker-lineup .m-scene.-living .m-scene-img { aspect-ratio: 544 / 629; }
  /* outdoor: 427×364 @ left 973 top 470 */
  .soundcore-speaker-lineup .m-scene.-outdoor { left: 67.57%; top: 24.52%; width: 29.65%; }
  .soundcore-speaker-lineup .m-scene.-outdoor .m-scene-img { aspect-ratio: 427 / 364; }
  /* bath: 584×344 @ left 232 top 801 */
  .soundcore-speaker-lineup .m-scene.-bath { left: 16.11%; top: 41.78%; width: 40.56%; }
  .soundcore-speaker-lineup .m-scene.-bath .m-scene-img { aspect-ratio: 584 / 344; }
  /* kitchen: 661×509 @ left 740 top 1251 */
  .soundcore-speaker-lineup .m-scene.-kitchen { left: 51.39%; top: 65.26%; width: 45.9%; }
  .soundcore-speaker-lineup .m-scene.-kitchen .m-scene-img { aspect-ratio: 661 / 509; }
  .soundcore-speaker-lineup .m-scene-cap { font-size: 14px; gap: 7px; }
}

/* =====================================================
   6. Quiz
   Figma 64:1098 - 1440 × 1602
   ===================================================== */
.soundcore-speaker-lineup .Quiz {
  background: linear-gradient(180deg, #fff 0%, var(--c-section-bg) 15%);
  padding: 60px 20px;
}
.soundcore-speaker-lineup .Quiz-inner { max-width: 1440px; margin-inline: auto; display: flex; flex-direction: column; gap: 32px; }
.soundcore-speaker-lineup .Quiz-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .Quiz-step { display: flex; flex-direction: column; gap: 16px; }
.soundcore-speaker-lineup .Quiz-step[hidden] { display: none; }
.soundcore-speaker-lineup .Quiz-question {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .Quiz-choices { display: grid; gap: 16px; }
.soundcore-speaker-lineup .Quiz-choices.-col2 { grid-template-columns: 1fr 1fr; }
.soundcore-speaker-lineup .Quiz-choices.-col3 { grid-template-columns: 1fr; }
.soundcore-speaker-lineup .Quiz-choices.-col4 { grid-template-columns: 1fr 1fr; }
.soundcore-speaker-lineup .m-quiz-card {
  position: relative;
  overflow: hidden;
  width: 100%;
  min-height: 140px;
  padding: 24px 16px;
  background: #fff;
  border-radius: 8px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-align: center;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  filter: drop-shadow(0 8px 15px rgba(0,0,0,0.12));
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.55s cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 0.55s cubic-bezier(0.22, 0.61, 0.36, 1),
              filter 0.2s ease;
}
.soundcore-speaker-lineup .m-quiz-card:hover { filter: drop-shadow(0 12px 22px rgba(0,0,0,0.18)); }
.soundcore-speaker-lineup .Quiz-choices:hover .m-quiz-card:not(:hover) {
  opacity: 0.55;
  transform: translateY(0) scale(0.97);
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.06));
}

/* A: stagger fade-up — reveals when section is in view + step is active */
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-step.is-active .m-quiz-card { opacity: 1; transform: translateY(0); }
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-step.is-active li:nth-child(1) .m-quiz-card { transition-delay: 0.06s; }
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-step.is-active li:nth-child(2) .m-quiz-card { transition-delay: 0.16s; }
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-step.is-active li:nth-child(3) .m-quiz-card { transition-delay: 0.26s; }
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-step.is-active li:nth-child(4) .m-quiz-card { transition-delay: 0.36s; }

/* heading + question — reveal slightly before cards */
.soundcore-speaker-lineup .Quiz-heading,
.soundcore-speaker-lineup .Quiz-question {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.6s cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-heading { opacity: 1; transform: translateY(0); }
.soundcore-speaker-lineup .Quiz.is-revealed .Quiz-step.is-active .Quiz-question { opacity: 1; transform: translateY(0); transition-delay: 0.05s; }

/* E: click feedback — ripple + scale */
.soundcore-speaker-lineup .m-quiz-card.is-pressing {
  transform: translateY(0) scale(0.96);
  transition: transform 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.soundcore-speaker-lineup .m-quiz-card .m-quiz-ripple {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 169, 224, 0.35) 0%, rgba(0, 169, 224, 0) 70%);
  transform: translate(-50%, -50%) scale(0);
  pointer-events: none;
  animation: sl-ripple 0.6s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
@keyframes sl-ripple {
  to { transform: translate(-50%, -50%) scale(1); opacity: 0; }
}

/* step transition fade */
.soundcore-speaker-lineup .Quiz-step { transition: opacity 0.28s ease; }
.soundcore-speaker-lineup .Quiz-step.is-leaving { opacity: 0; pointer-events: none; }

.soundcore-speaker-lineup .Quiz-results { display: flex; flex-direction: column; gap: 16px; }
.soundcore-speaker-lineup .Quiz-results[hidden] { display: none; }
.soundcore-speaker-lineup .m-quiz-result {
  background: #fff;
  border-radius: 12px;
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  filter: drop-shadow(0 8px 15px rgba(0,0,0,0.12));
}
.soundcore-speaker-lineup .m-quiz-result[hidden] { display: none; }
.soundcore-speaker-lineup .m-quiz-result-imgwrap { position: relative; width: 180px; height: 180px; flex: none; }
.soundcore-speaker-lineup .m-quiz-result-img { width: 100%; height: 100%; object-fit: contain; }
.soundcore-speaker-lineup .m-quiz-result-body { display: flex; flex-direction: column; gap: 10px; align-items: center; text-align: center; }
.soundcore-speaker-lineup .m-quiz-result-name { font-family: "Mont For Anker", sans-serif; font-weight: 400; font-size: 24px; line-height: 1; color: var(--c-black); }
.soundcore-speaker-lineup .m-quiz-result-tagline {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-quiz-result-price { font-family: "Mont For Anker", sans-serif; font-weight: 400; font-size: 18px; letter-spacing: 0.05em; color: var(--c-black); }
.soundcore-speaker-lineup .m-quiz-result-cta { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
.soundcore-speaker-lineup .m-quiz-result-cta .lp-btn { color: #fff; }
.soundcore-speaker-lineup .Quiz-restart {
  align-self: center;
  padding: 12px 24px;
  border: 1px solid var(--c-divider);
  border-radius: 100px;
  font-size: 13px;
  letter-spacing: 0.05em;
  color: var(--c-text-gray);
  background: transparent;
  transition: all 0.2s ease;
}
.soundcore-speaker-lineup .Quiz-restart:hover { background: var(--c-black); color: #fff; border-color: var(--c-black); }

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Quiz { padding: 120px 40px; }
  .soundcore-speaker-lineup .Quiz-inner { gap: 40px; }
  .soundcore-speaker-lineup .Quiz-heading { font-size: 28px; }
  .soundcore-speaker-lineup .Quiz-question { font-size: 20px; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .Quiz-choices { gap: 40px; }
  .soundcore-speaker-lineup .Quiz-choices.-col3 { grid-template-columns: repeat(3, 1fr); }
  .soundcore-speaker-lineup .Quiz-choices.-col4 { grid-template-columns: repeat(4, 1fr); }
  .soundcore-speaker-lineup .m-quiz-card { min-height: 310px; padding: 40px; font-size: 18px; letter-spacing: 0.05em; line-height: 1.5; border-radius: 8px; }

  .soundcore-speaker-lineup .m-quiz-result { flex-direction: row; padding: 40px 80px; gap: 40px; min-height: 310px; align-items: center; border-radius: 12px; }
  .soundcore-speaker-lineup .m-quiz-result-imgwrap { width: 223px; height: 223px; }
  .soundcore-speaker-lineup .m-quiz-result-body { align-items: flex-start; text-align: left; padding: 40px 0; }
  .soundcore-speaker-lineup .m-quiz-result-name { font-size: 32px; }
  .soundcore-speaker-lineup .m-quiz-result-tagline { font-size: 18px; }
  .soundcore-speaker-lineup .m-quiz-result-price { font-size: 20px; }
  .soundcore-speaker-lineup .m-quiz-result-cta { justify-content: flex-start; }
  .soundcore-speaker-lineup .m-quiz-result-cta .lp-btns { justify-content: flex-start; }
  .soundcore-speaker-lineup .m-quiz-result-cta .lp-btns li.is-more { text-align: left; }
  .soundcore-speaker-lineup .m-quiz-result-body .m-color-swatches { justify-content: flex-start; }
}

/* =====================================================
   7. Detail Lineup
   Figma 64:1136 - 4 blocks, each with sticky picker + scrolling cards
   ===================================================== */
.soundcore-speaker-lineup .Detail { background: transparent; padding: 0 20px; }
.soundcore-speaker-lineup .Detail-block { position: relative; margin-bottom: 80px; }
.soundcore-speaker-lineup .Detail-block:last-child { margin-bottom: 0; }
.soundcore-speaker-lineup .Detail-note {
  margin-top: 24px;
  margin-bottom: 80px;
  padding-inline: 20px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11px;
  line-height: 1.6;
  color: #666;
  text-align: left;
}

/* sticky picker内に追従するコンパクト見出し */
.soundcore-speaker-lineup .Detail-picker-head {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.4s cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
  pointer-events: none;
}
.soundcore-speaker-lineup .Detail-picker-num {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 300;
  font-size: 20px;
  line-height: 1;
  color: var(--c-black);
}
.soundcore-speaker-lineup .Detail-picker-title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .Detail-picker-head { display: none; }
.soundcore-speaker-lineup .Detail-block-head {
  position: static;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-start;
  margin: 0 auto 24px;
  max-width: 1440px;
  padding-top: 40px;
  padding-bottom: 0;
  border-top: 1px solid var(--c-divider);
  opacity: 1;
  pointer-events: none;
  transition: gap 0.25s ease, padding 0.25s ease, opacity 0.25s ease;
}
.soundcore-speaker-lineup .Detail-block-head.is-stuck {
  gap: 12px;
  padding-top: 12px;
  padding-bottom: 6px;
  border-top-color: transparent;
}
.soundcore-speaker-lineup .Detail-block-head.is-exiting { opacity: 0; }
.soundcore-speaker-lineup .Detail-block-num {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 72px;
  line-height: 1;
  color: var(--c-black);
  transition: font-size 0.25s ease;
}
.soundcore-speaker-lineup .Detail-block-head.is-stuck .Detail-block-num { font-size: 26px; }
.soundcore-speaker-lineup .Detail-block-title {
  flex: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  transition: font-size 0.25s ease;
}
.soundcore-speaker-lineup .Detail-block-head.is-stuck .Detail-block-title { font-size: 14px; }
.soundcore-speaker-lineup .Detail-block-sentinel { position: absolute; top: 0; left: 0; width: 1px; height: 1px; pointer-events: none; }
.soundcore-speaker-lineup .Detail-block-body { display: flex; flex-direction: column; gap: 30px; max-width: 1440px; margin-inline: auto; }
.soundcore-speaker-lineup .Detail-picker {
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
  position: static;
  z-index: 5;
  overflow-x: auto;
  overflow-y: visible;
  scrollbar-width: none;
  margin: 0 -20px;
  padding: 10px 20px;
  -webkit-overflow-scrolling: touch;
  background: transparent;
}
.soundcore-speaker-lineup .Detail-picker::-webkit-scrollbar { display: none; }
.soundcore-speaker-lineup .Detail-picker > .m-product {
  flex: 0 0 100px;
  width: 100px;
  height: 100px;
  background: #ced5e2;
  border-radius: 6px;
  padding: 8px;
  opacity: 1;
  filter: none;
  transform: scale(1);
  box-shadow: none;
  transition: background 0.3s ease, box-shadow 0.3s ease;
  cursor: pointer;
}
.soundcore-speaker-lineup .Detail-picker > .m-product.is-active {
  background: #fff;
  opacity: 1;
  filter: none;
  transform: none;
  box-shadow: 0 5.9px 7.4px rgba(0,0,0,0.12);
}
.soundcore-speaker-lineup .Detail-picker .m-product-img {
  top: -5px;
  width: 110%;
  height: 110%;
  transform: translateX(-50%);
  filter: drop-shadow(5px 6.5px 17px rgba(0,0,0,0.24));
}
.soundcore-speaker-lineup .Detail-picker .m-product-name { font-size: 12px; bottom: 8px; left: 5px; }

.soundcore-speaker-lineup .Detail-cards { display: flex; flex-direction: column; gap: 40px; }
.soundcore-speaker-lineup .m-detail-card {
  position: relative;
  height: auto;
  display: flex;
  flex-direction: column;
  border-radius: 12px;
  overflow: hidden;
  isolation: isolate;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1.2s cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 1.2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.soundcore-speaker-lineup .m-detail-card-pic { display: contents; }
.soundcore-speaker-lineup .m-detail-card-blur {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(2.5);
  filter: blur(30px) brightness(0.75);
  z-index: -1;
  pointer-events: none;
  user-select: none;
}
.soundcore-speaker-lineup .m-detail-card.is-revealed { opacity: 1; transform: translateY(0); }
.soundcore-speaker-lineup .m-detail-card.is-visible .m-detail-card-bg { transform: scale(1); }
.soundcore-speaker-lineup .m-detail-card-bg {
  position: static;
  width: 100%;
  height: auto;
  aspect-ratio: 893 / 640;
  object-fit: cover;
  display: block;
  transform: scale(1.05);
  transition: transform 2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.soundcore-speaker-lineup .m-detail-card-overlay {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 20px 20px 24px;
  background: rgba(0,0,0,0.55);
  color: #fff;
}
.soundcore-speaker-lineup .m-detail-card-tagline {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #fff;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-detail-card-feats-wrap { position: relative; }
.soundcore-speaker-lineup .m-detail-card-feats-arrow { display: none; }
.soundcore-speaker-lineup .m-detail-card-feats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
  overflow: visible;
  margin: 0;
  padding: 0;
}
.soundcore-speaker-lineup .m-detail-card-feats::-webkit-scrollbar { display: none; }
.soundcore-speaker-lineup .m-detail-card-feats > li {
  list-style: none;
  min-width: 0;
}
.soundcore-speaker-lineup .m-feat-pill {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  gap: 5px;
  padding: 5px 19px 5px 0;
  background: rgba(0,0,0,0.2);
  border-radius: 4px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  line-height: 1.25;
  letter-spacing: 0.05em;
  color: #fff;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-feat-pill-icon {
  display: block;
  flex: none;
  width: 48px;
  height: 48px;
  object-fit: contain;
}
.soundcore-speaker-lineup .m-feat-pill-label {
  display: inline-block;
}
.soundcore-speaker-lineup .m-detail-card-notes {
  display: flex;
  flex-wrap: wrap;
  column-gap: 14px;
  row-gap: 2px;
}
.soundcore-speaker-lineup .m-detail-card-note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  line-height: 1.4;
  color: rgba(255,255,255,0.7);
  font-feature-settings: "palt" 1;
  margin: 0;
}
.soundcore-speaker-lineup .m-detail-card-buy { display: flex; flex-direction: column; gap: 10px; }
.soundcore-speaker-lineup .m-detail-card-buy-info { display: flex; flex-direction: column; gap: 10px; }
.soundcore-speaker-lineup .m-detail-card-buy-name {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #fff;
}
.soundcore-speaker-lineup .m-detail-card-buy-meta { display: flex; align-items: center; justify-content: space-between; gap: 8px; flex-wrap: wrap; }
.soundcore-speaker-lineup .m-detail-card-buy-price {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #fff;
}
.soundcore-speaker-lineup .m-color-swatches {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
}
.soundcore-speaker-lineup .m-color-swatches li {
  padding: 3px;
  border: 1px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 0.2s ease;
  outline: none;
}
.soundcore-speaker-lineup .m-color-swatches li.is-selected { border-color: var(--c-black); }
.soundcore-speaker-lineup .m-color-swatches li:focus-visible { border-color: var(--c-brand-cyan, #00a9e0); }
/* Detail card overlay (dark bg) では白枠を維持 */
.soundcore-speaker-lineup .m-detail-card-overlay .m-color-swatches li.is-selected { border-color: #fff; }
.soundcore-speaker-lineup .m-color-swatches li > span {
  display: block;
  width: 24px;
  height: 24px;
  border-radius: 2px;
  overflow: hidden;
  background: #fff;
}
.soundcore-speaker-lineup .m-color-swatches li img { width: 100%; height: 100%; object-fit: contain; display: block; }

.soundcore-speaker-lineup .m-detail-card-buy-divider {
  display: block;
  width: 100%;
  height: 1px;
  background: rgba(255,255,255,0.1);
}
.soundcore-speaker-lineup .m-detail-card-buy-actions { display: flex; flex-direction: column; gap: 16px; align-items: center; }
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btns { display: flex; flex-wrap: wrap; gap: 10px; list-style: none; margin: 0; padding: 0; justify-content: center; }
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btns > li:not(.is-more) { flex: 1 1 0; min-width: 0; }
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btns > li.is-more { flex: 1 1 100%; display: flex; justify-content: center; }
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btn,
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btn-amazon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 16px 20px;
  border-radius: 100px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.04em;
  text-decoration: none;
  white-space: nowrap;
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btn { background: #17bbef; color: #fff; }
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btn.-inactive { background: rgba(255,255,255,0.2); pointer-events: none; }
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-btn-amazon {
  background: transparent;
  color: #fff;
  border: 1px solid #ffa600;
  backdrop-filter: blur(5.5px);
  -webkit-backdrop-filter: blur(5.5px);
}
.soundcore-speaker-lineup .m-detail-card-buy-actions .lp-txtLink {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  text-decoration: none;
}
.soundcore-speaker-lineup .m-detail-card-buy-btns { display: flex; gap: 10px; }
.soundcore-speaker-lineup .m-pillbtn.-cyan { background: #17bbef; color: #fff; }
.soundcore-speaker-lineup .m-pillbtn.-amazon-on-dark { background: transparent; color: #fff; border: 1px solid var(--c-amazon); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); }
.soundcore-speaker-lineup .m-textlink.-onDark { color: #fff; }

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Detail { padding: 0 40px; }
  .soundcore-speaker-lineup .Detail-block { margin-bottom: 160px; }
  .soundcore-speaker-lineup .Detail-block:last-child { margin-bottom: 0; }
  .soundcore-speaker-lineup .Detail-note { margin-top: 40px; margin-bottom: 120px; font-size: 12px; }
  .soundcore-speaker-lineup .Detail-block-head { position: sticky; top: 80px; flex-direction: row; align-items: center; padding-top: 40px; padding-bottom: 0; gap: 40px; }
  .soundcore-speaker-lineup .Detail-block-head.is-stuck { padding-top: 14px; padding-bottom: 10px; gap: 20px; }
  .soundcore-speaker-lineup .Detail-block-head.is-stuck .Detail-block-num { font-size: 32px; }
  .soundcore-speaker-lineup .Detail-block-title { font-size: 25px; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .Detail-block-head.is-stuck .Detail-block-title { font-size: 14px; }
  .soundcore-speaker-lineup .Detail-block-body { flex-direction: row; gap: 40px; align-items: flex-start; }
  .soundcore-speaker-lineup .Detail-picker { display: grid; width: 426px; flex: none; padding: 40px 0; position: sticky; top: 144px; grid-template-columns: repeat(2, 203px); gap: 20px; overflow: visible; margin: 0; background: transparent; transition: opacity 0.3s ease, visibility 0.3s ease; }
  .soundcore-speaker-lineup .Detail-picker.is-released { opacity: 0; visibility: hidden; pointer-events: none; }
  .soundcore-speaker-lineup .Detail-picker > .m-product { flex: none; width: 203px; height: 203px; background: var(--c-light-bg); opacity: 0.28; filter: saturate(0.6); transform: scale(0.94); box-shadow: none; padding: 8px; transition: background 0.6s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.6s cubic-bezier(0.22, 0.61, 0.36, 1), filter 0.6s cubic-bezier(0.22, 0.61, 0.36, 1), transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1), box-shadow 0.6s cubic-bezier(0.22, 0.61, 0.36, 1); }
  .soundcore-speaker-lineup .Detail-picker > .m-product.is-active { background: #fff; opacity: 1; filter: saturate(1); transform: translateY(-2px) scale(1.07); box-shadow: 0 24px 48px -16px rgba(0,0,0,0.22), 0 10px 20px -10px rgba(0,0,0,0.1); }
  .soundcore-speaker-lineup .Detail-picker .m-product-img { top: 0; width: 110%; height: 110%; transform: translate(-50%, -12px); }
  .soundcore-speaker-lineup .Detail-picker .m-product-name { font-size: 18px; bottom: 12px; left: 12px; }
  .soundcore-speaker-lineup .Detail-cards { flex: 1; padding: 40px 0; gap: 40px; display: flex; flex-direction: column; }
  .soundcore-speaker-lineup .m-detail-card { display: block; height: 640px; max-width: 893px; }
  .soundcore-speaker-lineup .m-detail-card-bg { position: absolute; inset: 0; width: 100%; height: 100%; aspect-ratio: auto; }
  .soundcore-speaker-lineup .m-detail-card-overlay { position: absolute; top: auto; bottom: 0; left: 0; right: 0; padding: 30px; gap: 24px; max-height: 70%; box-shadow: none; background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.5) 100%); overflow-y: auto; }
  .soundcore-speaker-lineup .m-detail-card-tagline { font-size: 28px; letter-spacing: 0.05em; }
  .soundcore-speaker-lineup .m-detail-card-feats { display: flex; flex-wrap: nowrap; gap: 8px; overflow-x: auto; overflow-y: hidden; margin: 0 -20px; padding: 0 20px; grid-template-columns: none; scroll-behavior: smooth; }
  .soundcore-speaker-lineup .m-detail-card-feats > li { flex: none; max-width: none; }
  .soundcore-speaker-lineup .m-detail-card-feats-wrap::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: -20px;
    width: 80px;
    pointer-events: none;
    background: linear-gradient(to right, rgba(0,0,0,0) 0%, rgba(0,0,0,0.45) 100%);
    opacity: 1;
    transition: opacity 0.25s ease;
    z-index: 2;
  }
  .soundcore-speaker-lineup .m-detail-card-feats-wrap.is-end::after,
  .soundcore-speaker-lineup .m-detail-card-feats-wrap.is-no-scroll::after { opacity: 0; }
  .soundcore-speaker-lineup .m-detail-card-feats-arrow {
    display: block;
    position: absolute;
    top: 50%;
    right: 4px;
    width: 28px;
    height: 28px;
    margin-top: -14px;
    border-radius: 50%;
    background: rgba(255,255,255,0.92);
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
    pointer-events: auto;
    cursor: pointer;
    z-index: 3;
    opacity: 1;
    transition: opacity 0.25s ease, transform 0.25s ease;
    animation: sl-feats-arrow-pulse 1.6s ease-in-out infinite;
  }
  .soundcore-speaker-lineup .m-detail-card-feats-wrap.is-end .m-detail-card-feats-arrow,
  .soundcore-speaker-lineup .m-detail-card-feats-wrap.is-no-scroll .m-detail-card-feats-arrow { pointer-events: none; }
  .soundcore-speaker-lineup .m-detail-card-feats-arrow:hover { background: #fff; }
  .soundcore-speaker-lineup .m-detail-card-feats-arrow::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 7px;
    height: 7px;
    margin: -4px 0 0 -5px;
    border-right: 2px solid #1a1a1a;
    border-top: 2px solid #1a1a1a;
    transform: rotate(45deg);
  }
  .soundcore-speaker-lineup .m-detail-card-feats-wrap.is-end .m-detail-card-feats-arrow,
  .soundcore-speaker-lineup .m-detail-card-feats-wrap.is-no-scroll .m-detail-card-feats-arrow { opacity: 0; }
  @keyframes sl-feats-arrow-pulse {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(4px); }
  }
  .soundcore-speaker-lineup .m-feat-pill { height: auto; }
  .soundcore-speaker-lineup .m-feat-pill {
    display: inline-flex;
    width: auto;
    padding: 10px 19px 10px 10px;
    font-size: 13px;
    gap: 8px;
    background: rgba(0,0,0,0.35);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  .soundcore-speaker-lineup .m-feat-pill-icon { width: 56px; height: 56px; }
  .soundcore-speaker-lineup .m-detail-card-buy { flex-direction: row; gap: 30px; align-items: center; }
  .soundcore-speaker-lineup .m-detail-card-buy-info { flex: 1; gap: 10px; }
  .soundcore-speaker-lineup .m-detail-card-buy-name { font-size: 24px; }
  .soundcore-speaker-lineup .m-detail-card-buy-price { font-size: 16px; }
  .soundcore-speaker-lineup .m-detail-card-buy-divider { width: 1px; height: auto; background: rgba(255,255,255,0.1); align-self: stretch; }
  .soundcore-speaker-lineup .m-detail-card-buy-actions { width: 258px; gap: 16px; align-items: stretch; }
}

/* =====================================================
   8. PR Carousel
   Figma 64:1327 - 4 placeholder cards
   ===================================================== */
.soundcore-speaker-lineup .Pr {
  background: linear-gradient(180deg, var(--c-section-bg) 0%, #fff 100%);
  padding: 48px 0 48px 20px;
}
.soundcore-speaker-lineup .Pr-inner { max-width: 1440px; margin-inline: auto; display: flex; flex-direction: column; gap: 24px; }
.soundcore-speaker-lineup .Pr-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
  padding-right: 20px;
}
.soundcore-speaker-lineup .Pr-list {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 8px 20px 16px 0;
  -webkit-overflow-scrolling: touch;
}
.soundcore-speaker-lineup .m-pr-card {
  flex: none;
  width: 240px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.soundcore-speaker-lineup .m-pr-card-img {
  width: 100%;
  aspect-ratio: 311/562;
  background: linear-gradient(180deg, #d7e9f4 0%, #b3cee4 100%);
  border-radius: 8px;
}
.soundcore-speaker-lineup .m-pr-card-video {
  width: 100%;
  aspect-ratio: 9 / 16;
  border-radius: 8px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}
.soundcore-speaker-lineup .m-pr-card-video iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.soundcore-speaker-lineup .m-pr-card-title { font-family: "Noto Sans JP", sans-serif; font-size: 14px; line-height: 1.5; color: var(--c-black); }
.soundcore-speaker-lineup .m-pr-card-desc { font-family: "Noto Sans JP", sans-serif; font-size: 12px; line-height: 1.5; color: var(--c-text-gray); }

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Pr { padding: 60px 40px; }
  .soundcore-speaker-lineup .Pr-heading { font-size: 28px; padding-right: 0; }
  .soundcore-speaker-lineup .Pr-list { gap: 40px; padding: 0; overflow-x: visible; flex-wrap: wrap; }
  .soundcore-speaker-lineup .m-pr-card { width: 311px; }
}

/* =====================================================
   9. Reviews — Space スタイル準拠
   ===================================================== */
.soundcore-speaker-lineup .Reviews {
  background: #f0f2f7;
  padding: clamp(48px, 13.33vw, 80px) clamp(16px, 5vw, 20px);
}
.soundcore-speaker-lineup .Reviews__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 6.67vw, 28px);
  max-width: 1440px;
  margin-inline: auto;
}
.soundcore-speaker-lineup .Reviews__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #333;
  margin: 0;
  text-align: center;
  line-height: 1.4;
  font-weight: 400;
}
.soundcore-speaker-lineup .Reviews__heading-row { display: flex; align-items: flex-end; }
.soundcore-speaker-lineup .Reviews__heading-brand {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(22px, 7.18vw, 28px);
  line-height: 1.4;
}
.soundcore-speaker-lineup .Reviews__heading-series {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(22px, 7.18vw, 28px);
  line-height: 1.4;
}
.soundcore-speaker-lineup .Reviews__heading-used {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(22px, 7.18vw, 28px);
  line-height: 1.5;
  letter-spacing: 0.15em;
}
.soundcore-speaker-lineup .Reviews__tabs {
  display: flex;
  background: rgba(51, 51, 51, 0.08);
  padding: 4px;
  border-radius: 50px;
  gap: 0;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  justify-content: flex-start;
}
.soundcore-speaker-lineup .Reviews__tabs::-webkit-scrollbar { display: none; }
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Reviews__tabs {
    overflow-x: visible;
    justify-content: center;
    flex-wrap: nowrap;
  }
}
.soundcore-speaker-lineup .Reviews__tab {
  appearance: none;
  border: 0;
  background: transparent;
  color: #333;
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: clamp(12px, 3.59vw, 14px);
  line-height: 1;
  padding: 12px 18px;
  border-radius: 80px;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
  white-space: nowrap;
}
.soundcore-speaker-lineup .Reviews__tab.is-active {
  background: var(--c-black);
  color: #fff;
}
.soundcore-speaker-lineup .Reviews__stack { display: grid; width: 100%; }
.soundcore-speaker-lineup .Reviews__contents {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 7px;
  padding: 0;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.4s ease, visibility 0s linear 0.4s;
}
.soundcore-speaker-lineup .Reviews__contents.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 0.4s ease, visibility 0s linear 0s;
}
.soundcore-speaker-lineup .Reviews__column { display: contents; }
.soundcore-speaker-lineup .Reviews__visual {
  position: relative;
  width: clamp(200px, 70vw, 280px);
  aspect-ratio: 344 / 370;
  flex-shrink: 0;
  animation: sl-reviewsVisualFloat 4.5s ease-in-out infinite;
  will-change: transform;
}
@keyframes sl-reviewsVisualFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}
@media (prefers-reduced-motion: reduce) {
  .soundcore-speaker-lineup .Reviews__visual { animation: none; }
}
.soundcore-speaker-lineup .Reviews__visual-img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1.2s ease;
}
.soundcore-speaker-lineup .Reviews__visual-img.is-active { opacity: 1; }
.soundcore-speaker-lineup .Reviews__card {
  background: #fff;
  border-radius: clamp(20px, 7.5vw, 30px);
  padding: clamp(14px, 5vw, 18px) clamp(14px, 5vw, 20px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: clamp(3px, 1vw, 4px);
  max-width: 460px;
  width: 100%;
  opacity: 0;
  transform: translateY(40px) scale(0.94);
  transition:
    opacity 0.6s ease,
    transform 0.9s cubic-bezier(0.34, 1.56, 0.64, 1);
  will-change: transform, opacity;
}
.soundcore-speaker-lineup .Reviews__card.is-in {
  opacity: 1;
  transform: translateY(0) scale(1);
}
@media screen and (max-width: 1079px) {
  .soundcore-speaker-lineup .Reviews__visual { order: -1; margin-bottom: 8px; }
  .soundcore-speaker-lineup .Reviews__card:not(.is-sp-shown) { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .soundcore-speaker-lineup .Reviews__card {
    transition: none;
    opacity: 1;
    transform: none;
  }
}
.soundcore-speaker-lineup .Reviews__stars {
  display: flex;
  gap: clamp(2px, 0.75vw, 3px);
  color: #ffd327;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: clamp(12px, 3.75vw, 15px);
  line-height: 1.25;
  letter-spacing: 0.07em;
  padding-bottom: clamp(3px, 1.25vw, 5px);
}
.soundcore-speaker-lineup .Reviews__stars .is-empty { color: rgba(51, 51, 51, 0.2); }
.soundcore-speaker-lineup .Reviews__text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(12px, 3.59vw, 14px);
  line-height: 1.8;
  letter-spacing: 0.05em;
  color: #333;
  margin: 0;
}
.soundcore-speaker-lineup .Reviews__author {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(10px, 2.75vw, 11px);
  line-height: 1.8;
  letter-spacing: 0.05em;
  color: rgba(51, 51, 51, 0.8);
  margin: 0;
  align-self: stretch;
}

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Reviews { padding: clamp(60px, 6.944vw, 100px) clamp(40px, 4.167vw, 60px); }
  .soundcore-speaker-lineup .Reviews__inner { gap: clamp(24px, 2.778vw, 40px); }
  .soundcore-speaker-lineup .Reviews__tabs { padding: clamp(6px, 0.556vw, 8px); border-radius: clamp(40px, 3.472vw, 50px); }
  .soundcore-speaker-lineup .Reviews__tab { font-size: clamp(14px, 1.181vw, 17px); padding: clamp(10px, 0.833vw, 12px) clamp(14px, 1.25vw, 18px); border-radius: clamp(60px, 5.556vw, 80px); }
  .soundcore-speaker-lineup .Reviews__heading { flex-direction: row; align-items: flex-end; justify-content: center; flex-wrap: nowrap; }
  .soundcore-speaker-lineup .Reviews__heading-row { display: contents; }
  .soundcore-speaker-lineup .Reviews__heading-brand { font-size: clamp(22px, 2.222vw, 32px); font-weight: 400; }
  .soundcore-speaker-lineup .Reviews__heading-series { font-size: clamp(22px, 2.222vw, 32px); font-weight: 400; }
  .soundcore-speaker-lineup .Reviews__heading-used { font-size: clamp(22px, 2.222vw, 32px); font-weight: 400; letter-spacing: normal; line-height: 1.4; }
  .soundcore-speaker-lineup .Reviews__contents { flex-direction: row; align-items: center; justify-content: center; gap: clamp(24px, 2.778vw, 40px); padding: 0; }
  .soundcore-speaker-lineup .Reviews__column { display: flex; flex-direction: column; align-items: center; justify-content: center; flex: 1 1 0; min-width: 0; gap: clamp(8px, 0.694vw, 10px); }
  .soundcore-speaker-lineup .Reviews__visual { width: clamp(220px, 23.889vw, 344px); }
  .soundcore-speaker-lineup .Reviews__card {
    max-width: none;
    width: auto;
    border-radius: clamp(20px, 2.083vw, 30px);
    padding: clamp(14px, 1.389vw, 20px) clamp(20px, 2.083vw, 30px);
    gap: clamp(3px, 0.278vw, 4px);
  }
  .soundcore-speaker-lineup .Reviews__stars { gap: clamp(2px, 0.208vw, 3px); font-size: clamp(13px, 1.042vw, 15px); padding-bottom: clamp(3px, 0.347vw, 5px); }
  .soundcore-speaker-lineup .Reviews__text { font-size: clamp(13px, 1.111vw, 16px); }
  .soundcore-speaker-lineup .Reviews__author { font-size: clamp(10px, 0.833vw, 12px); }
}

/* =====================================================
   10. Comparison Table
   ===================================================== */
.soundcore-speaker-lineup .Compare { background: transparent; padding: 48px 0 48px 20px; }
.soundcore-speaker-lineup .Compare-inner { max-width: 1440px; margin-inline: auto; display: flex; flex-direction: column; gap: 24px; padding-right: 20px; }
.soundcore-speaker-lineup .Compare-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
/* スペック比較表 - lp-spec-compare-eufy のデザインパターンを踏襲 */
.soundcore-speaker-lineup .Compare-table {
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt" 1;
  color: #2f333a;
  background: var(--c-section-bg);
  border-radius: 12px;
  border: 1px solid rgba(26, 26, 26, 0.08);
  position: relative;
}

.soundcore-speaker-lineup .Compare-filter {
  display: flex;
  flex-wrap: nowrap;
  gap: 4px;
  margin-bottom: 16px;
  padding: 6px;
  background: rgba(26, 26, 26, 0.08);
  border-radius: 999px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  width: max-content;
  max-width: 100%;
  margin-inline: auto;
}
.soundcore-speaker-lineup .Compare-filter::-webkit-scrollbar { display: none; }
.soundcore-speaker-lineup .Compare-filter-tab {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--c-black);
  font-family: inherit;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.4;
  padding: 8px 16px;
  border-radius: 999px;
  cursor: pointer;
  white-space: nowrap;
  flex: none;
  transition: background 0.2s ease, color 0.2s ease;
}
.soundcore-speaker-lineup .Compare-filter-tab:hover { background: rgba(0, 0, 0, 0.05); }
.soundcore-speaker-lineup .Compare-filter-tab.is-active {
  background: var(--c-black);
  color: #fff;
}
.soundcore-speaker-lineup .Compare-filter-tab.is-active:hover { background: var(--c-black); }
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Compare-filter { margin-bottom: 24px; gap: 6px; padding: 8px; }
  .soundcore-speaker-lineup .Compare-filter-tab { font-size: 14px; padding: 10px 22px; }
}

.soundcore-speaker-lineup .Compare-product-detail-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 400;
  line-height: 1.2;
  color: #fff;
  background: var(--c-black);
  border-radius: 999px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.soundcore-speaker-lineup .Compare-product-col:hover .Compare-product-detail-btn { opacity: 0.85; }
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Compare-product-detail-btn { font-size: 11px; padding: 5px 12px; }
}

.soundcore-speaker-lineup .Compare-header {
  position: sticky;
  top: 0;
  z-index: 30;
  background: var(--c-section-bg);
  border-bottom: 1px solid rgba(26, 26, 26, 0.08);
  border-radius: 12px 12px 0 0;
  display: flex;
}
.soundcore-speaker-lineup .Compare-header-blank {
  width: 110px;
  min-width: 110px;
  flex-shrink: 0;
}
.soundcore-speaker-lineup .Compare-header-scroll { overflow: hidden; flex: 1; }
.soundcore-speaker-lineup .Compare-header-products { display: flex; will-change: transform; }
.soundcore-speaker-lineup .Compare-product-col {
  width: 120px;
  min-width: 120px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 4px;
  gap: 6px;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.2s ease;
  position: relative;
}
.soundcore-speaker-lineup .Compare-recommended-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #69707b;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 8px;
  line-height: 1.15;
  letter-spacing: 0.05em;
  text-align: center;
}
.soundcore-speaker-lineup .Compare-hires-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  z-index: 2;
  width: 36px;
  height: auto;
  object-fit: contain;
}
.soundcore-speaker-lineup .Compare-product-price {
  font-family: "Mont For Anker", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: var(--c-black);
  margin: 4px 0 0;
  width: 100%;
}
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-unit { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-discount-rate-wrap { margin: 0; justify-content: center; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-discount-rate { font-size: 10px; padding: 1px 4px; line-height: 1.2; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2 { display: flex; flex-wrap: wrap; align-items: baseline; justify-content: center; gap: 2px 4px; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-sale-wrap { display: flex; align-items: baseline; gap: 4px; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-sale { font-size: 10px; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-default { font-size: 12px; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-tax { font-size: 10px; }
.soundcore-speaker-lineup .Compare-product-price .product-price-v2-soldout { font-size: 10px; margin: 2px 0 0; }
.soundcore-speaker-lineup .Compare-note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  line-height: 1.5;
  color: var(--c-text-gray);
  font-feature-settings: "palt" 1;
  margin: 16px 0 0;
  padding: 0 20px;
  text-align: left;
}
.soundcore-speaker-lineup .js-compare-swatch { cursor: pointer; padding: 0; border: 1.5px solid transparent; border-radius: 4px; transition: border-color 0.2s ease; }
.soundcore-speaker-lineup .js-compare-swatch.is-active { border-color: var(--c-black); }
.soundcore-speaker-lineup .Compare-product-variants {
  display: flex;
  flex-wrap: nowrap;
  gap: 2px;
  justify-content: center;
  align-items: center;
  margin: 4px 0 0;
  padding: 0;
  list-style: none;
  max-width: 100%;
  overflow: hidden;
}
.soundcore-speaker-lineup .Compare-product-variants li {
  width: 16px;
  height: 16px;
  border-radius: 3px;
  overflow: hidden;
  background: #fff;
  flex: none;
}
.soundcore-speaker-lineup .Compare-product-variants-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 16px;
  min-width: 16px;
  padding: 0 3px;
  border-radius: 3px;
  background: #e9ebef;
  color: #6b7280;
  font-family: "Mont For Anker", "Noto Sans JP", sans-serif;
  font-size: 9px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  flex: none;
}
.soundcore-speaker-lineup .Compare-product-variants img { width: 100%; height: 100%; object-fit: contain; display: block; }
.soundcore-speaker-lineup .Compare-product-col:hover { opacity: 0.8; }
.soundcore-speaker-lineup .Compare-product-img { width: 64px; height: 50px; object-fit: contain; border-radius: 4px; }
.soundcore-speaker-lineup .Compare-product-name {
  font-size: 11px;
  font-weight: 600;
  color: #2f333a;
  font-family: "Mont For Anker", "Noto Sans JP", sans-serif;
  line-height: 1.3;
}

.soundcore-speaker-lineup .Compare-body { overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; -ms-overflow-style: none; }
.soundcore-speaker-lineup .Compare-body::-webkit-scrollbar { display: none; }
.soundcore-speaker-lineup .Compare-body-inner { min-width: max-content; }
.soundcore-speaker-lineup .Compare-row { display: flex; border-bottom: 1px solid rgba(26, 26, 26, 0.06); background: var(--c-section-bg); }
.soundcore-speaker-lineup .Compare-row:last-child { border-bottom: none; }
.soundcore-speaker-lineup .Compare-row-label { background: var(--c-section-bg); }
.soundcore-speaker-lineup .Compare-row-label {
  width: 110px;
  min-width: 110px;
  flex-shrink: 0;
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--c-section-bg);
  padding: 10px 8px;
  font-size: 11px;
  font-weight: 500;
  color: #374151;
  line-height: 1.4;
  display: flex;
  align-items: center;
  border-right: 1px solid rgba(26, 26, 26, 0.08);
}
.soundcore-speaker-lineup .Compare-cell {
  width: 120px;
  min-width: 120px;
  flex-shrink: 0;
  padding: 10px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 12px;
  line-height: 1.4;
}
.soundcore-speaker-lineup .Compare-val { display: inline-flex; align-items: center; justify-content: center; gap: 4px; flex-wrap: wrap; }
.soundcore-speaker-lineup .Compare-variants {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}
.soundcore-speaker-lineup .Compare-variants li {
  width: 32px;
  height: 32px;
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
  flex: none;
}
.soundcore-speaker-lineup .Compare-variants img { width: 100%; height: 100%; object-fit: contain; display: block; }
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Compare-variants li { width: 40px; height: 40px; }
  .soundcore-speaker-lineup .Compare-product-variants li { width: 20px; height: 20px; }
  .soundcore-speaker-lineup .Compare-product-variants-more { height: 20px; min-width: 20px; padding: 0 4px; font-size: 10px; }
  .soundcore-speaker-lineup .Compare-recommended-badge { width: 44px; height: 44px; font-size: 10px; }
  .soundcore-speaker-lineup .Compare-hires-mark { width: 32px; }
}
.soundcore-speaker-lineup .Compare-val.-no { opacity: 0.4; }
.soundcore-speaker-lineup .Compare-val.-text { color: #374151; font-size: 11px; line-height: 1.4; }
.soundcore-speaker-lineup .Compare-cell.-stacked { flex-direction: column; gap: 6px; }
.soundcore-speaker-lineup .Compare-val.-check {
  width: 16px;
  height: 16px;
  background: transparent;
  border: 1px solid #2f333a;
  border-radius: 2px;
  color: transparent;
  font-size: 0;
  position: relative;
  flex: none;
}
.soundcore-speaker-lineup .Compare-val.-check::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 9px;
  height: 5px;
  border-left: 1.5px solid #2f333a;
  border-bottom: 1.5px solid #2f333a;
  transform: translate(-50%, -65%) rotate(-45deg);
}
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Compare-val.-check { width: 18px; height: 18px; }
  .soundcore-speaker-lineup .Compare-val.-check::after { width: 10px; height: 5px; }
}
.soundcore-speaker-lineup .Compare-bassup { flex-direction: column; gap: 4px; }
.soundcore-speaker-lineup .Compare-bassup-logo { width: 48px; height: auto; display: block; }
.soundcore-speaker-lineup .Compare-bassup-desc { display: block; }
@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Compare-bassup-logo { width: 58px; }
}

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Compare { padding: 60px 40px; }
  .soundcore-speaker-lineup .Compare-inner { padding-right: 0; gap: 30px; }
  .soundcore-speaker-lineup .Compare-heading { font-size: 32px; font-weight: 300; text-align: center; }
  .soundcore-speaker-lineup .Compare-header { top: 0; }
  .soundcore-speaker-lineup .Compare-header-blank { width: 180px; min-width: 180px; }
  .soundcore-speaker-lineup .Compare-product-col { width: 160px; min-width: 160px; padding: 16px 8px; gap: 8px; }
  .soundcore-speaker-lineup .Compare-product-img { width: 80px; height: 80px; }
  .soundcore-speaker-lineup .Compare-product-name { font-size: 13px; }
  .soundcore-speaker-lineup .Compare-row-label { width: 180px; min-width: 180px; padding: 14px 16px; font-size: 13px; }
  .soundcore-speaker-lineup .Compare-cell { width: 160px; min-width: 160px; padding: 14px 12px; font-size: 13px; }
  .soundcore-speaker-lineup .Compare-val.-text { font-size: 13px; }
}

/* =====================================================
   11. Soundcore Brand Footer (placeholder)
   ===================================================== */
.soundcore-speaker-lineup .Footer { background: transparent; padding: 48px 20px; }
.soundcore-speaker-lineup .Footer-inner { display: flex; flex-direction: column; gap: 24px; }
.soundcore-speaker-lineup .Footer-heading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--c-black);
  font-feature-settings: "palt" 1;
}
.soundcore-speaker-lineup .Footer-placeholder { background: #edf1f9; height: 400px; border-radius: 12px; }

@media screen and (min-width: 1080px) {
  .soundcore-speaker-lineup .Footer { padding: 60px 40px; }
  .soundcore-speaker-lineup .Footer-inner { gap: 40px; }
  .soundcore-speaker-lineup .Footer-heading { font-size: 28px; }
  .soundcore-speaker-lineup .Footer-placeholder { height: 760px; max-width: 1360px; margin-inline: auto; width: 100%; }
}

/* lp-soundcore-foot 内の Authority(「Ankerのオーディオ & ビジュアルブランド」) は本LP側のBrandBarと重複するため非表示 */
.soundcore-speaker-lineup .lp-soundcore-foot .Authority { display: none; }

/* =====================================================
   Wide-screen scaling (>=1600px): fluid scale to use width
   ===================================================== */
@media screen and (min-width: 1600px) {
  .soundcore-speaker-lineup {
    /* base font scales mildly for legibility on huge screens */
    font-size: clamp(16px, 1vw, 22px);
  }
  .soundcore-speaker-lineup .BrandBar-inner,
  .soundcore-speaker-lineup .Lineup-inner,
  .soundcore-speaker-lineup .Quiz-inner,
  .soundcore-speaker-lineup .Detail-block-head,
  .soundcore-speaker-lineup .Detail-block-body,
  .soundcore-speaker-lineup .Pr-inner,
  .soundcore-speaker-lineup .Reviews-inner,
  .soundcore-speaker-lineup .Compare-inner,
  .soundcore-speaker-lineup .Scene-stage {
    max-width: min(1680px, calc(100vw - 80px));
  }
  /* Section padding scales with viewport so the 40px feel stays proportional */
  .soundcore-speaker-lineup .BrandBar { padding: 80px clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .New { padding: clamp(40px, 3vw, 60px); }
  .soundcore-speaker-lineup .Lineup { padding: 80px clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .Scene { padding: 80px clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .Quiz { padding: clamp(80px, 6vw, 120px) clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .Detail { padding: 0 clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .Pr { padding: 80px clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .Reviews { padding: 80px 0 80px clamp(40px, 4vw, 80px); }
  .soundcore-speaker-lineup .Compare { padding: 80px clamp(40px, 4vw, 80px); }
}

/* Ultra-wide (>=1920px): cap content but center elegantly */
@media screen and (min-width: 1920px) {
  .soundcore-speaker-lineup .BrandBar-inner,
  .soundcore-speaker-lineup .Lineup-inner,
  .soundcore-speaker-lineup .Quiz-inner,
  .soundcore-speaker-lineup .Detail-block-head,
  .soundcore-speaker-lineup .Detail-block-body,
  .soundcore-speaker-lineup .Pr-inner,
  .soundcore-speaker-lineup .Reviews-inner,
  .soundcore-speaker-lineup .Compare-inner,
  .soundcore-speaker-lineup .Scene-stage {
    max-width: 1760px;
  }
  .soundcore-speaker-lineup .Kv .Kv-bg { width: 100%; max-width: 2400px; right: 0; }
  .soundcore-speaker-lineup .Kv .Kv-text { left: max(calc(50% - 720px + 40px), 40px); }
  .soundcore-speaker-lineup .Kv .Kv-no1 { right: max(calc(50% - 720px + 40px), 40px); }
  .soundcore-speaker-lineup .Kv .Kv-logo { left: max(calc(50% - 720px + 40px), 40px); }
}
