@charset "UTF-8";
@keyframes cercle {
  0% {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    -ms-transform: rotate(0);
    -o-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes blogBg {
  0% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
  50% {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    -ms-transform: scale(1.1);
    -o-transform: scale(1.1);
    transform: scale(1.1);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
}
/* =========================================================
layout
========================================================= */
.home-block {
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}

.main-slider-area {
  width: 1000px;
  height: 590px;
  margin: 0 auto;
  position: relative;
}
.main-slider-area:after {
  content: "";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}
.main-slider-area .flex-viewport {
  overflow: visible !important;
}
.main-slider-area .main-slide-item img {
  opacity: 0.4;
  filter: alpha(opacity=40);
}
.main-slider-area .main-slide-item a {
  position: relative;
}
.main-slider-area .main-slide-item .mask {
  width: 1000px;
  height: 590px;
  padding: 282px 0 0;
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  -webkit-transition: all 0.3s ease-out 0s;
  -moz-transition: all 0.3s ease-out 0s;
  -ms-transition: all 0.3s ease-out 0s;
  -o-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
  z-index: 1;
}
.main-slider-area .main-slide-item .mask:after {
  content: "";
  width: 100%;
  height: 100%;
  border: 1px solid #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: all 0.2s ease-out 0s;
  -moz-transition: all 0.2s ease-out 0s;
  -ms-transition: all 0.2s ease-out 0s;
  -o-transition: all 0.2s ease-out 0s;
  transition: all 0.2s ease-out 0s;
}
.main-slider-area .main-slide-item .mask span {
  display: inline-block;
  font-size: 2.6rem;
  line-height: 26px;
  color: #fff;
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: all 0.3s ease-out 0s;
  -moz-transition: all 0.3s ease-out 0s;
  -ms-transition: all 0.3s ease-out 0s;
  -o-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
}
.main-slider-area .main-slide-item .mask:hover {
  background: rgba(0, 0, 0, 0.6);
  -webkit-transition: all 0.3s ease-out 0s;
  -moz-transition: all 0.3s ease-out 0s;
  -ms-transition: all 0.3s ease-out 0s;
  -o-transition: all 0.3s ease-out 0s;
  transition: all 0.3s ease-out 0s;
}
.main-slider-area .main-slide-item .mask:hover:after {
  width: 92%;
  height: 86%;
  opacity: 1;
  filter: alpha(opacity=100);
  -webkit-transition: all 0.2s ease-out 0s;
  -moz-transition: all 0.2s ease-out 0s;
  -ms-transition: all 0.2s ease-out 0s;
  -o-transition: all 0.2s ease-out 0s;
  transition: all 0.2s ease-out 0s;
}
.main-slider-area .main-slide-item .mask:hover span {
  opacity: 1;
  filter: alpha(opacity=100);
  -webkit-transition: all 0.3s ease-out 0.2s;
  -moz-transition: all 0.3s ease-out 0.2s;
  -ms-transition: all 0.3s ease-out 0.2s;
  -o-transition: all 0.3s ease-out 0.2s;
  transition: all 0.3s ease-out 0.2s;
}
.main-slider-area .flex-caption {
  margin: 20px 0 0;
  padding: 0 30px 0 0;
  font-size: 1.4rem;
  line-height: 22px;
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: all .3s ease .6s;
  -moz-transition: all .3s ease .6s;
  -ms-transition: all .3s ease .6s;
  -o-transition: all .3s ease .6s;
  transition: all .3s ease .6s;
}
.main-slider-area .flex-active-slide img {
  opacity: 1;
  filter: alpha(opacity=100);
}
.main-slider-area .flex-active-slide .flex-caption {
  opacity: 1;
  filter: alpha(opacity=100);
}
.main-slider-area .flex-direction-nav a {
  width: 48px;
  height: 89px;
  overflow: hidden;
}
.main-slider-area .flex-direction-nav a:after {
  content: "";
  width: 61px;
  height: 61px;
  bottom: 2px solid transparent;
  border-top: 2px solid #111;
  border-right: 2px solid #111;
}
.main-slider-area .flex-direction-nav .flex-prev {
  position: absolute;
  top: 250px;
  left: -90px;
  -webkit-transition: all 0.1s ease;
  -moz-transition: all 0.1s ease;
  -ms-transition: all 0.1s ease;
  -o-transition: all 0.1s ease;
  transition: all 0.1s ease;
}
.main-slider-area .flex-direction-nav .flex-prev:after {
  position: absolute;
  top: 13px;
  right: -28px;
  -webkit-transform: rotate(-135deg);
  -moz-transform: rotate(-135deg);
  -ms-transform: rotate(-135deg);
  -o-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
.main-slider-area .flex-direction-nav .flex-prev:hover {
  left: -95px;
  -webkit-transition: all 0.1s ease;
  -moz-transition: all 0.1s ease;
  -ms-transition: all 0.1s ease;
  -o-transition: all 0.1s ease;
  transition: all 0.1s ease;
}
.main-slider-area .flex-direction-nav .flex-next {
  position: absolute;
  top: 250px;
  right: -90px;
  -webkit-transition: all 0.1s ease;
  -moz-transition: all 0.1s ease;
  -ms-transition: all 0.1s ease;
  -o-transition: all 0.1s ease;
  transition: all 0.1s ease;
}
.main-slider-area .flex-direction-nav .flex-next:after {
  position: absolute;
  top: 13px;
  left: -28px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}
.main-slider-area .flex-direction-nav .flex-next:hover {
  right: -95px;
  -webkit-transition: all 0.1s ease;
  -moz-transition: all 0.1s ease;
  -ms-transition: all 0.1s ease;
  -o-transition: all 0.1s ease;
  transition: all 0.1s ease;
}

.main-slider-area .main-slide-item.only img {
  opacity: 1;
  filter: alpha(opacity=100);
}
.main-slider-area .main-slide-item.only .flex-caption {
  width: 936px;
  opacity: 1;
  filter: alpha(opacity=100);
}

#main-slider-ctrl {
  position: absolute;
  top: 570px;
  right: -80px;
  z-index: 2;
}
#main-slider-ctrl ul {
  padding: 18px;
  background: #fff;
}
#main-slider-ctrl .ctrl-btn {
  width: 108px;
  margin: 0 18px 0 0;
  display: inline-block;
  vertical-align: middle;
  border: 2px solid transparent;
  cursor: pointer;
  overflow: hidden;
}
#main-slider-ctrl .ctrl-btn:last-child {
  margin-right: 0;
}
#main-slider-ctrl .ctrl-btn.flex-active {
  border: 2px solid #111;
}
#main-slider-ctrl .ctrl-btn.only {
  border: 2px solid #111;
}
#main-slider-ctrl .ctrl-btn img {
  width: 105px !important;
  opacity: 1;
  filter: alpha(opacity=100);
  -webkit-transition: all 0.1s ease;
  -moz-transition: all 0.1s ease;
  -ms-transition: all 0.1s ease;
  -o-transition: all 0.1s ease;
  transition: all 0.1s ease;
}
#main-slider-ctrl .ctrl-btn:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -webkit-transition: all 0.1s ease;
  -moz-transition: all 0.1s ease;
  -ms-transition: all 0.1s ease;
  -o-transition: all 0.1s ease;
  transition: all 0.1s ease;
}

.top-bnr-area {
  width: 1160px;
  margin: 90px auto 0;
}
.top-bnr-area .top-bnr-list {
  width: 100%;
}
.top-bnr-area .top-bnr-item {
  margin: 0 40px 40px 0;
  display: inline-block;
  vertical-align: baseline;
}
.top-bnr-area .top-bnr-item:nth-child(4n) {
  margin-right: 0;
}

.home-block.block02 {
  padding: 70px 0 20px;
  background: #f6f6f6;
}

.tab-btn-list {
  width: 1160px;
  margin: 0 auto;
  text-align: center;
}
.tab-btn-list .tab-btn {
  margin: 0 60px 0 0;
  display: inline-block;
}
.tab-btn-list .tab-btn:last-child {
  margin-right: 0;
}
.tab-btn-list .tab-btn a {
  font-size: 1.6rem;
  line-height: 16px;
  position: relative;
}
.tab-btn-list .tab-btn a:hover {
  text-decoration: none;
}
.tab-btn-list .tab-btn a:hover:before {
  opacity: 1;
  filter: alpha(opacity=100);
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.tab-btn-list .tab-btn a:hover:after {
  opacity: 1;
  filter: alpha(opacity=100);
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.tab-btn-list .tab-btn a:before {
  content: "\005B";
  position: absolute;
  top: 0;
  left: -10px;
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.tab-btn-list .tab-btn a:after {
  content: "\005D";
  position: absolute;
  top: 0;
  right: -10px;
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.tab-btn-list .tab-btn.active a {
  pointer-events: none;
}
.tab-btn-list .tab-btn.active a:before {
  opacity: 1;
  filter: alpha(opacity=100);
}
.tab-btn-list .tab-btn.active a:after {
  opacity: 1;
  filter: alpha(opacity=100);
}

.article-wrap {
  width: 1160px;
  margin: 68px auto 0;
}

.new-article {
  display: none;
}
.new-article.ctg-all {
  display: block;
}
.new-article .article-item {
  width: 260px;
  margin: 0 40px 50px 0;
  display: inline-block;
  position: relative;
  vertical-align: top;
}
.new-article .article-item:nth-child(4n) {
  margin-right: 0;
}
.new-article .article-item a:hover .img:after {
  opacity: 1;
  filter: alpha(opacity=100);
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.new-article .img {
  width: 260px;
  height: 312px;
  -webkit-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  position: relative;
  text-indent: 100%;
  overflow: hidden;
  white-space: nowrap;
}
.new-article .img.online:before {
  content: "";
  width: 80px;
  height: 17px;
  background: url(../images/common/ico_onlineshop.png) no-repeat center center;
  position: absolute;
  bottom: 0;
  left: 0;
}
.new-article .img:after {
  content: "";
  width: 260px;
  height: 312px;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.3);
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.new-article .detail {
  width: 100%;
  padding: 12px 0 0;
  position: relative;
}
.new-article .detail .ctg {
  font-weight: 500;
}
.new-article .detail .date {
  font-family: 'Lato','Noto Sans','ヒラギノ角ゴPro W3', 'Hiragino Kaku Gothic Pro', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', Arial, Helvetica, Verdana, sans-serif;
  font-size: 1.2rem;
  line-height: 12px;
  position: absolute;
  top: 18px;
  right: 0;
  color: #9f9f9f;
}
.new-article .detail .txt {
  margin: 10px 0 0;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.home-block.block03 {
  padding: 0 0 90px;
  position: relative;
}
.home-block.block03:after {
  content: "";
  width: 100%;
  height: 640px;
  background: rgba(0, 0, 0, 0.6);
  position: absolute;
  top: 0;
  left: 0;
}
.home-block.block03 .block-ttl {
  width: 100%;
  height: 640px;
  position: relative;
  overflow: hidden;
}
.home-block.block03 .block-ttl span:first-child {
  text-align: center;
  font-size: 3.4rem;
  line-height: 34px;
  color: #fff;
  position: absolute;
  top: 187px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 1;
}
.home-block.block03 .block-ttl .blog-bg {
  width: 100%;
  height: 640px;
  position: relative;
  overflow: hidden;
  background: url(../images/home/blog_bg/bg_topblog.jpg) no-repeat center top;
  -webkit-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}
.home-block.block03 .blog-wrap {
  width: 95%;
  margin: -250px auto 0;
  position: relative;
  z-index: 1;
}
.home-block.block03 .blog-list .blog-item {
  width: 200px;
  margin: 0 40px 40px 0;
  display: inline-block;
  vertical-align: top;
  text-align: left;
}
.home-block.block03 .blog-list .blog-item:nth-child(5n) {
  margin-right: 0;
}
.home-block.block03 .blog-list .blog-date {
  margin: 20px 0 10px;
  font-family: 'Lato','Noto Sans','ヒラギノ角ゴPro W3', 'Hiragino Kaku Gothic Pro', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', Arial, Helvetica, Verdana, sans-serif;
  font-size: 1.2rem;
  line-height: 12px;
  color: #9f9f9f;
}
.home-block.block03 .blog-list .blog-ctg {
  margin: 0 0 5px;
  font-size: 1.1rem;
  line-height: 18px;
}

.blog-list {
  width: 100%;
  padding: 50px 0 0;
  text-align: center;
  background: #fff;
}

@media screen and (max-width: 1240px) {
  .home-block.block03 .blog-wrap {
    width: 100%;
  }

  .blog-list {
    min-width: 1160px;
    padding: 50px 0 0;
  }
}
.blog-ctg-btn {
  margin: 15px 0 0;
}
.blog-ctg-btn .btn-list {
  width: 1160px;
  margin: 0 auto;
  text-align: center;
}
.blog-ctg-btn li {
  margin: 0 40px 0 0;
  display: inline-block;
}
.blog-ctg-btn li:last-child {
  margin-right: 0;
}
.blog-ctg-btn .cmn-btn {
  width: 256px;
}

.load-fix {
  overflow: hidden;
}

.load-view {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 5;
}
.load-view .load-img {
  width: 42px;
  height: 42px;
  background: url(../images/home/loading.svg) no-repeat center center;
  position: absolute;
  top: 300px;
  left: 50%;
  margin: -20px 0 0 -20px;
  -webkit-animation: cercle 1s linear 0s infinite;
  -moz-animation: cercle 1s linear 0s infinite;
  -o-animation: cercle 1s linear 0s infinite;
  animation: cercle 1s linear 0s infinite;
}