@charset "utf-8";

/* hypertext
-------------------- */
a {
  color: #333;
  text-decoration: none;
}
a:hover {
  color: #888;
  text-decoration: underline;
}
/* MainImage
-------------------- */
#topslidewrap{
  position: relative;
    height: 50vh;
    margin-bottom:50px;
}
.bx-viewport {
  max-height: 90vh;
}
#MainImage {
  display: block;
    height: 50vh;
    margin-bottom:2rem;
}
#spImage{
  display: none;
}
.slideTxt{
  font-family: serif;
  position: absolute;
  top:50%;
  left:50%;
  transform: translate(-50% , -50%);
  font-size: 3rem;
  font-weight: bold;
  color:white;
  z-index: 60;
  letter-spacing: 0.01em;
  text-align: center;
  text-shadow:1px 1px 0 #666,-1px 1px 0 #666,1px -1px 0 #666,-1px -1px 0 #666;
  /*text-shadow:0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666,0 0 3px #666;*/
}

@media screen and (max-width: 640px){
#topslidewrap{
  position: relative;
    height: auto;/*auto*/
}
  .bx-viewport {
    max-height: 85vh;
}
#MainImage {
  display: none;
}
#spImage{
    position: relative;
    top:-5%;
}
#spImage li:first-child {
    display:block;
}
#spImage li img{
    position: relative;
    top:0;
}
#spImage{
  display: block;
}
.slideTxt{
  font-size: 1.7rem;
  position: relative;
  top:-60vh;
  left:5%;
  text-align: center;
  /*transform: translateX(-50%);*/
  z-index: 90 ;
  }

}
/*以下不使用----
#PCMainImage {
	position: relative;
	width: 100%;
	min-width: 1200px;
	height: 90vh;
	margin-bottom: 36px;
    margin-top: 90px;
}
#PCMainImageWrap {
	position: relative;
	left: 50%;
	top: 0;
	width: 1400px;
	margin-left: -700px;
	margin-right: -100px;
}

#MainImage li {
    display:none;
}
#MainImage li:first-child {
    display:block;
}
*/
#shop{
  margin: 4rem auto;
}
#shop p{
  font-size: 1.25rem;
  line-height: 150%;
}

.concept{
  display: flex;
  justify-content: center;
  margin:5rem auto;
}
.concept div{
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.concept div h3{
  display: inline-block;
  width:auto;
  border:solid 1px #ccc;
  padding:1rem;
  margin:0 auto 2rem;
  letter-spacing: 0.1rem;
}
.concept div p{
    font-size: 1.25rem;
    color: #333;
    line-height: 300%;
}
@media screen and (max-width: 640px){
  .concept{
    margin-top:-5rem;
  }
  .concept div p{
    width:90%;
      margin:auto;
  }
}

/* Main
-------------------- */
.contents h2 {
    margin-bottom: 30px;
    line-height: 1;
}
.contents h2 span.main-title1 {
    display: inline-block;
    font-size: 32px;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 2px;
}
.contents h2 span.main-title1:before {
    display: block;
    width: 100px;
    content: '';
    margin: 0 auto;
    padding-top: 20px;
    border-top: 1px solid #999999;
}
.contents h2 span.main-title2 {
    font-size: 32px;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 2px;
}
.contents h2 span.sub-title {
    font-size: 14px;
    color: #999999;
}





/* works
-------------------- */
#Works {
    margin-bottom: 70px;
}
#Works h2 {
    margin-bottom: 70px;
    text-align: center;
}
#Works ul {
    margin-bottom: 30px;
}
#Works li {
    float: left;
    width: 274px;
    margin-right: 26px;
}
#Works li:last-child {
    margin-right: 0;
}
#Works li .thumbnail {
    margin-bottom: 15px;
}
#Works li h3 {
    margin-bottom: 20px;
    font-size: 16px;
}
#Works li h3 a {
    font-weight: bold;
}
#Works li p {
    color: #666666;
}
#Works .btn-more {
    text-align: center;
}

/* feed News
-------------------- */
#Feed {
    margin-bottom: 80px;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
}

#News {
    width: 60%;/*560*/
    margin:0;
    border: 4px solid #CCCCCC;
    padding: 50px 30px 20px;
}
@media screen and (max-width: 640px){
  #Feed {
    flex-direction: column;
}
  #News{
  width:90%;
  margin:auto;
  }
}


#News ul {
    margin-bottom: 20px;
}
#News li {
    margin-bottom: 12px;
}
#News li:after {
    clear: both;
    content: '';
    display: block;
    height: 0;
}
#News li span.date {
    float: left;
    display: block;
    width: 60px;
    padding: 10px 15px 10px 0;
    color: #666666;
    font-size: 12px;
}
#News li span.title {
    display: block;
    margin-left: 80px;
    margin-bottom: 10px;
    padding: 9px 0;
    padding-left: 25px;
    border-left: 1px solid #CCCCCC;
    font-size: 15px;
}
#News .btn-more {
    text-align: right;
}

/* feed Blog
-------------------- */
#Blog {
    position: relative;
    width: 80%;/*520px*/
    padding: 50px 30px 20px;
    border: 4px solid #CCCCCC;
}
#Blog li {
    float: left;
    width: 250px;
    margin-bottom: 30px;
}
#Blog li:nth-child(odd) {
    margin-right: 20px;
}
#Blog li:after {
    clear: both;
    content: '';
    display: block;
    height: 0;
}
#Blog li .thumbnail {
    float: left;
    width: 80px;
    margin-right: 10px;
}
#Blog li h3 a {
    font-size: 15px;
    font-weight: bold;
}
#Blog li .date {
    font-size: 12px;
}
#Blog li p {
    font-size: 13px;
    line-height:1.2;
}
#Blog .btn-more {
    position: absolute;
    right: -4px;
    bottom: -55px;
}

/* About
-------------------- */
#About {
    margin-bottom: 80px;
    padding: 50px 0;
}
#About h2 {
    text-align: center;
}
#About li {
    position: relative;
    float: left;
    width: 30%;
    margin-right: 40px;
}
#About li:last-child {
    margin-right: 0;
}
#About li:after {
    clear: both;
    content: '';
    display: block;
    height: 0;
}
#About li .thumbnail  {
  border:none;
    background: none;
}
#About li .thumbnail img {
    border-radius: 0;/*200px*/
    border: 2px solid #fff;
}
#About li h3 {
    position: relative;
    /*top: -50px;
    right: -120px;*/
    width: 100%;
    padding: 10px 0;
    background: none;
    color: #333;
    /*font-family: "ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","HGS明朝E","ＭＳ Ｐ明朝",serif;*/
    text-align: center;
    font-size: 16px;
    /*-webkit-font-smoothing: antialiased;*/
}
#About li h3 a:link,
#About li h3 a:visited,
#About li h3 a:hover{
  color:#000;
  text-decoration: none;
}
#About li p {
    color: #666666;
    font-size: 14px;
    line-height: 1.6;
}
