.l-content{
  overflow-x: hidden;
}

/*------------------------------
 m-special-title
------------------------------*/
.m-special-title{
  background-color: #fcfcfc;
  border-bottom: solid 4px #db0000;
}
.m-special-title .unit .inner h1{
  color: #db0000;
  font-size: 24px;
  text-align: left;
}
.m-special-title .unit .inner p{
  text-align: left;
}

@media screen and (min-width: 768px){
  .m-special-title .unit .inner h1{
    font-size: 32px;
    text-align: center;
  }
  .m-special-title .unit .inner p{
    text-align: center;
  }
}


/*------------------------------
 m-special-content
------------------------------*/
.m-special-content .unit{
  padding: 64px 0px 0px;
}

.m-special-content .unit .inner{
  display:-webkit-box;
  display:-ms-flexbox;
  display: -webkit-flex;
  display:flex;
  flex-flow: wrap-reverse;
  justify-content: center;
  position: relative;
  width: calc(100% - 2em);
  max-width: 1120px;
  margin: 0 auto;
  margin-bottom: 64px;
}

.m-special-content .unit .inner:nth-child(2n) {
  flex-direction: row-reverse;
}

.m-special-content .unit .inner .txt-holder{
  width: 90%;
  margin: 24px 0;
  padding: 24px 0;
  position: relative;
  z-index: 1;
}

.m-special-content .unit .inner .txt-holder .label{
  background: #d9c235;
  display: inline-block;
  padding: 4px 16px;
  color: #fff;
  margin-bottom: 0;
}

.m-special-content .unit .inner .txt-holder h2{
  color: #db0000;
  margin-bottom: 16px;
}

.m-special-content .unit .inner .txt-holder .ribon{
  margin-bottom: 24px;
}

.m-special-content .unit .inner .txt-holder .ribon img{
  width: 100%;
  vertical-align: baseline;
}

.m-special-content .unit .inner .txt-holder p{
  color: #606060;
  line-height: 1.75em;
}

.m-special-content .unit .inner .txt-holder .bg{
  background: #ffffff;
  width: 84%;
  height: 100%;
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.m-special-content .unit .inner .img-holder{
  position: relative;
  width: 70%;
}

@media screen and (min-width: 768px) {
  .m-special-content .unit .inner .txt-holder,
  .m-special-content .unit .inner .img-holder {
    width: 48%;
  }
  .m-special-content .unit .inner:nth-child(2n-1) .img-holder{
    margin-left: auto;
  }

  .m-special-content .unit .inner:nth-child(2n) .img-holder{
    margin-right: auto;
  }
}


/*------------------------------
 m-special-btn
------------------------------*/
.m-special-btn .unit{
  padding: 0 0 64px;
}

.m-special-btn .unit .inner {
  display: block;
  width: calc(100% - 2em);
  max-width: 520px;
  background: #ffffff;
  border: 2px solid #db0000;
  margin: 0 auto;
  padding: 24px;
}

.m-special-introduction .m-special-btn .unit .inner {
  display: block;
  width: calc(100% - 2em);
  max-width: 520px;
  background: #ffffff;
  border: 2px solid #db0000;
  margin: 0 auto;
  padding: 24px;
}

.m-special-btn .unit .inner .text-holder{
 text-align: center;
}

.m-special-btn .unit .inner .text-holder .price{
  font-size: 20px;
  color: #db0000;
  font-weight: 700;
  margin-bottom: 16px;
}

.m-special-btn .unit .inner .text-holder .price .span{
  font-size: 20px;
}

.m-special-btn .unit .inner .btn-holder{
  width: calc(100% - 2em);
  max-width: 400px;
  background: #db0000;
  border: 2px solid #fff;
}

.m-special-btn .unit .inner .btn-holder:hover{
  background: #7f0000;
}

.m-special-btn .unit .inner .btn-holder a{
  color: #fff;
}

.m-special-btn .unit .inner .soldout{
  pointer-events: none;
  background: #666;
  border: 2px solid #fff;
}

.m-special-btn .unit .inner .soldout:hover{
  background: #999;
}

.m-special-btn .unit .inner .soldout a{
  color: #fff;
}

@media screen and (min-width: 768px) {
  .m-special-btn .unit .inner .text-holder .price{
    font-size: 32px;
  }
}


/*------------------------------
 m-special-introduction
------------------------------*/
.m-special-introduction .unit .inner{
  width: calc(100% - 4em);
  max-width: 960px;
  margin: 0 auto;
}

.m-special-introduction .unit .inner .title-holder h2{
  text-align: center;
  font-size: 24px;
  font-weight: normal;
  margin-bottom: 40px;
}

.m-special-introduction .unit .inner .close-up-holder{
  display:-webkit-box;
  display:-ms-flexbox;
  display: -webkit-flex;
  display:flex;
  flex-flow: row wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack:distribute;
  -webkit-justify-content:space-between;
  justify-content:space-between;
  padding-top: 64px;
  margin-bottom: 64px;
}

.m-special-introduction .unit .inner .close-up-holder div{
  text-align: center;
  background: #ffffff;
  border-top: 16px solid #db0000;
  padding: 16px;
  width: 100%;
  margin-bottom: 32px;
}

.m-special-introduction .unit .inner .close-up-holder div:last-child{
  margin-bottom: 0;
}

.m-special-introduction .unit .inner .close-up-holder h3{
  font-size: 24px;
  font-weight: 700;
  color: #db0000;
}

.m-special-introduction .unit .inner .close-up-holder img{
  margin-bottom: 24px;
}

.m-special-introduction .unit .inner .close-up-holder p{
  width: 100%;
  line-height: 1.5;
  text-align: left;
}

.m-special-introduction .unit .inner .txt-holder p.price{
  color: #DC0325;
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}
.m-special-introduction .unit .inner .txt-holder p.price span{
  font-size: 24px;
}

.m-special-introduction .unit .inner .txt-holder p.day{
  color: #555;
  font-size: 24px;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .m-special-introduction .unit .inner .close-up-holder div{
    width: 31.8%;
    margin-bottom: 0;
  }
}


/*------------------------------
 m-special-attention
------------------------------*/
.m-special-attention .unit {
  padding: 48px 0;
}

.m-special-attention .unit .inner {
  width: calc(100% - 2em);
  max-width: 1200px;
  margin: 0 auto;
}


.m-special-attention .unit .inner .title-holder h2{
  text-align: center;
  font-size: 24px;
  font-weight: normal;
  margin-bottom: 40px;
}

.m-special-attention .unit .inner .detail dl{
  display:-webkit-box;
  display:-ms-flexbox;
  display: -webkit-flex;
  display:flex;
  flex-flow: row wrap;
  margin-bottom: 0;
  background: #fff;
  border: solid 1px #ccc;
}

.m-special-attention .unit .inner .detail dl + dl{
  border-top: 0;
}

.m-special-attention .unit .inner .detail dl dt{
  flex: 100%;
  padding: 16px 0;
  text-align: center;
  background: #eee;
}

.m-special-attention .unit .inner .detail dl dd{
  padding: 16px;
}

.m-special-attention .unit .inner .detail dl dd a{
  color: #DC0325;
}

@media screen and (min-width: 768px){
  .m-special-attention .unit .inner .detail dl dt{
    flex: 1;
  }

  .m-special-attention .unit .inner .detail dl dd{
    flex: 3;
  }
}
