/*
Theme Name: Lightning Child
Theme URI:
Template: lightning
Description:
Author:
Tags:
Version: 0.6.0
*/

/* カラー */
:root {
	--orange: 243, 152, 28;
	--blue: #0a569f;
	--light_blue: #e5f4fb;
}
/* 共通*/
body, html {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.site-header-sub {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.common_linebtn {
	border: 3px solid #0A569F;
	color: #0A569F;
	padding: 10px 20px;
	border-radius: 10px;
	text-decoration: none;
	display: block;
	width: 80%;
	margin: 0 0 15px 0;
	text-align: center;
}
.common_linebtn:hover {
	background: var(--blue);
	color: #fff;
	transition: all .3s;
}

h2.wp-block-heading:not(:first-of-type) {
	margin-top: 50px;
}
h2:not(:first-of-type) {
	margin-top: 50px;
}
h4:where(:not(.wp-block-post-title)) {
	background-color: #fff;
	border-bottom: 1px solid var(--vk-color-border);
}

@media (min-width: 768px) {
	h2.wp-block-heading:not(:first-of-type) {
		margin-top: 75px;
	}
	h2:not(:first-of-type) {
		margin-top: 75px;
	}
}

/* liの点を削除 */
ul {
  padding-left:0;
}

li {
  list-style:none;
}
/* pのmarginbottom削除 */
p {
	margin-bottom: 0;
}
span.bold {
	font-weight: bold;
}
/* header navi */
.site-header--layout--nav-float .site-header-container {
	flex-direction: column;
}

.site-header--layout--nav-float .site-header-logo {
	display: flex;
	justify-content: center;
}

body:not(.header_scrolled) .global-nav--layout--float-right {
	justify-content: center;
}
.global-nav--layout--float-right {
	margin-left: 0;
}

/* header 電話番号 */
.header-tell {
	font-size: 1.5em;
}
.header-tell_wrap {
	display: flex;
	gap: 30px;
	align-items: center;
}
span.tellicon {
	padding: 2px 10px;
	background-color: var(--blue);
	color: #fff;
	font-size: 0.7em;
	margin: 5px;
}

/* ロゴの横に電話番号を表示 */
#block-2 { 
	margin-bottom: 0;
	font-size: 1.5em;
} 
#block-3 {
	margin-top: 5px;
		font-size:0.8em;
}
.wp-block-preformatted {
	margin: 0;
}
.site-header-sub {
	display: none;
}
@media (min-width: 992px) {
	.site-header-sub {
	display: inline-block;
}
}

/* ハンバーガーメニュー */
.vk-mobile-nav-menu-btn {
	top: 8px;
	right: 5px;
	left: unset;
	width: 48px;
	height: 48px;
	background: url("/mchironosc/wp-content/themes/lightning-child/_g3/img/vk-menu-btn-white.svg") center 50% no-repeat rgb(243, 152, 28);
	border-color: #fff;
	border-radius: 5px;
}
.header-sp_telbox {
	font-size: 1.2em;
	font-weight: bold;
}
.vk-mobile-nav-menu-btn.menu-open {
	background: url("/mchironosc/wp-content/themes/lightning-child/_g3/img/vk-menu-close-white.svg") center 50% no-repeat rgb(243, 152, 28);
	border-color: #fff;
}
.vk-mobile-nav {
	padding: 64px 10px 45px;
}

/* lightning copyright 非表示 */
.site-footer-copyright p:nth-child(2) {
    display: none;
}

/* copyright padding調整 */
.site-footer-copyright {
	padding: 1rem 0 5rem;
}
@media ( min-width : 768px ) {
	.site-footer-copyright {
		padding: 1rem;
	}
}

/* メインビジュアル */
.item-2 .ltg-slide-text-set,
.item-3 .ltg-slide-text-set {
	position: absolute;
	bottom: 0;
	top: unset;
	left: 0;
	background: rgba(255, 255, 255, 0.8);
	height: 55%;
	width: 100%;
	display: flex;
	justify-content: center;
	transform: unset;
	clip-path: polygon(0% 15%, 100% 0%, 100% 100%, 0 100%);
}
.item-2 .mini-content-container-2,
.item-3 .mini-content-container-3 {
	display: flex;
	flex-flow: column;
	justify-content: center;
	margin: unset;
	width: 90%;
	height: 100%;
	position: relative;
}
.ltg-slide-text-title {
	font-family: "GSanSerif-B", sans-serif;
	font-size: 21px;
}
.ltg-slide-text-caption {
	font-size: 14px;
}
.ltg-slide picture img {
	width: 100%;
	height: 65vh;
	display: block;
	object-fit: cover;
}

@media (max-width: 768px) {
	.item-2 .container,
	.item-3 .container {
		max-width: unset;
	}
}

@media ( min-width : 768px ) {
	.item-2 .ltg-slide-text-set,
	.item-3 .ltg-slide-text-set {
		bottom: unset;
		top: 0;
		height: 100%;
		width: 50%;
		display: block;
		justify-content: unset;
		clip-path: polygon(0 0, 100% 0, 80% 100%, 0 100%);
	}
	.item-2 .mini-content-container-2,
	.item-3 .mini-content-container-3 {
		align-items: flex-end;
		width: 85%;
	}
	.ltg-slide picture img {
		height: 50vh;
	}
	.ltg-slide-text-title {
		font-size: 32px;
	}
	.ltg-slide-text-caption {
		font-size: clamp(12px, 2dvw, 18px);
	}
}
@media ( min-width : 1024px ) {
	.ltg-slide-text-title {
		font-size: 40px;
	}
}
@media ( min-width : 1051px ) {
	.ltg-slide picture img {
		height: 70vh;
	}
}

/* トップページ　body打ち消し用 */
.main-site-body {
	padding: unset;
}

/* トップページ　キャッチコピー */
.main-copy_back {
	display: flex;
	width: 100%;
	padding: 20px;
	margin: 0 0 4rem;
	background: var(--light_blue);
}
.main-copy_box {
	display: flex;
	width: 100%;
	margin: 0 auto;
	justify-content: center;
	align-items: center;
	flex-flow: column;
	margin: 0 auto;
}
.main-copy_title {
	display: flex;
	width: 100%;
	justify-content: center;
	align-items: baseline;
	text-align: center;
	gap: 10px;
	font-weight: bold;
}
p.copy-underline {
	font-size: 1.2em;
}
.copy-underline::after {
	content: "";
	display: block;
	height: 10px;
	width: 135px;
	background: url(/mchironosc/wp-content/uploads/copy-wave.svg);
}
.main-copy_text {
	display: inline-block;
	width: 100%;
	align-items: center;
	justify-content: center;
}
.main-copy_linkwrap {
	display: flex;
}
a.main-copy_linkbtn {
	border: 1px solid var(--blue);
	padding:5px 0;
	display: inline-block;
	width: 200px;
	text-align: center;
	margin: 5px 10px;
	color: var(--blue);
	font-weight: bold;
	border-radius: 5px;
}
a.main-copy_linkbtn:hover {
	background: var(--blue);
	color: #fff;
	transition: all .3s;
}
p.text-bold{
	font-weight: bold;
	margin: 1em 0 0 0;
}
#post-58 .entry-body p.text-bold {
	font-size: 1.2em;
}
#post-58 .entry-body p.text-bold::before {
	content: "■";
	margin: 0 .5em 0 0;
	color: rgb(234, 87, 23);
}

@media (min-width: 768px) {
	.main-copy_back {
		padding: 50px;
	}
	.main-copy_box {
		max-width: 1140px;
		flex-flow: wrap;
	}
	.main-copy_title {
		width: 30%;
		align-items: center;
		flex-flow: column;
		text-align: center;
		gap: unset;
	}
	.main-copy_title p {
		margin: unset;
	}
	.copy-underline::after {
		width: 175px;
	}
	.main-copy_text {
		width: 70%;
		display: inline-block;
	}
}

@media (min-width: 960px) {
	.copy-underline::after {
		width: 220px;
	}
}

/* トップページ　共通タイトル */
.main-title{
	text-align: center;
}
.main-title h2 {
	border: none;
	color: rgb(var(--orange));
	padding: unset;
}
.sports-class_subtext {
	text-align: center;
	font-weight: bold;
	font-size: 0.8em;
	margin-bottom: 0px;
}

/* トップページ　カレンダー */
.top-calendar {
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 20px;
}
.google-cal iframe {
width:100%;
height:400px;
}
@media (min-width: 750px) {
.google-cal iframe {
height:600px;
}
}

/* トップページ　info */
.main-info-container {
	display: block;
	width: 100%;
	max-width: 1140px;
	padding: 0 20px;
	margin: 0 auto 2rem;
}
p.info-date {
	font-weight: bold;
}
.main-info-margin {
	margin-bottom: 5rem;
}
.post-30 {
	width: 100%;
	margin: 0 auto;
	padding: 0 20px;
}
.is-layout-flex {
	justify-content: center;
}
.wp-block-post-date time {
	font-size: 16px;
	font-weight: bold;
}
hr.wp-block-separator {
	border-color: var(--light_blue);
}
.main-info_button a{
	display: flex;
	position: relative;
	background: var(--blue);
	color: #fff;
	justify-content: space-around;
	align-items: center;
	margin: 0 auto 50px;
	width: 100%;
	max-width: 250px;
	padding: 15px 20px;
	border-radius: 30px;
	box-shadow: 3px 5px 2px rgba(0, 0, 0, 0.3);
}
.main-info_button a:hover {
	color: #fff;
	text-decoration-color: unset;
	opacity: .7;
	transition: all .3s;
}

@media (min-width: 768px) {
	.post-30 {
		max-width: 1140px;
		padding: 0 50px;
	}
	.main-info-container {
		padding: 0 50px;
	}
	.main-info_button a{
		max-width: 350px;
		padding: 20px 25px;
	}
}

/* トップページ　2カラムデザイン */
.main-2col {
	display: flex;
	flex-flow: column;
	position: relative;
	width: 100%;
}
#main-sports-class {
	margin: 0 0 20px;
}
#main-club {
	margin: 0 0 20px;
}
#main-tournament {
	margin: 0 0 50px;
}
.main-2col_area {
	display: flex;
	position: relative;
	justify-content: center;
	width: 100%;
	padding: 25px 20px;
	flex-flow: column;
	background: repeating-linear-gradient(-45deg, rgba(229, 244, 251, 0.6), rgba(229, 244, 251, 0.6) 25px, #e5f4fb 25px, #e5f4fb 100px);
	order: 2;
}
.main-2col_text {
	display: block;
	position: relative;
}
.main-2col_text h3 {
	border-bottom: none;
	text-align: center;
	padding: unset;
	margin-top: 0px;
}
.main-2col_text h3::after {
	content: none !important;
}
.main-2col_img {
	display: flex;
	width: 100%;
	order: 1;
}
.main-2col_img img {
	width: 100%;
	max-height: 250px;
	height: 250px;
	object-fit: cover;
}
.main-2col_button a {
	display: flex;
	position: relative;
	background: var(--blue);
	color: #fff;
	justify-content: space-around;
    align-items: center;
	margin: 1em auto;
	max-width: 350px;
	padding: 20px 25px;
	border-radius: 30px;
	box-shadow: 3px 5px 2px rgba(0, 0, 0, 0.3);
}
.main-2col_button a:hover {
	color: #fff;
	text-decoration-color: unset;
	opacity: .7;
	transition: all .3s;
}

@media (min-width: 768px) {
	.main-2col {
		flex-flow: wrap;
	}
	.main-2col_area {
		width: 50%;
		padding: unset;
		order: 0;
	}
	.main-2col_text {
		position: absolute;
		max-width: 450px;
	}
	.main-2col_l {
		right: 10%;
		margin: 0 0 0 10%;
	}
	.main-2col_r {
		left: 10%;
		margin: 0 10% 0 0;
	}
	.main-2col_img {
		width: 50%;
		order: 0;
	}
	.main-2col_img img {
		max-height: 350px;
		height: 350px;
	}
}

/* トップページ　リンクボタン */
.main-link-3col {
	display: flex;
	position: relative;
	width: 100%;
	align-items: center;
	flex-flow: column;
	justify-content: space-evenly;
	gap: 6%;
	padding: 0 30px;
	margin: 0 0 5rem;
}
.main-link_button {
	display: block;
	position: relative;
	background: url(/mchironosc/wp-content/uploads/topimg-shisetsu.jpg) no-repeat center center / cover;
	height: 250px;
	width: 250px;
	text-decoration: none;
}
.main-link_area a.main-link_button:hover {
	color: #fff;
	text-decoration-color: unset;
	opacity: .7;
	transition: all .3s;
}
#facility>.main-link_button {
	background: url(/mchironosc/wp-content/uploads/topimg-shisetsu.jpg) no-repeat center center / cover;
}
#membership>.main-link_button {
	background: url(/mchironosc/wp-content/uploads/topimg-member.jpg) no-repeat center center / cover;
}
#our-club>.main-link_button {
	background: url(/mchironosc/wp-content/uploads/topimg-about.jpg) no-repeat center center / cover;
}

.main-link_button span {
	display: flex;
    position: absolute;
    background: var(--blue);
    color: #fff;
    justify-content: space-around;
    flex-flow: column;
    gap: 10px;
    bottom: -10px;
    right: -25px;
    width: 300px;
    max-width: 300px;
    padding: 15px 30px;
    border: 1px solid #fff;
    border-radius: 60px;
	text-align: center;
}
.main-link_button span small {
	font-size: 0.7em;
}
#membership {
	margin: 50px 0 0;
}
#our-club {
	margin: 50px 0 0;
}

@media (min-width: 650px) {
	#membership {
		margin: unset;
	}
	.main-link-3col {
		flex-flow: wrap;
	}
}

@media (min-width: 768px) {
	.main-link-3col {
		flex-wrap: wrap;
		justify-content: space-evenly;
		gap: 6%;
		padding: 0 50px;
	}
	.main-link_button {
		height: 300px;
		width: 300px;
	}
	.main-link_button span {
		bottom: 25px;
    	right: 30px;
	}
	.main-link_button span {
		text-align: unset;
	}
}

@media (min-width: 1060px) {
	#our-club {
		margin: unset;
	}
	.main-link-3col {
		justify-content: center;
		gap: 3%;
	}
}

@media (min-width: 1130px) {
	.main-link-3col {
		gap: 6%;
	}
}

/* トップページ　インスタグラム */
.main-instagram {
	width: 100%;
	padding: 0 20px;
	margin: 0 0 5rem;
}
.instagram-2col-container {
	display: flex;
	position: relative;
	flex-flow: column;
	width: 100%;
	max-width: 1140px;
	margin: 0 auto;
}
.instagram_text {
	display: none;
}
.instagram-post-area {
	display: block;
	width: 100%;
}
.instagram-button-area {
	display: block;
	width: 100%;
}
.instagram-button-area a {
	display: flex;
    position: relative;
    border: 3px solid var(--blue);
    color: #333;
    justify-content: space-around;
    align-items: center;
    margin: 20px auto 0;
	width: 100%;
    max-width: 350px;
    padding: 20px;
    border-radius: 15px;
    text-align: center;
}
.instagram-button-area a:hover {
	background: var(--blue);
	color: #fff;
	transition: all .3s;
}
@media (min-width: 500px) {
	.instagram-post-area {
	display: block;
	width: 80%;
	margin: 0 auto;
}
}

@media (min-width: 768px) {
	.main-instagram {
		padding: 0 50px;
	}
	.instagram-2col-container {
		flex-flow: wrap;
	}
	.instagram_text {
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
	}
	.instagram_text p {
		margin: unset;
		font-weight: bold;
	}
	.instagram-button-area {
		width: 50%;
		display: flex;
		flex-direction: column;
		justify-content: center;
		margin: 0 auto;
	}
	.instagram_text::before,
	.instagram_text::after {
		content: "";
		width: 40px;
		height: 2px;
		background-color: rgb(var(--orange));
		margin: 0px 4px -3px;
	}
	.instagram_text::before {
		transform: rotate(45deg);
	}
	.instagram_text::after {
		transform: rotate(-45deg);
	}
	.instagram-post-area {
	width: 50%;
	padding: 0 10px;
}
}

/* ページ共通　コンタクトセクション */
.contact-section-container {
	display: none;
	width: 100%;
	max-width: 1140px;
	padding: 0 50px;
	margin: 0 auto 5rem;
}
.contact-section {
	display: block;
	position: relative;
	width: 100%;
	background: var(--light_blue);
	text-align: center;
	border-radius: 25px;
	padding: 50px 30px;
}
.contact-section_title {
	text-align: center;
}
.contact-section_title h2 {
	border: none;
	color: rgb(var(--orange));
	margin: 0 0 15px;
	padding: unset;
}
.contact-section_text {
	font-weight: bold;
}
.contact-section_text p {
	margin: unset;
}
.contact-section_border {
	height: 2px;
	background: #fff;
	width: 100%;
	margin: 30px 0 50px;
}
.contact-section_2col {
	display: flex;
	width: 100%;
}
.contact-section_tel {
	width: 50%;
	display: flex;
	flex-flow: column;
	font-weight: bold;
}
.contact-section_tel p {
	margin: 0 0 10px;
}
.contact-section_tel span {
	color: var(--blue);
	font-size: 1.7em;
}
.contact-section_email {
	width: 50%;
	display: flex;
	flex-flow: column;
	font-weight: bold;
}
.contact-section_email p {
	margin: 0 0 10px;
}
.contact-section_button {
	display: flex;
	position: relative;
	background: var(--blue);
	color: #fff;
	justify-content: center;
    align-items: center;
	margin: 0 auto;
	width: 100%;
	max-width: 200px;
	padding: 10px 15px;
	border-radius: 30px;
}

@media (min-width: 768px) {
	.contact-section-container {
		display: block;
	}
}

/* トップページ　賛助会員 */
.main-supporting-member {
	display: block;
	position: relative;
	width: 100%;
	background: rgba(var(--orange), 0.15);
	padding: 50px 20px;
	text-align: center;
}
.main-sm-text_area {
	display: flex;
	position: relative;
	width: 100%;
	max-width: 1200px;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	background: #fff;
	padding: 30px 20px;
	border-radius: 30px;
	margin: 0 auto;
}
.main-sm_title h2 {
	padding: unset;
	border: none;
	margin: 0 0 10px;
	font-size: 1.4rem;
}
.main-sm_title {
	margin: 0 0 25px;
}
.main-sm_title h3 {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: unset;
	border: none;
	margin: unset;
	font-size: 1rem;
}
.main-sm_title h3::before,
.main-sm_title h3::after {
	content: "";
	width: 20px;
	overflow: unset;
	position: relative;
	bottom: 0;
	background: #333;
	height: 1px;
	border: none;
}
.main-sm_title h3::before {
	margin: 0 20px 0 0;
}
.main-sm_title h3::after {
	margin: 0 0 0 20px;
}
span.textspan_l {
	display: block;
    position: relative;
    font-size: 21px;
    font-weight: bold;
    margin: 0 0 25px;
}
span.textspan_m {
	font-size: 17px;
	font-weight: bold;
	margin: 0 0 20px;
}
span.textspan_s {
	margin: unset;
	line-height: 2.0;
}
.main-supporting-member_text {
	margin: 20px 0 0;
}
.support_wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 0 5%;
	justify-content: center;
}

@media (min-width: 768px) {
	.main-supporting-member {
		padding: 50px;
	}
	.main-sm-text_area {
		padding: 40px 50px;
	}
	.main-sm_title h2 {
		font-size: 1.75rem;
	}
	.main-sm_title h3 {
		font-size: 1.2rem;
	}
	.support_wrap {
		gap: 0 3%;
	}
	span.textspan_l {
		font-size: 25px;
	}
	span.textspan_m {
		font-size: 20px;
	}
	span.textspan_s {
		line-height: 3.0;
	}
}

/* フッターのグーグルマップを可変に */
.footer-map {
	position: relative;
    width: 100%;
    padding-top: 56.25%;
    /* 16:9のアスペクト比 */
    height: 0;
}
.footer-map iframe {
	position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* フッターナビ */

#menu-footer-navi > li > a::before {
	font-family: "Font Awesome 6 Free"; /* Font Awesomeのフォント名 */
	content: "\f04b";	/* 再生アイコンのUnicode */
	font-weight: 900;/* Solidスタイルの場合は900 */
	margin-right: 8px;/* アイコンとテキストの間隔 */
	color: var(--orange) !important;/* アイコンの色（必要に応じて変更） */
}

/* フッター左側 */
h2.footer-club-name {
	border: none;
}
.footer-adless {
	font-size:16px;
}
.footer-button {
	background-color: var(--blue);
	color: #fff;
	font-weight: bold;
	font-size: 1.2em;
	padding: 10px;
	display: inline-block;
	width: 200px;
	border-radius: 30px;
	text-align: center;
}
a.footer-button:hover {
	color: #fff;
	text-decoration-color: unset;
	opacity: .7;
	transition: all .3s;
}

/* 会員登録ボタン */
.floating-button-wrapper {
	position: fixed;
	right: 0;
	z-index: 1;
	bottom: 5px;
	display: flex;
    align-items: center;
	justify-content: center;
	width: 100%;
	gap: 15px;
	padding: 0 15px;
}
.contact-button-container {
	display: flex;
	width: 50%;
}
.floating-button-container {
	display: flex;
	width: 50%;
}
.contact-button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 55px;
    background: #F3981C;
    color: #FFF;
    text-decoration: none;
    text-align: center;
	font-family: "Shin Maru Go Futoline", sans-serif;
    font-weight: 400;
    font-style: normal;
	font-size: 14px;
}
a.contact-button:hover {
	color: #fff;
	text-decoration-color: unset;
	opacity: .7;
	transition: all .3s;
}
.floating-button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 55px;
    background: #0A569F;
    color: #FFF;
    text-decoration: none;
    text-align: center;
	font-family: "Shin Maru Go Futoline", sans-serif;
    font-weight: 400;
    font-style: normal;
	font-size: 14px;
}
a.floating-button:hover {
	color: #fff;
	text-decoration-color: unset;
	opacity: .7;
	transition: all .3s;
}
p.contact-button_text {
	margin-bottom: 0;
	line-height: 1.3;
}
span.font-l {
	font-size: 14px;
}

@media (min-width: 768px) {
	.floating-button-wrapper {
		right: 20px;
		flex-flow: column;
		bottom: 20px;
		align-items: flex-end;
		justify-content: flex-start;
		width: auto;
		gap: 0;
		padding: 0;
	}
	.contact-button-container {
		width: unset;
	}
	.floating-button-container {
		width: unset;
	}
	.contact-button {
		border-radius: 50%;
		width: 120px;
		height: 120px;
		font-size: 1.2em;
	}
	.floating-button {
		border-radius: 50%;
		width: 150px;
		height: 150px;
		margin: 20px 0 0 0;
		font-size: 1.5em;
	}
	span.font-l {
		font-size: 1.5em;
	}
}

/* information */
.vk_post.media {
	border-bottom: 2px solid #D1F1FF;
}
.entry-body>.vk_posts>.vk_post-col-lg-12 .vk_post_excerpt, .main-section>.vk_posts>.vk_post-col-lg-12 .vk_post_excerpt {
	font-size: 16px;
	color: #333;
}
.vk_post .vk_post_date {
	font-size: 16px;
	color: #333;
}
.vk_posts .col-12:nth-child(n+2) {
	margin: 25px 0 0;
}
.col-12 {
	padding: unset;
}
.latest-posts .col-12:nth-child(n+2) {
	margin: 25px 0 0;
}
.info-wrap {
	display: flex;
	flex-flow: column;
	padding: 0;
	border-bottom: 2px solid #D1F1FF;
}
.info-wrap_photo {
	display: flex;
	width: 100%;
	justify-content: center;
	margin: 0 0 15px;
}
.info-photo_box {
	width: 300px;
	height: 200px;
	border: 1px solid #efefef;
	position: relative;
}
.info-maintext p {
	margin: 0 0 25px;
}
.info-wrap_text {
	display: flex;
	width: 100%;
	flex-flow: column;
	padding: 0;
}
p.info-date {
	margin: 0 0 10px;
}
.info-title {
	font-size:1.2em;
	font-weight: bold;
	margin-bottom: 0;
}
.info_linebtn {
	border: 3px solid #0A569F;
	color: #0A569F;
	padding: 10px 20px;
	border-radius: 10px;
	text-decoration: none;
	display: block;
	width: 50%;
	margin: 0 auto 25px;
	text-align: center;
}
.info-link a.info_linebtn:hover {
	background: var(--blue);
	color: #fff;
	transition: all .3s;
}
ul.page-numbers li {
	margin: 0 5px;
	width: 50px;
	height: 50px;
}
ul.page-numbers li a, ul.page-numbers li span.page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: 100%;
	height: 100%;
	border-radius: 50px;
}
ul.page-numbers li:first-child>.page-numbers {
	border-radius: 50px !important;
}
ul.page-numbers li a, ul.page-numbers li span.page-numbers {
	padding: 0;
	border-radius: 50px !important;
}
ul.page-numbers li:last-child>.page-numbers {
	border-radius: 50px !important;
}
ul.page-numbers li a, ul.page-numbers li span.page-numbers {
	margin: 0;
}
.category-label {
	display: block;
	right: 0;
	padding: 5px;
	position: absolute;
	font-size: 14px;
	width: 75px;
	text-align: center;
	color: #fff;
}

@media (min-width: 768px) {
	.info-wrap {
		flex-flow: wrap;
		padding: 30px 50px;
	}
	.info-wrap_photo {
		width: 35%;
		margin: 0;
	}
	.info-wrap_text {
		width: 65%;
		padding: 0 0 0 20px;
	}
	.info_linebtn {
		margin: 0 0 15px 0;
	}
	.vk_posts .col-12:nth-child(n+2) {
		margin: unset;
	}
	.latest-posts .col-12:nth-child(n+2) {
		margin: unset;
	}
}

/* information ページネーション*/
ul.page-numbers li span.page-numbers.current {
	background-color: #0A569F;
}
ul.page-numbers li:first-child>.page-numbers {
	border-radius: 100px;
}
ul.page-numbers li a, ul.page-numbers li span.page-numbers {
	border-radius: 100px;
}
ul.page-numbers li:last-child>.page-numbers {
	border-radius: 100px;
}

/* 教室　クラブ・チーム共通レイアウト*/
li.lessonclubteam-item {
	margin-bottom: 50px;
}
.item-photobox {
	display: flex;
	margin: 15px 0 30px 0;
	flex-wrap: wrap;
	justify-content: center;
	gap: 15px;
	width: 100%;
}
.item-photobox>img {
	width: 100%;
	max-width: 300px;
}
.item-flexwrap {
	display: block;
	margin: 20px 0 0 0;
}
.item-flexbox {
	width: 100%;
}
.item-flexbox>p {
	margin-bottom: 1.2em;
}
.item-teacher {
	display: flex;
	align-items: center;
	margin: 0 0 1em 0;
	gap: 30px;
}
.item-teacher>p {
	margin-bottom: 0;
}
p.lesson_name_text{
	margin-bottom: 0;
}
.item-teacher_img {
	width: 120px;
	height: 120px;
	border-radius: 50%;
}
span.listitem_icon {
	display: inline-block;
	background-color: #E5F4FB;
	color: #000057;
	padding: 5px 10px;
	margin: 0 1em 0 0;
}
.item-photobox_img {
	width:300px;
	height:200px;
}
.item-photobox_img.dummy {
	visibility: hidden;
	width: 300px;
	height: 200px;
}
.itemphoto_2column {
	width:100%;
	min-width: 300px;
	height: 0;
	padding-top: 66.6666%;
	background-size: cover;
	background-position: center;
	margin: 0 0 30px;
}
.itemphoto_3column {
	min-width: 300px;
	height: 200px;
	background-size: cover;
	background-position: center;
}
@media (min-width: 768px) {
	li.lessonclubteam-item {
		margin-bottom: 75px;
	}
	.item-flexwrap {
		display: flex;
	}
	.item-flexbox {
		width: 50%;
	}
	.item-photobox>img {
		width: calc(33.33333% - 40px/3);
		max-width: none;
	}
	.itemphoto_3column {
		width: calc(33.33333% - 40px/3);
		height: 0;
		padding-top: 21.5%;
		min-height: 200px;
	}
	.itemphoto_2column {
		margin: 0;
	}
}

/* 大会*/
li.tournament-item {
	margin-bottom: 50px;
}
.item-flexbox_inner {
	display: flex;
}
.item-flexbox_inner a:hover {
	background: var(--blue);
	color: #fff;
	transition: all .3s;
}
.item-flexbox_innerbox_l {
	width: 20%;
	display: flex;
	flex-direction: column; 
	align-items: end;
	min-width: 100px;
}
.item-flexbox_innerbox_l>p {
	margin-bottom: 1em;
}
.item-flexbox_innerbox_r>p {
	margin-bottom: 1em;
}
.item-flexbox_innerbox_r {
	width: 80%;
	padding: 5px 0 0 0;
}
.item-caption {
	margin-bottom: 0;
	margin-top: 1em;
	font-weight: bold;
	color: var(--blue)
}
p.listitem_text {
	margin: 10px 0 0 0;
}
@media (min-width: 768px) {
	li.tournament-item {
		margin-bottom: 75px;
	}
}
/* 町代表チーム*/
li.representative-item {
	margin-bottom: 50px;
}
.representative-text_box {
	margin: -5px 0 1em 0;
}
.representativecomment_box {
	border: 3px solid var(--light_blue);
	border-radius: 15px;
	padding: 15px;
}
@media (min-width: 768px) {
	li.representative-item {
		margin-bottom: 75px;
	}
}

/* 入会案内*/
th.member-table_th {
	background-color: #E5F4FB;
}
li.member_subtitle {
	font-weight: bold;
	font-size:1.2em;
}
li.member_subtitle::before {
	content:"■";
	color:#EA5717;
	margin-right: 0.5em;
}
.wp-block-table .has-fixed-layout {
	width: 100%;
}
.img-center {
	text-align: center;
	margin: 15px 0 0 0;
}
td.td_bold {
	font-weight: bold;
}
@media (min-width: 768px) {
	.wp-block-table .has-fixed-layout {
		width: 80%;
		font-size: 16px;
	}
}

/* 施設利用*/

li.facility-text_li {
	list-style: none;
	position: relative;
	padding-left: 1.2em;
	margin:0 0 1em 0;
}
li.facility-text_li::before {
	content: "◆";
	color: #F3981C;
	position: absolute;
	left: 0;
}
.facility-appform_wrap {
	display: flex;
	margin: 0 0 0 10px;
}
.facility-appform_inner {
	width: 50%;
	padding: 10px;
}
.facility_linebtn {
	border: 3px solid #0A569F;
	color: #0A569F;
	padding: 10px 20px;
	border-radius: 10px;
	text-decoration: none;
	display: block;
	width: 100%;
	margin: 0 0 15px 0;
	text-align: center;
}
.facility-appform_inner a.facility_linebtn:hover {
	background: var(--blue);
	color: #fff;
	transition: all .3s;
}

/* 当クラブについて*/
table.about-table {
	width:100%;
	font-size: 16px;
}
th.about-table_th {
	background-color: #E5F4FB;
	width: 20%;
	height:50px;
}
.about-img_box {
	width: 100%;
	height: 300px;
	margin: 20px 0;
}
.timeline {
  list-style: none;
}
.timeline > li {
  margin-bottom: 60px;
}
table.about_work {
	width: 100%;
}

/* for Desktop */
.timeline > li {
	overflow: hidden;
	margin: 0;
	position: relative;
}
.timeline-content {
	width: 90%;
	float: left;
	border-left: 2px #DCDCDC solid;
	padding-left: 15px;
	margin: 0 0 0 3%;
}
.timeline-content::before {
	content: '';
	width: 12px;
	height: 12px;
	background: #ea5717;
	position: absolute;
	left: 3.2%;
	top: 6px;
	border-radius: 100%;
	transform: translate(-50%,0%);
}
.timeline_year {
	margin-bottom: 0.3rem;
	color: #ea5717;
	font-weight: bold;
}
.timeline_text {
	margin-bottom: 1.5em;
}
@media ( min-width : 768px ){
	.timeline-content {
		width: 90%;
		padding-left: 20px;
		margin: 0 0 0 9.9%;
	}
	.timeline-content::before {
		left: 10%;
		top: 9px;
	}
	.timeline_year {
		margin-bottom: 5px;
		margin-top: 2.5px;
	}
	.timeline_text {
		margin-bottom: 2em;
	}
}
@media ( min-width : 992px ) {
	.timeline-content::before {
    	top: 10.5px;
  }
}

.site-body .container {
	max-width: 1140px;
	padding: 0 20px;
}
@media ( min-width : 768px ){
	.site-body .container {
		padding: 0 50px;
	}
}

.site-main .container {
	padding: unset;
}
.vk_posts {
	margin: unset;
}

.explanation {
	margin: 0 0 50px;
}
.explanation p {
	margin: 0 0 10px;
}
.explanation span {
	display: block;
	font-size: 1.5em;
	border-bottom: 1px solid #d1f1ff;
	padding: 0 0 25px;
}
dl.formtable {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	align-items: center;
	margin: 0;
}
dl.formtable dt {
	display: flex;
	width: 100%;
	justify-content: flex-start;
	align-items: center;
    position: relative;
	padding: 0;
	gap: 10px;
	margin: 0;
}
.required {
	background: rgb(var(--orange));
	color: #fff;
	border-radius: 3px;
	padding: 1px 5px;
	font-size: 10px;
	font-weight: bold;
	position: relative;
	right: 0;
	display: inline-block;
	width: 30px;
}
.optional {
	background: #a3a3a3;
	color: #fff;
	border-radius: 3px;
	padding: 1px 5px;
	font-size: 10px;
	font-weight: bold;
	position: relative;
	right: 0;
	display: inline-block;
	width: 30px;
}
dl.formtable dt p {
	font-weight: bold;
	margin: 0;
}
dl.formtable dd {
	width: 100%;
	padding: 10px 0 25px;
}
dl.formtable dd p {
	margin: 0;
}
dl.formtable input[type=text],
dl.formtable input[type=email],
dl.formtable input[type=tel],
dl.formtable textarea {
	border: 1px solid #eaeaea;
	border-radius: 5px;
	padding: 15px;
	width: 100%;
	margin: 0;
}
input::placeholder {
	color: #eaeaea;
}
dl.formtable textarea {
	resize: vertical;
}
input,
textarea,
select {
	outline: none;
}
.agree-button p a {
	color: var(--blue);
	text-decoration: none;
}
.agree-button p + p {
  margin: 0 0 40px;
}
.submit-area {
	display: flex;
	flex-flow: column;
	align-items: center;
}
.submit-area > p {
	position: relative;
	margin: 0;
}
input[type=submit] {
	border: 2px solid var(--blue);
	background: var(--blue);
	color: #fff;
	padding: .8em 3em;
	width: 200px;
	border-radius: 15px;
}
input[type=submit]:not(:disabled):hover {
	border: 2px solid var(--blue);
	background: #fff;
	color: var(--blue);
	transition: all .3s;
}
/* 送信ボタン押下時に回転するやつ */
.wpcf7-spinner {
	position: absolute;
	right: 0;
}
@media ( min-width : 768px ){
	dl.formtable {
		flex-direction: row;
	}
	dl.formtable dt {
		width: 200px;
		justify-content: space-between;
		padding: 25px 0;
		gap: 0;
	}
	dl.formtable dd {
		width: calc(100% - 200px);
		padding: 25px 0 25px 25px;
	}
}

/* フッター調整 */
@media ( min-width : 768px ){
	.footer-nav-list {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		justify-content: space-around;
		gap: 2em;
		padding: 2em 0;
	}
	.footer-nav li {
		padding: 0;
	}
	.footer-nav-list li {
		border: unset;
	}
	.footer-nav-list li:first-child {
		border: unset;
	}
}

/* プライバシーポリシー */
ul.pp-list {
	padding-left: 1.5em;
}
ul.pp-list li{
	list-style: disc;
}

/* 広告バナー */
.advertisement_area {
	max-width:1140px;
	margin: 0 auto;
}
.advertisement_wrap {
	display:block;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0 3%;
}
.advertisement_box {
	width: 100%;
	margin: 20px 0;
	text-align: center;
}
.advertisement_box a img {
	width: 80%;
	margin: 0 auto;
}
.advertisement_text {
	font-size:0.875em;
}
@media (min-width: 500px){
	.advertisement_wrap {
	display:flex;
	}
	.advertisement_box a img {
		width:40%;
	}
}
@media ( min-width : 768px ){
	.advertisement_box {
		width: calc(100%/2 - 3%);
	}
	.advertisement_box a img {
		width: 60%;
	}
}
