@charset "UTF-8";

/*================================================
 *  CSSリセット
 ================================================*/
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,main,menu,nav.gnav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:normal;}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav.gnav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px dotted #000;margin:1em 0;padding:0}input,select{vertical-align:middle}

/*================================================
 *  共通
 ================================================*/



body {
	font-size: 98%;
	font: 500 15px / 2em "Verdana","Roboto","Droid Sans","游ゴシック","YuGothic","メイリオ", "Meiryo","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","ＭＳ Ｐゴシック",sans-serif;
	line-height: 1.6;
	margin:0;

	

}


img {
	user-drag: none;
	-webkit-user-drag: none;
	-moz-user-select: none;
	pointer-events: none;
	
	/* SPの長押し禁止 */
    -webkit-touch-callout:none;
    -webkit-user-select:none;
    -moz-touch-callout:none;

    user-select:none;
}



/* 仕切り背景：波動画 */
.header {
  position:relative;
  text-align:center;
  background:url("../images/slide01.jpg") no-repeat;
  color:#333;
  background-blend-mode: color-burn;
  background-size: cover;
}

.inner-header {
  height:65vh;
  width:100%;
  margin: 0;
  padding: 0;
}

.flex { /*Flexbox for containers*/
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.waves {
  position:relative;
  width: 100%;
  height:15vh;
  margin-bottom:-7px; /*Fix for safari gap*/
  min-height:100px;
  max-height:150px;
}

.content {
  position:relative;
  height:20vh;
  text-align:center;
  background-color: white;
}

/* Animation */

.parallax > use {
  animation: move-forever 25s cubic-bezier(.55,.5,.45,.5)     infinite;
}
.parallax > use:nth-child(1) {
  animation-delay: -2s;
  animation-duration: 7s;
}
.parallax > use:nth-child(2) {
  animation-delay: -3s;
  animation-duration: 10s;
}
.parallax > use:nth-child(3) {
  animation-delay: -4s;
  animation-duration: 13s;
}
.parallax > use:nth-child(4) {
  animation-delay: -5s;
  animation-duration: 20s;
}
@keyframes move-forever {
  0% {
   transform: translate3d(-90px,0,0);
  }
  100% { 
    transform: translate3d(85px,0,0);
  }
}
/*Shrinking for mobile*/
@media (max-width: 768px) {
  .waves {
    height:40px;
    min-height:40px;
  }
  .content {
    height:30vh;
  }
  h1 {
    font-size:24px;
  }
}




.inner {
	position: relative;
	width: 1024px;
	margin: 0 auto;
}




a {
	color: #043771;
	text-decoration: none;
}
a:hover {
	color: #144d8d;
}


a[target=_blank]:not(.notex)::after {
   margin: 0 0 0 3px;
  font-family: "Font Awesome 5 Free";
  content: '\f35d';
  font-weight: 900;
  width: 16px;
  height: 16px;
  display: inline-block;
  margin-left: 5px;

}





h1 {
	font-size: 28px;
}


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

em {
	font-weight: bold;
}

pre {
	margin:1em 0;
	padding:1em;
}

blockquote {
	margin-bottom: 1em;
	padding: 1em;
	border: 1px dotted #ddd;
	border-left: 5px solid #ddd;
}

ul,ol {
	margin: 0 0 1em 0;
}
ul li {
	
}
ol li {
	list-style: decimal;
}
li {
	margin-left: 2em;
}


table {
	width: 98%;
	margin-bottom: 1em;
	border-collapse: collapse;
	font-size: 97%;
	border-left:none;
	border-right:none;

	
}
th {
	padding: 15px;
	text-align: center;
	vertical-align: middle;
	border-bottom: 1px solid #ddd;
	color:#696969;
	letter-spacing: 1.5px;
	
	
	
}
td {
	padding: 15px;
	text-align: center;
	border-bottom: 1px solid #ddd;
	
}
dl{
  display: flex;
  flex-wrap: wrap;
	 margin: 0 0 10px 0;
}


dt{
  width: 25%;
  padding: 5px;
	
  margin: 0 0 5px 0;

	
  
}

dd{
  width: 60%;
     padding: 5px 0;
  margin: 0 0 5px 0;
	
  
}


/* 罫線：フッター */

hr{
	
	border-top: dotted 0.8px #fff;
	width: 100%;
}


.pc_none{
	display: block;
}

.tab_none{
	display:none;
}


.sp_none{
	display:none;
}

.d_tab{
	display: block;
	
}

.list_tab{
	display: none;
	
}

.f_tab{
	display: none;
	
}



.sp_tab{
	display:none;
	
}



@media screen and (min-width:768px) and (max-width:959px) {
	
hr{
	border-top: dotted 0.8px #fff;
	width: 100%;
	
}

.pc_none{
	display: none;
}
	
.tab_none{
	display:block;
}


.sp_none{
	display:none;
}

.d_tab{
	display: block;
	
}
	
.list_tab{
	display: block;
	
}

.f_tab{
	display: block;
	
}
	
.sp_tab{
	display:  none;
}
}
	
	

@media screen and (max-width:767px) {

hr{
border-top: none;
	border-bottom: dotted 0.8px #fff;
	width: 100%;
	padding: 10px 0 0 0;
}

	
.pc_none{
	display: none;
}
	
.tab_none{
	display: none;
}


.sp_none{
	display:block;
}
	
.d_tab{
	display:none;
	
}
	
.list_tab{
	display:none;
	
}
	
.f_tab{
	display: block;
	
}
	
.sp_tab{
	display: block;
	
}

}

/* スケジュール表 */
.table_design09 {
  border-collapse: collapse;
  table-layout: fixed;
  width: 100%;
  max-width: 700px;
  border-radius: 20px;
  overflow: hidden;
  text-align: center;
}
.table_design09 tr {
  background-color: #e6f1f6;
}
.table_design09 tr:nth-child(even) {
  background-color: #fff;
}
.table_design09 th, .table_design09 td {
  padding: 1em;
}
.table_design09 thead th {
  background-color: #4d9bc1;
  color: #fff;
  font-weight: bold;
  text-align: center;
}
.table_design09 tbody th {
  color: #4d9bc1;
}
@media screen and (max-width: 787px) {
  .table_design09 {
    border-radius: 0;
    text-align: left;
  }
  .table_design09 thead {
    display:none;
  }
  .table_design09 tr {
    background-color: unset;
  }
  .table_design09 th, .table_design09 td {
    display: block;
    border: 0;
    border-bottom: 1px solid #4d9bc1;
  }
  .table_design09 tbody th{
    background: #4d9bc1;
    color:#fff;
    text-align: center;
  }
  .table_design09 td::before{
    content: attr(data-label);
    background-color: #e6f1f6;
    font-weight: bold;
    display: inline-block;
    width: 20%;
    min-width: 4em;
    text-align: center;
    margin-right: 0.5em;
    padding: 4px;
    border-radius: 100vh;
  }
}

/* 画面外にいる状態 */
.fadein {
	opacity : 0.1;
	transform : translate(0, 50px);
	transition : all 500ms;
}



/* 画面内に入った状態 */
.fadein.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}

/* 左から */

.fadeLeft{
animation-name:fadeLeftAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeLeftAnime{
  from {
    opacity: 0;
	transform: translateX(-100px);
  }

  to {
    opacity: 1;
	transform: translateX(0);
  }
}

/* 右から */

.fadeRight{
animation-name:fadeRightAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeRightAnime{
  from {
    opacity: 0;
	transform: translateX(100px);
  }

  to {
    opacity: 1;
	transform: translateX(0);
  }
}
/* オンマウスでアニメーション */
.css-fade4 {
/* アニメーション設定 */
    animation-name: fade-in4;
    animation-duration: 2s; /* アニメーション時間 */
    animation-timing-function: ease-out; /* アニメーションさせるイージング */
    animation-delay: 1s; /* アニメーション開始させる時間 */
    animation-iteration-count: 1; /* 繰り返し回数 */
    animation-direction: normal; /* 往復処理をするかどうか */
    animation-fill-mode: forwards; /* アニメーション後のスタイルをどうするか */
  }
/* アニメーション */
  @keyframes fade-in4 {
    0% {
      opacity: 0;
      transform: translate3d(30px, 0, 0);
    }
    100% {
      opacity: 1;
      transform: translate3d(0, 0, 0);
    }
  }








@media screen and (max-width:767px) {


th {
	text-align: left;
}
td {

	text-align: left;

	
}
	
}


/*================================================
 *  余白
 ================================================*/

.mt10{
	margin-top: 10px;
}


.mt30{
	margin-top: 30px;
}

.mt40{
	margin-top: 40px;
}

.mt50{
	margin-top: 50px;
}

.mt80{
	margin-top: 80px;
}

.mt100{
	margin-top: 100px;
}

.mb10{
	margin-bottom: 10px;
}

.mb20{
	margin-bottom: 20px;
}

.mb30{
	margin-bottom: 30px;
}

.mb40{
	margin-bottom: 40px;
}


.mb50{
	margin-bottom: 50px;
}


.mb80{
	margin-bottom: 80px;
}

.mb100{
	margin-bottom: 100px;
}

.ml10{
	margin-left: 10px;
}

.mr30{
	margin-right: 30px;
}

.pt20{
	padding-top:20px;
}

.pt30{
	padding-top:30px;
}


.pb20{
	padding-bottom:20px;
}

.pb30{
	padding-bottom:30px;
}

/*================================================
 *  色指定、文字
 ================================================*/



.em{
	font-weight: bold;
}

	
.bg_r{
	background: #ffc0cb;
}

.bg_p{
	background: #ffe4e1;

}

.bg_p_half{
	background: linear-gradient(transparent 50%, #ffe4e1 50%);
	
}

.bg_b{
	background: #e0ffff;
}

.bg_g{
	background: #f5f5f5;
}

.bg_y{
	background: yellow;
}

.bg_y_half{
	background: linear-gradient(transparent 50%, yellow 50%);
	font-weight: bold;
}

.bg_w_half{
	background: linear-gradient(transparent 50%, #fff 50%);
	font-weight: bold;
}

.textRed{
	color: #c91a1d;
	
	
}

.textWhite{
	color: #fff;
	
}

.textGray{
	background: #f5f5f5;
	
	
}




.under {
  background: linear-gradient(transparent 70%, #f9db00 70%);
	font-weight: bold;
}




.small{
	font-size: 80%;
	letter-spacing:1px;
	text-align: left;
	margin:10px 0 0 0;
}


/*================================================
 *  ローディング
 ================================================*/

.loading {
  width: 100vw;
  height: 100vh;
  transition: all 1s;
 background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  opacity: 1;
  visibility: visible;
}

.loading.is-active {
  opacity: 0;
  visibility: hidden;
}

.loading-animation {
  width: 100vw;
  height: 100vh;
  transition: all 1s;

 
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
	margin: -40px 0 0 0;
}

.loading-animation.is-active {
  opacity: 1;
  visibility: visible;
}

.loading img {
  width: 243px;
  height: 249px;
 
}


/*================================================
 * タイトルアニメーション
 ================================================*/
.jojo {

white-space:nowrap;
overflow:hidden;
animation:jojo 4s linear infinite;
}

@keyframes jojo {

from {

width:0%;
}

}




/*==================================================
背景色が伸びてタイトルが出現
===================================*/

/*全共通*/

.bgextend{
  animation-name:bgextendAnimeBase;
  animation-duration:1s;
  animation-fill-mode:forwards;
  position: relative;
  overflow: hidden;/*　はみ出た色要素を隠す　*/
  opacity:0;
}

@keyframes bgextendAnimeBase{
  from {
    opacity:0;
  }

  to {
    opacity:1;  
}
}

/*中の要素*/
.bgappear{
  animation-name:bgextendAnimeSecond;
  animation-duration:1s;
  animation-delay: 0.6s;
  animation-fill-mode:forwards;
  opacity: 0;
}

@keyframes bgextendAnimeSecond{
  0% {
  opacity: 0;
  }
  100% {
  opacity: 1;
}
}

/*左から右*/
.bgLRextend::before{
  animation-name:bgLRextendAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgLRextendAnime{
  0% {
    transform-origin:left;
    transform:scaleX(0);
  }
  50% {
    transform-origin:left;
    transform:scaleX(1);
  }
  50.001% {
    transform-origin:right;
  }
  100% {
    transform-origin:right;
    transform:scaleX(0);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgLRextendTrigger{
    opacity: 0;
}

/*================================================
 * キラッとさせる
 ================================================*/

.reflection{
display:inline-block;
position:relative;
overflow:hidden;
}
 
.reflection:after {
content:"";
height:100%;
width:30px;
position:absolute;
top:-180px;
left:0;
background-color: #fff;
opacity:0;
-webkit-transform: rotate(45deg);
-webkit-animation: reflection 2s ease-in-out infinite;
}
 
@keyframes reflection {
0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.3; }
81% { -webkit-transform: scale(4) rotate(45deg); opacity: 0.5; }
100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
	


.jojo {

white-space:nowrap;
overflow:hidden;
animation:jojo 4s linear infinite;
animation-iteration-count:2;
}

@keyframes jojo {

from {

width:0%;
}

to {

width:80%;
}

}

.header_c{
	
	background: #dcdcdc;
	border-radius: 50px;
	
	
}



@media screen and (max-width:767px) {


}



/*ステップフローのCSS（受講の流れ）：PROCESS*/
ul.stepflow {
	border: none;
	margin: 10px 0.5em 1em 0;
	padding: 0;
	list-style: none;
}
ul.stepflow > li:before, ol.stepflow > li:before {
	background-color:#cccccc!important;
}
.stepflow li {
    position: relative;
    padding: 0 0 1.5em 1.8em;

	margin: 0;
}
.stepflow>li:before {
	content: "";
	width: 3px;
	background: #cccccc;
	display: block;
	position: absolute;
	top: 28px;
	bottom: 0;
	left: 5px;
}
.stepflow-white {
	content: '';
	display: inline-block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: solid 3px #c23f22;
	background-color: #dcdcdc;
}
.stepflow-black {
	content: '';
	display: inline-block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: solid 3px #c23f22;
	background-color: #ca1a1d;
}
.stepflow_label {
	padding: 3px 0px 8px 0px;
	margin-bottom:8px;
	color: #999999;
	font-size: 100%;
	font-weight: bold;
	text-align: left;
}
.stepflow_title {
	font-size: 1.2em;
	font-weight: bold;
	line-height: 1.5;
	margin-bottom:15px;
	text-align: left;
}
.stepflow_content {
	font-size: 100%;
	line-height: 1.5;
	margin-top: .5em;
	padding: 0 0 1.5em;
	border-bottom: dashed 1px #cccccc;
}



/*================================================
 *  クリックで
 ================================================*/
.target {
  background-color: #ea3345;
  padding: 10px;
  line-height: 1.5;
  transition:
    padding-top 300ms,
    line-height 300ms;
}
.target.is-hidden {
  padding-top: 0;
  padding-bottom: 0;
  line-height: 0;
  pointer-events: none;
}
.text {
  color: white;
  transition: opacity 200ms;
}
.target.is-hidden .text {
  opacity: 0;
}
p {
  margin: 0;
}

/*================================================
 * ページ内ドロップダウンメニュー
 ================================================*/


.menu_sub {
    position: relative;
    width: 90%;
    height: 40px;
    
    margin: 0 auto 80px auto;

	
}


.menu_sub > li {
    float: left;
    width: 19.9%; /* グローバルナビ3つの場合 */
    height: 40px;
    line-height: 40px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 95%;
	letter-spacing: 1px;
	margin: 0;
	
}

.menu_sub > li a {
    display: block;
    color:#c9171e;
	 background: #e5e5e5;
	
}

.menu_sub > li a:hover {
     background: #c9171e;
	color: #fff;
	
	
    -webkit-transition: all .5s;
    transition: all .5s;
}

ul.menu__second-level {
    visibility: hidden;
    opacity: 0;
    z-index: 1;
}

ul.menu__third-level {
    visibility: hidden;
    opacity: 0;
}

ul.menu__fourth-level {
    visibility: hidden;
    opacity: 0;
}


.menu__second-level li {
    border-top: 1px solid #fff;
}

.menu__third-level li {
    border-top: 1px solid #c9171e;
}


.menu__second-level li a:hover {
    background: #c9171e;
	color: #fff;
}

.menu__third-level li a:hover {
    background: #c9171e;
}

.menu__fourth-level li a:hover {
    background: #a0d8ef;
}

/* 下矢印 */
.init-bottom:after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: 0 0 0 15px;
	
    border-right: 3px solid #c9171e;
    border-bottom: 3px solid #c9171e;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* floatクリア */
.menu_sub:before,
.menu_sub:after {
    content: " ";
    display: table;
}

.menu_sub:after {
    clear: both;
}

.menu_sub {
    *zoom: 1;
}

.menu_sub > li.menu__single {
    position: relative;
}

li.menu__single ul.menu__second-level {
    position: absolute;
    top: 40px;
    width: 100%;
    background: #add8e6;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
}

li.menu__single:hover ul.menu__second-level {
    top: 50px;
    visibility: visible;
    opacity: 1;
}

.menu_sub2 {
    position: relative;
    width: 90%;
    height: 40px;
    
    margin: 0 auto 40px auto;

	
}


.menu_sub2 > li {
    float: left;
    width: 16.5%; /* グローバルナビ3つの場合 */
    height: 40px;
    line-height: 40px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 93%;
	letter-spacing: 2px;
	margin: 0;
}

.menu_sub2 > li a {
    display: block;
    color:#c9171e;
	 background: #e5e5e5;
}

.menu_sub2 > li a:hover {
     background: #c9171e;
	color: #fff;
	
	
    -webkit-transition: all .5s;
    transition: all .5s;
}

.menu_sub3 {
    position: relative;
    width: 80%;
    height: 40px;
    
    margin: 0 auto 40px auto;

	
}


.menu_sub3 > li {
    float: left;
    width: 24%; /* グローバルナビ3つの場合 */
    height: 40px;
    line-height: 40px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 93%;
	letter-spacing: 2px;
	margin: 0;
}

.menu_sub3 > li a {
    display: block;
    color:#c9171e;
	 background: #e5e5e5;
}

.menu_sub3 > li a:hover {
     background: #c9171e;
	color: #fff;
	
	
    -webkit-transition: all .5s;
    transition: all .5s;
}

@media screen and (min-width:768px) and (max-width:959px) {
	.menu_sub {
    position: relative;
    width: 100%;
   height: 40px;
    max-width: 1000px;
    margin: 0 auto 50px auto;

	
}

.menu_sub > li {
    float: left;
    width: 33.1%; /* グローバルナビ3つの場合 */
   height: 40px;
    line-height: 40px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 90%;
	letter-spacing: -0.5px;
}

.menu_sub > li a {
    display: block;
    color:#c9171e;
	 background: #e5e5e5;
}

.menu_sub > li a:hover {
     background: #c9171e;
	color: #fff;
	
	
    -webkit-transition: all .5s;
    transition: all .5s;
}
	
.menu_sub2 {
    position: relative;
    width: 90%;
    height: 40px;
    
    margin: 0 auto 40px auto;

	
}


.menu_sub2 > li {
    float: left;
    width: 33.1%; /* グローバルナビ3つの場合 */
   height: 40px;
    line-height: 40px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 90%;
	letter-spacing: -0.5px;
}

.menu_sub2 > li a {
    display: block;
    color:#c9171e;
	 background: #dcdcdc;
}

.menu_sub2 > li a:hover {
     background: #c9171e;
	color: #fff;
	
	
    -webkit-transition: all .5s;
    transition: all .5s;
}
	
.menu_sub3 {
    position: relative;
    width: 95%;
    height: 40px;
    
    margin: 0 auto;

	
}


.menu_sub3 > li {
    float: left;
    width: 24%; /* グローバルナビ3つの場合 */
   height: 40px;
    line-height: 40px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 90%;
	letter-spacing: -0.5px;
}

.menu_sub3 > li a {
    display: block;
    color:#c9171e;
	 background: #dcdcdc;
}

.menu_sub3 > li a:hover {
     background: #c9171e;
	color: #fff;
	
	
    -webkit-transition: all .5s;
    transition: all .5s;
}

}



@media screen and (max-width:768px) {

.menu_sub {
    position: relative;
    width: 100%;
    height: 40px;
    max-width: 1000px;
    margin: 0 auto 20px 1.5px;
	
	font-size: 95%;
	
}

.menu_sub > li {
       float: left;
   
	width: 49.7%;/* グローバルナビ3つから2つへレイアウト変更 */

    height: 35px;
    line-height: 35px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	text-align: center;
	font-size: 100%;
	padding: 0;
	
}

.menu_sub > li a {
    display: block;
    color:#c9171e;
	 background: #e5e5e5;
	padding: 0;
}

.menu_sub > li a:hover {
     background: #c9171e;
	color: #fff;
	
    -webkit-transition: all .5s;
    transition: all .5s;
}
	


ul.menu__second-level {
    visibility: hidden;
    opacity: 0;
    z-index: 1;
}

ul.menu__third-level {
    visibility: hidden;
    opacity: 0;
}

ul.menu__fourth-level {
    visibility: hidden;
    opacity: 0;
}


.menu__second-level li {
    border-top: 1px solid #111;
}

.menu__third-level li {
    border-top: 1px solid #111;
}

.menu__second-level li a:hover {
    background: #111;
}

.menu__third-level li a:hover {
    background: #2a1f1f;
}

.menu__fourth-level li a:hover {
    background: #1d0f0f;
}
	
	


/* 下矢印 */
.init-bottom:after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: 0 0 0 15px;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* floatクリア */
.menu_sub:before,
.menu_sub:after {
    content: " ";
    display: table;
}

.menu_sub:after {
    clear: both;
}

.menu_sub {
    *zoom: 1;
}

.menu_sub > li.menu__single {
    position: relative;
}

li.menu__single ul.menu__second-level {
    position: absolute;
    top: 40px;
    width: 100%;
    background: #072A24;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
}

li.menu__single:hover ul.menu__second-level {
    top: 50px;
    visibility: visible;
    opacity: 1;
}

.menu_sub2 {
    position: relative;
    width: 100%;
    height: 40px;
    max-width: 1000px;
    margin: 0 auto 20px 1.5px;
	
	font-size: 95%;
	
}

.menu_sub2 > li {
       float: left;
   
	width: 49.7%;/* グローバルナビ3つから2つへレイアウト変更 */

    height: 35px;
    line-height: 35px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	text-align: center;
	font-size: 100%;
	padding: 0;
	
}

.menu_sub2 > li a {
    display: block;
    color:#c9171e;
	 background: #ccc;
	padding: 0;
}

.menu_sub2 > li a:hover {
     background: #c9171e;
	color: #fff;
	
    -webkit-transition: all .5s;
    transition: all .5s;
}
.menu_sub3 {
    position: relative;
    width: 100%;
    height: 40px;
    max-width: 1000px;
    margin: 0 auto 20px 1.5px;
	
	font-size: 95%;
	
}

.menu_sub3 > li {
       float: left;
   
	width: 49.7%;/* グローバルナビ3つから2つへレイアウト変更 */

    height: 35px;
    line-height: 35px;
    background: #c9171e;
	color: #fff;
	border-right: 1px solid #fff;
	text-align: center;
	font-size: 100%;
	padding: 0;
	
}

.menu_sub3 > li a {
    display: block;
    color:#c9171e;
	 background: #ccc;
	padding: 0;
}

.menu_sub3 > li a:hover {
     background: #c9171e;
	color: #fff;
	
    -webkit-transition: all .5s;
    transition: all .5s;
}	
}

/*================================================
 * ページ内ドロップダウンメニュー スマホのみ（ハニーズ）
 ================================================*/
@media screen and (max-width:768px) {
.toggle_contents {
	

	border-top: 2px solid #c9171e;
	border-bottom: 2px solid #c9171e;

	
}
	
.toggle_contents dd ul {
	
	
}

.toggle_contents dd ul li {
	
	width: 98%;
	font-size: 110%;
	margin: 0 0 10px 30px;
	font-weight: bold;
	letter-spacing: 1.5px;

}
	
.open{
	
	
	font-weight: bold;
color: #c9171e;
}

.toggle_title {
	position: relative;
	padding: 15px 0 10px 5px ;
	cursor: pointer;
	font-size: 110%;
	text-align: left;
	line-height: 1.4;
	font-weight: bold;
	color: #c9171e;
	width: 86%;
	letter-spacing: 1px;
}
.toggle_btn {
	position: absolute;
	top: 50%;
	left: 105%;
	transform: translateY(-50%);
	background: #c9171e;
	display: block;
	width: 24px;
	height: 24px;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	border-radius: 50%;
}
.toggle_btn:before, .toggle_btn:after {
	display: block;
	content: '';
	background-color: #fff;
	position: absolute;
	width: 10px;
	height: 2px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.toggle_btn:before {
	width: 2px;
	height: 10px;
}
.toggle_title.selected .toggle_btn:before {
	content: normal;
}
.toggle_contents dd {
	display: none;
}
	
}
/*================================================
 *  汎用クラス
 ================================================*/
/* 中央寄せ */
.center {
	text-align: center;
}

/* 左寄せ */
.left {
	text-align: left;
}

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

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



/* 写真中央寄せ */
.imgC {
	clear:both;
	overflow:hidden;
	margin: 0 auto 50px auto;
	margin-bottom:50px;
	text-align:center;
}
.imgC img {
	margin-bottom:10px;
}

/* 写真左寄せ */
.imgL {
	clear:both;
	overflow:hidden;
	margin:0 40% 50px 0;
	background: #fff;
	padding: 20px 20px 20px 0;
	opacity: 0.95;
}
.imgL img {
	float:left;
	margin:0 20px 0 0;
	width: 53%;
}

@media screen and (max-width:767px) {
	.imgL {
		margin-bottom:20px;
	}
	.imgL img {
		float:none;
		margin:0 0 10px 0;
	}
}

/* 写真右寄せ */
.imgR {
	clear:both;
	overflow:hidden;
	margin:0 35% 50px 5%;
	background: #fff;
	padding: 20px 0 20px 20px;
	opacity: 0.95;
}
.imgR img {
	float:right;
	margin:0 0 0 10px;
	width: 53%;
}

@media screen and (max-width:767px) {
	.imgR {
		clear:both;
		overflow:hidden;
		margin-bottom:20px;
	}
	.imgR img {
		float:right;
		margin:0 0 10px 0;
	}
}


/* 写真ズーム */
.zoom {
	overflow: hidden;
}
.zoom img {
	display: block;
	-moz-transition: -moz-transform 0.8s linear;
	-webkit-transition: -webkit-transform 0.8s linear;
	-o-transition: -o-transform 0.8s linear;
	-ms-transition: -ms-transform 0.8s linear;
	transition: transform 0.8s linear;
}
.zoom img:hover {
	-webkit-transform: scale(1.05);
	-moz-transform: scale(1.05);
	-o-transform: scale(1.05);
	-ms-transform: scale(1.05);
	transform: scale(1.05);
}
.zoom img {
	margin-bottom: 0;
}

/* オーバーレイ */
.overlay {
	position: relative;
}
.overlay::after{
	background: rgba(0,0,0,.5);
	content: "　";
	display: block;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	transition: all .3s ease-out;
	pointer-events: none;
}
.overlay:hover::after {
	background: rgba(0,0,0,.1);
	transition: all .3s ease-out;
}
.overlay img {
	margin-bottom: 0;
}
/* ボタン：詳しく見る */

.Btn{
  
  margin: 50px auto 0 auto;

  width: 42%;
  
  line-height: 48px;
  display: flex;
  text-align: center;
  background: #fff;

	font-size: 90%;
	padding: 0;
	border-radius: 50px;
	

}

/* テーブル：バク転講座料金 */
.tbl-r05 th {
  
  padding: 10px;
	letter-spacing: 1px;
}
.tbl-r05 td {
　padding: 10px;
letter-spacing: 1px;
}


.tbl-r05 td:first-child {
  background: #fbf5f5;
}
@media screen and (max-width: 640px) {
  .tbl-r05 {
    width: 80%;
  }
  .tbl-r05 .thead {
    display: none;
  }
  .tbl-r05 tr {
    width: 98%;
  }
  .tbl-r05 td {
    display: block;
    text-align: right;
    width: 98%;
  }
  .tbl-r05 td:first-child {
    background: #808080;
    color: #fff;
    font-weight: bold;
    text-align: center;
  }
  .tbl-r05 td:before {
    content: attr(data-label);
    float: left;
    font-weight: bold;
    margin-right: 10px;
  }
}




/* 2カラム（スマートフォンでは1カラム) */
.twoCol {
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	position:relative;
	overflow:hidden;
	margin-bottom:60px;
	
}
.twoCol .inner {
	position: relative;
	overflow:hidden;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	align-items: center;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-direction: column-reverse;
	-webkit-box-direction: reverse;
	-webkit-flex-direction: column-reverse;
	flex-direction: column;
	width: 45.98%;
	width: calc((450 / 980) *100%);
	height: auto;
	margin:0 0 20px 0;
}
.twoCol .inner h4 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
}
.twoCol .inner p {
	width: 100%;
	margin-bottom: 0;
	text-align: justify;
}
.twoCol .inner > a {
	width: 100%;
	height: 100%;
}
.twoCol .inner .image {
	width: 80%;
	min-height: 0%;
}
.twoCol .inner img {
	width: 100%;
	border: solid 20px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 8px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 5px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;
}
.twoCol .inner .btn {
	margin-top: auto;
	padding-top: 20px;
}


.twoCol .inner .text a {
	position: absolute;
	top: 85%;
	left: 40%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	font-size: 140%;
	font-weight: bold;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;

	padding: 15px;
	width: 30%;
	
	letter-spacing: 2px;
	border: 2px solid #333;
	background: #333;
	border-radius: 50px;
	
}

.twoCol .inner .text a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;
}

@media screen and (max-width:767px) {
	.twoCol {
		display: block;
		margin-bottom:20px;
	}
	.twoCol .inner {
		width :100%;
		margin:0 0 10px 0;
	}
	
	.twoCol .inner .btn {
	margin-top: auto;
	padding-top: 10px;
}
	.twoCol .inner .text {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	font-size: 16px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
	border: 3px solid #fff;
	padding:  15px 30px 30px 30px;
	width: 65%;
	height: 70%;
	
}

}



/* 3カラム（スマートフォンでは1カラム) ：アクセス欄3ロゴ並列*/
.threeCol {
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
	margin:80px 5% 0 5%;
	
	
}
.threeCol .inner {
	position: relative;
	overflow: hidden;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	align-items: center;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-direction: normal;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	flex-direction: column;
	width: 30%;
	width: calc((300 / 980) *98%);
	margin: 0 auto;
	
	background: #fff;
	border-radius: 10px;
	opacity: 0.92;
	
}
.threeCol .inner h4 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
	letter-spacing: 2px;
	margin: 0;
	font-size: 140%;
	padding: 0;
	font-weight: bold;
}


.threeCol .inner h5 {
	width: 100%;
	letter-spacing: 1px;
	margin: 0 0 20px 0;
	border-bottom: 1px dotted #fff;
	color: #fff;
	font-size:55%;
	text-align: left;
	padding: 0 0 20px 0;
	font-weight: bold;
}

.threeCol .inner p {
	width: 100%;
	margin-bottom: 0;
	text-align: left;
}
.threeCol .inner > a {
	width: 100%;
	height: 100%;
}
.threeCol .inner .image {
	width: 100%;
	min-height: 0%;
}
.threeCol .inner img {
	width: auto;
	height: auto;
	margin: 0 auto;
	text-align: center;
	background: #fff;
	padding: 0 30px 30px 0;
	

}
.threeCol .inner .btn {
	margin-top: auto;
	padding-top: 20px;
}
.threeCol .inner .text {
	position: absolute;
	top: 77%;
	left: 50%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	font-size: 110%;
	font-weight: bold;
color:#000;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
}

@media screen and (min-width:769px) and (max-width:959px) {
.threeCol .inner .text {
	position: absolute;
	top: 63%;
	left: 49%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	font-size: 83%;
	font-weight: bold;
	
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
}
}





@media screen and (max-width:767px) {
	.threeCol {
		display: block;
		margin-bottom: 20px;
	}
	.threeCol .inner {
		width : 100%;
		margin: 0 0 10px 0;
	}
}

/* 4カラム（スマートフォンでは2カラム) */
.fourCol {
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
	margin-bottom:60px;
}
.fourCol .inner {
	position: relative;
	overflow: hidden;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	align-items: center;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-direction: normal;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	flex-direction: column;
	width: 20%;
	width: calc((230 / 980) *100%);
	margin: 50px 0 20px 0;
	border: 1px solid #000;
}

.fourCol .inner h3 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
	font-weight: bold;
		letter-spacing: 1px;
	font-size: 97%;
}
.fourCol .inner h4 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
}
.fourCol .inner p {
	width: 100%;
	margin-top: 10px;
	text-align: center;
}
.fourCol .inner > a {
	width: 100%;
	height: 100%;
}
.fourCol .inner .image {
	width: 100%;
	min-height: 0%;
	
}
.fourCol .inner img {
	width: 100%;
	
}
.fourCol .inner .btn {
	margin-top: auto;
	padding-top: 20px;
}


@media screen and (max-width:767px) {
	.fourCol {
		margin-bottom: 10px;
	}
	.fourCol .inner {
		box-sizing: border-box;
		width: 48.98%;
		width: calc((480 / 980) *100%);
		margin-bottom: 10px;
	}
	.fourCol .inner .text {
	position: absolute;
	top: 47%;
	left: 47%;
	
	-webkit-transform: translateY(-47%) translateX(-47%);
	transform: translateY(-47%) translateX(-47%);
	font-size: 98%;
	font-weight: bold;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
		letter-spacing: 0.05em;
		
	
}
}

/* 5カラム（スマートフォンでは2カラム) */
.fiveCol {
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
	margin:100px auto 0 auto;
	width: 95%;
}
.fiveCol .inner {
	position: relative;
	overflow: hidden;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	align-items: center;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-direction: normal;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	flex-direction: column;
	width: 20%;
	font-size: 110%;
	margin: 0;
}
.fiveCol .inner h4 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
}
.fiveCol .inner p {
	width: 110%;
	margin-bottom: 0;
	text-align: justify;
}
.fiveCol .inner > a {
	width: 100%;
	height: 100%;
}
.fiveCol .inner .image {
	width: 100%;
	min-height: 0%;
}
.fiveCol .inner img {
	width: 100%;
}
.fiveCol .inner .btn {
	margin-top: auto;
	

}



.fiveCol .inner .text {
	position: absolute;
	bottom: -3%;
	left: 50%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	font-size: 110%;
	font-weight: bold;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
	letter-spacing: 2px;
}

@media screen and (min-width:768px) and (max-width:959px) {
.fiveCol {
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
	margin:50px 0 0 0;
	width: 100%;
}
	
.fiveCol .inner .text {
	position: absolute;
	bottom: -8%;
	left: 50%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	font-size: 90%;
	font-weight: bold;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
	letter-spacing: 1px;
}
}

@media screen and (max-width:767px) {
	.fiveCol {
		margin-bottom: 20px;
		width: 94%;
		
	}
	.fiveCol .inner {
		box-sizing: border-box;
		width: 94%;
		width: calc((940 / 940) *100%);
		margin-bottom: 30px;
		
	}
	.fiveCol .inner .text {
	position: absolute;
	bottom: 1%;
	left: 47%;
	
	-webkit-transform: translateY(-47%) translateX(-47%);
	transform: translateY(-47%) translateX(-47%);
	font-size: 120%;
	font-weight: bold;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	pointer-events: none;
		letter-spacing: 2px;
		
	
}
}




/* タブ切り替え（スタジオについて）分割:ブロックを増やすごとに自動均等 */
.tab-wrap {
  display: flex;
  flex-wrap: wrap;
  margin:0;

}
.tab-wrap:after {

}
.tab-label {
  color: #4D4949;
 background:#eeeeee;
  font-weight: bold;
  white-space: nowrap;
  text-align: center;
  padding: 15px 10px;
  order: -1;
  position: relative;
  z-index: 1;
  cursor: pointer;
  flex: 1;
	
	margin: 0 0 8px 0;
	
}
.tab-label:not(:last-of-type) {
  margin-right: 5px;
}
.tab-content {
  width: 100%;
  height: 0;
  overflow: hidden;
  opacity: 0;
}

.tab-switch:checked+.tab-label {
  background:#d9372b;
	
	
}
.tab-switch:checked+.tab-label+.tab-content {
  height: auto;
  overflow: auto;
  padding: 50px 0 0 0;
  opacity: 1;
  transition: .5s opacity;
  
}
.tab-switch {
  display: none;
}

.tab-switch:checked+.tab-label:after {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(136, 183, 213, 0);
 
}
.tab-switch:checked+.tab-label {
    background:#000;
	 color: #fff;
	
}


/* 矢印下へ */

.scroll {
  display: inline-block;
  padding: 20px;
  
	border: 2px;
	margin: 0 0 20px 0;
	position: absolute;
	top:600px;
	

}
.scroll::before {
  animation: scroll 3.5s infinite;
  border: solid #000;
  border-width: 0 0 5px 5px;
  content: "";
  display: inline-block;
  margin: auto;
  position: absolute;
  top: 0;
  right: 0;
  left: -14px;
  transform: rotate(-45deg);
  width: 20px;
  height: 20px;
}
@keyframes scroll {
  0% {
    transform: rotate(-45deg) translate(0, 0);
  }
  80% {
    transform: rotate(-45deg) translate(-30px, 30px);
  }
  0%, 80%, 100% {
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
}

@media screen and (min-width:768px) and (max-width:959px) {
.scroll {
  display: none;
  
}	

}

@media screen and (max-width:768px) {
.scroll {
  display: none;
  
}	
}

/* スケジュール表（ポップアップ） */

.popup_wrap input {
  display: none;
	
}
.popup_overlay {
  display: flex;
  justify-content: center;
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
cursor: pointer;
  z-index: 9999;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  opacity: 0;
  transition: opacity 0.5s, transform 0s 0.5s;
  transform: scale(0);
}
.popup_trigger {
  position: absolute;
  width: 100%;
  height: 100%;
}
.popup_content {
  position: relative;
  align-self: center;
  width: 100%;
  max-width: 700px;
  box-sizing: border-box;
  background: #fff;
  line-height: 1.4em;
  transition: 0.5s;
  border-radius: 12px;
  box-shadow: 0 0 5px rgba(94, 94, 94, 0.7);
}



.popup_content p{
    padding:10px 8px 10px 0;
    
}
.close_btn {
  position: absolute;
  top: 14px;
  right: 14px;
  font-size: 30px;
  cursor: pointer;
  	padding: 5px 7px 10px 7px;
	background: #000;
	color:#fff;
	border-radius: 5px;
}
.popup_wrap input:checked ~ .popup_overlay {
  opacity: 1;
  transform: scale(1);
  transition: opacity 0.5s;
}
.open_btn {
    position: relative;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;


  cursor: pointer;
  transition: .3s ease;
	margin: 0;
	padding: 15px 0 15px 30px;
	 font-weight: bold;
}
	

.open_btn:hover{
 

    transition: .3s ease;
	opacity: 0.9;
	font-weight: bold;
	margin: 0;
}

@media screen and (max-width:768px) {

.popup_content {
  position: relative;
  align-self: center;
  width: 100%;
  max-width: auto;
  box-sizing: border-box;
  background: #fff;
  line-height: 1.4em;
  transition: 0.5s;
  border-radius: 12px;
  box-shadow: 0 0 5px rgba(94, 94, 94, 0.7);
margin: 0 3%;
	z-index: 9999;
}

.popup_content p{
    padding:10px;
    
}
.close_btn {
  position: absolute;
  top: 14px;
  right: 14px;
  font-size: 30px;
  cursor: pointer;
  	padding: 8px 9px 8px 9px;
	background: #000;
	color:#fff;
	border-radius: 5px;
}
	}

/* 点滅 */
.blink {
	animation: blinking 1s ease-in-out infinite alternate;
}
 
@keyframes blinking {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

/*================================================
 *  記事フレーム
 ================================================*/
#wrapper{
	width: 1024px;
	margin: 0 auto;
	padding: 15px;
	
	border: 2px #000 solid;
	
}

/*================================================
 *  ヘッダー
 ================================================*/
header {
	width:100%;
	height:65px;
	padding:0;
	margin:0 auto;
	z-index: 9999;
  position: fixed;
	background: #fff;
	opacity: 0.9;



}

header:after {
	content: ""; 
	display: block;
	clear: both;
}

header h1 {
float: left;
	
	margin: 5px 0 0 20px;
	
}



header h1 img {
	vertical-align: middle;
width: 200px;
	height:34px;

}

header p {
	
	text-align: right;
	font-size: 86%;
	padding: 2px 4% 0 0;
	margin: 0;

}



.is-animation {
width:100%;
	height:65px;
	padding:0;
	margin:0 auto;
	z-index: 9999;
  position: fixed;
	background: #fff;
	opacity: 0.9;


	
}
.is-animation h1 {
	width: auto;
	margin: 5px auto 0 20px;
 
}

.is-animation img{
	vertical-align: middle;
	width: 200px;
	height:34px;
}
.is-animation p{
display: none;


}

.header_r{
		width: auto;
	height: auto;
	float: right;
	border-radius: 50px;
	padding: 10px 15px;
	background: linear-gradient(-45deg, #ffedab, #fcc800, #fdd35c, #fff3b8) fixed;
  background-size: 800% 800%;
  animation: GradietionAnimation 15s ease infinite;

	

}



@media screen and (min-width:768px) and (max-width:959px) {
	header {

	height:60px;

}	
	
header h1 img {
width: 200px;
	height:34px;
	margin: 0 auto;
	border-right:none; 
	padding:0;

}

	
.is-animation h1 {

	margin: 0 0 0 20px;
width: 200px;
	height:34px;
 
}

.is-animation img{
width: 200px;
	height:34px;

}	

.is-animation {
	  position: fixed;
padding: 0;
  z-index: 9999;
  width: 100%;

	margin: 0 auto;

	
}
.is-animation h1 {
 
}

.is-animation img{
	width: 200px;
	height:34px;
	margin: 5px 0 0 0;

}

.header_r{
		width: 20%;
	height: auto;
	

}

	
}


@media screen and (max-width:768px) {
	
	header {

	height:60px;
	
}	
	
header h1 {
	float: left;
margin: 5px 0 0 20px ;
	
}
	
header h1 img {
	
	width: 200px;
	height:34px;
	margin: 5px 0 0 0 ;
	border-right: none;

}
	
header p {
	
	display: none;
	
}

.is-animation {
	  position: fixed;
padding: 0 0 30px 0;
  z-index: 9998;
  width: 100%;
  height: 30px;
	margin: 0 auto;
	box-shadow: 2px 2px 4px #d3d3d3;
-webkit-box-shadow: 2px 2px 4px #d3d3d3;
-moz-box-shadow: 2px 2px 4px #d3d3d3;
opacity: 0.9;
	background: #fff;

  z-index: 9999;
	
}
	
.is-animation img{
width: 200px;
	height:34px;
	margin: 0;
	
	
	

}

}

/*================================================
 *  グローバルナビゲーション
 ================================================*/
/* PC用 */
@media print, screen and (min-width:1280px) {
	nav.gnav:after {
		content: '';
		display: block;
		clear: both;
		
		

	}
	nav.gnav {
		display: block !important;
		
	}

	/* 共通 */
	nav.gnav ul {
		margin: 5px 0 0 0;
		padding: 0;
		width:  auto;
		float: right;

		
	}
	
	nav.gnav ul li {
		position: relative;
		list-style: none;
	
	}
	nav.gnav ul li a {
		display: block;
		width:auto;
		color:#000;
		font-size: 90%;
font-weight:bold;
		text-decoration: none;
		padding:0 4px 6px 4px;
		margin: 5px 4px 0 4px;
		letter-spacing:1px;
	}
	
	nav.gnav ul li:hover > a {
		color: #696969;
		font-weight:bold;
		
		padding:0 4px 6px 4px;
		margin: 5px 4px 0 4px;
		letter-spacing:1px;
		opacity: 0.9;
		
	}
	
	

	/* 1段目 */
	nav.gnav > ul > li {
		position: relative;
		width: auto;
		float: left;
		margin: 10px 0;
		padding: 0 6px;
		text-align: center;
		list-style: none;
		
		
	}
	nav.gnav > ul > li.subnav a {
		padding-right: 10px;
		
	}
	nav.gnav > ul > li.subnav > a:after {
		position: absolute;
		content: "";
		top: 50%;
		width: 0;
		height: 0;
		margin-top: -3px;
		margin-left: 2px;
		border: 5px solid transparent;
		border-top-color: #000;
		color:#000;
			
	}
	
	

	/* 2段目 */
	nav.gnav ul li ul {
		position: absolute;
		z-index: 3;
		top: 100%;
		left: 0;
		width: 195px;
		margin: 5px 0 0 -20px;
		padding: 0;
		letter-spacing: 0;
		background: none;
		
	}
	nav.gnav ul li ul li {
		overflow: hidden;
		height: 0;
		color: #fff;
		transition: .2s;
	
		
	}
	nav.gnav ul li ul li a {
		padding: 0 0 0 10px;
		text-align: left;
		background: #ccc;
		font-weight: normal;
		color: #fff;
		margin:0;
		letter-spacing:0;
		
	}
	nav.gnav ul li ul li a:hover {
		color: #dcdcdc;
		font-weight: normal;
		margin:0 0 0 0;
		padding: 0 0 0 8px;
		letter-spacing:0;
	}
	nav.gnav ul li:hover > ul > li {
		overflow: visible;
		height: 40px;
		line-height: 40px;
		
	}
	nav.gnav ul li:hover ul li:last-child {
		border-bottom: none;
	}
	nav.gnav > ul > li:last-child > ul {
		left: -60px;
	}
	nav.gnav ul li ul li ul:before {
		position: absolute;
		content: "";
		top: 17.5px;
		left: -20px;
		width: 0;
		height: 0;
		border: 5px solid transparent;
		border-left-color: #fff;
	}
	nav.gnav > ul > li:last-child ul li ul:before {
		position: absolute;
		content: "";
		top: 17.5px;
		left: 200%;
		margin-left: -20px;
		border: 5px solid transparent;
		border-right-color: #fff;
	}

	/* 3段目 */
	nav.gnav ul li ul li ul {
		top: 0;
		left: 100%;
	}
	nav.gnav ul li ul li ul li {
		width: 100%;
	}
	nav.gnav ul li ul li:hover > ul > li {
		border-bottom: 1px solid #555;
	}
	nav.gnav > ul > li:last-child > ul li ul {
		left: -100%;
	}
	nav.gnav ul li ul li ul li a {
		background: #444;
	}
	nav.gnav ul li ul li ul li a:hover {
		background: #666;
	}

	/* 3段目 */
	nav.gnav > ul {
		display: block !important;
	}
	#spMenu {
		display: none;
	}
}





/* タブレット・スマートフォン用 */
@media screen and (max-width:1279px) {
	nav.gnav {
		display: none;
	}
	nav.gnav ul {
		margin: 0;
		padding: 0;
		
	}
	nav.gnav > ul {
		
		overflow: auto;
		position: fixed;
		top: 47px;
		right: 0;
		width: 80%;
		height: 90%;
		height: -webkit-calc(100% - 50px);
		height: calc(100% - 50px);
		
	}
	nav.gnav li {
		position: relative;
		width: 100%;
		float: none;
		margin: 0;
		padding:0 0 2px 0;
		text-align: left;
		list-style: none;
		border-bottom: 0.2px dotted #dcdcdc;
		background: #333;
		opacity: 0.95; /* 2％ほど透過させる */
	}
	nav.gnav li:first-child {
		border-top: 0;
	}
	nav.gnav li:last-child {
		border-bottom: 0;
	}
	nav.gnav li a {
		display: block;
		padding: 10px 20px;
		color: #fff;
		text-decoration: none;
		background: #333;
		font-size: 100%;
	}
	nav.gnav li a:hover {
		color: #fff;
		background: #000;
		font-weight: bold;
		padding: 10px 20px;
	}
	nav.gnav ul ul {
		display: none;
		position: relative;
	}
	nav.gnav li li a {
		box-sizing: border-box;
		width: 100%;
		padding: 10px 30px 10px 34px;
		text-align: left;
	}
	nav.gnav li li li a {
		padding: 10px 20px 10px 48px;
	}

	nav.gnav .subnav > a:before {
		display: block;
		content: "";
		position: absolute;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		top: 20px;
		right: 20px;
		width: 10px;
		height: 10px;
		margin-top: -5px;
		background: #f1f1f1;
	}
	nav.gnav .subnav > a:after {
		display: block;
		content: "";
		position: absolute;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		top: 20px;
		right: 20px;
		width: 10px;
		height: 10px;
		margin-top: -10px;
		background: #000;
	}
	nav.gnav .subnav a:hover:after {
		background: #000;
	}
	nav.gnav .subnav.active > a:before {
		margin-top: 0;
	}
	nav.gnav .subnav.active > a:after {
		margin-top: 5px;
	}

	.spMenuWrap {
		display: block;
		position: fixed;
		top: 0;
		right: 0;
		-webkit-transition: all 1s;
		-moz-transition: all 1s;
		-ms-transition: all 1s;
		-o-transition: all 1s;
		transition: all 1s;
		background: transparent;
	}

	#spMenu {
		position: absolute;
		top: 10px;
		right: 10px;
	}

	#spMenu:hover {
		cursor: pointer;
	}

	#navBtn {
		display: inline-block;
		position: relative;
		width: 40px;
		height: 40px;
		
		background: #000;
	}
	#navBtnIcon {
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		width: 14px;
		height: 2px;
		margin: -1px 0 0 -7px;
		background: #f1f1f1;
		transition: .2s;
	}
	#navBtnIcon:before,
	#navBtnIcon:after {
		display: block;
		content: '';
		position: absolute;
		top: 50%;
		left: 0;
		width: 14px;
		height: 2px;
		background: #f1f1f1;
		transition: 0.3s;
	}
	#navBtnIcon:before {
		margin-top: -6px;
	}
	#navBtnIcon:after {
		margin-top: 4px;
	}
	#navBtn .close {
		background: transparent;
	}
	#navBtn .close:before,
	#navBtn .close:after {
		margin-top: 0;
	}
	#navBtn .close:before {
		transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
	}
	#navBtn .close:after {
		transform: rotate(-135deg);
		-webkit-transform: rotate(-135deg);
	}
	
	.header_c{
	background: none;
	border-radius: 0;
	
}
	
	#nav_flame{
	background: none;
	padding: 0;
	border-radius: 0;
font-size: 95%;
		
}
}


/*================================================
 *  フッター
 ================================================*/
footer {
	
padding: 50px 0;
	clear: both;

background: linear-gradient(-45deg, #c23f22, #ca1a1d, #c23f22, #ca1a1d) fixed;
  background-size: 800% 800%;
  animation: GradietionAnimation 15s ease infinite;
	

-webkit-animation: rainbow 18s ease infinite;
-z-animation: rainbow 18s ease infinite;
-o-animation: rainbow 18s ease infinite;}

@-webkit-keyframes rainbow {
    0%{background-position:0% 82%}
    50%{background-position:100% 19%}
    100%{background-position:0% 82%}
}
@-moz-keyframes rainbow {
    0%{background-position:0% 82%}
    50%{background-position:100% 19%}
    100%{background-position:0% 82%}
}
@-o-keyframes rainbow {
    0%{background-position:0% 82%}
    50%{background-position:100% 19%}
    100%{background-position:0% 82%}
}
@keyframes rainbow { 
    0%{background-position:0% 82%}
    50%{background-position:100% 19%}
    100%{background-position:0% 82%}
}

footer h2{

	font-size: 200%;
	margin: 10px 0 40px 0;
	font-weight: bold;
	letter-spacing: 0.2em;
color:#fff;
	

	
}

footer h2 span{

	font-size: 60%;
	letter-spacing: 1px;
	margin: 0;
	font-weight: bold;
	
}

footer h3{

	font-size: 120%;
	margin: 0 0 10px 0;
	font-weight: bold;
	letter-spacing: 3px;
color:#fff;

	
}

footer h4{
padding: 0;
	font-size: 110%;
	margin: 0 0 10px 0;
	font-weight: bold;
	letter-spacing: 2px;
color:#fff;

	
}


footer #flame_l{
	float: left;

	
	margin: 0 80px 0 0;
	width: 55%;
	padding: 0;
	

}




footer #flame_l ul{
	
	padding: 0;
	
}

footer #flame_l ul li{
	float: left;

	font-size: 98%;
	margin: 0 40px 30px 0;
	width: auto;
	padding: 0;
	letter-spacing: 1px;
	

}

footer #flame_l ul li a{
	
	font-size: 97%;

	color:#fff;
	letter-spacing: 1.5px;
}

footer #flame_l ul li a:hover{
	color:#D4CDCD;
	
	
}

footer #flame_l ul li ul li{

	font-size: 95%;
	margin: 5px 0 0 0;
	width: auto;
	padding: 0 15px 0 0px;
	list-style-type:none;
	float: left;
	
	
}

footer #flame_l ul li ul li a{
	font-size: 94%;
	
	letter-spacing: 1px;

}

footer #flame_l ul li ul li a:hover{
	
	font-size: 95%;
	
	font-weight: bold;
	letter-spacing: 1px;
}


footer #flame_r{
	float: left;

	font-size: 96%;
	margin: 20px 0 0 0;
	width: 35%;
	padding: 0;
	text-align: left;
	
}

footer #flame_r p{
	

	font-size: 94%;
	margin: 0 0 5px 0;
	line-height: 1.4;
	padding: 0;
	text-align: left;
	color:#fff;
}


footer #flame_r a{
	font-weight: bold;
color:#fff;
	
}

footer #flame_r a:hover{
	
	opacity: 0.7;
color: #CDC8C8;
	
}


footer .btn {
    
text-align:center;
	font-weight: bold;


}

footer .btn a {
		position: relative;
	display: inline-block;
	padding: 0 10px 0 0;

	float: left;
	font-size: 110%;


	text-align:center;
border-radius: 50%;

font-weight:bold;
	margin: 0 10px 30px 0;
}

footer .btn a:hover {
	opacity: 0.7;
}


/* フッターアイコン設定 */

#f_icon {
	width:90%;
	margin:0;
float: left;

}

#f_icon ul li{

	width:4%;
	margin:0 5px 0 0;
float: left;
	font-size: 140%;
	list-style: none;
	text-align: left;
	
}



#f_icon a {
	

color:#fff;
}



#f_icon a:hover {
	
	filter:alpha(opacity=90);
	-moz-opacity: 0.9;
	opacity: 0.9;
color: #CDC8C8;
}



.fnav {
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	
	margin: 0;
	padding: 15px 0;
}

.fnav > ul {
	width: auto;
	margin-bottom: 0;
	font-size: 82%;
}
.fnav > ul li {
	text-align: left;
	float: left;
}

.copyright {
	padding: 20px 0;
	font-size: 70%;
	text-align: left;
	margin: 40px 0 0 0;
	color: #fff;
}

.copyright_sent {
	padding:  20px 0;
	font-size: 80%;
	text-align: center;
	background: #000;
	margin: 0;
	color: #fff;
}

@media screen and (min-width:768px) and (max-width:959px) {
footer {
clear: both;
	padding: 30px 0 0 0;
	margin: 0;
	

	
}
	
footer h2{
padding: 0;
	font-size: 150%;
	margin: 0 0 30px 0;
	font-weight: bold;
	letter-spacing: 5px;


}

	
footer h3{
padding: 0;
	font-size: 120%;
	margin: 0 0 10px 0;
	font-weight: bold;
	letter-spacing: 2px;

	text-align: left;
	
}

footer #flame_l{
	float: none;

	font-size: 100%;
	margin: 0 0 0 30px;
	width: 95%;
	padding: 0;

}


footer #flame_l ul{
	
	padding: 0;
	
}

footer #flame_l ul li{
	float: left;

	font-size: 93%;
	margin: 0 30px 30px 0;
	width: auto;
	padding: 0;
	letter-spacing: 1px;

}

footer #flame_l ul li a:hover{
	
	font-size: 97%;
	
	font-weight: bold;
	letter-spacing: 1px;
}

footer #flame_l ul li ul li{

	font-size: 95%;
	margin: 5px 0 15px 10px;
	width: auto;
	padding: 0 15px 0 0px;
	list-style-type:none;
	float: left;
}

footer #flame_l ul li ul li a{
	font-size: 92%;
	
	letter-spacing: 1px;

}

footer #flame_l ul li ul li a:hover{
	
	font-size: 95%;
	
	font-weight: bold;
	letter-spacing: 1px;
}


footer #flame_r{
	float: none;
color: #fff;
	font-size: 96%;
	margin: 90px 0 0 30px;
	width: 93%;
	padding: 0;
	text-align: left;

	
}


/* フッターアイコン設定 */

#f_icon {
	width:90%;
	margin:0 0 0 30px;
float: left;


}

#f_icon ul li{

	width:4%;
	margin:0 5px 0 0;
float: left;
	font-size: 140%;
	list-style: none;
	text-align: left;

}




#f_icon a:hover {
	
	filter:alpha(opacity=90);
	-moz-opacity: 0.9;
	opacity: 0.9;

}




}

@media screen and (max-width:767px) {
	
footer {
	clear: both;
	padding: 30px 0 0 0;
	margin: 0;

}
	
	
footer h2{
padding: 0;
	font-size: 140%;
	margin: 0 0 30px 0;
	font-weight: bold;
	letter-spacing: 3px;

}

	
footer h3{
padding: 0;
	font-size: 120%;
	margin: 0 0 10px 0;
	font-weight: bold;
	letter-spacing: 2px;
	
}

footer #flame_l{
	float: none;

	font-size: 100%;
	margin: 0 0 30px 3%;
	width: 94%;
	padding: 0;
}


footer #flame_l ul{
	
	padding: 0;

}

footer #flame_l ul li{
	float: left;
	font-size: 100%;
	margin: 0 16px 15px 0;
	width: auto;
	padding: 0;
	letter-spacing: 1px;


}

footer #flame_l ul li a:hover{
	
	font-size: 100%;
	
	font-weight: bold;
	letter-spacing: 1px;
}

footer #flame_l ul li ul li{

	font-size: 100%;
	margin: 5px 0 15px 10px;
	width: auto;
	padding: 0 15px 0 0;
	list-style-type:none;
	float: left;

}

footer #flame_l ul li ul li a{
	font-size: 100%;
	
	letter-spacing: 1px;

}

footer #flame_l ul li ul li a:hover{
	
	font-size: 100%;
	
	font-weight: bold;
	letter-spacing: 1px;
}


footer #flame_r{
	float: none;
color: #fff;
	font-size: 100%;
margin: 120px 0 30px 3%;
	width: 92%;
	padding: 0;
	text-align: left;
}


/* フッターアイコン設定 */

#f_icon {
	width:93%;
	margin:0 0 0 3%;
float: left;



}

#f_icon ul li{

	width:12%;
	margin:0 0 0 0;
float: left;
	font-size: 160%;
	list-style: none;
	text-align: left;
	
}




#f_icon a:hover {
	
	filter:alpha(opacity=90);
	-moz-opacity: 0.9;
	opacity: 0.9;

}



}


/*================================================
 *  ページトップへの戻り
 ================================================*/
.totop {
	position:fixed;
	bottom:40px;
	right:20px;
	z-index: 9998;
	margin: 0;
	width: auto;
	
}
.totop a {
	display:block;
	text-decoration:none;
}
.totop img {
	background:#000;
	padding: 10px;
}
.totop img:hover {
	opacity:0.8;
}



@media screen and (min-width:768px) and (max-width:959px) {



}

@media screen and (max-width:767px) {

}

/*================================================
 *  フッター右下：電話・お問い合わせ固定
 ================================================*/

#tel {
   background:#c72d23;
    position:fixed;
	bottom:0;
	right:0;
	z-index:1;
	margin: 0;
	width: 50px;
	font-weight: bold;
	padding: 15px 10px;
	
	
}

#tel a {
  display: block;
  z-index: 999;
  text-decoration: none;
  text-align: center;
color: #fff;
	font-size: 140%;
}

#tel a:hover {
	text-decoration: none;
	opacity: 0.7;
}

.mail {
   
    position: fixed;
    bottom: 0;
    right: 0;
	background: #003366;
	width: 50px;
	height: 39px;
	border-radius: 0;
	
}

.mail a {
  display: block;
  z-index: 999;
  text-decoration: none;
  text-align: center;
}

.mail a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: "\f003";
  font-size: 20px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

.mail a:hover {
	text-decoration: none;
	opacity: 0.7;
}



/*================================================
 *  スライドショー
 ================================================*/
.slide {
	padding: 0;
	overflow: hidden;
	position: relative;
}
.slideInner {
	list-style: none;
	margin: 0;
	padding: 0;
}
.slideInner li {
	position: absolute;
	width: 100%;
	margin: 0;
	padding: 0;
	background: linear-gradient(-45deg, #e1ebf5, #f0f0f0, #fffafa, #fbf5ee) fixed;
  background-size: 800% 800%;
  animation: GradietionAnimation 9s ease infinite;
	background-position: 50% 0;
	background-repeat: no-repeat;
}

@media screen and (min-width:768px) and (max-width:959px) {
.slideInner li {
	position: absolute;
	width: 100%;
	margin: 0;
	padding: 0;
	background: linear-gradient(-45deg, #e1ebf5, #f0f0f0, #fffafa, #fbf5ee) fixed;
  background-size: 800% 800%;
  animation: GradietionAnimation 9s ease infinite;
	background-position: 50% 0;
	background-repeat: no-repeat;
}
}

@media screen and (max-width:767px) {
.slide {
	padding: 0;
	overflow: hidden;
	position: relative;
	margin: 0;
}
	
	.slideInner li {
	position: absolute;
	width: 100%;
	margin: 0;
	padding: 0;
	background: linear-gradient(-45deg, #e1ebf5, #f0f0f0, #fffafa, #fbf5ee) fixed;
  background-size: 800% 800%;
  animation: GradietionAnimation 9s ease infinite;
	background-position: 50% 0;
	background-repeat: no-repeat;
}
}

/*================================================
 *  タブレット・スマートフォン向けデザイン
 ================================================*/
/* テンプレートより小さくなった場合に適用 */
@media screen and (max-width:979px) {
	.inner {
		width: 100%;
	}

	#contents {
		box-sizing: border-box;
		width: 100%;
		padding: 0 10px;
	}

	footer {
		width: 100%;
	}

	.lock {
		position: fixed;
		z-index: -1;
		width: 100%;
		height: 100%;
		top: 0;
		right: 0;
	}
}


/* スライド（ギャラリーループ：トップスライド) */

/* 1.親スタイルリセットとペース設定 ++++++++++ */
.slider-box3 p, .slider-box3 div, .loop-box3 ul, .loop-box3 li {
  box-sizing: border-box; margin: 0 !important; padding: 0 !important;
}

/* 2.ベースBOXの設定 +++++++++++++++++++++ */
.slider-box3 {
  box-sizing: border-box;
  overflow: hidden;
  width: 100%; /* 画面又は親要素に対するサイズ - 変更可 */
  background:none; /* 背景色 - 変更可・削除可 */
  margin: 0 auto 0 auto; /* Box外の余白 - 変更可 */
  padding: 0 0 0 0; /* 上端からスライダーまでの距離 - 変更可・削除可 */
	z-index: 9996;
	
}

/* 3.チェックボックスを利用した停止・再生などの設定 +++++++++++++++++ */
.slider-check3 {
  display: none;
}
.slider-check3:checked ~ .loop-box3 > .loop {
  animation-play-state: paused;
}
.slider-label3 {
  display: block;
  cursor: pointer;
  color: #fff; /* 文字色 - 変更可 */
  font-size: 90%; /* 文字サイズ - 変更可 */
  line-height: 2; /* ボタン部分の高さ - 変更可 */
  text-align: center;  
}
.slider-label3::before {
  content: "\025a0  STOP"; /* 停止テキスト - 変更可 */
  } 
.slider-check3:checked ~ div > .slider-label3::before {
  content: "\025b6  MOVE"; /* 再生テキスト - 変更可 */
}

/* 4.スライダー本体とアニメーションの基本設定 ++++++++++++++ */
.loop-box3{
  position: relative;
  width: 100%;
  overflow: hidden;
	background:none;
}
.loop-box3, .loop-box3 ul {
  height: 700px; /* スライダーの高さ - 変更注意 */

}
.loop-box3 ul {
  position: absolute; left: 0; top: 0;
  display: flex; 
  justify-content: space-between;
 background:none; /* スライダーの背景色 - 変更可 */
  list-style: none;
  max-width: 10000%; 
  min-width: 100%;
  width: calc(500px * 1.5 * 5); /* 画像の横幅×枚数 - 変更注意・変更可・変更注意 */
  animation: 150s linear infinite; /* アニメーション設定 - 変更可 */

}
.loop-box3 li {
  display: flex;
  align-items: center; 
  justify-content: center;
  color: #000;
  width: calc(96% / 5); /* li の幅を均等にする - 削除可・変更注意 */

}
.loop-box3 li img {
border-left: 10px solid #fff;

width: auto;
margin: 250px 0 0 0;

}

/* 5.アニメーション個別設定 ++++++++++ */
.loop-box3 ul.loop1 {
  animation-name: loop1;
}
.loop-box3 ul.loop2 {
  animation-name: loop2;
}
.loop-box3 ul.loop5 {
  animation-name: loop5;
}
.loop-box3 ul.loop6 {
  animation-name: loop6;
}
@keyframes loop1 {
  0% {transform: translateX(0); }
  49.99999% {transform: translateX(-100%); }
  50% {transform: translateX(100%); }
}
@keyframes loop2 {
  0% {transform: translateX(100%); }
  100%{transform: translateX(-100%); }
}
@keyframes loop5 {
  0% {transform: translateX(0); }
  49.99999% {transform: translateX(100%); }
  50% {transform: translateX(-100%); }
}
@keyframes loop6 {
  0% {transform: translateX(-100%); }
  100%{transform: translateX(100%); }
}

@media screen and (min-width:768px) and (max-width:959px) {

.loop-box3 li img {
border-left: 10px solid #fff;

width: auto;
margin: 178px 0 0 0;

}
}

@media screen and (max-width:767px) {
.loop-box3, .loop-box3 ul {
  height: 500px; /* スライダーの高さ - 変更注意 */

}
	
.loop-box3 li img {
border-left: 10px solid #fff;

width: auto;
margin: 50px 0 0 0;
}
}

 /*================================================
 *  パンくず
 ================================================*/
.cp_breadcrumb *, .cp_breadcrumb *:after, .cp_breadcrumb *:before {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	
}
.cp_breadcrumb {
	margin:  40px auto 0 auto;
	padding: 0;
	
	width: 96%;
	font-size: 80%;

}
.cp_breadcrumb a {
	text-decoration: none;

	
}
.cp_breadcrumb .breadcrumbs {
	padding-left: 0;
	margin-top: 0;
	margin-bottom: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	float: right;
	
}
.cp_breadcrumb li {
	display: inline-block;
	position: relative;
	padding-right: calc(10px + 20px);
	
	
}
.cp_breadcrumb li::before {
	content: '›';
	width: 1em;
	height: 1em;
	line-height: 1;
	text-align: center;
	font-size: 1em;
	color: inherit;
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	        transform: translateY(-50%);
}
.cp_breadcrumb li:last-child {
	margin-right: 0;
	padding-right: 0;
	
}
.cp_breadcrumb li:last-child::before {
	content: normal;
	
}

@media screen and (min-width:768px) and (max-width:959px) {
	.cp_breadcrumb *, .cp_breadcrumb *:after, .cp_breadcrumb *:before {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	
}
.cp_breadcrumb {
	margin: 0 auto 30px auto;
	padding: 0 0 20px 0;
	
	width:90%;
	
	font-size: 80%;

}
.cp_breadcrumb a {
	text-decoration: none;

	
}
.cp_breadcrumb .breadcrumbs {
	padding-left: 0;
	margin-top: 0;
	margin-bottom: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	float: right;
	
}
.cp_breadcrumb li {
	display: inline-block;
	position: relative;
	padding-right: calc(10px + 20px);
	
	
}
.cp_breadcrumb li::before {
	content: '›';
	width: 1em;
	height: 1em;
	line-height: 1;
	text-align: center;
	font-size: 1em;
	color: inherit;
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	        transform: translateY(-50%);
}
.cp_breadcrumb li:last-child {
	margin-right: 0;
	padding-right: 0;
	
}
.cp_breadcrumb li:last-child::before {
	content: normal;
	
}
}


@media screen and (max-width:767px) {
	
.cp_breadcrumb {
	margin: 0 auto 30px auto;
	padding: 0 1% 0 0;
	width: 97%;
	font-size: 73%;
	text-align: left;


}
.cp_breadcrumb .breadcrumbs {
	padding-left: 0;
	margin-top: 0;
	margin-bottom: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	float: right;
	
}	
	
.cp_breadcrumb li {
	display: inline-block;
	position: relative;
	padding-right: calc(6px + 6px);
	
	
}

}





@media screen and (max-width:767px) {



}

 /*================================================
 *  クリックで開閉：アクション（受講内容：ジャンル）講師
 ================================================*/

/*ベース*/
.toggle {
	display: none;
}
.Label {		/*タイトル*/
	padding: 50px 0 0 0;
	display: block;
	color: #000;
	border-top:2px dotted #c0c0c0; 
	width: 100%;
	margin: 0;
background: #fff;
	font-weight: bold;
	
}
.Label::before{		/*タイトル横の矢印*/
	content:"";
	width: 10px;
	height: 10px;
	border-top: 4px solid #000;
	border-right: 4px solid #000;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 3px );
	right: 10px;
	transform: rotate(135deg);
	

}
.Label,
.content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
	width: 100%;
	padding: 30px 0 0 0;
margin: 40px 0 0 0;
}
.content {		/*本文*/
	height: 0;
	margin-bottom:10px;
	padding:0;
	overflow: hidden;
	font-size: 110%;
}


.toggle:checked + .Label + .content {	/*開閉時*/
	height: auto;
	padding:30px 0 10px 0;
	transition: all .3s;
	margin: 0;
}
.toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}

 /*================================================
 *  フワフワの動き
 ================================================*/
@keyframes fuwafuwa {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}

/* このクラスをつけると回転を無限に繰り返します */
.anime-fuwafuwa {
  animation: 3s fuwafuwa infinite;
}


.balloon {

 opacity: 0.98;


}


@media screen and (min-width:768px) and (max-width:959px) {
.balloon {
    
	width: 70%;
	float: right;
	
}

}

@media screen and (max-width:767px) {
.balloon {
    
	width: 96%;
	border-radius: 80px;
	padding: 40px;
	float: none;
	margin: 0 0 0 10px;

}
}

/* Loading背景画面設定　*/
@charset "utf-8";


 /*================================================
 * index.html
 ================================================*/

/* メイン画像：pc*/

.imageBox {
	
  width: 100%;
  
	margin: 0 0 0 auto;

	
	
	

}

/* メイン画像：tab*/

@media screen and (min-width:768px) and (max-width:959px) {
.imageBox {


width: auto;


}
	
}

/* メイン画像：sp*/

@media screen and (max-width:767px) {
	
.imageBox {
width: auto;
	


}
	
	
}


/* メインスライド：pc*/


.movieText{
	
	position: absolute;
  top: 140px;

	left: 210px;
z-index: 9997;
width: auto;
	height: auto;


	}


.movieText h2{
font-size: 110%;
    letter-spacing: 0.1em;
margin: 0;
	font-weight: bold;	


	}

.movieText h3{

margin: 0 0 0 -5px;
	padding: 0;
font-family: 'Rowdies', sans-serif;
	line-height: 1.2;
font-size: 450%;
	letter-spacing: 0.02em;
	



	}


.movieText h3 span{

font-size: 80%;

    letter-spacing: 0.1em;
margin: 0;
	padding: 0;

	line-height: 1.4;
	font-weight: bold;



	}





.movieText .btn a {
position: relative;
	display: inline-block;
	padding: 12px 20px;
	margin: 10px 0 0 -5px;
width: auto;


	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

.movieText .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}



.character{
	
	position: absolute;
  top:115px;
  left:30px;
z-index: 9997;
width: 163px;
	height: 163px;
background:url("../images/character.png") no-repeat;
	background-position: top center;
	background-size: 95%;
	
}

/* メインスライド：tab*/

@media screen and (min-width:768px) and (max-width:959px) {
	
/* メインスライド内タイトル、副題、カテゴリー tab*/	



.movieText{
	
	position: absolute;
  top: 125px;

	left: 175px;
z-index: 9997;
width: auto;
	height: auto;


	}


.movieText h2{
font-size: 110%;
    letter-spacing: 0.1em;
margin: 0;

	font-weight: bold;	


	}

.movieText h3{

font-size: 380%;
font-family: 'Rowdies', sans-serif;
    letter-spacing: 0.03em;
margin: 0 0 0 -5px;
	padding: 0;

	line-height: 1.2;
	font-weight: bold;



	}


.movieText h3 span{

font-size: 80%;

    letter-spacing: 0.1em;
margin: 0;
	padding: 0;

	line-height: 1.4;
	font-weight: bold;



	}

.movieText .subttl{
	font-weight: bold;
	letter-spacing: 2px;
	margin: 0 0 50px 0;
	font-size:110%;

	}

.movieText p{
	font-weight: bold;
	letter-spacing: 2px;
	margin: 20px auto 0 0;
	font-size:105%;
	padding: 10px 0  ;
border-top: 1px dotted #ccc;
		border-top: double 5px #000;    	/* 内側の線になる一本線の枠線をひく*/


	
	outline-offset: 1px;        /* 内側の線になる一本線の枠線をひく*/
	            	/* outlineの値＋outline-offsetの値*/
	line-height: 2.2;

	width: 70%;
	}



.movieText .btn a {
position: relative;
	display: inline-block;
	padding: 12px 20px;
	margin: 10px 0 0 -5px;
width: auto;


	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

.movieText .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}



.character{
	
	position: absolute;
  top:111px;
  left:10px;
z-index: 9997;
width: 153px;
	height: 153px;
background:url("../images/character.png") no-repeat;
	background-position: top center;
	background-size: 80%;
	
}
}


/* メインスライド：sp*/

@media screen and (max-width:767px) {


	
/* メインスライド内タイトル、副題、カテゴリー（sp）*/	


.movieText{
	
	position: absolute;
  top: 340px;
padding: 15px;
	left: 0;
z-index: 9997;
width: 85%;
	height: auto;
	background: #fff;
	opacity: 0.9;
border-radius: 0 20px 20px 0;

	}


.movieText h2{
font-size: 95%;
    letter-spacing: 0.05em;
margin: 0 0 10px 0;
text-align: left;
	font-weight: bold;	


	}

.movieText h3{

font-size: 200%;
font-family: 'Rowdies', sans-serif;
    letter-spacing: 0;
margin: 0;
	padding: 0;
text-align: left;
	line-height: 1.2;
	font-weight: bold;


	}


.movieText h3 span{

font-size: 80%;

    letter-spacing: 0.1em;
margin: 0;
	padding: 0;

	line-height: 1.4;
	font-weight: bold;



	}




.movieText .btn a {
display: none;
	
}

.movieText .btn a:hover {
display: none;
}
	
.character{
	
	position: absolute;
  top:450px;
  left:60%;
z-index: 9998;
width: 130px;
	height: 135px;
background:url("../images/character.png") no-repeat;
	background-position: top center;
	background-size: 100%;
	
	
}
}

/*========= スクロールダウンのためのCSS ===============*/

/*=== 9-1-2 丸が動いてスクロールを促す ====*/

/*スクロールダウン全体の場所*/
.scrolldown2{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:40px;
 right:5%;
z-index: 9998;
	
}

/*Scrollテキストの描写*/
.scrolldown2 span{
    /*描画位置*/
  position: absolute;
  left:10px;
  bottom:10px;
    /*テキストの形状*/
  color: #333;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  /*縦書き設定*/
  -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
}

/* 丸の描写 */
.scrolldown2:before {
    content: "";
    /*描画位置*/
    position: absolute;
    bottom:0;
    left:-4px;
    /*丸の形状*/
  width:10px;
  height:10px;
  border-radius: 50%;
  background:#333;
    /*丸の動き1.6秒かけて透過し、永遠にループ*/
  animation:
    circlemove 1.6s ease-in-out infinite,
    cirlemovehide 1.6s ease-out infinite;
}

/*下からの距離が変化して丸の全体が上から下に動く*/
@keyframes circlemove{
      0%{bottom:45px;}
     100%{bottom:-5px;}
 }

/*上から下にかけて丸が透過→不透明→透過する*/
@keyframes cirlemovehide{
      0%{opacity:0}
     50%{opacity:1;}
    80%{opacity:0.9;}
  100%{opacity:0;}
 }

/* 線の描写 */
.scrolldown2:after{
  content:"";
    /*描画位置*/
  position: absolute;
  bottom:0;
  left:0;
    /*線の形状*/
  width:2px;
  height: 50px;
  background:#333;
}


@media screen and (max-width:767px) {
.scrolldown2{
    /*描画位置※位置は適宜調整してください*/
  display: none;
}
	
}


/* news ニュース：pc*/

#news {
	padding:30px 8% 0 8%;
	margin: 0 auto 0 auto;
	width:auto;
	position: relative;
	
	z-index: 9998;
	
	

}

#news h2{
	
font-size: 530%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0;

	line-height: 1.4;
	font-weight: bold;

}

#news h3{
	font-weight: bold;
	font-size: 110%;
	margin:10px 0 15px 1%;
	letter-spacing: 2px;
	
	
}

#news h4{
	font-weight: bold;
	font-size: 110%;
	margin: 0 auto 5px auto;
	letter-spacing: 1px;
	
	
}

#news h5{
	font-weight: bold;
	font-size: 140%;
	color: #000;
	letter-spacing: 1px;
	text-align: center;
	margin: 30px 0 10px 0;
	
	
}



#news .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 1% ;

}




#news .flame_l{

	width: 30%;
float:left;
	margin: 50px 30px 0 0;

padding: 0;

	height: auto;

}



#news .flame_l p{
	
	
	margin: 0 0 10px 1%;
	
	text-align: left;
	font-size: 98%;
	

	

}

#news .flame_r{
padding: 0;
	width: 64%;
float:right;
	margin: 50px 0 0 0;

}


#news .flame_r p{
	
	text-align: left;
		font-size: 98%;
	letter-spacing: 0.8px;
	

	margin: 5px 0 10px 0;
	

}



#news .flame_r ul{
	
	margin: 0;

}


#news .flame_r ul li{
	
	width: auto;
	height: auto;
	margin: 0;
	padding: 20px 0 ;
	
	
	font-size: 98%;
	list-style-type: none;
	border-top: 1px dotted #333;
	

	

}

#news .flame_r ul li:first-child {
		border-top: none;
	}

#news .flame_r time {
	
	padding: 5px 0;
	margin: 0 17px 0 0;
	font-size: 98%;
	width: auto;
	
	float: left;
	 border: none;
}

#news .flame_r .category {
	
	padding: 2px 5px;
	font-size: 81%;
	margin: 3px 17px 0 0;
	
	width: 14%;
	text-align: center;
	float: left;
	border-radius: 20px;
	border: 3px solid #333;
	
	
	
	
}



/* sns*/


#news .btn a {
		position: relative;
	display: inline-block;
	padding:4px 5px 0 5px;
	border: 3px solid #ca1a1d;
	float: right;
	font-size: 120%;
	background: #ca1a1d;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 10px 10px 0 0;
font-weight:bold;
	
}

#news .btn a:hover {
	background: #fff;
	color: #000;
	border: 3px solid #000;
}



/* news ニュース：tab*/

@media screen and (min-width:768px) and (max-width:959px) {
#news {
	padding:0 4%;
	margin: 0 auto 0 auto;
	width:auto;
	position: relative;
	z-index: 9998;

}

#news h2{
	
font-size: 380%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0 0 0 -3px;

	line-height: 1.4;
	font-weight: bold;

}

#news h3{
	font-weight: bold;
	font-size: 110%;
	margin:0 0 20px 0;
	letter-spacing: 2px;
	
	
}



#news .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 20px 0 ;

}




#news .flame_l{

	width: auto;
float:none;
	margin: 0;

padding: 0;
height: auto;
	
}



#news .flame_l p{
	
	
	margin: 0 0 10px 1%;
	
	text-align: left;
	font-size: 98%;

}

#news .flame_r{
padding: 0;
	width: auto;
float:none;
	margin: 0;

}


#news .flame_r p{
	
	text-align: left;
		font-size: 98%;
	letter-spacing: 0.8px;
	margin: 5px 0 10px 0;
}



#news .flame_r ul{
	
	margin: 0;

}


#news .flame_r ul li{
	
	width: auto;
	height: auto;
	margin: 0;
	padding: 20px 0 ;
	
	
	font-size: 98%;
	list-style-type: none;
	border-top: 1px dotted #333;

}

#news .flame_r ul li:first-child {
		border-top: none;
	}

#news .flame_r time {
	
	padding: 5px 0;
	margin: 0 17px 0 0;
	font-size: 98%;
	width: auto;
	
	float: left;
	 border: none;
}

#news .flame_r .category {
	
	padding: 2px 5px;
	font-size: 90%;
	margin: 3px 17px 0 0;
	
	width: 14%;
	text-align: center;
	float: left;
	border-radius: 20px;
	border: 3px solid #333;
	
	
	
	
}



/* sns*/


#news .btn a {
		position: relative;
	display: inline-block;
	padding:4px 5px 0 5px;
	border: 3px solid #ca1a1d;
	float: right;
	font-size: 120%;
	background: #ca1a1d;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 10px 10px 0 0;
font-weight:bold;
	
}

#news .btn a:hover {
	background: #fff;
	color: #000;
	border: 3px solid #000;
}


}

/* news ニュース：sp*/

@media screen and (max-width:767px) {
#news {
	padding:0 4%;
	margin: 10px auto 0 auto;
	width:auto;
	position: relative;
	z-index: 9998;
	

}

#news h2{
	
font-size: 300%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0 0 0 -3px;

	line-height: 1.4;
	font-weight: bold;

}

#news h3{
	font-weight: bold;
	font-size: 110%;
	margin:0 0 20px 0;
	letter-spacing: 2px;

	
}



#news .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 20px 0 ;

}




#news .flame_l{

	width: auto;
float:none;
	margin: 0;

padding: 0;
height: auto;
}





#news .flame_r{
padding: 0;
	width: auto;
float:none;
	margin: 0;

}


#news .flame_r p{
	
	text-align: left;
		font-size: 98%;
	letter-spacing: 0.8px;
	margin: 5px 0 10px 0;

}





#news .flame_r .list{
width: auto;
	margin: 0 auto;
	text-align: left;
	float: none;

}



#news .flame_r .list ul{
	
	margin: 20px 0 ;

}


#news .flame_r .list ul li{
	float: none;
	width: 100%;
	height: auto;
	margin: 10px 0 0 0;
	padding: 20px 0 ;

	font-size: 100%;

}
	
#news .flame_r .list ul li p{
	
	height: auto;
	margin: 10px 0 0 0;
	
	font-size: 100%;

}

#news .flame_r .list ul li:last-child {
		border-bottom: none;
	}
#news .flame_r .list time {
	
	padding: 0;
	margin: 0 15px 0 0;
	font-size: 100%;
	width: auto;
	
	float: left;
	 border: none;
}

#news .flame_r .list .category {
	
	padding: 5px 10px ;
	font-size: 90%;
	margin: 0 0 20px 0;
	
	width: auto;
	text-align: center;
	float: none;
	border-radius: 50px;
	border: 2px solid #333;
	color: #333;
	
	
	
}


#news .flame_r .list ul li .ttl{
	text-align:center;
	font-weight:bold;
	margin:20px 0 10px 0;
	border-bottom: #000 dotted 1px;
	padding: 10px 0;
	font-size: 120%;
}


/* sns*/


#news .btn a {
		position: relative;
	display: inline-block;
	padding:4px 5px 0 5px;
	border: 3px solid #ca1a1d;
	float: right;
	font-size: 120%;
	background: #ca1a1d;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 10px 10px 0 0;
font-weight:bold;
	
}

#news .btn a:hover {
	background: #fff;
	color: #000;
	border: 3px solid #000;
}

}


/* CSSアニメーションの指定 */
.Headline{
  animation: SlideIn 1.6s infinite;
}

/* CSSアニメーションの設定 */
@keyframes SlideIn {
  0% {
    opacity: 0;/*初期状態では透明に*/
    transform: translateX(64px);
  }
  100% {
    opacity: 1;
    transform: translateX(1);
  }
}


/* info右欄：記事スライダー */
  .l-inner {
    position: relative;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0;
	  
  }

  .l-section {
   
  }
  .l-section .l-inner {
    padding-top: 3rem;
    padding-bottom: 2rem;
	
  }

  [class*=swiper]:focus {
    outline: none;
  }

  .slide-media,
  .thumb-media {
    position: relative;
    overflow: hidden;
  }
  .slide-media img,
  .thumb-media img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
	 
  }


  .swiper-button-prev, .swiper-button-next {
    display: grid;
    place-content: center;
    width: 6.4rem;
    height: 6.4rem;
    cursor: pointer;
    -webkit-transition: var(--transition);
    transition: var(--transition);
	
  }
  .swiper-button-prev::before, .swiper-button-next::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: "";
    border-radius: 50%;
    -webkit-box-shadow: var(--box-shadow);
            box-shadow: var(--box-shadow);
	  
	  
  }
  .swiper-button-prev::after, .swiper-button-next::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border: solid var(--color-gray);
    border-width: 3px 3px 0 0;
	  
  }
  .swiper-button-prev::after {
    margin-left: 0;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
	
  }
  .swiper-button-next::after {
    margin-right: 0;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
	  
	  
  }
  .swiper-button-disabled {
    pointer-events: none;
    opacity: 0;
  }

  .card02 {
    overflow: hidden;
  }
  .card02 .swiper {
    overflow: visible;
  }
  .card02 .swiper-controller {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: 1.6rem;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    margin-top: 2rem;
	  
  }
  .card02 .swiper-pagination {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    gap: 1.2rem 0.8rem;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    margin: 0 auto 0 0;
    text-align: center;
	  
  }
  .card02 .swiper-pagination-bullet {
    width: 1.6rem;
    height: 3px;
    cursor: pointer;
    -webkit-transition: var(--transition);
    transition: var(--transition);
    vertical-align: top;
    background: #000;
	 border-radius: 50px;
  }
  .card02 .swiper-pagination-bullet-active {
    width: 3rem;
 
	   background: #000;
  }
  .card02 .swiper-button-prev, .card02 .swiper-button-next {
    position: relative;
    -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
            flex-shrink: 0;
    margin: 0 5px;
	 
	
	 
  }
  .card02 .swiper-button-disabled {
    pointer-events: none;
    opacity: 0.5;

	  
  }
  .card02 .swiper-button-disabled::before {
    -webkit-box-shadow: var(--box-shadow-inset);
            box-shadow: var(--box-shadow-inset);
	  
  }
  .card02 .swiper-slide {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
	   box-shadow: 0 2px 2px rgba(0,0,0,0.10);
  transition: .3s;
  }
  .card02 .slide {
    overflow: hidden;
    width: 13rem;
    border-radius: 4px;
    -webkit-box-shadow: var(--box-shadow);
            box-shadow: var(--box-shadow);
	box-shadow: 0 0.3px 1px rgba(0,0,0,0.12);
  transition: .3s;
	  
  }
  .card02 .slide-media {
    padding-top: 62.5%;
	 
  }
  .card02 .slide-media img {
    height: calc(100% + 16px);
    -webkit-transform: translateY(-16px);
            transform: translateY(-16px);
  }
  .card02 .slide-content {
    padding: 0.7rem;

  }
  .card02 .slide-date {
    font-size: 0.4rem;
    line-height: 2;
   
    color: var(--color-theme);
	  margin: 0 0 0 0;
	  font-weight: bold;

	  text-align: right;
	
	
	  
  }
  .card02 .slide-title {
    line-height: 1.6;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
   
    margin-top: 3rem;
	  width: auto;
	  
  }



  @media only screen and (max-width: 1024px) {
    html {
      -webkit-text-size-adjust: 100%;
    }
    .l-inner {
      padding: 0 2.5rem;
    }
    .pc {
      display: none !important;
    }
  }

  @media only screen and (max-width: 599px) {
    html {
      font-size: 50%;
    }
    .pc-tab {
      display: none !important;
    }
    .card02 .slide {
      width: 24rem;
    }
  }

  @media only screen and (min-width: 1025px) {
    .tab-sp {
      display: none !important;
    }
    .swiper-button-prev::before, .swiper-button-next::before {
      -webkit-transition: var(--transition);
      transition: var(--transition);
    }
    .swiper-button-prev:hover::before, .swiper-button-next:hover::before {
      -webkit-transform: scale(1.2);
              transform: scale(1.2);
    }
    .card02 .slide {
      -webkit-transition: var(--transition);
      transition: var(--transition);
    }
    .card02 .slide img {
      -webkit-transition: var(--transition);
      transition: var(--transition);
    }
    .card02 .slide:hover {
      -webkit-transform: translateY(-16px);
              transform: translateY(-16px);
      -webkit-box-shadow: var(--box-shadow-hover);
              box-shadow: var(--box-shadow-hover);
    }
    .card02 .slide:hover img {
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }

  @media only screen and (min-width: 600px) {
    .sp {
      display: none !important;
    }
  }



/* 福岡校スケジュール開閉*/
#flame_list{
	font-size: 110%;
	text-align:center;
	margin: 40px auto 40px auto;
	
	padding: 20px 0;
	border: 4px solid #dcdcdc;
	border-radius: 10px;
	width: 82%;

}

#flame_list img{
	
	margin: 0 auto 20px auto;
	

}

#flame_list a{
	

}

#flame_list a:hover{
	opacity: 0.9;
	

}

@media screen and (min-width:768px) and (max-width:959px) {
#flame_list{
	font-size: 110%;
	text-align:center;
	margin: 30px 0 30px 18px;
	
	padding: 20px;
	border: 4px solid #dcdcdc;
	border-radius: 10px;
		width: 90.2%;

}
}

@media screen and (max-width:767px) {
	#flame_list{
	font-size: 110%;
	text-align:center;
	margin: 0 0 0 3%;
	color: #000;
	padding: 20px 10px;
	border: 4px solid #dcdcdc;
	border-radius: 10px;
		width: 87%;

}
	
	
}


/* 画像回転（拡大）*/

#circle {
	width: 905px;
	height: 913px;
	top:300px;
	left: -90px;
	margin: 0;
	position:absolute;
	background:url("../images/bg_circle.png") no-repeat;
	animation: r1 10s linear infinite;

  animation-duration: 30s;

  animation-iteration-count: infinite;


}
@keyframes r1 {
  0%   { transform: rotate(0); }
  100% { transform: rotate(-360deg); }
}


@media screen and (min-width:768px) and (max-width:959px) {
#circle {
width: 605px;
	height: 605px;
	top:730px;
	left: -90px;
	margin: 0;
	position:absolute;
	background:url("../images/bg_circle_tab.png") no-repeat;

	animation: r1 10s linear infinite;

  animation-duration: 30s;

  animation-iteration-count: infinite;
	

}
	
}


@media screen and (max-width:767px) {
#circle {
	
width: 400px;
	height: 400px;
	top:900px;
	left: -90px;
	margin: 0;
	position:absolute;
	background:url("../images/bg_circle_sp.png") no-repeat;

	animation: r1 10s linear infinite;

  animation-duration: 30s;

  animation-iteration-count: infinite;
	

}

	
}
	




.circle-4 {
  background: #f7f7f7;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 320px;
  height: 320px;

  mix-blend-mode: multiply;
position:absolute; top:-50px; left:-40px; z-index: 1;
	
	
}




.circle-5 {
  background: #f0f6da;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 500px;
  height: 500px;

  mix-blend-mode: multiply;
position:absolute; top:-50px; left:300px; z-index: 1;
	
	
}


/* Animation */
@keyframes border-animation {
  to { transform: rotate(360deg); }
}


.loop_css3 {
    position: relative;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: 98vw;
    height: 50vw;
   
    overflow: hidden;
  }

  .loop_css3 div {
    flex: 0 0 auto;
    padding: 0 12px;
   font-size: 20rem;
    margin: 0;
	 font-family:'Helvetica',sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #fed878 0%, #fa505e 100%);
  background: -webkit-linear-gradient(-45deg, #fed878 0%, #fa505e 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	 
	  opacity: 0.3;
  }

@media screen and (min-width:768px) and (max-width:959px) {
	.loop_css3 div {
    flex: 0 0 auto;
    padding: 0 12px;
     font-size: 10rem;
    margin: 0;
	 font-family:'Helvetica',sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #fed878 0%, #fa505e 100%);
  background: -webkit-linear-gradient(-45deg, #fed878 0%, #fa505e 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	 
	  opacity: 0.3;
  }

}

@media screen and (max-width:767px) {
    .loop_css3 div {
     display: none;
		
    }
  }

  .loop_css3 div:nth-child(odd) {
    -webkit-animation: loop3 50s -25s linear infinite;
    animation: loop3 50s -25s linear infinite;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
  }

  .loop_css3 div:nth-child(even) {
    -webkit-animation: loop4 50s  linear infinite;
    animation: loop4 50s linear infinite;
  }

  @-webkit-keyframes loop3 {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
  }

  @keyframes loop3 {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
  }

  @-webkit-keyframes loop4 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
  }

  @keyframes loop4 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
  }




/* イメージ動画 */

#movieBox {
	
	
	text-align: center;
margin: 120px 0;
	
}


#movieBox iframe {
	width: 950px;
	height: 600px;
	background-color: #ECECEC;
background-image: -webkit-gradient(linear, 0 0, 100% 100%,color-stop(.25, #F9F9F9), color-stop(.25, transparent),color-stop(.5, transparent), color-stop(.5, #F9F9F9),color-stop(.75, #F9F9F9), color-stop(.75, transparent),to(transparent));
-webkit-background-size: 14px 14px;
		padding:15px;
	border-radius: 10px;
	
}





@media screen and (min-width:768px) and (max-width:959px) {
	
#movieBox {

	text-align: center;
margin: 100px 0 100px 0;
	
}


#movieBox iframe {
	
	width: 88%;
	height: 480px;
	background-color: #ECECEC;
background-image: -webkit-gradient(linear, 0 0, 100% 100%,color-stop(.25, #F9F9F9), color-stop(.25, transparent),color-stop(.5, transparent), color-stop(.5, #F9F9F9),color-stop(.75, #F9F9F9), color-stop(.75, transparent),to(transparent));
-webkit-background-size: 14px 14px;
		padding:15px;
	border-radius: 10px;
	
	
}
}


@media screen and (max-width:767px) {

#movieBox {
	margin: 100px auto 0 auto;
	text-align: center;
	padding: 0 0 80px 0;
	width: auto;
}
	
#movieBox iframe {
	width: 92%;
	height: 300px;
	background-color: #fff;
	box-shadow: 5px 5px 10px #dcdcdc;
-webkit-box-shadow: 5px 5px 10px #dcdcdc;
-moz-box-shadow: 5px 5px 10px #dcdcdc;
	
		padding:4px;
	border-radius: 0;
	transform: rotateZ(-360deg);
}
}









/* スライド（ギャラリーループ) */

/* 1.親スタイルリセットとペース設定 ++++++++++ */
.slider-box p, .slider-box div, .loop-box ul, .loop-box li {
  box-sizing: border-box; margin: 0 !important; padding: 0 !important;
}

/* 2.ベースBOXの設定 +++++++++++++++++++++ */
.slider-box {
  box-sizing: border-box;
  overflow: hidden;
  width: 100%; /* 画面又は親要素に対するサイズ - 変更可 */
  background:none; /* 背景色 - 変更可・削除可 */
  margin: 0 auto; /* Box外の余白 - 変更可 */
  padding: 0; /* 上端からスライダーまでの距離 - 変更可・削除可 */


}

/* 3.チェックボックスを利用した停止・再生などの設定 +++++++++++++++++ */
.slider-check {
  display: none;
}
.slider-check:checked ~ .loop-box > .loop {
  animation-play-state: paused;
}
.slider-label {
  display: block;
  cursor: pointer;
  color: #fff; /* 文字色 - 変更可 */
  font-size: 90%; /* 文字サイズ - 変更可 */
  line-height: 2; /* ボタン部分の高さ - 変更可 */
  text-align: center;  
}
.slider-label::before {
  content: "\025a0  STOP"; /* 停止テキスト - 変更可 */
  } 
.slider-check:checked ~ div > .slider-label::before {
  content: "\025b6  MOVE"; /* 再生テキスト - 変更可 */
}

/* 4.スライダー本体とアニメーションの基本設定 ++++++++++++++ */
.loop-box{
  position: relative;
  width: 100%;
  overflow: hidden;
	background:none;
}
.loop-box, .loop-box ul {
  height: 200px; /* スライダーの高さ - 変更注意 */
	margin: 0;
}
.loop-box ul {
  position: absolute; left: 0; top: 0;
  display: flex; 
  justify-content: space-between;
 background:none; /* スライダーの背景色 - 変更可 */
  list-style: none;
  max-width: 10000%; 
  min-width: 100%;
  width: calc(290px * 1.5 * 5); /* 画像の横幅×枚数 - 変更注意・変更可・変更注意 */
  animation: 80s linear infinite; /* アニメーション設定 - 変更可 */

}
.loop-box li {
  display: flex;
  align-items: center; 
  justify-content: center;
  color: #000;
  width: calc(96% / 5); /* li の幅を均等にする - 削除可・変更注意 */

	
}
.loop-box img {
  height:auto;
  width: auto;
margin: 0;
	
}

/* 5.アニメーション個別設定 ++++++++++ */
.loop-box ul.loop1 {
  animation-name: loop1;
}
.loop-box ul.loop2 {
  animation-name: loop2;
}
.loop-box ul.loop5 {
  animation-name: loop5;
}
.loop-box ul.loop6 {
  animation-name: loop6;
}
@keyframes loop1 {
  0% {transform: translateX(0); }
  49.99999% {transform: translateX(-100%); }
  50% {transform: translateX(100%); }
}
@keyframes loop2 {
  0% {transform: translateX(100%); }
  100%{transform: translateX(-100%); }
}
@keyframes loop5 {
  0% {transform: translateX(0); }
  49.99999% {transform: translateX(100%); }
  50% {transform: translateX(-100%); }
}
@keyframes loop6 {
  0% {transform: translateX(-100%); }
  100%{transform: translateX(100%); }
}


@media screen and (max-width:767px) {
.slider-check {
  display: none;
}
.slider-check:checked ~ .loop-box > .loop {
  animation-play-state: paused;
}
.slider-label {
  display: block;
  cursor: pointer;
  color: #fff; /* 文字色 - 変更可 */
  font-size: 90%; /* 文字サイズ - 変更可 */
  line-height: 2; /* ボタン部分の高さ - 変更可 */
  text-align: center;  
}
.slider-label::before {
  content: "\025a0  STOP"; /* 停止テキスト - 変更可 */
  } 
.slider-check:checked ~ div > .slider-label::before {
  content: "\025b6  MOVE"; /* 再生テキスト - 変更可 */
}

/* 4.スライダー本体とアニメーションの基本設定 ++++++++++++++ */
.loop-box{
  position: relative;
  width: 100%;
  overflow: hidden; 
	
}
.loop-box, .loop-box ul {
  height: 185px; /* スライダーの高さ - 変更注意 */

}
.loop-box ul {
  position: absolute; left: 0; top: 0;
  display: flex; 
  justify-content: space-between;
  background: #fff; /* スライダーの背景色 - 変更可 */
  list-style: none;
  max-width: 10000%; 
  min-width: 100%;
  width: calc(450px * 1.5 * 3); /* 画像の横幅×枚数 - 変更注意・変更可・変更注意 */
  animation: 50s linear infinite; /* アニメーション設定 - 変更可 */
	
}
.loop-box li {
  display: flex;
  align-items: center; 
  justify-content: center;
  color: #000;
  width: calc(100% / 4); /* li の幅を均等にする - 削除可・変更注意 */
}
.loop-box img {
  height:auto;
  width: auto;
	border-radius: 0;
	
}
	

}
/* スライド（ギャラリーループ) aboutの下*/

/* 1.親スタイルリセットとペース設定 ++++++++++ */
.slider-box1 p, .slider-box1 div, .loop-box1 ul, .loop-box1 li {
  box-sizing: border-box; margin: 0 !important; padding: 0 !important;
}

/* 2.ベースBOXの設定 +++++++++++++++++++++ */
.slider-box1 {
  box-sizing: border-box;
  overflow: hidden;
  width: 100%; /* 画面又は親要素に対するサイズ - 変更可 */
  background:#fff; /* 背景色 - 変更可・削除可 */
  margin:0 auto 0 auto; /* Box外の余白 - 変更可 */
  padding: 0 0 0 0; /* 上端からスライダーまでの距離 - 変更可・削除可 */

}

/* 3.チェックボックスを利用した停止・再生などの設定 +++++++++++++++++ */
.slider-check1 {
  display: none;
}
.slider-check1:checked ~ .loop-box > .loop {
  animation-play-state: paused;
}
.slider-label1 {
  display: block;
  cursor: pointer;
  color: #fff; /* 文字色 - 変更可 */
  font-size: 90%; /* 文字サイズ - 変更可 */
  line-height: 2; /* ボタン部分の高さ - 変更可 */
  text-align: center;  
}
.slider-label1::before {
  content: "\025a0  STOP"; /* 停止テキスト - 変更可 */
  } 
.slider-check1:checked ~ div > .slider-label1::before {
  content: "\025b6  MOVE"; /* 再生テキスト - 変更可 */
}

@media screen and (min-width:768px) and (max-width:959px) {
/* 2.ベースBOXの設定 +++++++++++++++++++++ */
.slider-box1 {
  box-sizing: border-box;
  overflow: hidden;
  width: 100%; /* 画面又は親要素に対するサイズ - 変更可 */
  background:#fff; /* 背景色 - 変更可・削除可 */
  margin:0 auto 0 auto; /* Box外の余白 - 変更可 */
  padding:0; /* 上端からスライダーまでの距離 - 変更可・削除可 */

}
}

@media screen and (max-width:767px) {
/* 2.ベースBOXの設定 +++++++++++++++++++++ */
.slider-box1 {
  box-sizing: border-box;
  overflow: hidden;
  width: 100%; /* 画面又は親要素に対するサイズ - 変更可 */
  background:#fff; /* 背景色 - 変更可・削除可 */
  margin:0 auto 0 auto; /* Box外の余白 - 変更可 */
  padding: 0; /* 上端からスライダーまでの距離 - 変更可・削除可 */

}
}

/* 4.スライダー本体とアニメーションの基本設定 ++++++++++++++ */
.loop-box1{
  position: relative;
  width: 100%;
  overflow: hidden;
	
}
.loop-box1, .loop-box1 ul {
  height: 300px; /* スライダーの高さ - 変更注意 */
}
.loop-box1 ul {
  position: absolute; left: 0; top: 0;
  display: flex; 
  justify-content: space-between;
  background:#fff; /* スライダーの背景色 - 変更可 */
  list-style: none;
  max-width: 10000%; 
  min-width: 100%;
  width: calc(400px * 1.5 * 5); /* 画像の横幅×枚数 - 変更注意・変更可・変更注意 */
  animation: 80s linear infinite; /* アニメーション設定 - 変更可 */
	

}
.loop-box1 li {
  display: flex;
  align-items: center; 
  justify-content: center;
  color: #000;
  width: calc(96% / 5); /* li の幅を均等にする - 削除可・変更注意 */
	
}
.loop-box1 img {
  height:auto;
  width: auto;

	
}

/* 5.アニメーション個別設定 ++++++++++ */
.loop-box1 ul.loop1 {
  animation-name: loop1;
}
.loop-box1 ul.loop2 {
  animation-name: loop2;
}
.loop-box1 ul.loop5 {
  animation-name: loop5;
}
.loop-box1 ul.loop6 {
  animation-name: loop6;
}
@keyframes loop1 {
  0% {transform: translateX(0); }
  49.99999% {transform: translateX(-100%); }
  50% {transform: translateX(100%); }
}
@keyframes loop2 {
  0% {transform: translateX(100%); }
  100%{transform: translateX(-100%); }
}
@keyframes loop5 {
  0% {transform: translateX(0); }
  49.99999% {transform: translateX(100%); }
  50% {transform: translateX(-100%); }
}
@keyframes loop6 {
  0% {transform: translateX(-100%); }
  100%{transform: translateX(100%); }
}


@media screen and (max-width:767px) {
.slider-check {
  display: none;
}
.slider-check1:checked ~ .loop-box1 > .loop {
  animation-play-state: paused;
}
.slider-label1 {
  display: block;
  cursor: pointer;
  color: #fff; /* 文字色 - 変更可 */
  font-size: 90%; /* 文字サイズ - 変更可 */
  line-height: 2; /* ボタン部分の高さ - 変更可 */
  text-align: center;  
}
.slider-label1::before {
  content: "\025a0  STOP"; /* 停止テキスト - 変更可 */
  } 
.slider-check1:checked ~ div > .slider-label1::before {
  content: "\025b6  MOVE"; /* 再生テキスト - 変更可 */
}

/* 4.スライダー本体とアニメーションの基本設定 ++++++++++++++ */
.loop-box1{
  position: relative;
  width: 100%;
  overflow: hidden; 
	
}
.loop-box1, .loop-box1 ul {
  height: 225px; /* スライダーの高さ - 変更注意 */
}
.loop-box1 ul {
  position: absolute; left: 0; top: 0;
  display: flex; 
  justify-content: space-between;
  background: #fff; /* スライダーの背景色 - 変更可 */
  list-style: none;
  max-width: 10000%; 
  min-width: 100%;
  width: calc(250px * 1.5 * 3); /* 画像の横幅×枚数 - 変更注意・変更可・変更注意 */
  animation: 50s linear infinite; /* アニメーション設定 - 変更可 */
	
}
.loop-box1 li {
  display: flex;
  align-items: center; 
  justify-content: center;
  color: #000;
  width: calc(100% / 4); /* li の幅を均等にする - 削除可・変更注意 */
}
.loop-box1 img {
  height:auto;
  width: auto;
	
}
}




/* Circle 体験会 */

.circle {
    width: 30%;
    aspect-ratio: 1;
    margin: 0 auto;
    border-radius: 61% 39% 16% 84% / 57% 72% 28% 43%;
    animation: fluid-anim 20s infinite;
  background:url("../images/bg_trial_circle.jpg");
	background-size:100%;
	background-position:top center;
	position:absolute; top:0; left:10%;
}

@keyframes fluid-anim {
    0%    { border-radius: 65% 35% 55% 45% / 55% 50% 55% 45%; }
    12.5% { border-radius: 60% 75% 40% 80% / 70% 70% 60% 65%; }
    25%   { border-radius: 55% 95% 65% 90% / 75% 65% 85% 70%; }
    37.5% { border-radius: 60% 40% 50% 45% / 60% 40% 60% 40%; }
    50%   { border-radius: 55% 95% 65% 90% / 75% 65% 85% 70%; }
    62.5% { border-radius: 60% 40% 50% 45% / 60% 40% 60% 40%; }
    75%   { border-radius: 60% 75% 40% 80% / 70% 70% 60% 65%; }
    87.5% { border-radius: 40% 60% 55% 45% / 50% 60% 40% 50%; }
    100%  { border-radius: 65% 35% 55% 45% / 55% 50% 55% 45%; }
}




/* アクティブ・キッズ・ラボについて：pc */

#vision {
padding:0;

margin: 0;
background:url("../images/vision/bg_vision.jpg") no-repeat;
	background-position: top left;
	background-size: cover;
     /* コンテンツの高さが画像の高さより大きい時、動かないように固定 */
  background-attachment: fixed;

}


#vision .wave {
padding: 0 ;
margin: 0 auto;
	height:  140px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;




}

#vision .wave1 {
padding: 0 ;
margin: 0 auto;
	height:  160px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#vision h2{
font-size: 600%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0;
text-align: left;
	line-height: 1.4;
	font-weight: bold;


}





#vision h3{
	margin: 0 0 30px 0;
text-align: left;
	font-size: 120%;
	letter-spacing: 1.5px;
	font-weight: bold;
	
}

#vision h4{
	
	text-align: left;
	font-size: 150%;
	letter-spacing: 1px;
	font-weight: bold;
margin: 10px 0 20px 0;
	
}

#vision h5{
	
	text-align: left;
	font-size: 150%;
	letter-spacing: 1px;
	font-weight: bold;
margin: 0 0 10px 0;
	
}




#vision .underline {
  border-bottom: dotted 1px;
  width: 80px;
text-align: left;
	margin: 0 0 30px 0;
	color: #7D7A7A;
}


#vision .flame_r{
padding: 20px 50px 40px 50px;
	margin:90px 0 50px auto;
border-radius: 20px 0 0 20px;
width:45%;
	background-color: #fff;
	
}




#vision .flame_r p{
font-size:105%;
margin: 0 0 20px 0;	
	letter-spacing: 1px;
	
	
	
}



#vision .flame_r ul{

	margin:  20px 0 ;
}


#vision .flame_r ul li{
	
	margin: 0 0 30px 0;
	padding: 0 0 30px 15px;
	width: 96%;


	z-index: 9995;


}

#vision .flame_r ul li img{
	
	margin: -10px 10px 10px 0;
	width: 20%;
	float: left;
z-index: 9997;
	
}


#vision .flame_c{

	padding: 40px;
	margin: 0 auto;
	width: 75%;

	
	background: #fff;

	
	

}




#vision .btn a {
position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;

	
}

#vision .btn a:hover {
	
	color: #000;
border: 4px solid #333;
	background: #fff;
}




/* アクティブ・キッズ・ラボについて：tab */

@media screen and (min-width:768px) and (max-width:959px) {
#vision {
padding: 0;
background:url("../images/vision/bg_vision_tab.jpg") no-repeat;
	background-position: top left;
margin: 30px 0 0 0;
	background-size: 100%;
	background-color: #c1d7c3;

}
	

#vision .wave {
padding: 0 ;
margin: 0 auto;
	height:  140px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;




}

#vision .wave1 {
padding: 0 ;
margin: 0 auto;
	height:  100px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}



#vision h2{
font-family: 'Quicksand', sans-serif;
	margin:  0 ;
padding: 0 ;

}





#vision h3{
	margin: 0 0 30px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 1.5px;
	font-weight: bold;
	
}

#vision h4{
	
	text-align: left;
	font-size: 150%;
	letter-spacing: 1px;
	font-weight: bold;
margin: 10px 0 20px 0;
	
}

#vision h5{
	
	text-align: left;
	font-size: 180%;
	letter-spacing: 1px;
	font-weight: bold;
margin: 0 0 10px 0;
	
}




#vision .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0;
	color: #7D7A7A;
}



#vision .flame_r{
padding: 20px 50px 40px 50px;
	margin:490px 0 50px auto;
border-radius: 20px 0 0 20px;
width:85%;
	background-color: #fff;
}


#vision .flame_r p{
font-size:105%;
margin: 0 0 20px 0;	
	letter-spacing: 1px;
	
	
	
}



#vision .flame_r ul{

	margin:  20px 0 ;
}


#vision .flame_r ul li{
	
	margin: 0 0 30px 0;
	padding: 0 0 30px 0;
	width: 96%;


	z-index: 9995;


}

#vision .flame_r ul li img{
	
	margin: -10px 25px 10px 0;
	width: 15%;
	float: left;
z-index: 9997;
	
}

#vision .btn {
    
	
	margin:12px 0 30px 0;
	
	text-align:left;

	

}

#vision .btn a {
position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;

	
}

#vision .btn a:hover {
	
	color: #000;
border: 4px solid #333;
	background: #fff;
}

}


/* アクティブ・キッズ・ラボについて：sp */

@media screen and (max-width:767px) {
#vision {
padding: 0;
background:url("../images/vision/bg_vision_sp.jpg") no-repeat;
	background-position: top left;
margin: 50px 0 0 0;
	background-size: 100%;
	background-color:#c1d6c3;

}

	

#vision .wave {
padding: 0 ;
margin: 0 auto;
	height:  140px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}

#vision .wave1 {
padding: 0 ;
margin: 0 auto;
	height: 120px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}

#vision h2{
font-size: 380%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0;
text-align: left;
	line-height: 1.4;
	font-weight: bold;

}





#vision h3{
	margin: 0 0 20px 0;
	text-align: left;
	font-size: 110%;
	letter-spacing: 1.5px;
	font-weight: bold;
}






#vision .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0;
	color: #7D7A7A;
}


#vision h4{
	
	text-align: left;
	font-size: 130%;
	letter-spacing: 1px;
	font-weight: bold;
margin: 10px 0 20px 0;
	
}

#vision .flame_r{
margin: 280px 4% 0 4%;
	width: auto;
float: none;
background: #fff;
	padding: 20px 4% 30px 4%;
	border-radius: 30px;
	
}


#vision .flame_r p{
font-size:105%;
margin: 0 0 20px 0;	
	letter-spacing: 1px;
	
	
	
}



#vision .flame_r ul{

	margin:  20px 0 ;
}


#vision .flame_r ul li{
	
	margin: 0 0 30px 0;
	padding: 0 0 30px 0;
	width: 96%;


	z-index: 9995;


}



#vision .btn {
    
	
	margin:12px 0 30px 0;
	
	text-align:left;

	

}

#vision .btn a {
position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;

	
}

#vision .btn a:hover {
	
	color: #000;
border: 4px solid #333;
	background: #fff;
}
}

/* フレーム：斜め背景色（白） */
.custom-shape-divider-top-w {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}

.custom-shape-divider-top-w svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 100px;

	box-shadow: 2px 2px 4px #d3d3d3;
-webkit-box-shadow: 2px 2px 4px #d3d3d3;
-moz-box-shadow: 2px 2px 4px #d3d3d3;
}

.custom-shape-divider-top-w .shape-fill {
    fill: #FFFFFF;
}

.divider {
  position: relative;
}






/* features 特長：pc */

#features {
	
margin: 80px 0 0 0;
padding: 0 0 100px 0;
background:url("../images/features/bg_features.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
	background-size: cover;

	
}

#features .wave {
padding: 0 ;
margin: 0 auto;
	height: 140px;
	background:url("../images/coach/bg_coach.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 200%;
}


#features h2{
font-size: 930%;
 font-family: 'Futura', sans-serif;
    letter-spacing: 0.1em;
text-align: left;
margin: 0 0 0 -8px;
	font-weight: bold;	


	
}


#features h3{
	margin: -20px 0 30px 3px;
	text-align: left;
	font-size: 180%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;
	
	
}


#features .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 3px;

}


#features h4{

	margin: 0 0 15px 0;
	font-weight: bold;
	font-size: 140%;
	letter-spacing: 1.5px;
	line-height: 1.4;

}



#features .flame_l{
padding: 0;
width: 85%;
	height: auto;
	float: left;
	margin: 0 auto;
	background: #00ffff;
		

	
	
}



#features .flame_r{
margin: 600px auto 0 90px;
	width: 80%;
	
	border-radius: 0 20px 20px 0;
	padding: 0 50px 50px 0;


	
}


#features .flame_r #list_f ul li{
	
	float: left;
	width: 42%;
	border-radius: 20px;
	margin: 0 20px 20px 0;
	padding: 25px;
	background: #fff;

	

}




#features .flame_r #list_f ul li img{
	
	float: left;
	width: 60px;
	height: 57px;
	margin: 0 10px 0 0;

	

}






#features .flame_r p{
font-size:102%;
margin: 0 0 40px 0;	
	letter-spacing: 1px;
	
	
}


#features .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 0 auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

#features .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}

/* features：縦スライド（下から上）pc */

.slide-container {
  width: 380px;
  display: flex;
  align-items: center;
  height: 800px;
  overflow: hidden;
  flex-direction: column;
}
.slide-wrapper {
  display: flex;
  flex-direction: column;
  animation: slide-flow 20s infinite linear 1s both;
}
.slide{
  width: 400px;
  object-fit: cover;
  border: 1px solid #ddd;
}
@keyframes slide-flow {
     0% {transform: translateY(0);}
 100% {transform: translateY(-100%);}
}

/* features ワーサルの特長：tab */

@media screen and (min-width:768px) and (max-width:959px) {

#features {
	
margin: 50px 0 0 0;
	background:url("../images/features/bg_features_tab.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
background-size: 100%;
padding: 0 0 60px 0;
	background-color:#9bcffb;



}


#features h2{
	
font-size: 760%;
 font-family: 'Futura', sans-serif;
    letter-spacing: 0.1em;
text-align: center;
margin: 500px auto 0 auto;
	font-weight: bold;	
	
}


#features h3{

		margin: 0 auto 30px auto;
text-align: center;
	font-size: 150%;
	letter-spacing: 5px;
	font-weight: bold;
	color: #000;
}


#features .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
text-align: center;
margin: 0 auto 30px auto;

}


#features h4{

	margin: 0 0 20px 0;
	font-weight: bold;
	font-size: 150%;
	letter-spacing: 1px;
	line-height: 1.4;

}



#features .flame_l{
display: none;


	
	
}



#features .flame_r{
margin:0 3%;
width: auto;
float: none;
	padding: 0;

}



#features .flame_r #list_f ul{
	
	

}


#features .flame_r #list_f ul li {
margin: 0 0 30px 0;

padding: 30px;

width:auto;



}

#features .flame_r #list_f ul li img{
	
	float: left;
	width: 8%;
	height: 8%;
	margin: 0 10px 20px 0;

	

}






#features .flame_r p{
font-size:105%;
margin: 0 0 50px 0;	
	letter-spacing: 1px;
	
	
}


#features .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 0 auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

#features .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}

	

/* features：縦スライド（下から上）tab */

.slide-container {
  width: 200px;
  display: flex;
  align-items: center;
  height: 980px;
  overflow: hidden;
  flex-direction: column;
}
.slide-wrapper {
  display: flex;
  flex-direction: column;
  animation: slide-flow 20s infinite linear 1s both;
}
.slide{
  width: 400px;
  object-fit: cover;
  border: 1px solid #ddd;
}
@keyframes slide-flow {
     0% {transform: translateY(0);}
 100% {transform: translateY(-100%);}
}
	

}

/* features ワーサルの特長：sp */

@media screen and (max-width:767px) {

#features {
	
margin: 50px 0 0 0;
	background:url("../images/features/bg_features_tab.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
background-size: 100%;
padding: 0 0 50px 0;
	background-color:#9bcffb;



}


#features h2{
	
font-size: 500%;
 font-family: 'Futura', sans-serif;
    letter-spacing: 0.1em;
text-align: center;
margin: 250px auto 0 auto;
	font-weight: bold;	
	
}



#features h3{
	margin: 0 auto 30px auto;
	text-align: center;
	font-size: 120%;
	letter-spacing: 5px;
	font-weight: bold;
	color: #000;
}


#features .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
 text-align: center;
	margin: 0 auto 30px auto ;

}


#features h4{

	margin: 0 0 20px 0;
	font-weight: bold;
	font-size: 140%;
	letter-spacing: 1px;
	line-height: 1.4;

}



#features .flame_l{
display: none;


	
	
}



#features .flame_r{
margin:0 3%;
width: auto;
float: none;
	padding: 0;

}



#features .flame_r #list_f ul{
	
	

}


#features .flame_r #list_f ul li {
margin: 0 0 30px 0;

padding: 30px 30px 10px 30px;

width:auto;



}







#features .flame_r p{
font-size:105%;
margin: 0 0 50px 0;	
	letter-spacing: 1px;
	
	
}


#features .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 0 auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

#features .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}

/* features：縦スライド（下から上）sp */

.slide-container {

  display: none;

 
}
.slide-wrapper {
   display: none;
}
.slide{
   display: none;
}
@keyframes slide-flow {
     0% {transform: translateY(0);}
 100% {transform: translateY(-100%);}
}
}

/* スライドテキスト:LEONES*/


.loop_txt {
    position: absolute;
	bottom:-80px;
	left: 0;
	right: 0;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: auto;
border: none;
    overflow: hidden;
	
	
	
	
  }

  .loop_txt div {
    flex: 0 0 auto;
    padding: 0 12px;
   font-size: 21rem;
    margin: 0;
	 font-family:Avenir, 'Avenir Next LT Pro', Montserrat, Corbel, 'URW Gothic', source-sans-pro, sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #ccc 0%, #c0c0c0 100%);
  background: -webkit-linear-gradient(-45deg, #dcdcdc 0%, #a9a9a9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	 
	  opacity: 0.4;
  }

@media screen and (min-width:768px) and (max-width:959px) {
	.loop_txt {
    position: relative;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: auto;
border: none;
    overflow: hidden;
	 margin: -20px 0 0 0;
	
  }
	
	.loop_txt div {
    flex: 0 0 auto;
    padding: 70px 12px;
     font-size: 13.5rem;
    margin: 0;
	 font-family:'Helvetica',sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #f5f5f5 0%, #c0c0c0 100%);
  background: -webkit-linear-gradient(-45deg, #dcdcdc 0%, #a9a9a9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	  opacity: 0.2;
		
  }

}

@media screen and (max-width:767px) {
   .loop_txt {
    position: relative;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: auto;
border: none;
    overflow: hidden;
	 margin: 0;
	
  }
	
	.loop_txt div {
    flex: 0 0 auto;
    padding: 70px 12px;
     font-size: 13.5rem;
    margin: 0;
	 font-family:'Helvetica',sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #f5f5f5 0%, #c0c0c0 100%);
  background: -webkit-linear-gradient(-45deg, #dcdcdc 0%, #a9a9a9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	  opacity: 0.5;
		
  }

  }

  .loop_txt div:nth-child(odd) {
    -webkit-animation: loop3 50s -25s linear infinite;
    animation: loop3 50s -25s linear infinite;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
  }

  .loop_txt div:nth-child(even) {
    -webkit-animation: loop4 50s  linear infinite;
    animation: loop4 50s linear infinite;
  }

  @-webkit-keyframes loop3 {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
  }

  @keyframes loop3 {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
  }

  @-webkit-keyframes loop4 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
  }

  @keyframes loop4 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
  }


/* スライドテキスト:LEONES*/


.loop_txt2 {
    position: absolute;
	top:350px;
	left: 0;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: auto;
border: none;
    overflow: hidden;
	
	
	
  }

  .loop_txt2 div {
    flex: 0 0 auto;
    padding: 0 12px;
   font-size: 23rem;
    margin: 0;
	 font-family:Avenir, 'Avenir Next LT Pro', Montserrat, Corbel, 'URW Gothic', source-sans-pro, sans-serif;
	  font-weight: bold;
	letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #fff 0%, #fff 100%);
  background: -webkit-linear-gradient(-45deg, #fff 0%, #fff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	 z-index: 9995;
	  opacity: 0.3;
  }

@media screen and (min-width:768px) and (max-width:959px) {
	.loop_txt2 {
    position: relative;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: auto;
border: none;
    overflow: hidden;
	 margin: -20px 0 0 0;
	
  }
	
	.loop_txt2 div {
    flex: 0 0 auto;
    padding: 70px 12px;
     font-size: 13.5rem;
    margin: 0;
	 font-family:'Helvetica',sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #f5f5f5 0%, #c0c0c0 100%);
  background: -webkit-linear-gradient(-45deg, #dcdcdc 0%, #a9a9a9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	  opacity: 0.3;
		
  }

}

@media screen and (max-width:767px) {
   .loop_txt2 {
    position: relative;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: auto;
border: none;
    overflow: hidden;
	 margin: 0;
	
  }
	
	.loop_txt2 div {
    flex: 0 0 auto;
    padding: 70px 12px;
     font-size: 13.5rem;
    margin: 0;
	 font-family:'Helvetica',sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
	color: transparent;
		  background: linear-gradient(135deg, #f5f5f5 0%, #c0c0c0 100%);
  background: -webkit-linear-gradient(-45deg, #dcdcdc 0%, #a9a9a9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	  opacity: 0.3;
		
  }

  }

  .loop_txt2 div:nth-child(odd) {
    -webkit-animation: loop3 50s -25s linear infinite;
    animation: loop3 50s -25s linear infinite;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
  }

  .loop_txt2 div:nth-child(even) {
    -webkit-animation: loop4 50s  linear infinite;
    animation: loop4 50s linear infinite;
  }

  @-webkit-keyframes loop3 {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
  }

  @keyframes loop3 {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
  }

  @-webkit-keyframes loop4 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
  }

  @keyframes loop4 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
  }





/* マウスオーバーで下からテキストポップアップ*/

.entry-title{

width:90%;

margin:0 auto 80px;

}



.post-meta{

display:none;

}






#container{

overflow: hidden;

}








.popUp{

  position: relative;

  margin-bottom: -10px;

  margin-bottom: 140px;

}@media (max-width: 1023px){

  .popUp{

    margin-bottom: 100px;

  }

}



.popUp_catch{

  margin-bottom: 55px;

  text-align: center;

  font-weight: 500;

  letter-spacing: 0.1em;

}



.popUp_catch > .op_img{

  display: inline;

  position: relative;

  top: 24px;

  padding: 0 10px;

}@media (max-width: 1023px){

  .popUp_catch > .op_img{

    top: auto;

    padding: 15px 10px 5px;

  }

}



.popUp_tag{

  margin-bottom: 105px;

  display: -webkit-flex;

  display: -moz-flex;

  display: -ms-flex;

  display: -o-flex;

  display: flex;

  flex-wrap: wrap;

  justify-content: center;

  color: #3dace6;

  border: 1px solid #3dace6;

  padding: 30px 0;

  font-weight: bold;

  font-size: 18px;

}@media (max-width: 1023px){

  .popUp_tag{

    padding: 30px 20px 10px;

    font-size: 16px;

  }

}



.popUp_tag_item{

  margin-right: 20px;

}

@media (max-width: 1023px){

  .popUp_tag_item{

    margin-right: 0;

    padding: 0 10px;

    margin-bottom: 20px;

  }

}



.popUp_tag_item:last-child{

  margin-right: 0;

}



.popUp_inner{

  width: 1200px;

  margin-left: auto;

  margin-right: auto;

}@media (max-width: 1023px){

  .popUp_inner{

    width: 80%;

  }

}



.popUp_item{

  position: relative;

  width: calc((100% - 71px)/3);

  margin-right: 35px;

  margin-bottom: 60px;

}@media (max-width: 1023px){

  .popUp_item{

    width: 100%;

    margin-right: 0;

    margin-bottom: 60px;

  }

  .popUp_item:last-child{

    margin-bottom: 0;

  }

}



.popUp_item a{

  z-index: 3;

}



.popUp_item:nth-child(3n - 1){

  margin-top: 115px;

}@media (max-width: 1023px){

  .popUp_item:nth-child(3n - 1){

    margin-top: auto;

  }

}



.popUp_item:nth-child(3n){

  margin-top: 30px;

}@media (max-width: 1023px){

  .popUp_item:nth-child(3n){

    margin-top: auto;

  }

}



.popUp_wrapper{



}@media (max-width: 1023px){

  .popUp_wrapper{

    max-width: 375px;

    margin-left: auto;

    margin-right: auto;

  }

}



.popUp_wrapper_wrapper{

  display: -webkit-flex;

  display: -moz-flex;

  display: -ms-flex;

  display: -o-flex;

  display: flex;

  flex-wrap: wrap;

}@media (min-width: 1024px){

  .popUp_wrapper_wrapper{

    display: -webkit-flex !important;

    display: -moz-flex !important;

    display: -ms-flex !important;

    display: -o-flex !important;

    display: flex !important;

  }

}



.popUp_wrapper.js_openParent.js_fire .masktFaq_more_img > .op_img{

  transform: rotate(180deg);

}



.popUp_item_image{

  position: relative;

  margin-bottom: 20px;

  overflow: hidden;
border-radius: 20px;

}


/* ポップアップの枠内文章他 */

.popUp_item_image_text{

  position: absolute;

  left: 0;

  bottom: -122px;

  width: 100%;

  font-size: 100%;

  color: #fff;

  letter-spacing: 0.1em;

  line-height: 1.4;

  /*background-color: rgba(110,110,110,0.8);*/

  padding: 20px 20px 0 20px;

  box-sizing: border-box;

  transform: translateY(100%);

  transition: all 200ms ease-out;

}@media (max-width: 1023px){

  .popUp_item_image_text{

    bottom: -5px;

    transform: translateY(0%);

    font-size: 90%;

    padding: 15px 15px 15px;

  }

}



@media (min-width: 1024px){

  .popUp_item:hover .popUp_item_image_text{

    transform: translateY(0%);
color: #fff;
    bottom: 0;

  }

}



.el_anker{

  position: absolute;

  top: -103px;

  left: 0;

}@media (max-width: 1023px){

  .el_anker{

    top: -570px;

  }

}

/*テキスト部分：背景透かし*/

.popUp_item_image_text:before{

  content:"";

  position: absolute;

  top: -50px;

  left: 50%;

  width: 200%;

  height: 300px;

  background-color: #333;
	opacity: 0.8;


  transform: rotate(-8deg) translateX(-50%);

}@media (max-width: 1023px){

  .popUp_item_image_text:before{

    top: -45px;

  }

}@media (max-width: 400px){

  .popUp_item_image_text:before{

    top: -25px;
	 

  }

}

/*ポップアップ枠*/

.popUp_item_image_text .op_text{

  position: relative;

  z-index: 2;

  max-width: 100%;

  margin: 30px 0 0 auto;

  margin-right: auto;

  line-height: 1.5;


}



img.op_try{

  position: absolute;

  left: 0;

  top: 1px;

  transform:translateY(-100%);

  width: 100%;

  opacity: 0.8;

}



.popUp_item_texts{

  position: relative;

  padding: 0 20px;

  box-sizing: border-box;

  text-align: center;

}@media (max-width: 1023px){

  .popUp_item_texts{

    padding: 0;

  }

}



.popUp_item_texts .op_sub{

  margin-bottom: 10px;

  font-size: 14px;

  font-weight: bold;

  white-space: nowrap;

}@media (max-width: 1023px){

  .popUp_item_texts .op_sub{

    font-size: 14px;

    margin-bottom: 5px;

  }

}

.popUp_item_texts .op_main{

   font-size: 98%;

  font-weight: bold;

  line-height: 1.5;

  white-space: nowrap;

}@media (max-width: 1023px){

  .popUp_item_texts .op_main{

    font-size: 98%;

  }

}



.popUp_item:nth-child(3n){

  margin-right: 0;

}



.popUp_item_image{

}


/* coach 講師：pc*/



#coach {
padding: 0;
margin: 0 auto;
	background:url("../images/coach/bg_coach.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;



}

#coach .wave {
padding: 0 ;
margin: 0 auto;
	height:  140px;
	background:url("../images/coach/bg_coach.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top bottom;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}

#coach h2{
font-size: 1000%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: -170px 0 0 0;
text-align: center;
	font-weight: bold;
	color: #fff;


}

#coach #subttl{
	font-size: 120%;
	margin: 0 auto;
text-align: center;
	letter-spacing: 2px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}



#coach h3{
	margin: -10px auto 20px auto ;
	text-align: center;
	font-size: 160%;
	letter-spacing: 5px;
	font-weight: bold;
	color: #333;

}

#coach h4{
	margin: 20px auto ;
	text-align: center;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;

}

#coach h4 span{

	font-size: 80%;
	letter-spacing: 2px;
	

}





#coach .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: center;
	margin: 30px auto ;
	color: #000;

}

#coach .txt{
	
	font-size: 110%;
	margin: 0 0 50px 0;
	text-align: center;
	letter-spacing: 2px;
	

}


#coach p{
	
	font-size: 98%;
	margin: 0 0 -10px 0;
	

}


#coach .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 30px auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #fff;
	
}

#coach .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}

#coach .flame_c{

	padding: 5px 80px 20px 50px;
	margin: 670px 0 0 auto;
	width: 85%;
	border-radius:20px 0 0 20px;
background: #fff;
	opacity: 0.95;


}





.cp_accordionslide08 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	
}
.cp_accordionslide08:hover .slideitem {
	width: 100%;
}
.cp_accordionslide08 .slideitem {
	position: relative;
	overflow: hidden;
	width: 50%;
	height: 70vh;
	-webkit-transition: width 0.5s ease;
	        transition: width 0.5s ease;
	-webkit-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
	color: #ffffff;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.cp_accordionslide08 .slideitem:nth-child(1) {
	background-image: url('../images/coach/kadono.jpg');
	background-position: top left;
}
.cp_accordionslide08 .slideitem:nth-child(2) {
	background-image: url('../images/coach/kadono.jpg');
	background-position: top left;
}
.cp_accordionslide08 .slideitem:before,
.cp_accordionslide08 .slideitem:after {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: '';
	-webkit-transform: translate3d(0, 0, 0);
	        transform: translate3d(0, 0, 0);
}
.cp_accordionslide08 .slideitem:after {
	-webkit-transition: opacity 0.5s ease;
	        transition: opacity 0.5s ease;
	opacity: 1;
	
}
.cp_accordionslide08 .slideitem:before {
	z-index: 1;
	-webkit-transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
	        transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
	        transition: opacity 0.5s ease, transform 0.5s ease;
	        transition: opacity 0.5s ease, transform 0.5s ease, -webkit-transform 0.5s ease;
	-webkit-transform: translate3d(0, 0, 0) translateY(50%);
	        transform: translate3d(0, 0, 0) translateY(50%);
	opacity: 0;
	background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), color-stop(75%, #000000));
	background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 75%);
	background:         linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, #000000 75%);
}
.cp_accordionslide08 .slideitem:hover {
	width: 200% !important;
}
.cp_accordionslide08 .slideitem:hover:after {
	opacity: 0;
}
.cp_accordionslide08 .slideitem:hover:before {
	-webkit-transition: opacity 1s ease, -webkit-transform 1s ease 0.25s;
	        transition: opacity 1s ease, -webkit-transform 1s ease 0.25s;
	        transition: opacity 1s ease, transform 1s ease 0.25s;
	        transition: opacity 1s ease, transform 1s ease 0.25s, -webkit-transform 1s ease 0.25s;
	-webkit-transform: translate3d(0, 0, 0) translateY(0);
	        transform: translate3d(0, 0, 0) translateY(0);
	opacity: 1;
}
.cp_accordionslide08 .slideitem:hover .slidecont {
	-webkit-transition: all 0.75s ease 0.5s;
	        transition: all 0.75s ease 0.5s;
	-webkit-transform: translateY(0);
	        transform: translateY(0);
	opacity: 1;
}
.cp_accordionslide08 .slideitem h4 {
	font-size: 1.4em;
	position: absolute;
	z-index: 1;
	top: 83%;
	left: 50%;
	-webkit-transition: all 0.75s ease;
	        transition: all 0.75s ease;
	-webkit-transform: translateX(-50%) translateY(-50%);
	        transform: translateX(-50%) translateY(-50%);
	white-space: nowrap;
}
.cp_accordionslide08 .slideitem h4::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: '';
}
.cp_accordionslide08 .slideitem:hover h4 {
	top: 50%;
	left: 50%;
}

.cp_accordionslide08 .slideitem h5 {
	font-size: 1.4em;
	position: absolute;
	z-index: 1;
	top: 90%;
	left: 50%;
	-webkit-transition: all 0.75s ease;
	        transition: all 0.75s ease;
	-webkit-transform: translateX(-50%) translateY(-50%);
	        transform: translateX(-50%) translateY(-50%);
	white-space: nowrap;
}
.cp_accordionslide08 .slideitem h5::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: '';
}
.cp_accordionslide08 .slideitem:hover h5 {
	top: 56%;
	left: 50%;
}
.cp_accordionslide08 .slidecont {
	position: relative;
	z-index: 1;
	top: 64%;
	margin: 0 1.618em;
	-webkit-transform: translate3d(0, 0, 0) translateY(25px);
	        transform: translate3d(0, 0, 0) translateY(25px);
	text-align: left;
	opacity: 0;
}
@media only screen and (max-width:768px) {
	.cp_accordionslide08 {
		display: block;
	}
	.cp_accordionslide08:hover .slideitem {
		width: 100%;
		height: 20vh;
	}
	.cp_accordionslide08 .slideitem {
		width: 100%;
		height: 20vh;
	}
	.cp_accordionslide08 .slideitem:hover {
		width: 100% !important;
		height: 100vh !important;
	}
	.cp_accordionslide08 .slideitem h4 {
		top: 35%;
	}
}



/* coach 講師：tab*/

@media screen and (min-width:768px) and (max-width:959px) {

#coach {
padding:  0;
margin:  0;
background:url("../images/coach/bg_coach.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;



}

#coach h2{
font-size: 800%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0 0 0 0;
text-align: center;
	font-weight: bold;
	color: #333;

}



#coach h3{
	margin: 0 auto 30px auto ;
	text-align: center;	
	font-size: 150%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
	width: 50%;
}






#coach .underline {
   border-bottom: dotted 1px;
  width: 80px;
  text-align: center;
	margin: 30px auto ;
	color: #000;

}

#coach .txt{
	
	font-size: 110%;
	margin: 0 0 30px 0;
	text-align: center;
	letter-spacing: 2px;
	

}

#coach p{
	
	font-size: 98%;
	margin: 0 0 -10px 0;
	

}

#coach h4{
	margin: 20px auto ;
	text-align: center;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;

}

#coach h4 span{

	font-size: 80%;
	letter-spacing: 2px;
	

}



#coach .flame_c{

	padding: 0 auto ;
	margin: 360px 5% 0 5%;
	width: auto;
	float: none;
	border-radius: 20px;
	
	
	

}

#coach .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 30px auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #fff;
	
}

#coach .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}


}


/* coach 講師：sp*/

@media screen and (max-width:767px) {


#coach {
padding:  0;
margin: 0;
background:url("../images/coach/bg_coach_sp.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;



}

#coach h2{
font-size: 450%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0;
text-align: center;
	font-weight: bold;
	color: #333;

}



#coach h3{
	margin: 5px auto 20px auto ;
	text-align: center;	
	font-size: 130%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
	width: auto;
}






#coach .underline {
   border-bottom: dotted 1px;
  width: 80px;
  text-align: center;
	margin: 30px auto ;
	color: #000;
}

#coach .txt{
	
	font-size: 100%;
	margin: 0 0 30px 0;
	text-align: left;
	letter-spacing: 0.5px;
}
	
#coach p{
	
	font-size: 90%;
	margin: -10px 0 0 0;
	

}

#coach h4{
	margin: 20px auto ;
	text-align: center;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;

}

#coach h4 span{

	font-size: 80%;
	letter-spacing: 2px;
	

}



#coach .flame_c{

	padding: 10px 3% 0 3%;
	margin: 140px 5% 0 5%;
	width: auto;
	float: none;
border-radius: 20px;


}
	


#coach .btn a {
position: relative;
	display: inline-block;
	padding: 12px 16px;
	margin: 15px auto 10px auto;
width: auto;
	float: right;
font-size: 90%;
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 2px solid #fff;
	
}

#coach .btn a:hover {
	
	color: #333;
border: 2px solid #000;
	background: #f3efef;
}

}


/* スケジュール：PC */

#schedule {

	padding: 50px 0 0 0;
	margin: 0;
	
}

#schedule .wave {
padding: 0 ;
margin: 0 auto;
	height:  140px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top bottom;


   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#schedule h2{
font-size: 600%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0 auto;
	text-align: center;
	line-height: 1.2;
	font-weight: bold;

}

#schedule h3{
	
margin: 10px 0 5px 0;
	text-align: center;
	font-size: 130%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
}



#schedule .underline {
   border-bottom: dotted 1px;
  width: 80px;
	text-align: center;
	margin: 30px auto ;
	color: #000;

}

#schedule h4{
	
	margin: 0 0 10px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	line-height: 1.2em;
	
}



#schedule .flame_l{

	padding: 0;
	margin: 30px 0 30px 8%;
	width: 45%;
	float: left;
	
	background: #fff;

	letter-spacing: 2px;


}


#schedule .flame_r {

	padding:0 0 0 0;
margin: 50px 0 0 0;
width: 43%;
float: right;

	
	
}



#schedule .flame_l p {


	margin: 0 0 30px 0;
	font-size: 95%;
	text-align: left;

	
}





#schedule .tbl-r02 {
  margin: 30px 0;
	width: 100%;
	font-size:100%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
}


#schedule .tbl-r02 th {
font-weight: bold;
 border: dotted 1px #ccc;
  color: #333;
  padding: 15px 8px 15px 40px;
	width: 20%;
	border-left: none;
	border-right: none;
text-align: center;
vertical-align: top; /* 内容を上寄せにする */
	background: #f5f5f5;
	
}

#schedule .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	
}

#schedule .tbl-r02 p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 0;
	line-height: 2em

}



.main_imgBox_l {
    min-height: 700px;
    overflow: hidden;
    position: relative; 

}


  .main_img_l {
    z-index:10;
    opacity: 0;
    width: 100%;
    height: auto;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 100%;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-animation: anime 36s 0s infinite;
    animation: anime 36s 0s infinite; }

    .main_img_l:nth-of-type(2) {
      -webkit-animation-delay: 6s;
      animation-delay: 6s; }

    .main_img_l:nth-of-type(3) {
      -webkit-animation-delay: 12s;
      animation-delay: 12s; }

    .main_img_l:nth-of-type(4) {
      -webkit-animation-delay: 18s;
      animation-delay: 18s; }

    .main_img_l:nth-of-type(5) {
      -webkit-animation-delay: 24s;
      animation-delay: 24s; }

    .main_img_l:nth-of-type(6) {
      -webkit-animation-delay: 30s;
      animation-delay: 30s; }

  .main_imgM {
    opacity: 0;
    width:100%;
    height:100%;
    object-fit: cover;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-animation: anime 36s 0s infinite;
    animation: anime 36s 0s infinite; }

    .main_imgM:nth-of-type(2) {
      -webkit-animation-delay: 6s;
      animation-delay: 6s; }

    .main_imgM:nth-of-type(3) {
      -webkit-animation-delay: 12s;
      animation-delay: 12s; }

    .main_imgM:nth-of-type(4) {
      -webkit-animation-delay: 18s;
      animation-delay: 18s; }

    .main_imgM:nth-of-type(5) {
      -webkit-animation-delay: 24s;
      animation-delay: 24s; }

    .main_imgM:nth-of-type(6) {
      -webkit-animation-delay: 30s;
      animation-delay: 30s; }

@keyframes anime {
    0% {
        opacity: 0;
    }
    8% {
        opacity: 1;
    }
    17% {
        opacity: 1;
    }
    25% {
        opacity: 0;
         transform: scale(1.0);
                    z-index:9;
    }
    100% { opacity: 0 }
}

@-webkit-keyframes anime {
    0% {
        opacity: 0;
    }
    8% {
        opacity: 1;
    }
    17% {
        opacity: 1;
    }
    25% {
        opacity: 0;
         -webkit-transform: scale(1.2);
            z-index:9;
    }
    100% { opacity: 0 }
}


/* スケジュール：tab */

@media screen and (min-width:568px) and (max-width:959px) {

	
#schedule {

	padding: 0 30px;
width: auto;
	margin: 50px 0 0 0;
	
border-radius: none;       /* 角丸のサイズ指定 */

	}
	
#schedule .wave {
padding: 0 ;
margin: 0 auto;
	height:  140px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;


   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#schedule h2{
	margin: 0 auto;
	font-family: 'Quicksand', sans-serif;
	font-size: 600%;
}

#schedule h3{
	
  text-align:center;
	margin: 20px auto 30px auto;
	font-size: 150%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
}


#schedule .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align:center;
	margin: 0 auto 30px auto;
	color: #000;

}

#schedule h4{
	
	margin: 0 0 10px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	line-height: 1.2em;
	
}

#schedule .flame_l {
padding: 0;
	margin: 30px 0 30px 8%;
	width: auto;
	float: none;
	
	background: #fff;

	letter-spacing: 2px;



	
}


#schedule .flame_r {

display: none;
	
}




#schedule .tbl-r02 table {
  margin: 80px 0;
	width: 90%;
		font-size:100%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
	
}


#schedule .tbl-r02 th {
font-weight: bold;
 border: dotted 1px #ccc;
  color: #000;
  padding: 15px auto 15px auto;
	width: 17%;
	border-left: none;
	border-right: none;
text-align: center;
vertical-align: top; /* 内容を上寄せにする */
	
	
}

#schedule .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	
}

#schedule .tbl-r02 p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 0;
	line-height: 2em

}
}





/* スケジュール：sp */

@media screen and (max-width:767px) {
#schedule {

	padding: 0 30px;
width: auto;
	margin: 0;

border-radius: none;       /* 角丸のサイズ指定 */

}

#schedule .wave {
padding: 0 ;
margin: 0 auto;
	height:  100px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#schedule h2{
	margin: 50px auto 0 0;
	font-family: 'Quicksand', sans-serif;
	font-size: 380%;

}

#schedule h3{
	
  text-align:center;
	margin: 20px auto 30px auto;
	font-size: 120%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
}


#schedule .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align:center;
	margin: 0 auto 30px auto;
	color: #000;

}

#schedule h4{
	
	margin: 0 0 10px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	line-height: 1.2em;
	
}

#schedule .flame_l {

padding: 0;
	margin: 30px 2%;
	width: auto;
	float: none;
	
	background: #fff;

	letter-spacing: 2px;

	
}


#schedule .flame_r {

display: none;
	
}
	
	

#schedule .inner table {
	width: 95%;

}


#schedule .tbl-r02 {
    width: 100%;
border: none;
	 margin: 0 0 40px 0;
  }

#schedule  .tbl-r02 th,
#schedule  .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 96.5%;
	padding: 8px 0 0 0;
	border: none;
	text-align: left;
	margin: 10px 0;
border-top: dotted 1px #ccc;
	background: none;

	
		
  }


}



/* よくあるご質問 */

#faq{

	padding: 80px 0 0 0;
	margin: 0 0 50px 0;
	
}

#faq h2{
font-size: 650%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 20px 0 0 0;
text-align: left;
	line-height: 1.2;
	font-weight: bold;

}

#faq h3{
	
margin: 10px 0 5px 0;
	text-align: left;
	font-size: 150%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
}


#faq .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 30px 0;
	color: #000;

}

#faq h4{
	
	margin: 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	line-height: 1.2em;
	
}

#faq .flame_l {

	padding: 0 0 0 10%;
margin: 0 0 65px 0;

height: auto;
float: left;
	width: 25%;
	
}


#faq .flame_r {

	padding:0 0 0 0;
margin: 0 5% 0 0;
width: 54%;
float: right;

	
	
}


#faq .flame_r .question {

padding: 13px 15px;


	margin: 0 15px 0 0;
	font-weight: bold;
	
	
		
}

#faq .flame_r .answer {
padding: 15px;
background-color: #000;

	margin: 0 15px 0 0;
	font-weight: bold;
	font-size: 110%;
	width: 5%;
	
	

}

#faq .flame_r .answer02 {

	padding: 15px;
background:#000;
	font-weight: bold;
	font-size: 110%;
	margin: 0 15px 0 0;
	float: left;
	color: #fff;

}

#faq .flame_r p {


	margin: 0 0 10px 0;
	font-size: 95%;
	text-align: left;

	
}



@media screen and (min-width:568px) and (max-width:959px) {

	
#faq {

	padding: 0 0 30px 5%;
width: auto;
	margin: 50px 0 0 0;
	
border-radius: none;       /* 角丸のサイズ指定 */

	}

#faq h2{
	margin: 0 0 0 -5px;
	
}

#faq h3{
	
margin: 10px 0 5px 0;
	text-align: left;
	font-size: 150%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #000;
	
}



#faq .underline {
display: none;

}

#faq h4{
	
	margin: 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	line-height: 1.2em;
	
}

#faq .flame_l {


	padding:0;
margin: 50px 0 0 0;
width: 95%;
float: none;
	
}


#faq .flame_r {

	padding:0;
margin: 50px 0 0 0;
width: 95%;
float: none;

	
	
}


#faq .flame_r .question {

padding: 13px 15px;


	margin: 0 15px 0 0;
	font-weight: bold;
	
	
		
}

#faq .flame_r .answer {
padding: 15px;
background-color: #000;

	margin: 0 15px 0 0;
	font-weight: bold;
	font-size: 110%;
	width: 5%;
	
	

}

#faq .flame_r .answer02 {

	padding: 15px;
background:#000;
	font-weight: bold;
	font-size: 110%;
	margin: 0 15px 0 0;
	float: left;
	color: #fff;

}

#faq .flame_r p {


	margin: 0 0 10px 0;
	font-size: 95%;
	text-align: left;

	
}
}


@media screen and (max-width:767px) {
	
#faq {

	padding: 0 0 50px 0;
width: auto;
	margin: 0;
	
border-radius: none;       /* 角丸のサイズ指定 */

	}

#faq h2{
margin: 15px auto 5px auto;	
font-size: 550%;
text-align: center;
}

#faq h3{
	
margin: 15px auto 5px auto;
	text-align: center;
	font-size: 110%;
	letter-spacing: 0.2em;
	font-weight: bold;
	color: #000;
	
}

#faq .underline {
 display: none;

}

#faq h4{
	
	margin: 0 ;
	text-align: left;
	font-size: 105%;
	letter-spacing: 1px;
	font-weight: bold;
	line-height: 1.2em;
	
}

#faq .flame_l {

	padding:0;
margin: 50px 0 0 0;
width: 95%;
float: none;
}


#faq .flame_r {

	padding:0 4%;
margin: 50px 0 0 0;
width: auto;
float: none;
	
}


#faq .flame_r .question {

padding: 13px 15px;
font-size: 95%;

	margin: 0 15px 0 0;
	font-weight: bold;
	
	
		
}

#faq .flame_r .answer {
padding: 15px;
background-color: #000;

	margin: 0 15px 0 0;
	font-weight: bold;
	font-size: 110%;
	width: 5%;
	
	

}

#faq .flame_r .answer02 {

	padding: 15px;
background:#000;
	font-weight: bold;
	font-size: 110%;
	margin: 0 15px 0 0;
	float: left;
	color: #fff;

}

#faq .flame_r p {


	margin: 0;
	font-size: 95%;
	text-align: left;

}
}

/* 受講の流れ pc */

#flow {
padding: 0;
margin:0;
	background:url("../images/flow/bg_flow.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
background-color: #3db7fa;


}

#flow .wave {
padding: 0 0 100px 0;
margin: 0 auto;
	height:  140px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top bottom;


	
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}

#flow .wave1 {
padding: 0 ;
margin: 0 auto;
	height:  150px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#flow h2{
font-size: 600%;
font-family: 'Quicksand', sans-serif;
    text-align: center;
margin: 0 auto 10px auto;
letter-spacing: 0.1em;
	line-height: 1.2;
	font-weight: bold;
}


#flow h3{
	margin: 0 auto ;
	text-align: center;
	font-size: 140%;
	letter-spacing: 0.1em;
	font-weight: bold;
	color: #000;
	
	width: auto;
}


#flow h4{
	margin: 20px 0 5px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;
	
}

#flow .underline {
  border-bottom: dotted 1px;
  width: 80px;
 text-align: center;
	margin: 30px auto 35px auto;
	color: #000;

}


#flow .flame_c{

	padding: 5px 40px 50px 40px;
	margin: 250px auto 30px auto;
	width: 60%;

	border-radius: 20px ;
	background: #fff;

	letter-spacing: 2px;


}

#flow .flame_c .txt_center{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 15px 0;
	text-align: center;

	
}

#flow .flame_c p{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 5px 0;

	
}


#flow .btn {
    
	margin:12px 0 0 0;
	
	text-align:left;

	
	

}

#flow .btn a {

	position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto 0 auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	
	
}

#flow .btn a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;

}



.readmore2 {
  position: relative;
  margin: 50px auto 0;
  padding: 0px 0px 75px;
}

.readmore2 img {
 width: 25%;
	float: left;
	margin: 0 20px 0 0;
}

.readmore2 .readmore-content p{
  margin: 15px 0;
}

.readmore2 .readmore-content {
  position: relative;
  height: 275px;
  overflow: hidden;
}

.readmore2 .readmore-content::before {
  position: absolute;
  display: block;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75px;
  background: linear-gradient( rgba(255,255,255,0) 0%, rgba(255,255,255,0.8) 50%, #fff 100%);
}

.readmore2 label {
  position: absolute;
  display: table;
  left: 50%;
  bottom: 0px;
  margin: 0 auto;
  width: auto;
 padding: 15px 30px;
  color: #fff;
  text-align: center;
  border-radius: 50px;
  background-color: #333;
  transform: translateX(-50%);
  cursor: pointer;
  z-index: 1;
	font-size: 100%;
	font-weight: bold;
}

.readmore2 label::before{
  content: '▼ 続きを見る';
	cursor: pointer;
	
}

.readmore2 input[type="checkbox"]:checked ~ label::before {
  content: '▲ 閉じる';
	cursor: pointer;
}

.readmore2 input[type="checkbox"]{
  display: none;
}

.readmore2 input[type="checkbox"]:checked ~ .readmore-content {
  height: auto;
}

.readmore2 input[type="checkbox"]:checked ~ .readmore-content::before {
  display: none;
}


/* 受講までの流れ：tab */

@media screen and (min-width:768px) and (max-width:959px) {

#flow {
padding:0;
margin:0 ;
background:url("../images/flow/bg_flow.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: right top;



   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
background-color: #3db7fa;


}
	
#flow .wave {
padding: 0 0 100px 0;
margin: 0 auto;
	height:  140px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top bottom;


	
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}

#flow .wave1 {
padding: 0 ;
margin: 0 auto;
	height:  150px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#flow #subttl{
	font-size: 120%;
	margin: 0%;
text-align: center;
	letter-spacing: 2px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}




#flow .flame_c{

	padding: 0 40px 40px 40px;
		margin: 180px 5% 0 5%;
		width: auto;
	float: none;
	border-radius: 20px;
	background: #fff;



}
	
#flow .flame_c .txt_center{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 15px 0;
	text-align: center;

	
}


#flow .flame_c h2{
font-size: 600%;
font-family: 'Quicksand', sans-serif;

    letter-spacing: 0.1em;
margin: 30px auto 10px auto;
text-align: center;
	line-height: 1.2;
	font-weight: bold;
}

#flow .flame_c .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: center;
	margin: 30px auto ;
	color: #000;

}

#flow .flame_c .flame_c_l{

	
	margin: 0 30px 30px 0;
	width: 45%;
	float: left;


	letter-spacing: 2px;


}


#flow .flame_r{

	padding: 5px 30px 40px 30px;
	margin: 10px 5% 30px 5%;
	width: auto;

	border-radius: 20px;
	background: #fff;




}

#flow .flame_r h2{
font-size: 640%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: -10px 0 0 0;
text-align: left;
	z-index: 9998;
	font-weight: bold;
}

#flow .flame_r .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 30px 0 ;
	color: #000;

}
#flow img{

	width: 25%;
	margin: 0 15px 0 0;
	float: left;
}


#flow p{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 5px 0;
	
}


#flow .btn {
    
	margin:12px 0 0 0;
	
	text-align:left;

	
	

}

#flow .btn a {

	position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto 0 auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	
	
}

#flow .btn a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;

}



}


/* 受講までの流れ：sp */

@media screen and (max-width:767px) {

#flow {
padding: 0 ;
margin:0 ;
background:url("../images/flow/bg_flow_tab.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: right top;
 
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
background-color: #3db7fa;


}

#flow .wave {
padding: 0 0 100px 0;
margin: 0 auto;
	height:  100px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top right;

	
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}

#flow .wave1 {
padding: 0 ;
margin: 0 auto;
	height:  100px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}


#flow #subttl{
	font-size: 120%;
	margin: 0%;
text-align: left;
	letter-spacing: 2px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}


#flow .flame_c{

	padding: 0 30px 30px 30px;
		margin: 0 5% ;
		width: auto;
	float: none;
	border-radius: 20px;
	background: #fff;

}
	
#flow .flame_c .txt_center{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 15px 0;
	text-align: left;

	
}


#flow .flame_c h2{
font-size: 340%;
font-family: 'Quicksand', sans-serif;

margin: 20px auto 0 auto;
text-align: center;
	font-weight: bold;
}
	
#flow .flame_c h3{
margin: 10px auto 0 auto;
text-align: center;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #333;
	width: 50%;
}


#flow .flame_c .underline {
  border-bottom: dotted 1px;
  width: 80px;
text-align: center;
	margin: 25px auto 30px auto;
	color: #000;

}

#flow .flame_c .flame_c_l{

	
	margin: 0 0 30px 0;
	width: auto;
	float: none;


	letter-spacing: 2px;

}


#flow p{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 5px 0;
	
}


#flow .btn {
    
	margin:12px 0 0 0;
	
	text-align:left;

	
	

}

#flow .btn a {

	position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto 0 auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	
	
}

#flow .btn a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;

}

#flow img{

	width: auto;
	margin: 0 0 20px 0;
	float: left;
}
	

	
.readmore2 label {
  position: absolute;
  display: table;
  left: 50%;
  bottom: 0px;
  margin: 0 auto;
  width: 50%;
 padding: 15px 30px;
  color: #fff;
  text-align: center;
  border-radius: 50px;
  background-color: #333;
  transform: translateX(-50%);
  cursor: pointer;
  z-index: 1;

	font-weight: normal;

}

	
.readmore2 .readmore-content {
  position: relative;
  height: 240px;
  overflow: hidden;
}

}



/* contact_i2 トップページお問い合わせ：PC　 */


#contact_i2 {
padding:  0 0 30px 0;
margin:  50px 5% 80px 10%;
	width: auto;


}


#contact_i2 h3{
	font-size: 160%;
	margin: 0 0 30px 0;
text-align: left;

	

	font-weight: bold;
	line-height: 1.5em;
	letter-spacing: 2px;
	width: auto;
	padding: 0;
	
	
}



#contact_i2 .underline {
 
   border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0 ;

}


#contact_i2 p {
  
  text-align: left;
	margin: 0 0 20px 6%;
	font-size: 110%;

}







#contact_i2 .btn a {
position: relative;
	display: inline-block;
	padding: 20px 0;
	margin: 15px 20px 10px auto;
width: 30%;
	float: left;
font-size: 100%;
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 50px;
	letter-spacing: 1px;
border: 5px solid #dcdcdc;
	
}

#contact_i2 .btn a:hover {
	
	color: #333;
border: 5px solid #000;
	background: #f3efef;
}


/* contact_i2 トップページお問い合わせ：tab　 */

@media screen and (min-width:768px) and (max-width:959px) {
	

#contact_i2 {
padding:  50px 4% 30px 6%;
margin:  0 0 80px 0;
	width: auto;



}


#contact_i2 h3{
	font-size: 160%;
	margin: 0 0 30px 0;
text-align: left;

	

	font-weight: bold;
	line-height: 1.5em;
	letter-spacing: 2px;
	width: auto;
	padding: 0;
	
	
}


#contact_i2 .underline {
 
   border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0 ;

}



#contact_i2 p {
  
  text-align: left;
	margin: 0 0 20px 6%;
	font-size: 110%;

}



#contact_i2 .btn a {
position: relative;
	display: inline-block;
	padding: 20px 0;
	margin: 15px 10px 10px auto;
width: 30%;
	float: left;
font-size: 100%;
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 50px;
	letter-spacing: 1px;
border: 5px solid #dcdcdc;
	
}

#contact_i2 .btn a:hover {
	
	color: #333;
border: 5px solid #000;
	background: #f3efef;
}


}

/* contact_i2 トップページお問い合わせ：sp　 */

@media screen and (max-width:767px) {
	

#contact_i2 {
padding:  30px 4% 30px 4%;
margin:  0;
	width: auto;


}


#contact_i2 h3{
	font-size: 120%;
	margin: 0 0 30px 0;
text-align: left;

	

	font-weight: bold;
	line-height: 1.5em;
	letter-spacing: 2px;
	width: auto;
	padding: 0;
	
	
}


#contact_i2 .underline {
 
   border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0 ;

}



#contact_i2 p {
  
  text-align: left;
	margin: 0 0 20px 6%;
	font-size: 105%;

}



#contact_i2 .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 15px auto 0 auto;
width: 87%;
	float: none;
font-size: 100%;
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 50px;
	letter-spacing: 1px;
border: 5px solid #dcdcdc;
	
}

#contact_i2 .btn a:hover {
	
	color: #333;
border: 5px solid #000;
	background: #f3efef;
}

}


/* 使用機材 pc */

#equipment {
padding: 0 0 100px 0;
margin:50px 0 0 0 ;
	background:url("../images/equipment/bg_equipment.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
background-color: #01a6f4;
}

#equipment .wave {
padding: 0 0 100px 0;
margin: 0 auto;
	height:  140px;
	background:url("../images/vision/bg_vision.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top bottom;


	
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;

}

#equipment .wave1 {
padding: 0 ;
margin: 0 auto;
	height:  160px;
	background:url("../images/schedule/bg_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top right;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
}


#equipment h2{
font-size: 700%;
font-family: 'Quicksand', sans-serif;
    text-align: center;
margin: 0 auto 10px auto;

	line-height: 1.2;
	font-weight: bold;
}


#equipment h3{
	margin: 0 auto ;
	text-align: center;
	font-size: 140%;
	letter-spacing: 0.5em;
	font-weight: bold;
	color: #000;
	
	width: auto;
}


#equipment h4{
	margin: 20px 0 5px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;
	
}

#equipment .underline {
  border-bottom: dotted 1px;
  width: 80px;
 text-align: center;
	margin: 30px auto 35px auto;
	color: #000;

}


#equipment .flame_c{

	padding: 40px 40px 50px 40px;
	margin: 250px auto 30px auto;
	width: 70%;

	border-radius: 20px ;
	background: #fff;

	letter-spacing: 2px;


}


#equipment .flame_c .flame_c_l{

	
	margin: 0 30px 30px 0;
	width: 45%;
	float: left;


	letter-spacing: 2px;


}

#equipment #mat{

	height: 400px;

	background:url("../images/bg_mat.jpg") no-repeat;
background-size: cover; 
margin: 50px 0;
    background-position: center right;
width: 80%;
	float: right;
}



#equipment .flame_r{

	padding: 10px 40px 40px 50px;
	margin: 60px auto 0 8%;
	width: 55%;

	border-radius: 20px;
	background: #fff;

	letter-spacing: 2px;


}

#equipment .flame_r h2{
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: -20px 0 0 -5px;
text-align: left;
	line-height: 1.2;
	font-weight: bold;
}

#equipment .flame_r .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 30px 0 ;
	color: #000;

}


#equipment p{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 5px 0;

	
}


#equipment .btn {
    
	margin:12px 0 0 0;
	
	text-align:left;

	
	

}

#equipment .btn a {

	position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto 0 auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	
	
}

#equipment .btn a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;

}


/* 使用機材 tab */

@media screen and (min-width:768px) and (max-width:959px) {


#equipment {
padding: 0 0 100px 0 ;
margin:50px 0 0 0 ;
	background:url("../images/equipment/bg_equipment.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: right top;

   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
background-color: #01a6f4;


}


#equipment #subttl{
	font-size: 120%;
	margin: 0%;
text-align: left;
	letter-spacing: 2px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}



#equipment .flame_c{

	padding: 5px 40px 40px 40px;
		margin: 130px 5% 0 5%;
		width: auto;
	float: none;
	border-radius: 20px;
	background: #fff;



}

#equipment .flame_c h2{
font-size: 600%;
font-family: 'Quicksand', sans-serif;
margin: 20px auto 0 auto;
text-align: center;

	font-weight: bold;
}
	
	#equipment h3{
	margin: 20px auto 10px auto ;
	text-align: center;
	font-size: 150%;
	letter-spacing: 0.5em;
	font-weight: bold;
	color: #000;
	
	width: 50%;
}

#equipment .flame_c .underline {
  border-bottom: dotted 1px;
  width: 80px;
margin: 20px auto 35px auto;
text-align: center;

	color: #000;

}

#equipment .flame_c .flame_c_l{

	
	margin: 0 0 30px 0;
	width: auto;
	float: none;


	letter-spacing: 2px;


}


#equipment .flame_r{

	padding: 5px 30px 40px 30px;
	margin: 10px 5% 30px 5%;
	width: auto;

	border-radius: 20px;
	background: #fff;




}

#equipment img{

	width: 25%;
	margin: 0 15px 0 0;
	float: left;
}


#equipment p{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 5px 0;
	
}


#equipment .btn {
    
	margin:12px 0 0 0;
	
	text-align:left;

	
	

}

#equipment .btn a {

	position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto 0 auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	
	
}

#equipment .btn a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;

}



}


/* 使用機材 sp */

@media screen and (max-width:767px) {


#equipment {
padding: 0 0 50px 0 ;
margin:70px 0 0 0 ;
	background:url("../images/equipment/bg_equipment.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: right top;
 
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 100%;
background-color: #01a6f4;
}



#equipment .flame_c h2{
font-size: 320%;
font-family: 'Quicksand', sans-serif;
margin: 10px auto 0 auto;
text-align: center;
	font-weight: bold;
}
	
	#equipment h3{
	margin: 20px auto 10px auto ;
	text-align: center;
	font-size: 130%;
	letter-spacing: 0.5em;
	font-weight: bold;
	color: #000;
	width: 50%;
}

#equipment .flame_c .underline {
  border-bottom: dotted 1px;
  width: 80px;
margin: 20px auto 35px auto;
text-align: center;

	color: #000;

}


#equipment #subttl{
	font-size: 120%;
	margin: 0%;
text-align: left;
	letter-spacing: 2px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
}


#equipment .flame_c{

	padding: 20px 30px 30px 30px;
		margin: 0 5%;
		width: auto;
	float: none;
	border-radius: 20px;
	background: #fff;

}


#equipment .flame_c .flame_c_l{

	
	margin: 0 0 30px 0;
	width: auto;
	float: none;


	letter-spacing: 2px;


}




#equipment p{

	font-size: 100%;
	letter-spacing: 0;
	margin: 0 0 5px 0;
}


#equipment .btn {
    
	margin:12px 0 0 0;
	
	text-align:left;

	
	

}

#equipment .btn a {

	position: relative;
	display: inline-block;
	padding: 15px 40px;
	margin: 10px auto 0 auto;
width: auto;
	
	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	
	
}

#equipment .btn a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;

}



#equipment img{

	width: auto;
	margin: 0 0 20px 0;
	float: left;
}
	


}





/* 挿画：お問い合わせとお申し込みの間 */
#mat{
margin: 0;
	height: 400px;
	background:url("../images/bg_mat.jpg") no-repeat;
	background-position: top left;
	background-size: 100% ;


}

@media screen and (max-width:767px) {
#mat {
	width: 100%;
	height: 240px;
background:url("../images/bg_mat_sp.jpg") no-repeat;
background-position: top left;
	background-size: 90% ;

	


}
}


/* 挿画：お申し込みの上 */
#mat2 {
	height: 400px;

	background:url("../images/bg_mat.jpg") no-repeat;
background-size: cover; 

    background-position: center right;
width: 80%;


}

@media screen and (min-width:768px) and (max-width:959px) {
#mat2 {
	width: auto;
	height: 450px;
	margin: 0;

background:url("../images/bg_mat2.jpg") no-repeat;
	 /* 画像を常に天地左右の中央に配置 */
  background-position:top center;
   
background-size: 100%;

}
}

@media screen and (max-width:767px) {
#mat2 {
	width: auto;
	height: 330px;
	margin: 0;

background:url("../images/bg_mat2.jpg") no-repeat;
	 /* 画像を常に天地左右の中央に配置 */
  background-position:top center;
   
background-size: 130%;
}
}



/* スクール：PC*/


#school {

margin: 0;
	padding: 0 0 400px 0;

	background:url("../images/access/bg_access.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom left;

	
	 background-size: 100%; /*--背景画像のサイズ--*/
	
}



#school h2{
font-size: 470%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0 0 0 -5px;
text-align: left;
	line-height: 1.2;
	font-weight: bold;

}


#school h3{
		margin: 10px 0 20px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;
	
	
}


#school .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0 ;

}


#school h4{
	
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	
}


#school .flame_l{
padding: 20px;
width: 36%;
	float:left;
background: #fff;
	margin: 0 60px 0 7%;
 box-shadow: 0 0 3px rgba(94, 94, 94, 0.3);
	border-radius: 20px;

	


}


#school .flame_r{

width: 46%;

margin: 0 auto 0 auto;
	text-align: left;
float:left;
	border-radius: 20px;
	

}

#school .flame_r p{

font-size: 100%;
	margin: 0 0 10px 0;
	


}




/*mainimg02
---------------------------------------------------------------------------*/
/*画像ブロック*/
#mainimg02, #subimg02 {
	clear: both;
	/*max-width: 1500px;*/
	width: 100%;	/*※マニュアル用に追加*/
	overflow: hidden;
	margin: 0 auto;
	/*position: absolute;*/
	position: relative;	/*※マニュアル用に追加*/
	
	
}
/*subimgブロックの画像*/
#subimg02 img {
	width: 100%;
	
	border: 3px solid #eeeeee;
	background-color: #eeeeee;
background-image: -webkit-gradient(linear, 0 0, 100% 100%,color-stop(.25, #F9F9F9), color-stop(.25, transparent),color-stop(.5, transparent), color-stop(.5, #F9F9F9),color-stop(.75, #F9F9F9), color-stop(.75, transparent),to(transparent));
-webkit-background-size: 14px 14px;
	width: 70%;	
	
	padding: 20px 10px 10px 10px;
	margin: 0 auto 30px auto;
}
/*３枚画像の共通設定*/
.slide01,.slide02,.slide03 {
	animation-duration: 20s;	/*実行する時間。「s」は秒の事。*/
	animation-iteration-count:infinite;		/*実行する回数。「infinite」は無限に繰り返す意味。*/
	position: absolute;left:0px;top:0px;width: 100%;height: auto;
	animation-fill-mode: both;
	animation-timing-function: linear;
	animation-delay: 3s;
	
	
}
/*土台画像*/
.slide00 {
	position: relative;width: 100%;height: auto;
}
/*１枚目*/
.slide01 {
	animation-name: slide1;		/*上で設定しているキーフレーム（keyframes）の名前*/
}
/*２枚目*/
.slide02 {
	animation-name: slide2;		/*上で設定しているキーフレーム（keyframes）の名前*/
}
/*３枚目*/
.slide03 {
	animation-name: slide3;		/*上で設定しているキーフレーム（keyframes）の名前*/
}


#school p{
  font-size: 120%;
	text-align: left;
	  margin: 0 0 10px 0;
  padding: 0;
}




#school .btn a {
	position: relative;
	display: inline-block;
	padding:4px 5px 0 5px;
	border: 3px solid #ca1a1d;
	float: left;
	font-size: 120%;
	background: #ca1a1d;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 10px 10px 0 0;
font-weight:bold;
	
}

#school .btn a:hover {
	background: #fff;
	color: #000;
	border: 3px solid #000;
}




/* スクール：tab*/

@media screen and (min-width:768px) and (max-width:959px) {
#school {

margin: 0;
	padding: 0 0 300px 0;


background:url("../images/access/bg_access.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom left;

	
	 background-size: 100%; /*--背景画像のサイズ--*/
	
}



#school h2{
font-size: 470%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;
margin: 0 0 0 -5px;
text-align: left;
	line-height: 1.2;
	font-weight: bold;

}


#school h3{
		margin: 10px 0 30px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #000;
	
	
}


#school .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0 ;

}


#school h4{
	
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	
}

#school .flame_l{
padding: 0;
width: auto;
	float:none;
background: #fff;
	margin: 50px 0 0 0;
 box-shadow: none;
	border-radius: 0;
		border: none;    	/* 内側の線になる一本線の枠線をひく*/
	outline: none;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 0;        /* 内側の線になる一本線の枠線をひく*/
	


}
	


#school .flame_l p{

font-size: 105%;
	margin: 0 0 20px 0;
	


}

#school .flame_r{

width: 90%;
	float:none;

margin: 30px 0 0 6%;
	text-align: left;

	

}

#school .flame_r p{

font-size: 105%;
	margin: 0 0 10px 0;
	font-weight: normal;
	


}
	

#school .btn a {
	position: relative;
	display: inline-block;
	padding:4px 5px 0 5px;
	border: 3px solid #ca1a1d;
	float: left;
	font-size: 120%;
	background: #ca1a1d;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 10px 10px 0 0;
font-weight:bold;
	
}

#school .btn a:hover {
	background: #fff;
	color: #ca1a1d;
	border: 2px solid #ca1a1d;
}

}

/* スクール：sp*/

@media screen and (max-width:767px) {
#school {

margin: 50px 0 0 0;
	padding: 0 0 120px 0;


	background:url("../images/access/bg_access.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom left;

	
	 background-size: 100%; /*--背景画像のサイズ--*/

}


#school h2{
		
margin: 30px 0 0 -3px;
font-family: 'Quicksand', sans-serif;
}


#school h3{
		margin: 10px 0 30px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	color: #333;
	
}


#school .underline {
  border-bottom: dotted 1px #7D7A7A;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 0 ;

}


#school h4{
	
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	
}


#school .flame_l{
padding: 0;
width: auto;
	float:none;
background: #fff;
	margin: 0;
 box-shadow: none;
	border-radius: 7px;
		border: none;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 1px #fff;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 0;        /* 内側の線になる一本線の枠線をひく*/

}

#school .flame_l p{

font-size: 105%;
	margin: 0 0 20px 0;


}

#school .flame_r{

width: 90%;
	float:none;

margin: 0 0 0 6%;
	text-align: left;


}

#school .flame_r p{

font-size: 105%;
	margin: 0 0 10px 0;
	font-weight: normal;


}
	



#school .btn a {
		position: relative;
	display: inline-block;
	padding:8px 7px 2px 7px;
	border: 2px solid #ca1a1d;
	float: left;
	font-size: 120%;
	background: #ca1a1d;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 10px 15px 0 auto;
font-weight:bold;
	
}

#school .btn a:hover {
	background: #fff;
	color: #ca1a1d;
	border: 2px solid #ca1a1d;
}

}




/* 練習の流れ */

.List {
margin-left: auto;
margin-right: auto;
max-width: 1024px;
	padding: 0 0 0 0;
	
}



.List-Item {

width: 88%;
	padding: 5px 30px 10px 30px ;
	
	
	
	margin: 7px auto 60px auto;
	 box-shadow: 0px 0px 0px 8px #f3f3f3;
	opacity: 0.96;
background: repeating-linear-gradient(-45deg, #fdfdfd, #fdfdfd 10px, #fff 0, #fff 20px);

}

@media screen and (min-width:768px) and (max-width:959px) {
.List-Item {

width: 95%;
	padding: 10px 20px ;
	
	background: #f7f7f7;
	margin: 10px auto 40px auto;
	 box-shadow: 0px 0px 0px 10px #f3f3f3;
	opacity: 0.96;
	


}

}

@media screen and (max-width: 767px) {
.List-Item {

width: 97%;

	padding: 5px;
	background: #f7f7f7;
	margin: 10px auto 10px auto;
	 box-shadow: 0px 0px 0px 10px #f3f3f3;
	opacity: none;
	border: 1px #000;


}

}

.List-Item:nth-of-type(1) {
border-top: 0;
}

.List-Item-Content {
margin-left: auto;
margin-right: auto;

max-width: 1024px;
display: flex;
align-items: center;

}

@media screen and (max-width: 767px) {
.List-Item-Content {
padding: 0;

flex-wrap: wrap;

}
}


.List-Item-Content.one {
padding-top: 0;
}

.List-Item-Content-Number {
position: relative;
margin-right: 40px;
border-radius: 50%;
width: 123px;
height: 78px;
line-height: 80px;
text-align: center;
background: #2e8b57;
color: #fff;
font-size: 250%;
	border: 1px solid #2e8b57;
		
}

@media screen and (max-width: 767px) {
.List-Item-Content-Number {
display: none;
}
}


.List-Item-Content-Number-Line {
position: absolute;
top: -70%;
left: 50%;
transform: translate(-50%,-50%);
width: 4px;
height: 90px;
background: #ccc;
	opacity: 0.6;
	
}

@media screen and (max-width: 767px) {
.List-Item-Content-Number-Line {
display: none;
	
}
}


.List-Item-Content-Title {
margin-right: 0;
flex-basis: 90%;
color: #1A1A1A;

font-size: 130%;
font-weight: bold;

}


.List-Item-Content-Title p {


color: #000;
	margin: 30px 0 0 0;
}
@media screen and (min-width:768px) and (max-width:959px) {
	
.List-Item-Content-Title p {

font-size: 65%;
color: #000;
	margin: 10px 0 0 0;
}
}
	
	
@media screen and (max-width: 767px) {
.List-Item-Content-Title {
margin:0;
flex-basis: auto;
color: #1A1A1A;
font-size: 140%;
font-weight: bold;
	float: none;
	width: 100%;
	
}
	

}


.List-Item-Content-Description {
line-height: 1.5;

margin: 0;

}

.List-Item-Content-Description img {

	margin: 0;
	box-shadow: 5px 5px 10px #dae0dc;
-webkit-box-shadow: 5px 5px 10px #dae0dc;
-moz-box-shadow: 5px 5px 10px #dae0dc;
	

}

@media screen and (min-width:768px) and (max-width:959px) {


}

@media screen and (max-width: 767px) {
.List-Item-Content-Description {
margin-left: 0;
max-width: 100%;
font-weight: normal;
font-size: 13px;
	padding: 0;
	float: none;
	width: 100%;
	vertical-align: top;
	
}
	

	
.List-Item-Content-Description img {
width: 100%;
float: left;
	padding: 10px;
	background: #fff;
	margin: 0;
	box-shadow: 5px 5px 10px #dae0dc;
-webkit-box-shadow: 5px 5px 10px #dae0dc;
-moz-box-shadow: 5px 5px 10px #dae0dc;

}
}
 



/*CSSスライドショー設定：各3枚スライド：MEDIAで使用
---------------------------------------------------------------------------*/
/*１枚目*/
@keyframes slide1 {
	0% {opacity: 0; transform: scale(1);}
	10% {opacity: 1;}
	40% {transform: scale(1.05);}
	50% {opacity: 1;}
	60% {opacity: 0;}
	100% {opacity: 0;}
}
/*２枚目*/
@keyframes slide2 {
	0% {opacity: 0;}
	25% {opacity: 0; transform: scale(1);}
	35% {opacity: 1;}
	65% {transform: scale(1.05);}
	75% {opacity: 1;}
	85% {opacity: 0;}
	100% {opacity: 0;}
}
/*３枚目*/
@keyframes slide3 {
	0% {opacity: 0;}
	50% {opacity: 0; transform: scale(1);}
	60% {opacity: 1;}
	80% {opacity: 1;}
	90% {opacity: 0; transform: scale(1.05);}
	100% {opacity: 0;}
}

/*mainimg
---------------------------------------------------------------------------*/
/*画像ブロック*/
#mainimg, #subimg {
	clear: both;
	/*max-width: 1500px;*/
	width: 100%;	/*※マニュアル用に追加*/
	overflow: hidden;
	margin: 0 auto;
	/*position: absolute;*/
	position: relative;	/*※マニュアル用に追加*/
}
/*subimgブロックの画像*/
#subimg img {
	width: 100%;
	border: 3px solid #eeeeee;
	background-color: #eeeeee;
background-image: -webkit-gradient(linear, 0 0, 100% 100%,color-stop(.25, #F9F9F9), color-stop(.25, transparent),color-stop(.5, transparent), color-stop(.5, #F9F9F9),color-stop(.75, #F9F9F9), color-stop(.75, transparent),to(transparent));
-webkit-background-size: 14px 14px;
	width: 70%;	
	
	padding: 20px 10px 10px 10px;
	margin: 0 auto 30px auto;
}
/*３枚画像の共通設定*/
.slide1,.slide2,.slide3 {
	animation-duration: 20s;	/*実行する時間。「s」は秒の事。*/
	animation-iteration-count:infinite;		/*実行する回数。「infinite」は無限に繰り返す意味。*/
	position: absolute;left:0px;top:0px;width: 100%;height: auto;
	animation-fill-mode: both;
	animation-timing-function: linear;
	animation-delay: 3s;
	
	
}
/*土台画像*/
.slide0 {
	position: relative;width: 100%;height: auto;
}
/*１枚目*/
.slide1 {
	animation-name: slide1;		/*上で設定しているキーフレーム（keyframes）の名前*/
}
/*２枚目*/
.slide2 {
	animation-name: slide2;		/*上で設定しているキーフレーム（keyframes）の名前*/
}
/*３枚目*/
.slide3 {
	animation-name: slide3;		/*上で設定しているキーフレーム（keyframes）の名前*/
}



/*CSSスライドショー設定：各3枚スライド：MEDIAで使用
---------------------------------------------------------------------------*/
/*１枚目*/
@keyframes slide01 {
	0% {opacity: 0; transform: scale(1);}
	10% {opacity: 1;}
	40% {transform: scale(1.05);}
	50% {opacity: 1;}
	60% {opacity: 0;}
	100% {opacity: 0;}
}
/*２枚目*/
@keyframes slide02 {
	0% {opacity: 0;}
	25% {opacity: 0; transform: scale(1);}
	35% {opacity: 1;}
	65% {transform: scale(1.05);}
	75% {opacity: 1;}
	85% {opacity: 0;}
	100% {opacity: 0;}
}
/*３枚目*/
@keyframes slide03 {
	0% {opacity: 0;}
	50% {opacity: 0; transform: scale(1);}
	60% {opacity: 1;}
	80% {opacity: 1;}
	90% {opacity: 0; transform: scale(1.05);}
	100% {opacity: 0;}
}






/* 動画 movie：PC*/

#movie{
	padding: 0 0 80px 0;
margin: 100px 0 160px 0;


background:url("../images/bg_movie.jpg") ;
	background-position: top left;	
	 /* 画像をタイル状に繰り返し表示しない */
  background-repeat: no-repeat;
   
  /* コンテンツの高さが画像の高さより大きい時、動かないように固定 */
  background-attachment: fixed;
   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: 91%;
	
	
}




#movie h2{
	
	margin: -80px 0 20px 8%;

padding: 75px 0;
	
	background:url("../images/h2_movie.png") no-repeat;
	background-position: bottom left;
	

}

#movie h3{
	
	margin: 0 0 30px 8%;
font-size: 200%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
	line-height: 1.5;
}
	
#movie h4{
	
	margin: 10px 0 20px 0;
font-size: 105%;
	letter-spacing: 1px;
	padding: 0;
	text-align: center;
	color: #000;
}
	
#movie .underline {
  border-bottom: solid 2px;
  width: 80px;
  text-align: left;
	margin: 0 0 40px 8% ;
	color: #000;
}


#movie .flame_l{
padding: 0;
	width: 60%;
float:left;
	margin: 0 30px 0 0;
	
}



#movie .flame_r{
	float:right;
	width: 94%;
	padding: 0;
	margin: 0 3% 0 0;
}

#movie .flame_r img{
	background:  #fbfbfb;
	padding: 15px;
	width: 90%;
	
}



#movie .btn {
    
	
	margin:0 30px 0 0;
	
	text-align:center;
	width: 10%;
	font-size: 90%;
	float: right;
	

}

#movie .btn a {
	position: relative;
	display: inline-block;
	padding: 15px;
	background:#c72d23;
	width: 100%;
font-weight: normal;
	border-radius: 50px;
	color: #fff;
}

#movie .btn a:hover {
	
	font-weight: bold;
	opacity: 0.9;
	
}


/* 動画 movie：tab*/

@media screen and (min-width:768px) and (max-width:959px) {

#movie{
	padding: 110px 0;
margin: 150px 0 160px 11%;


background:url("../images/bg_movie.jpg") ;
	background-position: top center;	
	 /* 画像をタイル状に繰り返し表示しない */
  background-repeat: no-repeat;
   
  /* コンテンツの高さが画像の高さより大きい時、動かないように固定 */
  background-attachment: fixed;
   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: cover;

}
	
#movie h2{
	
	margin: -180px 0 20px 6%;

padding: 70px 0;
	
	background:url("../images/h2_movie.png") no-repeat;
	background-position: top left;
	background-size: 80%;

}

#movie h3{
	
	margin: 0 0 30px 6%;
font-size: 125%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
	line-height: 1.5;

}

#movie .underline {
  border-bottom: solid 2px;
  width: 80px;
  text-align: left;
	margin: 0 0 40px 6% ;
	color: #000;
}
	
	
#movie h4{
	
	margin: 10px 0 20px 0;
font-size: 105%;
	letter-spacing: 1px;
	padding: 0;
	text-align: center;
	color: #000;
}

	
#movie .flame_l{
padding: 0;
	width: 98%;
float:none;
	margin: 0;
	
}



#movie .flame_r{
float:none;
	width: 100%;
	padding: 0;
	margin: 60px 0 0 -50px;
	
}

#movie .flame_r img{
	background:  #fbfbfb;
	padding: 10px;
	margin: 0;
	
}


#movie .btn {
    
	
	margin:0 ;
	
	text-align:center;
	width: auto;
	font-size: 90%;
	float: right;
	

}

#movie .btn a {
	position: relative;
	display: inline-block;
	padding: 15px;
	background:#c72d23;
	width: 100%;
font-weight: normal;
	border-radius: 50px;
	color: #fff;
}

#movie .btn a:hover {
	
	font-weight: bold;
	opacity: 0.9;
	
}	
}


/* 動画：sp*/

@media screen and (max-width:767px) {
#movie{
	padding: 30px 0 50px 0;
margin: 80px 0 100px 10%;


background:url("../images/bg_movie.jpg") ;
	background-position: top center;	
	 /* 画像をタイル状に繰り返し表示しない */
  background-repeat: no-repeat;
   
  /* コンテンツの高さが画像の高さより大きい時、動かないように固定 */
  background-attachment: fixed;
   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: cover;
	

}
	
#movie h2{
	
	margin: -70px 0 0 5%;

padding: 55px 0;
	width:auto;
	background:url("../images/h2_movie.png") no-repeat;
	background-position: top left;
	background-size: 90%;
	
	

}

#movie h3{
	
	margin: 0 0 30px 6%;
font-size: 125%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
	line-height: 1.5;
width: auto;
}

#movie .underline {
  border-bottom: solid 2px;
  width: 80px;
  text-align: left;
	margin: 0 0 30px 6% ;
	color: #000;
}

	
#movie h4{
	
	margin: 5px 0 10px 0;
font-size: 105%;
	letter-spacing: 1px;
	padding: 0;
	text-align: center;
	color: #000;
}	
#movie .flame_l{
padding: 0;
	width: auto;
float:none;
	margin: 0;
	
	
}


#movie .flame_r{
float:none;
	width: 100%;
	padding: 0;
	margin: 0 0 0 -20px;
	
}

#movie .flame_r img{
	
	padding: 0;
	margin: 0;
	width: 97%;
	
}


#movie .btn {
    
	
	margin:0 ;
	
	text-align:center;
	width: 30%;
	font-size: 90%;
	float: none;
	

}

#movie .btn a {
	position: relative;
	display: inline-block;
	padding: 15px;
	background:#c72d23;
	width: 100%;
font-weight: normal;
	border-radius: 50px;
	color: #fff;
}

#movie .btn a:hover {
	
	font-weight: bold;
	opacity: 0.9;
	
}

}








/*================================================
 * ご依頼・お問い合わせ：contact.html
 ================================================*/

/* お問い合わせ：pc　 */

#contact {
	
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#contact #ttl_bg{
	font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 auto;
background:url("../images/contact/bg_contact.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
height: 350px;

}




#contact .inner {
margin: 0 auto 80px auto;

	background: #fff;
	padding: 50px 50px 0 80px;
	
}



#contact .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#contact h2{
	
margin: 140px auto 20px auto;
	font-size: 400%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#contact #subttl{
	font-size: 120%;
	margin: 0 auto;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}


#contact h3{
	font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	
	
}






#contact h4{
	
	margin: 30px 0 15px 0;
font-size: 130%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#contact h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}




/* お申し込み（個人情報の取扱い・携帯）*/

#contact .flame_l2{

	float:left;
	width: 45%;

	margin: 30px 30px 0 0;
}


#contact .flame_r2{
	
	width: 50%;
float:left;
	margin: 20px 0 0 0;
	text-align: left;

}




#contact table{
  border-bottom: #ccc 1px dotted;
  text-align: center;
  padding: 10px;
	width: 90%;
	letter-spacing: 1px;
	margin: 50px 0;
}



#contact .tbl-r02 {
  margin: 80px 0;
	width: 100%;
	font-size:105%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
}


#contact .tbl-r02 th {
font-weight: bold;
 border: dotted 1px #ccc;
  color: #000;
  padding: 15px 10px 15px 50px;
	width: 25%;
	border-left: none;
	border-right: none;
	text-align: center;

	
	
}
#contact .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	
}

#contact .tbl-r02 td p {
	
	text-align: center;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 20px 0 0 0;
	

}


#contact iframe{
	
	width: 95%;
	height: 300px;
	margin: 10px auto;

	border: 1px dotted #dcdcdc;
	
	padding: 10px;

	

}


/* お問い合わせ：tab　 */

@media screen and (min-width:768px) and (max-width:959px) {
#contact #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 auto 20px 0;;
background:url("../images/contact/bg_contact.jpg") no-repeat;
	background-position: top left;
background-size:100%;
height: 350px;


}






#contact .inner {
margin: 0 2%;
	background: #fff;
	padding: 0 0 50px 0;
	width: auto;
	
}



#contact .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#contact h2{
margin: 140px auto 20px auto;
	font-size: 380%;
font-family: 'Quicksand', sans-serif;
	

    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#contact #subttl{
	font-size: 110%;
	margin: 0;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}



#contact h3{
	font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	
	
}






#contact h4{
	
	margin: 30px 0 15px 0;
font-size: 130%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#contact h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}


/* お申し込み（個人情報の取扱い・携帯）*/

#contact .flame_l2{

	float:left;
	width: 45%;

	margin: 30px 30px 0 0;
}


#contact .flame_r2{
	
	width: 50%;
float:left;
	margin: 20px 0 0 0;
	text-align: left;

}






#contact table {
  margin: 50px 0;
	width: 98%;
	font-size:105%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
}


#contact .tbl-r02 table {
  margin: 80px 0;
	width: 98%;
	font-size:105%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
	
}


#contact .tbl-r02 th {
font-weight: bold;
 border: dotted 1px #ccc;
  color: #000;
  padding: 15px 10px 15px 10px;
	width: 30%;
	border-left: none;
	border-right: none;
	text-align: left;

	
	
}
#contact .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	
}

#contact .tbl-r02 td p {
	
	text-align: center;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 20px 0 0 0;
	

}
}


/* お問い合わせ：sp　 */

@media screen and (max-width:767px) {

#contact #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 auto 20px 0;
background:url("../images/contact/bg_contact_sp.jpg") no-repeat;
	background-position: top left;
background-size:140%;
height: 250px;


}






#contact .inner {
margin: 0 3% 0 4%;
	background: #fff;
	padding: 0 0 50px 0;
	width: auto;
	
}



#contact .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#contact h2{
	
margin: 100px auto 20px auto;
	font-size: 280%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#contact #subttl{
	font-size: 120%;
	margin: 0 auto;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}



#contact h3{
	font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	
	
}






#contact h4{
	
	margin: 30px 0 15px 0;
font-size: 130%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#contact h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}





/* お申し込み（個人情報の取扱い・携帯）*/

#contact .flame_l2{

	float:left;
	width: 45%;

	margin: 30px 30px 0 0;
}


#contact .flame_r2{
	
	width: 50%;
float:left;
	margin: 20px 0 0 0;
	text-align: left;

}





#contact table {
  margin: 50px 0;
	width: 96%;
	font-size:105%;
	

	border: none;
	
}
	


#contact .inner table {
	width: 95%;
	 
	
}


#contact .inner .tbl-r02 {
    width: 100%;
border: none;
	 margin: 0 0 40px 0;
  }

#contact .inner .tbl-r02 th,
#contact .inner .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 96.5%;
	padding: 0px 8px 0 8px;
	border: none;
	text-align: left;
	margin: 10px 0;


	
		
  }

	
/* お申し込み*/
#contact .flame_l{
background:url("../images/contact/contact01.jpg") no-repeat;
	background-position: top left;
	background-size:130%;
	float:none;
	width: auto;
padding: 0;
	margin: 0;
	height: 240px;



}


#contact .flame_r{


	width: 96%;
padding:0 ;
float: none;
background: #fbfaf5;

	margin: 0 0 0 3%;
	

}


/* お申し込み（個人情報の取扱い）*/

#contact .flame_l2{

	float:none;
	width: 96%;

	margin: 30px 0 0 0;
}


/* お申し込み（携帯）*/
#contact .flame_r2{
	
	width: 97%;
float:none;
	margin: 0;
	text-align: left;

}




#contact iframe{
width: 97%;
	height: 380px;
	margin: 20px 0;
	float: none;
	border: 1px solid #ccc;
	padding: 10px;
	background: none;
	
}







#contact #mobile_f{
width: 97%;
	
	margin: 20px 0 50px 0;
	float: none;
	font-size: 98%;



	
}




	
input[type="text"]{
	width: 100%;
	max-width: 300px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

textarea {
	width: 100%;
	max-width: 400px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

/*sent.php*/
#submit article{
	padding:0 10px 50px 10px;
	margin: 0 0 0 10px;

	
}
#submit table{
	width:95%;
	margin:0 auto;
	background:#FFF;
}
#submit table tr td{
	border:#AAA solid 1px;
	text-align:left;
}
#submit table tr .gray{
	background:#DDD;
	width:40%;
}
#submit .submit-box{
	text-align:center;
	font-size: 120%;
	padding: 0;
	margin: 30px 0 0 0;
}
	


#submit .error{
	text-align:center;
	color:#F00;
}
	
}



/*sent.php*/
#submit article{
	padding:150px 0 50px 0;
}
#submit table{
	width:60%;
	margin:0 auto;
	background:#FFF;
}
#submit table tr td{
	border:#AAA solid 1px;
	text-align:left;
}
#submit table tr .gray{
	background:#DDD;
	width:30%;
}
#submit .submit-box{
	text-align:center;
	font-size: 120%;
	padding:30px 0 50px 0;
}


#submit .error{
	text-align:center;
	color:#F00;
}


/*================================================
 * ご予約
 ================================================*/

#reserve {
	
	position: relative;
  overflow: hidden;
  margin: 0;
	  padding:0;

}

#reserve #ttl_bg{
	font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 auto;
background:url("../images/reserve/bg_reserve.jpg") no-repeat;
	background-position: center center;
	background-size:100%;
height: 350px;


}



#reserve .inner {
margin: 0 auto;
	background: #fff;
	padding: 50px 0;
	
}


#reserve .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#reserve h2{
margin: 140px auto 20px auto;
	font-size: 480%;

    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#reserve #subttl{
	font-size: 120%;
	margin: 0 auto;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}




#reserve h3{
	
		font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#reserve h4{
	
	margin: -20px 0 15px 0;
font-size: 140%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#reserve h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}



#reserve h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}




#reserve iframe{
	
	width: 44.5%;
	height: 380px;
	margin: 40px 10px 40px 0;
	float: left;
	border: 1px dotted #ccc;
	padding: 20px;
	
	
}



#reserve #mobile{
width: 98%;
	
	margin: 0 0 50px 0;
	float: left;
	font-size: 98%;

}




#reserve .tbl-r02 {
  margin: 80px 0;
	width: 100%;
	font-size:105%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
}


#reserve .tbl-r02 th {
font-weight: bold;
 border: dotted 1px #ccc;
  color: #000;
  padding: 15px 10px 15px 50px;
	width: 25%;
	border-left: none;
	border-right: none;
	text-align: center;

	
	
}
#reserve .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	
}

#reserve .tbl-r02 td p {
	
	text-align: center;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 20px 0 0 0;
	

}

input[type="text"]{
	width: 100%;
	max-width: 300px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

textarea {
	width: 80%;
	max-width: 400px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}


/*LINE*/




#reserve img {
	
	margin: 0 20px 0 0;
	width: 11%;
	float: left;

}

#reserve #flame #ttl {
	
	margin: 0 0 20px 0;
	font-size: 150%;
	text-align: center;
	font-weight: bold;
	padding: 0 0 15px 0;
	border-bottom: 1px dotted #ccc;
	letter-spacing: 2px;

}

#reserve #flame p {
	
	margin: 0 0 10px 0;
	font-size: 110%;
	

}

.zoom_txt{
	
	font-size: 120%;
	margin: 15px 0 0 0;
	letter-spacing: 1px;
	text-align: left;
	font-weight: bold;

}
.zoom_line{
	
	font-size: 170%;
	margin: 20px 0 50px 0;
	letter-spacing: 5px;
	text-align: center;
	font-weight: bold;

}

.zoom_guide{
	
	font-size: 150%;
	font-weight: bold;


}

.zoom_icon{
	
	font-size: 250%;
	margin: 0;
	letter-spacing: 5px;
	text-align: left;
	font-weight: bold;
	


}



.zoom_icon a{
	
	font-size: 180%;
	margin: 20px 0;
	letter-spacing: 5px;
	text-align: left;
	font-weight: bold;
	color: #fff;
	


}

.zoom_icon a:hover{
	
	opacity: 0.9;


}

#reserve #main{

width:auto;
border:2px solid #ccc;
margin: 10px 0 0 0;
padding:10px;

}


/*sent.php*/
#submit article{
	padding:150px 0 50px 0;
}
#submit table{
	width:60%;
	margin:0 auto;
	background:#FFF;
}
#submit table tr td{
	border:#AAA solid 1px;
	text-align:left;
}
#submit table tr .gray{
	background:#DDD;
	width:30%;
}
#submit .submit-box{
	text-align:center;
	font-size: 120%;
	padding:30px 0 50px 0;
}


#submit .error{
	text-align:center;
	color:#F00;
}

 
 
@media screen and (min-width:768px) and (max-width:959px) {

#reserve #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 auto 20px auto;
	background:url("../images/reserve/bg_reserve.jpg") no-repeat;
	background-position: center top;
	background-size:100%;
height: 350px;

}



#reserve .inner {
margin: 0 2% 0 2%;
	background: #fff;
	padding: 0 0 50px 0;
	width: auto;
}


#reserve .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#reserve h2{
margin: 140px auto 20px auto;
	font-size: 380%;
font-family: 'font-family: 'Quicksand', sans-serif;dies', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#reserve #subttl{
	font-size: 110%;
	margin: 0;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}




#reserve h3{
	
		font-size: 150%;
	margin: 0 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#reserve h4{
	
	margin: -20px 0 15px 0;
font-size: 140%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#reserve h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}



#reserve h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}




#reserve iframe{
	
	width: 94.5%;
	height: 380px;
	margin: 20px 0 40px 0;
	float: left;

	padding: 20px;
	
	
}





#reserve .tbl-r02 table {
  margin: 80px 0;
	width: 98%;
	font-size:105%;
	border-top: dotted 1px #ccc;
border-bottom: dotted 1px #ccc;
	border-left: none;
	
	
}


#reserve .tbl-r02 th {
font-weight: bold;
 border: dotted 1px #ccc;
  color: #000;
  padding: 15px 10px 15px 10px;
	width: 30%;
	border-left: none;
	border-right: none;
	text-align: left;

	
	
}
#reserve .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	
}

#reserve .tbl-r02 td p {
	
	text-align: center;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 20px 0 0 0;
	

}
/*LINE*/

#reserve #flame {
	
	margin: 20px auto 80px auto;
	border: 5px solid #ccc;
	padding: 20px 20px 10px 20px;
	border-radius: 15px;
	width: 90%;
	border: 1px solid #000;
	
	
}



#reserve img {
	
	margin: 0 20px 0 0;
	width: 15%;
	float: left;

}

#reserve #flame #ttl {
	
	margin: 0 0 20px 0;
	font-size: 140%;
	text-align: center;
	font-weight: bold;
	padding: 0 0 15px 0;
	border-bottom: 1px dotted #ccc;
	letter-spacing: 2px;

}

#reserve #flame p {
	
	margin: 0 0 10px 0;
	font-size: 110%;
	

}
	
.zoom_guide{
	
	font-size: 150%;
	font-weight: bold;

}

.zoom_txt{
	
	font-size: 120%;
	margin: 20px 0 0 0;
	letter-spacing: 1px;
	text-align: center;

}
.zoom_line{
	
	font-size: 170%;
	margin: 20px 0 50px 0;
	letter-spacing: 5px;
	text-align: center;
	font-weight: bold;

}

.zoom_icon{
	
	font-size: 180%;
	margin: 0;
	letter-spacing: 5px;
	text-align: left;
	font-weight: bold;
	


}

.zoom_icon a{
	
	font-size: 180%;
	margin: 20px 0;
	letter-spacing: 5px;
	text-align: left;
	font-weight: bold;
	color: #fff;
	


}

.zoom_icon a:hover{
	
	opacity: 0.9;


}
}

@media screen and (max-width:767px) {



#reserve #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 auto 20px auto;
	background:url("../images/reserve/bg_reserve_sp.jpg") no-repeat;
	background-position: right center;
	background-size:140%;
height: 250px;


}

#reserve .inner {
margin: 0;
	background: #fff;
	padding: 0 3% 50px 4%;
	width: auto;
}


#reserve h2{

margin: 120px auto 10px auto;
	font-size: 230%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#reserve #subttl{
	font-size: 110%;
	margin: 0 auto;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}

#reserve h3{
	
		font-size: 150%;
	margin: 0 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#reserve h4{
	
	margin:15px 0;
font-size: 140%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}


#reserve h5{
	
	margin: 50px 0 50px 0;
font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
	
}

#reserve h6{
	
	margin: 20px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}



#reserve p {
 
	text-align: left;
	font-size: 100%;
	
  
}


#reserve iframe{
	
	width: 93%;
	height: 380px;
	margin:  20px 0 ;
	float: none;
	border: 1px solid #ccc;
	padding: 20px 10px;
	background: #fdfdfd;

}
	

#reserve #mobile{
width: auto;
	
	margin: 0 0 50px 0;
	float: left;
	font-size: 98%;

}


#reserve.inner table {
	width: 95%;
	 
	
}


#reserve .inner .tbl-r02 {
   width: 95%;
border: none;
	 margin: 0 0 40px 0;
  }

#reserve .inner .tbl-r02 th,
#reserve .inner .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 96.5%;
	padding: 0px 8px 0 8px;
	border: none;
	text-align: left;
	margin: 10px 0;


	
		
  }


	
input[type="text"]{
	width: 100%;
	max-width: 300px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

textarea {
	width: 100%;
	max-width: 400px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}
	
	
/*LINE*/

#reserve #flame {
	
	margin: 20px auto 80px auto;
	
	padding: 20px 20px 10px 20px;
	border-radius: 15px;
	width: 87%;
	background: #fff;
	
}

#reserve img {
	
	margin: 0 20px 0 0;
	width: 25%;
	float: left;

}

#reserve #flame #ttl {
	
	margin: 0 0 20px 0;
	font-size: 125%;
	text-align: left;
	font-weight: bold;
	padding: 0 0 15px 0;
	border-bottom: 1px dotted #ccc;
	letter-spacing: 1px;

}
	
.zoom_guide{
	
	font-size: 130%;
	font-weight: bold;

}

.zoom_line{
	
	font-size: 140%;
	margin: 20px 0 50px 0;
	letter-spacing: 2px;
	text-align: center;
	font-weight: bold;
	


}
/*sent.php*/
#submit article{
	padding:0 10px 50px 10px;
	margin: 0 0 0 10px;;

	
}
#submit table{
	width:95%;
	margin:0 auto;
	background:#FFF;
	
}
#submit table tr td{
	border:#AAA solid 1px;
	text-align:left;
}
#submit table tr .gray{
	background:#DDD;
	width:40%;
}
#submit .submit-box{
	text-align:center;
	font-size: 120%;
	padding: 0;
	margin: 30px 0 0 0;
}
	


#submit .error{
	text-align:center;
	color:#F00;
}
}



/*================================================
 * サンクスページ
 ================================================*/

/* サンクスページ：pc*/

#thanks {
	
	position: relative;
  overflow: hidden;
  margin: 0;
	  padding:0;

}

#thanks #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 auto;
background:url("../images/thanks/bg_thanks.jpg") no-repeat;
	background-position: top center;
	background-size:100%;
height: 350px;


}


#thanks .inner {
margin: 0 auto;
	background: #fff;
	padding: 50px 0;
	
}


#thanks .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#thanks h2{
margin: 140px auto 20px auto;
	font-size: 480%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#thanks #subttl{
	font-size: 120%;
	margin: 0 auto;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}


#thanks h3{
	
		font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#thanks h4{
	
	margin: 40px 0 15px 0;
font-size: 140%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#thanks h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}



#thanks h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}


#thanks .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 30px auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

#thanks .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}
/* サンクスページ：tab*/

@media screen and (min-width:768px) and (max-width:959px) {
	



#thanks #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 auto 20px auto;

	background:url("../images/thanks/bg_thanks.jpg") no-repeat;
	background-position:top center;
	background-size:100%;
height: 350px;

}



#thanks .inner {
margin: 0 2% 0 2%;
	background: #fff;
	padding: 0 0 50px 0;
	width: auto;
	
}


#thanks .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}



#thanks h2{
margin: 140px auto 20px auto;
	font-size: 380%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#thanks #subttl{
		font-size: 120%;
	margin: 0;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}


#thanks h3{
	
		font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#thanks h4{
	
	margin: 40px 0 15px 0;
font-size: 140%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#thanks h5{
	
	margin: 0 0 15px 0;
font-size: 130%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}



#thanks h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}




#thanks .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 30px auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

#thanks .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}

}


@media screen and (max-width:767px) {

#thanks #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 auto 20px auto;

	background:url("../images/thanks/bg_thanks_sp.jpg") no-repeat;
	background-position: left center;
background-size:140%;
height: 250px;

}



#thanks .inner {
margin: 0 3% 0 4%;
	background: #fff;
	padding: 0 0 50px 0;
	width: auto;
	
}


#thanks .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}



#thanks h2{

margin: 100px auto 20px auto;
	font-size: 280%;
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#thanks #subttl{
	font-size: 120%;
	margin: 0;
text-align: center;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1em;
	
	width: auto;
	padding: 0;
	
	
}


#thanks h3{
	
		font-size: 130%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	font-weight: bold;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#thanks h4{
	
	margin: 40px 0 15px 0;
font-size: 120%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#thanks h5{
	
	margin: 0 0 15px 0;
font-size: 110%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #000;
	
}



#thanks h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}

#thanks .btn a {
position: relative;
	display: inline-block;
	padding: 15px 20px;
	margin: 30px auto 20px auto;
width: auto;
	float: right;

	text-align: center;
	text-decoration: none;
	-moz-transition: 0.5s;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
	z-index: 1;
	color: #fff;
	background: #ca1a1d;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #ccc;
	
}

#thanks .btn a:hover {
	
	color: #333;
border: 4px solid #000;
	background: #f3efef;
}

}


/*sent.php*/
#submit article{
	padding:150px 0 50px 0;
}
#submit table{
	width:80%;
	margin:0 auto;
	background:#FFF;
}
#submit table tr td{
	border:#AAA solid 1px;
	text-align:left;
}
#submit table tr .gray{
	background:#DDD;
	width:30%;
}
#submit .submit-box{
	text-align:center;
	font-size: 120%;
}


#submit .error{
	text-align:center;
	color:#F00;
}


@media screen and (max-width:767px) {

#submit header{
	display: none;
	}




	
input[type="text"]{
	width: 100%;
	max-width: 300px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

textarea {
	width: 100%;
	max-width: 400px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

/*sent.php*/
#submit article{
	padding:0 10px 50px 10px;
	margin: 0;

	
}
#submit table{
	width:95%;
	margin:0 auto;
	background:#FFF;
}
#submit table tr td{
	border:#AAA solid 1px;
	text-align:left;
}
#submit table tr .gray{
	background:#DDD;
	width:40%;
}
#submit .submit-box{
	text-align:center;
	font-size: 120%;
}
#submit .error{
	text-align:center;
	color:#F00;
}
}


