@charset "UTF-8";
/*---------------------------------------------------------
Theme Name: mathys25_ot
Author URI: 
Version: 1.0
Description: 
---------------------------------------------------------*/


.st-main, 
article,
.st-.st-aside,
header,
canvas,
details,
figcaption,
figure, footer,
nav,
section,
summary {
	display: block;
}

ul{ list-style-type:none; margin:0; padding:0; }
li{ margin:0; } 
p{ text-align:left; }

@keyframes fade-in {
  0% {
	display: none;
	opacity: 0;
  }
  1% {
	display: block;
	opacity: 0;
  }
  100% {
	display: block;
	opacity: 1;
  }
}
@-moz-keyframes fade-in {
  0% {
	display: none;
	opacity: 0;
  }
  1% {
	display: block;
	opacity: 0;
  }
  100% {
	display: block;
	opacity: 1;
  }
}
@-webkit-keyframes fade-in {
  0% {
	display: none;
	opacity: 0;
  }
  1% {
	display: block;
	opacity: 0;
  }
  100% {
	display: block;
	opacity: 1;
  }
}

@-webkit-keyframes dropdown {
  100% {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1
  }
}

@keyframes dropdown {
  100% {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1
  }
}

.fadein {
  opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

:root{
	--mtblack: #232120;
	--mtblackgray: #484644;
	--mtgray: #bdbab6;
	--mtlightgray: #e1ded9;
	--mtwhitegray: #f9f7f5;
	--mtbluegray: #6b8296;
	--mtbluelightgray: #e7ebf0;
	--mtdarkblue: #335c82;
}

html{
	height: 100%;
	scroll-behavior: smooth;
	line-height: 2.5em;
}

body{
	height: 100%;
	min-width: 320px;
	word-wrap: break-word;
	background: var(--mtwhitegray);
	color: var(--mtblack);
	font-size: 0.95em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 400;
	font-style: normal;
}


.pcnon{
	display: block;
}
.spnon{
	display: none;
}

@media screen and (min-width: 990px) {
	.pcnon{
		display: none;
	}
	.spnon{
		display: block;
	}
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}
a[href*="tel:"] {
	text-decoration: none;
}


/* リンクの色 */
a{
	color: #333333;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}

/* リンクにマウスオーバーした時の色 */
a:hover{
	color: #53697f;
	text-decoration: underline;
}

.arrow-button {
	margin-top: 20px;
	margin-bottom: 20px;
	display: inline-flex;
	align-items: center;
	background-color: var(--mtblack);
	border-radius: 30px;
	color: white;
	padding: 18px 40px;
	border: none;
	font-size: 16px;
	cursor: pointer;
	text-decoration: none;
	position: relative;
	transition: background-color 0.3s ease;
}
.arrow-button .arrow {
	display: inline-block;
	margin-left: 10px;
	transition: transform 0.3s ease, width 0.3s ease;
	white-space: nowrap;
}
.arrow-button .arrow::after {
	content: "→";
	display: inline-block;
	transition: transform 0.3s ease;
}
.arrow-button:hover{
	background: var(--mtdarkblue);
}
.arrow-button:hover .arrow {
	transform: scaleX(2); /* 矢印を横に伸ばす感じ */
}
.arrow-button:hover .arrow::after {
	transform: translateX(5px); /* ニュッと動く感じ */
}


/* clearfix */
.clearfix{
	zoom: 1;
}

.clearfix:after{
	content: "";
	display: block;
	clear: both;
}

/*画像 */
img.alignright {
	display: block;
	margin:0 auto 10px;
}
img.alignleft {
	display: block;
	margin:0 auto 10px;
}
img.aligncenter {
	display: block;
	margin:0 auto 10px;
}
img.float-left {
	float: left;
}
img.float-right {
	float: right;
}
.wp-caption {
	text-align: center;
}
.aligncenter {
	clear: both;
	display: block;
	margin:0 auto 10px;
}
.txt-right{
	text-align: right;
}
.txt-left{
	text-align: left;
}


/* youtube */
.youtube{
	text-align: center;
}
.youtube p{
	text-align: center;
	margin-top: 0;
	font-size: 0.9em;
}
@media screen and (max-width: 599px) {
	.youtube {
		position: relative;
		width: 100%;
		padding-top: 56.25%;
	}
	.youtube iframe {
		position: absolute;
		top: 0;
		right: 0;
		width: 100%;
		height: 100%;
	}
}


/* 画像リンクのマウスオーバーに透かし */
a:hover img{
	-moz-opacity: 0.8;
	opacity: 0.8;
}

#wrapper{
	margin: 0 auto;
	overflow:hidden;
	text-align: center;
}

.wid1200{
	margin: 0 auto;
	width: 100%;
	max-width: 1230px;
	padding: 0 15px;
	box-sizing: border-box;
}
.wid1500{
	margin: 0 auto;
	width: 100%;
	max-width: 1530px;
	padding: 0 15px;
	box-sizing: border-box;
}


.mt20{ margin-top: 20px; }
.mt50{ margin-top: 50px; }
.mt70{ margin-top: 70px; }
.mt100{ margin-top: 100px; }
.mt200{ margin-top: 200px; }
.mb20{ margin-bottom: 20px; }
.mb50{ margin-bottom: 50px; }
.fs09{ font-size:0.9em; line-height: 1.4em; }
.fs12{ font-size:1.2em; }
.fs15{ font-size:1.5em; }
.fs20{ font-size:2.0em; }
.fcr{ color: #ff0000; }
.fcc{ color: #7d2c00; }
.fcgreen{ color: #729220; }
.pgt50{ padding-top: 50px; }



ul.wp-block-list{
	margin-top: -10px;
	padding-left: 30px;
	list-style-type: disc;
}
ul.wp-block-list li{
	line-height: 1.4em;
	margin-bottom: 8px;
}

.alignfull{
	width:100vw;
	margin-right:calc(50% - 50vw);
	margin-left:calc(50% - 50vw);
}


/* ギャラリー調整 */
.wp-block-gallery.has-nested-images figure.wp-block-image {
	flex-grow: 0;
}
@media screen and (max-width:600px) {
	.wp-block-gallery {
		display: block !important;
	}
	.wp-block-gallery .wp-block-image {
		width: 100% !important;
		margin-bottom: 10px !important; /* 画像の間に余白を追加 */
	}
}



/*---------------------------------------------------------*/
/* ヘッダー */
/*---------------------------------------------------------*/

header{
	text-align: center;
}
#headbox{
	margin:0;
	text-align: center;
	top: 0;
	width: 100%;
	background: none !important;
	z-index: 5;
	position:fixed;
}
.logo{
	top: 30px;
	left: 30px;
	position: fixed;
}

#header-fullscreen{
	position: relative;
	width: 100vw;
	height: 100vh;
	background-image: url('images/index/top-pc.jpg');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.header-txt{
	position: absolute;
	text-align: left;
	right: 50px;
	bottom: 50px;
	font-size: 2.5em;
	color: #fff;
}
.hbutton , .hbutton2{
	display: none;
}
@media (max-width: 600px) {
	#header-fullscreen{
		background-image: url('images/index/top-sp.jpg');
	}
	.header-txt{
		right: auto;
		left: 20px;
		bottom: 50px;
		font-size: 1.5em;
	}
}


/*--------------------------------
アコーディオンメニュー
---------------------------------*/

.menu-navigation-container {
	overflow: hidden;
}

nav li a:hover {
	text-decoration: underline;
}

#s-navi ul.sub-menu {
	display:block;
}
#s-navi ul.sub-menu li::before {
	content: "- ";
	color: #fff;
}

.trigger .fa:not(.fa-bars) {
	font-size:14px;
}

/*アコーディオンメニューボタン*/

#s-navi:after {
	content: "";
	display: block;
	clear: both;
}
.acordion_tree ul.menu{
	float: none !important;
}
.acordion_tree ul.menu li {
	float: none !important;
	font-size: 16px;
	padding: 4px 10px;
	list-style:none;
}
.acordion_tree ul.menu li{
	min-width: 1em;
	color: #fff;
}
.acordion_tree ul.menu li a{
	text-decoration: none;
	color: #fff;
	font-size: 16px;
}
.acordion_tree ul.menu li a:hover{
	text-decoration: underline;
}
.menu-close {
	padding:10px;
}

/*   ハンバーガーボタン3本線   */
button {
	display: inline;
	background: none;
	border: 1px solid #fff;
	border-radius: 20px;
	padding: 0 20px;
	width: 80px;
	color: #fff;
	letter-spacing: 0.1em;
	cursor: pointer;
	top: 50px;
	right: 20px;
	z-index: 100;
	text-align: center;
	outline: none;
	position:fixed;
}
/*   ハンバーガーボタン3本線   */
button span.bar {
	display: block;
	height: 1px;
	background-color:#fff;
	margin: 10px 0;
	transition: all 0.2s;
	transform-origin: 0 0;
}
/*  メニューアクティブ時  */
button.active span.bar {
	width: 49px;
}
button.active .bar1 {
	transform: rotate(30deg);
}
button.active .bar2 {
	opacity: 0;
}
button.active .bar3 {
	transform: rotate(-30deg);
}
/* ナビ */
nav#s-navi {
	width: 400px;
	height: 100%;
	transition: all 0.2s;
	transform: translate(401px);
	position: fixed;
	top: 0;
	right: 0;
	z-index: 90;
	background: #232120;
	padding-top: 100px;
	padding-left: 50px;
	padding-right: 50px;
	box-sizing: border-box;
	text-align: left;
}
nav#s-navi.open {
	transform: translate(0); 
}
nav#s-navi ul{
	margin-top: 10px;
	margin-left: 15px;
}
nav#s-navi ul li{
	margin-bottom: 10px;
}

/*   ハンバーガートップ以外   */
body:not(.home) button {
	display: inline;
	background: none;
	border: 1px solid var(--mtblack);
	border-radius: 20px;
	padding: 0 20px;
	width: 80px;
	color: #fff;
	letter-spacing: 0.1em;
	cursor: pointer;
	top: 50px;
	right: 20px;
	z-index: 100;
	text-align: center;
	outline: none;
	position:fixed;
}
body:not(.home) button span.bar {
	display: block;
	height: 1px;
	background-color: var(--mtblack);
	margin: 10px 0;
	transition: all 0.2s;
	transform-origin: 0 0;
}
body:not(.home) button.active {
	background: none;
	border: 1px solid #fff;
	color: #fff;
}
body:not(.home) button.active span.bar {
	background-color:#fff;
}

.gbutton{
	display: block;
	background: #fff;
	text-align: center;
	color: var(--mtblack);
	padding: 15px 20px;
	border-radius: 30px;
	width: 190px;
	text-decoration: none;
}
.gbutton:hover{
	color: #fff;
	text-decoration: none;
	background: var(--mtblack);
}		
.gbutton img{
	filter: invert(100%);
	transition: all 1s;
}
.gbutton:hover img{
	filter: none;
}

.gsns{
	width: 200px;
	margin-top: 30px;
	padding-top: 10px;
	border-top: 1px solid var(--mtblackgray);
	color: #fff;
	display: flex;
	justify-content: space-around;
}

/*---------------------------------------------------------*/
/* フッター */
/*---------------------------------------------------------*/
footer{
	padding-top:30px;
	padding-bottom: 80px;
	font-size: 0.9em;
	color: #fff;
	background: var(--mtbluegray);
}
#footbox{
	width: 100%;
	text-align: left;
}

.foot-logo{
	text-align: center;
}

#menu-footer ul{
	display: flex; /* 親カテゴリを横並びに */
  gap: 40px; /* 親カテゴリ同士の間隔 */
  list-style: none;
  padding: 0;
  margin: 0;
  color: #fff;
}
#menu-footer > .menu-item {
  position: relative;
  text-align: center;
}
#menu-footer .sub-menu {
  list-style: none;
  padding: 0;
  margin-top: 10px;
  display: block; /* 常に表示するなら block。hoverで表示する場合は none に */
}
#menu-footer .sub-menu .menu-item {
  margin-top: 5px;
}
#menu-footer .sub-menu .menu-item a::before {
  content: "- ";
}
#menu-footer .menu-item a{
	text-decoration: none;
	color: #fff;
	transition: all  1s ease;
}
#menu-footer .menu-item a:hover{
	text-decoration: underline;
}

@media screen and (max-width: 768px) {
	footer{
		font-size: 1em;
	}
  #menu-footer ul {
    flex-direction: column; /* 横から縦に！ */
    gap: 20px;
  }
  #menu-footer > li.menu-item {
    align-items: flex-start; /* 左寄せを維持 */
  }
}



#footer-flex{
	display: flex;
	justify-content: center;
	margin: 20px 0;
	width: 100%;
	gap: 20px;
	justify-content: space-around;
	flex-direction: column;
}
.footer-fbox{
	width: 100%;
	text-align: center;
}
.formlink {
	margin: 20px auto 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	text-decoration: none;
	font-size: 1.2em;
	border-radius: 50px;
	width: auto;
	height: 60px;
	border: 1px solid #fff;
	position: relative;
	transition: 0.3s;
	background-color: #fff;
	color: var(--mtdarkblue);
}
.formlink:hover{
	background: var(--mtbluegray);
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all  0.5s ease;
	color: #fff;
	text-decoration: none;
}

.fsns{
	width: 100px;
	margin-top: 20px;
	padding-top: 20px;
	color: #fff;
	display: flex;
	justify-content: space-around;
}

.footadr{
	border-top: 1px solid #a8abae;
	margin-top: 30px;
	padding-top: 20px;
	line-height: 2em;
}
.copyright{
	margin-top: 20px;
	text-align: center;
}

#page_top{
	width: 50px;
	height: 50px;
	position: fixed;
	right: 30px;
	bottom: 70px;
	background: #838383;
	opacity: 0.6;
	border-radius: 15%;
	z-index: 1000;
}
#page_top a{
	position: relative;
	display: block;
	width: 50px;
	height: 50px;
	text-decoration: none;
}
#page_top a::before{
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f062';
	font-size: 25px;
	color: #fff;
	position: absolute;
	width: 25px;
	height: 25px;
	top: 0;
	bottom: 10px;
	right: 0;
	left: 0;
	margin: auto;
	text-align: center;
}



/*---------------------------------------------------------*/
/* フロントページ */
/*---------------------------------------------------------*/

h2.catch{
	font-size: 2em;
	color: var(--mtdarkblue);
	margin-top: 50px;
	margin-bottom: 25px;
}
h2.catch span{
	font-size: 0.4em;
}

.front-panel {
  position: relative;
	padding: 20px 0;
	text-align: center;
  z-index: 1;
	background: var(--mtwhitegray);
}


.marquee {
	width: 100%;
	overflow: hidden;
	white-space: nowrap;
	box-sizing: border-box;
}
.rollttl{
	color: #f3f1ee;
	font-size: 7em;
	display: inline-block;
	padding-left: 100%;
	animation: marquee 60s linear infinite;
}
@keyframes marquee {
	from {
		transform: translateX(0%);
	}
	to {
		transform: translateX(-100%);
	}
}
.rollttl-r{
	color: #f3f1ee;
	font-size: 7em;
	display: inline-block;
	padding-left: 100%;
	animation: marquee-r 60s linear infinite;
}
@keyframes marquee-r {
	from {
		transform: translateX(-100%);
	}
	to {
		transform: translateX(0%);
	}
}

.spe-flex{
	width: 100%;
	max-width: 1000px;
	margin: 10px auto;
	display: flex;
}
.spe-left{
	padding: 50px;
	width: 50%;
}
.spe-right{
	padding: 50px;
	width: 50%;
}
.martxt{
	margin-top: 80px;
	font-size: 1.2em;
}
@media (max-width: 768px) {
	.rollttl, .rollttl-r{
		font-size: 3em;
	}
	.spe-flex {
		flex-direction: column-reverse; /* ← 順序を逆に！ */
		margin: 0px auto;
	}
	.spe-left, .spe-right {
		width: 100%;
	}
	.spe-left img{
		width: 100%;
		height: auto;
	}
	.martxt{
		margin-top: 40px;
		font-size: 1em;
	}
}



/* about */
#section2{
	position: relative;
	background: var(--mtlightgray);
	overflow: hidden;
	border-radius: 200px 200px 0 0;
}
#section2::before{
	content: '';
	position: absolute;
	bottom: 0;
	right: 0;
	width: 50%;
	height: 100%;
	background-image: url('images/index/about.jpg');
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-position: bottom center;
}
.sec2{
	width: 50%;
	text-align:left;
	padding: 100px;
	box-sizing: border-box;
}
.ab-img{
	display: none;
	margin-top: 50px;
	margin-bottom: -20px;
}
.ab-img img{
	width: 100%;
}

@media (max-width: 1100px) {
	#section2{
		border-radius: 100px 100px 0 0;
	}
	#section2::before{
		contents: none;
		background: none;
	}
	.sec2{
		width: 100%;
		padding: 50px;
	}
	.ab-img{
		display: block;
	}
}



/* Schedule */
.sche{
	background: var(--mtwhitegray);
}
.sche-flower{
	background-image: url("images/index/flower.png");
	background-repeat: no-repeat;
	background-position: 10% 50px;
}

.swiper-container {
	width: 100%;
	padding: 20px;
}
.swiper-slide {
}
.swiper-button-next,
.swiper-button-prev {
	top: 60% !important;
	color: #fff; /* 矢印の色 */
	background-color: var(--mtgray);
	padding: 15px;
	border-radius: 50% !important;
	width: 50px !important;
	height: 50px !important;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.7;
}
.swiper-button-next::after,
.swiper-button-prev::after {
	font-size: 20px !important;
	color: #fff;
}




/* information */
.information{
	margin: 0;
	width: 100%;
	padding: 20px 15px;
	box-sizing: border-box;
	background: var(--mtbluelightgray);
	text-align: left;
}
.info-table{
	padding: 50px;
}
.info-table table{
	width: 100%;
}
.info-table tr{
	transition:1s all;
}
.info-table tr:hover{
	background: #f2f5f7;
}
.info-row{
	cursor: pointer;
}
.info-table td{
	padding: 20px;
	border-bottom: 1px solid #fff;
}
.info-table tr:last-child td{
	border-bottom: none;
}
.info-table td:nth-child(1) img{
	width: 350px;
}
.info-date{
	font-size: 0.9em;
	color: var(--mtbluegray);
}
.info-ttl{
	font-size: 1.2em;
	margin: 5px auto 10px;
}
.new-txt{
	font-size: 0.9em;
	margin-left: 10px;
	color: #ff0000;
}
@media (max-width: 800px) {
	.info-table{
		padding: 0;
	}
	.info-table table{
		table-layout: fixed;
	}
	.info-table td{
		display: block;
		width: 100%;
	}
	.info-table td img{
		width: 100% !important;
		height: auto;
	}
.info-table  td:first-child{
	border-bottom: none;
}
}


/* Instagram */
.insta-link{
	margin-top: 50px;
	text-align: center;
	color: #fff;
	margin-bottom: 100px;
	font-size: 1.4em;
}
.insta-link a{
	background: var(--mtblack);
	color: #fff;
	text-decoration: none;
	padding: 20px 40px 25px;
	border-radius: 35px;
}
.insta-link a:hover{
	background: var(--mtdarkblue);
}



/*---------------------------------------------------------*/
/* コンテンツページ */
/*---------------------------------------------------------*/

.contents_pg{
	margin-top: 230px;
}

.contents-base{
	margin: 50px 0 0px;
	line-height: 2em;
	text-align: left;
}

h1{
	color: var(--mtdarkblue);
}
h1 span{
	font-size: 0.5em;
}

.contents-base h2{
	clear: both;
	color: var(--mtdarkblue);
	margin-bottom: 25px;
	font-size: 1.5em;
}
.contents-base h3{
	clear: both;
	color: var(--mtdarkblue);
	border-bottom: 1px solid var(--mtdarkblue);
	margin-bottom: 25px;
	padding: 5px 5px 10px 15px;
	font-size: 1.3em;
	text-align: left;
}
.contents-base h4{
	clear: both;
	color: var(--mtdarkblue);
	border-left: 5px double var(--mtdarkblue);
	margin-bottom: 25px;
	padding: 5px 5px 5px 15px;
	text-align: left;
}



/* パンくず */
.breadcrumbs{
	text-align: left;
	margin-top: 10px;
	margin-bottom: 40px;
}
.breadcrumbs a{
	text-decoration: underline;
}

/* youtubeレスポンシブ */
iframe.youtube-16-9 {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}


/* about */
.about table{
	width: auto !important;
	border-collapse: separate;
	border-spacing: 10px;
}
.about tr, .about td{
	border: none;
	padding: 5px 20px;
}
.about td:nth-child(1){
	border: 1px solid var(--mtlightgray);
	text-align: center;
}
@media (max-width: 600px) {
	.about table{
		width: 100% !important;
	}
  .about th, .about td {
    display: inline-block;
    width: 100%;
    float: left;
  }
  .about td{
  	text-align: center;
  }
}


/* クラス */
.lesson{
	display: flex;
	flex-direction: row;
	max-width: 1500px;
	margin: 0 auto;
	padding: 0;
}
#lesson-menu{
	position: relative;
	width: 360px;
	flex-shrink: 0;
}
#lesson-menubox{
	position: sticky;
	top: 260px;
	padding: 20px;
	width: 360px;
}
#lesson-contents{
	flex: 1;
	padding: 20px;
}

/* ===== スマホ用（幅768px以下） ===== */
@media (max-width: 768px) {
	.lesson{
		flex-direction: column;
	}
	#lesson-menu {
		width: 100%;
	}
	#lesson-menubox{
		position: relative !important;
		top: auto !important;
		width: 100%;
	}
}

/* クラステーブル */
.lesson-table{
	width: 100%;
	border-collapse: collapse;
}
.lesson-table tr{
	cursor: pointer;
	vertical-align: top;
	margin-top: 20px;
	background: #eeeae6;
}
.lesson-table tr:hover td{
	background: var(--mtlightgray);
}
.lesson-table td{
	padding: 8px;
	border-top: 3px solid var(--mtwhitegray);
}
.lesson-table td:first-child{
  white-space: nowrap;
}

.price table{
	width: 100%;
	max-width: 800px;
	border-collapse: separate;
	border-spacing: 5px;
	margin: 0 auto;
}
.price td{
	padding: 8px 30px;
	border:none;
	border-bottom: 1px solid #eeeae6;
}
.price td:first-child{
	background: #eeeae6;
  white-space: nowrap;
  text-align: center;
}

@media (max-width: 600px) {
	.price table{
		width: 100% !important;
	}
  .price th, .price td {
    display: inline-block;
    width: 100%;
    float: left;
  }
  .price td{
  	text-align: center;
		border: 1px solid #eeeae6;
  }
}




/* 講師 */
.actor-cari{
	color: var(--mtdarkblue);
	line-height: 2em;
	margin-bottom: 10px;
}


/* カレンダー */
.calen{
	text-align: center;
}


/* タイムテーブル */
.tttable td{
	font-size: 0.9em;
}


/* お問合せ */
.contact-con{
	background: #eeecea;
	padding: 100px 150px;
}
@media (max-width: 768px) {
	.contact-con{
		padding: 50px 30px;
	}
}

.wpcf7-form input, .wpcf7-formt textarea {
  width: 100%;
}
.wpcf7-form input{
	margin-bottom: 20px;
}
.wpcf7-form {
  font-size: 0.95em;
}
.wpcf7-form br {
  margin-bottom: 5px;
}
.wpcf7-form label {
  width: 100%;
}

div.wpcf7-validation-errors {
  margin: 20px 0px;
  padding: 15px;
}

div.wpcf7-response-output {
  margin: 20px 0px;
}

.hissu{
	color: va(--mtdarkblue);
	font-size: 0.9em;
	margin-left: 10px;
}
.submit-wrap{
	margin-top: 50px;
	text-align: center; 
}

.wpcf7-form label {
	width: 100%;
	font-size: 1.2em;
	font-weight: normal;
}

input[type="text"], input[type="email"], input[type="tel"], textarea {
	width: 100%;
	outline:solid 1px #e4e4e4;
}
input[type="submit"] {
	width: 300px;
}

input.brth{
	width: 100px;
}
input.adrs{
	width: 300px;
}

input[type="reset"], input[type="submit"] {
  cursor: pointer;
  background: #314558;
  border: none;
  display: inline-block;
  color: #fff;
  letter-spacing: 1px;
  line-height: 1;
  text-align: center;
  padding: 15px 23px 15px 23px;
  box-shadow: 0 -1px 0 0 rgba(0, 0, 0, 0.1) inset;
  margin: 3px 0;
  text-decoration: none;
}

input[type="reset"]:hover, input[type="submit"]:hover{
	opacity: 0.7;
	background: #41586f;
	color: #fff;
	border: none;
}

input[type="button"]:hover, input[type="button"]:focus, input[type="reset"]:hover,
input[type="reset"]:focus, input[type="submit"]:hover, input[type="submit"]:focus,
button:hover, button:focus {
  cursor: pointer;
}

textarea {
  resize: vertical;
}

select {
  max-width: 100%;
  overflow: auto;
  vertical-align: top;
  outline: none;
  border: 1px solid #c7d3ea;
  padding: 10px;
}

textarea:not(.editor-post-title__input),
input[type="date"],
input[type="datetime"],
input[type="datetime-local"],
input[type="email"],
input[type="month"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="text"],
input[type="time"],
input[type="url"],
input[type="week"] {
  padding: 10px;
  max-width: 100%;
  border: 0px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  background-color: #fff;
  border-bottom: 1px solid #fff;
  box-sizing: border-box;
}
textarea:not(.editor-post-title__input):focus,
input[type="date"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="email"]:focus,
input[type="month"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="text"]:focus,
input[type="time"]:focus,
input[type="url"]:focus,
input[type="week"]:focus {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  border-color: #EBEBEB;
  border-bottom: 1px solid #fff !important;
  background: #fff;
}

button::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input[type="radio"], input[type="checkbox"] {
  margin: 0 ;
}

.wpcf7-spinner {display: block;}
.btn_submit{
	text-align: center;
}

.fmsz100 input[type="text"]{
	width: 100px !important;
}
.fmsz250 input[type="text"]{
	max-width: 250px !important;
}

.wpcf7-list-item input{
	width: 20px;
}
.wpcf7-list-item-label{
	margin-right: 10px;
}

.recap{
	margin-top: 50px;
	text-align: left;
	font-size: 0.8em;
}
.grecaptcha-badge { visibility: hidden; }



/*---------------------------------------------------------*/
/* アーカイブページ */
/*---------------------------------------------------------*/

.archive-base{
	text-align: left;
}

.archive-base h4{
	clear: both;
	color: var(--mtdarkblue);
	border-bottom: 1px solid var(--mtbluegray);
	padding-top: 50px;
	padding-bottom: 10px;
}

.archive-grid{
	margin: 80px auto 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.archive-grid .archive-box{
	text-align: left;
	padding: 12px;
	line-height: 1.2em;
	max-width: 500px;
	margin-bottom: 30px;
}
@media print, screen and (min-width: 960px) {
	.archive-grid .archive-box{
		max-width: 370px;
	}
}

.archive-grid .archive-box a{
	text-decoration: none;
}
.archive-grid .archive-box .arc-img{
	overflow:hidden;
	margin-bottom: 10px;
	text-align: center;
	background: #eeeeee;
	padding: 0;
}
.archive-grid .archive-box .arc-img img{
	width: 100%;
	height: 220px;
	object-fit: cover;
	padding: 0;
	transition:1s all;
}
.archive-grid .archive-box .arc-img img:hover{
	transform:scale(1.2,1.2);
}
.archive-grid .archive-box .arc-ttl{
	margin: 0 0 5px;
}
.archive-grid .archive-box .date{
	font-size: 0.8em;
	color: #4e4e4e;
}
.archive-grid .archive-box .archive-cate{
	padding: 2px 5px;
	font-size: 0.8em;
	color: #fff;
	background: #cccccc;
}
.archive-grid .archive-box hr{
	margin-bottom: 2px;
}

.archive-grid .archiveC-box{
	text-align: center;
	padding: 12px;
	line-height: 1.2em;
	max-width: 500px;
	margin-bottom: 30px;
}
.archive-grid .archiveC-box a{
	text-decoration: none;
}
.archive-grid .archiveC-box .arc-img img{
	width: 100%;
	object-fit: cover;
	padding: 0;
	transition:1s all;
}


/* 講師プロフィール用 */
.actor-grid{
	margin: 80px auto 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.actor-grid .actor-box{
	text-align: left;
	padding: 12px;
	line-height: 1.2em;
	max-width: 500px;
	margin-bottom: 30px;
}

.actor-grid .actor-box a{
	text-decoration: none;
}
.actor-grid .actor-box .actor-img{
	overflow:hidden;
	margin-bottom: 10px;
	text-align: center;
	background: var(--mtblack);;
	padding: 0;
	position: relative;
}
.actor-grid .actor-box .actor-img img{
	width: 100%;
	height: auto;
	object-fit: cover;
	padding: 0;
	transition:1s all;
}
.actor-grid .actor-box .actor-img img:hover{
	transform:scale(1.1,1.1);
}
.actor-arrow{
	position: absolute;
	right: 25px;
	bottom: 20px;
	height: 6px !important;
	width: 26px !important;
}
.actor-name{
	position: absolute;
	left: 25px;
	bottom: 50px;
	font-size: 1.6em;
	color: #fff;
	opacity: 0.6;
}
.actor-ttl{
	position: absolute;
	left: 25px;
	bottom: 20px;
	font-size: 1em;
	color: #fff;
	opacity: 0.6;
}


/* ギャラリーページ用 */
.gallery-grid{
	margin: 80px auto 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	justify-items: center;
	gap: 12px;
}
.gallery-grid .gallery-box{
	text-align: center;
	line-height: 1.2em;
	max-width: 600px;
	overflow: hidden;
	position: relative;
	display: inline-block;
}
.gallery-grid .gallery-box img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition:1s all;
}
.gallery-grid .gallery-box::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border: 10px solid rgba(255,255,255,0.6);
  pointer-events: none;
  opacity: 0;
	transition:1s all;
  box-sizing: border-box;
}
.gallery-grid .gallery-box:hover::after {
  opacity: 1;
}

.gallery-grid .gallery-box .gallery-subbox{
	position: absolute;
	width: 100%;
	padding: 25px 20px;
	bottom: 0px;
	background: rgba(255,255,255,0.7);
	text-align: left;
}
.gallery-subbox .date{
	color: var(--mtdarkblue);
	font-size: 0.9em;
}
.gallery-subbox .ttl{
	margin-top: 10px;
	font-size: 1.2em;
}
.gallery-arrow{
	position: absolute;
	filter: brightness(0);
	bottom: 20px;
	right: 20px;
	height: 6px !important;
	width: 26px !important;
}


nav.navigation{

}
.nav-previous{
	float:left;
}
.nav-next{
	float:right;
}


/*---------------------------------------------------------*/
/* 投稿ページ*/
/*---------------------------------------------------------*/
#main{
	display: flex;
	flex-direction: column;
}

.single-base{
	width: 100%;
	max-width: 1200px;
	text-align: left;
}



/*---------------------------------------------------------*/
/* サイドバー */
/*---------------------------------------------------------*/

#side .st-aside {
	padding: 0;
	text-align: left;
	margin-bottom: 50px;
}
@media print, screen and (min-width: 768px) {
	#main{
		display: flex;
		flex-direction: row;
	}
	#side .st-aside {
		margin-left: 20px;
		margin-top: 0px;
		width: 280px;
		padding: 0px;
	}
}

#side .st-aside h2, #side .st-aside h3, #side .st-aside h4{
	margin-top: 20px;
	padding: 10px 0;
	font-size: 1.2em;
	border-bottom: solid 1px #154e8f;
}

#side .st-aside li{
	list-style-type:none; margin:0; padding:0;
}
#side .st-aside ul li {
	list-style-type: disc;
	margin: 0px;
	padding: 0px;
	margin-left: 25px;
}
#side .st-aside ul li a{
	text-decoration: none;
}



/*media Queries スマートフォンとタブレットサイズ（959px以下）で適応したいCSS - スマホ・タブレット
---------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 959px) {


/*-- ここまで --*/
}

/*media Queries タブレットサイズ（600px～959px）のみで適応したいCSS -タブレットのみ
---------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 600px) and (max-width: 959px) {


/*-- ここまで --*/
}


/*media Queries タブレット（600px）以上で適応したいCSS -タブレット・PC
---------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 600px) {

	img.alignright {
		float: right;
		margin: 10px 0 5px 10px;
	}
	img.alignleft {
		float: left;
		margin: 10px 10px 5px 0;
	}
	img.aligncenter {
		display: block;
		margin: 10px auto 10px;
	}

	.logo{
		width: 300px;
		height: 201px;
	}
	.home .hbutton{
		display: block;
		background: #fff;
		color: var(--mtblack);
		padding: 10px 20px;
		border-radius: 25px;
		top: 50px;
		right: 280px;
		z-index: 10;
		position:fixed;
		text-decoration: none;
	}
	body:not(.home) .hbutton{
		display: block;
		background: var(--mtblack);
		color: #fff;
		padding: 10px 20px;
		border-radius: 25px;
		top: 50px;
		right: 280px;
		z-index: 10;
		position:fixed;
		text-decoration: none;
	}
	.home .hbutton2{
		display: block;
		background: #fff;
		color: var(--mtblack);
		padding: 10px 20px;
		border-radius: 25px;
		top: 50px;
		right: 150px;
		z-index: 10;
		position:fixed;
		text-decoration: none;
	}
	body:not(.home) .hbutton2{
		display: block;
		background: var(--mtblack);
		color: #fff;
		padding: 10px 20px;
		border-radius: 25px;
		top: 50px;
		right: 150px;
		z-index: 10;
		position:fixed;
		text-decoration: none;
	}
	.home .hbutton:hover, .home .hbutton2:hover{
		color: #fff;
		text-decoration: none;
		background: var(--mtblack);
	}		
	body:not(.home) .hbutton:hover, body:not(.home) .hbutton2:hover{
		color: #fff;
		text-decoration: none;
		background: var(--mtdarkblue);
	}
	.home .hbutton img, .home .hbutton2 img{
		filter: invert(100%);
		transition: all 1s;
 	}
	.home .hbutton:hover img, .home .hbutton2:hover img{
		filter: none;
	}
	body:not(.home) .hbutton img, body:not(.home) .hbutton2 img{
		filter: none;
	}
	button{
		right: 60px;
	}
	body:not(.home) button {
		right: 60px;
	}

	.concept{
		font-size: 1.5em;
	}
	h2.catch{
		font-size: 3.5em;
	}
	.contents-base h2{
		font-size: 1.8em;
	}
	.contents-base h3{
		font-size: 1.5em;
	}

	#footer-flex{
		width: 400px;
		flex-direction: row;
	}
	.copyright{
		text-align: right;
	}

	/*-- ここまで --*/
}

/*media Queries PCサイズ（960px）以上で適応したいCSS - PCのみ
---------------------------------------------------------------------------------------------------*/
@media print, screen and (min-width: 960px) {

	#wrapper {
		overflow:visible; /*グローバルメニューの下層リンクを表示する為*/
		padding:0;
		width:100%;
	}
	.foot-logo{
		float: right;
	}


/*-- ここまで --*/
}


