@charset "utf-8";
/* レイアウトのためのCSS */

body{
    font-family: 'Source Sans Pro', 'メイリオ', 'Hiragino Kaku Gothic Pro', sans-serif;
	color: #333;
	font-size:1rem;
	line-height:1.85;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%; 
	word-wrap: break-word;
	a:hover {background-color: #fff0f5;
}

@media screen and (max-width:768px) {
body{
	font-size:0.8rem;
	}
}

*{box-sizing: border-box;}

ul{
	margin:0;
	padding: 0;
	list-style: none;
}

a{
	color: #000;
	text-decoration: none;
    outline: none;
}

img{
   max-width:100%; /*画像が親要素からはみ出すのを防ぐ*/
   height: auto;
}

/* font-family */

#splash-logo,
.top-lead,
h1,
h2,
h3 span,
#g-nav,
#pc-nav,
.openbtn,
#footer{
    font-family: 'Lato', sans-serif;
    letter-spacing: 0.1em;
}

/* splash */

#splash-logo{
    font-size: 1.2rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #CC0066;
}

/* g-nav */

#g-nav.panelactive li:last-child a{
    margin: 30px 0 0 0;
    padding: 10px 20px;
    border: 2px solid #333;
    white-space: nowrap;
}

/*pc-nav*/

#pc-nav ul{
	line-height: 1.2;
}

#pc-nav span.bgLRextend::before{
    background:#CC0066;
}


@media screen and (max-width:1024px) {
    #pc-nav{
        display: none;
    }
}

/* heading */

h1{
    text-transform: uppercase;
    font-size: 3.5rem;
    position: absolute;
    top: 20%;
    left: 5%;
    line-height: 1;
    letter-spacing: 0.2em;
}

h1.img{
    width:182px;
    height:57px;
}


@media screen and (max-width:550px) {
    h1{
        font-size:3.5rem;
        top: 10%;
    }
}


h1 a{
    color:#CC0066;
}

h2{
    text-transform: uppercase;
    font-size: 3rem;
}

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

  h2{
      font-size:2rem;
    }
}

/* lead */

.top-lead{
    position: fixed;
    bottom:18%;
    left:7%;
    font-size:1.2rem;
    color:#fff;
    font-weight: bold;
    line-height: 1.5;
    text-transform:none;
}


.top-lead a {
	color: #fffacd;
	text-decoration: none;
}

.top-lead a:hover {
	color: #cc6699;
	text-decoration: none;
}


.top-lead span.bgLRextend::before{
    background:#fff;
}

@media screen and (max-width:550px) {
.top-lead{
    font-size:1.0rem;
    }
}
@media screen and (max-width:380px) {
.top-lead{
    font-size:1.0rem;
    }
}

/* main-area */

#main-area{
    width:90%;
    margin:0 auto;
    padding: 50px 0; 
}

/* topics */

#topics{
    border-left:3px solid #000;
    padding: 0 0 0 20px;
}

@media screen and (max-width:768px) {
    #topics{
        margin:0 0 100px 0;
}
}

#topics h2{
    font-size: 1.5rem;
}

#topics h2 span.bgLRextend::before{
    background:#000;
}

.bx-wrapper{
    box-shadow:none;
    border:none;
}

/* stamp */

#stamp img{
   vertical-align: middle;
}

/* vision */

#vision{
    display: flex;
    justify-content:space-between;
    align-items: center;
    flex-wrap: wrap;
    margin:0 0 100px 0;
}

@media screen and (max-width:1024px) {
    #vision{
        margin:0 0 50px 0;
    }
    
}

#vision .img{
    width:40%;
    min-height: 590px;
    background:url("../img/pict_01.jpg") no-repeat center;
    background-size: cover;
}

#vision .content{
   width:50%; 
    text-align: right;
}

@media screen and (max-width:1024px) {
  #vision .img{
    width:100%;
    min-height: 290px;
      margin:0 0 50px 0;
}

#vision .content{
   width:100%; 
    text-align: left;
}  
}

#vision h2{
    color:#CC0066;
    margin:0 0 30px 0;
    line-height: 2;
    font-size:1.7rem;
}

#vision p{
    line-height: 1.7;
    margin: 0 0 20px 0;
    font-size:1rem;
}

#vision .vision-lead{
    position: relative;
    color:#2f4f4f;
    font-size:1.2rem;
    font-weight: bold;
    margin: 0 0 90px 0;
}

@media screen and (max-width:1024px) {
#vision .vision-lead{
    font-size:1rem;
    }
    
}

#vision .vision-lead::after{
     content:'';
    position: absolute;
    bottom:-30px;
    right:0;
    background:#CC0066;
    width:70%;
    height: 3px;
}


/* service */

#service h2{
    text-align: center;
    color:#CC0066;
    margin:0 0 100px 0;
}

@media screen and (max-width:550px) {
#service h2{
    margin:0 0 50px 0;
    }
}

#service h2 span.bgLRextend::before{
    background:#CC0066;
}


#service .service-area{
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin:0 0 300px 0;
}

@media screen and (max-width:768px) {
#service .service-area{
    margin:0 0 200px 0;   
}
}

@media screen and (max-width:590px) {
 #service .service-area{
    margin:0 0 50px 0;   
}
   
}

#service .service-area::after{
     content:'';
    position: absolute;
    width: 70%;
    height: 23em;
    background:#f3f3f3;
    right:10%;
    top:20%;
    z-index: -1;
}


#service .service-area:nth-of-type(2n+1){
     flex-direction: row-reverse;
}


#service .service-area .img{
    width:50%;
}

#service .service-area .content{
    width:40%;
    background:#efdbd3;
    box-shadow: 0 0 20px #ccc;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top:150px;
}

@media screen and (max-width:768px) {
#service .service-area .content{
    width:47%;
    top:100px;
    }  
}

@media screen and (max-width:590px) {
#service .service-area .img{
    width:100%;
    z-index: 2;
}
#service .service-area .content{
    width:100%;
    top:-10px;
    animation:none;
    opacity: 1;
    z-index: 1;
}
}

#service .service-area .content-area{
    padding:40px;   
}

#service .service-area .content-area h3{
     text-align: center;
    font-size: 1rem;
    margin: 0 0 30px 0;
}

#service .service-area .content-area h3 span{
    font-weight: bold;
    text-transform: uppercase;
    display: block;
    font-size: 1.2rem;
}

#service .service-area .content-area p{
     margin:0 0 30px 0;   
}

#service .btn{
    text-align: right;
}



/* rental */

#rental h2{
    text-align: center;
    color:#CC0066;
    margin:0 0 100px 0;
}

@media screen and (max-width:550px) {
#rental h2{
    margin:0 0 50px 0;
    }
}

#rental h2 span.bgLRextend::before{
    background:#CC0066;
}


#rental .service-area{
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin:0 0 300px 0;
}

@media screen and (max-width:768px) {
#rental .service-area{
    margin:0 0 200px 0;   
}
}

@media screen and (max-width:590px) {
 #rental .service-area{
    margin:0 0 50px 0;   
}
   
}

#rental .service-area::after{
     content:'';
    position: absolute;
    width: 70%;
    height: 23em;
    background:#f3f3f3;
    right:10%;
    top:20%;
    z-index: -1;
}


#rental .service-area:nth-of-type(2n+1){
     flex-direction: row-reverse;
}


#rental .service-area .img{
    width:50%;
}

#rental .service-area .content{
    width:40%;
    background:#efdbd3;
    box-shadow: 0 0 20px #ccc;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top:150px;
}

@media screen and (max-width:768px) {
#rental .service-area .content{
    width:47%;
    top:100px;
    }  
}

@media screen and (max-width:590px) {
#rental .service-area .img{
    width:100%;
    z-index: 2;
}
#rental .service-area .content{
    width:100%;
    top:-10px;
    animation:none;
    opacity: 1;
    z-index: 1;
}
}

#rental .service-area .content-area{
    padding:40px;   
}

#rental .service-area .content-area h3{
     text-align: center;
    font-size: 1rem;
    margin: 0 0 30px 0;
}

#rental .service-area .content-area h3 span{
    font-weight: bold;
    text-transform: uppercase;
    display: block;
    font-size: 1.2rem;
}

#rental .service-area .content-area p{
     margin:0 0 30px 0;   
}

#rental .btn{
    text-align: right;
}


/* brand */

#brand h2{
    text-align: center;
    color:#CC0066;
    margin:0 0 100px 0;
}

@media screen and (max-width:550px) {
#brand h2{
    margin:0 0 50px 0;
    }
}

#brand h2 span.bgLRextend::before{
    background:#CC0066;
}


#brand .service-area{
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin:0 0 300px 0;
}

@media screen and (max-width:768px) {
#brand .service-area{
    margin:0 0 200px 0;   
}
}

@media screen and (max-width:590px) {
 #brand .service-area{
    margin:0 0 50px 0;   
}
   
}

#brand .service-area::after{
     content:'';
    position: absolute;
    width: 70%;
    height: 23em;
    background:#f3f3f3;
    right:10%;
    top:20%;
    z-index: -1;
}


#brand .service-area:nth-of-type(2n+1){
     flex-direction: row-reverse;
}


#brand .service-area .img{
    width:50%;
}

#brand .service-area .content{
    width:40%;
    background:#efdbd3;
    box-shadow: 0 0 20px #ccc;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top:150px;
}

@media screen and (max-width:768px) {
#brand .service-area .content{
    width:47%;
    top:100px;
    }  
}

@media screen and (max-width:590px) {
#brand .service-area .img{
    width:100%;
    z-index: 2;
}
#brand .service-area .content{
    width:100%;
    top:-10px;
    animation:none;
    opacity: 1;
    z-index: 1;
}
}

#brand .service-area .content-area{
    padding:40px;   
}

#brand .service-area .content-area h3{
     text-align: center;
    font-size: 1rem;
    margin: 0 0 30px 0;
}

#brand .service-area .content-area h3 span{
    font-weight: bold;
    text-transform: uppercase;
    display: block;
    font-size: 1.2rem;
}

#brand .service-area .content-area p{
     margin:0 0 30px 0;   
}

#brand .btn{
    text-align: right;
}


/* about */

#about{
    margin: 0 0 200px 0;
}

@media screen and (max-width:768px) {
#about{
    margin: 0 0 100px 0;
}
    
}

#about h2{
    text-align: center;
    color:#CC0066;
    margin:0 0 100px 0;
    padding-top: 100px;
    margin-top:-100px;
}

@media screen and (max-width:550px) {
#about h2{
    margin:0 0 50px 0;
    }
}

#about .about-list{
   width: 96%;
    max-width: 900px;
    margin: 0 auto;
}

#about .about-list li{
    border-bottom: 1px solid #ccc;
    margin:0 0 15px 0;
    padding: 0 0 15px 0;
    padding-top: 100px;
    margin-top:-100px;
}

#about .about-list dl{
     display: flex;
    justify-content: space-between;
}

#about .about-list dt{
    width:30%;
    padding: 0 0 0 40px;
}


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

#about .about-list dt{
     padding:0 0 0 10px; 
    }
}

#about .about-list dd{
    width:65%;
}


/* topics_kiji */

#topics_kiji h2{
    text-align: center;
    color:#CC0066;
    margin:0 0 100px 0;
    padding-top: 150px;
    margin-top:-150px;
}

#topics_kiji h4{
    text-align: left;
    font-size: 16px;
    color:#000;
    margin:0 0 20px 0;
    padding-top: 150px;
    margin-top:-150px;
}

@media screen and (max-width:550px) {
#topics_kiji h2{
    margin:0 0 50px 0;
    }
}

#topics_kiji h2 span.bgLRextend::before{
    background:#CC0066;
}


#topics_kiji .service-area{
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin:0 0 300px 0;
}

@media screen and (max-width:768px) {
#topics_kiji .service-area{
    margin:0 0 200px 0;   
}
}

@media screen and (max-width:590px) {
 #topics_kiji .service-area{
    margin:0 0 50px 0;   
}
   
}

#topics_kiji .service-area::after{
     content:'';
    position: absolute;
    width: 70%;
    height: 23em;
    background:#f3f3f3;
    right:10%;
    top:20%;
    z-index: -1;
}


#topics_kiji .service-area:nth-of-type(2n+1){
     flex-direction: row-reverse;
}


#topics_kiji .service-area .img{
    width:50%;
}

#topics_kiji .service-area .content{
    width:40%;
    background:#efdbd3;
    box-shadow: 0 0 20px #ccc;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top:150px;
}

@media screen and (max-width:768px) {
#topics_kiji .service-area .content{
    width:47%;
    top:100px;
    }  
}

@media screen and (max-width:590px) {
#topics_kiji .service-area .img{
    width:100%;
    z-index: 2;
}
#topics_kiji .service-area .content{
    width:100%;
    top:-10px;
    animation:none;
    opacity: 1;
    z-index: 1;
}
}

#topics_kiji .service-area .content-area{
    padding:40px;   
}

#topics_kiji .service-area .content-area h3{
     text-align: center;
    font-size: 1rem;
    margin: 0 0 30px 0;
}

#topics_kiji .service-area .content-area h3 span{
    font-weight: bold;
    text-transform: uppercase;
    display: block;
    font-size: 1.2rem;
}

#topics_kiji .service-area .content-area p{
     margin:0 0 30px 0;   
}

#topics_kiji .btn{
    text-align: right;
}


/* product */

#product h2{
    text-align: center;
    margin:0 0 100px 0;
    color: #CC0066;
    padding-top: 100px;
    margin-top:-100px;
    text-transform:none;
}

#product h4{
    text-align: left;
    font-size: 20px;
    color:#000;
    margin:0px 0px 0px 0px;
    padding-top: 100px;
    margin-top:-100px;
    text-transform:none;
}

@media screen and (max-width:550px) {
#product h2{
    margin:0 0 50px 0;
    }
}

#product h2 span.bgLRextend::before{
    background:#CC0066;
}


#product .service-area{
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin:0 0 300px 0;
}

@media screen and (max-width:768px) {
#product .service-area{
    margin:0 0 200px 0;   
}
}

@media screen and (max-width:590px) {
 #product .service-area{
    margin:0 0 50px 0;   
}
   
}

#product .service-area::after{
     content:'';
    position: absolute;
    width: 70%;
    height: 23em;
    background:#f3f3f3;
    right:10%;
    top:20%;
    z-index: -1;
}


#product .service-area:nth-of-type(2n+1){
     flex-direction: row-reverse;
}


#product .service-area .img{
    width:50%;
}

#product .service-area .content{
    width:40%;
    background:#f5fffa;
    box-shadow: 0 0 20px #ccc;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top:150px;
}

@media screen and (max-width:768px) {
#product .service-area .content{
    width:47%;
    top:100px;
    }  
}

@media screen and (max-width:590px) {
#product .service-area .img{
    width:100%;
    z-index: 2;
}
#product .service-area .content{
    width:100%;
    top:-10px;
    animation:none;
    opacity: 1;
    z-index: 1;
}
}

#product .service-area .content-area{
    padding:40px;   
}

#product .service-area .content-area h3{
     text-align: center;
    font-size: 1rem;
    margin: 0 0 30px 0;
}

#product .service-area .content-area h3 span{
    font-weight: bold;
    text-transform: uppercase;
    display: block;
    font-size: 1.2rem;
}

#product .service-area .content-area p{
     margin:0 0 30px 0;   
}

#product .btn{
    text-align: right;
}



/* faq */

#faq{
    margin:0 0 200px 0;
}

#faq h2{
    text-align: center;
    margin:0 0 100px 0;
    color: #CC0066;
    padding-top: 100px;
    margin-top:-100px;
}

#faq h4{
    text-align: left;
    font-size: 20px;
    color:#000;
    margin:0 0 25px 0;
    padding-top: 100px;
    margin-top:-100px;
}

#faq h2 span.bgLRextend::before{
    background:#CC0066;
}

.faq-bg{
    position: relative;
    height: 45vh;
    background:url("../img/cycle.png") no-repeat center;
    background-size:cover;
    margin: 0 0 100px 10%;
}

.faq-bg::after{
    content:'';
    position: absolute;
    top:20%;
    left:-32%;
    width:100%;
    height:40vh;
    background:#f3f3f3;
    z-index: -1;
}


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

.faq-bg,
.faq-bg::after{
    height:35vh;
}   
}

@media screen and (max-width:550px) {
#faq{
    margin:0 0 100px 0;
}
    
#faq h2{
 margin: 0 0 50px 0;   
}
    
.faq-bg{
    margin:0 0 50px 10%;
}

.faq-bg,
.faq-bg::after{
    height:20vh;
} 
}


/* contact */

#contact{
    margin:0 0 100px 0;
}

#contact h2{
    text-align: center;
    margin:0 0 50px 0;
    color: #CC0066;
    padding-top: 100px;
    margin-top:-100px;
}

@media screen and (max-width:550px) {
 #contact h2{
     margin:0 0 50px 0;
    }
}

#contact .form-list{
    width:100%;
    max-width: 700px;
    margin: 0 auto;
}

#contact input , button , textarea , select {
	margin:0;
	padding:0;
	border:none;
	outline:none;
	background:none;
    font-size: 16px;
}

#contact .form-list input[type='text'] , 
#contact .form-list input[type='email'] , 
#contact .form-list textarea{
	width:100%;
	border:1px solid #666;
	background:#fff;
	padding: 10px;
	-webkit-appearance:none;
	   -moz-appearance:none;
	        appearance:none;
}

#contact .form-list input[type='text'] , input[type='email'] {
	height:50px;
}

#contact .submit-btn{
    width:152px;
    margin: 0 auto;
}

#contact input[type='submit']{
   border:2px solid #333;
    color: #333;
    text-align: center;
    padding: 5px 20px;
    width:152px;
    margin: 0 auto;
    transition: all .3s;
}

#contact input[type='submit']:hover{
    background: #333;
    color: #fff;
} 

#contact .form-list dl{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
	padding:0 0 20px 0;
}

#contact .form-list dt{
    width:30%;
}

#contact .form-list dd{
    width:66%;
}

#contact .form-list textarea {
	height:200px;
}

@media screen and (max-width:768px) {
#contact .form-list dt{
	margin:0 0 10px 0;
}
#contact .form-list dt,
#contact .form-list dd{
    width:100%;
}
	
}


/* footer */

#footer{
    background: #CC6699;
    color: #fff;
}

#footer a{
    color: #fff;
}

.footer-area{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

.school-info{
    width:30%;
}

.school-info span{
    display: block;
    font-size:1.7rem;
    font-weight: bold;
    line-height: 1.5;
}

.school-info dt.footer-title,
.school-info li:first-of-type{
    margin: 0 0 10px 0;
}

.school-info li dt{
    margin:0 10px 0 0;
}

.school-info li dt,
.school-info li dd{
    display: inline-block;
}

.footer-sitemap{
    width:65%;
}

.footer-sitemap img {
    vertical-align: middle;
}

.footer-sitemap ul{
    display: flex;
    flex-wrap: wrap;
    margin: 0 0 20px 0;
    font-size: 0.9rem;
}

.footer-sitemap li{
    padding: 10px 20px;
}

.footer-sitemap li a{
	position: relative;
    padding: 0 20px;
}

.footer-sitemap li a:before{
	position: absolute;
	top:40%;
	left:-10px;
	content: '';
  width: 7px;
  height:7px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}

small{
    display: block;
    text-align: right;
}

@media screen and (max-width:1090px) {
    .footer-area{
        align-items: flex-start;
    }
.school-info{
    width:40%;
}
.footer-sitemap{
    width:56%;
}
    
}



@media screen and (max-width:768px) {
.school-info,
.footer-sitemap{
    width:100%;
}
    
.school-info{
    text-align: center;
    margin:0 0 70px 0;
    padding: 0 0 70px 0;
    border-bottom:1px solid rgba(255,255,255,0.8);
}
    .school-info span{
        font-size:1.3rem;
    }    
}


/* area */

.inner{
    width:100%;
    margin:0 auto;
    padding:70px;
}

@media screen and (max-width:940px) {
.inner{
    padding:70px 30px;
}
}





/* 注意事項 チェックマーク*/
.check ul {
  background: #fff0f5;
  box-shadow: 0px 0px 0px 10px #fff0f5;/*線の外側*/
  border: dashed 2px #c71585;
  border-radius: 9px;
  margin-left: 10px;/*はみ出ないように調整*/
  margin-right: 10px;/*はみ出ないように調整*/
  margin-bottom: 30px;
  margin-top: 20px;
  vertical-align: middle;
  padding: 0.5em 0.5em 0.5em 2em;
  position: relative;
}

.check img{
   vertical-align: middle;
}

.check ul li {
  line-height: 1.2;
  padding: 10px;
  list-style-type: none!important;/*ポチ消す*/
}

.check ul li:before {
  font-family: FontAwesome;
  content: "\f00c";
  position: absolute;
  left : 0.5em; /*左端からのアイコンまで*/
  color: #c71585; /*アイコン色*/
}

.check li a {
	align-items: baseline;
	padding: 2px;
	color: #000066;
	font-size: 16px;
	text-decoration: none;
}

.check li a:hover {background-color: #cc6699
}


/* 各リンクへ*/
.link ul {
  background: #fff0f5;
  border: solid 2px #c71585;
  padding: 0.5em;
  position: relative;
  margin-top: 50px;
}
.link ul li {
  line-height: 1.5;
  padding: 0.5em 0 0.5em 1.4em;
  border-bottom: dashed 1px silver;
  list-style-type: none!important;
}
.link ul li:last-of-type {
  border-bottom: none;
}
.link ul li:before {
  /*リスト内のアイコン*/
  font-family: FontAwesome;
  content: "\f138";/*アイコン種類*/
  position: absolute;
  left : 0.5em; /*左端からのアイコンまで*/
  color: #c71585; /*アイコン色*/
}
.link ul li:after {
  /*タイトルタブ*/
  background: #c71585;
  color: #fff;
  font-weight: bold;
  position: absolute;
  left: -2px;
  bottom: 100%;
  padding: 1px 7px;
  content: "各メニューへ";/*タブの文字*/
  letter-spacing: 0.05em;/*字間*/
}

.link li a {
	align-items: baseline;
	padding: 2px;
	color: #000066;
	font-size: 18px;
	text-decoration: none;
}

.link li a:hover {background-color: #cc6699
}

.link h5	{margin-top: 0;
	margin-bottom: 5px;
	align-items: center;
	font-size: 20px;
	color: #c71585;
}


/* テーブル */


table{
  border-collapse: collapse;
  width: 100%;
}


/* 1列目のスタイル */
table tr td:nth-of-type(1){
  background-color:#ffb6c1;
  text-align:center;
　width: 30%; 
  color: #fff;
  font-weight:bold;
}

/* 2列目のスタイル */
table tr td:nth-of-type(2){
  background-color:#ffe4e1;
  text-align:right;
}
 
/* 3列目のスタイル */
table tr td:nth-of-type(3){
  background-color:#ffe4e1;
  text-align:right;
}
 
/* 4列目のスタイル */
table tr td:nth-of-type(4){
  background-color:#ff7f50;
  text-align:right;
}

/* 5列目のスタイル */
table tr td:nth-of-type(5){
  background-color:#ffe4e1;]
  text-align:left;
}

.tb01 th,
.tb01 td{
  padding: 10px;
  border: solid 2px #5f9ea0;
  text-align:left;
  box-sizing:border-box;
}
.tb01 th {
  background: #ff7bac;
  color: #fff;
  text-align:center;
}

@media screen and (max-width: 640px) {
  .tb01 .head{
    display:none;
  }
  .tb01 {
    width: 100%;
  }
  .tb01 td,
  .tb01 th{
    display: block;
    width: 100%;
    border-bottom:none;
  }
  .tb01 td{
    padding: 0px 12px 0 0;
    display: block;
    width: 100%;
    line-height: 2.5;
    text-align:left;
  }
  .tb01 td:before{
    color: #fff;
    content: attr(data-label);
    font-weight: bold;
    padding: 0px 10px;
    display: inline;
    background-color: #ffb6c1;
    margin-right: 10px;
    float: left;
  }
  .tb01 tr:last-child{
    border-bottom: solid 2px #5f9ea0;
  }
}

.tb01 a:hover	{background-color: #cc6699}


/* blog */

#blog{
    margin:0 0 50px 0;
}
.blog-area{
    display: flex;
    justify-content: space-between;
    text-align: center;
    flex-wrap: wrap;
    overflow: hidden;
}


.blog-area img{
    width: 100%;
    height:32vh;   
}

.blog-area .blog-block{
    width:96%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.blog-area .blog-block article{
     margin:0 0 3vh 0;   
}

.blog-area .blog-block article:nth-of-type(1){ 
    width:32%;
}
.blog-area .blog-block article:nth-of-type(2){ 
    width:32%;
}
.blog-area .blog-block article:nth-of-type(3){
    width:32%;
}

.blog-area .blog-block article:nth-of-type(4){ 
    width:32%;
}
.blog-area .blog-block article:nth-of-type(5){
    width:32%; 
}
.blog-area .blog-block article:nth-of-type(6){
    width:32%;
}

@media screen and (max-width:1300px) {
    .blog-area .blog-block article:nth-of-type(n+1){ 
        width:48%;
    }
}

@media screen and (max-width:820px) {
.blog-area .blog-block article:nth-of-type(n+1) {
    width:100%;
    }
}

@media screen and (max-width:768px){
.blog-area .blog-block article:nth-of-type(n+1) {
    width:100%;
    }
}

@media screen and (max-width:450px){
.blog-area .blog-block article:nth-of-type(n+1) {
    width:100%;
    }
}


.blog-area h3{
    font-size:1rem;
    margin: 0 0 20px 0;
}

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

  .blog-area h3{
    font-size:0.9rem;
}
    
  .blog-area p{
  display: none;
    }
}

.blog-area time{
     font-size: 0.8rem;   
}


  
.blog-area .blog-block article:nth-of-type(n+1) img{
   width:100%;
    height:auto;   
}


@media screen and (max-width:820px) {
.blog-area .blog-block article:nth-of-type(n+1) img{
    width:100%;
    height:auto;
    }
}
  
@media screen and (max-width:450px){
.blog-area img,
.blog-area .blog-block article:nth-of-type(n+1) img{
    width:100%;
    height:auto;
}
}

.blog-area figure time{
    position: absolute;
    bottom:0;
    left:0;
    background:rgba(226,162,178,0.8);
    display: block;
    width:100%;
    padding: 10px;
    color: #fff;
}

.blog-area p{
     margin:0 0 20px 0; 
    text-align: left;
    font-size: 0.9rem;
}

.blog-area span{
     border:1px solid rgba(255,255,255,0.7);
    display: inline-block;
    padding:5px 10px;
    text-align: center;
    font-size: 0.8rem;
    white-space: nowrap;
}



/* menu.html */
.menu-block {
    padding-top: 100px;
    margin-top:-100px;
    vertical-align: middle;
}


.menu-item {
	display: flex;
	border-bottom: 1px dashed #bec2c7;
	padding: 20px 8px;
    padding-top: 100px;
    margin-top:-100px;
    vertical-align: middle;
}
.menu-photo {
	margin-top: 16px;
	margin-right: 16px;
	flex: 1 1 auto;
}
.menu-text {
	flex: 0 0 65%;
	margin-top: 16px;
}

.menu-text img {
	vertical-align: middle;
}

.menu-item ul {
  border: solid 2px #3cb371;
  padding: 0 0.5em;
  position: relative;
}

.menu-item ul li {
  line-height: 1.5;
  padding: 0.5em 0 0.5em 1.4em;
  border-bottom: dashed 1px silver;
  list-style-type: none!important;
}

.menu-item ul li:before {
  font-family: FontAwesome;
  content: "\f101";/*アイコン種類*/
  position: absolute;
  left : 0.5em; /*左端からのアイコンまで*/
  color: #3cb371; /*アイコン色*/
}

.menu-item ul li:last-of-type {
  border-bottom: none;
}




/* スマートフォン向けCSS */
@media (max-width: 767px) {

	/* menu.html - 横並び解除 */
	.menu-item {
		display: block;
	}
	.menu-photo {
		margin-right: 0;
		width: 100%;
	}
	.menu-text {
		width: 100%;
	}
}



/* バナー */
.top-banner{
	display: flex;
	flex-wrap:wrap;
}
.top-banner li {
	width: calc(100%/5);/*←画像を横に4つ並べる場合*/
	padding:5px 5px 5px 5px;/*←画像の左右に5pxの余白を入れる場合*/
	box-sizing:border-box;
}
.top-banner li img {
	max-width:90%; /*画像のはみだしを防ぐ*/
	height: auto; /*画像の縦横比を維持 */
}


/* スマートフォン向けCSS */
@media (max-width: 767px) {

	/* menu.html - 横並び解除 */
	.top-banner {
	display: flex;
	flex-wrap:wrap;
	}
	.top-banner li {
	width: calc(100%/2);/*←画像を横に4つ並べる場合*/
	}
	.top-banner li img {
	max-width:100%;
	}
}

/* テキストメーカー */
.moji{
	display: flex;
	flex-wrap:wrap;
}
.moji li {
	width: calc(100%/5);/*←画像を横に4つ並べる場合*/
	padding:5px 5px 5px 5px;/*←画像の左右に5pxの余白を入れる場合*/
	box-sizing:border-box;
	text-align: center;
 	font-size: 23px;
}
.moji li img {
	max-width:90%; /*画像のはみだしを防ぐ*/
	height: auto; /*画像の縦横比を維持 */
}


/* スマートフォン向けCSS */
@media (max-width: 767px) {

	/* menu.html - 横並び解除 */
	.moji {
	display: flex;
	flex-wrap:wrap;
	}
	.moji li {
	width: calc(100%/2);/*←画像を横に4つ並べる場合*/
	}
	.moji li img {
	max-width:100%;
	}
}

/* 決済 */
.pay{
	display: flex;
	flex-wrap:wrap;
}
.pay li {
	width: calc(100%/4);/*←画像を横に4つ並べる場合*/
	padding:10px 10px 10px 10px;/*←画像の左右に5pxの余白を入れる場合*/
	box-sizing:border-box;
	text-align: center;
}
.pay li img {
	max-width:100%; /*画像のはみだしを防ぐ*/
	height: auto; /*画像の縦横比を維持 */
}


/* スマートフォン向けCSS */
@media (max-width: 767px) {

	/* menu.html - 横並び解除 */
	.pay {
	display: flex;
	flex-wrap:wrap;
	}
	.pay li {
	width: calc(100%/2);/*←画像を横に4つ並べる場合*/
	}
	.pay li img {
	max-width:100%;
	}
}

/* 記事 */
.kiji img	{max-width: 100%;
	height: auto}

.kiji h2	{margin-top: 20px;
	margin-bottom: 10px;
	border-bottom: ridge 5px #CC6699;
	color: #993366;
	text-transform:none;
	font-size: 24px;}

.kiji p	{margin-top: 0;
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 2;
	text-align: justify;}


/* 記事の小見出し */
.kiji h3	{margin-top: 40px;
	margin-bottom: 40px;
	border-bottom: double 5px #990066;
	font-size: 25px;
	font-weight: normal;
    padding-top: 100px;
    margin-top:-100px;
}

.kiji h4	{margin-top: 50px;
	margin-bottom: 25px;
	color: #3cb371;
	font-size: 22px;
	font-weight: bold;}

.kiji a:hover	{background-color: #cc6699}




/* お知らせリンク*/

.newslink ul	{margin: 0;
 	padding: 0em 0em 0em 1.5em;
	position: relative;
	list-style: none;
	margin-bottom: 100px;
}

.newslink ul li {
  line-height: 1.5;
  padding: 8px;
  list-style-type: none!important;/*ポチ消す*/
　font-size: 16px;
}

.newslink li a	{
	padding: 2px;
	color: #000000;
	font-size: 16px;
	text-decoration: none;}

.newslink li a:hover	{background-color: #cc6699;}


.newslink ul li:before {
  /*リスト内のアイコン*/
  font-family: FontAwesome;
  content: "\f138";/*アイコン種類*/
  position: absolute;
  left : 0.5em; /*左端からのアイコンまで*/
  color: #c71585; /*アイコン色*/
　font-size: 16px;
}

/* 自転車,山旅リンク */

.cyari ul {
  padding: 0;
}

.cyari ul li {
  color: white;
  position:relative;
  background: #da70d6;/*バーの色*/
  border-radius: 9px;
  line-height: 1.5;
  padding: 0.5em;
  margin-bottom: 10px;
  border-left : solid 35px #c71585;/*先の色＝アイコン裏の色*/
  list-style-type: none!important;
}

.cyari ul li:before {
  font-family: FontAwesome;
  content: "\f101";
  position: absolute;
  display: block;
  padding: 0.5em;
  width: 1.2em;
  color: white; /*アイコン色*/
  font-weight: normal;/*アイコンは太字にしない*/
  text-align: center;
  left : -35px; /*左端からのアイコンまでの距離*/
  /*以下 上下中央寄せのため*/
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}


.cyari li a	{
	padding: 2px;
	color: #ffffff;
	font-size: 16px;
	text-decoration: none;}

.cyari li a:hover	{background-color: #cc6699;}

