@media print, screen and (min-width: 751px) {
  .contents {
    padding: 40px 20px;
  }
}
@media print, screen and (min-width: 751px) {
  .contents:last-child {
    padding-bottom: 90px;
  }
}

@media print, screen and (min-width: 751px) {
  .ttlPrimary {
    margin-bottom: 20px;
  }
}

@media print, screen and (min-width: 751px) {
  .sectionImage + .sectionImage {
    margin-top: 30px;
  }
}

@media print, screen and (min-width: 751px) {
  .sectionImage .txt {
    padding: 30px 15px;
  }
}
@media print, screen and (min-width: 751px) {
  .sectionImage .txt h2.ttlPrimary {
    margin-bottom: 15px;
  }
}
@media print, screen and (min-width: 751px) {
  .sectionImage .txt .btnPrimary {
    margin: 20px auto 0 auto;
  }
}
@media print, screen and (min-width: 751px) {
  .sectionImage .txt .txtLinkWrap {
    margin-top: 15px;
  }
}

@media print, screen and (min-width: 751px) {
  .sectionImage.sectionImage03 figure {
    height: 260px;
  }
}
@media print, screen and (min-width: 751px) {
  .sectionImage.sectionImage03 .txt {
    padding: 30px 50px;
  }
}

section.animate {
  opacity: 0;
}
section.animate .ttlPrimary {
  transform: translateY(30px);
  opacity: 0;
}
section.animate .ttlPrimary span:before {
  transform: scaleX(0);
}
section.animate .lead {
  transform: translateY(30px);
  opacity: 0;
}
section.animate.animated {
  opacity: 1;
  transition-duration: 1s;
}
section.animate.animated .ttlPrimary {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}
section.animate.animated .ttlPrimary span:before {
  transform: scaleX(1);
  transition-delay: 0.5s;
  transition-duration: 1s;
}
section.animate.animated .lead {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
  transition-delay: 0.2s;
}

#mv .visual {
  text-align: center;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 1024px) {
  #mv .visual {
    margin: 0 -25%;
  }
}
@media screen and (max-width: 750px) {
  #mv .visual {
    margin: 0;
  }
}
#mv .visual .slick-list {
  overflow: visible;
}
@media screen and (max-width: 1024px) {
  #mv .visual .slick-list {
    overflow: visible;
  }
}
.pcView #mv .visual .slick-slide a:hover img {
  opacity: 0.8;
}
@media screen and (max-width: 1024px) {
  #mv .visual .slick-arrow.slick-prev {
    left: 17.5%;
  }
}
@media screen and (max-width: 750px) {
  #mv .visual .slick-arrow.slick-prev {
    left: 5px;
  }
}
@media screen and (max-width: 1024px) {
  #mv .visual .slick-arrow.slick-next {
    right: 17.5%;
  }
}
@media screen and (max-width: 750px) {
  #mv .visual .slick-arrow.slick-next {
    right: 5px;
  }
}
#mv .news {
  background: #eef4f3;
}
#mv .news dl dt {
  width: 144px;
  float: left;
  position: relative;
  font-size: 1.6rem;
  font-weight: 500;
  text-align: center;
  line-height: 56px;
  height: 56px;
}
@media screen and (max-width: 1024px) {
  #mv .news dl dt {
    display: none;
  }
}
#mv .news dl dt:before {
  content: "";
  width: 1px;
  height: calc(100% - 26px);
  position: absolute;
  top: 13px;
  right: 0;
  background: #dfdfdf;
}
#mv .news dl dd {
  width: calc(100% - 144px);
  float: left;
}
@media screen and (max-width: 1024px) {
  #mv .news dl dd {
    width: 100%;
  }
}
@media screen and (max-width: 1024px) {
  #mv .news dl dd .newsList {
    margin: 0;
  }
}
#mv .news dl dd .newsList li {
  border: none;
}
#mv .news dl dd .newsList li a {
  padding: 14px 0;
}
@media screen and (max-width: 1024px) {
  #mv .news dl dd .newsList li a {
    padding: 20px 25px 20px 15px;
  }
}
@media print, screen and (min-width: 751px) {
  #mv .news dl dd .newsList li a:hover {
    background: none;
  }
}
#mv .news dl dd .newsList li p {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#productArea .lead {
  margin: 0 0 40px;
}
@media print, screen and (min-width: 751px) {
  #productArea .lead {
    margin: 0 0 25px;
  }
}
@media print, screen and (min-width: 751px) {
  #productArea * + .sectionSecondary {
    margin-top: 25px;
  }
}
@media print, screen and (min-width: 751px) {
  #productArea .ttlSecondary {
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 1024px) {
  #productArea .boxLinkWrap.col3 {
    margin: -11px 0 0 -11px;
  }
}
@media screen and (max-width: 1024px) {
  #productArea .boxLinkWrap.col3 .boxLink {
    width: calc(33.3333333333% - 11px);
    margin: 11px 0 0 11px;
  }
}
@media screen and (max-width: 1024px) {
  #productArea .boxLinkWrap.col3 .boxLink p span {
    font-size: 1.2rem;
  }
}
#productArea .tabBtn {
  margin-top: 50px;
}
#productArea .tabBtn ul {
  border-bottom: none;
}
@media print, screen and (min-width: 751px) {
  #productArea .tabBtn {
    margin: 30px 0;
  }
  #productArea .tabBtn.border ul {
    border-bottom: 2px solid #008086;
  }
}
#productArea .tabContent {
  display: none;
}
#productArea .tabContent .btnPrimary {
  margin-top: 55px;
}
@media screen and (max-width: 1024px) {
  #productArea .tabContent .btnPrimary {
    margin-top: 40px;
  }
}
@media screen and (max-width: 750px) {
  #productArea .tabContent .btnPrimary + .btn {
    margin-top: 15px;
  }
}
#productArea .business ul {
  margin: -20px 0 0 -20px;
}
@media screen and (max-width: 1024px) {
  #productArea .business ul {
    margin: -10px 0 0 -10px;
  }
}
#productArea .business ul li {
  width: calc(33.3333333333% - 20px);
  margin: 20px 0 0 20px;
  float: left;
}
@media screen and (max-width: 1024px) {
  #productArea .business ul li {
    width: calc(50% - 10px);
    margin: 10px 0 0 10px;
  }
}
#productArea .keyword dl + dl {
  margin: 40px 0 0;
}
@media screen and (max-width: 1024px) {
  #productArea .keyword dl + dl {
    margin: 30px 0 0;
  }
}
#productArea .keyword dl dt {
  font-size: 1.8rem;
  margin: 0 0 25px;
}
@media screen and (max-width: 1024px) {
  #productArea .keyword dl dt {
    font-size: 1.6rem;
    margin: 0 0 10px;
  }
}
#productArea .keyword dl .linkNone {
  cursor: default;
}
#productArea .keyword dl .linkNone span {
  opacity: 0.5;
}
#productArea .keyword dl .linkNone:before {
  opacity: 0.5;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
}
#productArea .keyword dl .linkNone:hover {
  background: #fff;
  color: #333;
}
#productArea .keyword dl .linkNone:hover:before {
  border-top: 1px solid #333;
  border-right: 1px solid #333;
}
#productArea .keyword .searchBox {
  width: 100%;
  max-width: 680px;
}
#productArea .keyword ul {
  margin: -20px 0 0 -20px;
}
@media screen and (max-width: 1024px) {
  #productArea .keyword ul {
    margin: -10px 0 0 -10px;
  }
}
#productArea .keyword ul li {
  width: calc(16.6666666667% - 20px);
  margin: 20px 0 0 20px;
  float: left;
}
@media screen and (max-width: 1024px) {
  #productArea .keyword ul li {
    width: calc(25% - 10px);
    margin: 10px 0 0 10px;
  }
}
#productArea .keyword ul li a {
  padding: 0 40px;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  #productArea .keyword ul li a {
    padding: 0 15px;
  }
}
#productArea.animate .lead ~ * {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.4s;
}
#productArea.animate.animated .lead ~ * {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}
@media print, screen and (min-width: 751px) {
  #productArea .boxLink > a p span {
    height: 40px;
    font-size: 1.6rem;
  }
}
#productArea .slideProduct {
  margin-top: 30px;
}
@media screen and (max-width: 750px) {
  #productArea .slideProduct {
    margin: 30px auto;
  }
}

#irArea .btnWrap {
  display: flex;
}
@media screen and (max-width: 750px) {
  #irArea .btnWrap {
    flex-direction: column;
  }
}
@media screen and (max-width: 750px) {
  #irArea .btnPrimary {
    width: 100%;
  }
}
@media print, screen and (min-width: 751px) {
  #irArea .btnPrimary a {
    font-size: 1.4rem;
    padding: 0 20px;
  }
}
@media screen and (max-width: 750px) {
  #irArea .btnPrimary a {
    margin-top: 0 !important;
  }
}
@media print, screen and (min-width: 751px) {
  #irArea .btnPrimary + .btnPrimary {
    margin-left: 20px;
  }
}
@media screen and (max-width: 750px) {
  #irArea .btnPrimary + .btnPrimary {
    margin-top: 30px;
    margin-right: auto;
    margin-left: auto;
  }
}

@media screen and (max-width: 1024px) {
  .sectionImage .btn {
    max-width: 260px;
  }
}
.sectionImage .txtLinkWrap {
  margin-top: 40px;
}
@media screen and (max-width: 750px) {
  .sectionImage .txtLinkWrap {
    margin-top: 30px;
    margin-left: -15px;
    margin-right: -15px;
    margin-bottom: -30px;
  }
}
.sectionImage.animate figure img {
  transform: scale(1.1);
  transition-duration: 1.5s;
}
.sectionImage.animate .btn {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.4s;
}
.sectionImage.animate .txtLinkWrap {
  opacity: 0;
  transition-delay: 0.6s;
}
.sectionImage.animate.animated figure img {
  transform: scale(1);
}
.sectionImage.animate.animated .btn {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}
.sectionImage.animate.animated .txtLinkWrap {
  opacity: 1;
  transition-duration: 1s;
}

#movieArea .tabBtn {
  margin-top: 50px;
}
#movieArea.animate .tabBtn {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.4s;
}
#movieArea.animate .tabContent {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.4s;
}
#movieArea.animate.animated .tabBtn {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}
#movieArea.animate.animated .tabContent {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}

#newsArea.animate .sortBtn {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.4s;
}
#newsArea.animate .newsList {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.4s;
}
#newsArea.animate .btn {
  transform: translateY(30px);
  opacity: 0;
  transition-delay: 0.6s;
}
#newsArea.animate.animated .sortBtn {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}
#newsArea.animate.animated .newsList {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
}
#newsArea.animate.animated .btn {
  transform: translateY(0);
  opacity: 1;
  transition-duration: 1s;
  transition-delay: 0.6s;
}
@media print, screen and (min-width: 751px) {
  #newsArea .btnPrimary {
    margin-top: 20px;
  }
}

@media screen and (max-width: 1024px) {
  .pickupArea .ttl {
    font-size: 2.4rem;
  }
}