.cl-main {
  padding: 0;
  color: #5b5b5b;
}

.cl-kv {
  position: relative;
  height: 796px;
  background: url("../img/kv_bg.jpg") repeat-x 0 0/auto 100%;
  animation: bgMove 40s linear infinite;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.cl-kv h1 {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
  text-align: center;
}

.cl-kv h1 img {
  pointer-events: none;
}

@keyframes bgMove {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -3354px 0;
  }
}

@keyframes bgMoveSP {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -1601px 0;
  }
}

.cl-btn {
  height: 45px;
  background: #ff9906;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.4);
  border-radius: 30px;
  border: none;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.3;
}

.cl-section {
  width: 960px;
  margin: 70px auto;
}

.cl-section.full {
  width: auto;
}

.cl-section h2 {
  margin-bottom: 30px;
  text-align: center;
}

.cl-section p {
  font-size: 1.4rem;
  line-height: 1.643;
}

.cl-section .tac {
  text-align: center;
}

.cl-section .cl-heading-02 {
  width: 800px;
}

.cl-section .tokuten_text_01 {
  width: 332px;
}

.cl-section .tokuten_text_02 {
  width: 373px;
}

.cl-section .tokuten_text_03 {
  width: 322px;
}

.cl-section .tokuten_text_04 {
  width: 360px;
}

.cl-product {
  padding-bottom: 40px;
  border-bottom: 1px solid #f3f3f3;
}

.cl-product:last-child {
  border: none;
}

.cl-product .cl-limited {
  margin-bottom: 35px;
  text-align: center;
}

.cl-product .cl-limited img {
  height: 34px;
}

.cl-product-column {
  display: flex;
  justify-content: space-between;
  margin: 40px 0;
  padding-bottom: 20px;
}

.cl-product-column > div {
  width: 460px;
}

.cl-product-column img {
  width: 100%;
}

.cl-product-column .cl-product-image a {
  display: block;
  outline: none;
}

.cl-product-column .cl-product-image img {
  display: block;
}

.cl-product-column.change-image .cl-product-image {
  position: relative;
  height: 460px;
}

.cl-product-column.change-image .cl-product-image a {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  opacity: 0;
  transition: opacity .2s;
  pointer-events: none;
}

.cl-product-column.change-image .cl-product-image a.current {
  z-index: 1;
  opacity: 1;
  pointer-events: auto;
}

.cl-product-column .cl-product-right h3 {
  margin: -5px 0 14px;
  font-size: 1.7rem;
  line-height: 1.706;
}

.cl-product-column .cl-product-right .cl-price {
  font-size: 1.4rem;
}

.cl-product-column .cl-product-right .cl-price span {
  color: #fd8f4c;
  font-size: 1.7rem;
  font-weight: 600;
}

.cl-product-column .cl-product-right .cl-buy {
  margin: 20px 0 30px;
}

.cl-product-column .cl-product-right .cl-btn {
  width: 290px;
}

.cl-product-column .cl-product-right .cl-notice {
  color: #ef4416;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.25;
}


.cl-product-column .cl-product-right .cl-select-heading {
  margin: 24px 0 12px;
  font-size: 1.4rem;
  font-weight: 600;
}

.cl-product-column .cl-product-right .cl-select-list {
  width: 324px;
}

.cl-product-column .cl-product-right .cl-select-list label {
  display: block;
  margin-bottom: 8px;
  padding: 6px 22px;
  border: 1px solid #d9d9d9;
  border-radius: 4px;
  font-size: 1.3rem;
  transition: all .15s;
  cursor: pointer;
}

.cl-product-column .cl-product-right .cl-select-list :checked + label {
  border-color: #ff9625;
  background: #ff9625;
  color: #fff;
  font-weight: 600;
}

.cl-product-tile {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: -40px;
}

.cl-product-tile li {
  width: 140px;
  margin-bottom: 20px;
}

.cl-product-tile a {
  display: block;
  outline: none;
}

.cl-product-tile img {
  display: block;
}

.cl-product-detail {
  padding-top: 40px;
  border-top: 1px solid #f3f3f3;
}

.cl-product-detail h4 {
  margin: -4px 0 12px;
  font-size: 1.4rem;
}

.cl-product-detail p {
  font-size: 1.3rem;
  line-height: 1.769;
}

.cl-product-detail p + p {
  margin-top: 16px;
}

.cl-product-detail .cl-text-column {
  display: flex;
}

.cl-product-detail .cl-text-column > div {
  width: 50%;
}

.cl-tokuten {
  margin: 70px auto 120px;
}

.cl-tokuten-list {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
}

.cl-tokuten-list li {
  position: relative;
  z-index: 0;
  margin: 0 auto;
  width: 700px;
}

.cl-tokuten-list li::after {
  display: block;
  position: absolute;
  z-index: -1;
  content: "";
}

.cl-tokuten-list h3 img {
  display: block;
  margin: 0 auto;
}

.cl-tokuten-list figure {
  margin-bottom: 30px;
  text-align: center;
}

.cl-tokuten-list figure img {
  width: 100%;
}

.cl-tokuten-list h4 {
  margin: 30px 0;
  text-align: center;
}

.cl-tokuten-list p {
  font-size: 1.3rem;
  line-height: 1.692;
  text-align: center;
  letter-spacing: -.05em;
}

.cl-tokuten-list p + p {
  margin-top: 30px;
}

.cl-tokuten-list .cl-tokuten-badge {
  width: 140px;
}

.cl-tokuten-list .cl-tokuten-01 h3 {
  margin-bottom: 37px;
}

.cl-tokuten-list .cl-tokuten-01 .cl-tokuten-badge {
  margin-bottom: 37px;
}

.cl-tokuten-list .cl-tokuten-01::after {
  top: 454px;
  left: 0px;
  width: 656px;
  height: 719px;
  background: url("../img/chara_01.jpg") no-repeat 0 0;
}

.cl-tokuten-list .cl-tokuten-02 h3 {
  margin-bottom: 20px;
}

.cl-tokuten-list .cl-tokuten-02 .cl-tokuten-badge {
  margin-bottom: 20px;
}

.cl-tokuten-list .cl-tokuten-02::after {
  top: 300px;
  left: 643px;
  width: 314px;
  height: 301px;
  background: url("../img/chara_02.jpg") no-repeat 0 0;
}

.cl-tokuten .cl-notice {
  font-size: 1.2rem;
  text-align: center;
  margin: 10px auto;
  color:#5A1B1D;
}

.cl-tokuten .cl-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 22px;
  text-decoration: none;
}

/* sp */
@media screen and (max-width: 1000px) {
  .cl-main img {
    max-width: 100%;
  }
  .cl-kv {
    height: 380px;
    animation: bgMoveSP 35s linear infinite;
  }
  .cl-kv h1 img {
    width: 355px;
  }
  .cl-btn {
    min-height: 50px;
  }
  .cl-section {
    width: auto;
    margin: 30px auto;
    padding: 0 24px;
  }
  .cl-section h2 {
    margin-bottom: 24px;
  }
  .cl-section p {
    font-size: 1.4rem;
    line-height: 1.643;
  }
  .cl-section .tac {
    text-align: center;
  }
  .cl-section .tac + p {
    margin-top: 1em;
    font-size: 1.3rem;
  }
  .cl-section .cl-heading-01 {
    width: 403px;
  }
  .cl-product {
    padding-bottom: 40px;
    border-bottom: 1px solid #f3f3f3;
  }
  .cl-product:last-child {
    border: none;
  }
  .cl-product .cl-limited {
    margin-bottom: 20px;
  }
  .cl-product .cl-limited img {
    width: 246px;
  }
  .cl-product-column {
    display: block;
    margin: 30px 0 0;
    padding: 0;
  }
  .cl-product-column > div {
    width: auto;
  }
  .cl-product-column.change-image .cl-product-image {
    height: auto;
    padding-top: 100%;
  }
  .cl-product-column .cl-product-image {
    margin-bottom: 20px;
  }
  .cl-product-column .cl-product-right h3 {
    margin: 0 0 10px;
    font-size: 1.7rem;
    line-height: 1.4;
  }
  .cl-product-column .cl-product-right .cl-btn {
    width: 100%;
  }
  .cl-product-column .cl-product-right .cl-notice {
    font-size: 1.8rem;
  }
  .cl-product-column .cl-product-right .cl-select-list {
    width: auto;
  }
  .cl-product-column .cl-product-right .cl-select-list label {
    padding: 8px 22px;
  }
  .cl-product-tile {
    margin-bottom: 0;
  }
  .cl-product-tile li {
    width: calc(50% - 10px);
    margin-bottom: 20px;
  }
  .cl-product-tile li img {
    width: 100%;
  }
  .cl-product-detail {
    padding-top: 40px;
    border-top: 1px solid #f3f3f3;
  }
  .cl-product-detail h4 {
    margin: -4px 0 12px;
    font-size: 1.4rem;
  }
  .cl-product-detail p {
    font-size: 1.3rem;
    line-height: 1.769;
  }
  .cl-product-detail p + p {
    margin-top: 16px;
  }
  .cl-product-detail .cl-text-column {
    display: block;
  }
  .cl-product-detail .cl-text-column > div {
    width: auto;
    margin-top: 16px;
  }
  .cl-tokuten {
    margin: 40px auto 60px;
  }
  .cl-tokuten-list {
    display: block;
    margin: 0 0 30px;
  }
  .cl-tokuten-list li {
    width: auto;
  }
  .cl-tokuten-list li::after {
    display: none;
  }
  .cl-tokuten-list h3 {
    margin-bottom: 20px !important;
  }
  .cl-tokuten-list .cl-tokuten-badge {
    width: 140px;
    margin-bottom: 20px !important;
  }
  .cl-tokuten-list h4 {
    margin: 20px 0;
  }
  .cl-tokuten-list p {
    text-align: left;
  }
  .cl-tokuten-list p + p {
    margin-top: 20px;
  }
  .cl-tokuten-list .cl-tokuten-01 {
    margin-bottom: 40px;
  }
  .cl-tokuten .cl-btn {
    display: block;
    padding-top: 6px;
    text-align: center;
  }
}
