@charset "UTF-8";
/* 2026専用 CSS */

/* ヘッダー */
.header .hdlogo a {
  background-image: url("../img/common/2026logo_sp.svg");
  width: 1.6rem;
  height: .3202rem;
}
.header .gnav-wrap > ul > li {
  padding: .24rem 0;
}
/* メインビジュアル */
#mv + #main {
  margin-top: .5rem;
}
#mv .container .maincopy {
  position: absolute;
  width: auto;
  height: auto;
  max-width: 8.6753rem;
  max-height: 1.1426rem;
  left: 4%;
  right: 4%;
}
#mv .container .maincopy h1 img {
  width: 100%;
  height: auto;
  filter: none;
  /*Close用はcommonに記載のものを使用*/
}
#mv h1 {
	height: 100%;
}
#mv h1 img {
	position: absolute;
	z-index: 1000;
	display: block;
	margin: auto;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
/* TOPコンテンツ*/
.container {
  max-width: 1130px;
}
.tpbnr__box div {
  width: 100%;
}
.tpbnr__box div a {
  outline: 2px solid #000;
  outline-offset: -2px;
  padding: .2rem;
  max-width: 5.2rem;
  font-size: .26rem;
  font-weight: 800;
  font-family: '見出ゴMB31';
  height: 100%;
  align-items: center;
  display: flex;
  justify-content: center;
  position: relative;
}
.tpbnr__box div a span {
  padding-right: .2rem;
}
.tpbnr__box div a span:after {
  content: ">";
  position: absolute;
  right: .25rem;
  top: -4px;
  bottom: 0;
  font-size: .22rem;
  width: .1rem;
  height: .1rem;
  word-break: break-word;
  font-weight: 400;
  line-height: .1rem;
  margin: auto;
}
.tpbnr__box div a img {
  max-width: 2.1113rem;
  margin: auto;
  display: block;
}
.tpentry p.entry_btn {
  padding-top: .3rem;
}
.tpentry p.entry_btn a {
  font-size: .16rem;
}
.tpentry p.entry_btn a span {
  font-size: 16px;
  display: block;
  padding-bottom: .625em;
}
/*.tpentry p.entry_btn a::after {
  content: none;
} */
.toppage .info_box {
  position: relative;
}
.toppage .info_box p:last-child a {
  width: 100%;
  max-width: 100%;
  border: none;
  font-size: .16rem;
}
.tpentry .tpbnr__box.bnr div {
  width: 48.5%;
}
.main_event {
  margin: .4rem auto;
  padding: 0 .25rem;
}
.main_event_txt dt {
  font-size: .2rem;
  line-height: 1;
  padding-top: 0;
}
.main_event_txt dd {
  margin: .3rem 0 .25rem 0;
}
hr.kugiri {
  margin: 1rem auto;
}
.tpbnr__box .bosyu {
  position: absolute;
  right: 0;
  top: -59px;
  background: #0082C8;
  border-radius: .59rem;
  width: 1.18rem;
  height: 1.18rem;
  line-height: 1.18rem;
  text-align: center;
  color: #fff;
  font-size: .25rem;
  font-weight: 800;
  font-family: '見出ゴMB31';
}
.main_event_img img {
  margin-top: 0;
}
.main_event_txt table th, .main_event_txt table td {
  padding: .05rem 0;
}
.main_event_txt table .main_event_link {
  padding-top: .25rem;
  font-size: .16rem;
}
.main_event_txt table tr th:not(.main_event_link), .main_event_txt table tr:not(:last-child) th {
  width: 3em;
}
.main_event_info {
  border-top: 2px solid #000;
  border-bottom: 2px solid #000;
  margin: .4rem auto;
  max-width: 1080px;
}
.tpentry .main_event_attention {
  margin: -0.60316974em auto;
  max-width: 1080px;
}
/* イベントサーチ：絞り込み調整 */
.toppage .search-btn {
  top: -10px;
  right: .25rem;
}

/* フォーム追加分 */
.entry .logo img {
  width: 200px;
  height: 121px;
}
.entry__form input[type=email] {
  font-family: 'Helvetica Neue', 'Helvetica', 'Roboto Condensed', "メイリオ", Meiryo, YuGothic, 游ゴシック, "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif !important;
  padding: 6px 10px;
  width: 100%;
  background: #f6f8fa;
  line-height: 1.75;
  font-size: 15px;
}
.wpcf7-spinner {
  display: block !important;
}

/* ABOUT 追加編集分 */
#overview.overview {
  margin-bottom: .7rem;
  padding-top: .35rem;
}
#overview table th, #overview table td, #overview p {
  line-height: 2;
}
img.u-logo {
  float: right;
  padding-top: .2rem;
}
#overview hr.kugiri {
  margin: 1rem auto;
}
#overview .clear {
  clear: both;
}
#overview h3.archive_ttl {
  padding-top: .4rem;
}

@media screen and (max-width: 768px) {
  .entry .logo img {
    width: 70%;
  }
  .tpnews .search-btn {
    right: .25rem;
  }
  .main_event {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  /* ヘッダー */
  .header .hdlogo {
    top: .1655rem;
  }
  #mv .container, #mv .container .maincopy, #mv h1 {
	  height: calc(100svh - .65rem);
  }
  /* TOPコンテンツ */
 .tpentry h2 {
    font-size: .25rem;
    line-height: .35rem;
    margin: .387rem 0 .287rem 0;
  }
  .tpentry p.entry_btn.first {
    padding-bottom: .5rem;
    padding-top: 0;
  }
  .tpentry p.entry_btn a {
    line-height: 1;
    padding: .166rem .2rem;
  }
  .tpentry p.entry_btn a span {
    padding-bottom: .315em;
    line-height: .2rem;
  }
  .tpentry .tpbnr__box {
    margin-bottom: .35rem;
  }
  .tpbnr__box div {
    margin-bottom: .25rem;
  }
  .tpentry .tpbnr__box.bnr div {
    width: 100%;
  }
  .tpbnr__box div a {
    padding: .18rem;
    font-size: .16rem;
    height: .71rem;
  }
  .tpbnr__box div a img {
    max-width: 2.28rem;
  }
  .toppage .info_box h2 {
    font-size: .2rem;
    margin-top: .4rem;
  }
  .tpbnr__box .bosyu {
    top: .36rem;
    border-radius: .4rem;
    width: .8rem;
    height: .8rem;
    line-height: .8rem;
    font-size: .17rem;
    margin: 0;
  }
  .main_event_info {
    margin: .4rem .15rem;
  }
  .tpentry .main_event_attention {
    padding: 0 .15rem;
  }
  .main_event {
    margin: .7rem 0;
  }
  .main_event_txt dd:last-child {
    margin-bottom: .25rem;
  }
  /* イベント：絞り込み調整 */
  .tpnews .search-btn {
    right: .15rem;
  }
  .tpnews p.entry_btn {
    padding-top: 0;
  }
  /* 共通 */
  #main {
    padding-top: .75rem;
  }
}
@media screen and (min-width: 768px) {
  .container {
    padding: 0 .25rem;
  }
  /* ヘッダー */
  .header .hdlogo {
    left: .32rem;
  }
  .header .hdlogo a {
    background-image: url("../img/common/2026logo.svg");
    width: 2.9576rem;
    height: .3415rem;
  }
  .header .hdlogo {
    left: .4rem;
    top: .279rem;
  }
  /* メインビジュアル */
  #mv .container .maincopy {
    left: 8%;
    right: 8%;
  }
  /* TOPコンテンツ */
  .tpbnr__box div a img {
    max-width: 4.2rem;
  }
  .tpentry p {
    max-width: 650px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1080px) {
  .tpbnr__box .bosyu {
    right: -.34rem;
  }
  .tpbnr__box div a {
    padding: .16rem;
    font-size: .16rem;
  }
  .tpbnr__box div a img {
    max-width: 2.18rem;
  }
  .tpentry p {
    width: 100%;
    max-width: 100%;
  }
}

/* =====================
   CF7 確認モーダル
===================== */

/* モーダル本体（非表示時） */
#cf7-confirm-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
}
/* .is-visible クラスが付いたとき表示 */
#cf7-confirm-modal.is-visible {
  display: block;
}

/* 背景オーバーレイ（半透明の黒） */
#cf7-confirm-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}

/* モーダルボックス本体 */
#cf7-confirm-box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  padding: 32px 28px;
  width: 90%;
  max-width: 800px;
  max-height: 80vh;        /* 画面高さの80%を超えたらスクロール */
  overflow-y: auto;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}
#cf7-confirm-box > * {
  font-family: '中ゴシックBBB';
}
/* タイトル */
#cf7-confirm-box h2 {
  font-size: 18px;
  margin: 0 0 8px;
  color: #000;
  font-family: '見出ゴMB31';
  font-weight: 600;
}

/* リード文 */
.cf7-confirm-lead {
  font-size: 14px;
  color: #000;
  margin: 0 0 20px;
  line-height: 1.7;
}

/* 入力内容テーブル（dl要素） */
#cf7-confirm-table {
  margin: 0 0 24px;
  padding: 0;
}

/* 1行分（項目名 + 入力値） */
.cf7-confirm-row {
  display: grid;
  grid-template-columns: 30% 1fr;  /* 左：項目名 / 右：入力値 */
  gap: 8px 16px;
  padding: 12px 0;
  border-bottom: 1px solid #efefef;
  font-size: 14px;
  line-height: 1.6;
}
.cf7-confirm-row:first-child {
  border-top: 1px solid #efefef;
}

/* 項目名 */
.cf7-confirm-row dt {
  font-family: '見出ゴMB31';
  font-weight: 600;
  color: #000;
  word-break: break-all;
}

/* 入力値 */
.cf7-confirm-row dd {
  margin: 0;
  color: #000;
  word-break: break-all;
}

/* ボタンエリア */
.cf7-confirm-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* 「戻って修正する」ボタン */
#cf7-back-btn {
  padding: 10px 24px;
  background: #000;
  outline-offset: -2px;
  outline: 2px solid #000;
  color: #fff;
  border: none;
  font-size: 16px;
  font-family: '見出ゴMB31';
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease 0s;
}
#cf7-back-btn:hover {
  background-color: #fff;
  color: #000;
}
/* 「送信する」ボタン */
#cf7-send-btn {
  padding: 10px 24px;
  background: #0374be;
  outline-offset: -2px;
  outline: 2px solid #0374be;
  color: #fff;
  border: none;
  font-size: 16px;
  font-family: '見出ゴMB31';
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease 0s;
}
#cf7-send-btn:hover {
  background: #fff;
  color: #0374be;
  outline: 2px solid #0374be;
}

/* モーダル表示中はページ本体のスクロールを禁止 */
body.cf7-modal-open {
  overflow: hidden;
}

/* ===============
   スマホ対応
=============== */
@media (max-width: 480px) {
  #cf7-confirm-box {
    padding: 24px 16px;
  }
  /* スマホでは項目名と入力値を縦並びに */
  .cf7-confirm-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}