/* ============================================================
   どこスポ スタイルシート — Apple HP風デザイン
   白基調・大型タイポグラフィ・すりガラスナビ・ピル型ボタン
   ============================================================ */
:root {
  --bg: #ffffff;
  --bg-alt: #f5f5f7;
  --bg-hero: #fbfbfd;
  --card: #ffffff;
  --ink: #1d1d1f;
  --ink-soft: #6e6e73;
  --ink-faint: #86868b;
  --line: #d2d2d7;
  --blue: #0071e3;
  --blue-hover: #0077ed;
  --link: #0066cc;
  --green: #248a3d;
  --green-tint: rgba(52, 199, 89, .13);
  --blue-tint: rgba(0, 122, 255, .12);
  --purple: #8944ab;
  --purple-tint: rgba(175, 82, 222, .12);
  --yellow-tint: rgba(255, 204, 0, .16);
  --yellow-ink: #946300;
  --red: #ff3b30;
  --red-deep: #d70015; /* 白文字でWCAG AA(4.5:1)を満たす濃い赤。テキスト背景はこちらを使う */
  --radius: 18px;
  --shadow: 0 4px 20px rgba(0, 0, 0, .06);
  --shadow-hover: 0 12px 32px rgba(0, 0, 0, .10);
}

* { box-sizing: border-box; }
/* hidden属性をdisplay指定のある要素（.sched-list等）にも確実に効かせる */
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue",
    "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Yu Gothic UI", sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.65;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: inherit; }

/* ---- PR表記バー（景品表示法対応：ページ最上部に常時表示） ---- */
.pr-bar {
  background: var(--bg-alt);
  color: var(--ink-faint);
  font-size: 11.5px;
  text-align: center;
  padding: 7px 12px;
  border-bottom: 1px solid rgba(0, 0, 0, .06);
}

/* ---- すりガラスの固定ナビ ---- */
.glass-nav {
  position: sticky; top: 0; z-index: 40;
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  background: rgba(255, 255, 255, .78);
  border-bottom: 1px solid rgba(0, 0, 0, .08);
}
.glass-nav .nav-inner {
  max-width: 1080px; margin: 0 auto; padding: 0 22px;
  height: 48px; display: flex; align-items: center; gap: 26px;
}
.nav-brand { font-size: 17px; font-weight: 700; color: var(--ink); letter-spacing: -.01em; }
.nav-brand .spo { color: var(--blue); }
.nav-brand:hover { text-decoration: none; }
.nav-links { display: flex; gap: 24px; margin-left: auto; }
.nav-links a { font-size: 12.5px; color: rgba(29, 29, 31, .82); }
.nav-links a:hover { color: var(--ink); text-decoration: none; }

/* ---- ヒーロー（フルスクリーン・パララックス） ---- */
.hero {
  position: relative;
  background: radial-gradient(130% 100% at 50% 0%, #1b2032 0%, #0c0e18 55%, #07080d 100%);
  color: #f5f5f7;
  text-align: center;
  padding: 100px 22px 110px;
  min-height: 92svh;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.hero-inner { width: 100%; max-width: 880px; min-width: 0; margin: 0 auto; position: relative; z-index: 2; }
.hero h1 {
  margin: 0 0 16px;
  font-size: clamp(42px, 7.5vw, 84px);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -.02em;
  color: #f5f5f7;
}
.hero h1 .grad {
  background: linear-gradient(95deg, #2997ff 0%, #5e5ce6 55%, #bf5af2 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hero .tagline {
  font-size: clamp(16px, 2.4vw, 22px);
  color: #a1a1a6;
  margin: 0 0 8px;
  font-weight: 400;
}
.hero .updated { font-size: 12px; color: rgba(255, 255, 255, .42); margin: 0 0 32px; }
.hero-ctas { display: flex; gap: 18px; justify-content: center; align-items: center; flex-wrap: wrap; margin-bottom: 36px; }
.link-arrow { font-size: 15px; color: var(--link); }
.link-arrow:hover { text-decoration: underline; }
.hero .link-arrow { color: #2997ff; }
.hero .btn-ghost { background: rgba(255, 255, 255, .12); color: #f5f5f7; }
.hero .btn-ghost:hover { background: rgba(255, 255, 255, .2); }
.hero .toggle-free input { accent-color: #2997ff; }

/* パララックス装飾レイヤー（JSがdata-depthに応じてtransformを更新） */
.hero-decor { position: absolute; inset: -10% 0; pointer-events: none; z-index: 0; }
.decor { position: absolute; will-change: transform; }
.decor-watermark {
  left: 0; right: 0; top: 6%;
  text-align: center;
  font-size: clamp(110px, 24vw, 330px);
  font-weight: 800; line-height: 1; letter-spacing: .03em;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(255, 255, 255, .07);
  user-select: none; white-space: nowrap;
}
.decor-orb { border-radius: 50%; filter: blur(70px); opacity: .6; }
.decor-orb.o1 { width: 540px; height: 540px; left: -150px; top: -90px; background: radial-gradient(circle, rgba(10, 132, 255, .42), transparent 70%); }
.decor-orb.o2 { width: 640px; height: 640px; right: -200px; bottom: -180px; background: radial-gradient(circle, rgba(191, 90, 242, .34), transparent 70%); }
.decor-ball { font-size: clamp(44px, 7vw, 96px); filter: drop-shadow(0 18px 30px rgba(0, 0, 0, .5)); animation: floaty 7s ease-in-out infinite; }
.decor-ball.b1 { left: 6%; top: 22%; }
.decor-ball.b2 { right: 8%; top: 30%; font-size: clamp(34px, 5vw, 72px); animation-delay: 1.2s; }
.decor-ball.b3 { left: 12%; bottom: 18%; font-size: clamp(30px, 4.5vw, 64px); animation-delay: 2.2s; }
.decor-ball.b4 { right: 13%; bottom: 14%; filter: blur(2px) drop-shadow(0 18px 30px rgba(0, 0, 0, .5)); animation-delay: .6s; }
@keyframes floaty { 0%, 100% { translate: 0 0; } 50% { translate: 0 -16px; } }
@media (prefers-reduced-motion: reduce) { .decor-ball { animation: none; } }

.scroll-cue {
  position: absolute; bottom: 20px; left: 0; right: 0; z-index: 2;
  text-align: center; font-size: 10.5px; letter-spacing: .34em;
  color: rgba(255, 255, 255, .4); animation: cuePulse 2.4s ease-in-out infinite;
}
@keyframes cuePulse { 0%, 100% { opacity: .35; } 50% { opacity: .85; } }

/* セクションの英字アイブロウ（小さなキャップス見出し） */
.eyebrow {
  display: block; text-align: center;
  font-size: 11.5px; font-weight: 600; letter-spacing: .34em;
  color: var(--blue); margin-bottom: 10px;
}

.search-row { display: flex; gap: 12px; justify-content: center; align-items: center; flex-wrap: wrap; }
.search-box {
  flex: 0 1 520px; min-width: 260px;
  display: flex; align-items: center; gap: 10px;
  background: #fff;
  border: 1px solid transparent;
  border-radius: 980px; padding: 11px 20px;
  box-shadow: 0 10px 36px rgba(0, 0, 0, .35);
  transition: box-shadow .25s ease, border-color .25s ease;
}
.search-box:focus-within { border-color: #2997ff; box-shadow: 0 0 0 4px rgba(41, 151, 255, .25); }
.search-box input {
  border: none; outline: none; font-size: 15px; width: 100%;
  background: transparent; color: var(--ink);
}

/* ---- ボタン ---- */
.btn {
  border: none; border-radius: 980px; cursor: pointer;
  font-size: 14px; font-weight: 500; padding: 10px 22px;
  transition: background .2s ease, transform .12s ease;
}
.btn:active { transform: scale(.975); }
.btn-accent { background: var(--blue); color: #fff; }
.btn-accent:hover { background: var(--blue-hover); }
.btn-lg { font-size: 16px; padding: 13px 28px; }
.btn-ghost {
  background: rgba(0, 0, 0, .045); color: var(--ink);
  border: none;
}
.btn-ghost:hover { background: rgba(0, 0, 0, .08); }
.toggle-free { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; cursor: pointer; user-select: none; }
.toggle-free input { accent-color: var(--blue); width: 15px; height: 15px; }

/* ---- 注目ストリップ ---- */
.featured-strip {
  display: flex; gap: 10px; justify-content: flex-start;
  overflow-x: auto; padding: 30px 4px 4px; max-width: 880px; margin: 0 auto;
  scrollbar-width: none;
}
.featured-strip::-webkit-scrollbar { display: none; }
.featured-chip {
  flex: 0 0 auto; cursor: pointer;
  background: rgba(255, 255, 255, .08); border: 1px solid rgba(255, 255, 255, .18);
  color: #f5f5f7; border-radius: 980px; padding: 8px 18px; font-size: 13px;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  transition: border-color .2s ease, background .2s ease;
}
.featured-chip b { color: #2997ff; margin-right: 7px; font-weight: 600; }
.featured-chip:hover { border-color: rgba(255, 255, 255, .45); background: rgba(255, 255, 255, .14); }

/* ---- レイアウト ---- */
main { margin: 0; padding: 0; }
section { padding: 72px 0; }
section.alt { background: var(--bg-alt); }
.container { max-width: 1080px; margin: 0 auto; padding: 0 22px; }
.section-title {
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 700; letter-spacing: -.015em;
  text-align: center; margin: 0 0 8px; line-height: 1.25;
}
.section-title .count-inline { font-size: 14px; font-weight: 400; color: var(--ink-faint); }
.section-sub {
  font-size: 14.5px; color: var(--ink-soft);
  text-align: center; max-width: 640px; margin: 0 auto 40px;
}

/* ---- スクロールフェードイン ---- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s cubic-bezier(.16, 1, .3, 1), transform .8s cubic-bezier(.16, 1, .3, 1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ---- ジャンルタブ ---- */
.genre-tabs { display: flex; gap: 9px; flex-wrap: wrap; justify-content: center; margin-bottom: 26px; }
.genre-tab {
  border: 1px solid transparent; background: #fff; color: var(--ink-soft);
  border-radius: 980px; padding: 8px 18px; font-size: 13px; cursor: pointer;
  transition: all .2s ease;
}
.genre-tab:hover { color: var(--ink); }
.genre-tab.active, section.alt .genre-tab.active { background: var(--ink); color: #fff; font-weight: 600; }

/* ---- サービス絞り込みバナー ---- */
.filter-banner {
  display: none; align-items: center; gap: 10px; flex-wrap: wrap;
  background: rgba(0, 113, 227, .08); color: var(--link);
  border-radius: 14px; padding: 11px 16px; margin-bottom: 18px; font-size: 13.5px;
}
.filter-banner.show { display: flex; }
.filter-banner button {
  margin-left: auto; background: none; border: 1px solid var(--blue); color: var(--blue);
  border-radius: 980px; padding: 4px 14px; font-size: 12px; cursor: pointer;
}
.filter-banner button:hover { background: var(--blue); color: #fff; }

/* ---- 大会カード ---- */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 18px; }
.card {
  background: var(--card); border-radius: var(--radius);
  padding: 22px 22px 18px; display: flex; flex-direction: column; gap: 11px;
  box-shadow: var(--shadow);
  transition: transform .3s cubic-bezier(.16, 1, .3, 1), box-shadow .3s ease;
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.card.highlight { box-shadow: 0 0 0 2px var(--blue), var(--shadow-hover); }
.card-head { display: flex; align-items: flex-start; gap: 8px; }
.card-head h3 { margin: 0; font-size: 17px; font-weight: 700; letter-spacing: -.01em; line-height: 1.4; flex: 1; }
.badge-genre {
  flex: 0 0 auto; font-size: 11px; font-weight: 600; color: var(--ink-soft);
  background: var(--bg-alt); border-radius: 980px; padding: 3px 10px; margin-top: 2px;
}
.badge-live { background: var(--red-deep); color: #fff; }
.season { font-size: 12px; color: var(--ink-faint); margin: -4px 0 0; }

.media-group { display: flex; flex-direction: column; gap: 7px; }
.media-row { display: flex; align-items: flex-start; gap: 8px; }
.media-kind {
  flex: 0 0 60px; text-align: center; font-size: 11px; font-weight: 600;
  border-radius: 980px; padding: 3px 0; margin-top: 2px;
}
.media-kind.k-chijou { background: var(--green-tint); color: var(--green); }
.media-kind.k-bscs { background: var(--blue-tint); color: var(--link); }
.media-kind.k-haishin { background: var(--purple-tint); color: var(--purple); }
.media-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.media-chip {
  font-size: 12.5px; border: 1px solid var(--line); border-radius: 980px;
  padding: 3px 12px; background: #fff; cursor: pointer; color: var(--ink);
  transition: border-color .2s ease;
}
.media-chip:hover { border-color: var(--blue); }
.media-chip .lv { font-weight: 700; margin-left: 4px; }
.lv3 { color: var(--green); }
.lv2 { color: var(--link); }
.lv1 { color: var(--ink-faint); }

.free-note {
  font-size: 12.5px; background: var(--yellow-tint);
  color: var(--yellow-ink); border-radius: 12px; padding: 8px 12px;
}
.card-actions { margin-top: auto; display: flex; align-items: center; gap: 10px; }
.detail-toggle {
  background: none; border: none; color: var(--link); font-size: 13.5px;
  cursor: pointer; padding: 4px 0;
}
.detail-toggle:hover { text-decoration: underline; }
.card-detail { display: none; border-top: 1px solid rgba(0, 0, 0, .08); padding-top: 12px; font-size: 13px; }
.card-detail.open { display: block; }
.card-detail ul { margin: 0 0 8px; padding-left: 0; list-style: none; }
.card-detail li { margin-bottom: 8px; }
.card-detail .svc-name { font-weight: 600; }
.card-detail .note-line { color: var(--ink-soft); font-size: 12.5px; }
.cta-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.cta {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--blue); color: #fff !important; text-decoration: none !important;
  font-size: 12.5px; font-weight: 500; border-radius: 980px; padding: 7px 16px;
  transition: background .2s ease;
}
.cta:hover { background: var(--blue-hover); }
.cta .pr { font-size: 9.5px; background: rgba(255, 255, 255, .28); color: #fff; border-radius: 5px; padding: 1px 5px; }
.checked-date { font-size: 11px; color: var(--ink-faint); margin-top: 9px; }
.empty-msg { color: var(--ink-soft); padding: 30px 10px; text-align: center; }
.detail-page-link { font-size: 12.5px; display: inline-block; margin-top: 9px; }
.player-chips { font-size: 12.5px; color: var(--ink-soft); margin: 8px 0 2px; display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.player-chip {
  display: inline-block; background: var(--bg-alt); border-radius: 980px;
  padding: 3px 11px; font-size: 12px; color: var(--ink); text-decoration: none;
}
.player-chip:hover { background: #e8e8ed; text-decoration: none; }

/* ---- サービス逆引き ---- */
.service-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 14px; }
.service-card {
  background: var(--bg-alt); border-radius: var(--radius);
  padding: 18px 18px 16px; cursor: pointer;
  transition: transform .25s cubic-bezier(.16, 1, .3, 1), box-shadow .25s ease, background .25s ease;
}
.service-card:hover { transform: translateY(-2px); background: #f0f0f2; }
.service-card.active { background: #fff; box-shadow: 0 0 0 2px var(--blue), var(--shadow); }
.service-card h4 { margin: 2px 0 2px; font-size: 14.5px; font-weight: 700; letter-spacing: -.01em; }
.service-card .kind { font-size: 11px; font-weight: 600; }
.service-card .kind.k-chijou { color: var(--green); }
.service-card .kind.k-bscs { color: var(--link); }
.service-card .kind.k-haishin { color: var(--purple); }
.service-card .price { font-size: 12.5px; color: var(--ink-soft); margin-top: 4px; }
.service-card .count { font-size: 12px; color: var(--blue); font-weight: 600; margin-top: 3px; }

.service-detail {
  display: none; background: #fff; border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 24px 26px; margin-top: 20px;
}
.service-detail.show { display: block; }
.service-detail h3 { margin: 0 0 6px; font-size: 19px; letter-spacing: -.01em; }
.service-detail .meta { font-size: 13px; color: var(--ink-soft); margin-bottom: 10px; }
.service-detail .desc { font-size: 14px; margin-bottom: 12px; }
.service-detail .program-list { font-size: 13.5px; margin: 6px 0 14px; padding-left: 18px; }
.service-detail .program-list li { margin-bottom: 5px; }

/* ---- 料金表 ---- */
.price-table-wrap { overflow-x: auto; background: #fff; border-radius: var(--radius); box-shadow: var(--shadow); }
table.price-table { border-collapse: collapse; width: 100%; min-width: 760px; font-size: 13.5px; }
.price-table th, .price-table td { text-align: left; padding: 13px 16px; border-bottom: 1px solid rgba(0, 0, 0, .07); vertical-align: top; }
.price-table tr:last-child td { border-bottom: none; }
.price-table th { font-size: 11.5px; font-weight: 600; color: var(--ink-faint); white-space: nowrap; letter-spacing: .02em; }
.price-table td.price-cell { font-weight: 700; white-space: nowrap; }
.price-table .small { font-size: 11.5px; color: var(--ink-soft); font-weight: 400; }
.price-table .cta { padding: 5px 14px; }

/* ---- 診断モーダル ---- */
.modal-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0, 0, 0, .4);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  z-index: 50; padding: 20px; overflow-y: auto;
}
.modal-overlay.show { display: flex; align-items: flex-start; justify-content: center; }
.modal {
  background: #fff; border-radius: 22px; max-width: 660px; width: 100%;
  padding: 30px 30px 26px; margin: 5vh 0; box-shadow: 0 30px 80px rgba(0, 0, 0, .25);
}
.modal h3 { margin: 0 0 4px; font-size: 22px; letter-spacing: -.015em; }
.modal .modal-sub { font-size: 13.5px; color: var(--ink-soft); margin: 0 0 18px; }
.modal-close { float: right; background: var(--bg-alt); border: none; width: 32px; height: 32px; border-radius: 50%; font-size: 15px; cursor: pointer; color: var(--ink-soft); }
.modal-close:hover { background: #e8e8ed; }
.diag-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.diag-chip {
  border: 1px solid var(--line); background: #fff; border-radius: 980px;
  padding: 8px 16px; font-size: 13px; cursor: pointer; color: var(--ink);
  transition: all .15s ease;
}
.diag-chip:hover { border-color: var(--blue); }
.diag-chip.on { background: var(--blue); border-color: var(--blue); color: #fff; font-weight: 600; }
.diag-result { border-top: 1px solid rgba(0, 0, 0, .08); padding-top: 18px; margin-top: 18px; }
.diag-result h4 { margin: 0 0 10px; font-size: 16px; letter-spacing: -.01em; }
.plan-box {
  border: 1px solid rgba(0, 0, 0, .1); border-radius: 16px; padding: 15px 17px; margin-bottom: 10px;
}
.plan-box.best { border-color: var(--blue); background: rgba(0, 113, 227, .05); }
.plan-box .plan-title { font-weight: 700; font-size: 15px; letter-spacing: -.01em; }
.plan-box .plan-meta { font-size: 12.5px; color: var(--ink-soft); margin: 3px 0 6px; }
.plan-box .covers { font-size: 12.5px; }
.free-summary { font-size: 13px; background: var(--yellow-tint); color: var(--yellow-ink); border-radius: 14px; padding: 12px 14px; margin-top: 8px; }

/* ---- 直近の注目試合 ---- */
.sched-list { display: flex; flex-direction: column; gap: 10px; max-width: 880px; margin: 0 auto; }
.sched-row {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  background: var(--bg-alt); border-radius: 16px;
  padding: 13px 18px;
  transition: background .2s ease;
}
.sched-row:hover { background: #f0f0f2; }
.sched-date {
  flex: 0 0 auto; display: flex; align-items: center; gap: 6px;
  font-weight: 700; font-size: 13px; color: var(--ink);
  background: #fff; border-radius: 980px; padding: 4px 12px; min-width: 88px; justify-content: center;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .06);
}
.sched-date .badge-today {
  background: var(--red-deep); color: #fff; font-size: 10px; border-radius: 5px; padding: 1px 6px; font-weight: 600;
}
.badge-live-now {
  background: var(--red-deep); color: #fff; font-size: 10px; border-radius: 5px;
  padding: 1px 7px; font-weight: 700; letter-spacing: .05em;
  animation: livePulse 1.6s ease-in-out infinite;
}
.sched-row.live {
  background: rgba(255, 59, 48, .06);
  box-shadow: inset 0 0 0 1px rgba(255, 59, 48, .28);
}
.live-btn {
  margin-left: 16px; flex: 0 0 auto;
  display: inline-flex; align-items: center;
  background: var(--red-deep); color: #fff; border: none; border-radius: 980px;
  padding: 5px 14px; font-size: 12px; font-weight: 700; letter-spacing: .03em;
  cursor: pointer; animation: livePulse 1.6s ease-in-out infinite;
}
.live-btn[hidden] { display: none; }
.live-btn:hover { background: #b8000f; }
@keyframes livePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255, 59, 48, .45); }
  50% { box-shadow: 0 0 0 7px rgba(255, 59, 48, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .live-btn, .badge-live-now { animation: none; }
}
.sched-time { flex: 0 0 50px; font-size: 13px; color: var(--ink-soft); font-weight: 600; }
.sched-title {
  flex: 1 1 240px; background: none; border: none; text-align: left; cursor: pointer;
  font-size: 14.5px; font-weight: 600; color: var(--ink); padding: 0; letter-spacing: -.01em;
}
.sched-title:hover { color: var(--link); }
.sched-where { flex: 2 1 260px; font-size: 12.5px; color: var(--ink-soft); }
.sched-note { flex-basis: 100%; font-size: 11.5px; color: var(--ink-faint); margin: -5px 0 0 102px; }
@media (max-width: 560px) { .sched-note { margin-left: 0; } }

/* ---- 大会フィルタチップ＆試合予定ジャンプ ---- */
.sched-filter {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  max-width: 880px; margin: -6px auto 18px;
}
.sched-filter:empty { display: none; }
.sched-chip {
  border: 1px solid var(--line); background: #fff; border-radius: 980px;
  padding: 6px 14px; font-size: 12.5px; cursor: pointer; color: var(--ink-soft);
  font-family: inherit; transition: all .15s ease;
}
.sched-chip:hover { border-color: var(--blue); color: var(--blue); }
.sched-chip.active { background: var(--ink); border-color: var(--ink); color: #fff; font-weight: 600; }
.sched-jump {
  display: inline-block; background: none; border: none; color: var(--link);
  font-size: 12.5px; cursor: pointer; padding: 0; margin-top: 9px; font-family: inherit;
}
.sched-jump:hover { text-decoration: underline; }

/* ---- リスト⇄カレンダー表示切り替え＆月間カレンダー ---- */
.view-toggle {
  display: flex; gap: 0; background: var(--bg-alt); border-radius: 980px;
  padding: 3px; width: max-content; margin: 0 auto 20px;
}
.vt-btn {
  border: none; background: none; border-radius: 980px; padding: 6px 24px;
  font-size: 13px; color: var(--ink-soft); cursor: pointer; font-family: inherit;
}
.vt-btn.active { background: #fff; color: var(--ink); font-weight: 600; box-shadow: 0 1px 4px rgba(0, 0, 0, .12); }
.mcal { max-width: 880px; margin: 0 auto; }
.mcal-head { display: flex; align-items: center; justify-content: center; gap: 18px; margin-bottom: 12px; }
.mcal-month { font-size: 15px; font-weight: 700; letter-spacing: -.01em; min-width: 92px; text-align: center; }
.mcal-nav {
  width: 30px; height: 30px; border-radius: 50%; border: none;
  background: var(--bg-alt); color: var(--ink); font-size: 16px; cursor: pointer;
}
.mcal-nav:hover { background: #e8e8ed; }
.mcal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.mcal-dow { text-align: center; font-size: 11px; color: var(--ink-soft); font-weight: 600; padding: 2px 0; }
.mcal-dow.sun { color: var(--red-deep); }
.mcal-dow.sat { color: var(--link); }
.mcal-cell {
  background: var(--bg-alt); border: none; border-radius: 12px; min-height: 80px;
  padding: 6px; text-align: left; display: flex; flex-direction: column; gap: 3px;
  font-family: inherit; min-width: 0;
}
.mcal-cell.empty { background: transparent; }
button.mcal-cell { cursor: pointer; transition: background .15s ease; }
button.mcal-cell:hover { background: #ececf0; }
.mcal-cell.today { box-shadow: inset 0 0 0 2px var(--blue); }
.mcal-d { font-size: 11.5px; color: var(--ink-soft); font-weight: 600; }
.mcal-cell.today .mcal-d { color: var(--blue); }
.mcal-chip {
  display: flex; align-items: center; gap: 3px; background: #fff;
  border-radius: 6px; padding: 2px 5px; font-size: 10.5px; line-height: 1.35;
  color: var(--ink); overflow: hidden; max-width: 100%;
}
.mcal-chip .t { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mcal-chip.live { background: var(--red-deep); color: #fff; }
.mcal-more { font-size: 10px; color: var(--ink-soft); }

/* 日別モーダル */
.modal-sm { max-width: 500px; }
.day-match { border-bottom: 1px solid rgba(0, 0, 0, .07); padding: 14px 0; }
.day-match:last-child { border-bottom: none; }
.day-match-head { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--ink-soft); font-weight: 600; }
.day-title { display: block; font-size: 15.5px; font-weight: 700; color: var(--ink); margin: 5px 0 2px; letter-spacing: -.01em; }
.day-title:hover { color: var(--link); text-decoration: none; }
.day-where { font-size: 12.5px; color: var(--ink-soft); margin-bottom: 9px; }
.cta.cta-sub { background: var(--bg-alt); color: var(--ink) !important; border: none; font-family: inherit; cursor: pointer; }
.cta.cta-sub:hover { background: #e8e8ed; }
.sched-detail-link { flex: 0 0 auto; font-size: 12px; white-space: nowrap; }

/* ---- カレンダー追加（Google / .ics） ---- */
.sched-cal { position: relative; flex: 0 0 auto; margin-left: auto; }
.cal-btn {
  background: #fff; border: 1px solid var(--line); border-radius: 980px;
  padding: 5px 14px; font-size: 12px; cursor: pointer; color: var(--ink); white-space: nowrap;
  transition: all .15s ease;
}
.cal-btn:hover { border-color: var(--blue); color: var(--blue); }
.cal-menu {
  display: none; position: absolute; right: 0; top: 34px; z-index: 10;
  background: #fff; border-radius: 14px; box-shadow: 0 12px 40px rgba(0, 0, 0, .18);
  padding: 6px; min-width: 210px;
}
.cal-menu.open { display: block; }
.cal-menu a, .cal-menu button {
  display: block; width: 100%; text-align: left; background: none; border: none;
  font-size: 13px; color: var(--ink); padding: 9px 12px; border-radius: 9px; cursor: pointer;
}
.cal-menu a:hover, .cal-menu button:hover { background: var(--bg-alt); text-decoration: none; }
.sched-actions { text-align: center; margin-top: 20px; }

/* ---- 大会別ページ・固定ページ ---- */
.page-nav {
  position: sticky; top: 0; z-index: 40;
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  background: rgba(255, 255, 255, .78);
  border-bottom: 1px solid rgba(0, 0, 0, .08);
  padding: 13px 22px;
}
.page-nav a { color: var(--ink); text-decoration: none; font-weight: 700; font-size: 15px; letter-spacing: -.01em; }
.page-nav a .spo { color: var(--blue); }
.article { max-width: 800px; margin: 0 auto; padding: 44px 22px 72px; }
.article h1 { font-size: clamp(28px, 4.5vw, 40px); font-weight: 700; letter-spacing: -.02em; line-height: 1.25; margin: 0 0 10px; }
.article h2 { font-size: 23px; font-weight: 700; letter-spacing: -.015em; margin: 42px 0 14px; }
.article .meta-line { font-size: 12.5px; color: var(--ink-faint); }
.article ul { font-size: 14.5px; }
.conclusion {
  background: var(--bg-alt); border-radius: var(--radius);
  padding: 20px 24px; margin: 22px 0; font-size: 15px; line-height: 1.85;
}
.media-table {
  width: 100%; border-collapse: collapse; background: #fff;
  border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; font-size: 13.5px;
}
.media-table th, .media-table td { padding: 12px 14px; border-bottom: 1px solid rgba(0, 0, 0, .07); text-align: left; vertical-align: top; }
.media-table tr:last-child td { border-bottom: none; }
.media-table th { font-size: 11.5px; font-weight: 600; color: var(--ink-faint); white-space: nowrap; letter-spacing: .02em; }
.back-link { display: inline-block; margin-top: 22px; font-size: 14.5px; }

/* ---- お問い合わせフォーム ---- */
.visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
.form-field { margin-bottom: 18px; }
.form-field label { display: block; font-size: 13.5px; font-weight: 600; margin-bottom: 6px; }
.form-field .req {
  font-size: 10.5px; font-weight: 600; color: #fff; background: var(--blue);
  border-radius: 5px; padding: 1px 7px; margin-left: 8px; vertical-align: 1px;
}
.form-field input, .form-field select, .form-field textarea {
  width: 100%; box-sizing: border-box;
  font-family: inherit; font-size: 15px; color: var(--ink);
  background: #fff; border: 1px solid var(--line); border-radius: 12px;
  padding: 11px 14px; outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.form-field textarea { resize: vertical; min-height: 120px; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
  border-color: var(--blue); box-shadow: 0 0 0 4px rgba(0, 113, 227, .14);
}
.form-hint { font-size: 12.5px; color: var(--ink-soft); margin: -2px 0 8px; }
.form-note { font-size: 12.5px; color: var(--ink-soft); margin: 4px 0 18px; }
.form-status { margin-top: 14px; font-size: 14px; border-radius: 12px; }
.form-status.sending { color: var(--ink-soft); }
.form-status.ok { background: rgba(52, 199, 89, .12); color: #1e7233; padding: 12px 14px; }
.form-status.err { background: rgba(255, 59, 48, .1); color: #c7281e; padding: 12px 14px; }
#submitBtn:disabled { opacity: .55; cursor: default; }

/* ---- フッター ---- */
footer {
  background: var(--bg-alt); color: var(--ink-soft); font-size: 12px;
  padding: 34px 22px 44px; line-height: 1.9;
  border-top: 1px solid rgba(0, 0, 0, .07);
}
footer .inner { max-width: 1080px; margin: 0 auto; }
footer h4 { color: var(--ink); margin: 0 0 4px; font-size: 12px; }
footer p { margin: 0 0 14px; }
footer a { color: #424245; text-decoration: underline; text-underline-offset: 2px; }
footer a:hover { color: var(--ink); }

/* ---- 広告枠（AdSense審査通過後に有効化） ---- */
.ad-slot {
  max-width: 1080px; margin: 8px auto; text-align: center;
  font-size: 11px; color: var(--ink-faint);
}

@media (max-width: 640px) {
  .nav-brand, .nav-links a { white-space: nowrap; }
  .glass-nav .nav-inner { gap: 14px; padding: 0 14px; }
  .nav-links { gap: 14px; }
  .nav-links a { font-size: 12px; }
  .nav-links a:nth-child(n+3) { display: none; }
  .live-btn { margin-left: 0; padding: 5px 10px; }
  /* カレンダーはモバイルでは絵文字ドット表示（タップで日別詳細） */
  .mcal-grid { gap: 4px; }
  .mcal-cell { min-height: 56px; padding: 4px; border-radius: 9px; }
  .mcal-chip .t { display: none; }
  .mcal-chip { padding: 2px 4px; width: max-content; }
  .cards { grid-template-columns: 1fr; }
  .media-kind { flex-basis: 54px; }
  section { padding: 52px 0; }
  .hero { padding: 56px 18px 44px; }
  /* モバイルは装飾を間引いて可読性優先 */
  .decor-ball.b2, .decor-ball.b3 { display: none; }
  .decor-ball.b1 { left: 3%; top: 7%; font-size: 42px; }
  .decor-ball.b4 { right: 4%; bottom: 7%; font-size: 50px; }
  .decor-watermark { font-size: 30vw; top: 3%; }
}
