/* ============================================================
   MONSTER-CLUB LP — theme-sports.css
   SPORTS × ENERGY Redesign (Dark Navy × Cyan × Race Red)
   2026-06-04
   - style.css の後に読み込む上書きテーマ。
   - スコープ: body.t-sports 配下のページクローム全般。
   - 製品モック (.ks-mock-* / laptop-screen 内部 / iphone 内部) は
     実サロン UI の再現のため、ライト配色のまま維持する。
   ============================================================ */

/* ===== 1. Tokens ========================================== */
body.t-sports {
  --sp-bg:        #0B121C;
  --sp-bg-2:      #0E1724;
  --sp-bg-3:      #111E2E;
  --sp-surface:   #15212F;
  --sp-surface-2: #1B2A3B;
  --sp-line:      rgba(151, 180, 209, 0.14);
  --sp-line-2:    rgba(151, 180, 209, 0.26);
  --sp-text:      #EEF4FA;
  --sp-text-soft: #C2CFDC;
  --sp-muted:     #8A9DB0;
  --sp-cyan:      #2BD9F2;
  --sp-cyan-deep: #0FA8C6;
  --sp-cyan-dim:  rgba(43, 217, 242, 0.12);
  --sp-red:       #F03A56;
  --sp-red-deep:  #C2243C;
  --sp-red-dim:   rgba(240, 58, 86, 0.14);
  --sp-lime:      #A8E04A;
  --sp-disp:      "Oswald", "Noto Sans JP", sans-serif;
  --sp-sans:      "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sp-skew:      -8deg;
  --sp-stripe:    repeating-linear-gradient(115deg,
                    transparent 0 22px,
                    rgba(255,255,255,0.022) 22px 44px);
  --sp-shadow-card: 0 1px 0 rgba(255,255,255,0.04) inset, 0 24px 60px -28px rgba(0,0,0,0.55);
  --sp-shadow-pop:  0 18px 50px -12px rgba(240,58,86,0.45);
}

/* ===== 2. Base ============================================ */
body.t-sports {
  background: var(--sp-bg);
  color: var(--sp-text-soft);
  font-family: var(--sp-sans);
  letter-spacing: 0.01em;
}
body.t-sports ::selection { background: rgba(43,217,242,0.35); color: #fff; }
body.t-sports strong { color: var(--sp-text); font-weight: 700; }
body.t-sports em { font-style: normal; }
body.t-sports a { color: inherit; }
body.t-sports .hairline { background: var(--sp-red); height: 2px; width: 56px; transform: skewX(var(--sp-skew)); }

/* ===== 3. Chapter / Section heads ========================= */
body.t-sports .chapter { gap: 12px; }
body.t-sports .chapter-num {
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 600;
  font-size: 15px;
  color: #0B121C;
  background: var(--sp-cyan);
  padding: 2px 12px;
  transform: skewX(var(--sp-skew));
  border-radius: 2px;
}
body.t-sports .chapter-label {
  font-family: var(--sp-disp);
  color: var(--sp-cyan);
  letter-spacing: 0.34em;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 500;
}
body.t-sports .section-title {
  font-family: var(--sp-sans);
  font-weight: 900;
  letter-spacing: 0.02em;
  color: var(--sp-text);
}
body.t-sports .section-title em {
  font-style: normal;
  color: var(--sp-red);
  position: relative;
}
body.t-sports .section-title em::after {
  content: "";
  position: absolute;
  left: 2%;
  bottom: 0.04em;
  width: 96%;
  height: 0.16em;
  background: linear-gradient(90deg, var(--sp-red), transparent 92%);
  transform: skewX(var(--sp-skew));
  opacity: 0.55;
  z-index: -1;
}
body.t-sports .section-lead { color: var(--sp-muted); }
body.t-sports .section-lead strong { color: var(--sp-cyan); font-weight: 700; }

/* ===== 4. Buttons ========================================= */
body.t-sports .btn {
  font-family: var(--sp-sans);
  font-weight: 800;
  letter-spacing: 0.08em;
  border-radius: 3px;
  border: none;
  transform: skewX(var(--sp-skew));
}
body.t-sports .btn > span,
body.t-sports .btn > svg { display: inline-block; transform: skewX(calc(var(--sp-skew) * -1)); }
body.t-sports .btn--primary {
  background: linear-gradient(135deg, var(--sp-red) 0%, var(--sp-red-deep) 100%);
  color: #fff;
  box-shadow: 0 12px 32px -10px rgba(240,58,86,0.55), 0 0 0 1px rgba(255,255,255,0.08) inset;
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
body.t-sports .btn--primary::after {
  background: linear-gradient(135deg, #FF5A73 0%, var(--sp-red) 100%);
}
body.t-sports .btn--primary:hover {
  transform: skewX(var(--sp-skew)) translateY(-2px);
  box-shadow: 0 18px 44px -12px rgba(240,58,86,0.7), 0 0 0 1px rgba(255,255,255,0.1) inset;
  color: #fff;
}
body.t-sports .btn--ghost {
  background: transparent;
  color: var(--sp-text);
  box-shadow: 0 0 0 1.5px var(--sp-line-2) inset;
}
body.t-sports .btn--ghost:hover { box-shadow: 0 0 0 1.5px var(--sp-cyan) inset; color: var(--sp-cyan); }

/* ===== 5. Header ========================================== */
body.t-sports .site-header {
  background: rgba(11, 18, 28, 0.78);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--sp-line);
  box-shadow: none;
}
body.t-sports .site-header.scrolled {
  background: rgba(11, 18, 28, 0.92);
  border-bottom-color: var(--sp-line-2);
  box-shadow: 0 12px 36px -18px rgba(0,0,0,0.7);
}
body.t-sports .brand-mark {
  background: linear-gradient(135deg, var(--sp-red), var(--sp-red-deep));
  color: #fff;
  border: none;
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 700;
  transform: skewX(var(--sp-skew));
  border-radius: 2px;
}
body.t-sports .brand-name {
  font-family: var(--sp-disp);
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--sp-text);
}
body.t-sports .header-nav a {
  font-family: var(--sp-sans);
  font-weight: 600;
  color: var(--sp-text-soft);
}
body.t-sports .header-nav a:hover { color: var(--sp-cyan); }
body.t-sports .header-nav a::after { background: var(--sp-cyan); height: 2px; }
body.t-sports .header-nav-badge {
  color: var(--sp-lime);
  border: 1px solid rgba(168, 224, 74, 0.35);
  background: rgba(168, 224, 74, 0.08);
}
body.t-sports .header-nav-badge-dot { background: var(--sp-lime); box-shadow: 0 0 8px var(--sp-lime); }
body.t-sports .header-login { color: var(--sp-text-soft); }
body.t-sports .header-login:hover { color: var(--sp-cyan); }
body.t-sports .header-join {
  background: linear-gradient(135deg, var(--sp-red), var(--sp-red-deep));
  color: #fff;
  border: none;
  font-weight: 800;
  letter-spacing: 0.08em;
  transform: skewX(var(--sp-skew));
  border-radius: 3px;
  box-shadow: 0 10px 26px -10px rgba(240,58,86,0.55);
}
body.t-sports .header-join:hover { background: linear-gradient(135deg, #FF5A73, var(--sp-red)); color: #fff; }
body.t-sports .hamburger span { background: var(--sp-text); }

/* mobile menu panel */
@media (max-width: 768px) {
  body.t-sports .header-nav.mobile-open,
  body.t-sports .header-actions.mobile-open {
    background: #0E1724;
    border-bottom: 1px solid var(--sp-line-2);
    box-shadow: 0 24px 48px -16px rgba(0,0,0,0.8);
  }
  body.t-sports .header-nav.mobile-open a { border-bottom: 1px solid var(--sp-line); color: var(--sp-text); }
}

/* ===== 6. Hero ============================================ */
body.t-sports .hero {
  background:
    radial-gradient(900px 520px at 88% -10%, rgba(43,217,242,0.14), transparent 60%),
    radial-gradient(800px 540px at -12% 108%, rgba(240,58,86,0.12), transparent 60%),
    var(--sp-stripe),
    linear-gradient(180deg, #0D1622 0%, var(--sp-bg) 100%);
}
body.t-sports .hero::before,
body.t-sports .hero::after { display: none; }
body.t-sports .hero-eyebrow-line { background: var(--sp-red); height: 2px; transform: skewX(var(--sp-skew)); }
body.t-sports .hero-eyebrow-label {
  font-family: var(--sp-disp);
  color: var(--sp-cyan);
  letter-spacing: 0.3em;
  font-weight: 500;
}
body.t-sports .hero-title {
  font-family: var(--sp-sans);
  font-weight: 900;
  color: var(--sp-text);
  letter-spacing: 0.01em;
}
body.t-sports .hero-title em {
  font-style: normal;
  color: transparent;
  background: linear-gradient(115deg, var(--sp-cyan) 0%, #7EE9FA 100%);
  -webkit-background-clip: text;
  background-clip: text;
  position: relative;
}
body.t-sports .hero-title-accent {
  background: linear-gradient(180deg, transparent 0 68%, var(--sp-red-dim) 68% 100%);
  font-weight: 900;
}
body.t-sports .hero-lead { color: var(--sp-text-soft); }
body.t-sports .hero-lead--sub { color: var(--sp-muted); }
body.t-sports .hero-lead em { color: var(--sp-red); font-weight: 700; }
body.t-sports .hero-sub-cta { color: var(--sp-cyan); font-weight: 700; }
body.t-sports .hero-sub-cta:hover { color: #7EE9FA; }
body.t-sports .hero-sub-cta svg { stroke: currentColor; }
body.t-sports .hero-scroll-hint { color: var(--sp-muted); }
body.t-sports .hero-scroll-hint::after { background: linear-gradient(180deg, var(--sp-cyan), transparent); }

/* hero device shell */
body.t-sports .laptop-frame {
  background: #1B222C;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.4),
    0 44px 110px -30px rgba(0,0,0,0.75),
    0 0 80px -20px rgba(43,217,242,0.18);
}
body.t-sports .laptop-browser-bar { background: #232B36; border-bottom: 1px solid rgba(255,255,255,0.06); }
body.t-sports .laptop-tab { background: #2C3540; color: #C6D2DE; }
body.t-sports .laptop-tab--active { background: #39434F; color: #fff; }
body.t-sports .laptop-url { background: #1B222C; color: #9AA8B6; border: 1px solid rgba(255,255,255,0.06); }
body.t-sports .laptop-base { background: linear-gradient(180deg, #2A323D, #161C24); }
body.t-sports .iphone-frame {
  border-color: #1B222C;
  box-shadow:
    0 0 0 2px rgba(255,255,255,0.07),
    0 40px 90px -28px rgba(0,0,0,0.8),
    0 0 64px -18px rgba(43,217,242,0.22);
}

/* ===== 7. Ticker ========================================== */
body.t-sports .ticker {
  background: linear-gradient(115deg, var(--sp-red-deep) 0%, var(--sp-red) 55%, var(--sp-red-deep) 100%);
  border-top: 1px solid rgba(255,255,255,0.16);
  border-bottom: 1px solid rgba(0,0,0,0.35);
}
body.t-sports .ticker-label {
  background: #0B121C;
  color: var(--sp-cyan);
  font-family: var(--sp-disp);
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}
body.t-sports .ticker-item { color: #fff; font-weight: 600; }
body.t-sports .ticker-date { color: rgba(255,255,255,0.65); }
body.t-sports .ticker-amount { color: #FFE16A; font-family: var(--sp-disp); font-weight: 600; letter-spacing: 0.04em; }

/* ===== 8. Salon features (sf-*) =========================== */
body.t-sports .salon-features { background: transparent; }
body.t-sports .sf-item {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  box-shadow: var(--sp-shadow-card);
  border-radius: 6px;
  background-image: var(--sp-stripe);
}
body.t-sports .sf-tag {
  background: var(--sp-red);
  color: #fff;
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 600;
  letter-spacing: 0.2em;
  transform: skewX(var(--sp-skew));
  border-radius: 2px;
}
body.t-sports .sf-heading { color: var(--sp-text); font-weight: 900; font-family: var(--sp-sans); }
body.t-sports .sf-body { color: var(--sp-text-soft); }
body.t-sports .sf-body strong { color: var(--sp-cyan); }
body.t-sports .sf-highlight {
  background: var(--sp-cyan-dim);
  border-left: 3px solid var(--sp-cyan);
}
body.t-sports .sf-highlight-mark { color: var(--sp-cyan); }
body.t-sports .sf-highlight-text { color: var(--sp-text); }
body.t-sports .sf-factor {
  background: #0F1A28;
  border: 1px solid var(--sp-line-2);
  color: var(--sp-text-soft);
  border-radius: 3px;
}
body.t-sports .sf-subblock { border-color: var(--sp-line); background: rgba(255,255,255,0.02); }
body.t-sports .sf-subblock-title { color: var(--sp-cyan); }
body.t-sports .sf-badge {
  background: #0B121C;
  border: 1px solid var(--sp-cyan);
  color: var(--sp-cyan);
  box-shadow: 0 0 24px -6px rgba(43,217,242,0.5);
}
body.t-sports .sf-badge-num { font-family: var(--sp-disp); color: #fff; }
body.t-sports .sf-badge-label { color: var(--sp-cyan); }
body.t-sports .sf-indicator { background: var(--sp-surface-2); border: 1px solid var(--sp-line); }
body.t-sports .sf-indicator-title { color: var(--sp-text); }
body.t-sports .sf-indicator-body { color: var(--sp-muted); }
body.t-sports .sf-indicator-foot { color: var(--sp-muted); }
body.t-sports .sf-marks-row { border-bottom: 1px solid var(--sp-line); }
body.t-sports .sf-marks-text { color: var(--sp-text-soft); }
body.t-sports .sf-marks-row--special { background: var(--sp-red-dim); }
body.t-sports .sf-marks-note { color: var(--sp-muted); }
body.t-sports .sf-mini-legend-text { color: var(--sp-muted); }
body.t-sports .sf-stat { background: var(--sp-surface-2); border: 1px solid var(--sp-line); }
body.t-sports .sf-stat-num { font-family: var(--sp-disp); color: var(--sp-cyan); font-weight: 600; }
body.t-sports .sf-stat-label { color: var(--sp-muted); }
body.t-sports .sf-screenshot {
  border: 1px solid var(--sp-line-2);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,0.7);
  border-radius: 6px;
}
body.t-sports .sf-text .hairline { margin-left: 0; }

/* ===== 9. Results table =================================== */
body.t-sports .results { background: var(--sp-bg-2); background-image: var(--sp-stripe); }
body.t-sports .results-block { background: transparent; }
body.t-sports .results-table-wrap {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-radius: 6px;
  box-shadow: var(--sp-shadow-card);
}
body.t-sports .results-table th {
  background: #0C1520;
  color: var(--sp-cyan);
  font-family: var(--sp-disp);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--sp-line-2);
}
body.t-sports .results-table th small { color: var(--sp-muted); }
body.t-sports .results-table td {
  color: var(--sp-text-soft);
  border-bottom: 1px solid var(--sp-line);
}
body.t-sports .results-table tr:hover td { background: rgba(43,217,242,0.04); }
body.t-sports .results-table .is-hot { color: #FF7A8E; font-weight: 800; }
body.t-sports .results-table .is-warm { color: #FFC46A; font-weight: 700; }
body.t-sports .results-table .is-name { color: var(--sp-text); font-weight: 700; }
body.t-sports .is-premium, body.t-sports .is-regular {
  font-family: var(--sp-disp);
  font-weight: 600;
  letter-spacing: 0.1em;
  font-size: 10.5px;
  padding: 3px 10px;
  border-radius: 2px;
  transform: skewX(var(--sp-skew));
  display: inline-block;
}
body.t-sports .is-premium { background: var(--sp-red-dim); color: #FF8296; border: 1px solid rgba(240,58,86,0.45); }
body.t-sports .is-regular { background: var(--sp-cyan-dim); color: var(--sp-cyan); border: 1px solid rgba(43,217,242,0.4); }
body.t-sports .picks-empty-cell { color: var(--sp-muted); }
body.t-sports .picks-skeleton { background: linear-gradient(90deg, var(--sp-surface) 25%, var(--sp-surface-2) 50%, var(--sp-surface) 75%); }
body.t-sports .results-note { color: var(--sp-muted); }

/* ===== 10. Voices ========================================= */
body.t-sports .voice {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-radius: 6px;
  box-shadow: var(--sp-shadow-card);
}
body.t-sports .voice::before { color: var(--sp-cyan); opacity: 0.6; }
body.t-sports .voice-image-wrap { border: 1px solid var(--sp-line-2); border-radius: 6px; overflow: hidden; }
body.t-sports .voice-image-caption { color: var(--sp-muted); }

/* ===== 11. Plans ========================================== */
body.t-sports .plans { background: var(--sp-bg-3); background-image: var(--sp-stripe); }
body.t-sports .plans-intro-num { font-family: var(--sp-disp); color: var(--sp-cyan); }
body.t-sports .plans-intro-title { color: var(--sp-text); font-weight: 900; }
body.t-sports .plans-intro-body { color: var(--sp-muted); }
body.t-sports .plans-tier { border: 1px solid var(--sp-line); background: rgba(255,255,255,0.015); border-radius: 8px; }
body.t-sports .plans-tier--premium { border-top: 3px solid var(--sp-red); }
body.t-sports .plans-tier--regular { border-top: 3px solid var(--sp-cyan); }
body.t-sports .plans-tier-mark {
  font-family: var(--sp-disp);
  font-weight: 600;
  letter-spacing: 0.3em;
  transform: skewX(var(--sp-skew));
  display: inline-block;
  padding: 3px 14px;
  border-radius: 2px;
}
body.t-sports .plans-tier--premium .plans-tier-mark { background: var(--sp-red); color: #fff; }
body.t-sports .plans-tier--regular .plans-tier-mark { background: var(--sp-cyan); color: #0B121C; }
body.t-sports .plans-tier-title { color: var(--sp-text); font-weight: 900; }
body.t-sports .plans-tier-desc { color: var(--sp-muted); }
body.t-sports .plan {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-radius: 6px;
  box-shadow: var(--sp-shadow-card);
}
body.t-sports .plan--featured {
  background: linear-gradient(180deg, rgba(240,58,86,0.08), rgba(240,58,86,0.02) 40%), var(--sp-surface);
  border: 1px solid rgba(240,58,86,0.55);
  box-shadow: 0 0 0 1px rgba(240,58,86,0.25), 0 28px 70px -24px rgba(240,58,86,0.35);
}
body.t-sports .plan--featured::before {
  background: var(--sp-red);
  color: #fff;
  font-weight: 800;
  transform: translateX(-50%) skewX(var(--sp-skew));
  border-radius: 2px;
}
body.t-sports .plan-name {
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 600;
  color: var(--sp-cyan);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
body.t-sports .plan-name-jp { color: var(--sp-text); font-weight: 800; }
body.t-sports .plan-price {
  font-family: var(--sp-disp);
  font-weight: 700;
  color: var(--sp-text);
  letter-spacing: 0.02em;
}
body.t-sports .plan-price-yen, body.t-sports .plan-price-period { color: var(--sp-muted); }
body.t-sports .plan-monthly { color: var(--sp-muted); }
body.t-sports .plan-monthly strong { color: var(--sp-lime); }
body.t-sports .plan-save {
  background: rgba(168,224,74,0.12);
  color: var(--sp-lime);
  border: 1px solid rgba(168,224,74,0.4);
  font-weight: 800;
  transform: skewX(var(--sp-skew));
  display: inline-block;
  border-radius: 2px;
}
body.t-sports .plan-features { color: var(--sp-text-soft); border-top: 1px solid var(--sp-line); border-bottom: 1px solid var(--sp-line); }
body.t-sports .plan-features strong { color: var(--sp-cyan); }
body.t-sports .plan-step-label, body.t-sports .plan-apply-label {
  font-family: var(--sp-disp);
  color: var(--sp-muted);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
body.t-sports .plan-warn-badge {
  background: rgba(255, 196, 106, 0.08);
  border: 1px solid rgba(255, 196, 106, 0.35);
  color: #FFC46A;
  border-radius: 4px;
}
body.t-sports .plan-warn-badge-icon { background: #FFC46A; color: #0B121C; }
body.t-sports .plan-warn-badge-text strong { color: #FFD896; }
body.t-sports .plan-apply-btn {
  background: linear-gradient(135deg, var(--sp-red), var(--sp-red-deep));
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.08em;
  border: none;
  border-radius: 3px;
  transform: skewX(var(--sp-skew));
  box-shadow: 0 12px 30px -12px rgba(240,58,86,0.6);
}
body.t-sports .plan-apply-btn:hover { background: linear-gradient(135deg, #FF5A73, var(--sp-red)); color: #fff; transform: skewX(var(--sp-skew)) translateY(-2px); }
body.t-sports .plan-bank { background: rgba(255,255,255,0.03); border: 1px dashed var(--sp-line-2); color: var(--sp-text-soft); }
body.t-sports .plan--featured .plan-bank { background: rgba(255,255,255,0.05); }
body.t-sports .plan-bank-label { color: var(--sp-cyan); }
body.t-sports .plan-note { color: var(--sp-muted); }
body.t-sports .plan-pay-or { color: var(--sp-muted); }
body.t-sports .plans-payment-legend { border: 1px solid var(--sp-line); background: rgba(255,255,255,0.02); border-radius: 6px; }
body.t-sports .plans-payment-legend-text { color: var(--sp-text-soft); }
body.t-sports .plans-flow-step { background: var(--sp-surface); border: 1px solid var(--sp-line); color: var(--sp-text-soft); }
body.t-sports .plans-flow-num { font-family: var(--sp-disp); background: var(--sp-cyan); color: #0B121C; font-weight: 700; }
body.t-sports .plans-flow-arrow { color: var(--sp-cyan); }
body.t-sports .plans-foot { color: var(--sp-muted); }
body.t-sports .plans-compare-table th,
body.t-sports .plans-compare-table td { border-color: var(--sp-line); color: var(--sp-text-soft); }
body.t-sports .plans-compare-table thead th { background: #0C1520; color: var(--sp-cyan); font-family: var(--sp-disp); letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500; }
body.t-sports .plans-compare-table { background: var(--sp-surface); border: 1px solid var(--sp-line); border-radius: 6px; overflow: hidden; }
body.t-sports .plans-compare-mark { color: var(--sp-lime); }
body.t-sports .plans-compare-name { color: var(--sp-text); }

/* ===== 12. Mobile-ready =================================== */
body.t-sports .mobile-ready { background: var(--sp-bg-2); background-image: var(--sp-stripe); }
body.t-sports .mobile-ready-feature { background: var(--sp-surface); border: 1px solid var(--sp-line); border-radius: 6px; }
body.t-sports .mobile-ready-feature-icon { background: var(--sp-cyan-dim); color: var(--sp-cyan); border: 1px solid rgba(43,217,242,0.35); }
body.t-sports .mobile-ready-feature-title { color: var(--sp-text); font-weight: 800; }
body.t-sports .mobile-ready-feature-body { color: var(--sp-muted); }
body.t-sports .mobile-ready-device-caption { color: var(--sp-muted); }
body.t-sports .device-nav-btn {
  background: var(--sp-surface-2);
  border: 1px solid var(--sp-line-2);
  color: var(--sp-text);
}
body.t-sports .device-nav-btn:hover { border-color: var(--sp-cyan); color: var(--sp-cyan); }
body.t-sports .device-dot { background: var(--sp-line-2); }
body.t-sports .device-dot.active { background: var(--sp-cyan); }

/* ===== 13. FAQ ============================================ */
body.t-sports .faq { background: transparent; }
body.t-sports .faq-item { background: var(--sp-surface); border: 1px solid var(--sp-line); border-radius: 6px; }
body.t-sports .faq-item.open { border-color: rgba(43,217,242,0.4); }
body.t-sports .faq-q { color: var(--sp-text); font-weight: 700; }
body.t-sports .faq-q::before, body.t-sports .faq-q::after { background: var(--sp-cyan); }
body.t-sports .faq-a { color: var(--sp-muted); }
body.t-sports .faq-a strong { color: var(--sp-text-soft); }
body.t-sports .faq-more-btn {
  background: transparent;
  border: 1.5px solid var(--sp-line-2);
  color: var(--sp-text);
  font-weight: 700;
  border-radius: 3px;
  transform: skewX(var(--sp-skew));
}
body.t-sports .faq-more-btn:hover { border-color: var(--sp-cyan); color: var(--sp-cyan); }

/* ===== 14. Profile ======================================== */
body.t-sports .profile { background: var(--sp-bg-3); background-image: var(--sp-stripe); }
body.t-sports .profile-card { background: var(--sp-surface); border: 1px solid var(--sp-line); box-shadow: var(--sp-shadow-card); border-radius: 8px; }
body.t-sports .profile-visual-bg { background: linear-gradient(135deg, rgba(43,217,242,0.18), rgba(240,58,86,0.14)); }
body.t-sports .profile-img { border: 1px solid var(--sp-line-2); }
body.t-sports .profile-name { color: var(--sp-text); font-weight: 900; }
body.t-sports .profile-name-en { font-family: var(--sp-disp); color: var(--sp-cyan); letter-spacing: 0.3em; }
body.t-sports .profile-body { color: var(--sp-text-soft); }
body.t-sports .profile-meta-item { border-left: 2px solid var(--sp-cyan); }
body.t-sports .profile-meta-label { color: var(--sp-muted); }
body.t-sports .profile-books-tag {
  background: var(--sp-red);
  color: #fff;
  font-family: var(--sp-disp);
  letter-spacing: 0.2em;
  transform: skewX(var(--sp-skew));
  display: inline-block;
  border-radius: 2px;
}
body.t-sports .profile-book-card { background: var(--sp-surface-2); border: 1px solid var(--sp-line); }
body.t-sports .profile-book-cover { border: 1px solid var(--sp-line-2); }
body.t-sports .profile-books-note { color: var(--sp-muted); }

/* ===== 15. Why ============================================ */
body.t-sports .why-ashiguchi { background: var(--sp-bg-2); background-image: var(--sp-stripe); }
body.t-sports .why-card {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-top: 3px solid var(--sp-cyan);
  border-radius: 6px;
  box-shadow: var(--sp-shadow-card);
}
body.t-sports .why-card:nth-child(2) { border-top-color: var(--sp-red); }
body.t-sports .why-card:nth-child(3) { border-top-color: var(--sp-lime); }
body.t-sports .why-card-num {
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 700;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(43,217,242,0.5);
}
body.t-sports .why-card:nth-child(2) .why-card-num { -webkit-text-stroke-color: rgba(240,58,86,0.55); }
body.t-sports .why-card:nth-child(3) .why-card-num { -webkit-text-stroke-color: rgba(168,224,74,0.5); }
body.t-sports .why-card-tag {
  font-family: var(--sp-disp);
  color: var(--sp-cyan);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}
body.t-sports .why-card-title { color: var(--sp-text); font-weight: 900; }
body.t-sports .why-card-body { color: var(--sp-muted); }
body.t-sports .why-card-accent { border-top: 1px dashed var(--sp-line-2); }
body.t-sports .why-card-accent-num { font-family: var(--sp-disp); color: var(--sp-cyan); font-weight: 600; }
body.t-sports .why-card-accent-label { color: var(--sp-muted); }
body.t-sports .why-card-accent-chip {
  background: var(--sp-cyan-dim);
  color: var(--sp-cyan);
  border: 1px solid rgba(43,217,242,0.4);
}
body.t-sports .why-foot { color: var(--sp-text-soft); }
body.t-sports .why-foot-avatar { border: 2px solid var(--sp-cyan); box-shadow: 0 0 24px -6px rgba(43,217,242,0.5); }

/* ===== 16. Footer ========================================= */
body.t-sports .lp-footer {
  background: #070D15;
  border-top: 1px solid var(--sp-line);
  color: var(--sp-muted);
}
body.t-sports .footer-mark {
  background: linear-gradient(135deg, var(--sp-red), var(--sp-red-deep));
  color: #fff;
  transform: skewX(var(--sp-skew));
  border-radius: 2px;
}
body.t-sports .footer-brand { color: var(--sp-text); font-family: var(--sp-disp); letter-spacing: 0.18em; }
body.t-sports .footer-tagline { color: var(--sp-muted); }
body.t-sports .footer-col-title { color: var(--sp-cyan); font-family: var(--sp-disp); letter-spacing: 0.24em; text-transform: uppercase; }
body.t-sports .footer-links a { color: var(--sp-muted); }
body.t-sports .footer-links a:hover { color: var(--sp-cyan); }
body.t-sports .footer-legal { border-top: 1px solid var(--sp-line); }
body.t-sports .footer-legal-title { color: var(--sp-text-soft); }
body.t-sports .footer-legal-note, body.t-sports .footer-legal-list { color: var(--sp-muted); }
body.t-sports .footer-bottom { border-top: 1px solid var(--sp-line); }
body.t-sports .footer-copy { color: var(--sp-muted); }

/* ===== 17. Sticky CTA / Scroll top / Lightbox ============= */
body.t-sports .sticky-cta {
  background: rgba(11, 18, 28, 0.9);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--sp-line-2);
  box-shadow: 0 -16px 40px -18px rgba(0,0,0,0.8);
}
body.t-sports .sticky-cta-btn {
  background: linear-gradient(135deg, var(--sp-red), var(--sp-red-deep));
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.1em;
  border-radius: 3px;
  box-shadow: 0 10px 28px -10px rgba(240,58,86,0.7);
}
body.t-sports .sticky-cta-btn:hover { background: linear-gradient(135deg, #FF5A73, var(--sp-red)); color: #fff; }
body.t-sports .scroll-top {
  background: var(--sp-surface-2);
  border: 1px solid var(--sp-line-2);
  color: var(--sp-cyan);
}
body.t-sports .scroll-top:hover { background: var(--sp-cyan); color: #0B121C; border-color: var(--sp-cyan); }
body.t-sports .lightbox-overlay { background: rgba(5, 9, 15, 0.92); }
body.t-sports .lightbox-caption { color: var(--sp-text-soft); }
body.t-sports .lightbox-close { color: #fff; }

/* ===== 18. Fine tuning ==================================== */
/* セクション境界の斜めアクセント */
body.t-sports .results,
body.t-sports .plans,
body.t-sports .mobile-ready,
body.t-sports .why-ashiguchi,
body.t-sports .profile { position: relative; }
body.t-sports .results::before,
body.t-sports .plans::before,
body.t-sports .mobile-ready::before,
body.t-sports .why-ashiguchi::before,
body.t-sports .profile::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--sp-red) 0%, var(--sp-red) 18%, transparent 18.5%, transparent 20%, var(--sp-cyan) 20.5%, var(--sp-cyan) 26%, transparent 26.5%);
  opacity: 0.8;
  pointer-events: none;
}

/* モック内部はライトのまま: 影だけ濃く */
body.t-sports .ks-mock-table, body.t-sports .ks-mock-body { box-shadow: none; }

/* アクセシビリティ: motion 配慮は base 側の設定を継承 */
@media (prefers-reduced-motion: reduce) {
  body.t-sports .btn--primary, body.t-sports .plan-apply-btn { transition: none; }
}

/* ============================================================
   v2 (2026-06-04) 視認性修正 — 本番確認で発覚した低コントラスト箇所
   1) 旧テーマの金マーカー (gold-pale gradient) を暗背景用に置換
   2) ライト背景のまま残っていたブロックをダーク化
   3) 見出し内 em のセリフ斜体を解除
   ============================================================ */

/* ---- 1. 金マーカー強調 → シアン下線ハイライト ---- */
body.t-sports .hero-lead em,
body.t-sports .sf-body strong,
body.t-sports .sf-indicator-body strong,
body.t-sports .why-card-body strong,
body.t-sports .profile-body strong {
  color: var(--sp-text);
  background: linear-gradient(180deg, transparent 0 72%, rgba(43, 217, 242, 0.28) 72% 100%);
  padding: 0 2px;
  font-weight: 700;
}
body.t-sports .hero-lead em { color: #FF8296; background: linear-gradient(180deg, transparent 0 72%, rgba(240, 58, 86, 0.3) 72% 100%); }
body.t-sports .results-note strong,
body.t-sports .plans-foot strong,
body.t-sports .faq-a strong { color: var(--sp-cyan); background: none; }

/* ---- 2. 見出し内 em (セリフ斜体・金) の解除 ---- */
body.t-sports .section-title em,
body.t-sports .why-card-title em,
body.t-sports .profile-name em {
  font-family: inherit;
  font-style: normal;
  font-weight: inherit;
}
body.t-sports .why-card-title em { color: var(--sp-cyan); }
body.t-sports .profile-name { color: var(--sp-text); }
body.t-sports .profile-name em { color: var(--sp-red); }

/* ---- 3. 会員の声: セクションごとダーク化 ---- */
body.t-sports .voices { background: var(--sp-bg-2); background-image: var(--sp-stripe); }
body.t-sports .voice { background: var(--sp-surface); }
body.t-sports .voice-meta { color: var(--sp-muted); }
body.t-sports .voice-name { color: var(--sp-text); }

/* ---- 4. お申し込みの流れ (plans-intro) ---- */
body.t-sports .plans-intro {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-left: 3px solid var(--sp-cyan);
  border-radius: 6px;
}
body.t-sports .plans-intro-title { color: var(--sp-text); }

/* ---- 5. プラン比較表 ---- */
body.t-sports .plans-compare-table { background: var(--sp-surface); border: 1px solid var(--sp-line); font-family: var(--sp-sans); }
body.t-sports .plans-compare-table thead th { border-bottom: 1px solid var(--sp-line-2); }
body.t-sports .plans-compare-table thead th.is-feature { background: #0C1520; }
body.t-sports .plans-compare-table thead th.is-premium { background: linear-gradient(135deg, var(--sp-red-deep), var(--sp-red)); color: #fff; }
body.t-sports .plans-compare-table thead th.is-regular { background: var(--sp-surface-2); color: var(--sp-text); }
body.t-sports .plans-compare-table thead th.is-premium .plans-compare-mark { color: #FFD0D9; }
body.t-sports .plans-compare-table thead th.is-regular .plans-compare-mark { color: var(--sp-cyan); }
body.t-sports .plans-compare-table tbody td { color: var(--sp-text-soft); border-bottom: 1px solid var(--sp-line); background: transparent; }
body.t-sports .plans-compare-table tbody td.is-feature { background: #0C1520; color: var(--sp-text); font-weight: 600; }
body.t-sports .plans-compare-table tbody tr:hover td { background: rgba(43, 217, 242, 0.05); }

/* ---- 6. sf-marks 系 白カード → ダークカード ---- */
body.t-sports .sf-marks-row {
  background: #0F1A28;
  border: 1px solid var(--sp-line);
}
body.t-sports .sf-marks-row b,
body.t-sports .sf-marks-row strong { color: var(--sp-cyan); background: none; }
body.t-sports .sf-marks-row--special {
  background: var(--sp-red-dim);
  border-color: rgba(240, 58, 86, 0.45);
}
body.t-sports .sf-marks-note { color: var(--sp-muted); font-style: normal; }

/* ---- 7. sf-subblock-title 等のセリフ斜体見出し → Oswald ---- */
body.t-sports .sf-subblock-title,
body.t-sports .plan-bank-label,
body.t-sports .footer-legal-title,
body.t-sports .plans-intro-num {
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 600;
  letter-spacing: 0.24em;
  color: var(--sp-cyan);
  border-bottom-color: var(--sp-line);
}

/* ---- 8. PayPal ボタン: 規定の紺色文字を強制 (strong 上書き対策) ---- */
body.t-sports .plan-paypal-btn,
body.t-sports .plan-paypal-btn strong,
body.t-sports .plan-paypal-btn span { color: #003087 !important; background: none; }

/* ---- 9. 銀行振込テーブル ---- */
body.t-sports .plan-bank td { color: var(--sp-text-soft); }
body.t-sports .plan-bank td:first-child { color: var(--sp-muted); }

/* ---- 10. プロフィール メタ・運営者情報 ---- */
body.t-sports .profile-meta-item { color: var(--sp-text-soft); }
body.t-sports .profile-meta-label {
  font-family: var(--sp-disp);
  font-style: normal;
  color: var(--sp-cyan);
}
body.t-sports .footer-legal-list dt,
body.t-sports .footer-legal-list dd,
body.t-sports .footer-legal-list { color: var(--sp-text-soft); }
body.t-sports .footer-legal-note {
  background: var(--sp-surface);
  border-left: 2px solid var(--sp-cyan);
  color: var(--sp-text-soft);
}

/* ---- 11. 的中実績テーブルの hover (base の cream 上書き) ---- */
body.t-sports .results-table--picks tbody tr:hover td { background: rgba(43, 217, 242, 0.05); }

/* ---- 12. プレミアム説明文 (gold-pale 文字) ---- */
body.t-sports .plans-tier--premium .plans-tier-desc { color: var(--sp-text-soft); }
body.t-sports .plans-tier--premium .plans-tier-desc strong,
body.t-sports .plans-tier-desc strong { color: var(--sp-cyan); background: none; }

/* ---- 13. why-card-num: ローマ数字を Noto で描画 (Oswald に字形なし) ---- */
body.t-sports .why-card-num { font-family: var(--sp-sans); font-weight: 900; }

/* ---- 14. ヘッダー入会ボタンの折り返し防止 ---- */
body.t-sports .header-join { white-space: nowrap; }
body.t-sports .sticky-cta-btn { white-space: nowrap; }

/* ---- 15. mobile-ready 本文の可読性 ---- */
body.t-sports .mobile-ready-feature-body { color: var(--sp-text-soft); }

/* ============================================================
   v3 (2026-06-04) 本番再確認での残修正
   ============================================================ */

/* PayPal カスタムボタン: v2 で background まで消していたのを修正 */
body.t-sports .plan-paypal-btn { background: #FFC439 !important; border: none; }
body.t-sports .plan-paypal-btn:hover { background: #FFD25E !important; }

/* プランティアヘッダ (REGULAR がクリームのままだった) */
body.t-sports .plans-tier-head,
body.t-sports .plans-tier--regular .plans-tier-head {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-left: 4px solid var(--sp-cyan);
  color: var(--sp-text-soft);
}
body.t-sports .plans-tier--premium .plans-tier-head {
  background: var(--sp-surface);
  border: 1px solid var(--sp-line);
  border-left: 4px solid var(--sp-red);
  color: var(--sp-text-soft);
}

/* sf-indicator-foot (印の重みノート) のクリーム残り */
body.t-sports .sf-indicator-foot {
  background: rgba(255, 255, 255, 0.03);
  border-left: 2px solid var(--sp-cyan);
  color: var(--sp-muted);
}
body.t-sports .sf-indicator-foot strong { color: var(--sp-cyan); background: none; }

/* sf-marks-text 内の strong ラベル (確率カスタマイズ 等) を確実にシアンへ */
body.t-sports .sf-marks-list .sf-marks-text strong,
body.t-sports .sf-marks-row .sf-marks-text strong {
  color: var(--sp-cyan);
  background: none;
}

/* ============================================================
   v4 (2026-06-04) ヒーロースライド実画像化に伴う調整
   ============================================================ */
body.t-sports .laptop-slide { padding: 0; overflow: hidden; background: #FBF8F2; }
body.t-sports .laptop-slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}

/* ============================================================
   v5 (2026-06-04) 入会案内・FAQ・スマホ・Whyセクション調整
   ============================================================ */

/* 比較表: 右余白の偏りを解消し 3 列を均等配分 */
body.t-sports .plans-compare-table { table-layout: fixed; width: 100%; min-width: 560px; }
body.t-sports .plans-compare-table th.is-feature,
body.t-sports .plans-compare-table td.is-feature { width: 44%; }
body.t-sports .plans-compare-table th.is-premium,
body.t-sports .plans-compare-table td.is-premium,
body.t-sports .plans-compare-table th.is-regular,
body.t-sports .plans-compare-table td.is-regular { width: 28%; text-align: center; }
body.t-sports .plans-compare-table tbody td { padding: 16px 14px; }
body.t-sports .plans-compare-table .price {
  font-family: var(--sp-disp);
  font-style: normal;
  font-weight: 600;
  font-size: 18px;
  color: var(--sp-text);
  letter-spacing: 0.02em;
}
body.t-sports .plans-compare-table small { color: var(--sp-muted); }
body.t-sports .plans-compare-table .ok {
  display: inline-block;
  background: var(--sp-cyan-dim);
  border: 1px solid rgba(43, 217, 242, 0.4);
  color: var(--sp-cyan);
  font-weight: 700;
  font-size: 12px;
  padding: 4px 14px;
  border-radius: 2px;
  transform: skewX(var(--sp-skew));
}

/* FAQ: カード化に伴う内側余白 */
body.t-sports .faq-item { padding: 2px 24px; }
body.t-sports .faq-item .faq-q { padding-left: 0; }
body.t-sports .faq-item.open .faq-a { padding-bottom: 22px; }

/* スマホでも全機能: 本文テキストが基底の黒のままだった */
body.t-sports .mobile-ready-feature-text { color: var(--sp-text-soft); }
body.t-sports .section-lead--center { color: var(--sp-muted); }

/* Why: プローズ本文 */
body.t-sports .why-prose { max-width: 880px; }
body.t-sports .why-prose p {
  color: var(--sp-text-soft);
  font-size: 15px;
  line-height: 2.1;
  margin: 0 0 1.4em;
}
body.t-sports .why-prose strong { color: var(--sp-cyan); font-weight: 700; }

/* ============================================================
   v6 (2026-06-04) F03指標カード余白 / 会員の声ズームカーソル
   ============================================================ */
body.t-sports .sf-indicators { display: grid; gap: 14px; }
body.t-sports .sf-indicator { padding: 18px 22px; border-radius: 4px; }
body.t-sports .sf-indicator-title { margin: 0 0 10px; }
body.t-sports .sf-indicator-body { margin: 0; }
body.t-sports .voice-image-wrap { cursor: zoom-in; }

/* ============================================================
   v7 (2026-06-04) スマホのモックUI / ハイライト余白改善
   ============================================================ */
@media (max-width: 768px) {
  /* ◆ハイライト帯: 余白と行間を確保 */
  body.t-sports .sf-highlight {
    padding: 14px 16px;
    gap: 10px;
    align-items: flex-start;
  }
  body.t-sports .sf-highlight-text { font-size: 13px; line-height: 1.7; }

  /* 勝負レースのモックカード: 3列→2列 (3枚目は非表示) で1枚あたりを読める大きさに */
  body.t-sports .ks-mock-pick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
  body.t-sports .ks-mock-pick-grid .ks-mock-pick:nth-child(3) { display: none; }
  body.t-sports .ks-mock-pick { padding: 9px 10px !important; }
  body.t-sports .ks-mock-pick-stat { padding: 6px 8px !important; }
  body.t-sports .ks-mock-pick-stat-label { font-size: 8.5px !important; }
  body.t-sports .ks-mock-pick-stat-val { font-size: 13px !important; }
  body.t-sports .ks-mock-pick-himo { gap: 4px !important; }

  /* モック表: スマホでは副次列を隠して主要列に余白を回す */
  body.t-sports .laptop-slide[data-label="オリジナル注目馬"] .ks-mock-table th:nth-child(5),
  body.t-sports .laptop-slide[data-label="オリジナル注目馬"] .ks-mock-table td:nth-child(5),
  body.t-sports .laptop-slide[data-label="オリジナル注目馬"] .ks-mock-table th:nth-child(6),
  body.t-sports .laptop-slide[data-label="オリジナル注目馬"] .ks-mock-table td:nth-child(6) { display: none; }

  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table th:nth-child(4),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table td:nth-child(4),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table th:nth-child(5),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table td:nth-child(5),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table th:nth-child(6),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table td:nth-child(6),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table th:nth-child(7),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table td:nth-child(7),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table th:nth-child(8),
  body.t-sports .laptop-slide[data-label="MONSTER解析表"] .ks-mock-table td:nth-child(8) { display: none; }

  body.t-sports .laptop-slide[data-label="追い切り詳細チェック"] .ks-mock-table th:nth-child(6),
  body.t-sports .laptop-slide[data-label="追い切り詳細チェック"] .ks-mock-table td:nth-child(6) { display: none; }

  /* モック表セルの最低限の余白 */
  body.t-sports .laptop-slide .ks-mock-table th,
  body.t-sports .laptop-slide .ks-mock-table td { padding: 4px 5px !important; }
}
