@charset "utf-8";
/*
Theme Name: urachucms
Theme URI:
Template: habakiri
Description:
Author: Studio Orbiter TS
Tags:
Version: 0.1.0
*/


/*------------------------------------------------------------------------------*/
/* フォント */
/*------------------------------------------------------------------------------*/
@font-face {
	font-family: 'Anton';
	src: url('font/Anton.woff') format('woff');
}

@font-face {
	font-family: 'Noto Sans JP';
	src: url('font/NotoSansJP-Regular.woff') format('woff');
	font-weight: 400;
}
@font-face {
	font-family: 'Noto Sans JP';
	src: url('font/NotoSansJP-Medium.woff') format('woff');
	font-weight: 500;
}
@font-face {
	font-family: 'Noto Sans JP';
	src: url('font/NotoSansJP-SemiBold.woff') format('woff');
	font-weight: 600;
}
@font-face {
	font-family: 'Noto Sans JP';
	src: url('font/NotoSansJP-Black.woff') format('woff');
	font-weight: 900;
}


/*------------------------------------------------------------------------------*/
/* 基本設定 */
/*------------------------------------------------------------------------------*/
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	color: #fff;
	min-width: 320px;
	animation: fadeIn 2s ease 0s 1 normal;
	-webkit-animation: fadeIn 2s ease 0s 1 normal;
}

p {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.8em;
	margin: 0px;
}

ul {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.8em;
	padding-left: 30px;
	list-style: square;
}

ol {
	font-size: 16px;
}

@media screen and (max-width:799px) {
	p {
		font-size: 16px;
	}
}

@media screen and (max-width:599px) {
	p {
		font-size: 16px;
	}

	ul {
		font-size: 16px;
		padding-left: 20px;
	}
}

table {
	font-size: 16px;
	width: 100%;
}

table td {
	font-size: 16px;
}

table ul {
	font-size: 16px;
}

a:focus {
	outline: none;
}

.small,
small {
	font-size: 80%;
}

.sub-page-contents {
	padding-top: 0px;
}

#main {
	margin-bottom: 0px;
}

section {
	padding: 60px 0px;
}

video {
	width: 100%;
	height: auto;
}

/*------------------------------------------------------------------------------*/
/* プリセットマージン */
/*------------------------------------------------------------------------------*/
.mb0 {
	margin-bottom: 0;
}

.mb5 {
	margin-bottom: 5px;
}

.mb10 {
	margin-bottom: 10px;
}

.mb15 {
	margin-bottom: 15px;
}

.mb20 {
	margin-bottom: 20px;
}

.mb25 {
	margin-bottom: 25px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb35 {
	margin-bottom: 35px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb45 {
	margin-bottom: 45px;
}

.mb50 {
	margin-bottom: 50px;
}

.mb55 {
	margin-bottom: 55px;
}

.mb60 {
	margin-bottom: 60px;
}

.ptb15 {
	padding-top: 15px;
	padding-bottom: 15px;
}

.ptb30 {
	padding-top: 30px;
	padding-bottom: 30px;
}
.ptb60 {
	padding-top: 60px;
	padding-bottom: 60px;
}

/*------------------------------------------------------------------------------*/
/* ヘッダ */
/*------------------------------------------------------------------------------*/
#header {
	z-index: 4;
}

.header--transparency.header--fixed--is_scrolled {
	background-color: rgba(255, 255, 255, .5) !important;
}

.header--transparency.header--fixed--is_scrolled a {
	color: #707070 !important;
}

.site-branding {
	padding: 15px 15px 15px 0px;
}

.site-branding__heading img {
	max-height: 50px;
/*	filter: drop-shadow(1px 1px 0px rgb(255, 255, 255));*/
}

/*---アンカータグがある場合のズレ調整---*/
.anchor {
	margin-top: -106px;
	padding-top: 106px;
}


/*------------------------------------------------------------------------------*/
/* ページヘッダ */
/*------------------------------------------------------------------------------*/
.page-header {
	padding: 80px 15px;
	border-bottom: none;
	background: linear-gradient(90deg, #333 20%, #000 80%);
	background-repeat: none;
}

.page-header__title {
	font-size: 3.0em;
	font-weight: 900;
	letter-spacing: 0.05em;
	text-align: left;
	margin: 0;
	color: #fff;
}

@media (max-width: 960px) {
	.page-header__title {
		font-size: 2.2em;
		margin: 0;
	}
}

@media (max-width: 599px) {
	.page-header {
		padding: 60px 15px;
	}

	.page-header__title {
		font-size: 2.0em;
		margin: 0;
	}
}

@media (max-width: 499px) {
	.page-header__title {
		font-size: 1.8em;
		margin: 0;
	}
}


/*------------------------------------------------------------------------------*/
/* パンくずリスト */
/*------------------------------------------------------------------------------*/
.breadcrumbs_wrapper {
	position: relative;
	background: #666;
	height: 32px;
}

.breadcrumbs {
	font-weight: 300;
	padding: 6px;
	margin-bottom: 0px;
	color: #fff;
	background-color: #666;
}

.breadcrumbs a:active, .breadcrumbs a:hover, .breadcrumbs a:link, .breadcrumbs a:visited {
	color: #fff;
	margin-right: 10px;
}

.breadcrumbs a:hover {
	color: #D60016;
}

.breadcrumbs strong {
	margin: 0 10px;
}

@media (max-width: 599px) {
	.breadcrumbs {
		margin-bottom: 20px;
	}
}


/*------------------------------------------------------------------------------*/
/* グローバルナビ */
/*------------------------------------------------------------------------------*/
.header {
	background-color: rgba(0, 0, 0, 0.6) !important;
}

.header--fixed,
.header.header--fixed--is_scrolled {
	box-shadow: none;
	background-color: rgba(0, 0, 0, 0.6) !important;
}

.header--fixed--is_scrolled .menu li small {
	color: #777 !important;
}

/*---グローバルナビの文字左寄せ---*/
.responsive-nav .menu-item {
	text-align: left;
	/*filter: drop-shadow(0 0 2px rgba(0, 0, 0, .1));*/
}

/*---説明文字の高さ---*/
.menu li small {
	line-height: 0.8em;
}

/*---グローバルナビに区切り線---*/
.menu li:first-child {
	border-left: none;
}

.menu li a {
	position: relative;
	width: 100%;
	display: inline-block;
	text-decoration: none;
	font-weight: bold;
}

/*---ホバーで下線---*/
.menu li a:hover {
	color: #D60016 !important;
}

.menu li a::after {
	position: absolute;
	bottom: 0px;
	left: 0px;
	content: '';
	width: 100%;
	height: 2px;
	background: #D60016;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform .3s;
}

.menu li a:hover::after {
	transform: scale(1, 1);
}

/*---選択時文字色 ノーマル---*/
.current_page_item a {
	color: #D60016 !important;
}
.header--fixed--is_scrolled .current_page_item a {
	color: #D60016 !important;
}
/*---選択時文字色 ノーマル・サブメニュー---*/
.current_page_item small {
	color: #D60016!important;
}
.header--fixed--is_scrolled .current_page_item small {
	color: #D60016!important;
}
/*---選択時文字色 カスタム投稿タイプ---*/
.current-menu-item a {
	color: #D60016!important;
}
.header--fixed--is_scrolled .current-menu-item a {
	color: #D60016!important;
}
.current-menu-item a,
.header--fixed--is_scrolled .current-menu-item a {
    color: #000 !important; /* 黒に変更 */
}
/*---サブメニューhover時に全幅（最大幅は親に準拠）---*/
.responsive-nav .children a,
.responsive-nav .sub-menu a {
	padding: 10px;
	width: 100%;
	font-size: 12px;
	font-weight: 600;
}


/*------------------------------------------------------------------------------*/
/* オリジナルナビ */
/*------------------------------------------------------------------------------*/
/*---オリジナルナビ設置のための位置調整---*/
#contents {
	margin-top: 106px !important;
}

#orgin_menu {
	position: fixed;
	width: 100%;
	height: 40px;
	background: #000;
	margin-top: 66px;
	text-align: center;
	z-index: 4;
}

.header_list {
	display: table;
	margin: -16px auto;
}
.header_list_l, .header_list_img, .header_list_r {
	display: table-cell;
}
.header_list ul {
	padding: 0px;
	margin: 0px;
}
.header_list ul li {
	width: 100px;
}
.header_list ul li a {
	display: block;
    height: 40px;
	position: relative;
	font-family: 'Anton', sans-serif;
	font-size: 16px;
	text-decoration: none;
	color: #fff;
	background: #000;
	transition: all 0.3s;
}
.header_list ul li a span {
    display: block;
    height: 8px;
    position: absolute;
    bottom: 16px;
    left: 0px;
    right: 0px;
    margin: 0 auto;
	font-family: 'Noto Sans JP', sans-serif;
    font-size: 8px;
}

.header_list ul li a:hover {
	background: #666;
	transition: all 0.3s;
}

.header_list .current {
	background: #D60016;
}

.header_list_l ul {
	display: table;
}
.header_list_l ul li {
	display: table-cell;
}

.header_list_r ul {
	display: table;
}
.header_list_r ul li {
	display: table-cell;
}

@media screen and (max-width:659px) {
	#contents {
		margin-top: 80px !important;
	}
	#orgin_menu {
		display: none;
	}
}


/*------------------------------------------------------------------------------*/
/* ハンバーガーボタン */
/*------------------------------------------------------------------------------*/
/*---角丸---*/
#responsive-btn {
	border-width: 0.5px !important;
	border-radius: 2px !important;
	padding: 6px 8px 8px;
	transition: all .5s;
	font-size: 20px;
}

/*---開くアイコン変更（fontaesome）---*/
.responsive-nav-wrapper #responsive-btn::before {
	content: url(/urachu/wp-content/themes/urachucms/img/bars-solid.svg);
}

/*---閉じるアイコン変更（fontaesome）---*/
.responsive-nav-wrapper.off-canvas-nav-open #responsive-btn::before {
	content: url(/urachu/wp-content/themes/urachucms/img/xmark-solid.svg);
}

/*------------------------------------------------------------------------------*/
/* オフキャンバスメニュー */
/*------------------------------------------------------------------------------*/
/*---LINEアイコン---*/
.ilne_icon {
	position: absolute;
	top: 13px;
	left: 190px;
}

/*---メニュー既存スタイル変更：メインコンテンツ影消去---*/
.responsive-nav-contents {
	position: relative;
	box-shadow: none;
}

.off-canvas-nav--dark {
	background: #666;
}

.off-canvas-nav--dark a {
	color: #333;
}

.off-canvas-nav--dark a:hover {
	color: #D60016;
	background: #fff;
}

.off-canvas-nav--dark ul {
	border: none;
}

.off-canvas-nav--dark li {
	border: none;
}

.off-canvas-nav--dark .current_page_item a {
	background-color: #fff;
	color: #D60016
}

/*---サブメニュー既存スタイル変更：左線消去---*/
.off-canvas-nav--dark ul ul {
	border-top: none;
	border-left: none;
	margin-bottom: -1px;
	margin-left: 2em;
	opacity: 1;
	visibility: visible;
}

.off-canvas-nav--dark ul ul li {
	border-left: none;
}

.responsive-nav-contents {
	position: relative;
	box-shadow: none;
}


/*------------------------------------------------------------------------------*/
/* メインヴィジュアル */
/*------------------------------------------------------------------------------*/
#main_visual {
	display: grid;
	position: relative;
	place-items: center;
	padding: 0px;
	background: #000;
}

#main_visual_sp {
    display: none;
	position: relative;
    width: 100%;
	padding: 0px;
	background: #000;
}

@media screen and (max-width: 659px) {
	#main_visual {
		display: none;
	}
	#main_visual_sp {
		display: block;
	}
}

.sp-video {
	display: block;
}

.pc-video {
	display: none;
}

@media screen and (min-width: 659px) {
	.sp-video {
		display: none;
	}

	.pc-video {
		display: block;
	}
}


/*------------------------------------------------------------------------------*/
/* フッタ */
/*------------------------------------------------------------------------------*/

/*---汎用要素---*/
.origin_footer {
	position: relative;
	max-height: 480px;
	padding: 60px 0px;
}

.origin_footer a {
	color: #fff;
}

.footer_list {
	display: table;
	margin: 0px auto;
}

.footer_logo_lg {
	display: inline-table;
	padding-bottom: 15px;
}
.footer_logo_lg img {
	max-width: 100px;
	margin: 0px 60px;
}

.footer_logo_sp {
	display: none;
}

.footer_link {
	display: inline-table;
	text-decoration: none;
	padding: 0px 0px 0px 15px;
	margin: 0px 60px 15px 0px;
	vertical-align: top;
}

.footer_link li {
	list-style: none;
	margin-bottom: 0px;
}

.footer_link li a {
	color: #fff;
	font-size: 14px;
}

.bold_link {
	font-weight: bold;
	font-size: 16px!important;
}

.last_link {
	margin-right: 0px;
}


.copyright {
	font-size: 12px;
	text-align: center;
	color: #fff;
	padding: 15px;
	background-color: #333;
}

@media screen and (max-width: 1302px) {
	.footer_logo_lg {
		display: none;
	}
	.footer_logo_sp {
		display: block;
		width: 100%;
		text-align: center;
		margin-top: 30px;
	}
	.footer_logo_sp img {
		max-width: 100px;
		margin: 0px auto;
	}
}
@media screen and (max-width: 1039px) {
	.footer_list {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
	}
}
@media screen and (max-width: 699px) {
	.footer_list {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width: 499px) {
	.footer_link {
		margin: 0px 15px 15px 0px;
	}
}
@media screen and (max-width: 499px) {
	.footer_list {
		grid-template-columns: repeat(1, 1fr);
	}
	.footer_logo_sp img {
		max-width: 80px;
	}
}

/*------------------------------------------------------------------------------*/
/* Page to Top */
/*------------------------------------------------------------------------------*/
.footer_cta {
	width: 100%;
}

#page_top {
	position: absolute;
	right: 0px;
	top: -40px;
	width: 40px;
	height: 40px;
	background: #D60016;
}

#page_top a {
	position: relative;
	display: block;
	text-decoration: none;
	padding: 8px;
}

#page_top a::before {
	content: '▲';
	display: block;
	text-align: center;
	font-weight: 900;
	font-size: 12px;
	color: #fff;
	margin: auto;
}


/*------------------------------------------------------------------------------*/
/* WP Page navi */
/*------------------------------------------------------------------------------*/
.page_navi_wrapper {
	display: grid;
}

.wp-pagenavi {
	padding: 30px 15px;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    margin: 0px auto;
}

.wp-pagenavi a, .wp-pagenavi span {
	display: block;
	width: 24px;
	height: 35px;
    text-decoration: none;
    border: 1px solid #000;
    padding: 3px 3px;
    margin: 2px;
}

.wp-pagenavi .pages {
	width: 64px;
}

/*--- カレント ---*/
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	color: #fff;
	background: #D60016;;
    border-color: #D60016;
}

/*------------------------------------------------------------------------------*/
/* レイアウトコントロール */
/*------------------------------------------------------------------------------*/
/*---CTA座標検知のための設定---*/
body {
	position: relative;
}

/*---メインコンテンツ最低高1画面---*/
.sub-page-contents {
	min-height: 100vh;
}

/*---中央寄せ---*/
.align_center {
	text-align: center;
}

/*---右寄せ---*/
.align_right {
	text-align: right;
}

/*---スマホ幅で現れる改行---*/
.br_sp {
	display: none;
}

/*---強調段落---*/
.strong_p {
	display: inline-block;
	font-family: 'M PLUS 2', sans-serif;
	font-size: 2.2em;
	font-weight: 600;
	line-height: 1.4em;
	text-align: left;
	color: #FE5A00;
	padding: 1.0em 0em;
}
@media screen and (max-width: 599px) {
	.strong_p {
		font-size: 1.4em;
	}
}

/*---太字---*/
.bold {
	font-weight: bold;
}


/*------------------------------------------------------------------------------*/
/* 見出し */
/*------------------------------------------------------------------------------*/
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
	margin-top: 0em;
	margin-bottom: 0.3em;
}

h2 {
	font-size: 3.0em;
}

h3 {
	font-size: 2.0em;
	margin-bottom: 0.5em;
}

h4 {
	font-size: 1.5em;
	margin-bottom: 0.5em;
}


@media screen and (max-width: 1239px) {
	h2 {
		font-size: 2.8em;
	}
	h3 {
		font-size: 1.8em;
	}
	h4 {
		font-size: 1.3em;
	}
}
@media screen and (max-width: 939px) {
	h2 {
		font-size: 2.6em;
	}
	h3 {
		font-size: 1.6em;
	}
	h4 {
		font-size: 1.2em;
	}
}
@media screen and (max-width: 499px) {
	h2 {
		font-size: 2.4em;
	}
	h3 {
		font-size: 1.4em;
	}
	h4 {
		font-size: 1.0em;
	}
}


/*---Anton邦字副題付き（要span）---*/
.anton_h {
	font-family: 'Anton', sans-serif;
	line-height: 1.0em;
	color: #707070;
	margin-bottom: 0.5em;
}
.anton_h span {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.6em;
	color: #fff;
}


/*---背景画像付き（透過白画像+白文字限定）---*/
.bg_h {
	position: relative;
}
.bg_h img {
	position: absolute;
	bottom: 0px;
	left: 0px;
}


/*---左ボーダー---*/
.border_left_h {
	color: #000;
    padding: 4px 15px 5px;
    border-left: 4px solid #D60016;
	background: #707070;
}


/*------------------------------------------------------------------------------*/
/* ボタン */
/*------------------------------------------------------------------------------*/
/*---メイン配色ボタン---*/
.button {
	max-width: 240px;
	position: relative;
	bottom: 0px;
	left: 0px;
	right: 0px;
	margin: auto;
	border: 1px solid #000000;
	border-radius: 2px;
	color: #fff;
	text-align: center;
	background-color: #000000;
	transition: 0.5s;
}

.button i {
	transition: 0.5s;
}

.button:hover {
	background-color: #fff;
	border: 1px solid #000000;
}

.button a {
	display: block;
	color: #fff;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 10px;
}

.button a:hover {
	color: #000000;
	text-decoration: none;
}


/*---差し色配色ボタン---*/
.button_r {
	max-width: 240px;
	position: relative;
	bottom: 0px;
	left: 0px;
	right: 0px;
	margin: auto;
	border: 1px solid #D60016;
	border-radius: 2px;
	color: #fff;
	text-align: center;
	background-color: #D60016;
	transition: 0.5s;
}

.button_r i {
	transition: 0.5s;
}

.button_r:hover {
	background-color: #fff;
	border: 1px solid #D60016;
}

.button_r a {
	display: block;
	color: #fff;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 10px;
}

.button_r a:hover {
	color: #D60016;
	text-decoration: none;
}


/*---灰色ボタン---*/
.button_gray {
	max-width: 240px;
	position: relative;
	bottom: 0px;
	left: 0px;
	right: 0px;
	margin: auto;
	border: 1px solid #707070;
	border-radius: 2px;
	color: #fff;
	text-align: center;
	background-color: #707070;
	transition: 0.5s;
}

.button_gray i {
	transition: 0.5s;
}

.button_gray:hover {
	background-color: #fff;
	border: 1px solid #D60016;
}

.button_gray a {
	display: block;
	color: #fff;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 10px;
}

.button_gray a:hover {
	color: #D60016;
	text-decoration: none;
}


/*---2ボタン並列配置---*/
.button_2 {
	max-width: 380px;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin: 30px auto;
	padding: 0px 15px;
}
.button_2 .button {
	display: table-cell;
}
.button_2 .button a {
	min-width: 160px;
}
@media screen and (max-width: 599px) {
	.button_2 .button a {
		min-width: 130px;
	}
}

/*------------------------------------------------------------------------------*/
/* リスト */
/*------------------------------------------------------------------------------*/
/*---強調リスト---*/
.point_list {
	color: #000;
	text-align: left;
	font-size: 1.5em;
	font-weight: 500;
	padding: 1em 1em 0.5em 2.5em;
	background: #ccc;
}
.point_list li {
	margin-bottom: 0.5em;
}
.point_list li span {
	font-weight: 700;
	background:linear-gradient(transparent 60%, #FDC942 60%);
}


/*---注意書きリスト---*/
.notice_list {
	text-align: left;
	font-size: 1.0em;
	font-weight: 400;
	list-style: none;
}
.notice_list li::before {
	content: '※';
	text-indent: 1em;
	margin-left: -1em;
}
@media screen and (max-width: 939px) {
	.point_list {
		font-size: 1.6em;
	}
}
@media screen and (max-width: 759px) {
	.point_list {
		font-size: 1.2em;
	}
}
@media screen and (max-width: 599px) {
	.point_list {
		padding: 0.5em 0.5em 0.5em 2.0em;
	}
}


/*------------------------------------------------------------------------------*/
/* テーブル */
/*------------------------------------------------------------------------------*/
/*---汎用レスポンシブテーブル---*/
.float_table {
	width: 100%;
	table-layout: auto;
	word-break: break-all;
	word-wrap: break-all;
}

.float_table tr {
	border-bottom: 1px solid #000;
}

.float_table th {
	width: auto;
	min-width: 150px;
	/*white-space: nowrap;*/
	word-break: break-word;
	padding: 10px 15px;
	background: #707070;
}

.float_table td {
	width: auto;
	box-sizing: border-box;
	word-break: break-word;
	color: #000;
	padding: 10px 15px;
	background: #ccc;
}

.float_table .lv2 {
	font-weight: 500;
	font-size: 0.8em;
}

.sp_th_title {
	display: none;
}

@media screen and (max-width:599px) {
	.float_table tr {
		border-bottom: none;
	}
	.float_table table {
		width: 100%;
		table-layout: fixed;
		font-size: 1.2em;
	}

	.float_table th {
		display: block;
		width: 100%;
		background: #707070;
		border-left: 4px solid #D60016;
		padding: 4px 15px 5px;
	}

	.float_table td {
		display: block;
		width: 100%;
		padding: 5px 15px 10px;
	}

	.last {
		padding-bottom: 30px!important;
	}

	.sp_th_title {
		display: inherit;
		color: #fff;
		font-size: 16px;
		padding: 2px 10px 5px;
		background: #afc288;
		border-radius: 2px;
	}

	.disable {
		display: none!important;
	}
}


/*------------------------------------------------------------------------------*/
/* フォーム */
/*------------------------------------------------------------------------------*/
/*---既存フォーム要素のスタイリング修正---*/
.form-control {
	border-radius: 0px;
	box-shadow: none;
}

/*---既存フォーム要素のスタイリング修正---*/
input[type="date"],
input[type="datetime-local"],
input[type="month"],
input[type="time"] {
	line-height: 25px;
}

/*---既存フォーム要素のスタイリング修正---*/
input,
textarea {
	width: 100%;
	padding: 8px;
	color: #000;
	background: #eee;
	border: none;
	border-radius: 0px;
	box-shadow: none;
}

/*---既存フォーム要素のスタイリング修正---*/
input:focus {
	border-radius: 0px;
}

/*---既存フォーム要素のスタイリング修正---*/
input[type="checkbox"],
input[type="radio"] {
	line-height: normal;
	text-align: center;
	margin: 0 auto;
}

/*---既存フォーム要素のスタイリング修正---*/
select {
	width: 100%;
	color: #000;
	padding: 10px;
	background: #eee;
	border: none;
	border-radius: 0px;
	box-shadow: none;
}

/*---既存フォーム要素のスタイリング修正---*/
label {
	font-size: 1.2em;
}

.submit_button {
	display: flex;
    gap: 15px;
}

/*---要素並列配置---*/
input[type="date"] {
	width: 200px !important;
}

/*---必須事項span---*/
.must {
	position: relative;
	top: -2px;
	font-weight: 300;
	font-size: 12px;
	white-space: nowrap;
	color: #fff;
	padding: 0px 8px 2px 7px;
	margin-left: 1em;
	background: #D60016;
	border-radius: 2px;
}

input[type="submit"] {
	max-width: 280px;
	display: block;
	color: #fff;
	font-size: 1.2em;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 16px;
	margin: auto;
	position: relative;
	bottom: 0px;
	left: 0px;
	right: 0px;
	border: 1px solid #D60016;
	border-radius: 4px;
	background-color: #D60016;
	transition: 0.5s;
}
input[type="submit"]:hover {
	color: #D60016;
	background-color: #fff;
	border: 1px solid #D60016;
}

.mwform-checkbox-field label, .mwform-radio-field label {
	text-align: center;
}


/*------------------------------------------------------------------------------*/
/* HOME */
/*------------------------------------------------------------------------------*/
/*---セクション共通---*/
.section_inner {
	max-width: 1240px;
	margin: auto;
	padding: 0px 15px;
}

.contents_card {
	background: #333;
	margin-bottom: 30px;
}
.contents_card_text {
	padding: 30px 45px;
}
.contents_card p {
	margin-bottom: 35px;
}

@media screen and (max-width: 719px) {
	.section_inner h2 {
		text-align: initial;
	}
}
@media screen and (max-width: 599px) {
	.contents_card_text {
		padding: 30px 15px;
	}
	.bg_h img {
		width: 50%;
	}
}


/*---section_01 vision---*/
.top_logo {
	padding: 15px 0px;
}

#team_vision {
	padding:10px 0 0;
	background: #000;
}
#team_vision h2 {
	color: #D60016;
}
#team_vision h2 span {
	color: #fff;
}

.vision_2 {
	display: flex;
}

.img_vision_00 {
	flex-basis: 70%;
}
.img_vision_00 img {
	width: 100%;
}
.team_vision_contents {
	flex-basis: 30%;
	position: relative;
}

.vision_2 .contents_card {
	position: absolute;
	left: -45px;
	bottom: 60px;
	margin-bottom: 0px;
}

.bg_h-team img{
	position: absolute;
  bottom: 150px;
  left: 50px;
}


@media screen and (max-width: 1807px) {
	.img_vision_00 {
		flex-basis: 60%;
	}
	.team_vision_contents {
		flex-basis: 40%;
	}
}
@media screen and (max-width: 1583px) {
	.vision_2 .contents_card {
		bottom: 0px;
	}
}
@media screen and (max-width: 1439px) {
	.vision_2 {
		display: block;
	}
	.vision_2 .contents_card {
		position: inherit;
		left: 0;
		bottom: 0px;
	}
}

@media screen and (max-width: 599px) {
	.bg_h-team img{
		position: absolute;
		bottom: 110px;
		left: 10px;
		max-width: 40% !important;
	}

	#team_vision .pd-50{
		padding-bottom: 10px !important;
	}
}


/*---section_02 RECRUITING---*/

#recruiting {
	padding:10px 0 0 0;
	background: #000;
}
#team_vision h2 {
	color: #D60016;
}
#team_vision h2 span {
	color: #fff;
}

.recruiting {
	display: flex;
	flex-direction: row-reverse;
}

.img_recruiting_00 {
	flex-basis: 70%;
}
.img_recruiting_00 img {
	width: 100%;
}
.team_recruiting_contents {
	flex-basis: 30%;
	position: relative;
}

.recruiting .contents_card {
	position: absolute;
	left: 30px;
	bottom: 60px;
	margin-bottom: 0px;
	background: none;
}

.bg_h-recruiting img{
	position: absolute;
  bottom: 175px;
  left: 40px;
}


@media screen and (max-width: 1807px) {
	.img_recruiting_00 {
		flex-basis: 60%;
	}
	.team_recruiting_contents {
		flex-basis: 40%;
	}
}
/* @media screen and (max-width: 1583px) {
	.recruiting .contents_card {
		bottom: 0px;
	}
} */
@media screen and (max-width: 1439px) {
	.recruiting {
		display: block;
	}
	.recruiting .contents_card {
		position: inherit;
		left: 0;
		bottom: 0px;
	}
}

@media screen and (max-width: 599px) {
	.bg_h-recruiting img{
		position: absolute;
		bottom: 180px;
		left: 10px;
		max-width: 80% !important;
	}
}



/*---section_03 activity---*/

#activity {
	padding:10px 0 0;
	background: #000;
}
#activity h2 {
	color: #D60016;
}
#activity h2 span {
	color: #fff;
}

#activity p {
	padding:0 0 25px;
}

.activity {
	display: flex;
}

.img_activity_00 {
	flex-basis: 70%;
}
.img_activity_00 img {
	width: 100%;
}
.activity_contents {
	flex-basis: 30%;
	position: relative;
}

.activity .contents_card {
	position: absolute;
	left: -45px;
	bottom: 60px;
	margin-bottom: 0px;
}

.bg_h-activity img{
	position: absolute;
  bottom: 150px;
  left: 50px;
}

.contents_card-activity{
	width: 100%;
  background: #333;
  position: absolute;
  left: -45px;
  bottom: 60px;
  margin-bottom: 0px;
}


@media screen and (max-width: 1807px) {
	.img_activity_00 {
		flex-basis: 60%;
	}
	.activity_contents {
		flex-basis: 40%;
	}
}
@media screen and (max-width: 1583px) {
	.activity .contents_card {
		bottom: 0px;
	}
}
@media screen and (max-width: 1439px) {
	.activity {
		display: block;
	}
	.activity .contents_card {
		position: inherit;
		left: 0;
		bottom: 0px;
	}
	.contents_card-activity{
		position: static;
	}
}

@media screen and (max-width: 599px) {
	.bg_h-activity img{
		position: absolute;
		bottom: 150px;
		left: 10px;
		max-width: 57.5% !important;
	}


	#activity p {
	padding:0 0 15px;
}
}



/*---section_02 join_us---*/
#join_us {
	padding: 60px 0px;
	background: #000;
}

.join_us_3 {
	position: relative;
	margin: auto;
	padding: 0px 15px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 15px;
}

.trial_session {
	text-align: center;
}
.trial_session .contents_card {
	background: #000;
}

.img_trial_session_00 {
	padding: 35px;
}

@media screen and (max-width: 1439px) {
	.join_us_3 {
		margin: 0px auto;
		display: grid;
		grid-template-columns: 1fr 1fr;
		grid-template-rows: 1fr;
		gap: 10px;
		grid-template-areas:
			"join_us_card_b join_us_card_c"
			"join_us_card_a join_us_card_a";
	}
	.trial_session {
		grid-area: join_us_card_a;
	}
	.message {
		grid-area: join_us_card_b;
	}
	.join_info {
		grid-area: join_us_card_c;
	}
}

@media screen and (max-width: 759px) {
	.join_us_3 {
		grid-template-columns: 1fr;
		grid-template-rows: 1fr;
		gap: 15px;
		grid-template-areas:
			"join_us_card_b"
			"join_us_card_c"
			"join_us_card_a";
	}
}


#index_equipment_guide {
	padding:40px 0 0 0;
	background: #000;
}

.equipment_guide_2 {
	/* display: flex; */
}

.equipment_img_4 {
	flex-basis: 100%;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0px;
	position: relative;
}

.equipment_img_4 .button_r{
  bottom: 100px;
  left: 50%;
  width: 300px;
}

/* .equipment_img_4 a {
	position: relative;
	height: 100%;
	display: block;
} */
.equipment_img_4 h3 {
	font-family: 'Noto Sans JP', sans-serif;
	position: absolute;
	top: 8px;
	left: 8px;
	color: #fff;
}
.equipment_img_4 img {
	width: 100%;
	transition-duration: 0.5s;
}
/* .equipment_img_4 img:hover {
	transform: scale(1.1, 1.1);
	cursor: pointer;
	transition-duration: 0.5s;
} */

.equipment_01, .equipment_02, .equipment_03, .equipment_04 {
	width: 100%;
	overflow: hidden;
}

.equipment_guide_contents {
	flex-basis: 40%;
	padding: 30px 45px;
}
.equipment_guide_contents p {
	margin-bottom: 1.0em;
}

@media screen and (max-width: 599px) {
	.equipment_guide_contents {
		padding: 30px 15px;
	}
}





/*---section_03 index_equipment_guide---*/
/* #index_equipment_guide {
	padding: 0px;
	background: #333;
}

.equipment_guide_2 {
	display: flex;
}

.equipment_img_4 {
	flex-basis: 60%;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0px;
}
.equipment_img_4 a {
	position: relative;
	height: 100%;
	display: block;
}
.equipment_img_4 h3 {
	font-family: 'Noto Sans JP', sans-serif;
	position: absolute;
	top: 8px;
	left: 8px;
	color: #fff;
}
.equipment_img_4 img {
	width: 100%;
	transition-duration: 0.5s;
}
.equipment_img_4 img:hover {
	transform: scale(1.1, 1.1);
	cursor: pointer;
	transition-duration: 0.5s;
}

.equipment_01, .equipment_02, .equipment_03, .equipment_04 {
	width: 100%;
	overflow: hidden;
}

.equipment_guide_contents {
	flex-basis: 40%;
	padding: 30px 45px;
}
.equipment_guide_contents p {
	margin-bottom: 1.0em;
}

@media screen and (max-width: 599px) {
	.equipment_guide_contents {
		padding: 30px 15px;
	}
}

@media screen and (max-width: 1564px) {
	.equipment_guide_2 {
		display: inherit;
	}
	.equipment_img_4 {
		width: 100%;
	}
	.equipment_guide_contents {
		width: 100%;
	}
} */


/*---section_04 index_information---*/
#index_information {
	padding: 60px 0px;
	background: #000;
}
#index_information h2 {
	color: #fff;
}
#index_information h2 span {
	color: #707070;
}

.information_4 {
	margin-bottom: 35px;
}

.information_4 a {
	color: #fff;
	text-decoration: none;
}

.information_card {
	background: #707070;
	padding: 10px 15px;
	margin-bottom: 20px;
	display: block;
}
.information_card .post_title a {
	font-weight: 600;
	color: #fff;
}


/*---section_05 index_gallery---*/
#index_gallery {
	padding: 80px 0px 60px;
	background: #333;
}

.index_gallery_inner {
	max-width: 1640px;
	margin: 0px auto;
	padding: 0px 15px;
}


/*---section_06 index_team_profile---*/
#index_team_profile {
	padding: 60px 0px;
	background: #000;
}
#index_team_profile h2 {
	color: #fff;
}

.team_profile_2 {
	position: relative;
	max-width: 1640px;
	margin: 0px auto;
	padding: 0px 15px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 15px;
}

.team_profile_01, .team_profile_02 {
	width: 100%;
	overflow: hidden;
	position: relative;
}


.team_profile_01 h2 {
	position: absolute;
	bottom: 15px;
	right: 0px;
	left: 0px;
	margin: 0px auto;
}
.team_profile_01 a {
	position: relative;
	height: 100%;
	display: block;
}
.team_profile_01 img {
	width: 100%;
	transition-duration: 0.5s;
}
.team_profile_01 img:hover {
	transform: scale(1.1, 1.1);
	cursor: pointer;
	transition-duration: 0.5s;
}

.team_profile_02 h2 {
	position: absolute;
	bottom: 15px;
	right: 0px;
	left: 0px;
	margin: 0px auto;
}
.team_profile_02 a {
	position: relative;
	height: 100%;
	display: block;
}
.team_profile_02 img {
	width: 100%;
	transition-duration: 0.5s;
}
.team_profile_02 img:hover {
	transform: scale(1.1, 1.1);
	cursor: pointer;
	transition-duration: 0.5s;
}

@media screen and (max-width:499px) {
	.equipment_img_4 {
		grid-template-columns: repeat(1, 1fr);
		gap: 15px;
		padding: 0px 15px 45px;
	}
}
@media screen and (max-width:719px) {
	.team_profile_2 {
		position: relative;
		grid-template-columns: repeat(1, 1fr);
	}
}

@media screen and (max-width: 599px) {
	.equipment_img_4 .button_r {
		position: static;
		margin-top: 25px;
	}
}



/*---section_07 index_schedule---*/
#index_schedule {
	padding: 60px 0px;
	background: #333;
}
#index_schedule h2 {
	color: #D60016;
}
#index_schedule h2 span {
	color: #fff;
}

.schedule_4 {
	margin-bottom: 35px;
}

.schedule_card {
	background: #707070;
	padding: 10px 15px;
	margin-bottom: 20px;
}
.schedule_card .post_title p {
	font-weight: 600;
}

.schedule_sub_card {
	display: flex;
	flex-wrap: wrap;
}

.post_title {
	flex-basis: 25%;
    display: flex;
    margin-bottom: 4px;
	font-weight: 600;
/*	color: #000;*/
	color: #fff;
}
.post_title p {
	line-height: 1.4em;
}

.post_sub_item {
	flex-basis: 25%;
	display: flex;
	margin-bottom: 4px;
}
.post_sub_item p {
	line-height: 1.4em;
}


@media screen and (max-width:1079px) {
	.post_title {
		flex-basis: 100%;
	}
	.post_sub_item {
		flex-basis: 33%;
	}
}
@media screen and (max-width:799px) {
	.post_sub_item {
		flex-basis: 100%;
	}
	.schedule_sub_card {
		margin-bottom: 10px;
	}
}


/*------------------------------------------------------------------------------*/
/* TEAM チーム紹介 */
/*------------------------------------------------------------------------------*/
/*---選手紹介用テーブル---*/
.players_table {
	max-width: 380px;
	font-family: 'Anton', sans-serif;
	padding: 0px 15px;
	margin: 0px auto;
/*	text-shadow: 2px 2px 2px #000, -2px -2px 2px #000, -2px 2px 2px #000, 2px -2px 2px #000;*/
}

.players_table th {
	font-size: 2.0em;
	line-height: 1.5em;
	text-align: right;
	color: #707070;
}
.players_table td {
	font-size: 2.0em;
	line-height: 1.5em;
	text-align: center;
}

.players_list {
	margin-bottom: 45px;
}

.players_list p {
	margin-bottom: 1.0em;
}

.float_img {
	display: block;
	float: left;
	margin: 0em 2em 2em 0em;
	width: 50%;
}

.float_text {
	text-align: justify;
	width: 100%;
}

#coaching_staff .float_table th {
	width: 20%;
}

@media screen and (max-width:599px) {
	.players_table th {
		font-size: 1.5em;
	}
	.players_table td {
		font-size: 1.5em;
	}
	#coaching_staff .float_table th {
		width: 100%;
	}
	.float_img {
		margin: 0em 0em 2em 0em;
		width: 100%;
	}
}


/*------------------------------------------------------------------------------*/
/* STAFF スタッフ紹介 */
/*------------------------------------------------------------------------------*/
.leadership {
	max-width: 840px;
	margin: 0px auto;
}
.leadership p {
	font-size: 1.5em;
}

@media screen and (max-width:1079px) {
	#coaching_style .point_list {
		font-size: 1.2em;
	}
	#leadership_discipline .point_list {
		font-size: 1.2em;
	}
	.leadership p {
		font-size: 1.2em;
	}
}


/*------------------------------------------------------------------------------*/
/* VISION ビジョン */
/*------------------------------------------------------------------------------*/
#vision_top_read p {
	text-align: center;
	font-size: 1.8em;
	background: #707070;
	padding: 1em;
}

.urachu_vision_4 {
	position: relative;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 15px;
}

.vision_card {
	margin: 0px auto 3em;
    padding: 2em;
    border: 1px solid #D60016;
}
.vision_card ul {
	font-size: 1.8em;
}

@media screen and (max-width:1142px) {
	.vision_card ul {
		font-size: 1.5em;
	}
}
@media screen and (max-width:999px) {
	#vision_top_read p {
		font-size: 1.4em;
	}
	.vision_card ul {
		font-size: 1.2em;
	}
}
@media screen and (max-width:839px) {
	#vision_top_read p {
		font-size: 1.2em;
	}
	.urachu_vision_4 {
		grid-template-columns: repeat(1, 1fr);
	}
}
@media screen and (max-width:679px) {
	#vision_top_read p {
		text-align: left;
	}
	.vision_card {
		padding: 2em 1em;
	}
}
@media screen and (max-width:402px) {
	.vision_card ul {
		font-size: 1.0em;
	}
}


/*------------------------------------------------------------------------------*/
/* GROUND 設備紹介 */
/*------------------------------------------------------------------------------*/
.equip_4 {
	position: relative;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
}

.equip_4 .post_card {
	margin-bottom: 30px;
}

.equip_4 .post_title h3 {
    position: relative;
	font-size: 1.5em;
}
.equip_4 .post_title h3::before {
	position: absolute;
	left: 0px;
	bottom: 0px;
	width: 100%;
	height: 8px;
	transform: skew(-45deg);
	background-image: repeating-linear-gradient(90deg, transparent 0 4px, #D60016 4px 8px);
	content: '';
	z-index: -1;
}

.equip_2 {
	position: relative;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 15px;
}

.equip_2 .post_card {
	margin-bottom: 30px;
}

.equip_2 .post_title h3 {
    position: relative;
	font-size: 1.5em;
}
.equip_2 .post_title h3::before {
	position: absolute;
	left: 0px;
	bottom: 0px;
	width: 100%;
	height: 8px;
	transform: skew(-45deg);
	background-image: repeating-linear-gradient(90deg, transparent 0 4px, #D60016 4px 8px);
	content: '';
	z-index: -1;
}

.map_link {
	font-size: 1.5em;
	margin-bottom: 20px;
}
.category_icon_span {
	font-size: 0.9em;
	color: #fff;
	text-decoration: none;
	padding: 0em 0.5em 0.1em;
	margin-right: 0.5em;
	background: #000;
	border: 1px solid #000;
	border-radius: 2px;
	transition: all 0.3s;
}

@media screen and (max-width:1079px) {
	.equip_4 {
		grid-template-columns: repeat(3, 1fr);
	}
}
@media screen and (max-width:839px) {
	.equip_4 {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width:599px) {
	.equip_4 {
		grid-template-columns: repeat(1, 1fr);
	}
	.equip_2 {
		grid-template-columns: repeat(1, 1fr);
	}
}


/*------------------------------------------------------------------------------*/
/* JOIN 選手募集 */
/*------------------------------------------------------------------------------*/
.membership_card {
	padding: 0px 15px 30px;
	margin-bottom: 20px;
}
.membership_card h4 {
	color: #fff;
	padding-bottom: 0.3em;
	border-bottom: 1px dotted;
}

#join_welcome p {
	font-size: 1.8em;
	background: #707070;
	padding: 1em;
}
@media screen and (max-width:919px) {
	#join_welcome p {
		font-size: 1.6em;
	}
}
@media screen and (max-width:599px) {
	#join_welcome p {
		font-size: 1.2em;
	}
}

.event_table {
	max-width: 300px;
}
.event_table th {
	font-weight: 500;
	text-align: left;
}
.event_table td {
	font-weight: 500;
	text-align: right;
}



/*------------------------------------------------------------------------------*/
/* GALLERY ギャラリー アーカイブ */
/*------------------------------------------------------------------------------*/
/*--- アンカーリンクリスト ---*/
.anchor_navi_3 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 15px;
	padding: 0px 15px;
	text-align: center;
}
.anchor_navi_3 li {
	list-style: none;
}
.anchor_navi_3 li a {
	display: block;
	font-weight: bold;
	text-decoration: none;
	color: #000;
	padding: 4px 0px;
	background-color: #fff;
}
.anchor_navi_3 li a:hover {
	display: block;
	font-weight: bold;
	text-decoration: none;
	color: #fff;
	padding: 4px 0px;
	background-color: #000;
}
.anchor_navi_3 .current {
	color: #fff;
	background-color: #D60016;
}


/*--- 投稿一覧 ---*/
.gallery_4 {
	max-width: 1680px;
	position: relative;
	padding: 15px;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
}

.gallery_4 .post_card {
	margin-bottom: 20px;
}

.gallery_4 .post_title h3 {
	color: #000;
}


@media screen and (max-width:1179px) {
	.gallery_4 {
		grid-template-columns: repeat(3, 1fr);
	}
}
@media screen and (max-width:969px) {
	.gallery_4 {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width:619px) {
	.gallery_4 {
		grid-template-columns: repeat(1, 1fr);
	}
}


/*------------------------------------------------------------------------------*/
/* GALLERY ギャラリー シングルページ */
/*------------------------------------------------------------------------------*/
.gallery_list {
	margin: 0px auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr;
	gap: 10px;
}

.gallery_sub_img_4 {
	position: relative;
	margin: 0px auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
}
.gallery_sub_img_4 img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	margin-bottom: 0px!important;
}

.post_caption {
	min-height: 100px;
	padding: 8px;
}

/*---LihgtBox---*/
.lightbox .lb-image {
	border-radius: 0px!important;
	border: 0px solid #fff!important;
}


@media screen and (max-width:991px) {
	.gallery_sub_img_4 {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width:499px) {
	.gallery_sub_img_4 {
		grid-template-columns: repeat(1, 1fr);
	}
}


/*------------------------------------------------------------------------------*/
/* GALLERY ギャラリー トップページループ */
/*------------------------------------------------------------------------------*/
/*--- SlickSlider（制御はヘッダjsに記載） ---*/
.slick-dots {
	position: inherit;
	top: 15px;
}
.slick-dotted.slick-slider {
	margin-bottom: 30px;
}

.slider_5 .post_card {
	margin: 0px 8px;
}
.slider_5 .post_img {
	margin: 0px;
}
.slider_5 .post_card h3 {
	font-size: 14px;
	font-weight: 500;
	color: #000;
}

@media screen and (max-width: 599px) {
	.slider_5 .post_card {
		margin: 0px;
	}
}


/*------------------------------------------------------------------------------*/
/* MESSAGE 先輩のメッセージ */
/*------------------------------------------------------------------------------*/
.movie_2 {
	display: flex;
}

.massage_movie {
	flex-basis: 30%;
}

.massage_contents {
	flex-basis: 70%;
	position: relative;
	padding: 20px 35px;
}

.seniors_name {
	border-bottom: 1px solid #D60016;
	margin-bottom: 20px;
}
.seniors_name p {
	font-size: 2.0em;
	font-weight: bold;
	line-height: 1.5em;
	padding-bottom: 2px;
}
.seniors_name span {
	font-size: 0.8em;
	font-weight: 500;
	margin-left: 0.5em;
}

.seniors_data {
	background: #707070;
	padding: 10px;
	margin-bottom: 30px;
}
.seniors_data ul {
	margin-bottom: 0px;
}

@media screen and (max-width:1110px) {
	.movie_2 {
		display: block;
	}
	.massage_movie {
		flex-basis: 100%;
	}
	.massage_contents {
		flex-basis: 100%;
	}
}
@media screen and (max-width:599px) {
	.massage_contents {
		flex-basis: 70%;
		position: relative;
		padding: 20px 15px;
	}
}


/*------------------------------------------------------------------------------*/
/* CONTACT お問い合わせ */
/*------------------------------------------------------------------------------*/
#contact_top_read {
	padding-bottom: 0px;
}
.contact_call_link {
	font-size: 2.5em;
	font-weight: 900;
	color: #D60016;
}


/*------------------------------------------------------------------------------*/
/* GoogleMap */
/*------------------------------------------------------------------------------*/
.google_map {
	margin-top: 20px;
	position: relative;
	padding-bottom: 30%;
	height: 0;
	overflow: hidden;
}

.google_map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}
@media screen and (max-width:599px) {
	.google_map {
		position: relative;
		padding-bottom: 80%;
	}
}
@media screen and (max-width:1140px) {
	.google_map {
		padding-bottom: 90%;
	}
}
@media screen and (max-width:1449px) {
	.google_map {
		flex-basis: 60%;
		padding-bottom: 50%;
	}

	#access {
		flex-basis: 40%;
		display: grid;
		place-items: center;
		background: #D60016;
		padding: 30px 20px;
	}
}
@media screen and (max-width: 939px) {
	.access_outer {
		flex-wrap: wrap;
	}
	.google_map {
		flex-basis: 100%;
	}
	#access {
		flex-basis: 100%;
	}
}


/*------------------------------------------------------------------------------*/
/* 投稿　シングルページ */
/*------------------------------------------------------------------------------*/
#single_page .contents_box {
	margin: 0px auto 30px;
	max-width: none;
}

#single_page img {
	margin: 0px auto 15px;
	width: 100%;
}
#single_page p {
	margin-bottom: 1.0em;
}

.next_prev {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 15px;
	padding: 0px 15px 60px;
	margin: 0px auto;
}

.next_button_outer, .prev_button_outer {
	display: contents;
	width: 100%;
}

.next_button, .prev_button {
	display: inline-block;
	width: 100%;
	color: #fff;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 10px;
	background: #000;
	transition: all 0.5s;
}
.next_button:hover, .prev_button:hover {
	color: #000000;
	background-color: #fff;
	text-decoration: none;
	transition: all 0.5s;
}

.entry-meta {
	border-bottom: 1px dotted #fff;
	font-size: 1em;
	margin-bottom: 30px;
	padding-bottom: 10px;
}

.entry-meta .news_date {
	font-size: 1.5em;
}

.entry-meta .news_title {
	padding: 0px;
}
.news_title h3 {
	margin: 0px;
}

.entry-meta .sub_title_h {
	padding: 0px 10px 10px 10px;
}

.post_icon {
	display: inline-flex;
}

.post_icon .news_cate span a {
	top: 4px;
}


@media screen and (max-width: 599px) {
	.entry-meta .news_date {
		padding-right: 15px;
	}

	.post_icon .news_cate span a {
		top: -3px;
	}

	.entry-meta .sub_title_h {
		font-size: 1.5em;
	}
}


/*------------------------------------------------------------------------------*/
/* 投稿　アーカイブページ */
/*------------------------------------------------------------------------------*/
/*---カードアーカイブ3カラム折り返し配置---*/
.post_outer {
	display: grid;
	grid-template-columns: repeat(auto-fill,30%);
	grid-template-rows: auto;
	grid-gap: 15px;
	justify-content: center;
	padding: 0px 0px 60px;
}

.post_img {
	margin-bottom: 10px;
}
.post_img img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}
.post_img video {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.post_excerpt p {
	font-size: 14px;
}

/*---カードアーカイブ縦1カラム配置---*/
.post_sideby_card {
	display: flex;
	margin-bottom: 30px;
	background: #333;
}

.img_post_sideby_card {
	text-align: center;
	flex-basis: 30%;
	display: grid;
	place-items: center;
}

.contents_post_sideby_card {
	flex-basis: 70%;
	padding: 0px 15px;
}

/*---カードアーカイブ縦1カラム配置画像無し---*/
.post_noimage {
	background: #eee;
	padding: 15px;
	border-radius: 4px;
	margin-bottom: 20px;
}

@media screen and (max-width: 919px) {
	.post_outer {
		grid-template-columns: repeat(auto-fill,45%);
	}
}
@media screen and (max-width: 699px) {
	.post_outer {
		grid-template-columns: repeat(auto-fill,100%);
	}
	.img_post_sideby_card {
		text-align: center;
		flex-basis: 40%;
		display: grid;
		place-items: center;
	}
	.contents_post_sideby_card {
		flex-basis: 60%;
	}
}
@media screen and (max-width: 599px) {
	.post_sideby_card {
		display: block;
	}
	.contents_post_sideby_card {
		padding: 0px 0px 30px 0px;
	}
}

.archive_box {
	background: #eee;
	padding: 15px;
	border-radius: 8px;
}

.post_info {
	display: inline-flex;
	margin-bottom: 0.4em;
}

.post_date {
	font-size: 1.2em;
	margin-right: 0.5em;
}

.post_title h3 {
	font-size: 1.2em;
	text-align: left;
}

.category_icon a {
	font-size: 0.9em;
	color: #fff;
	text-decoration: none;
	padding: 0em 0.5em 0.1em;
	margin-right: 0.5em;
	background: #000;
	border: 1px solid #000;
	border-radius: 2px;
	transition: all 0.3s;
}
.category_icon a:hover {
	color: #fff;
	background: #D60016;
	border: 1px solid #D60016;
}

.category_icon p {
	display: inline;
	font-size: 0.9em;
	color: #fff;
	text-decoration: none;
	padding: 0em 0.5em 0.1em;
	margin-right: 0.5em;
	background: #000;
	border: 1px solid #000;
	border-radius: 2px;
	transition: all 0.3s;
}

/*.category_icon span {
	font-size: 0.9em;
	color: #fff;
	text-decoration: none;
	padding: 0em 1.0em 0.1em;
	margin-right: 0.5em;
	background: #000;
	border: 1px solid #000;
	border-radius: 2px;
	transition: all 0.3s;
}*/

.schedule_4 .category_icon span {
	display: block;
	width: 72px;
	text-align: center;
	font-size: 0.9em;
	color: #000;
	text-decoration: none;
	padding: 0em 1.0em 0.1em;
	margin-right: 0.5em;
	background: #ccc;
	border: 1px solid #ccc;
	border-radius: 2px;
	transition: all 0.3s;
}

.sub_category_icon span {
	display: block;
	width: 72px;
	text-align: center;
	font-size: 0.9em;
	color: #000;
	text-decoration: none;
	padding: 0em 1.0em 0.1em;
	margin-right: 0.5em;
	background: #ccc;
	border: 1px solid #ccc;
	border-radius: 2px;
	transition: all 0.3s;
}

.term_title_h {
	color: #D60016;
	font-weight: 300;
	font-size: 2.4em;
}

@media screen and (max-width: 699px) {
	.term_title_h {
		font-size: 1.8em;
	}
}
@media screen and (max-width: 599px) {
	.term_title_h {
		font-size: 1.2em;
	}
}



.contents_card-new{
	width: 100%;
	background: #333;
	position: absolute;
  left: -45px;
  bottom: 60px;
  margin-bottom: 0px;
}

.w-30 img{
	max-width: 30%;
}


.w-40 img{
	max-width: 40%;
}

.w-50 img{
	max-width: 50%;
}

.w-60 img{
	max-width: 60%;
}

.w-100 img{
	max-width: 100%;
}

.w-120 img{
	max-width: 120%;
}

.pd-50{
	padding-bottom: 50px;
}

.pd-70{
	padding-bottom: 70px;
}

@media screen and (max-width: 1439px) {
	.contents_card-new{
		position: static;
	}

.w-40 img{
	max-width: 30%;
}

.w-60 img{
	max-width: 40%;
}

.w-100 img{
	max-width: 50%;
}

.w-120 img{
	max-width: 50%;
}

}




/* ===== タイトル歴専用（スマホ用調整） ===== */
@media screen and (max-width: 600px) {
  .title_table,
  .title_table th,
  .title_table td {
    font-size: 10px !important;
    line-height: 1.2 !important;
  }
  .title_table th,
  .title_table td {
    padding: 2px !important;
    white-space: nowrap !important;
  }

  /* はみ出し時に横スクロール */
  .title_table {
    display: block;
    overflow-x: auto;
  }
}





.membership_card ul ul {
  list-style-type: none; /* サブリストの黒丸を消す */
  padding-left: 1em;    /* インデントは少し残す */
}

.membership_card ul ul li {
  margin: 0.2em 0;      /* 行間を調整 */
}





#membership_10 .event_table {
  font-size: 16px;   /* 好きなサイズに統一 */
  line-height: 1.8;  /* 行間も揃える */
}






/* スマホ表示で、太字以外の項目を右に寄せる */
@media (max-width: 640px) {
  /* 見出し（太字）はそのまま */
  .footer_link a.bold_link {
    font-weight: 700;
  }
  /* 太字じゃないリンクだけインデント（約2文字ぶん） */
  .footer_link a:not(.bold_link) {
    display: block;       /* 余白を効かせるためブロック化 */
    padding-left: 2em;    /* ← “2マスくらい” の感覚。1.5em～2emで微調整可 */
  }
  /* 行頭の揃えが気になる場合は li に余白をかけてもOK
  .footer_link li:not(:first-child) { margin-left: 2em; }
  */
}



@media screen and (min-width: 768px) {
  /* TEAM INFOの中央寄せ（中身は左揃え） */
  #team_info h2.anton_h:nth-of-type(3) + .mb60 {
    display: inline-block;
    text-align: left;
  }
  #team_info h2.anton_h:nth-of-type(3) {
    text-align: center;
  }

  /* スタッフ紹介の中央寄せ（中身は左揃え） */
  #team_info h2.anton_h:nth-of-type(4) + .mb60 {
    display: inline-block;
    text-align: left;
  }
  #team_info h2.anton_h:nth-of-type(4) {
    text-align: center;
  }

  /* 共通：親を中央寄せ */
  #team_info .align_center {
    text-align: center;
  }
}




@media screen and (min-width: 768px) {
  /* TEAM INFOの本文とスタッフ紹介の間隔を詰める */
  #team_info h2.anton_h:nth-of-type(3) + .mb60 {
    margin-bottom: 16px; /* ←デフォルト60pxが効いているので小さくする */
  }

  /* スタッフ紹介 見出しの上の余白も軽く詰める */
  #team_info h2.anton_h:nth-of-type(4) {
    margin-top: 8px; /* 必要なら0にしてもOK */
  }
}




/* ===== 202510 MVビジュアル上バナー設置 ===== */

#main_visual {
  position: relative;
}

#main_visual .overlay-banner {
  position: absolute;
  top: 45px;
  right: 45px;
  z-index: 2;
  display: inline-block;
}

#main_visual .overlay-banner img {
  width: 250px;
  transition: transform 0.3s ease;
}

/* PC用：hover時に拡大 */
@media (min-width: 768px) {
  #main_visual .overlay-banner img:hover {
    transform: scale(1.1);
  }
}

@media screen and (max-width: 1439px) {
#main_visual .overlay-banner img {
  width: 16vw;
}

}


/* スマホ用：hover効果なし */
@media (max-width: 767px) {

#main_visual_sp {
  position: relative;
}

#main_visual_sp .overlay-banner {
  position: absolute;
  top: 5vw;
  right: 3vw;
  z-index: 2;
  display: inline-block;
}

#main_visual_sp .overlay-banner img {
  width: 36.5vw;
}



}
