@charset "utf-8";

@font-face {
  font-family: 'BLG';
  src: url(../font/bleage_font.ttf);
  font-weight: normal;
}

img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

p,
span,
h1,
h2,
h3,
h4,
div,
nav,
li,
ul {
  font-family: 'Noto Sans JP', sans-serif;
  font-style: normal;
  font-feature-settings: "palt";
  font-size: 1.4rem;
}

html {
  scroll-padding-top: 0px;
  /* 固定ヘッダの高さ分 */
  font-size: 62.5%;
  overflow-x: hidden;
}

body {
  line-height: 1.6875;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  margin: 0;
  background: #fff;
}

.module_title {
  display: none;
}

.blg-font {
  font-family: 'BLG';
  src: url(font/bleage_font.ttf);
  background-size: cover;
}

.color-white {
  color: white;
}

@media (min-width: 700px) {
  .onlySP {
    display: none;
  }
}

.onlyPC {
  display: none;
}

@media (min-width: 700px) {
  .onlyPC {
    display: block;
  }
}

.red_color {
  color: #E13520;
}

.pink_color {
  color: #EA6183;
}

.yellow_color {
  color: #F39800;
}

.green_color {
  color: #8EC31F;
}

.kv {
  padding-top: 44px;
}

@media (min-width: 700px) {
  .kv {
    padding-top: 66px;
  }
}

/* ===== Global Header ===== */
.clubaction_globalHeader {
  position: relative;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #eee;
  z-index: 50;
  position: fixed;
}

.clubaction_globalHeaderInner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.clubaction_headerLogo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.clubaction_headerLogo img {
  display: block;
  height: 24px;
  width: auto;
}

.clubaction_headerCta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 14px;
  border: 1px solid #E13520;
  border-radius: 999px;
  color: #E13520;
  font-weight: 700;
  font-size: 0.85rem;
  text-decoration: none;
  white-space: nowrap;
  line-height: 1;
  transition: background-color .2s, color .2s, opacity .2s;
}

.clubaction_headerCta:hover {
  background: #E13520;
  color: #fff;
}

@media (min-width: 700px) {
  .clubaction_globalHeaderInner {
    padding: 14px 24px;
  }

  .clubaction_headerLogo img {
    height: 28px;
  }

  .clubaction_headerCta {
    padding: 10px 25px;
    font-size: 1.6rem;
  }
}




:root {
  --actres-bg: #E13520;
  /* 背景の赤（見本に近い色味） */
  --actres-white: #fff;
  --actres-card: #ffffff;
  --actres-border: #eee;
  --actres-line: #f0f0f0;
  --actres-text: #232323;
  --actres-muted: #666;
  --actres-shadow: 0 6px 20px rgba(0, 0, 0, .10);
  --actres-radius-lg: 14px;
  --actres-radius-sm: 12px;
  --actres-gap: 16px;
  --actres-gap-lg: 20px;
}


.actres_wrap {
  background: var(--actres-bg);
  font-family: "Noto Sans JP", system-ui, -apple-system, Segoe UI, Roboto, "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Yu Gothic", Meiryo, sans-serif;
}

.actres_inner {
  max-width: 900px;
  /* 指定② */
  margin: 0 auto;
  padding: 0 20px;
  /* 指定③ SP左右余白20px */
  box-sizing: border-box;
}

/* タイトル行 */
.actres_titleRow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}

@media (min-width: 700px) {
  .actres_titleRow {
    margin-bottom: 30px;
  }
}

.actres_titleIcon {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.actres_title {
  color: var(--actres-white);
  font-size: 22px;
  line-height: 1.3;
  font-weight: 800;
  letter-spacing: .02em;
}

/* 概要ボックス */
.actres_summary {
  background: white;
  border-radius: 10px;
  padding: 20px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 10px;
}

.actres_copy {
  color: var(--actres-text);
  font-size: 14px;
  line-height: 1.7;
  font-weight: bold;
}

.actres_totalBox {
  background: #fff;
  border-radius: var(--actres-radius-sm);
}

/* ヘッダー（アイコン＋テキスト） */
.actres_boxHead {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 8px;
}

.actres_headIcon {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

.actres_headLabel {
  font-weight: 700;
  font-size: 16px;
  color: var(--actres-text);
}


.actres_stats {
  margin: 0;
}

.actres_statRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
}

.actres_statLabel {
  font-size: 14px;
  font-weight: bold;
}

.actres_statValue {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-variant-numeric: tabular-nums;
}

.actres_num {
  font-weight: 800;
  font-size: 24px;
  letter-spacing: .06em;
  line-height: 1;
}

.actres_unit {
  font-size: 14px;
  font-weight: 700;
}

.actres_divider {
  height: 1px;
  background: var(--actres-line);
}

.actres_cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.actres_card {
  background: white;
  border-radius: 10px;
  padding: 20px;
}

/* PCレイアウト（指定① 700px 以上） */
@media (min-width: 700px) {
  .actres_title {
    font-size: 28px;
  }

  .actres_summary {
    grid-template-columns: 1fr 1fr;
    align-items: start;
    padding: 20px;
    gap: 18px;
    align-items: center;
  }

  .actres_cards {
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 6px;
  }

  .actres_card {
    padding: 16px;
  }

  .actres_statLabel {
    font-size: 14px;
  }

  .actres_num {
    font-size: 26px;
  }
}




/* 最新活動 */
.bg {
  background-color: #E13520;
}

:root {
  --latest-red: #d14937;
  --latest-bg: #fff;
  --latest-text: #1a1a1a;
  --latest-muted: #707070;
  --latest-line: #e7e7e7;
  --latest-radius-xl: 18px;
  --latest-radius-lg: 14px;
  --latest-shadow: 0 0px 0px rgba(0, 0, 0, .08);
}


/* ヘッダー帯 */
.latest_head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.latest_badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 35px;
  border: 1px solid #2e2e2e;
  border-radius: 5px;
  background: #fff;
  font-weight: 700;
  font-size: 1.3rem;
}

@media (min-width: 700px) {
  .latest_badge {
    padding: 5px 20px;
  }
}

.latest_updated {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #6b6b6b;
  font-weight: 700;
  font-size: 1.3rem;
}

.latest_icon {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  color: #6b6b6b;
}

.latest_updatedSuffix {
  font-weight: 700;
}

/* 画像 */
.latest_media {
  margin: 0;
  border-radius: 5px;
  overflow: hidden;
  border: 1px solid var(--latest-line);
}

.latest_media img {
  display: block;
  width: 100%;
  height: auto;
}

/* 本文 */
.latest_body {
  padding: 14px 6px 0;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* タイトル行 */
.latest_titleRow {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.latest_clubLogo {
  width: 44px;
  height: 44px;
  object-fit: cover;
  background: #fff;
}

.latest_title {
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 800;
  margin: 0;
  text-align: left;
}

/* 説明 */
.latest_desc {
  margin: 8px 0 16px;
  color: #333;
  line-height: 1.9;
  text-align: left;
  display: -webkit-box;
  /* フレキシブルボックスを使う */
  -webkit-box-orient: vertical;
  /* 縦方向に並べる */
  -webkit-line-clamp: 3;
  /* 表示する最大行数を指定 */
  overflow: hidden;
  /* はみ出した部分を非表示 */
  text-overflow: ellipsis;
  /* 省略記号を付ける */
  line-height: 1.6;
  /* 行間はお好みで調整 */
  max-height: calc(1.6em * 3);
  flex-grow: 1;
}

@media (min-width:700px) {
  .latest_desc {
    font-size: 1.4rem;
  }
}

/* カテゴリチップ（下部の赤アウトライン） */
.latest_chip {
  padding: 5px 20px;
  border-radius: 999px;
  border: 1px solid #E8546B;
  font-size: 1.3rem;
  color: #E8546B;
  display: inline-flex;
  align-self: flex-start;
  width: auto;
}

.latest_chip_midori{
  color: #90C20A;
  border: 1px solid #90C20A;
}
.latest_chip_orange{
  color: #E89600;
  border: 1px solid #E89600;
}

/* ===== Responsive (任意で微調整) ===== */
@media (min-width:700px) {
  .latest_card {
    padding: 18px;
  }

  .latest_title {
    font-size: 1.5rem;
  }
}

.latest_section {
  background: #d14937;
  padding: 34px 0;
  color: #fff;
  overflow: hidden;
  /* ← 見出し部分の左右端を守る */
}

/* ===== タイトル部分だけ中央寄せ max-width:900px ===== */
.latest_section_headwrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

.latest_section_head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
}

.latest_section_icon {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.latest_section_title {
  font-size: 22px;
  font-weight: 800;
}

/* ===== スライダーエリア（max-width解除） ===== */
.latest_section_sliderarea {
  position: relative;
  overflow: visible;
  padding-left: 20px;
  /* SP 左余白 */
}

/* ===== スライダー本体 ===== */
.latest_slider_wrap {
  position: relative;
  overflow: visible;
}

.latest_slider {
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.latest_slider::-webkit-scrollbar {
  display: none;
}

.latest_slider_inner {
  display: flex;
  gap: 20px;
  scroll-snap-align: start;
  padding-right: 80px;
  /* peek用 */
}

.latest_card {
  flex: 0 0 calc(100% - 60px);
  /* peek幅を差し引く */
  scroll-snap-align: start;
  background: #fff;
  color: #000;
  border-radius: 10px;
  border: 1px solid #eee;
  box-shadow: 0 0px 8px rgba(0, 0, 0, .1);
  padding: 16px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.latest_card a{
  text-decoration: none;
  color: #000;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.latest_card a:hover{
  opacity: 0.6;
}
.time {
  width: 20px !important;
  display: block;
}

/* ===== ナビボタン ===== */
.latest_btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: #fff;
  color: #111;
  box-shadow: 0 6px 16px rgba(0, 0, 0, .25);
  display: grid;
  place-items: center;
  z-index: 2;
}

.latest_btn-prev {
  left: 0;
}

.latest_btn-next {
  right: 20px;
}

/* ===== PC時（700px以上） ===== */
@media (min-width: 700px) {
  .latest_section_headwrap {
    padding: 0;
  }

  .latest_section_sliderarea {
    padding-left: calc((100vw - 900px) / 2 + 20px);
    /* 画面中央基準で左合わせ */
  }

  .latest_card {
    flex: 0 0 calc(33.333% + 40px);
    /* はみ出し感 */
    height: 100%;
    display: flex;
    flex-direction: column;
  }

  .latest_btn-prev {
    left: calc((100vw - 900px) / 2);
  }

  .latest_btn-next {
    right: 40px;
  }
}


.sp_width {
  width: calc(100% - 40px);
  margin: 0 auto 2.5rem;
}

@media (min-width: 700px) {
  .sp_width {
    width: calc(100% - 0px);
    margin: 0 auto 3rem;
    max-width: 900px;
  }
}

.section-lineup {
  background-color: #E13520;
  overflow: hidden;
  padding: 50px 0;
}

.section-lineup .inner {
  margin: 0 auto;
  max-width: 900px;
  position: relative;
}

.section-lineup .slick-track {
  display: flex;
  align-items: stretch;
}

.section-lineup .slick-slide {
  height: auto;
}

.section-lineup .slick-slide > div {
  height: 100%;
}

.lineup-carousel li {
  /* text-align: center; */
  margin: 0 7.5px;
  display: flex;
  height: 100%;
}

.lineup-carousel img {
  display: block;
  width: 100%;
}

.slick-list {
  overflow: visible;
}

/* ===== 矢印 ===== */
.slick-prev::before,
.slick-next::before {
  content: none !important;     
  /* display: none !important;      */
}
.slick-prev,.slick-next{
  z-index: 100;
  width: 40px;
}
.slick-prev.is-hidden,
.slick-next.is-hidden {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity .2s ease;
}
@media (max-width: 599px) {
  .slick-prev,
  .slick-next {
    /* display: none !important; */
  }
}

.slick-next{
  right: 10px !important;
}
.slick-prev{
  left: 10px !important;
}
/* ---------------------------------- */
.sponser_ttl {
  text-align: center;
  justify-content: center;

}

.sponser_ttl h2 {
  color: #E60012;
}

.sponser {
  width: calc(100% - 40px);
  margin: 0 auto;
  display: block;
  border-radius: 10px;
}

@media (min-width: 700px) {
  .sponser {
    width: calc(100% - 0px);
    width: 510px;
  }
}

.sponser_link {
  text-align: center;
  display: block;
  margin-bottom: 5rem;
  font-size: 1.5rem;
  color: #000;
}


/* KV下のスライダー画像 */
:root {
  --band-color: #E13520;
  --radius: 16px;
  --gap: 28px;
  --slide-speed: 40s;
}

/* セクション + 赤い帯 */
.hero-slider {
  position: relative;
  padding: 30px 0 50px;
  background: #fff;
  overflow: hidden;
}

.hero-slider::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 50%;
  background: var(--band-color);
  z-index: 0;
}

/* 内側ラッパー */
.hero-slider__inner {
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.hero-slider__track {
  display: flex;
  gap: var(--gap);
  width: max-content;
  animation: loopSlide var(--slide-speed) linear infinite;
}

.hero-slider__item {
  flex: 0 0 auto;
  width: clamp(220px, 30vw, 280px);
  border-radius: 10px;
  overflow: hidden;
}

.hero-slider__item img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 10px;
}

@keyframes loopSlide {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-slider__track {
    animation: none;
  }
}

.hero-slider__item_bt {
  margin-top: 3rem;
}


:root {
  --baska-red: #E13520;
  --overlay: rgba(0, 0, 0, .55);
  --radius: 20px;
  --fab-size-sp: 68px;
  --fab-size-pc: 113px;
}


.baska-modal * {
  box-sizing: border-box;
}


.baska-toggle {
  position: fixed;
  left: -9999px;
}

.baska-fab {
  position: fixed;
  right: 16px;
  bottom: 20px;
  width: var(--fab-size-sp);
  height: var(--fab-size-sp);
  border-radius: 50%;
  background: var(--baska-red);
  color: #fff;
  display: grid;
  place-items: center;
  text-align: center;
  line-height: 1.05;
  font-weight: 700;
  box-shadow: 0 0px 8px rgba(0, 0, 0, 0.139);
  cursor: pointer;
  z-index: 1000;
  user-select: none;
}

.baska-fab__text {
  font-size: 11px;
  letter-spacing: .02em;
  transform: translateY(1px);
  line-height: 1.5rem;
}

@media (min-width: 700px) {
  .baska-fab {
    right: 28px;
    bottom: 28px;
    width: var(--fab-size-pc);
    height: var(--fab-size-pc);
  }

  .baska-fab__text {
    font-size: 1.4rem;
    line-height: 2rem;
  }
}

/* ========= モーダル（チェックONで表示） ========= */
.baska-modal {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity .25s ease;
  z-index: 999;
}

/* 背景暗幕 */
.baska-modal__overlay {
  position: absolute;
  inset: 0;
  background: var(--overlay);
  cursor: pointer;
}

/* ダイアログ本体 */
.baska-modal__dialog {
  position: relative;
  background: var(--baska-red);
  color: #fff;
  max-width: 800px;
  margin: 24px;
  padding: clamp(20px, 5vw, 40px);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, .35);
  transform: translateY(12px);
  transition: transform .25s ease, opacity .25s ease;
}

/* タイトル・ロゴ */
.baska-modal__logo img {
  display: block;
  max-width: 220px;
  width: 50%;
  height: auto;
}

.baska-modal__title {
  max-width: 380px;
  margin: 0 auto 2rem;
}

@media (min-width: 700px) {
  .baska-modal__title {
    margin: 0 auto 3rem;
  }
}

.baska-modal__title span {
  font-size: 1.2em;
  letter-spacing: .03em;
}

.baska-modal__body {
  font-size: 1.4rem;
  line-height: 1.9;
  font-weight: bold;
}

.baska-modal__body p {
  margin: 0 0 1em;
  text-align: center;
}

.baska-modal__close {
  position: absolute;
  right: clamp(10px, 2vw, 16px);
  top: clamp(10px, 2vw, 16px);
  width: clamp(28px, 3.5vw, 36px);
  height: clamp(28px, 3.5vw, 36px);
  border-radius: 50%;
  color: #fff;
  font-size: clamp(18px, 2.5vw, 22px);
  display: grid;
  place-items: center;
  cursor: pointer;
  user-select: none;
}

.baska-toggle:checked~.baska-modal {
  pointer-events: auto;
  opacity: 1;
}

.baska-toggle:checked~.baska-modal .baska-modal__dialog {
  transform: translateY(0);
}


@media (prefers-reduced-motion: reduce) {

  .baska-modal,
  .baska-modal__dialog {
    transition: none;
  }
}