@charset "UTF-8";
@import url(swiper-bundle.min.css);
@media screen and (max-width: 767.9px) {
  body {
    padding-bottom: 13.3333333333vw;
  }
}
/* ------------------------------------------------
 floatnav
------------------------------------------------ */
#suntory_contents #floatnav {
  background-color: #301617;
  background-image: linear-gradient(0deg, #301617 0%, #53282a 49%, #301617 100%);
  max-width: none;
  width: 100%;
  padding: 0.5333333333em 0;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 9;
  transition: all 0.4s ease;
  box-sizing: border-box;
}
#suntory_contents #floatnav .list {
  display: flex;
  justify-content: stretch;
  position: relative;
}
#suntory_contents #floatnav .list li {
  text-align: center;
  line-height: 1;
  flex-grow: 1;
}
#suntory_contents #floatnav .list li a {
  color: #fff;
  font-size: 1em;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  min-height: 2.2666666667em;
  display: block;
  box-sizing: border-box;
  align-content: center;
}
#suntory_contents #floatnav .list li + li {
  position: relative;
}
#suntory_contents #floatnav .list li + li a {
  border-left: 1px solid #fff;
}
#suntory_contents #floatnav.hide {
  opacity: 0;
  visibility: hidden;
}
#suntory_contents #floatnav.view {
  opacity: 1;
  visibility: visible;
}
@media screen and (min-width: 768.1px) {
  #suntory_contents #floatnav {
    display: none !important;
  }
}

/* ------------------------------------------------
本キャンペーンは終了いたしました.sp_show
------------------------------------------------ */
#suntory_contents .message_close .message {
  position: relative;
}
#suntory_contents .message_close .message img {
  margin: 0 auto;
  width: 53.5em;
  display: block;
}
@media screen and (max-width: 767.9px) {
  #suntory_contents .message_close {
    padding-bottom: 3em;
  }
  #suntory_contents .message_close .message img {
    width: 22.0666666667em;
  }
}

#howto + .message_close {
  background-color: #edddcf;
}

/* ------------------------------------------------
 cpend
------------------------------------------------ */
@media screen and (max-width: 767.9px) {
  #suntory_contents .cpnend {
    padding: 1.1333333333em 0;
  }
}

/* ------------------------------------------------
 MV
------------------------------------------------ */
#kv {
  color: #fff;
  background: url(../img/cp01/kv_bg.webp);
  background-size: 100% auto;
  background-size: cover;
}
#kv > .inner {
  padding-top: 6.25em;
  min-height: 96.25em;
}
#kv .lead {
  margin: 0 auto;
  width: 49.875em;
  position: relative;
}
#kv .lead .note {
  font-size: 0.75em;
  position: absolute;
  left: 0;
  top: 7.1666666667em;
}
#kv .title {
  margin-top: 0.875em;
  margin-left: 18.75em;
  width: 39.6875em;
}
#kv .items {
  margin-top: -4.375em;
  margin-left: 15em;
  width: 45.625em;
}
#kv .detail {
  margin-top: -0.375em;
  margin-left: 19.375em;
  width: 36.1875em;
}
#kv .image {
  margin-top: 1.625em;
  margin-left: 18.75em;
  width: 34.8125em;
}
#kv .text {
  margin-top: 2.375em;
  margin-left: 12.5em;
}
#kv .text .size {
  font-size: 1.25em;
}
#kv .text .note {
  font-size: 0.75em;
  margin-top: 1em;
}
@media screen and (max-width: 767.9px) {
  #kv {
    background-image: url(../img/cp01/kv_bg-sp.webp);
  }
  #kv > .inner {
    padding-top: 1.6666666667em;
    min-height: 74.5333333333em;
  }
  #kv .lead {
    width: 23em;
  }
  #kv .lead .note {
    font-size: 0.6em;
    top: 9.6666666667em;
  }
  #kv .title {
    margin-top: 0.4666666667em;
    margin-left: 0.4em;
    width: 24em;
  }
  #kv .items {
    margin-top: -4.3333333333em;
    margin-left: 0;
    width: 100%;
    overflow: hidden;
  }
  #kv .detail {
    margin-top: 2.6666666667em;
    margin-left: 1.6666666667em;
    width: 21.1666666667em;
  }
  #kv .image {
    margin-top: 2.6666666667em;
    margin-left: auto;
    margin-right: 0;
    width: 24.6666666667em;
  }
  #kv .text {
    margin-top: 1.0666666667em;
    margin-left: 1.8333333333em;
  }
  #kv .text .size {
    font-size: 0.7333333333em;
  }
  #kv .text .note {
    font-size: 0.6em;
  }
}

/* ----------------------------
 items_slider
------------------------------*/
@media screen and (max-width: 767.9px) {
  #items_slider {
    width: 21.2em;
    overflow: visible;
  }
  #items_slider .swiper-wrapper {
    padding-top: 4em;
    padding-bottom: 2.3333333333em;
  }
  #items_slider .swiper-slide {
    box-sizing: border-box;
    opacity: 0.25;
    transition: opacity 0.4s ease;
  }
  #items_slider .swiper-slide img {
    transform-origin: 50% 57%;
    transform: scale(1.0755);
    transition: transform 0.4s ease;
  }
  #items_slider .swiper-slide-active {
    opacity: 1;
  }
  #items_slider .swiper-slide-active img {
    transform: scale(1.3679);
  }
  #items_slider .swiper-slide-prev, #items_slider .swiper-slide-next {
    opacity: 0.5;
  }
  #items_slider .ctrl {
    display: flex;
    justify-content: center;
    align-items: center;
    -moz-column-gap: 3em;
         column-gap: 3em;
  }
  #items_slider .ctrl > * {
    position: static !important;
  }
  #items_slider .swiper-button-prev, #items_slider .swiper-button-next {
    font-size: 1em;
    line-height: 1;
    border: none;
    margin: 0;
    padding: 0;
    outline: none;
    background-color: transparent;
    width: auto;
    height: auto;
    display: block;
    cursor: pointer;
    filter: drop-shadow(5px 5px 6px rgba(56, 9, 15, 0.4));
  }
  #items_slider .swiper-button-prev::after, #items_slider .swiper-button-next::after {
    content: "";
    font-size: 1em;
    background: url(../img/cp01/item_slider_arrow.png) no-repeat;
    background-size: contain;
    width: 1.4em;
    aspect-ratio: 42/63;
    display: block;
  }
  #items_slider .swiper-button-prev {
    left: 2.2333333333em;
    left: auto;
    right: calc(50% + 8.5em);
  }
  #items_slider .swiper-button-prev::after {
    transform: scale(-1, 1);
  }
  #items_slider .swiper-button-next {
    right: 2.2333333333em;
    right: auto;
    left: calc(50% + 8.5em);
  }
  #items_slider .swiper-pagination {
    width: -moz-fit-content;
    width: fit-content;
    display: flex;
    justify-content: center;
    align-items: center;
    -moz-column-gap: 1.6666666667em;
         column-gap: 1.6666666667em;
  }
  #items_slider .swiper-pagination-bullet {
    border: 0.1em solid #fff;
    background-color: #fff;
    margin: 0;
    width: 0.7333333333em;
    height: 0.7333333333em;
    opacity: 1;
  }
  #items_slider .swiper-pagination-bullet-active {
    background-color: #322212;
  }
}
/* ------------------------------------------------
about
------------------------------------------------ */
#suntory_contents #about > .inner {
  background: url(../img/cp01/about_bg.webp) no-repeat;
  background-size: 100% auto;
  background-size: cover;
  padding-top: 12.5em;
  min-height: 36.25em;
}
#suntory_contents #about .info {
  width: 39.375em;
}
@media screen and (max-width: 767.9px) {
  #suntory_contents #about > .inner {
    background-image: url(../img/cp01/about_bg-sp.webp);
    padding-top: 2.3333333333em;
    min-height: 61.4666666667em;
  }
  #suntory_contents #about .lineoubo .heading {
    margin: 0 auto;
    width: 18.7333333333em;
  }
  #suntory_contents #about .lineoubo .link .basic_btn {
    margin: 0 auto;
    width: 21.6em;
    display: block;
  }
  #suntory_contents #about .sbody {
    margin-top: 6em;
  }
  #suntory_contents #about .sbody .info {
    width: 17.3333333333em;
  }
}

/* ------------------------------------------------
応募の流れ.sp_show
------------------------------------------------ */
@media screen and (max-width: 767.9px) {
  #suntory_contents .bg_paper {
    background: url(../img/cp01/flow_bg.webp) repeat-y;
    background-size: 100% auto;
    padding-top: 1px;
  }
}
#suntory_contents #flow {
  position: relative;
  z-index: 1;
}
#suntory_contents #flow > .inner {
  padding-top: 3em;
  position: relative;
}
#suntory_contents #flow .heading {
  margin-left: 3em;
  width: 19em;
  position: relative;
  z-index: 1;
}
#suntory_contents #flow .flow {
  margin-top: -1.8em;
  margin-left: 0.9333333333em;
  width: 23.2666666667em;
  filter: drop-shadow(4px 4px 16px rgba(0, 0, 0, 0.6));
}

/* ------------------------------------------------
 応募方法の詳細
------------------------------------------------ */
#suntory_contents #howto > .inner {
  padding-top: 1.8333333333em;
  padding-bottom: 2.6666666667em;
}
#suntory_contents #howto .more .basic_btn {
  margin: 0 auto;
  width: 23.2666666667em;
  display: block;
  position: relative;
}
#suntory_contents #howto .more .basic_btn::after {
  content: "";
  background: url(../img/cp01/btn_more_icon.png) no-repeat;
  background-size: auto 100%;
  width: 1.2em;
  aspect-ratio: 1/1;
  position: absolute;
  right: 1.4666666667em;
  top: 1.6em;
}
#suntory_contents #howto .more .basic_btn.open::after {
  background-position: 100% 0;
}
#suntory_contents #howto .content {
  padding-top: 2.6666666667em;
  display: none;
}
#suntory_contents #howto .content .step {
  margin: 0 auto;
  width: 23.2666666667em;
  position: relative;
}
#suntory_contents #howto .content .step + .step {
  margin-top: 1.8333333333em;
}
#suntory_contents #howto .content .step .basic_btn {
  width: 19.2666666667em;
  position: absolute;
  left: 2em;
  top: 49.0666666667em;
}
#suntory_contents #howto .content.open .step .btn {
  display: block;
}
#suntory_contents #howto .cpnend {
  bottom: 2em;
}

/* ------------------------------------------------
応募はこちら.sp_show
------------------------------------------------ */
#suntory_contents #oubo {
  color: #fff;
}
#suntory_contents #oubo > .inner {
  background: url(../img/cp01/oubo_bg.webp) no-repeat;
  background-size: 100% auto;
  padding-top: 3.3333333333em;
  min-height: 40.2666666667em;
}
#suntory_contents #oubo .sheader .title {
  margin: 0 auto;
  width: 20.6666666667em;
}
#suntory_contents #oubo .sbody {
  margin-top: 2em;
  box-sizing: border-box;
}
#suntory_contents #oubo .sbody .lead {
  font-size: 1em;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.06em;
  margin: 0 auto;
  width: -moz-fit-content;
  width: fit-content;
}
#suntory_contents #oubo .sbody .confirm {
  margin-top: 1.4em;
  margin-left: 1em;
  width: 23.0666666667em;
  height: 9.7333333333em;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  position: relative;
}
#suntory_contents #oubo .sbody .confirm::before {
  content: "";
  background: url(../img/cp01/oubo_confirm_bg.webp) no-repeat;
  background-size: contain;
  width: 23.4666666667em;
  height: 10em;
  position: absolute;
  left: 0;
  top: 0;
}
#suntory_contents #oubo .sbody .confirm > * {
  position: relative;
}
#suntory_contents #oubo .sbody .confirm .link {
  font-weight: 500;
}
#suntory_contents #oubo .sbody .confirm .link a {
  color: #118492;
}
#suntory_contents #oubo .sbody .confirm label {
  font-size: 1.0666666667em;
  font-weight: bold;
  line-height: 1;
  margin-top: 1.1333333333em;
  cursor: pointer;
  display: inline-block;
  outline: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
#suntory_contents #oubo .sbody .confirm label::before {
  content: "";
  background: url(../img/cp01/oubo_checkbox_disabled.png) no-repeat;
  background-size: contain;
  margin-right: 0.5em;
  width: 1.6666666667em;
  aspect-ratio: 1/1;
  display: inline-block;
  vertical-align: middle;
}
#suntory_contents #oubo .sbody .confirm label .txt {
  color: #322212;
  font-size: 1.0666666667em;
}
#suntory_contents #oubo .sbody .confirm input[name=chk_confirm] {
  display: none;
}
#suntory_contents #oubo .sbody .link_btns {
  margin: 1.8em auto 0;
  width: 21.9333333333em;
  height: 4.2666666667em;
  position: relative;
}
#suntory_contents #oubo .sbody .link_btns .btn {
  font-size: 1em;
  border-width: 0;
  border-radius: 128px;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  transition: all 0.4s ease;
}
#suntory_contents #oubo .sbody .link_btns .btn.on {
  z-index: 10;
  opacity: 0;
  left: 0;
  visibility: hidden;
}
#suntory_contents #oubo .sbody .link_btns .btn.off {
  z-index: 2;
  opacity: 1;
  visibility: visible;
}
#suntory_contents #oubo .sbody .note {
  font-weight: normal;
  line-height: 1.6;
  letter-spacing: normal;
  text-align: left;
  margin: 3.3636363636em 2.5em 0;
}
#suntory_contents #oubo .sbody .note a {
  color: #35e9ff;
}
#suntory_contents #oubo.active .sbody .confirm label::before {
  background-image: url(../img/cp01/oubo_checkbox.png);
}
#suntory_contents #oubo.active .sbody .link_btns .btn.on {
  z-index: 2;
  opacity: 1;
  visibility: visible;
}
#suntory_contents #oubo.active .sbody .link_btns .btn.off {
  z-index: 1;
  opacity: 0;
  visibility: hidden;
}

/* ------------------------------------------------
contact
------------------------------------------------ */
#contact .sbody {
  margin-top: 2.1875em;
}
@media screen and (max-width: 767.9px) {
  #contact .sbody {
    margin-top: 1.6666666667em;
  }
}

/* ------------------------------------------------
 floatbnr
------------------------------------------------ */
#suntory_contents #floatbnr {
  padding: 10px 0;
  width: 100%;
  position: fixed;
  left: 0;
  bottom: 0;
  opacity: 0;
  filter: blur(4px);
  transition: opacity 0.4s ease, filter 1s ease;
}
#suntory_contents #floatbnr img {
  margin: 0 auto;
}
#suntory_contents #floatbnr.show {
  filter: blur(0);
  opacity: 1;
}