@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 "source-han-sans-japanese","Noto Sans JP","Hiragino Kaku Gothic Pro", "YuGothic", "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
	
	line-height: 1.6;
	margin:0;
	background: #f8f6f2;

	

}


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;
  }
}

.area{
    background: #4e54c8;  
    background: -webkit-linear-gradient(to left, #8f94fb, #4e54c8);  
    width: 100%;
    height:100vh;
    
   
}

.circles{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.circles li{
    position: absolute;
    display: block;
    list-style: none;
    width: 20px;
    height: 20px;
    background: rgba(255, 255, 255, 0.2);
    animation: animate 25s linear infinite;
    bottom: -150px;
    
}

.circles li:nth-child(1){
    left: 25%;
    width: 300px;
    height: 10px;
    animation-delay: 0s;
	border: 1px solid #000;
	border-radius: 50px 50px 50px 50px;
}


.circles li:nth-child(2){
    left: 10%;
    width: 20px;
    height: 20px;
    animation-delay: 2s;
    animation-duration: 12s;
}

.circles li:nth-child(3){
    left: 70%;
    width: 20px;
    height: 20px;
    animation-delay: 4s;
}

.circles li:nth-child(4){
    left: 40%;
    width: 60px;
    height: 60px;
    animation-delay: 0s;
    animation-duration: 18s;
}

.circles li:nth-child(5){
    left: 65%;
    width: 20px;
    height: 20px;
    animation-delay: 0s;
}

.circles li:nth-child(6){
    left: 75%;
    width: 110px;
    height: 110px;
    animation-delay: 3s;
}

.circles li:nth-child(7){
    left: 35%;
    width: 150px;
    height: 150px;
    animation-delay: 7s;
}

.circles li:nth-child(8){
    left: 50%;
    width: 25px;
    height: 25px;
    animation-delay: 15s;
    animation-duration: 45s;
}

.circles li:nth-child(9){
    left: 20%;
    width: 15px;
    height: 15px;
    animation-delay: 2s;
    animation-duration: 35s;
}

.circles li:nth-child(10){
    left: 85%;
    width: 150px;
    height: 150px;
    animation-delay: 0s;
    animation-duration: 11s;
}



@keyframes animate {

    0%{
        transform: translateY(0) rotate(0deg);
        opacity: 1;
        border-radius: 0;
    }

    100%{
        transform: translateY(-1000px) rotate(720deg);
        opacity: 0;
        border-radius: 50%;
    }

}


.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-top: 1px dotted #ddd;
	color:#696969;
	letter-spacing: 1.5px;
	
	
	
}
td {
	padding: 15px;
	text-align: center;
	border-top: 1px dotted #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 #606060;
	width: 100%;
}


/* pcのみ可能*/

.pc_none{
	display: block;
}

/* tabのみ可能*/

.tab_none{
	display:none;
}

/* spのみ可能*/

.sp_none{
	display:none;
}

/* pc、tabのみ可能*/

.d_tab{
	display: block;
	
}


/* tab、spのみ可能*/

.f_tab{
	display: none;
	
}




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

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


.sp_none{
	display:none;
}

.d_tab{
	display: block;
	
}

.f_tab{
	display: block;
	
}
	

}
	
	

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

hr{
	
	border-top: none;
	width: 100%;
}

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


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


}



/* 画面外にいる状態 */
.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;
}


.mt50{
	margin-top: 50px;
}

.mt80{
	margin-top: 80px;
}

.mt100{
	margin-top: 100px;
}

.mb10{
	margin-bottom: 10px;
}

.mb20{
	margin-bottom: 20px;
}

.mb30{
	margin-bottom: 30px;
}

.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;
	
	
}

.textGreen{
	color: #3cb371;
	
	
}


.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;
}

/*必須ボタン：お問い合わせ、お申し込み*/

.must {
	
	margin: 10px 0 0 10px;
font-size: 75%;
	padding: 4px 8px;
	color:#7a6b5c;
	background: #fff;
	border-radius: 20px;
	width: 80px;
	text-align: center;
	letter-spacing: 1px;
	border: 2px solid #7a6b5c;
	font-weight: bold;
}


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

.loading {
  width: 100vw;
  height: 100vh;
  transition: all 1s;
 background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  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: 589px;
  height:270px;
 
}

@media screen and (max-width:767px) {
.loading img {
  width: 80%;
  height:80%;
 
}

}




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

white-space:nowrap;
overflow:hidden;
animation:jojo 2s 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（受講の流れ：一般チア共通）*/

.step-wrap {
 counter-reset:count;
 margin: 2em 0;
 position: relative;
}
.step-content {
 padding: 0 0 1.3em 2em;
 margin: 0;
 position: relative;
}

.step-content img {
 width: 200px;
	height: 130px;
 position: relative;
	margin: 0 20px 0 0;
	float: left;
}

.step-content::before {
 content: "";
 display: block;
 width: 13px;
 height: 13px;
 background: #8e8172;
 border: solid 3px #ffffff;
 border-radius: 50%;
 position: absolute;
 top: 3px;
 left: 3px;
 box-shadow: 0 0 0 2px #8e8172;
}
.step-content::after {
 content: "";
 display: block;
 height: calc(100% - 35px);
 border-left: dotted 5px #768888;
 position: absolute;
 top: 30px;
 left: 10px;
}
.step-title {

 font-size: 120%;
	margin: 10px 0;
}
.step-label {
 color: #768888;
 font-weight: bold;
}
.step-label::after {
 counter-increment:count;
 content:counter(count);
 position: relative;
 left: .3em;
}
.step-body {
 margin-top: .5em;
 padding: 0 0 1em;
 border-bottom: dotted 1px #ddd;
}
.step-wrap > :last-of-type::after {
 display: none;
}


/*ステップフローのCSS（流れ：一般クラス）*/

.step-wrap1 {
 counter-reset:count;
 margin: 2em 0;
 position: relative;
}
.step-content1 {
 padding: 0 0 1.3em 2em;
 margin: 0;
 position: relative;
}

.step-content1 img {
 width: 200px;
	height: 130px;
 position: relative;
	margin: 0 20px 0 0;
	float: left;
}

.step-content1::before {
 content: "";
 display: block;
 width: 13px;
 height: 13px;
 background: #44b039;
 border: solid 3px #ffffff;
 border-radius: 50%;
 position: absolute;
 top: 3px;
 left: 3px;
 box-shadow: 0 0 0 2px #44b039;
}
.step-content1::after {
 content: "";
 display: block;
 height: calc(100% - 35px);
 border-left: dotted 3px #768888;
 position: absolute;
 top: 30px;
 left: 10px;
}
.step-title1 {
 font-weight: bold;
 font-size: 120%;
}
.step-label1 {
 color: #768888;
 font-weight: bold;
}
.step-label1::after {
 counter-increment:count;
 content:counter(count);
 position: relative;
 left: .3em;
}
.step-body1 {
 margin-top: .5em;
 padding: 0 0 1em;
 border-bottom: dotted 2px #ddd;
}
.step-wrap1 > :last-of-type::after {
 display: none;
}


/*ステップフローのCSS（流れ：チアクラス）*/

.step-wrap2 {
 counter-reset:count;
 margin: 2em 0;
 position: relative;
}
.step-content2 {
 padding: 0 0 1.3em 2em;
 margin: 0;
 position: relative;
}

.step-content2 img {
 width: 200px;
	height: 130px;
 position: relative;
	margin: 0 20px 0 0;
	float: left;
}

.step-content2::before {
 content: "";
 display: block;
 width: 13px;
 height: 13px;
 background: #e68898;
 border: solid 3px #ffffff;
 border-radius: 50%;
 position: absolute;
 top: 3px;
 left: 3px;
 box-shadow: 0 0 0 2px #e68898;
}
.step-content2::after {
 content: "";
 display: block;
 height: calc(100% - 35px);
 border-left: dotted 5px #768888;
 position: absolute;
 top: 30px;
 left: 10px;
}
.step-title2 {
 font-weight: bold;
 font-size: 120%;
}
.step-label2 {
 color: #768888;
 font-weight: bold;
}
.step-label2::after {
 counter-increment:count;
 content:counter(count);
 position: relative;
 left: .3em;
}
.step-body2 {
 margin-top: .5em;
 padding: 0 0 1em;
 border-bottom: dotted 2px #ddd;
}
.step-wrap2 > :last-of-type::after {
 display: none;
}

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

@media screen and (max-width:767px) {
	
.step-content1 img {
 width: auto;
	height: auto;
 position: relative;
	margin: 0 0 20px 0;
	float: left;
}
	
	
.step-content2 img {
 width: auto;
	height: auto;
 position: relative;
	margin: 0 0 20px 0;
	float: left;
}


	
}



/*================================================
 *  クリックで
 ================================================*/
.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%;
	border: 1px solid #000;
}

@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 .inner2 {
	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 .inner2 h4 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
}
.twoCol .inner2 p {
	width: 100%;
	margin-bottom: 0;
	text-align: justify;
}
.twoCol .inner2 > a {
	width: 100%;
	height: 100%;
}
.twoCol .inner2 .image {
	width: 80%;
	min-height: 0%;
}
.twoCol .inner2 img {
	width: 100%;
	border: solid 20px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 8px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 5px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;
}
.twoCol .inner2 .btn {
	margin-top: auto;
	padding-top: 20px;
}


.twoCol .inner2 .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 .inner2 .text a:hover {
	
		color: #000;
border: 4px solid #333;
	background: #e1edbc;
}

@media screen and (max-width:767px) {
	.twoCol {
		display: block;
		margin-bottom:20px;
	}
	.twoCol .inner2 {
		width :100%;
		margin:0 0 10px 0;
	}
	
	.twoCol .inner2 .btn {
	margin-top: auto;
	padding-top: 10px;
}
	.twoCol .inner2 .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:20px 0 0 0;
	
	
}
.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: 27%;
	width: calc((270 / 980) *98%);

border-top:4px solid #dfdbd6;
	  margin: 2em auto; /* 外側余白 */
  padding: 2em; /* 内側余白 */
  background-image: repeating-linear-gradient(
    -45deg, /* ストライプの角度 */
    #fff 0, /* ストライプの色（薄いグレー） */
    #fff 2px, /* ストライプの太さ（3pxの間隔） */
    transparent 2px, /* 透明部分 */
    transparent 4px /* 透明部分（3pxから6pxまで） */
  );
	
	border-radius: 0 0 10px 10px;

	
}
.threeCol .inner h4 {
	width: 100%;
	margin-top: 0.5em;
	text-align: left;
	letter-spacing: 2px;
	margin: 0;
	font-size: 140%;
	padding: 0;
	
}


.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: 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 {
	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:30px 0 0 0;
	
	
}
	.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: 40%;
	width: calc((400 / 980) *98%);

border-top:4px solid #dfdbd6;
	  margin: 2em auto; /* 外側余白 */
  padding: 2em; /* 内側余白 */
  background-image: repeating-linear-gradient(
    -45deg, /* ストライプの角度 */
    #fff 0, /* ストライプの色（薄いグレー） */
    #fff 2px, /* ストライプの太さ（3pxの間隔） */
    transparent 2px, /* 透明部分 */
    transparent 4px /* 透明部分（3pxから6pxまで） */
  );
	
	border-radius: 0 0 10px 10px;

	
}
	
	.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: -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:30px 0 0 0;
	
	
}
	.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: 40%;
	width: calc((400 / 980) *98%);

border-top:4px solid #dfdbd6;
	  margin: 2em auto; /* 外側余白 */
  padding: 1em; /* 内側余白 */
  background-image: repeating-linear-gradient(
    -45deg, /* ストライプの角度 */
    #fff 0, /* ストライプの色（薄いグレー） */
    #fff 2px, /* ストライプの太さ（3pxの間隔） */
    transparent 2px, /* 透明部分 */
    transparent 4px /* 透明部分（3pxから6pxまで） */
  );
	
	border-radius: 0 0 10px 10px;

	
}
	

	.threeCol {
		display: block;
		margin-bottom: 20px;
	}
	.threeCol .inner {
		width : auto;
		margin: 0 0 10px 0;
		font-size: 95%;
	}
}

/* 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: 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: 0;
	 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: 85%;
  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;}
}


/*================================================
 *  プルダウンメニュー：プライバシーポリシー
 ================================================*/
.accordion {
  width: 100%;
}

/* inputのチェックボックスを非表示 */
.accordion-hidden {
  display: none;
	margin: 40px 0 0 0;
}

/* 見出しボタン部分 */
.accordion-open {
  display: block;
  padding: 1rem 2.5rem 1rem 0;
	font-weight: bold;
 border-top:2px dotted #a0a0a0;
  cursor: pointer;
  margin: 5px 0;
  position: relative;
	font-size: 110%;
	letter-spacing: 0.1em;
}


/* ＋アイコン */
.accordion-open::before,
.accordion-open::after {
  content: '';
  width: 15px;
  height: 3px;
  background: #000;
  position: absolute;
  top: 50%;
  right: 2%;
  transform: translateY(-50%);
}

/* アイコンのー */
.accordion-open::after {
  transform: translateY(-50%) rotate(90deg);
  transition: .5s;
}

/* アコーディオンが開いたらーに */
.accordion-hidden:checked+.accordion-open:after {
  transform: translateY(-50%) rotate(0);
}

/* アコーディオン中身部分 */
.accordion-inner {
  display: block;
  height: 0;
  overflow: hidden;
  padding: 0;
  opacity: 0;

  /* 表示速度の設定 */
  cursor: pointer;
}

/* チェックボックスにチェックが入ったら中身部分を表示する */
.accordion-hidden:checked+.accordion-open+.accordion-inner {
  height: auto;
  opacity: 1;
  padding: 0;
}



/* Q&A追加 */
.accordion_qa .Q,
.accordion_qa .A {
  position: relative;
}

.accordion_qa .Q::before,
.accordion_qa .A::before {
  font-size: 1.5em;
  display: block;
  position: absolute;
  top: -.6em;
  left: -1.3em;
}

.accordion_qa .Q::before {
  content: 'Q.';
}

.accordion_qa .A::before {
  content: 'A.';
}

.accordion_qa .accordion-open {
  padding-left: 2.5em;
}

.accordion_qa .accordion-hidden:checked+.accordion-open+.accordion-inner {
  height: auto;
  opacity: 1;
  padding: 10px 10px 10px 2.5em;
}
/* Q&A追加ここまで */


/* 中にいろいろ入れたいとき */
.accordion-box {
  display: block;
  height: 0;
  overflow: hidden;
  padding: 0;
  opacity: 0;
 
}

.accordion-hidden:checked+.accordion-open+.accordion-box {
  height: auto;
  opacity: 1;
  padding: 10px;
}


/*
  アコーディオンそのものの横幅と余白を指定。
  開閉動作に影響なし。
*/
.accordion__list {
  width: 130px;
  padding: 10px;
}

/*
  アコーディオンの2つ目以降、上に余白を取る。
  開閉動作に影響なし。
*/
.accordion__item:nth-child(n+2) {
  margin-top: 10px;
}

/*
  アコーディオンの開閉ボタンの装飾。
  position: relative;が無いと、
  「+」「-」の位置がずれるので注意。
*/
.accordion__head {
  position: relative;
  width: 100%;
  padding: 10px 10px 10px 10px;
  background: #333;
  cursor: pointer;
	border-bottom: 1.5px solid #333;
}

.accordion__head div {
  font-weight: bold;
	margin: 0 0 0 10px;
	color: #fff;
}

/*
  アコーディオンの開閉ボタンの右側に「+」を表示。
*/
.accordion__head::after {
  content: "+";
  position: absolute;
  top: 8px;
  right: 10px;
	color: #fff;
}

/*
  アコーディオンが開いた際に、
  開閉ボタンの右側に「+」を「-」に変更する。
*/
.accordion__item.active .accordion__head::after {
  content: "-";
  right: 13px;
	color: #fff;
}

/*
  アコーディオンの閉じている部分の装飾。
  height: 0; overflow: hidden;にすることで、
  通常時は表示されないようにする。
*/
.accordion__body {
  overflow: hidden;
  width: 100%;
  height: 0;
  padding: 0 10px;
  background: #333;
  transition: all .25s ease;
	
}

/*
  アコーディオンが開いた際に、
  heightを0からautoに、paddingの上下を0から10に。
*/
.accordion__item.active .accordion__body {
  height: auto;
  padding: 0 10px;
	 background: #333;
	
}

.accordion__list p {
  
  background: #333;
	padding: 10px 0;
	text-align: center;
	border-bottom:0.1px dotted #ccc; 
	font-size: 90%;
	color: #fff;
}

.accordion__list p a {
  
  
	color: #fff;
}


.accordion__list p:last-child {
  
	border-bottom:none; 
}


/*背景が動く*/

.bg {
  animation:slide 3s ease-in-out infinite alternate;
  background-image: linear-gradient(-60deg, #eae5dd 50%, #f3f0ea 50%);
  bottom:0;
  left:-50%;
  opacity:.5;
  position:fixed;
  right:-50%;
  top:0;
  z-index:-1;
}

.bg2 {
  animation-direction:alternate-reverse;
  animation-duration:4s;
}

.bg3 {
  animation-duration:5s;
}

.content_bg {
  background-color:rgba(231,217,192);
  border-radius:.25em;
  box-shadow:0 0 .25em rgba(0,0,0,.25);
  box-sizing:border-box;
  left:50%;
  padding:10vmin;
  position:fixed;
  text-align:center;
  top:50%;
  transform:translate(-50%, -50%);
}


@keyframes slide {
  0% {
    transform:translateX(-25%);
  }
  100% {
    transform:translateX(25%);
  }
}



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


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

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

}

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

header h1 {
	float: left;
	margin: 15px auto 0 20px;

}



header h1 img {
width: 80%;
	height: 80%;
	border-right:none; 
	padding:0 ;

}

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

}



.is-animation {
	  position: fixed;
padding: 0 0 30px 0;
  z-index: 9999;
  width: 100%;
  height: 40px;
	margin: 0 auto;
	
opacity: 0.95;


	
}
.is-animation h1 {
		float: left;
	margin: 15px auto 0 20px;

 
}

.is-animation img{
width: 80%;
	height: 80%;
	border-right:none; 
	padding:0 ;


}

.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;

	

}


/* 電話 */
.sns_btn{
	position: absolute;
	top:28px;
	right: 8px;

}

.sns_btn a{

font-size: 110%;
	
	padding: 10px 13px 12px 13px;
background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;
	border-radius: 50%;

}

.sns_btn a:hover{

font-size: 110%;
	
	padding: 10px 13px 12px 13px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;


}

/* お問い合わせ */
.sns_btn02{
		
position: absolute;
	top:28px;
	right: 108px;


}

.sns_btn02 a{
	
font-size: 120%;
	
	padding: 10px 13px 11px 13px;
background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;
	border-radius: 50%;

}

.sns_btn02 a:hover{

	
font-size: 120%;
	
	padding: 10px 13px 11px 13px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
}

/* アクセス */
.sns_btn03{
		
position: absolute;
	top:28px;
	right: 58px;

	
}

.sns_btn03 a{
	
font-size: 125%;

	
	padding: 10px 14px;
background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;
	border-radius: 50%;

}

.sns_btn03 a:hover{
	
		padding: 10px 14px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
}

/* よくあるご質問 */
.sns_btn04{
		
position: absolute;
	top:28px;
	right: 145px;
	font-size: 100%;

}

.sns_btn04 a{
		

	border-radius: 50px;
	padding: 10px 12.5px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.sns_btn04 a:hover{

background: #fff;
font-size: 100%;
	color: #333;

	

}


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

	height:60px;

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

	

.is-animation {
	  position: fixed;
padding: 0 0 40px 0;
  z-index: 9999;
  width: 100%;
  height: 35px;
	margin: 0 auto;

	
}

.is-animation img{
width: 75%;
	height: 75%;
	border-right:none; 
	padding:0 ;
	margin: 15px 0 0 20px;

}

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

}
	
/* 電話 */
.sns_btn{
	position: absolute;
	top:20px;
	right: 50px;
	font-size: 100%;
}

.sns_btn a{

	border-radius: 50px;
	padding: 10px;

font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	
	background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;

}

.sns_btn a:hover{

font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
	

}

/* お問い合わせ */
.sns_btn02{
		
position: absolute;
	top:20px;
	right: 140px;
	font-size: 100%;

}

.sns_btn02 a{
		

	border-radius: 50px;
	padding: 10px;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;

}

.sns_btn02 a:hover{

font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

}

/* アクセス */
.sns_btn03{
		
position: absolute;
	top:20px;
	right: 95px;
	font-size: 100%;
	
}

.sns_btn03 a{
		
border-radius: 50px;
	padding: 10px 12px;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;
}

.sns_btn03 a:hover{

font-size: 100%;
padding: 10px 12px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

}

/* よくあるご質問 */
.sns_btn04{
		
position: absolute;
	top:20px;
	right: 185px;
	font-size: 100%;

}

.sns_btn04 a{
		
font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

}

.sns_btn04 a:hover{

background: #fff;
font-size: 100%;
	color: #333;

	

}
	

/* 電話 */
.is-animation .sns_btn{
	position: absolute;
	top:20px;
	right: 50px;
	font-size: 100%;
}

.is-animation .sns_btn a{

	border-radius: 50px;
	padding: 10px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn a:hover{
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
	

}
	
/* お問い合わせ */
.is-animation .sns_btn02{
position: absolute;
	top:20px;
	right: 140px;
	font-size: 100%;

}

.is-animation .sns_btn02 a{
		

	border-radius: 50px;
	padding: 10px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn02 a:hover{
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

}

/* アクセス */
.is-animation .sns_btn03{
position: absolute;
	top:20px;
	right: 95px;
	font-size: 100%;
	
}

.is-animation .sns_btn03 a{
		

	border-radius: 50px;
	padding: 10px 12px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn03 a:hover{

  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

}

/* よくあるご質問 */
.is-animation .sns_btn04{
		
position: absolute;
	top:20px;
	right: 195px;
	font-size: 100%;

}

.is-animation .sns_btn04 a{
		

	border-radius: 50px;
	padding: 10px 12.5px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn04 a:hover{

background: #fff;
font-size: 100%;
	color: #333;

	

}
	

	
}


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

	height:60px;
	
}	
	
header h1 {
	float: left;
	margin: 0 ;
	
}
	
header h1 img {
	
	width: 60%;
	height: 60%;
	margin: 10px auto 0 10px;
	border-right: none;
	padding: 0;
}
	
header p {
	
	display: none;
	
}

.is-animation {
	  position: fixed;
padding: 0 0 40px 0;
  z-index: 9999;

  height: 35px;
	margin: 0 auto;
}
	
.is-animation img{
	width: 55%;
	height: 55%;
	margin: -3px auto 0 -10px;
	border-right: none;
	padding: 0;

}
	

/* 電話 */
.sns_btn{
	position: absolute;
	top:20px;
	right: 50px;
	font-size: 100%;
}

.sns_btn a{

	border-radius: 50px;
	padding: 10px;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;

}

.sns_btn a:hover{
		

font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
}

/* お問い合わせ */
.sns_btn02{
		
position: absolute;
	top:20px;
	right: 140px;
	font-size: 100%;

}

.sns_btn02 a{
		

	border-radius: 50px;
	padding: 10px;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;

}

.sns_btn02 a:hover{

font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
}

/* アクセス */
.sns_btn03{
		
position: absolute;
	top:20px;
	right: 95px;
	font-size: 100%;
	
}

.sns_btn03 a{
		

	border-radius: 50px;
	padding: 10px 12px;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	background: #7a6b5c;
   color: #fff;
	border: 2px solid #7a6b5c;

}

.sns_btn03 a:hover{

font-size: 100%;
padding: 10px 12px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
}

/* よくあるご質問 */
.sns_btn04{
		
position: absolute;
	top:20px;
	right: 195px;
	font-size: 100%;

}

.sns_btn04 a{
		

	border-radius: 50px;
	padding: 10px 12.5px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.sns_btn04 a:hover{

background: #fff;
font-size: 100%;
	color: #333;

	

}
	

/* 電話 */
.is-animation .sns_btn{
	position: absolute;
	top:20px;
	right: 50px;
	font-size: 100%;
}

.is-animation .sns_btn a{

	border-radius: 50px;
	padding: 10px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn a:hover{
		
font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

	

}
	
/* お問い合わせ */
.is-animation .sns_btn02{
		
position: absolute;
	top:20px;
	right: 140px;
	font-size: 100%;

}

.is-animation .sns_btn02 a{
		

	border-radius: 50px;
	padding: 10px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn02 a:hover{
font-size: 100%;
padding: 10px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;

}

/* アクセス */
.is-animation .sns_btn03{
		
position: absolute;
	top:20px;
	right: 95px;
	font-size: 100%;
	
}

.is-animation .sns_btn03 a{
		

	border-radius: 50px;
	padding: 10px 12px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn03 a:hover{

font-size: 100%;
padding: 10px 12px;
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	border-radius: 50%;
}

/* よくあるご質問 */
.is-animation .sns_btn04{
		
position: absolute;
	top:20px;
	right: 205px;
	font-size: 100%;

}

.is-animation .sns_btn04 a{
		

	border-radius: 50px;
	padding: 10px 12.5px;
background: #333;
font-size: 100%;
-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
	color: #fff;

}

.is-animation .sns_btn04 a:hover{

background: #fff;
font-size: 100%;
	color: #333;

	

}

}

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

	}
	nav.gnav {
		display: block !important;
		
	}
	
	#menu_h {
		margin: 20px 165px 0 0;
		padding: 0 7px 0 6px;
		width:  auto;
		float: right;
	font-family: 'Lato', sans-serif;
		

background: #fff;
	border-radius: 50px;
	}
	
		#menu_h_r {
		margin: -49px 0 0 0;
		padding: 0 8px 0 6px;
		width:  120px;
		float: right;
	font-family: 'Lato', sans-serif;
		height: 48px;
			


	border-radius: 50px 0 0 50px;

	}


	/* 共通 */
	nav.gnav ul {
		margin: 0;
		padding: 0 4px;
		width:  auto;
		float: right;
		background: #fff;
border-radius: 50px;
		
	}
	
	nav.gnav ul li {
		position: relative;
		list-style: none;
	
	}
	nav.gnav ul li a {
		display: block;
		width:auto;
		color:#333;
		font-size: 90%;
font-weight:bold;
		text-decoration: none;
		padding:0 3px 4px 4px;
		margin: 3px 2px 0 2px;
		letter-spacing:1px;
	}
	
	nav.gnav ul li:hover > a {
		color: #7a6b5c;
		font-weight:bold;
		
		padding:0 3px 4px 4px;
		margin: 3px 2px 0 2px;
		letter-spacing:1px;
		background: linear-gradient(transparent 96%, #7a6b5c 96%);
		opacity: 0.8;


		
		
	}
	
	

	/* 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:#333;
			
	}
	
	

	/* 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: 60px;
		right: 0;
		width: 80%;
		height: auto;
		border: 3px solid #7a6b5c;

		border-right: none;
		border-radius: 30px 0 0 30px;
		 z-index: 9999; /* 一番上に表示 */
  pointer-events: auto; /* クリックを有効化 */
		
		
	}
	nav.gnav li {
		position: relative;
		width: 99.99%;
		float: none;
		margin: 0;
		text-align: left;
		list-style: none;
		border-bottom: 1px dotted #fff;
		background: #7a6b5c;
		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: #7a6b5c;
		text-decoration: none;
		background: #fff;
		font-size: 100%;
	}
	nav.gnav li a:hover {
		color: #7a6b5c;
		background: #fff;
		font-weight: bold;
	}
	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: #7a6b5c;
	}
	nav.gnav .subnav a:hover:after {
		background: #7a6b5c;
	}
	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: 15px;
		
	}

	#spMenu:hover {
		cursor: pointer;
	}

	#navBtn {
		display: inline-block;
		position: relative;
		width: 40px;
		height: 40px;
		border-radius: 5%;
		background: none;
	}
	#navBtnIcon {
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		width: 25px;
		height: 3px;
		margin: -1px 0 0 0;
		background: #333;
		transition: .2s;
		
	}
	#navBtnIcon:before,
	#navBtnIcon:after {
		display: block;
		content: '';
		position: absolute;
		top: 50%;
		left: 0;
		width: 25px;
		height: 3px;
		background: #333;
		transition: 0.3s;
	}
	#navBtnIcon:before {
		margin-top: -10px;
	}
	#navBtnIcon:after {
		margin-top: 8px;;
	}
	#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 20px 0;
	

 margin: 0;

background: linear-gradient(124deg, #a39586, #715c42, #77695a, #715c42, #a39586, #715c42, #77695a, #a39586, #715c42);
background-size: 1800% 1800%;

-webkit-animation: rainbow 18s ease infinite;
-z-animation: rainbow 18s ease infinite;
-o-animation: rainbow 18s ease infinite;
  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: 110%;
	margin: 0;

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

footer h2 a{
	
	

	color: #fff;
	
}

footer h2 a:hover{
	color: #fff;

	
	
}

footer h3{

	font-size: 130%;
	margin: 0 0 20px 0;

	letter-spacing: 2px;
color: #fff;

	
}

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




footer .flame_l{
	float: left;

	
	margin: 0 0 10px 0;
	width: 28%;

}

footer .flame_l p{
	
font-size: 84%;
color: #fff;
	letter-spacing: 0.2em;
	margin: 0 0 20px 0;
	



}

footer .flame_r{
	float: left;
	font-size: 100%;
	margin: 0 ;
	width: 70%;
	padding: 0;

}

footer .flame_b{
	

	font-size: 95%;
	margin: 15px 0 0 0 ;
width: auto;
	padding: 20px 0 1px 0;

	border-top:0.5px dotted #ccc;

}
footer .flame_c{
	

	font-size: 95%;
	margin: 5px 0 0 0 ;
width: auto;
	padding: 20px 0 1px 0;

	border-top:0.5px dotted #ccc;

}

footer .flame_d{
	

	font-size: 95%;
	margin: 5px 0 0 0 ;
width: auto;
	padding: 20px 0 ;

	border-top:0.5px dotted #ccc;

}

footer ul{
	
	padding: 0;
	width: auto;
	margin: 0 0 50px 0;
	
	
	
	
}

footer ul li{
	float: left;
color: #fff;
	
		margin: 0 35px 10px 0;
	width: auto;
	padding: 0;

}

footer ul li+ li {
 border-left: none;
}

footer ul li a{
	
	font-size: 85%;

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

footer ul li a:hover{
color: #fff;

	
	
}

footer ul li ul li{
	

	margin: 0;
	color: #fff;
	letter-spacing: 1px;
	
}

footer ul li ul li a{
	
	font-size: 80%;

	color: #fff;
	letter-spacing: 1px;
	margin: 0 0 10px 0;
	
}

footer ul li ul li a:hover{
	color: #fff;
	
}



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


}

footer .btn a {
		position: relative;
	display: inline-block;
	padding: 10px 15px 0 0;
color: #fff;
	float: left;
	font-size: 120%;


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

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

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


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

.f_icon {
	width:90%;
	margin:0 0 0 1px;
float: left;

}

.f_icon ul li{


	margin:0 5px 0 0;
float: left;
	
	list-style: none;
	text-align: left;
	
}



.f_icon a {
	
color: #fff;
font-size: 130%;
}



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



.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_l {
	padding: 0;
	font-size: 60%;
	text-align: left;
	margin: 30px 0 0 0;
	color: #fff;

}

.copyright {
	padding: 0;
	font-size: 60%;
	text-align: right;
	
	color: #fff;
width: 90%;
	
}

.copyright_sent {
	padding: 0;
	font-size: 70%;
	text-align: center;
	color:#fff;
	margin: 0;
	
}

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

	background-color: #f0810f;

}




footer h2{

	font-size: 120%;
	margin: 0 0 20px 40px;
	font-weight: bold;
	letter-spacing: 2px;
color: #fff;
	width: 90%;
}

footer h2 a{
	
	

	color: #fff;
	
}

footer h2 a:hover{
	color: #fff;

	
	
}

footer h3{

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

	
}

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




footer .flame_l{
	display: none;






}

footer .flame_l p{
display: none;
	



}

footer .flame_r{
	float: left;
	font-size: 95%;
	margin: 0 0 0 40px;
	width: 92%;
	padding: 0;


}
	
footer .flame_b{
	

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

	border-top:0.5px dotted #ccc;

}

footer .flame_c{
	

	font-size: 95%;
	margin: 30px 0 0 0;
width: 98%;
	padding: 20px 0 5px 0;

	border-top:0.5px dotted #ccc;

}

footer .flame_d{
	

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

	border-top:0.5px dotted #ccc;

}

footer ul{
	
	padding: 0;
	width: auto;
	margin: 0 0 50px 0;
	
	
	
}

footer ul li{
	float: left;
color: #fff;
	
		margin: 0 0 10px 0;
	width: 200px;
	padding: 0 ;




}

footer ul li+ li {
 border-left: nonef;
}

footer ul li a{
	
	font-size: 85%;

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

footer ul li a:hover{
color: #fff;

	
	
}

footer ul li ul li{
	

	margin: 0;
	color: #fff;
	letter-spacing: 1px;
}

footer ul li ul li a{
	
	font-size: 80%;

	color: #fff;
	letter-spacing: 1px;
	margin: 0 0 10px 0;
	
}

footer ul li ul li a:hover{
	color: #fff;
	
}



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


}

footer .btn a {
		position: relative;
	display: inline-block;
	padding: 10px 15px 0 0;
color: #fff;
	float: left;
	font-size: 120%;


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

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

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


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

.f_icon {
	width:90%;
	margin:0 0 0 1px;
float: left;

}

.f_icon ul li{


	margin:0 5px 0 0;
float: left;
	
	list-style: none;
	text-align: left;

}



.f_icon a {
	
color: #fff;
font-size: 130%;
}



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

.copyright_l {
	padding: 0;
	font-size: 60%;
	text-align: left;
	margin: 20px 0 0 0;
	color: #fff;

}

.copyright {
	padding: 0;
	font-size: 60%;
	text-align: left;
	margin: 20px 0 0 0;
	color:#fff;
	width: 80%;

}

}

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



}




footer h2{

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


}

footer h2 a{
	
	

	color: #fff;
	
}

footer h2 a:hover{
	color: #fff;

	
	
}

footer h3{

	font-size: 110%;
	margin: 0 0 10px 30px;
	font-weight: bold;
	letter-spacing: 2px;
color: #fff;

	
}

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




footer .flame_l{
	display: none;






}

footer .flame_l p{
display: none;
	



}

footer .flame_r{
	float: none;
	font-size: 95%;
	margin: 25px 0 0 5%;;
	width: 88%;
	padding: 0;


}
	
footer .flame_b{
	

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

	border-top:0.5px dotted #ccc;
}

footer .flame_c{
	

	font-size: 95%;
	margin: 50px 0 0 0;
width: auto;
	padding: 20px 0 35px 0;

	border-top:0.5px dotted #ccc;
}

footer .flame_d{
	

	font-size: 95%;
	margin: 50px 0  ;
width: auto;
	padding: 20px 0 ;

	border-top:0.5px dotted #ccc;

}

footer ul{
	
	padding: 0;
	width: auto;
	margin: 0 0 30px 0;
	
	
}

footer ul li{
	float: left;
color: #fff;
	
		margin: 0 0 10px 0;
	width: 49%;
	padding: 0 ;
}

footer ul li+ li {
 border-left: none;
}

footer ul li a{
	
	font-size: 85%;

	color: #fff;
	letter-spacing: 1px;

}

footer ul li a:hover{
color: #fff;

	
	
}

footer ul li ul li{
	

	margin: 0;
	color: #fff;
	letter-spacing: 1px;
}

footer ul li ul li a{
	
	font-size: 80%;

	color: #fff;
	letter-spacing: 1px;
	margin: 0 0 10px 0;

}

footer ul li ul li a:hover{
	color: #fff;
	
}






footer .btn a {
		position: relative;
	display: inline-block;
	padding: 10px 15px 0 0;
color: #fff;
	float: left;
	font-size: 120%;


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

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

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


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

.f_icon {
	width:90%;
	margin:0 0 0 1px;
float: left;

}

.f_icon ul li{


	margin:0 5px 0 0;
float: left;
	
	list-style: none;
	text-align: left;

}



.f_icon a {
	
color: #fff;
font-size: 130%;

}



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


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


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



@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;
	}
}



 /*================================================
 *  パンくず
 ================================================*/
.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: 30px auto 0 auto;
	padding: 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) {



}

 
 /*================================================
 *  フワフワの動き
 ================================================*/
@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 {

	min-height: auto;
	
	width: auto;
	
}
	
}

/* メイン画像：sp*/

@media screen and (max-width:767px) {
	
.imageBox {
	text-align:center;
	width: auto;
	min-height: auto;

}
	
	
}


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

.main_imgBox {
    min-height: 100vh;
    overflow: hidden;
    position: relative; 

	width: 80%;
	margin: 0 0 0 auto;
	 border-radius: 0 0 0 50px; 



}


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

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

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

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

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

    .main_img: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 }
}




.movieText{
	
	position: absolute;
  top: 210px;
  left: 40px;
z-index: 9997;
width: auto;

	
	}


.movieText h2{

	margin: 0 0 5px 0;

padding: 75px 0;
	background:url("../images/ttl.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
	background-size: 100%;
	width: 550px;
	height: 60px;

	}


.movieText .subttl{

	
	letter-spacing: 2px;
	margin: 10px 0 0 48px;
	font-size:120%;
	color:#8e8172;

	}

.movieText .subttl2{


	letter-spacing: 2px;
	margin: 40px 80px 0 48px;
	font-size:100%;
	color:#8e8172;

	}

.movieText ul{
	
	
	margin: 0;
	
	
	}

.movieText ul li{
	
	font-size:80%;
	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
margin: 0;
	
	width: auto;
	float: left;
	
	}

.movieText ul li a{
	
	
	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
	padding: 2px 8px;
	background: #000;
	width: auto;
	float: left;
	margin: 0 7px 7px 0;
	
	}

.movieText ul li a:hover{
	

	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
	
	background:#c72d23;
	width: auto;
	float: left;
	margin: 0 7px 7px 0;
	
	}

/* 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%; }
}




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

@media screen and (min-width:768px) and (max-width:959px) {
.main_imgBox {
      min-height: 100vh;
    overflow: hidden;
    position: relative; 

	width: 100%;
	margin: 0 0 0 auto;
	 border-radius: 0; 

}

	
	
/* メインスライド*/

.main_imgBox {
    min-height: 650px;
    overflow: hidden;
    position: relative; 

	z-index: 1;

}



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


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

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

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

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

    .main_img: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*/	
.movieText{
	
	position: absolute;
  top: 200px;
  left: 20px;
z-index: 9997;
width: 50%;


	
	}
	
	.movieText h2{

	margin: 0 0 5px 0;

padding: 55px 0;
	background:url("../images/ttl.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 95%;
	width:auto;
	height: 50px;

	}


.movieText .subttl{

	
	letter-spacing: 0.1em;
	margin: 20px 0 0 33px;
	font-size:100%;
	color:#8e8172;

	}

.movieText .subttl2{


	letter-spacing: 2px;
	margin: 30px 0 0 33px;
	font-size:90%;
	color:#8e8172;

	}

.movieText h3{
	color: #fff;
	font-weight: bold;
	letter-spacing: 2px;
	margin: 10px 0 20px 0;
	font-size:110%;
	
	
	}

.movieText ul{
	
	
	margin: 20px 0;
	
	
	}

.movieText ul li{
	
	font-size:85%;
	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
margin: 0;
	
	width: auto;
	float: left;
	
	}

.movieText ul li a{
	
	
	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
	padding: 2px 8px;
	background: #000;
	width: auto;
	float: left;
	margin: 0 7px 7px 0;
	
	}

.movieText ul li a:hover{
	

	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
	
	background:#c72d23;
	width: auto;
	float: left;
	margin: 0 7px 7px 0;
	
	}
	
	

#sns{
  
	
}

#sns ul {
	
	
	

}

#sns ul li{
	 
	}
	
	

}


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

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


.main_imgBox {
      min-height: 100vh;
    overflow: hidden;
    position: relative; 

	width: 100%;
	margin: 0 0 0 auto;
	 border-radius: 0; 

}

 
  .main_img {
    z-index:10;
    opacity: 0;
    width: 100%;
    

    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-animation: anime 36s 0s infinite;
    animation: anime 36s 0s infinite; }

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

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

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

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

    .main_img: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 }
}
	
/* メインスライド内タイトル、副題、カテゴリー（sp）*/	
.movieText{
	
	position: absolute;
  top: 370px;
  left: 20px;
z-index: 9998;
width: 90%;

	}
	
	.movieText h2{

	margin: 0 0 5px 0;

padding: 55px 0;
	background:url("../images/ttl.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 100%;
	width:auto;
	height: 50px;

	}


.movieText .subttl{

	text-align: left;
	letter-spacing: 0.1em;
	margin: 0 auto 0 auto;
	font-size:100%;
	color:#8e8172;
width:82%;
	}

.movieText .subttl2{

text-align: right;
	letter-spacing: 2px;
	margin: 20px auto 0 auto ;
	font-size:90%;
	color:#8e8172;
width:80%;
	}

.movieText h3{
	color: #fff;
	font-weight: bold;
	letter-spacing: 2px;
	margin: 10px 0 20px 0;
	font-size:110%;
	
	
	}

.movieText ul{
	
	
	margin: 20px 0;
	
	
	}

.movieText ul li{
	
	font-size:85%;
	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
margin: 0;
	
	width: auto;
	float: left;
	
	}

.movieText ul li a{
	
	
	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
	padding: 2px 8px;
	background: #000;
	width: auto;
	float: left;
	margin: 0 7px 7px 0;
	
	}

.movieText ul li a:hover{
	

	color: #fff;
	font-weight: bold;
	letter-spacing: 1px;
	
	background:#c72d23;
	width: auto;
	float: left;
	margin: 0 7px 7px 0;
	
	}
	

#sns{
  display: none;
	
}

#sns ul {
	 display: none;
	
	

}

#sns ul li{
	 display: none;


	

}

}

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

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

/*スクロールダウン全体の場所*/
.scrolldown2{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:50px;
  left:6.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:7px;
  height:7px;
  border-radius: 50%;
	border: 2px solid #8e8172;
  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 (min-width:768px) and (max-width:959px) {
	
/*スクロールダウン全体の場所*/
.scrolldown2{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:80px;
  left:7.5%;
z-index: 9999;

	
}

/*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;
}
}

/* news ニュース：pc*/

#news {
	padding:0;
	margin: 0 10% ;
	width:auto;
	position: relative;

	border-radius: 0 50px 50px 0;
	
	z-index: 9998;
	

}



#news h2{
	
margin: 0 0 5px 0;

padding: 30px 0;
	background:url("../images/news/h2_news.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 40%;
}

#news h3{
	font-weight: bold;
	font-size: 110%;
	margin: 30px 0 5px 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: 20px 0 30px 1% ;

}




#news .flame_l{

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

padding: 0;
	height: auto;

	
}

#news .flame_l img{

	width: 90%;

	margin: 0 0 15px 0;
	border-radius: 20px;
	padding: 3px;
	background: #9d9b8a;


	
}




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

	

}

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


	
}


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

	margin: 10px 0;
	

}

#news .flame_r .list{
width: 98%;
	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: 12px 0 ;

	border-bottom: 1px dotted #ccc;
	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: 88%;
	margin: 0 0 20px 0;
	
	width: auto;
	text-align: center;
	float: none;
	
	background: #eae5dd;
	color: #a08965;
	
	border-radius: 5px;
	
	
}


#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%;
}




#news ul{
	
	margin: 0;

}


#news ul li{
	
	width: 14%;
	height: auto;
	margin: 0;
	padding: 10px 0 8px 5px;
	
	float: left;
	font-size: 150%;
	list-style-type: none;

	

}

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

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

#news .category {
	
	padding: 3px 5px;
	font-size: 92%;
	margin: 3px 17px 0 0;
	
	width: 14%;
	text-align: center;
	float: left;
	
	background:#696969;
	color: #fff;
	
	
	
}

/* スケジュール表：pc*/

#news .btn {
position: relative;
	display: inline-block;
	padding: 5px 30px 5px 0;
	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;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 50px;
	letter-spacing: 1px;

	
}

#sns ul li{


	margin:0 5px 0 0;
float: left;
	
	list-style: none;
	text-align: center;
	
}



#sns ul li a {
	
color: #333;
font-size: 100%;
}



#sns ul li a:hover {
	
	filter:alpha(opacity=90);
	-moz-opacity: 0.9;
	opacity: 0.8;
color: #333;
}




/* news ニュース：tab*/

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

	border-radius: 0 50px 50px 0;
	
	z-index: 9998;
	

}



#news h2{
	
margin: 0 0 5px 0;

padding: 30px 0;
	background:url("../images/news/h2_news.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 40%;
}

#news h3{
	font-weight: bold;
	font-size: 110%;
	margin: 30px 0 5px 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: 20px 0 30px 1% ;

}




#news .flame_l{

	width: 28%;
float:left;
	margin: 0 0 0 0;

padding: 0;
	height: auto;

	
}

#news .flame_l img{

	width: 90%;

	margin: 0 0 20px 0;
	border-radius: 20px;
	padding: 3px;
	background: #9d9b8a;


	
}




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

	

}

#news .flame_r{
padding: 0;
	width: 70%;
float:right;
	margin: 30px 0 0 0;

	
}


#news .flame_r p{
	
	text-align: left;
	font-size: 96%;
	letter-spacing: 0.1em;
	

	margin: 10px 0;
	

}

#news .flame_r .list{
width: 96%;
	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: 12px 0 ;

	border-bottom: 1px dotted #ccc;
	font-size: 96%;
	

	

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

	

}

#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: 88%;
	margin: 0 0 20px 0;
	
	width: auto;
	text-align: center;
	float: none;
	
	background: #eae5dd;
	color: #a08965;
	
	border-radius: 5px;
	
	
}


#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%;
}




#news ul{
	
	margin: 0;

}


#news ul li{
	
	width: 14%;
	height: auto;
	margin: 0;
	padding: 10px 0 8px 5px;
	
	float: left;
	font-size: 150%;
	list-style-type: none;

	

}

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

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

#news .category {
	
	padding: 3px 5px;
	font-size: 92%;
	margin: 3px 17px 0 0;
	
	width: 14%;
	text-align: center;
	float: left;
	
	background:#696969;
	color: #fff;
	
	
	
}

/* スケジュール表：pc*/




#news .btn {
position: relative;
	display: inline-block;
	padding: 5px 30px 5px 0;
	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;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 50px;
	letter-spacing: 1px;

	
}

}

/* news ニュース sp*/

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

	border-radius: 0;
	
	z-index: 9998;

}



#news h2{
	
margin: 0 0 20px 0;

padding: 25px 0;
	background:url("../images/news/h2_news.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 40%;
}

#news h3{
	font-weight: bold;
	font-size: 110%;
	margin: 30px 0 5px 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: 20px 0 30px 1% ;

}




#news .flame_l{

	width: 98%;
float:none;
	margin: 0;

padding: 0;
	height: auto;

}

#news .flame_l img{

	width: auto;

	margin: 0 0 15px 0;
	border-radius: 20px;
	padding: 3px;
	background: #9d9b8a;

}




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

	

}

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

	
}


#news .flame_r p{
	
	text-align: left;
	font-size: 96%;
	letter-spacing: 0.1em;
	

	margin: 10px 0;
	

}

#news .flame_r .list{
width: 98%;
	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: 12px 0 ;

	border-bottom: 1px dotted #ccc;
	font-size: 96%;
	

	

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

}

#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: 88%;
	margin: 0 0 20px 0;
	
	width: auto;
	text-align: center;
	float: none;
	
	background: #eae5dd;
	color: #a08965;
	
	border-radius: 5px;
	
	
}


#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%;
}




#news ul{
	
	margin: 0;

}


#news ul li{
	
	width: 14%;
	height: auto;
	margin: 0;
	padding: 10px 0 8px 5px;
	
	float: left;
	font-size: 150%;
	list-style-type: none;

	

}

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

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

#news .category {
	
	padding: 3px 5px;
	font-size: 92%;
	margin: 3px 17px 0 0;
	
	width: 14%;
	text-align: center;
	float: left;
	
	background:#696969;
	color: #fff;
	
	
	
}

/* スケジュール表：pc*/

#news .btn {
position: relative;
	display: inline-block;
	padding: 5px 30px 5px 0;
	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;
	color: #fff;
	background: #333;
	font-weight: bold;
	border-radius: 50px;
	letter-spacing: 1px;

}
	
#sns ul li{


	margin:0 5px 0 0;
float: left;
	
	list-style: none;
	text-align: center;
	
}



#sns ul li a {
	
color: #333;
font-size: 100%;
}



#sns ul li a:hover {
	
	filter:alpha(opacity=90);
	-moz-opacity: 0.9;
	opacity: 0.8;
color: #333;
}

}


/* 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: 50px 0 0 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: 50px 0 0 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: 0 auto 0 auto;
	text-align: center;
	padding: 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: 10px 0 0 0; /* 上端からスライダーまでの距離 - 変更可・削除可 */

	position: absolute;
	top:53%;
	left: 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;
	margin: 0 0 50px 0;
}
.loop-box, .loop-box ul {
  height: 300px; /* スライダーの高さ - 変更注意 */
}
.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(400px * 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;
	border-radius: 50px;
	
}

/* 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; 
	
}


}

/* スライド（ギャラリーループ) 右から左*/

/* 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:none; /* 背景色 - 変更可・削除可 */
  margin:0 auto; /* Box外の余白 - 変更可 */
  padding: 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:#fbfaf5; /* 背景色 - 変更可・削除可 */
  margin:-50px auto 0 auto; /* Box外の余白 - 変更可 */
  padding: 0 0 0 0; /* 上端からスライダーまでの距離 - 変更可・削除可 */

}
}

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

}
}



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

	
	
}
.loop-box1 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(400px * 1.5 * 5); /* 画像の横幅×枚数 - 変更注意・変更可・変更注意 */
  animation: 90s linear infinite; /* アニメーション設定 - 変更可 */
	 z-index: 9996;

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

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

}


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

}

/* trial トップページ；体験 pc*/

#trial_i{
	padding:0 auto 250px auto;
margin: 0 ;


background:url("../images/trial/bg_trial_i.jpg") no-repeat;
	background-position: top left;
background-size: 100%;
	
}

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


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


}


#trial_i h2{
margin: 0 0 10px 0;

padding: 50px 0;
	background:url("../images/trial/h2_trial.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 40%;
	

}



#trial_i h3{
	margin: 0 0 30px 2px ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 3px;
	color: #333;


}



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

}


#trial_i h4{
	margin: 30px 0 5px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}

#trial_i h4 span{
	margin: 0 0 50px 5px ;
	text-align: left;
	font-size: 70%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}

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




#trial_i p{
  font-size: 98%;
	text-align: left;
  padding: 0;
	letter-spacing: 1px;
	font-weight: normal;

}


#trial_i .flame_r{
width: 48%;
	text-align: left;
margin: 0 0 100px auto;
    letter-spacing: 0.1em;

background: #fff;
	padding: 40px;
border-radius: 20px 0 0 20px;

	
}

#trial_i .flame_r img{
width: 10%;
	text-align: left;
margin: 20px 20px 0 0;
	float: left;


	
}
#trial_i .flame_r .flex{
	display:flex;
	flex-wrap: wrap;
	
}

#trial_i .flame_r .box{
	width: 30%;
	padding: 0;
border-radius: 10px;
    margin: 20px 20px 10px 0;
	
	color: #333;

	box-sizing:border-box;
    list-style: none;


}


#trial_i .flame_r .box img{
	width: 100%;
}


#trial_i .flame_r .box h5{
	
	margin: 10px 0;
font-size:110%;
	 letter-spacing: 0.1em;
	font-weight: bold;
	padding: 15px 0;
	text-align: center;
	border-top:1px solid #333; 
	border-bottom:1px solid #333; 
}

#trial_i .flame_r .box p{
	
	margin: 0 0 10px 0;
font-size:100%;
	 letter-spacing: 0.1em;
	
	
	text-align: center;

}


#trial_i .flame_r .btn a {
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 15px 30px 15px 5px;
    width: 28%;
    padding: 10px 30px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 85%;
	float: right;
}

#trial_i .flame_r .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 85%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial_i .flame_r .btn a:hover {
    background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}

#trial_i .flame_r .btn a:hover:after {
  right: 1.4rem;
}


#trial_i .flame_r .btn2 {


	text-align:center;
	font-weight: bold;
	


}




/* trial トップページ：体験 tab*/

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

#trial_i{
	padding:0 auto 0 auto;
margin: 0 ;
background:url("../images/trial/bg_trial_i_tab.jpg") no-repeat;
	background-position: top center;
background-size: 100%;
	border-top: 1px solid #fff;
	
}

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


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

}


#trial_i h2{
margin: 0 0 5px 0;

padding: 50px 0;
	background:url("../images/trial/h2_trial.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 40%;


}



#trial_i h3{
	margin: 0 0 30px 2px ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 3px;
	color: #333;


}


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

}


#trial_i h4{
	margin: 30px 0 5px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}

#trial_i h4 span{
	margin: 0 0 50px 5px ;
	text-align: left;
	font-size: 70%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}

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


#trial_i p{
  font-size: 98%;
	text-align: left;
  padding: 0;
	letter-spacing: 1px;
	font-weight: normal;

}


#trial_i .flame_r{
width: 85%;
	text-align: left;
margin: 570px auto 40px auto;
    letter-spacing: 0.1em;
background: #fff;
	padding: 40px;
border-radius: 20px;

	
}

#trial_i .flame_r img{
width: 10%;
	text-align: left;
margin: 20px 20px 0 0;
	float: left;


	
}

#trial_i .flame_r .flex{
	display:flex;
	flex-wrap: wrap;
	
}

#trial_i .flame_r .box{
	width: 30%;
	padding: 0;
border-radius: 10px;
    margin: 20px 20px 10px 0;
	
	color: #333;

	box-sizing:border-box;
    list-style: none;


}


#trial_i .flame_r .box img{
	width: 100%;
}


#trial_i .flame_r .box h5{
	
	margin: 10px 0;
font-size:110%;
	 letter-spacing: 0.1em;
	font-weight: bold;
	padding: 15px 0;
	text-align: center;
	border-top:1px solid #333; 
	border-bottom:1px solid #333; 
}

#trial_i .flame_r .box p{
	
	margin: 0 0 10px 0;
font-size:100%;
	 letter-spacing: 0.1em;
	
	
	text-align: center;

}


#trial_i .flame_r .btn a {
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 15px 30px 15px 5px;
    width: 28%;
    padding: 10px 30px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 85%;
	float: right;
}

#trial_i .flame_r .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 85%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial_i .flame_r .btn a:hover {
    background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}

#trial_i .flame_r .btn a:hover:after {
  right: 1.4rem;
}


#trial_i .flame_r .btn2 {


	text-align:center;
	font-weight: bold;
	


}

#trial_i .flame_r .btn2 a {
		position: relative;
	display: inline-block;
	padding:8px 7px 2px 7px;
	border: 2px solid #000;
	float: left;
	font-size: 120%;
	background: #333;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 30px 15px 0 auto;
font-weight:bold;
	
}

#trial_i .flame_r .btn2 a:hover {
	background: #fff;
	color: #333;
	border: 2px solid #333;
}



}

/* trial トップページ：体験 sp*/

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


#trial_i{
	padding:0 auto ;
margin: 0 ;
background:url("../images/trial/bg_trial_i_sp.jpg") no-repeat;
	background-position: top center;
background-size: 100%;
border-top:1px solid #fff; 
	
}

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



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


#trial_i h2{
margin: 0;

padding: 30px 0;
	background:url("../images/trial/h2_trial.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 60%;
	


}



#trial_i h3{
	margin: 0 0 20px 2px ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 3px;
	color: #333;

}



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

}



#trial_i p{
  font-size: 98%;
	text-align: left;
  padding: 0;
	letter-spacing: 1px;
	font-weight: normal;

}


#trial_i .flame_r{
width: 70%;
	text-align: left;
margin: 220px auto 40px auto;
    letter-spacing: 0.1em;
background: #fff;
	padding: 30px;
border-radius: 20px;

	
}

#trial_i .flame_r img{
width: 10%;
	text-align: left;
margin: 20px 20px 0 0;
	float: left;


	
}
#trial_i .flame_r .flex{
	display:flex;
	flex-wrap: wrap;
	
}

#trial_i .flame_r .box{
	width: 30%;
	padding: 0;
border-radius: 10px;
    margin: 20px 20px 10px 0;
	
	color: #333;

	box-sizing:border-box;
    list-style: none;


}


#trial_i .flame_r .box img{
	width: 100%;
}


#trial_i .flame_r .box h5{
	
	margin: 10px 0;
font-size:110%;
	 letter-spacing: 0.1em;
	font-weight: bold;
	padding: 15px 0;
	text-align: center;
	border-top:1px solid #333; 
	border-bottom:1px solid #333; 
}

#trial_i .flame_r .box p{
	
	margin: 0 0 10px 0;
font-size:100%;
	 letter-spacing: 0.1em;
	
	
	text-align: center;

}


#trial_i .flame_r .btn a {
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 15px auto 5px auto;
    width: 88%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 80%;
	float: auto;
}

#trial_i .flame_r .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 85%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial_i .flame_r .btn a:hover {
    background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}

#trial_i .flame_r .btn a:hover:after {
  right: 1.4rem;
}


#trial_i .flame_r .btn2 {


	text-align:center;
	font-weight: bold;
	


}

#trial_i .flame_r .btn2 a {
		position: relative;
	display: inline-block;
	padding:8px 7px 2px 7px;
	border: 2px solid #000;
	float: left;
	font-size: 120%;
	background: #333;
color: #fff;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 30px 15px 0 auto;
font-weight:bold;
	
}

#trial_i .flame_r .btn2 a:hover {
	background: #fff;
	color: #333;
	border: 2px solid #333;
}

}



/* スケジュール：トップ PC */

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

	
	 background-size: 100%; /*--背景画像のサイズ--*/

}

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


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


}


#schedule_i h2{

margin: 0 0 5px -6px;

padding: 45px 0;
	background:url("../images/schedule/h2_schedule.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 86%;


}


#schedule_i h3{
	margin: 0 0 30px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 0.1em;

	color: #333;

}


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

}


#schedule_i h4{
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	color:#7a6b5c;
	
}

#schedule_i h4 span{
	margin: 0 0 50px 5px ;
	text-align: left;
	font-size: 70%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}

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


#schedule_i p{
	
	margin: 0 0 20px 0;
	text-align: left;
	font-size: 100%;

	
}



#schedule_i .flame{

width: 38%;
	
margin: 50px auto 50px 6%;

background: #fff;
	padding: 50px 30px 50px 50px;
	border-radius: 30px;
float: left;


}


#schedule_i .btn a {
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 0 0 0 ;
    width:60%;
    padding: 10px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	 font-size: 90%;
	float: left;
	letter-spacing: 0.2em;
}

#schedule_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule_i .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#schedule_i .btn a:hover:after {
  right: 1.4rem;
}



#schedule_i .btn2 a {
    background: #333;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
   
   width: 41%;
	width: calc((410 / 980) *100%);
	margin: 0 15px 20px 0;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;
    color: #fff;
	letter-spacing: 0.1em;
    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: bold;
	float: left;
	 font-size: 90%;

	
}

#schedule_i .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule_i .btn2 a:hover {
  background: #8aca41;
   color: #fff;

	
}

#schedule_i .btn2 a:hover:after {
  right: 1.4rem;
}


/* スケジュール：トップ tab*/

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

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

	
	 background-size: 100%; /*--背景画像のサイズ--*/

}

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


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

}


#schedule_i h2{

margin: 0 0 10px 0;

padding: 40px 0;
	background:url("../images/schedule/h2_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 35%;


}


#schedule_i h3{
	margin: 0 0 30px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 0.5em;

	color: #333;

}


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

}


#schedule_i h4{
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	color:#7a6b5c;
	
}

#schedule_i h4 span{
	margin: 0 0 50px 5px ;
	text-align: left;
	font-size: 70%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}

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


#schedule_i p{
	
	margin: 0 0 5px 0;
	text-align: left;
	font-size: 95%;

	
}


#schedule_i .flame{

width: 80%;
	
margin: 650px auto 0 auto;

background: #fff;
	padding: 50px 30px 50px 50px;
	border-radius: 30px;
float: none;


}



#schedule_i .btn a {
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 5px 30px 10px;
    width:40%;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	 font-size: 90%;
	float: right;
	letter-spacing: 0.2em;
}

#schedule_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule_i .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#schedule_i .btn a:hover:after {
  right: 1.4rem;
}



#schedule_i .btn2 a {
    background: #333;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
   
   width: 41%;
	width: calc((410 / 980) *100%);
	margin: 0 15px 20px 0;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;
    color: #fff;
	letter-spacing: 0.1em;
    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: bold;
	float: left;
	 font-size: 90%;

	
}

#schedule_i .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule_i .btn2 a:hover {
  background: #8aca41;
   color: #fff;

	
}

#schedule_i .btn2 a:hover:after {
  right: 1.4rem;
}

}


/* スケジュール：トップ sp*/

@media screen and (max-width:767px) {
#schedule_i {
padding: 0 0 50px 0;
margin:50px 0 0 0;
background:url("../images/schedule/bg_schedule_i_sp.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top center;

	
	 background-size: 100%; /*--背景画像のサイズ--*/
}

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


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

}


#schedule_i h2{

margin: 0;

padding: 28px 0;
background:url("../images/schedule/h2_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 90%;


}


#schedule_i h3{
	margin: 0 0 30px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 0.1em;

	color: #333;
}


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

}


#schedule_i h4{
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
	color:#7a6b5c;
}

#schedule_i h4 span{
	margin: 0 0 50px 5px ;
	text-align: left;
	font-size: 70%;
	letter-spacing: 3px;
	font-weight: bold;
	color: #333;
	
}


#schedule_i p{
	
	margin: 0 0 5px 0;
	text-align: left;
	font-size: 95%;
	
}

#schedule_i .flame{

width: 70%;
	
margin: 380px auto 0 auto;

background: #fff;
	padding: 35px 30px 30px 30px;
	border-radius: 30px;
float: none;


}


#schedule_i .btn a {
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 10px 10px;
    width:90%;
    padding: 10px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	 font-size: 90%;
	float: right;
	letter-spacing: 0.2em;
}

#schedule_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule_i .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#schedule_i .btn a:hover:after {
  right: 1.4rem;
}



#schedule_i .btn2 a {
    background: #333;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
   
   width: 41%;
	width: calc((410 / 980) *100%);
	margin: 0 15px 20px 0;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;
    color: #fff;
	letter-spacing: 0.1em;
    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: bold;
	float: left;
	 font-size: 90%;

	
}

#schedule_i .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule_i .btn2 a:hover {
  background: #8aca41;
   color: #fff;

	
}

#schedule_i .btn2 a:hover:after {
  right: 1.4rem;
}

}





/* process　受講までの流れ：pc*/

.readmore2 {
  position: relative;
  margin: 20px auto 0;
  padding: 0px 0px 75px;
}

.readmore2 .readmore-content p{
  margin: 15px 0;
}

.readmore2 .readmore-content {
  position: relative;
  height: 800px;
  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: 20%;
 padding: 18px 40px;

  text-align: center;
  border-radius: 50px;
     background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
  transform: translateX(-50%);
  cursor: pointer;
  z-index: 1;
	font-size: 100%;

}

.readmore2 label::before{
  content: '▼ 続きを見る';
	
}

.readmore2 input[type="checkbox"]:checked ~ label::before {
  content: '▲ 閉じる';
}

.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;
}

/* process受講までの流れ：途中から開閉 tab*/

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


}


/* process受講までの流れ：途中から開閉sp*/

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

	
.readmore2 label {
  position: absolute;
  display: table;
  left: 50%;
  bottom: 0px;
  margin: 0 auto;
  width: 40%;
 padding: 18px 40px;
  color: #fff;
  text-align: center;
  border-radius: 50px;
  background-color: #333;
  transform: translateX(-50%);
  cursor: pointer;
  z-index: 1;
	font-size: 110%;
	font-weight: bold;
}

	
.readmore2 .readmore-content {
  position: relative;
  height: 240px;
  overflow: hidden;
}

}



/* Circles コーチ右 */
.circle {
  background: #fef4f4;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 200px;
  height: 200px;

  mix-blend-mode: multiply;
position:absolute; top:-160px; left:34%; z-index: 1;

	
	
}

/* Circles スケジュール */

.circle-1 {
  background: #fff5ee;
  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:-80px; left:30%; z-index: 1;
	
	
}

/* Circles 左*/
.circle-2 {
 background: #9d9b8a;
  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:100px; 
	left:-50px; 
	z-index: 9998;
	opacity: 0.07;
}

/* Circles ロゴ横*/
.circle-3 {
  background: #eee;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 300px;
  height:300px;

  mix-blend-mode: multiply;
position:absolute; top:-200px; left:16%; 

	z-index: 9998;
opacity: 0.3;

}

/* Circles 右*/
.circle-4 {
 background: #eee;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 230px;
  height:230px;

  mix-blend-mode: multiply;
position:absolute; top:90px; right:20px; z-index: 1;
	opacity: 0.4;
	
}


/* Circles 体験会 */

.circle-5 {
  background: #f0f6da;
  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:340px; z-index: 1;
	
	
}


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

.is-animation .circle-4 {
		display: none;

 
}

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

/* Circles スケジュール */

.circle-1 {
  background: #fff5ee;
  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:350px; left:0; z-index: 1;
	
	
}


/* Circles 左*/
.circle-2 {
 background: #9d9b8a;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 400px;
  height:400px;

  mix-blend-mode: multiply;
position:absolute; 
	top:100px; 
	left:-50px; 
	z-index: 9997;
	opacity: 0.07;
	
}
	

	
/* Circles 体験会 */

.circle-5 {
  background: #f0f6da;
  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:300px; left:340px; z-index: 1;
	
	
}

}


@media screen and (max-width:767px) {
	
/* Circles スケジュール */

.circle-1 {
  background: #fff5ee;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 280px;
  height: 280px;

  mix-blend-mode: multiply;
position:absolute; top:190px; left:-10%; z-index: 1;
	
	
}


/* Circles 左*/
.circle-2 {
 background: #9d9b8a;
  border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
  animation: border-animation 10s infinite linear;
	width: 300px;
  height:300px;

  mix-blend-mode: multiply;
position:absolute; 
	top:300px; 
	left:-20px; 
	z-index: 9998;
	opacity: 0.07;
	
}

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

  mix-blend-mode: multiply;
position:absolute; top:0; left:-40px; z-index: 1;
	
	
}
/* Circles 体験会 */

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

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

}



/* about トップページ；クラスについて pc */

#about_i {
padding:0 0 80px 0;
background:url("../images/vision/bg_about2.jpg") no-repeat;
	background-position: top left;
margin: 100px 0 0 0;
background-size: 85%;
	


}


#about_i h2{

	padding: 60px 0;
	margin: 0 auto 0 0;
	
font-family: 'Quicksand', sans-serif;
    letter-spacing: 0.1em;

text-align: left;
	line-height: 1.4;
	font-weight: bold;
	
	background:url("../images/vision/h2_about.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top left;

	
	 background-size: 55%; /*--背景画像のサイズ--*/

}

#about_i #subttl{
	font-size: 120%;
	margin: 0%;
text-align: left;
	letter-spacing: 2px;

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


#about_i h3{
	margin: 0 0 20px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 0.1em;
	color: #333;
	
	
}

#about_i h4{
	
	margin: 30px 0 30px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 0.1em;
color:#8e8172;

	
}


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


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


#about_i .flame_l{
margin: 0 0 80px 0;
padding: 0 30px 30px 0;
width: 35%;
border-radius: 0 30px 30px 0;
	float: left;

	
	
}

#about_i .flame_l p{

	margin: 0 0 20px 0;
	font-size: 100%;
	letter-spacing: 1px;
	color: #333;
}


#about_i .flame_r{
margin: 0 5% 0 0 ;
	width: 49%;
float: right;

}


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


#about_i .btn a {
    background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 15px 30px 15px 5px;
    width: 28%;
    padding: 15px 30px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 85%;
	float: right;
}

#about_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 85%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#about_i .btn a:hover {
    background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}

#about_i .btn a:hover:after {
  right: 1.4rem;
}



/* about クラスについて tab */

@media screen and (min-width:768px) and (max-width:959px) {
#about_i {
padding: 700px 5% 0 5%;
background:url("../images/vision/bg_about_tab.jpg") no-repeat;
	background-position: top left;
margin: 20px 0 50px 0;
	background-size: 100%;
	

}


#about_i h2{

text-align: left;

	font-weight: bold;
	
	
	background:url("../images/vision/h2_about.png") no-repeat;
	background-position: top left;
background-size: 45%;
	
	margin: 30px 0 5px 2px;

padding: 100px 0 0 0 ;



}


#about_i h3{
	margin: 0 0 20px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 0.1em;
	color: #333;
	
	
}



#about_i h4{
	
	margin: 30px 0 20px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 0.1em;
color:#8e8172;

	
}


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


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


#about_i .flame_l{
margin: 0 0 80px 0;
padding: 0 30px 30px 0;
width: 35%;
border-radius: 0 30px 30px 0;
	float: left;

	
	
}

#about_i .flame_l p{

	margin: 0 0 20px 0;
	font-size: 100%;
	letter-spacing: 1px;
	color: #333;
}






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

	
}


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


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

	

}

#about_i .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: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	float: right;
	
}

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



}

/* about クラスについて sp */

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


}


#about_i h2{
	
background:url("../images/vision/h2_about.png") no-repeat;
	background-position: top left;
background-size: 75%;
	
	margin: 20px 0 5px 2px;
padding: 40px 0 ;




}


#about_i h3{
	margin: 0 0 20px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 0.1em;
	color: #333;
	
}

#about_i h4{
	
	margin: 30px 0 20px 0;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;
color:#8e8172;

	
}


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




#about_i .flame_l{
display: none;
	
	
}






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

	
}


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

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

	

}

#about_i .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: #333;
	font-weight: bold;
	border-radius: 30px;
	letter-spacing: 1px;
border: 4px solid #333;
	float: right;
	
}

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



}

/* フレーム：斜め背景色（白） */
.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 {
padding: 0 0 150px 0;
margin:0;
	background:url("../images/features/bg_features2.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
      background-color: #fff;

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


}


#features h2{
	
background:url("../images/features/h2_features.svg") no-repeat;
	background-position: top left;

	
	margin: 30px 0 0 0;

padding: 100px 0 10px 0 ;

	background-size: 37%;

}



#features h3{
	margin: 0 0 20px 8px;
	text-align: left;
	font-size: 110%;
	letter-spacing: 2px;

	color: #333;
	
}

#features h4{
	margin: 20px 0 20px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
color:#8e8172;

	
}

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

#features p{

font-size: 100%;
	margin: 0;
	letter-spacing: 0.1em;
	
}

/* タイトル下テキスト */

#features .txt{

font-size: 100%;
	margin: 0 0 10px 0;
	letter-spacing: 0.1em;
	
}

#features .flame_c{

	
	margin: 0 6%;
	width: auto;

}






#features ul{

margin: 20px 0 0 0;
	width: 100%;
}

#features ul li{


	padding: 3px 10px;
	width: auto;
	float: left;
	margin: 0 8px 8px 0;
	text-align: center;
	font-size: 85%;
	border-radius: 5px;
	background: #eae5dd;
	color: #a08965;
	
}

#features .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 30px auto;
    width:30%;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;
text-align: center;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 90%;

	letter-spacing: 0.2em;
}

#features .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#features .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#features .btn a:hover:after {
  right: 1.4rem;
}

.flower{
	
background:url("../images/flower.png") no-repeat;
padding: 200px 0;
	width: 400px;

	 /* 画像を常に天地左右の中央に配置 */
  background-position: top center;	
	background-size: 100%;
	position: absolute;
	top:0;
	right: 0;
	z-index: 9998;
	
	
}

/* features　特長 tab*/

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

#features {
padding: 0 4% 40px 4%;
margin:0;
	background:url("../images/features/bg_features2_tab.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
   background-color: #fff;

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


}


#features h2{
	
background:url("../images/features/h2_features.svg") no-repeat;
	background-position: top left;

	
	margin: 30px 0 0 2px;

padding: 80px 0 0 0 ;

	background-size: 46%;


}



#features h3{
	margin: 0 0 30px 6px;
	text-align: left;
	font-size: 120%;
	letter-spacing: 2px;

	color: #333;
	
}

#features h4{
		margin: 30px 0 20px 7px;
	text-align: left;
	font-size: 130%;
	letter-spacing: 0.1em;
color:#8e8172;
	
}

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

#features p{

font-size: 100%;
	margin: 0;
	
}

#features .txt{

font-size: 100%;
	margin: 0 0 0 1%;
	
}

#features .flame_c{

	
	margin: 0;
	width: auto;

}






#features ul{

margin: 20px 0 0 0;
	width: 100%;
}

#features ul li{


	padding: 3px 10px;
	width: auto;
	float: left;
	margin: 0 8px 8px 0;
	text-align: center;
	font-size: 85%;
	border-radius: 5px;
	background: #eae5dd;
	color: #a08965;
	
}

#features .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 30px auto;
    width:30%;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;
text-align: center;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 90%;

	letter-spacing: 0.2em;
}

#features .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#features .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#features .btn a:hover:after {
  right: 1.4rem;
}

.flower{
	
background:url("../images/flower.png") no-repeat;
padding: 150px 0;
	width: 300px;

	 /* 画像を常に天地左右の中央に配置 */
  background-position: top center;	
	background-size: 100%;
	position: absolute;
	top:0;
	right: 0;
	z-index: 9998;
	
	
}
}


/* features 特長 sp*/

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


#features {
padding: 0 4% 45px 4%;
margin:0;
	background:url("../images/features/bg_features2_sp.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
   background-color: #fff;

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

}


#features h2{
	
background:url("../images/features/h2_features.svg") repeat-y;
	background-position: top left;

	
	margin: 20px 0 5px 2px;

padding: 60px 0 0 0 ;

	background-size: 70%;
}



#features h3{
	margin: 0 0 30px 6px;
	text-align: left;
	font-size: 100%;
	letter-spacing: 2px;

	color: #333;
}

#features h4{
		margin: 30px 0 20px 4px;
	text-align: left;
	font-size: 130%;
	letter-spacing: 0.1em;
color:#8e8172;
	
}

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

#features p{

font-size: 100%;
	margin: 0;
	letter-spacing: 0.1em;
	
}

#features .txt{

font-size: 100%;
	margin: 0 0 0 1%;

	
}

#features .flame_c{

	
	margin: 0;
	width: auto;
}






#features ul{

margin: 20px 0 0 0;
	width: 100%;
}

#features ul li{


	padding: 3px 10px;
	width: auto;
	float: left;
	margin: 0 8px 8px 0;
	text-align: center;
	font-size: 85%;
	border-radius: 5px;
	background: #eae5dd;
	color: #a08965;
	
}

#features .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 30px auto;
    width:70%;
    padding: 15px 0;
    font-family: "Noto Sans Japanese";
    text-decoration: none;
text-align: center;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 90%;

	letter-spacing: 0.2em;
}

#features .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#features .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#features .btn a:hover:after {
  right: 1.4rem;
}

.flower{
	
background:url("../images/flower.png") no-repeat;
padding: 200px 0;
	width: 300px;

	 /* 画像を常に天地左右の中央に配置 */
  background-position: top center;	
	background-size: 100%;
	position: absolute;
	top:0;
	right: 0;
	z-index: 9998;
	
	
}
}




.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 }
}


/* 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) {


.main_imgBox_l {
   height: 880px;
    overflow: hidden;
    position: relative; 

}

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

/* 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) {


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

}

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

	
/* 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, #fff 0%, #fff 100%);
  background: -webkit-linear-gradient(-45deg, #fff 0%, #fff 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: 0 12px 70px 12px;
     font-size: 10rem;
    margin: 0;
	 font-family:'Helvetica',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;
	  opacity: 0.4;
		
  }

}

@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: 0 12px 70px 12px;
     font-size:13rem;
    margin: 0;
	 font-family:'Helvetica',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;
	  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:200px;
	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: 25rem;
    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%);
    }
  }



/* スライドテキスト（挿絵内）*/


.loop_txt4 {

    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: 300px;
border: none;
    overflow: hidden;
margin: 0;
padding: 20px 0 0 0;

	
  }

.loop_txt4 div {

	 flex: 0 0 auto;
    padding: 0 12px;
   font-size: 20rem;
    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_txt4 {

    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height: 300px;
border: none;
    overflow: hidden;
margin: 0;


	
	
  }

.loop_txt4 div {
    flex: 0 0 auto;
    padding: 0 12px;
   font-size: 18rem;
    margin: 0;
	 font-family: 'Lato', sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
color: transparent;
-webkit-text-stroke: 2px rgb(255, 255, 255);

	
  }
}

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

    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: auto;
    height:180px;
border: none;
    overflow: hidden;
margin: 0;
	
	
  }

.loop_txt4 div {
    flex: 0 0 auto;
    padding: 0 12px;
   font-size: 18rem;
    margin: 0;
	 font-family: 'Lato', sans-serif;
	  font-weight: bold;
	  letter-spacing: 4px;
color: transparent;
-webkit-text-stroke: 2px rgb(255, 255, 255);

	
  }
  }

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

.loop_txt4 div:nth-child(even) {
    -webkit-animation: loop4 70s  linear infinite;
    animation: loop4 70s 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;

}


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

.popUp_item_image_text{

  position: absolute;

  left: 0;

  bottom: -122px;

  width: 100%;

  font-size: 100%;

  color: #fff;

  letter-spacing: 0.1em;

  line-height: 1.7;

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

  padding: 20px 20px 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: 98%;

    padding: 20px 20px 20px;

  }

}



@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: -70px;

  }

}



.popUp_item_image_text:before{

  content:"";

  position: absolute;

  top: -145px;

  left: 50%;

  width: 200%;

  height: 400px;

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

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

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

  .popUp_item_image_text:before{

    top: -145px;

  }

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

  .popUp_item_image_text:before{

    top: -115px;

  }

}

/*ポップアップ枠*/

.popUp_item_image_text .op_text{

  position: relative;

  z-index: 2;

  max-width: 100%;

  margin-left: 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_list {
padding: 0 ;
margin: 0;
	background:url("../images/coach/bg_coach_i.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
background-color:#fff;
	

}

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


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

}

#coach_list h2{
	margin: 0 0 20px 0;

padding: 60px 0;
	background:url("../images/coach/h2_coach.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
	background-size: 45%;

}




#coach_list h3{
	margin: 10px 0 20px 0;
	text-align: left;
	font-size: 150%;
	letter-spacing: 3px;

	color: #333;
	
}

#coach_list h3 span{
	margin: 0 0 20px 1px;
	text-align: left;
	font-size: 60%;
	letter-spacing: 3px;
	color: #8e8172;
	font-weight: bold;
}


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

}



#coach_list .btn a {
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 30px 10px;
    width:auto;
    padding: 10px 60px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	 font-size: 90%;
	float: right;
	letter-spacing: 0.2em;
}

#coach_list .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#coach_list .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#coach_list .btn a:hover:after {
  right: 1.4rem;
}


#coach_list .flame_c{

	padding: 40px 30px 30px 30px;
	margin: 620px auto 80px auto;
	width: 70%;
	background: #fff;
	border-radius: 30px;

	



}





#coach_list .flame_c img{

	padding: 10px;

width: 75%;
	border: solid 6px #f0ece6;    	/* 内側の線になる一本線の枠線をひく*/
	
	
	border-radius: 50%;


	
}

#coach_list .flame_l{

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

}

#coach_list .flame_r{

	width: 64%;
	float:left;

}



.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_list {
padding: 0 ;
margin: 0;
	background:url("../images/coach/bg_coach_i_tab.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
background-color:#fff;
}

#coach_list h2{
	margin: 0 0 20px 0;

padding: 45px 0;
	background:url("../images/coach/h2_coach.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
	background-size: 45%;

}




#coach_list h3{
	margin: 10px 0 20px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 3px;

	color: #333;
	
}

#coach_list h3 span{
	margin: 0 0 20px 1px;
	text-align: left;
	font-size: 60%;
	letter-spacing: 3px;
	color: #8e8172;
	font-weight: bold;
}


#coach_list .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 30px 0 30px 4.5% ;
	color: #333;

}



#coach_list .btn a {
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 10px 5px 30px 10px;
    width:auto;
    padding: 10px 60px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	 font-size: 90%;
	float: right;
	letter-spacing: 0.2em;
}

#coach_list .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#coach_list .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#coach_list .btn a:hover:after {
  right: 1.4rem;
}


#coach_list .flame_c{

	padding: 40px 30px 30px 30px;
	margin: 420px auto 80px auto;
	width: 85%;
	background: #fff;
	border-radius: 30px;

	



}





#coach_list .flame_c img{

	padding: 10px;

width: 75%;
	border: solid 6px #f0ece6;    	/* 内側の線になる一本線の枠線をひく*/
	
	
	border-radius: 50%;


	
}

#coach_list .flame_l{

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

}

#coach_list .flame_r{

	width: 64%;
	float:left;

}



}


/* coach 講師 sp*/

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


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

}

#coach_list h2{
	margin: 0 ;

padding: 45px 0;
	background:url("../images/coach/h2_coach.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: center top;
	background-size: 75%;
}




#coach_list h3{
	margin: 20px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 3px;

	color: #333;

}

#coach_list h3 span{
	margin: 0 0 20px 1px;
	text-align: left;
	font-size: 60%;
	letter-spacing: 3px;
	color: #8e8172;
	font-weight: bold;

}


#coach_list .underline {
  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	margin: 30px 0 30px 4.5% ;
	color: #333;

}



#coach_list .btn a {
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 10px 5px 30px 10px;
    width:auto;
    padding: 10px 60px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	 font-size: 90%;
	float: right;
	letter-spacing: 0.2em;
}

#coach_list .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#coach_list .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#coach_list .btn a:hover:after {
  right: 1.4rem;
}


#coach_list .flame_c{

	padding: 40px 30px 20px 30px;
	margin: 100px auto 10px auto;
	width: 70%;
	background: #fff;
	border-radius: 30px;


}





#coach_list .flame_c img{

	padding: 10px;
text-align: center;
width: 90%;
	border: solid 6px #f0ece6;    	/* 内側の線になる一本線の枠線をひく*/
	margin: 0 auto;
	
	border-radius: 50%;


	
}

#coach_list .flame_l{

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


}

#coach_list .flame_r{

	width: auto;
	float: none;

}



}



/* contact トップページお問い合わせ：PC　 */



#contact_i {
padding: 50px 0 0 0;
margin: 0 auto 0 auto;

background:url("../images/contact/bg_contact_i.jpg") no-repeat;
background-position: top left;
	background-size: 110%;



}

#contact_i .wave {

padding: 0 ;
margin: 0 auto;
	height:  110px;
	background:url("../images/contact/bg_contact_i.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom center;


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

}


#contact_i h2{
	
margin: 0;

padding: 45px 0;
	background:url("../images/contact/h2_contact.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 50%;


}


#contact_i h3{
	font-size: 110%;
	margin: 0 0 30px 3px;
text-align: left;


	line-height: 1.5em;
	letter-spacing: 2px;
	width: auto;
	padding: 0;
}



#contact_i .underline {

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

}

#contact_i h4{
	
margin: 50px 0 0 0;

padding: 45px 0;
	background:url("../images/reserve/h2_reserve.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 48%;


}


#contact_i .flame_l{

	
width: 40%;
	
	margin: 0;
	float: left;


}



#contact_i .flame_r{

width: 55%;
	margin: 20px 5% 20px 0;
	float: right;
	font-weight: bold;
}

#contact_i .flame_r p{
 

 font-size: 100%;
	margin: 0 0 30px 0;
	letter-spacing:1px;
	
}



#contact_i .flame_r2{

width: 61%;
	margin: 0 0 20px 0 ;
	float: left;
	font-weight: bold;

}

#contact_i .flame_r2 p{
 
  color: #000;
 font-size: 110%;
	margin: 0 0 30px 0;
	letter-spacing:1px;
	
}




#contact_i .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 5px 20px 30px;
    width: 35%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: left;
	letter-spacing: 0.1em;
}

#contact_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#contact_i .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#contact_i .btn a:hover:after {
  right: 1.4rem;
}

#contact_i .btn2 a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 5px 20px 30px;
    width: 20%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 98%;
	float: left;
	letter-spacing: 0.2em;
}

#contact_i .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#contact_i .btn2 a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#contact_i .btn2 a:hover:after {
  right: 1.4rem;
}

.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 img{
	border-radius: 0 30px 30px 0;

	}

    .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 }
	


}



/* contact トップページお問い合わせ tab　 */

@media screen and (min-width:768px) and (max-width:959px) {
#contact_i {
padding: 590px 0 0 0;
margin: 0 auto 0 auto;

background:url("../images/contact/bg_contact_i_tab.jpg") no-repeat;
background-position: top left;
	background-size: 100%;



}

#contact_i .wave {

padding: 0 ;
margin: 0 auto;
	height:  50px;
	background:url("../images/contact/bg_contact_i.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom center;


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

}


#contact_i h2{
	
margin: 0 0 0 2px;

padding: 45px 0;
	background:url("../images/contact/h2_contact.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 50%;


}


#contact_i h3{
	font-size: 105%;
	margin: 0 0 30px 3px;
text-align: left;


	line-height: 1.5em;
	letter-spacing: 2px;
	width: auto;
	padding: 0;
}



#contact_i .underline {

  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	color: #000;
	margin: 0 0 30px 2px;

}

#contact_i h4{
	
margin: 50px 0 0 0;

padding: 45px 0;
	background:url("../images/reserve/h2_reserve.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 48%;


}


#contact_i .flame_l{

	
width: 80%;
	
	margin: 0 auto;
	float: none;
background: #fff;

}



#contact_i .flame_r{

width: 80%;
	margin: 20px auto 20px auto;
	float: none;
	font-weight: bold;
	background: #fff;
	padding: 40px 0 40px 40px;
	border-radius: 30px;
}

#contact_i .flame_r p{
 

 font-size: 100%;
	margin: 0 0 30px 0;
	letter-spacing:1px;
	
}



#contact_i .flame_r2{

width: 61%;
	margin: 0 0 20px 0 ;
	float: left;
	font-weight: bold;

}

#contact_i .flame_r2 p{
 
  color: #000;
 font-size: 110%;
	margin: 0 0 30px 0;
	letter-spacing:1px;
	
}




#contact_i .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
     margin: 5px 5px 20px 30px;
    width: 35%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: left;
	letter-spacing: 0.1em;
}

#contact_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#contact_i .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#contact_i .btn a:hover:after {
  right: 1.4rem;
}

#contact_i .btn2 a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
     margin: 5px 5px 20px 30px;
    width: 20%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 98%;
	float: left;
	letter-spacing: 0.2em;
}

#contact_i .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#contact_i .btn2 a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#contact_i .btn2 a:hover:after {
  right: 1.4rem;
}


.main_imgBox_l {
    min-height: 550px;
    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 img{
	border-radius: 0;

	}

    .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; }


}

/* contact トップページお問い合わせ sp　 */

@media screen and (max-width:767px) {
#contact_i {
padding: 450px 3% 50px 3%;
margin: 0;

background:url("../images/contact/bg_contact_i_sp.jpg") no-repeat;
background-position: top left;
	background-size: 100%;


}

#contact_i .wave {

display: none;
}


#contact_i h2{
	
margin: 0 0 0 2px;

padding: 28px 0;
	background:url("../images/contact/h2_contact.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 82%;


}


#contact_i h3{
	font-size: 100%;
	margin: 0 0 30px 3px;
text-align: left;


	line-height: 1.5em;
	letter-spacing: 2px;
	width: auto;
	padding: 0;

}



#contact_i .underline {

  border-bottom: dotted 1px;
  width: 80px;
  text-align: left;
	color: #333;
	margin: 0 0 30px 2px;

}

#contact_i h4{
	
margin:20px 0 0 0;

padding: 30px 0;
	background:url("../images/reserve/h2_reserve.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 75%;


}


#contact_i .flame_l{

	
width: auto;
	
	margin: 0 auto;
	float: none;
background: #fff;

}



#contact_i .flame_r{

width: 75%;
	margin: 0 auto;
	float: none;
	font-weight: bold;
	background: #fff;
	padding: 30px 30px 10px 30px;
	border-radius: 30px;
}

#contact_i .flame_r p{
 

 font-size: 100%;
	margin: 0 0 30px 0;
	letter-spacing:1px;
	
}



#contact_i .flame_r2{

width: 61%;
	margin: 0 0 20px 0 ;
	float: left;
	font-weight: bold;

}

#contact_i .flame_r2 p{
 
  color: #333;
 font-size: 110%;
	margin: 0 0 30px 0;
	letter-spacing:1px;
	
}




#contact_i .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px auto 20px auto;
    width: 88%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 80%;
	float: none;
	letter-spacing: 0.1em;
}

#contact_i .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#contact_i .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#contact_i .btn a:hover:after {
  right: 1.4rem;
}

#contact_i .btn2 a {
     background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px auto 20px auto;
   width: 88%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 80%;
	float: none;
	letter-spacing: 0.1em;
}

#contact_i .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#contact_i .btn2 a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#contact_i .btn2 a:hover:after {
  right: 1.4rem;
}


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

}
	

	
.main_imgBox_l2 {
    min-height: 280px;
    overflow: hidden;
    position: relative;

}


  .main_img_l2 {
    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_l2 img{
	border-radius: 0;

	}

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

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

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

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

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

}









/* 挿画：お問い合わせとお申し込みの間 */
#mat{
	height: 550px;

	background:url("../images/bg_mat2.jpg") no-repeat;
background-size:cover; 
    background-attachment: fixed; 
    background-position: top center;
	margin: 0 12% 0 0;



}

@media screen and (max-width:767px) {
#mat {
	width: 100%;
	height: 300px;
background:url("../images/bg_mat2.jpg") no-repeat;
background-position: top left;
	background-size: 90% ;

}
}


/* 挿画：お申し込みの上 */
#mat2 {
	height: 400px;

	background:url("../images/bg_mat2.jpg") no-repeat;
background-size:130%; 
    background-attachment: fixed; 
    background-position: center center;
	margin: 100px 0 0 12%;



}

@media screen and (min-width:768px) and (max-width:959px) {
#mat2 {
	width: auto;
	height: 350px;

	background:url("../images/bg_mat2.jpg") no-repeat;
background-size:cover; 
    background-attachment: fixed; 
    background-position: center center;
	margin: 40px 0 0 12%;


}
}

@media screen and (max-width:767px) {
#mat2 {
	width: auto;
	height: 250px;

	background:url("../images/bg_mat2_sp.jpg") no-repeat;
background-size:100%; 

    background-position:top right;
	margin: 40px 0 0 7%;

}
}

/* accessの上*/
#mat3{
margin: 100px 0 0 0;
	height: 300px;
	background:url("../images/bg_mat3.jpg") no-repeat;
	background-position: center right;
background-size:85%;



}

@media screen and (min-width:768px) and (max-width:959px) {
#mat3{
margin: 100px 0 0 0;
	height: 250px;
	background:url("../images/bg_mat3.jpg") no-repeat;
	background-position: top right;
background-size:85%;



}
}

@media screen and (max-width:767px) {
#mat3 {
	
	margin: 50px 0 120px 0;
	height: 250px;
background:url("../images/bg_mat3_sp.jpg") no-repeat;
	background-position: top right;
background-size:90%;


}
}

/* 挿画：お問い合わせの上 */
#mat4 {

	width: auto;
	height: 450px;
	margin: 0;

background:url("../images/bg_mat4.jpg") no-repeat;
	 /* 画像を常に天地左右の中央に配置 */
  background-position:top right;
   
background-size: 80%;

}

@media screen and (min-width:768px) and (max-width:959px) {
#mat4 {
	width: auto;
	height: 230px;
	margin: 50px 0 0 0;

background:url("../images/bg_mat4.jpg") no-repeat;
	 /* 画像を常に天地左右の中央に配置 */
  background-position:center right;
   
background-size: 85%;

}
}

@media screen and (max-width:767px) {
#mat4 {
	width: auto;
	height: 300px;
	margin: 50px 0 0 0;

background:url("../images/bg_mat4_sp.jpg") no-repeat;
	 /* 画像を常に天地左右の中央に配置 */
  background-position:center right;
   
background-size: 90%;
}
}

/* アクセス access：PC*/


#access {

margin: 0;
	padding: 0 0 100px 0;

	background:url("../images/access/bg_access.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom left;

	background-color: none;
	 background-size: 100%; /*--背景画像のサイズ--*/
	
}




#access h2{
margin: 30px 0 0 0;
	padding: 60px 0;
	background:url("../images/access/h2_access.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top left;
	background-size:55%;

}




#access h3{
	margin: 0 0 30px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 3px;
	color: #333;
	
	width: 50%;
}


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


#access h4{
	
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	
}


#access .flame_l{
padding: 20px;
width: 36%;
	float:left;
background: #fff;
	margin: 130px 0 0 7%;
 box-shadow: 0 0 3px rgba(94, 94, 94, 0.3);
	border-radius: 30px;

	


}



#access .flame_l p{

font-size: 105%;
	margin: 0 0 20px 0;
	


}
#access .flame_r{

width: 49%;
	
	float:right;

margin: 100px 0 0 0;
	text-align: left;

	

}

#access .flame_r p{

font-size: 105%;
	margin: 0 0 10px 0;
	font-weight: normal;
	


}




/*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）の名前*/
}









#access p{
  font-size: 120%;
	text-align: left;
	  margin: 0 0 10px 0;
  padding: 0;
}


#access .btn {


	text-align:center;
	font-weight: bold;
	


}

#access .btn a {
		position: relative;
	display: inline-block;
	padding:7px 7px 2px 7px;

	float: left;
	font-size: 120%;
 background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
	width: 30px;
	height: 35px;
	text-align:center;
border-radius: 50%;
margin: 30px 15px 0 auto;
font-weight:bold;
	
}

#access .btn a:hover {
	  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}




/* access アクセス：tab*/

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

margin: 0;
	padding: 0 0 30px 0;


	background:url("../images/access/bg_access_tab.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom left;

	
	 background-size: 100%; /*--背景画像のサイズ--*/
	
}



#access h2{
margin: 0;
	padding: 55px 0;
	background:url("../images/access/h2_access.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top left;
	background-size:45%;

}




#access h3{
	margin: 0 0 30px 0 ;
	text-align: left;
	font-size: 120%;
	letter-spacing: 3px;
	color: #333;
	
	width: 50%;
}


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

}


#access h4{
	
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	
}


#access .flame_l{
padding: 10px;
width: 70%;
	float:none;
background: #fff;
	margin: 80px auto 0 auto;
 box-shadow: none;
	
		border: 5px solid #fff;
	


}
	



#access .flame_l p{

font-size: 105%;
	margin: 0 0 20px 0;
	


}
#access .flame_r{

width: 90%;
	float:none;

margin: 100px 0 0 6%;
	text-align: left;

	

}

#access .flame_r p{

font-size: 105%;
	margin: 0 0 10px 0;
	font-weight: normal;
	


}
	
#access .btn {
    
margin: 20px auto 0 auto;

	text-align:center;
	font-weight: bold;


}

#access .btn a {
		position: relative;
	display: inline-block;
	padding: 12px 6px 0 6px;
	float: right;
	font-size: 150%;
 background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;

	width: 50px;
	height: 50px;
	text-align:center;
border-radius: 50%;

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

#access .btn a:hover {
	  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}

}

/* access アクセス：sp*/

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

margin: 0;
	padding: 0 0 80px 0;


	background:url("../images/access/bg_access_sp.jpg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: bottom left;

	
	 background-size: 100%; /*--背景画像のサイズ--*/

}



#access h2{
margin: 0;
	padding: 50px 0;
	background:url("../images/access/h2_access.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: top left;
	background-size:75%;

}




#access h3{
	margin: 0 0 30px 0 ;
	text-align: left;
	font-size: 110%;
	letter-spacing: 3px;
	color: #333;
	width: 50%;
}


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

}


#access h4{
	
	margin: 30px 0 10px 0;
	text-align: left;
	font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	
}


#access .flame_l{
padding: 0;
width: auto;
	float:none;
background: none;
	margin: 0 auto 0 auto;
border: none;
 box-shadow: none;


}
	



#access .flame_l p{

font-size: 105%;
	margin: 0 0 20px 0;
	


}
#access .flame_r{

width: 90%;
	float:none;

margin: 50px 0 0 6%;
	text-align: left;	

}

#access .flame_r p{

font-size: 105%;
	margin: 0 0 10px 0;
	font-weight: normal;
	


}
	
#access .btn {
    
margin: 20px auto 0 auto;

	text-align:center;
	font-weight: bold;


}

#access .btn a {
		position: relative;
	display: inline-block;
	padding: 12px 6px 0 6px;
	float: right;
	font-size: 150%;
 background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;

	width: 50px;
	height: 50px;
	text-align:center;
border-radius: 50%;

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

#access .btn a:hover {
	  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
}

}




	




/* 練習の流れ */

.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;

}
}
 

/* join */

#join {

margin: 120px 0 0 0;
	height: 350px;
	background:url("../images/bg_join2.jpg") no-repeat;
	background-position: center right;
	background-size: 80% 80%;
	border: 1px solid #000;


}


#join h2{
	
	margin: 0 auto 50px auto;
	font-weight: bold;
	
  /* margin: 20px; */
  font-family: "Paytone One";
  text-transform: uppercase;
	text-align: center;
 display: block;
  font-size: 800%;
  line-height: 200%;
  color: #fff;
  text-shadow: 0 13.36px 8.896px #c4b59d,0 -2px 1px #fff;
  letter-spacing: -4px;
	animation: flash 5s linear infinite;
}


@keyframes flash {

	0%,
	100% {
		opacity: 1;
	}
	
	25% {
		opacity: 0;
	}

	50% {
		opacity: 1;
	}
	75% {
		opacity: 1;
		
	}
}









@media screen and (min-width:768px) and (max-width:959px) {
#join {
padding: 0 0 720px 0;
margin: 0;
	background:url("../images/bg_join2.jpg") no-repeat;
	background-position: top center;	
	
  /* コンテンツの高さが画像の高さより大きい時、動かないように固定 */
  background-attachment: fixed;
   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: cover;
	border-radius: 0;
   


}






}

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

#join {
padding: 0 0 330px 0;
margin: 0;
	background:url("../images/bg_join2.jpg") no-repeat;
	background-position: top center;	
	
  /* コンテンツの高さが画像の高さより大きい時、動かないように固定 */
  background-attachment: fixed;
   
  /* 表示するコンテナの大きさに基づいて、背景画像を調整 */
  background-size: cover;
	background-size: 140%;
	border-radius: 0;
   


}

}


/*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;}
}





/*================================================
 * クラスについて、特長：about.html
 ================================================*/

/* クラスについて、特長：pc　 */

#about {
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#about #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/about/bg_about.jpg") no-repeat;
	background-position: top center;
	background-size:100%;
height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}



#about .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 50px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
}


#about .inner p {
 
	text-align: left;
	font-size: 100%;

	line-height: 1.6;

	
	
  
}


#about h2{
position: absolute;
	top:180px;
	left: 87px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/vision/h2_about.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 60%;

}

#about #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#about h3{
	font-size: 130%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 0.1em;

	line-height: 1.6em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#about h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#about h4{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing: 0.1em;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#about h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#about h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}


#about .flame_l{

	float:left;
	width: 28%;

	margin: 20px 30px 0 0;

	
}


#about .flame_l img{

	
  overflow: hidden;
margin: 0 0 0 0;
border-radius: 50px;


}



#about .flame_r{
	
	width: 65%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;


}






#about .list{


	padding: 3px 10px;
	width: auto;
	float: left;
	margin: 0 8px 8px 0;
	text-align: center;
	font-size: 85%;
	border-radius: 5px;
	background: #eae5dd;
	color: #a08965;
	
}



#about .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}


#about .flame_f {
	width: 46%;



    margin:  30px 30px 20px auto;
	color: #333;
	float: left;




}



#about .flame_f h4{
	
	margin: 10px 0;
font-size: 110%;
	 letter-spacing: 0.1em;

	padding: 10px;
	text-align: center;
	border-top: 1px solid #715c42;
	border-bottom: 1px solid #715c42;
}



#about .flame_f ul li p{
	
	margin: 10px 0;
font-size: 90%;
	 letter-spacing: 0.1em;
	font-weight: bold;
	padding: 0;
	text-align: center;
}




#about .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 5px 10px;
    width: 21%;
    padding: 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 90%;
	float: left;
	letter-spacing: 0.2em;
}

#about .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#about .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#about .btn a:hover:after {
  right: 1.4rem;
}




/* クラスについて、特長 tab　 */

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

#about #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/about/bg_about.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 330px;

}



#about .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
}



#about .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#about h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
background:url("../images/vision/h2_about.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 55%;

}

#about #subttl{
	position: absolute;
	top:230px;
	left: 66px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#about h3{
	font-size: 130%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 0.1em;

	line-height: 1.4em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#about h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#about h4{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#about h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#about h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}



#about .flame_l{

	float:left;
	width: 30%;

	margin: 10px 30px 0 0;
	
}


#about .flame_l img{

	
  overflow: hidden;
margin: 0 0 0 -15px;
border-radius: 30px;
	padding: 10px;
	background: #fff;
box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
}



#about .flame_r{
	
	width: 63%;
float:right;
	margin: 10px 0 30px 0;
	text-align: left;

}



#about .flame_f {
	width: auto;
height: auto;


    margin:  30px 30px 120px auto;
	color: #333;
	float: none;




}



#about .flame_f h4{
	
	margin: 10px 0;
font-size: 110%;
	 letter-spacing: 0.1em;

	padding: 10px;
	text-align: center;
	border-top: 1px solid #715c42;
	border-bottom: 1px solid #715c42;
}



#about .flame_f ul li p{
	
	margin: 10px 0;
font-size: 90%;
	 letter-spacing: 0.1em;
	font-weight: bold;
	padding: 0;
	text-align: center;
}




#about .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 5px 10px;
    width: 21%;
    padding: 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 90%;
	float: left;
	letter-spacing: 0.2em;
}

#about .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#about .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#about .btn a:hover:after {
  right: 1.4rem;
}


}


/* クラスについて sp　 */

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

#about #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/about/bg_about_sp.jpg") no-repeat;
	background-position: top right;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}



#about .inner {
margin: 30px auto 30px 0;

	background: #fff;
	padding: 30px 5% 0 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}



#about .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#about h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
background:url("../images/vision/h2_about.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 30%;

}

#about #subttl{
	position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#about h3{
font-size: 120%;
	margin:10px 0 20px 0;
text-align: left;
	letter-spacing: 0.1em;

	line-height: 1.4em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#about h3 span{
	font-size: 50%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#about h4{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#about h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#about h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}



#about .flame_l{

	display: none;
	
}


#about .flame_r img{

	
  overflow: hidden;
margin: 0 auto 20px auto;
border-radius: 30px;
	padding: 5px;
	background: #fff;
box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
	width: 94%;
}



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


}


#about .flame_f {
	width: auto;
height: auto;


    margin:  30px auto 150px auto;
	color: #333;
	float: none;




}



#about .flame_f h4{
	
	margin: 10px 0;
font-size: 110%;
	 letter-spacing: 0.1em;

	padding: 10px;
	text-align: center;
	border-top: 1px solid #715c42;
	border-bottom: 1px solid #715c42;
}



#about .flame_f ul li p{
	
	margin: 10px 0;
font-size: 90%;
	 letter-spacing: 0.1em;
	font-weight: bold;
	padding: 0;
	text-align: center;
}

#about .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 0 5px 0;
    width:93%;
    padding: 8px 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 85%;
	float: none;
	letter-spacing: 0.1em;
}

#about .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#about .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#about .btn a:hover:after {
  right: 1.4rem;
}
}


/*================================================
 * スケジュール：schedule.html
 ================================================*/

/* スケジュール pc　 */

#schedule {
	
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#schedule #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/schedule/bg_schedule.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}


#schedule .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}





#schedule h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/schedule/h2_schedule.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 84%;

}

#schedule #subttl{
		position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#schedule h3{
	font-size: 130%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.0em;
	color:#7a6b5c;
	width: auto;
	padding: 20px 0;
	border-top: 1px solid #333;

	
}



#schedule h4{
	
	margin: 0 0 5px 0;
font-size: 100%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
color:#7a6b5c;
}

#schedule h5{
	
	margin: 0 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}



#schedule .flame_l{

	float:left;
	width: 20%;

	margin: 0 30px 0 0;
	
}


#schedule .flame_r{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 0 0 0 0;
}



#schedule table{
 
  text-align: center;
  padding: 10px;
	width: 95%;
	letter-spacing: 1px;
	margin: 0;
}

#schedule .tbl-r02 {
  margin: 0;
	width: 100%;
	font-size:105%;


	border-left: none;
	
}


#schedule .tbl-r02 th {

 border-top: dotted 1px #ccc;
  color: #000;
  padding: 20px 10px 15px 20px;
	width: 28%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	
	
}

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

#schedule .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 0.1em;
	
	

}


#schedule iframe{
	
	width: 95%;
	height: 300px;
	margin: 10px auto;

	border: 1px dotted #dcdcdc;
	
	padding: 10px;

	

}


#schedule .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 25%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#schedule .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#schedule .btn a:hover:after {
  right: 1.4rem;
}



/* スケジュール tab　 */

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

	


#schedule #ttl_bg{
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/schedule/bg_schedule.jpg") no-repeat;
		background-position: right top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}


#schedule .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;

	
}




#schedule h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/schedule/h2_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 58%;

}

#schedule #subttl{
		position: absolute;
	top:220px;
	left: 61px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#schedule h3{
		font-size: 120%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0 0 0;
	border-top: none;

	
}




#schedule h4{
	
	margin: 0 0 5px 0;
font-size: 100%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
color:#7a6b5c;
}

#schedule h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
}


#schedule .flame_l{

	float:none;
	width: 50%;
	margin: 0;
	
}


#schedule .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 10px 0 0 0;
}



#schedule table{
  border-bottom: #ccc 1px dotted;
  text-align: center;
  padding: 10px;
	width: 90%;
	letter-spacing: 1px;
	margin: 20px 0;
}



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


#schedule .tbl-r02 th {
 border-top: dotted 1px #ccc;
  color: #333;
  padding: 20px 10px 15px 20px;
	width: 33%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	font-size: 98%;
	
	
}
#schedule .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 20px 0 15px 20px;
	border-left: none;
border-right: none;
	text-align: left;
	font-size: 98%;
}

#schedule .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 0.1em;

}

#schedule .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 28%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#schedule .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#schedule .btn a:hover:after {
  right: 1.4rem;
}


}


/* スケジュール sp　 */

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

	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/schedule/bg_schedule_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;


}

#schedule .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#schedule h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/schedule/h2_schedule.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 42%;

}

#schedule #subttl{
position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;

	
}

#schedule h3{
	font-size: 120%;
	margin: 0 0 10px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0 0 20px 0;
	border-top: none;
	border-bottom: dotted 1px #333;	
	
}


#schedule h4{
	
	margin: 0 0 0 0;
font-size: 110%;
	letter-spacing: 0.1em;

	padding: 0;
	text-align: left;
color:#7a6b5c;
}


#schedule h5{
	
	margin: 10px 0 5px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}


#schedule h6{
	
	margin: 20px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}


#schedule p {
 
	text-align: left;
	font-size: 100%;
margin: 0 0 20px 0;
	
  
}
	
#schedule .flame_l{

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

#schedule .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 0;
}



#schedule .inner table {
	width: 100%;
	 
	
}


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

#schedule .inner .tbl-r02 th {
　　border-bottom: none;
    display: block;
    width: 100%;
	padding: 10px 0 ;
	border: none;
	text-align: left;
	margin: 0;
font-size: 95%;
	background: none;

	
	}


#schedule .inner .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 95%;
	padding: 0 ;
	border: none;
	text-align: left;
	margin: 0 0 10px 0;
font-size: 95%;

	
	}
	
	
#schedule .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 60%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#schedule .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#schedule .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#schedule .btn a:hover:after {
  right: 1.4rem;
}

  }



/*================================================
 * 料金：price.html
 ================================================*/

/* 料金 pc　 */

#price {
	
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#price #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/price/bg_price.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}


#price .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}





#price h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/price/h2_price.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 48%;

}

#price #subttl{
		position: absolute;
	top:273px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#price h3{
		font-size: 130%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.0em;
	color:#7a6b5c;
	width: auto;
	padding: 20px 0;
	border-top: 1px solid #333;

	
}

#price h4{
	margin: 0 0 0 0;
font-size: 100%;
	letter-spacing: 0.1em;

	padding: 0;
	text-align: left;
color:#7a6b5c;
}

#price h5{
	
	margin: 0 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}


#price .flame_l{

	float:left;
	width: 20%;

	margin: 0 30px 0 0;
	
}


#price .flame_r{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 0 0 0 0;
}



#price table{
 
  text-align: center;
  padding: 10px;
	width: 95%;
	letter-spacing: 1px;
	margin: 0;
}


#price .tbl-r02 {
  margin: 0;
	width: 100%;
	font-size:105%;


	border-left: none;
	
}


#price .tbl-r02 th {

 border-top: dotted 1px #ccc;
  color: #000;
  padding: 20px 10px 15px 20px;
	width: 28%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	
	
}

#price .tbl-r02 td {
border-top: dotted 1px #ccc;
  padding: 20px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	vertical-align :top;
	
}

#price .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 0 0 15px 0;
	

}


#price iframe{
	
	width: 95%;
	height: 300px;
	margin: 10px auto;

	border: 1px dotted #dcdcdc;
	
	padding: 10px;

	

}


#price .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 30px 30px 20px 0;
    width: 25%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.1em;
}

#price .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#price .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#price .btn a:hover:after {
  right: 1.4rem;
}



/* 会社概要 tab　 */

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

#price #ttl_bg{
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/price/bg_price.jpg") no-repeat;
		background-position: right top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}


#price .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;

	
}



#price h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/price/h2_price.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 33%;

}

#price #subttl{
		position: absolute;
	top:220px;
	left: 58px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#price h3{
		font-size: 120%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0 0 0;
	border-top: none;

	
}


#price h4{
	margin: 0 0 5px 0;
font-size: 100%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
color:#7a6b5c;

}

#price h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
}


#price .flame_l{

	float:none;
	width: 50%;
	margin: 0;
	
}


#price .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 10px 0 0 0;
}



#price table{
  border-bottom: #ccc 1px dotted;
  text-align: center;
  padding: 10px;
	width: 90%;
	letter-spacing: 1px;
	margin: 20px 0;
}



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


#price .tbl-r02 th {
 border-top: dotted 1px #ccc;
  color: #333;
  padding: 20px 0 15px 20px;
	width: 33%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	font-size: 98%;
	
	
}
#price .tbl-r02 td {
border: dotted 1px #ccc;
   padding: 20px 10px 15px 0;
	border-left: none;
border-right: none;
	text-align: left;
	font-size: 98%;
	vertical-align :top;
}

#price .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 0.1em;

}


#price .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 28%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#price .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#price .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#price .btn a:hover:after {
  right: 1.4rem;
}


}


/* 料金 sp　 */

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

	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/price/bg_price_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;


}

#price .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#price h2{
position: absolute;
	top:130px;
	left: 22px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/price/h2_price.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 24%;

}

#price #subttl{
position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;

	
}

#price h3{
	font-size: 120%;
	margin: 0 0 10px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0 0 20px 0;
	border-top: none;
	border-bottom: dotted 1px #333;	
	
}


#price h4{
	
font-size: 105%;
	text-align: left;

	margin: 5px 0 0 0;
	letter-spacing: 0.1em;

	line-height: 1.1em;
	
	width: auto;
	padding: 0 0 10px 0;

	
}


#price h5{
	
	margin: 10px 0 5px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}


#price h6{
	
	margin: 20px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}



	
#price .flame_l{

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

#price .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 0;
}


#price .inner table {
	width: 100%;
	 
	
}


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

#price .inner .tbl-r02 th {
　　border-bottom: none;
    display: block;
    width: 100%;
	padding: 10px 0 0 0 ;
	border: none;
	text-align: left;
	margin: 0;
font-size: 95%;
	background: none;

	
	}


#price .inner .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 95%;
	padding: 0 ;
	border: none;
	text-align: left;
	margin: 0 0 10px 0;
font-size: 95%;

	
	}

#price .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 0.1em;
	

}
#price .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 60%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#price .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#price .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#price .btn a:hover:after {
  right: 1.4rem;
}

  }


/*================================================
 * 体験：trial.html
 ================================================*/

/* 体験 pc　 */

#trial {
	
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#trial #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/trial/bg_trial.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}


#trial .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}


#trial .inner p {
 
	text-align: left;
	font-size: 105%;
	margin: 0 0 25px 0;
	line-height: 1.6;

}


#trial h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/trial/h2_trial.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 44%;

}

#trial #subttl{
		position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#trial h3{
	font-size: 130%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.0em;
	color:#7a6b5c;
	width: auto;
	padding: 20px 0;
	border-top: 1px solid #333;

	
}



#trial h4{
	
	margin: 50px 0 15px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;

}

#trial h5{
	
	margin: 0 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}



#trial .flame_l{

	float:left;
	width: 20%;

	margin: 0 30px 0 0;
	
}


#trial .flame_r{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 0 0 0 0;
}



#trial table{
 
  text-align: center;
  padding: 10px;
	width: 95%;
	letter-spacing: 1px;
	margin: 0;
}


#trial .tbl-r02 {
  margin: 0;
	width: 100%;
	font-size:105%;


	border-left: none;
	
}


#trial .tbl-r02 th {

 border-top: dotted 1px #ccc;
  color: #000;
  padding: 20px 10px 15px 20px;
	width: 28%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	
	
}

#trial .tbl-r02 td {
border-top: dotted 1px #ccc;
  padding: 20px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	vertical-align :top;
	
}

#trial .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 0 0 20px 0;
	

}

#trial .tbl-r02 td .txt {
  text-align: left;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 20px 0 20px 0;
}



#trial iframe{
	
	width: 95%;
	height: 300px;
	margin: 10px auto;

	border: 1px dotted #dcdcdc;
	
	padding: 10px;

	

}


#trial .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 0 20px 0;
    width: 45%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 90%;
	float: right;
	letter-spacing: 0.1em;
}

#trial .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#trial .btn a:hover:after {
  right: 1.4rem;
}

#trial .btn2 a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 0 20px 10px;
    width: 40%;
    padding: 10px 15px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 90%;
	float: right;
	letter-spacing: 0.1em;
}

#trial .btn2 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial .btn2 a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#trial .btn2 a:hover:after {
  right: 1.4rem;
}


/* 体験 tab　 */

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

	
#trial #ttl_bg{
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/trial/bg_trial.jpg") no-repeat;
		background-position: right top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}


#trial .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;

	
}


#trial .inner p {
 
	text-align: left;
	font-size: 100%;

  
}


#trial h2{
position: absolute;
	top:150px;
	left: 55px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/trial/h2_trial.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 34%;

}

#trial #subttl{
		position: absolute;
	top:220px;
	left: 56px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#trial h3{
		font-size: 120%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0 0 0;
	border-top: none;

	
}


#trial h4{
	
	margin: 30px 0 15px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;

}

#trial h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
}



#trial .flame_l{

	float:none;
	width: 50%;
	margin: 0;
	
}


#trial .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 10px 0 0 0;
}



#trial table{
  border-bottom: #ccc 1px dotted;
  text-align: center;
  padding: 10px;
	width: 90%;
	letter-spacing: 1px;
	margin: 20px 0;
}



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


#trial .tbl-r02 th {
 border-top: dotted 1px #ccc;
  color: #333;
  padding: 20px 10px 15px 20px;
	width: 33%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	font-size: 98%;
	
	
}

#trial .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 20px;
	border-left: none;
border-right: none;
	text-align: left;
	font-size: 98%;
}


#trial .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 28%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#trial .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#trial .btn a:hover:after {
  right: 1.4rem;
}


}


/* 体験 sp　 */

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

	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/trial/bg_trial_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;


}

#trial .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#trial h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/trial/h2_trial.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 23%;

}

#trial #subttl{
position: absolute;
	top:180px;
	left: 22px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;

	
}

#trial h3{
	font-size: 120%;
	margin: 0 0 10px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0 0 20px 0;
	border-top: none;
	border-bottom: dotted 1px #333;	
	
}


#trial h4{
	
	margin: 30px 0 10px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}




#trial h5{
	
	margin: 10px 0 5px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}


#trial h6{
	
	margin: 20px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}


#trial p {
 
	text-align: left;
	font-size: 100%;
margin: 0 0 20px 0;
	
  
}
	
#trial .flame_l{

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

#trial .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 0;
}



#trial .inner table {
	width: 100%;
	 
	
}


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

#trial .inner .tbl-r02 th {
　　border-bottom: none;
    display: block;
    width: 100%;
	padding: 10px 0 ;
	border: none;
	text-align: left;
	margin: 0;
font-size: 95%;
	background: none;

	
	}


#trial .inner .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 95%;
	padding: 0 ;
	border: none;
	text-align: left;
	margin: 0 0 10px 0;
font-size: 95%;

	
	}
	
	
#trial .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 60%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#trial .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#trial .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#trial .btn a:hover:after {
  right: 1.4rem;
}

  }


/*================================================
 * 受講の流れ：process.html
 ================================================*/

/* 受講の流れ pc　 */

#process {
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#process #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/process/bg_process.jpg") no-repeat;
	background-position: top center;
	background-size:100%;
height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}



#process .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 50px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
}



#process .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#process h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/process/h2_process.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 70%;

}

#process #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#process h3{
	font-size: 140%;
	margin: 20px 0 0 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#process h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}


#process h4{
	
	margin: 50px 0 5px 0;
font-size: 110%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#process h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#process h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}


#process .flame_l{

	float:left;
	width: 28%;

	margin: 0 60px 0 0;
	
}


#process img{

float:left;
	width: 13%;
	margin: 0 30px 0 0;
}





#process .flame_l2{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
	
}


#process .flame_l2 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}

#process .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}



#process .flame_l3{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
}


#process .flame_l3 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}


#process .flame_r3{
	
	width: 64%;
float:right;
	margin: 0 0 80px 0;
	text-align: left;

}

#process .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px auto 5px auto;
    width: 21%;
    padding: 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 90%;
	
	letter-spacing: 0.2em;
}

#process .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#process .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#process .btn a:hover:after {
  right: 1.4rem;
}




/* 受講の流れ tab　 */

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

#process #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/process/bg_process.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 330px;

}



#process .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
}



#process .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#process h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
background:url("../images/process/h2_process.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 55%;

}

#process #subttl{
	position: absolute;
	top:220px;
	left: 58px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#process h3{
	font-size: 170%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#process h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#process h4{
	
	margin: 50px 0 10px 0;
font-size: 115%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#process h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#process h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}


#process .flame_l{

	float:left;
	width: 30%;

	margin: 0 30px 0 0;
	
}


#process .flame_l img{

	
  overflow: hidden;
margin: 0 0 0 -15px;
border-radius: 30px;
	padding: 10px;
	background: #fff;
box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
}


#process .flame_r{
	
	width: 63%;
float:right;
	margin: 0;
	text-align: left;


}


#process .flame_l2{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
	
}


#process .flame_l2 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}


#process .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}



#process .flame_l3{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
}


#process .flame_l3 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}


#process .flame_r3{
	
	width: 64%;
float:right;
	margin: 0 0 80px 0;
	text-align: left;

}

#process .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 5px 10px;
    width:25%;
    padding: 8px 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 85%;
	float: left;
	letter-spacing: 0.1em;
}

#process .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#process .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#process .btn a:hover:after {
  right: 1.4rem;
}

}


/* 受講の流れ sp　 */

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

#process #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/process/bg_process_sp.jpg") no-repeat;
	background-position: top right;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}


#process .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#process .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#process h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/process/h2_process.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 35%;

}

#process #subttl{
	position: absolute;
	top:180px;
	left: 18px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#process h3{
	font-size: 130%;
	margin: 0 0 20px 0;
text-align: left;
	letter-spacing: 0.1em;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#process h3 span{
	font-size: 50%;
	margin: 0 0 30px 0;
text-align: left;	
	
}


#process h4{
	
	margin: 30px 0 10px 0;
font-size: 115%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#process h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#process h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}


#process .flame_l{

	display: none;
	
}


#process .flame_r img{

	
  overflow: hidden;
margin: 0 auto 30px auto;
border-radius: 30px;
	padding: 5px;
	background: #fff;
box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
	width: 90%;
}



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


}



#process .flame_l2{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
	
}


#process .flame_l2 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#process .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}



#process .flame_l3{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
}


#process .flame_l3 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#process .flame_r3{
	
	width: 64%;
float:right;
	margin: 0 0 80px 0;
	text-align: left;

}

#process .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 0 5px 0;
    width:93%;
    padding: 8px 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 85%;
	float: none;
	letter-spacing: 0.1em;
}

#process .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#process .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#process .btn a:hover:after {
  right: 1.4rem;
}
}

/*================================================
 * 講師：coach.html
 ================================================*/

/* 講師：pc　 */

#coach {
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#coach #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/coach/bg_coach.jpg") no-repeat;
	background-position: top center;
	background-size:100%;
height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}



#coach .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 50px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
}



#coach .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#coach h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/coach/h2_coach.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 70%;

}

#coach #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#coach h3{
	font-size: 170%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#coach h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#coach h4{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#coach h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#coach h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}



#coach .flame_l{

	float:left;
	width: 28%;

	margin: 18px 30px 0 0;
	
}


#coach .flame_l img{

  overflow: hidden;
margin: 0 0 0 0;
border-radius: 50px;
}



#coach .flame_r{
	
	width: 65%;
float:right;
	margin: 0;
	text-align: left;


}



#coach .flame_l2{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
	
}


#coach .flame_l2 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#coach .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}



#coach .flame_l3{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
}


#coach .flame_l3 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#coach .flame_r3{
	
	width: 64%;
float:right;
	margin: 0 0 80px 0;
	text-align: left;

}

#coach .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 5px 10px;
    width: 21%;
    padding: 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 90%;
	float: left;
	letter-spacing: 0.1em;
}

#coach .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#coach .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#coach .btn a:hover:after {
  right: 1.4rem;
}




/* お問い合わせ：tab　 */

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

#coach #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/coach/bg_coach.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 330px;

}



#coach .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
}



#coach .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#coach h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
background:url("../images/coach/h2_coach.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 55%;

}

#coach #subttl{
	position: absolute;
	top:230px;
	left: 66px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#coach h3{
	font-size: 170%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#coach h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#coach h4{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#coach h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#coach h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}



#coach .flame_l{

	float:left;
	width: 30%;

	margin: 0 30px 0 0;
	
}


#coach .flame_l img{

	
  overflow: hidden;
margin: 0 0 0 -15px;
border-radius: 30px;
	padding: 10px;
	background: #fff;
box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
}



#coach .flame_r{
	
	width: 63%;
float:right;
	margin: 0;
	text-align: left;


}



#coach .flame_l2{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
	
}


#coach .flame_l2 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#coach .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}



#coach .flame_l3{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
}


#coach .flame_l3 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#coach .flame_r3{
	
	width: 64%;
float:right;
	margin: 0 0 80px 0;
	text-align: left;

}

#coach .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 5px 5px 10px;
    width:25%;
    padding: 8px 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 85%;
	float: left;
	letter-spacing: 0.1em;
}

#coach .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#coach .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#coach .btn a:hover:after {
  right: 1.4rem;
}

}


/* お問い合わせ sp　 */

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

#coach #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/coach/bg_coach_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}



#coach .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}



#coach .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#coach h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/coach/h2_coach.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 30%;

}

#coach #subttl{
	position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#coach h3{
	font-size: 150%;
	margin: 0 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#coach h3 span{
	font-size: 50%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#coach h4{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#coach h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#coach h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}



#coach .flame_l{

	display: none;
	
}


#coach .flame_r img{

	
  overflow: hidden;
margin: 0 auto 30px auto;
border-radius: 30px;
	padding: 5px;
	background: #fff;
box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
	width: 90%;
}



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


}



#coach .flame_l2{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
	
}


#coach .flame_l2 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#coach .flame_r2{
	
	width: 64%;
float:right;
	margin: 0 0 50px 0;
	text-align: left;

}



#coach .flame_l3{

	float:left;
	width: 28%;

	margin: 0 30px 0 0;
}


#coach .flame_l3 img{

	padding: 0;

	
	
	border: solid 6px #e1edbc;    	/* 内側の線になる一本線の枠線をひく*/
	outline: solid 5px #000;    /* 外側の線になる5pxの一本線の枠線をひく*/
	outline-offset: 3px;        /* 内側の線になる一本線の枠線をひく*/
	border-radius: 10px;

	
}



#coach .flame_r3{
	
	width: 64%;
float:right;
	margin: 0 0 80px 0;
	text-align: left;

}

#coach .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px 0 5px 0;
    width:93%;
    padding: 8px 10px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	 font-size: 85%;
	float: none;
	letter-spacing: 0.1em;
}

#coach .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#coach .btn a:hover {
  background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#coach .btn a:hover:after {
  right: 1.4rem;
}
}

/*================================================
 * よくあるご質問：faq.html
 ================================================*/

/* 講師：pc　 */

#faq {
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#faq #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/company/bg_company.jpg") no-repeat;
	background-position: top center;
	background-size:100%;
height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}



#faq .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 50px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
}



#faq .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#faq h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/faq/h2_faq.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 35%;

}

#faq #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#faq h3{
	font-size: 140%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#faq h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#faq h4{
	
	margin: 10px 0 10px 0;
font-size: 110%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#faq h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#faq h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}




/* お問い合わせ：tab　 */

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

#faq #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
background:url("../images/company/bg_company.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 330px;

}


#faq .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
}


#faq .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#faq h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
background:url("../images/faq/h2_faq.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 25%;

}

#faq #subttl{
	position: absolute;
	top:225px;
	left: 58px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#faq h3{
	font-size: 130%;
	margin: 20px 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#faq h3 span{
	font-size: 70%;
	margin: 0 0 30px 0;
text-align: left;	
	
}



#faq h4{
	
	margin: 20px 0 10px 0;
font-size: 110%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#faq h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#faq h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}




}


/* お問い合わせ sp　 */

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

#faq #ttl_bg{
font-family: 'Quicksand', sans-serif;
	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/company/bg_company_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}



#faq .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}



#faq .inner p {
 
	text-align: left;
	font-size: 100%;
	margin: 0 0 25px 0;
	line-height: 1.6;

	
	
  
}


#faq h2{
position: absolute;
	top:130px;
	left: 22px;
	
	margin: 0;


padding: 40px 0;
	background:url("../images/faq/h2_faq.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 20%;

}

#faq #subttl{
	position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#faq h3{
	font-size: 130%;
	margin: 0 0 20px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	color:#7a6b5c;
	width: auto;
	padding: 0;
	
	
}

#faq h3 span{
	font-size: 50%;
	margin: 0 0 30px 0;
text-align: left;	
	
}


#faq h4{
	
	margin: 0 0 10px 0;
font-size: 100%;
	letter-spacing: 1px;
color:#7a6b5c;
	padding: 0;
	text-align: left;

}

#faq h5{
	
	margin: 0 0 5px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

#faq h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	padding: 0;
	color:#7a6b5c;
	
}

}

/*================================================
 *  クリックで開閉：よくあるご質問
 ================================================*/

/*ベース*/
.toggle {
	display: none;
}
.Label {		/*タイトル*/
	padding: 50px 0 0 0;
	display: block;
	color: #333;
	border-top:2px dotted #c0c0c0; 
	width: 100%;
	margin: 0;

	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: 20px 0 0 0;
	background: none;
}
.content {		/*本文*/
	height: 0;
	margin-bottom:10px;
	padding:0;
	overflow: hidden;
	font-size: 100%;
}


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


/*================================================
 * 会社概要：#company.html
 ================================================*/

/* 会社概要 pc　 */

#company {
	
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#company #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/company/bg_company.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}




#company .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}



#company .inner p {
 
	text-align: left;
	font-size: 105%;
	margin: 0 0 25px 0;
	line-height: 1.6;

}


#company h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/company/h2_company.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 84%;

}

#company #subttl{
		position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#company h3{
	font-size: 130%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.0em;
	color:#7a6b5c;
	width: auto;
	padding: 20px 0;
	border-top: 1px solid #333;

	
}



#company h4{
	margin: 0 0 5px 0;
font-size: 100%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
color:#7a6b5c;
}

#company h5{
	
	margin: 0 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}




#company .flame_l{

	float:left;
	width: 20%;

	margin: 0 30px 0 0;
	
}


#company .flame_r{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 0 0 0 0;
}



#company table{
 
  text-align: center;
  padding: 10px;
	width: 95%;
	letter-spacing: 1px;
	margin: 0;
}



#company .tbl-r02 {
  margin: 0;
	width: 100%;
	font-size:105%;


	border-left: none;
	
}


#company .tbl-r02 th {

 border-top: dotted 1px #ccc;
  color: #000;
  padding: 20px 10px 15px 20px;
	width: 28%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	
	
}

#company .tbl-r02 td {
border-top: dotted 1px #ccc;
  padding: 20px 30px;
	border-left: none;
border-right: none;
	text-align: left;
	vertical-align :top;
	
}

#company .tbl-r02 td p {
	
	text-align: left;
	font-size: 100%;
	letter-spacing: 0.1em;
	

}


#company iframe{
	
	width: 95%;
	height: 300px;
	margin: 10px auto;

	border: 1px dotted #dcdcdc;
	
	padding: 10px;

	

}


#company .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 25%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#company .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#company .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#company .btn a:hover:after {
  right: 1.4rem;
}



/* 会社概要 tab　 */

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

	


#company #ttl_bg{
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/company/bg_company.jpg") no-repeat;
		background-position: right top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}


#company .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;

	
}



#company h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/company/h2_company.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 58%;

}

#company #subttl{
		position: absolute;
	top:220px;
	left: 61px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}


#company h3{
		font-size: 120%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0 0 0;
	border-top: none;

	
}



#company h4{
	margin: 0 0 5px 0;
font-size: 100%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
color:#7a6b5c;

}

#company h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
}



#company .flame_l{

	float:none;
	width: 50%;
	margin: 0;
	
}


#company .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 10px 0 0 0;
}



#company table{
  border-bottom: #ccc 1px dotted;
  text-align: center;
  padding: 10px;
	width: 90%;
	letter-spacing: 1px;
	margin: 20px 0;
}



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


#company .tbl-r02 th {
 border-top: dotted 1px #ccc;
  color: #333;
  padding: 20px 10px 15px 20px;
	width: 33%;
	border-left: none;
	border-right: none;
	text-align: left;
vertical-align :top;
	font-size: 98%;
	
	
}
#company .tbl-r02 td {
border: dotted 1px #ccc;
  padding: 15px 20px;
	border-left: none;
border-right: none;
	text-align: left;
	font-size: 98%;
	vertical-align :top;
}


#company .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 28%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#company .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#company .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#company .btn a:hover:after {
  right: 1.4rem;
}


}


/* 会社概要 sp　 */

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

	position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/company/bg_company_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;


}

#company .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#company h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/company/h2_company.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 42%;

}

#company #subttl{
position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;

	
}

#company h3{
	font-size: 120%;
	margin: 0 0 10px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0 0 20px 0;
	border-top: none;
	border-bottom: dotted 1px #333;	
	
}


#company h4{
	
margin: 0 0 0 0;
font-size: 110%;
	letter-spacing: 0.1em;

	padding: 0;
	text-align: left;
color:#7a6b5c;
}




#company h5{
	
	margin: 10px 0 5px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}


#company h6{
	
	margin: 20px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}


#company p {
 
	text-align: left;
	font-size: 100%;
margin: 0 0 20px 0;
	
  
}
	
#company .flame_l{

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

#company .flame_r{
width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: none;
	padding: 0;
}



#company .inner table {
	width: 100%;
	 
	
}


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

#company .inner .tbl-r02 th {
　　border-bottom: none;
    display: block;
    width: 100%;
	padding: 10px 0 ;
	border: none;
	text-align: left;
	margin: 0;
font-size: 95%;
	background: none;

	
	}


#company .inner .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 95%;
	padding: 0 ;
	border: none;
	text-align: left;
	margin: 0 0 10px 0;
font-size: 95%;

	
	}
	
	
#company .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 60%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#company .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#company .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#company .btn a:hover:after {
  right: 1.4rem;
}

  }


/*================================================
 * プライバシーポリシー：privacy.html
 ================================================*/

/* プライバシーポリシー pc */

#privacy {
		position: relative;
  overflow: hidden;
 margin: 0;
	

}

#privacy #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/company/bg_company.jpg") no-repeat;
	background-position: left top;
	background-size:100%;
	height:400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}



#privacy .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}



#privacy.inner p {
 
	text-align: left;
	font-size: 105%;
	margin: 0 0 25px 0;
	line-height: 1.6;

}


#privacy h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 600px;

padding: 50px 0;
	background:url("../images/privacy/h2_privacy.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 100%;

}

#privacy #subttl{
position: absolute;
	top:274px;
	left: 83px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}

#privacy h3{
	font-size: 120%;
	margin: 0 0 0 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0;

	
	
}



#privacy h4{
	
	margin: 30px 0 10px 0;
font-size: 120%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;

}

#privacy h5{
	
	margin: 5px 0;
font-size: 110%;
	letter-spacing:0.5px;

	padding: 0;
color: #333;
	
}


#privacy h6{
	
	margin: 40px 0 10px 0;
font-size: 110%;
	letter-spacing:0.5px;

	padding: 0;
	color: #333;
	
}




#privacy .inner img{
  

	margin: 30px 30px 30px 0;
	
	

}

#privacy #menu {
	
	margin: 30px auto 0 auto ;
	width: auto;

	
}

#privacy #menu ul li{

	padding: 6px 10px;
margin: 0 15px 10px 0;
	float: left;
width: auto;
	border-radius: 10px;
	border: 2px solid #ccc;
text-align: center;
	
}

#privacy #menu ul li a{

	font-weight: bold;
	font-size: 100%;
color: #333;
	letter-spacing: 0.1em;
	


}

#privacy #menu ul li a:hover{



	color: #333;
	width: auto;
opacity: 0.7;

	
}


#privacy #list {
	
	margin: 20px 0 0 0 ;
	width: auto;


	text-align: left;
	color: #333;
	

	
}

#privacy #list ul{
	

}

#privacy #list ul li{
  
border: none;
	
	height: auto;
	list-style-type: none;
	
	padding: 0;
	margin: 0 0 20px 0;

	

}


#privacy #policy  {
	
	margin: -20px auto 0 auto ;
	width: auto;
padding: 30px 0 0 0;
	text-align: left;
	color: #333;

	
}


#privacy #policy h3 {
 

	margin: 40px 0 15px 0;
text-align: left;

	
  
}





#privacy #policy p {
 
	font-size: 96%;
	margin: 0 0 20px 0;
text-align: left;

  
}

#privacy #policy .text_w{
	
	column-count: 2;
}




#privacy #policy ul{
	
	margin: 0 0 20px 0;

}

#privacy #policy ul li{
  
border: none;
	
	height: auto;
	list-style-type: disc;
	
	padding: 0;
	margin: 0 0 2px 20px;

	

}



#privacy .kaiji ul {

	margin-top: -10px;

	

}

#privacy .kaiji ul li{
  
border: none;
	
	height: auto;
	list-style-type: disc;
	
	padding: 0;
	margin: 0 0 2px 20px;

	

}

#privacy .kaiji img{

	
	padding: 0;
	margin: 0 0 0 0;
	width: 100px;
	height: 11px;

}
#privacy .flame_r{
	
	margin: 40px 0 30px 0;
font-size: 90%;
	width: auto;

	padding: 20px 50px 30px 50px;

	background:#fff;
	border-radius: 20px;
	box-shadow: 4px 4px 4px #d3d3d3;
-webkit-box-shadow: 4px 4px 4px #d3d3d3;
-moz-box-shadow: 4px 4px 4px #d3d3d3;
	border-left:1px solid #f5f5f5; 
	border-top:1px solid #f5f5f5; 

	
}


/* プライバシーポリシー tab　 */

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


#privacy #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/company/bg_company.jpg") no-repeat;
		background-position: right top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}


#privacy .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 50px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;

	
}


#privacy .inner p {
 
	text-align: left;
	font-size: 100%;

  
}


#privacy h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 600px;

padding: 25px 0;
	background:url("../images/privacy/h2_privacy.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 75%;


}

#privacy #subttl{
position: absolute;
	top:221px;
	left: 59px;
	font-size: 115%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}

#privacy h3{
	font-size: 120%;
	margin: 0 0 0 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0;

	
	
}



#privacy h4{
	
		margin: 30px 0 10px 0;
font-size: 120%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
}




#privacy h5{
	
	margin: 20px 0 5px 0;
font-size: 115%;
	letter-spacing:0.5px;
	padding: 0;
	color: #000;
	
}






#privacy #menu {
	
		margin: 30px auto 0 auto ;
	width: auto;

	
}

#privacy #menu ul li{

padding: 6px 8px;
margin: 0 5px 10px 0;
	float: left;
width: auto;
	border-radius: 10px;
	border: 2px solid #ccc;
text-align: center;
	
}

#privacy #menu ul li a{

	font-weight: bold;
	font-size: 93%;
color: #333;
	


}

#privacy #menu ul li a:hover{



	color: #333;
	width: auto;
opacity: 0.7;

	
}


#privacy #list {
	
	margin: 20px 0 0 0 ;
	width: auto;


	text-align: left;
	color: #333;
	

	
}

#privacy #list ul{
	

}

#privacy #list ul li{
  
border: none;
	
	height: auto;
	list-style-type: none;
	
	padding: 0;
	margin: 0 0 20px 0;

	

}


#privacy #policy  {
	
	margin: -20px auto 0 auto ;
	width: auto;
padding: 30px 0 0 0;
	text-align: left;
	color: #333;

	
}


#privacy #policy h3 {
 

	margin: 40px 0 15px 0;
text-align: left;

	
  
}





#privacy #policy p {
 
	font-size: 96%;
	margin: 0 0 20px 0;
text-align: left;

  
}

#privacy #policy .text_w{
	
	column-count: 2;
}




#privacy #policy ul{
	
	margin: 0 0 20px 0;

}

#privacy #policy ul li{
  
border: none;
	
	height: auto;
	list-style-type: none;
	
	padding: 0;
	margin: 0 0 2px 0;

	

}



#privacy .kaiji ul {

	margin-top: -10px;

	

}

#privacy .kaiji ul li{
  
border: none;
	
	height: auto;
	list-style-type: disc;
	
	padding: 0;
	margin: 0 0 2px 20px;

	

}

#privacy .kaiji img{

	
	padding: 0;
	margin: 0 0 0 0;
	width: 100px;
	height: 11px;

}
#privacy .flame_r{
	
	margin: 40px 0 30px 0;
font-size: 90%;
	width: auto;

	padding: 20px 50px 30px 50px;

	background:#fff;
	border-radius: 20px;
	box-shadow: 4px 4px 4px #d3d3d3;
-webkit-box-shadow: 4px 4px 4px #d3d3d3;
-moz-box-shadow: 4px 4px 4px #d3d3d3;
	border-left:1px solid #f5f5f5; 
	border-top:1px solid #f5f5f5; 

	
}

}


/* プライバシーポリシー：sp　 */

@media screen and (max-width:767px) {
#privacy #ttl_bg{
position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
	background:url("../images/company/bg_company_sp.jpg") no-repeat;
	background-position: top right;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}


#privacy .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#privacy .inner p {
 
text-align: left;
	font-size: 100%;
	margin: 0 0 15px 0;
	line-height: 1.6;
}


#privacy h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/privacy/h2_privacy.png") no-repeat;

  /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 46%;


}

#privacy #subttl{
position: absolute;
	top:175px;
	left: 18px;
	font-size: 100%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}

#privacy h3{
	font-size: 120%;
	margin: 0 0 0 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0;

	
	
}



#privacy h4{
	
		margin: 30px 0 10px 0;
font-size: 120%;
	letter-spacing: 1px;

	padding: 0;
	text-align: left;
}




#privacy h5{
	
	margin: 20px 0 5px 0;
font-size: 115%;
	letter-spacing:0.5px;
	padding: 0;
	color: #333;
	
}






#privacy #menu {
	
		display: none;

	
}

#privacy #menu ul li{

padding: 6px 8px;
margin: 0 5px 10px 0;
	float: left;
width: auto;
	border-radius: 10px;
	border: 2px solid #ccc;
text-align: center;
	
}

#privacy #menu ul li a{

	font-weight: normal;
	font-size: 90%;
color: #333;
	


}

#privacy #menu ul li a:hover{



	color: #333;
	width: auto;
opacity: 0.7;

	
}


#privacy #list {
	
	margin: 20px 0 0 0 ;
	width: auto;


	text-align: left;
	color: #333;
	

	
}

#privacy #list ul{
	

}

#privacy #list ul li{
  
border: none;
	
	height: auto;
	list-style-type: none;
	
	padding: 0;
	margin: 0 0 20px 0;

	

}


#privacy #policy  {
	
	margin: -20px auto 0 auto ;
	width: auto;
padding: 30px 0 0 0;
	text-align: left;
	color: #333;

	
}


#privacy #policy h3 {
 

	margin: 40px 0 15px 0;
text-align: left;

	
  
}





#privacy #policy p {
 
	font-size: 96%;
	margin: 0 0 20px 0;
text-align: left;

  
}

#privacy #policy .text_w{
	
	column-count: 2;
}




#privacy #policy ul{
	
	margin: 0 0 20px 0;

}

#privacy #policy ul li{
  
border: none;
	
	height: auto;
	list-style-type: none;
	
	padding: 0;
	margin: 0 0 2px 0;

	

}



#privacy .kaiji ul {

	margin-top: -10px;

	

}

#privacy .kaiji ul li{
  
border: none;
	
	height: auto;
	list-style-type: disc;
	
	padding: 0;
	margin: 0 0 2px 20px;

	

}

#privacy .kaiji img{

	
	padding: 0;
	margin: 0 0 0 0;
	width: 100px;
	height: 11px;

}
#privacy .flame_r{
	
	margin: 40px 0 30px 0;
font-size: 90%;
	width: auto;

	padding: 20px 50px 30px 50px;

	background:#fff;
	border-radius: 20px;
	box-shadow: 4px 4px 4px #d3d3d3;
-webkit-box-shadow: 4px 4px 4px #d3d3d3;
-moz-box-shadow: 4px 4px 4px #d3d3d3;
	border-left:1px solid #f5f5f5; 
	border-top:1px solid #f5f5f5; 

	
}
}


/*================================================
 * お問い合わせ：contact.html
 ================================================*/

/* お問い合わせ pc　 */

#contact {
	
	position: relative;
  overflow: hidden;
 margin: 0;
	

}

#contact #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/contact/bg_contact.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;

}






#contact .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}



#contact .inner p {
 
	text-align: left;
	font-size: 105%;
	margin: 0 0 25px 0;
	line-height: 1.6;

}



#contact h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/contact/h2_contact.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 80%;

}

#contact #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}




#contact h3{
	font-size: 120%;
	margin: 0 0 0 0;
text-align: left;
	letter-spacing: 3px;
color:#7a6b5c;
	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0;
	border-top: 1px solid #333;
	
}






#contact h4{
	
	margin: 30px 0 15px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#contact h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#contact h6{
	
	margin: 0 0 5px 0;
font-size: 105%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#contact .flame_l{

	float:left;
	width: 20%;

	margin: 0 30px 0 0;
	
}


#contact .flame_r{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 30px 0 0 0;
}

#contact .flame_r2{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
	border-top: 1px solid #333;
	padding: 0;
}


/* お申し込み（個人情報の取扱い・携帯）*/

#contact .flame_l2{

	float:left;
	width: 46%;

	margin: 0 0 0 30px;
}






#contact table{

  text-align: center;
  padding: 10px;
	width: 90%;
	letter-spacing: 1px;
	margin: 50px 0 0 0;
	border-top: none;
	border-bottom: none;
}



#contact .tbl-r02 {
  margin: 80px 0 0 0 ;
	width: 100%;
	font-size:105%;
border: none;

	border-left: none;

	
}


#contact .tbl-r02 th {
font-weight: bold;

  color: #333;
  padding: 15px 10px 15px 0;
	width: 28%;
	border-left: none;
	border-right: none;
	text-align: left;

	
	
}
#contact .tbl-r02 td {

  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: center;

}

#contact .tbl-r02 td p {
	
	text-align: center;
	font-size: 100%;
	letter-spacing: 1.5px;
	margin: 20px 0 0 0;


}


#contact iframe{
	
	width: 100%;
	height: 200px;
	margin: 10px auto;
padding: 10px 0 0 0;
}

#contact #submit a {
      display       : inline-block;
  border-radius : 5%;          /* 角丸       */
  font-size     : 18pt;        /* 文字サイズ */
  text-align    : center;      /* 文字位置   */
  cursor        : pointer;     /* カーソル   */
  padding       : 12px 12px;   /* 余白       */
  background    : #000066;     /* 背景色     */
  color         : #ffffff;     /* 文字色     */
  line-height   : 1em;         /* 1行の高さ  */
  transition    : .3s;         /* なめらか変化 */
  box-shadow    : 6px 6px 3px #666666;  /* 影の設定 */
  border        : 2px solid #000066;    /* 枠の指定 */
	border-style: solid;
}


#contact #submit a:hover {
  box-shadow    : none;        /* カーソル時の影消去 */
  color         : #000066;     /* 背景色     */
  background    : #ffffff;     /* 文字色     */
}



/* お問い合わせ tab　 */

@media screen and (min-width:768px) and (max-width:959px) {
#contact #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/contact/bg_contact.jpg") no-repeat;
	background-position: top left;
	background-size:100%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 330px;
}

#contact .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
	
}


#contact .inner p {
 
	text-align: left;
	font-size: 110%;

  
}


#contact h2{
	
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/contact/h2_contact.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 55%;
}

#contact #subttl{
	position: absolute;
	top:220px;
	left: 61px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}



#contact h3{
font-size: 120%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 20px 0;
	border-top: none;
	
	
}






#contact h4{
	margin: 30px 0 15px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#contact h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
}
	
	
#contact h6{
	
		margin: 0 0 5px 0;
font-size: 105%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#contact .flame_l{

	float:none;
	width: 50%;
	margin: 0 0 10px 0;;
	
}


#contact .flame_r{
	
	width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 30px 0 0 0;
}

#contact .flame_r2{
	
	width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
	border-top: 1px solid #333;
	padding: 0;
}


#contact iframe{
	
		width: 100%;
	height: 200px;
	margin: 10px auto;
padding: 10px 0 0 0;
	
	
}


#contact table {
  margin: 50px 0;
	width: 98%;
	font-size:105%;
	border-top: none;

	border-left: none;
	
}


#contact .tbl-r02 table {
  margin: 0 0 80px 0;
	width: 98%;
	font-size:105%;
	border:none;
	
	
}


#contact .tbl-r02 th {
font-weight: bold;
 border:none;
  color: #000;
  padding: 15px 10px 15px 10px;
	width: 40%;
	border-left: none;
	border-right: none;
	text-align: left;

	
	
}
#contact .tbl-r02 td {
border:none;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: center;
	
}

#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 0 30px auto;
background:url("../images/contact/bg_contact_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;
}






#contact .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 50px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
	
}



#contact .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#contact h2{
	
position: absolute;
	top:130px;
	left: 40px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/contact/h2_contact.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 30%;
}

#contact #subttl{
	position: absolute;
	top:180px;
	left: 40px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;

	
}



#contact h3{
	font-size: 120%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	border: none;
	
	
}






#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_l{

	float:none;
	width: 50%;
	margin: 0 0 10px 0;;
	
}


#contact .flame_r{
	
	width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 30px 0 0 0;
}

#contact .flame_r2{
	
	width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
	border-top: 1px solid #333;
	padding: 0;
}


#contact iframe{
	
		width: 100%;
	height: 200px;
	margin: 10px auto;
padding: 10px 0 0 0;
	
	
}


#contact table {
  margin: 50px 0;
	width: 98%;
	font-size:105%;
	border-top: none;

	border-left: none;
	
}


#contact .tbl-r02 table {
  margin: 0 0 80px 0;
	width: 98%;
	font-size:105%;
	border:none;
	
	
}


#contact .tbl-r02 th {
font-weight: bold;
 border:none;
  color: #000;
  padding: 15px 10px 15px 10px;
	width: 40%;
	border-left: none;
	border-right: none;
	text-align: left;

	
	
}
#contact .tbl-r02 td {
border:none;
  padding: 15px 30px;
	border-left: none;
border-right: none;
	text-align: center;
	
}

#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 0 30px auto;
background:url("../images/contact/bg_contact_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;
}






#contact .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 0 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
	
}



#contact .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}


#contact h2{
	
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/contact/h2_contact.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 40%;
}

#contact #subttl{
	position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
	
	
}



#contact h3{
	font-size: 130%;
	margin: 0 0 10px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	border: none;
	
	
}






#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_l{

	float:none;
	width: auto;
	margin: 0 0 10px 0;;
	
}



#contact table {
  margin: 50px 0;
	width: 98%;
	font-size:105%;
	

	border: none;
	
}
	


#contact .inner table {
	width: 98%;
	 
	
}


#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: 98%;
	padding: 0;
	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;
}

/*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{
	
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/reserve/bg_reserve.jpg") no-repeat;
	background-position: left top;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;
}



#reserve .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}


#reserve .inner p {
 
	text-align: left;
	font-size: 100%;

	
	
  
}


#reserve h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/reserve/h2_reserve.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 74%;

}

#reserve #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}



#reserve h3{
	
			font-size: 120%;
	margin: 0 0 0 0;
text-align: left;
	letter-spacing: 3px;
color:#7a6b5c;
	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0;
	border-top: 1px solid #333;
	
}



#reserve h4{
	
	margin: 30px 0 15px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#reserve h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#reserve h6{
	
	margin: 0 0 5px 0;
font-size: 105%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#reserve .flame_l{

	float:left;
	width: 20%;

	margin: 0 30px 0 0;
	
}


#reserve .flame_r{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 30px 0 0 0;
}

#reserve .flame_r2{
	
	width: 75%;
float:left;
	margin: 0 0 50px 0;
	text-align: left;
	border-top: 1px solid #333;
	padding: 0;
}


#reserve iframe{
	
		width: 100%;
	height: 200px;
	margin: 10px auto;
padding: 10px 0 0 0;
	
	
}







#reserve .tbl-r02 {
  margin:40px 0;
	width: 100%;
	font-size:100%;


	border-left: none;
	
}


#reserve .tbl-r02 th {
font-weight: bold;

  color: #333;
  padding: 15px 10px 15px 0;
	width: 32%;
	border-left: none;
	border-right: none;
	text-align: left;

	
	
}
#reserve .tbl-r02 td {

  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;
	

}

#reserve .short {
	
	margin: 0;
	width: 18%;

}



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;

}


.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 0 0 auto;
	background:url("../images/reserve/bg_reserve.jpg") no-repeat;
	background-position: left top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}



#reserve .inner p {
 
	text-align: left;
	font-size: 110%;

	
	
  
}

#reserve .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
	
}


#reserve .inner p {
 
	text-align: left;
	font-size: 100%;

	
	
  
}


#reserve h2{
position: absolute;
	top:150px;
	left: 60px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/reserve/h2_reserve.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 50%;

}

#reserve #subttl{
	position: absolute;
	top:220px;
	left: 58px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}



#reserve h3{
	
		font-size: 120%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 20px 0;
	border-top: none;
	
}



#reserve h4{
	
	margin: 30px 0 5px 0;
font-size: 120%;
	letter-spacing: 1px;
	font-weight: bold;
	padding: 0;
	text-align: left;
}

#reserve h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#reserve h6{
	
	margin: 0 0 5px 0;
font-size: 105%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#reserve .flame_l{

	float:none;
	width: 50%;
	margin: 0 0 10px 0;
	
}


#reserve .flame_r{
	
	width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
border-top: 1px solid #333;
	padding: 30px 0 0 0;
}

#reserve .flame_r2{
	
	width: auto;
float:none;
	margin: 0 0 50px 0;
	text-align: left;
	border-top: 1px solid #333;
	padding: 0;
}


#reserve iframe{
	
		width: 100%;
	height: 200px;
	margin: 10px auto;
padding: 10px 0 0 0;
	
	
}










#reserve .tbl-r02 table {
  margin:  0;
	width: 98%;
	font-size:105%;


	border-left: none;
	
	
}


#reserve .tbl-r02 th {
font-weight: bold;

  color: #000;
  padding: 15px 10px 15px 10px;
	width: 35%;
	border-left: none;
	border-right: none;
	text-align: left;


	
	
}
#reserve .tbl-r02 td {

  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 img {
	
	margin: 0 20px 0 0;
	width: 15%;
	float: left;

}

	
.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 0 30px auto;
	background:url("../images/reserve/bg_reserve_sp.jpg") no-repeat;
	background-position: center top;
	background-size:170%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}



#reserve .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 30px 5% 0 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
	
}


#reserve .inner p {
 
	text-align: left;
	font-size: 100%;

	
	
  
}


#reserve h2{
position: absolute;
	top:130px;
	left: 22px;
	
	margin: 0;

padding: 50px 0;
	background:url("../images/reserve/h2_reserve.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 37%;

}

#reserve #subttl{
	position: absolute;
	top:180px;
	left: 20px;
	font-size: 110%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}



#reserve h3{
	
	font-size: 120%;
	margin: 0 0 10px 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	border: none;
	
}



#reserve h4{
	
		margin: 30px 0 15px 0;
font-size: 110%;
	letter-spacing: 0.1em;

	padding: 0;
	text-align: left;
}

#reserve h5{
	
	margin: 0 0 10px 0;
font-size: 115%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}

#reserve h6{
	
	margin: 0 0 5px 0;
font-size: 105%;
	letter-spacing:0.5px;
	font-weight: bold;
	padding: 0;
	color: #333;
	
}


#reserve p {
 
	text-align: left;
	font-size: 110%;
	
  
}

#reserve .flame_l{

	float:none;
	width: auto;
	margin: 0 0 10px 0;;
	
}
	
#reserve .flame_r{

	float:none;
	width: auto;
	margin: 0 0 10px 0;;
	
}

#reserve .flame_l2{

	float:none;
	width: auto;
	margin: 0 0 10px 0;
	
}
	
#reserve .flame_r2{

	float:none;
	width: auto;
	margin: 0 0 10px 0;;
	
}	
#reserve iframe{
	
		width: 100%;
	height: 200px;
	margin: 10px auto;
padding: 10px 0 20px 0;
	
	
}

#reserve.inner table {
	width: 97%;
	 border: none;
	
}


#reserve .inner .tbl-r02 {
   width: 97%;
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;


	
		
  }

#reserve .short {
	
	margin: 0;
	width: 20%;

}
	
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 img {
	
	margin: 0 20px 0 0;
	width: 29%;
	float: left;

}

	
	
.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;
}




#thanks #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/thanks/bg_thanks.jpg") no-repeat;
	background-position: left bottom;
	background-size:100%;
	height: 400px;
	border-radius: 0 0 0 80px;
	width: 76%;
}



#thanks .inner {

margin: 50px auto 80px 0;

	background: #fff;
	padding: 80px 6% 50px 10%;
	border-radius: 0 50px 50px 0;
	
}



#thanks .inner p {
 
	text-align: left;
	font-size: 105%;
	margin: 0 0 25px 0;
	line-height: 1.6;

}


#thanks h2{
position: absolute;
	top:180px;
	left: 80px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/thanks/h2_thanks.svg") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 52%;

}

#thanks #subttl{
	position: absolute;
	top:280px;
	left: 86px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
}



#thanks h3{
	
		font-size: 170%;
	margin: 0 0 30px 0;
text-align: left;
	letter-spacing: 3px;
color: #715c42;
	line-height: 1.1em;
	
	width: auto;
	padding: 0;
}

#thanks h4{
	
	margin: 50px 0 10px 0;
font-size: 140%;
	letter-spacing: 0.1em;
color: #715c42;
	padding: 0;
	text-align: left;
}

#thanks h5{
	
	margin: 50px 0 10px 0;
font-size: 130%;
	letter-spacing:0.5px;
	padding: 0;
	color: #715c42;
	
}



#thanks h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	padding: 0;
	
}


#thanks .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 25%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#thanks .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#thanks .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#thanks .btn a:hover:after {
  right: 1.4rem;
}


/* サンクスページ tab*/

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



#thanks #ttl_bg{
	
	position: relative;
  overflow: hidden;
  	  margin:0 0 0 auto;
	background:url("../images/thanks/bg_thanks.jpg") no-repeat;
	background-position: left top;
	background-size:100%;
	border-radius: 0 0 0 80px;
		width: 80%;
	height: 330px;

}



#thanks .inner {
margin: 50px auto 80px 0;

	background: #fff;
	padding: 30px 6% 50px 7%;
	border-radius: 0 50px 50px 0;
	width: 81%;
}


#thanks .inner p {
 
	text-align: left;
	font-size: 100%;

	
	
  
}



#thanks h2{
position: absolute;
	top:150px;
	left: 55px;
	
	margin: 0;
width: 500px;

padding: 50px 0;
	background:url("../images/thanks/h2_thanks.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 35%;
}

#thanks #subttl{
		position: absolute;
	top:230px;
	left: 61px;
	font-size: 120%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 3px;

	line-height: 1em;

	color: #333;
	
	
}


#thanks h3{
	
	font-size: 130%;
	margin: 0;
text-align: left;
	letter-spacing: 3px;

	line-height: 1.1em;
	
	width: auto;
	padding: 30px 0;
	border-top: none;
}

#thanks h4{
	

	margin: 30px 0 10px 0;
font-size: 120%;
	letter-spacing: 1px;
	padding: 0;
	text-align: left;
}

#thanks h5{
	
	
	margin: 30px 0 10px 0;
font-size: 120%;
	letter-spacing: 0.1em;
	padding: 0;
	text-align: left;
	
}


#thanks .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 25%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#thanks .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#thanks .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#thanks .btn a:hover:after {
  right: 1.4rem;
}


}


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

#thanks #ttl_bg{
	
		position: relative;
  overflow: hidden;
  	  margin:0 0 30px auto;
background:url("../images/thanks/bg_thanks_sp.jpg") no-repeat;
	background-position: top center;
	background-size:150%;
	border-radius: 0 0 0 80px;
	width: 80%;
	height: 280px;

}



#thanks .inner {
margin: 30px auto 80px 0;

	background: #fff;
	padding: 40px 5% 30px 5%;
	border-radius: 0 50px 50px 0;
	width: 85%;
}


#thanks .inner p {
 
	text-align: left;
	font-size: 100%;

	
	
  
}



#thanks h2{
position: absolute;
	top:130px;
	left: 20px;
	
	margin: 0;


padding: 50px 0;
	background:url("../images/thanks/h2_thanks.png") no-repeat;
	
	 /* 画像を常に天地左右の中央に配置 */
  background-position: left top;
	background-size: 25%;
}

#thanks #subttl{
		position: absolute;
	top:180px;
	left: 20px;
	font-size: 105%;
	margin: 0 auto;
text-align: left;
	letter-spacing: 0.1em;

	line-height: 1em;

	color: #333;
	
	
}


#thanks h3{
	font-size: 130%;
	margin: 0 0 20px 0;
text-align: left;
	letter-spacing: 0.1em;

	line-height: 1.1em;
	
	width: auto;
	padding: 0;
	border: none;
}

#thanks h4{
	
	margin: 40px 0 10px 0;
font-size: 120%;
	letter-spacing: 0.1em;
	padding: 0;
	text-align: left;
}

#thanks h5{
	
	margin: 0 0 10px 0;
font-size: 120%;
letter-spacing: 0.1em;
	padding: 0;
	
}



#thanks h6{
	
	margin: 20px 0 5px 0;
font-size: 130%;
	letter-spacing: 2px;
	font-weight: bold;
	padding: 0;
	
}


#thanks .btn a {
      background: #3d352e;
   color: #fff;
	border: 2px solid #715c42;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 5px 30px 20px 5px;
    width: 55%;
    padding: 10px 20px;
    font-family: "Noto Sans Japanese";
    text-decoration: none;

    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

	 font-size: 95%;
	float: right;
	letter-spacing: 0.2em;
}

#thanks .btn a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
 font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}

#thanks .btn a:hover {
   background: #dfdbd6;
   color: #8d775c;
	border: 2px solid #715c42;
	
}
#thanks .btn a:hover:after {
  right: 1.4rem;
}


}


/*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;
}
}


