/*
* products_category.css
*
*/
/* --------------------------------
  cv btn
-------------------------------- */
@media (min-width: 768px) {
  .products_shops_empty {
    visibility: hidden;
    opacity: 0; 
    width: 100%;
    height: auto;
    min-height: 93px;
  }
}

.products_shop_btnArea {
  position: relative;
  z-index: 1;
}
@media (max-width: 767.98px) {
  .products_shop_btnArea {
    position: fixed;
    z-index: 1000;
    bottom: 0;
    left: 0;
    padding: 7px;
    width: 100%;
    -webkit-transition: all 0.35s;
    transition: all 0.35s; 
    background: rgba(0, 0, 0, 0.55);
  }
  .products_shop_btnArea.is-hide {
    visibility: hidden;
    opacity: 0;
  }
}

.btn-logo {
  overflow: hidden; 
  position: relative;
  padding: 3px;
  border-radius: 39px;
  height: 71px;
  background: #e3b865;
}
@media (min-width: 1024px) {
  .btn-logo {
    border-radius: 44px;
    height: 86px;
  }
}
.btn-logo a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 10px;
  border-radius: inherit; 
  height: 100%;
  background: #fff;

  -webkit-box-pack: center;

      -ms-flex-pack: center;

          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (min-width: 1024px) {
  .btn-logo a {
    padding: 20px;
  }
  .btn-logo a:before {
    content: "";
    position: absolute;
    top: 0;
    right: -2%;
    width: 0;
    height: 100%;
    -webkit-transition: width 0.35s;
    transition: width 0.35s; 
    -webkit-transform: skewX(25deg); 
        -ms-transform: skewX(25deg); 
            transform: skewX(25deg);
    background: #000;
  }
  .btn-logo a:hover:before {
    left: -2%;
    width: 104%;
  }
  .btn-logo a:after {
    content: "";
    opacity: 0; 
    position: absolute; 
    top: 0; 
    right: 0; 
    bottom: 0; 
    left: 0;
    margin: auto;
    -webkit-transition: opacity 0.35s;
    transition: opacity 0.35s;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
  }
  .products_shops_list_amazon .btn-logo a:after {
    background-image: url(/sports/savas/img/products_detail/logo_amazon_ov.svg);
  }
  .products_shops_list_rakuten .btn-logo a:after {
    background-image: url(/sports/savas/img/products_detail/logo_rakuten_ov.svg);
  }
  .products_shops_list_lohaco .btn-logo a:after {
    background-image: url(/sports/savas/img/products_detail/logo_lohaco_ov.svg?20210601);
  }
  .btn-logo a:hover:after {
    opacity: 1;
  }
}
.btn-logo a .icon_blank {
  position: absolute;
  top: 0;
  right: 15px;
  bottom: 0;
  margin: auto;
  width: 9px;
  height: 8px;
}
@media (min-width: 1024px) {
  .btn-logo a .icon_blank {
    right: 19px;
    width: 11px;
    height: 9px;
  }
}
.btn-logo a .icon_blank:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: opacity 0.25s 0.15s;
  transition: opacity 0.25s 0.15s; 
  background: url(/sports/savas/img/common/icon_blank.webp) 0 0 no-repeat;
  background-size: contain;
}
@media (min-width: 1024px) {
  .btn-logo a .icon_blank:after {
    content: "";
    opacity: 0; 
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transition: opacity 0.25s 0.15s;
    transition: opacity 0.25s 0.15s;
    background: url(/sports/savas/img/common/icon_blank_ov.webp) 0 0 no-repeat;
    background-size: contain;
  }
}
@media (min-width: 1024px) {
  .btn-logo a:hover .icon_blank:before {
    opacity: 0;
  }
  .btn-logo a:hover .icon_blank:after {
    opacity: 1;
  }
}

.products_shop_btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border: 2px solid #f5f5f5;
  background: #fff;
}
@media (min-width: 1024px) {
  .products_shop_btns {
    border-width: 3px;
  }
}
.products_shop_btns li {
  width: calc(100% / 3);
}
.products_shop_btns li:nth-child(n + 2) {
  border-left: 2px solid #f5f5f5;
}
@media (min-width: 1024px) {
  .products_shop_btns li:nth-child(n + 2) {
    border-width: 3px;
  }
}
.products_shop_btns li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  padding: 15px 0;
  height: 100%; 

  -webkit-box-pack: center; 

      -ms-flex-pack: center; 

          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (min-width: 1024px) {
  .products_shop_btns li a {
    overflow: hidden;
    padding: 16px 5px 14px;
  }
  .products_shop_btns li a:before {
    content: "";
    position: absolute;
    top: 0;
    right: -10%;
    width: 0;
    height: 100%;
    -webkit-transition: width 0.35s;
    transition: width 0.35s; 
    -webkit-transform: skewX(20deg); 
        -ms-transform: skewX(20deg); 
            transform: skewX(20deg);
    background: #000;
  }
  .products_shop_btns li a:hover:before {
    left: -10%;
    width: 120%;
  }
  .products_shop_btns li a:after {
    content: "";
    opacity: 0; 
    position: absolute; 
    top: 0; 
    right: 0; 
    bottom: -2px; 
    left: 0;
    z-index: 1;
    margin: auto;
    -webkit-transition: opacity 0.35s;
    transition: opacity 0.35s;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
  }
  .products_shop_btns li a:hover:after {
    opacity: 1;
  }
}
.products_shop_btns li .icon_blank {
  position: absolute;
  right: 3px;
  bottom: 3px;
  width: 9px;
  height: 8px;
}
@media (min-width: 1024px) {
  .products_shop_btns li .icon_blank {
    right: 6px;
    bottom: 6px;
    width: 11px;
    height: 9px;
  }
}
.products_shop_btns li .icon_blank:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: opacity 0.25s 0.15s;
  transition: opacity 0.25s 0.15s; 
  background: url(/sports/savas/img/common/icon_blank.webp) 0 0 no-repeat;
  background-size: contain;
}
@media (min-width: 1024px) {
  .products_shop_btns li .icon_blank:after {
    content: "";
    opacity: 0; 
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transition: opacity 0.25s 0.15s;
    transition: opacity 0.25s 0.15s;
    background: url(/sports/savas/img/common/icon_blank_ov.webp) 0 0 no-repeat;
    background-size: contain;
  }
}
@media (min-width: 1024px) {
  .products_shop_btns li a:hover .icon_blank:before {
    opacity: 0;
  }
  .products_shop_btns li a:hover .icon_blank:after {
    opacity: 1;
  }
}

.products_shop_btns_amazon img {
  width: 50.84746%;
}
@media (min-width: 1024px) {
  .products_shop_btns_amazon img {
    width: 106px;
  }
}

.products_shop_btns_amazon a::after {
  background-image: url(/sports/savas/img/products_detail/logo_amazon_ov.svg);
}
@media (min-width: 1024px) {
  .products_shop_btns_amazon a::after {
    width: 106px;
  }
}

.products_shop_btns_rakuten img {
  width: 51.27119%;
}
@media (min-width: 1024px) {
  .products_shop_btns_rakuten img {
    width: 107px;
  }
}

.products_shop_btns_rakuten a::after {
  background-image: url(/sports/savas/img/products_detail/logo_rakuten_ov.svg);
}
@media (min-width: 1024px) {
  .products_shop_btns_rakuten a::after {
    width: 107px;
  }
}

.products_shop_btns_lohaco img {
  width: 62.71186%;
}
@media (min-width: 1024px) {
  .products_shop_btns_lohaco img {
    width: 128px;
  }
}

.products_shop_btns_lohaco a::after {
  background-image: url(/sports/savas/img/products_detail/logo_lohaco_ov.svg?20240222);
}
@media (min-width: 1024px) {
  .products_shop_btns_lohaco a::after {
    width: 128px;
  }
}

.products_detail {
  opacity: 0; 
  padding-top: 25px;
  -webkit-transition: opacity 0.7s 0.9s;
  transition: opacity 0.7s 0.9s;
}
@media (min-width: 1024px) {
  .products_detail {
    position: relative;
    padding: 40px 4.14286% 0;
    width: 50%;
  }
}
@media (min-width: 1400px) {
  .products_detail {
    padding: 40px 58px 0;
    width: 700px;

    -ms-flex-negative: 0;

        flex-shrink: 0;
  }
}
.is-loaded .products_detail {
  opacity: 1;
}
@media (min-width: 768px) {
  .products_detail.w_bottle {
    min-height: calc(100vh - 80px);
  }
}

.products_shop_btnArea._productTop,
.products_shop_btnArea._productCategory {
  position: fixed;
  z-index: 5;
  bottom: 0;
  left: 0;
  width: 100%;
  -webkit-transition: opacity 0.34s cubic-bezier(0.25, 0.46, 0.45, 0.94), visibility 0.34s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.34s cubic-bezier(0.25, 0.46, 0.45, 0.94), visibility 0.34s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.products_shop_btnArea._productTop.is-hidden,
.products_shop_btnArea._productCategory.is-hidden {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.16s cubic-bezier(0.25, 0.46, 0.45, 0.94), visibility 0.16s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.16s cubic-bezier(0.25, 0.46, 0.45, 0.94), visibility 0.16s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.products_shop_btnArea._productCategory {
  height: 67px;
}
@media (min-width: 768px) {
  .products_shop_btnArea._productCategory {
    height: 68px;
  }
}
.products_shop_btnArea._productCategory .products_shop_btns {
  display: block;
  height: 100%;
}
.products_shop_btnArea._productCategory .products_shop_btns li {
  width: 100%;
  height: 100%;
}
.products_shop_btnArea._productCategory .products_shop_btns a {
  height: 100%;
}
.products_shop_btnArea._productCategory .products_shop_btns a img {
  height: 100%;
}

/* --------------------------------
  intro
-------------------------------- */
@media (min-width: 1024px) {
  .intro {
    margin-bottom: 100px;
  }
}

.hero {
  position: relative;
}
.mv_animation .hero {
  overflow: hidden;
  background: #f5f4f5;
}

.hero_visual img {
  width: 100%;
}

.hero_title {
  position: absolute;
  z-index: 1;
  bottom: 0;
  left: 0;
  padding: 0 20px 6.66667% 20px;
  color: #fff; 
  font-size: 1.9375rem;
  font-weight: bold;
  line-height: 1;
}
@media (min-width: 768px) {
  .hero_title {
    padding: 0 5.71429% 2.57143% 5.71429%;
    font-size: 3rem;
  }
}
.hero_title small {
  display: block;
  margin-top: 10px;
  font-size: 45.16%;
}
.mv_animation .hero_title {
  -webkit-transition: opacity 0.35s 0.85s;
  transition: opacity 0.35s 0.85s;
}
.hero_title > span {
  font-size: 0.8em;
}
@media (min-width: 768px) {
  .hero_title > span {
    font-size: 0.9em;
  }
}

.mv_animation .hero_visual {
  -webkit-transition: all 0.35s 0.1s;
  transition: all 0.35s 0.1s;
}

body:not(.is-loaded) .mv_animation .hero_visual {
  opacity: 0; 
  -webkit-transform: translateY(30px); 
      -ms-transform: translateY(30px); 
          transform: translateY(30px);
}

body:not(.is-loaded) .mv_animation .hero_title {
  opacity: 0;
}

.lead_content {
  padding: 52px 20px 10px;
}
@media (min-width: 768px) {
  .lead_content {
    padding: 105px 6.45161% 0;
  }
}

@media (min-width: 768px) {
  .lead_images_content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 auto;
    max-width: 1256px;
  }
}

.lead_image {
  margin-top: 8px;
  height: 180px;
  background-repeat: no-repeat;
  background-position: center center;
}
@media (max-width: 767.98px) {
  .lead_image {
    background-size: cover;
  }
}
@media (min-width: 768px) {
  .lead_image {
    margin: 0 8px;
    width: calc(50% - 16px);
    height: 328px;
  }
}

/* --------------------------------
  products lineup
-------------------------------- */
.lineup_sort_wrapper {
  margin: 33px auto 0;
}
@media (min-width: 768px) {
  .lineup_sort_wrapper {
    margin-top: 60px;
  }
}

.lineup_sort_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;

  -ms-flex-wrap: wrap;

      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px 12px;
}
@media (min-width: 768px) {
  .lineup_sort_list {
    gap: 10px 20px;
  }
}

.lineup_sort_list_item {
  border-radius: 100vmax;
}
.lineup_sort_list_item > button {
  display: block;
  padding: 9px 13px;
  border: none;
  border-radius: 100vmax;
  outline: none;
  width: 100%;
  height: 100%;
  cursor: pointer;
  background-color: #f5f5f5;
  letter-spacing: 0;
  color: #000;
  font-size: 10px;
  font-weight: bold;
  line-height: 1;

  -webkit-appearance: none;

     -moz-appearance: none;

          appearance: none;
  text-box: trim-both cap alphabetic;
}
@media (min-width: 768px) {
  .lineup_sort_list_item > button {
    font-size: 14px;
  }
}
.lineup_sort_list_item > button.is-selected {
  background-color: #000;
  color: #fff;
}

.lineup {
  margin: 80px 20px 70px;
}
@media (min-width: 768px) {
  .lineup {
    padding: 0 6.45161%;
  }
}
@media (min-width: 1024px) {
  .lineup {
    margin: 18px 0;
  }
}

.lineup_container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin: 68px auto 0; 
  width: 100%;

  -webkit-box-align: center;

      -ms-flex-align: center;

          align-items: center;
  gap: 80px;
}
@media (min-width: 768px) {
  .lineup_container {
    margin-top: 120px;

    gap: 96px;
  }
}
@media (min-width: 1024px) {
  .lineup_container {
    max-width: 1240px;
  }
}

.lineup_list_wrapper {
  width: 100%;
}
.lineup_list_wrapper.is-hidden {
  display: none;
}

.lineup_list_category {
  position: relative;
  padding-bottom: 16px;
  border-bottom: 1px solid #e5e5e5;
  letter-spacing: 0; 
  font-size: 19px;
  font-weight: bold;
  line-height: 1;
}
@media (min-width: 768px) {
  .lineup_list_category {
    padding-bottom: 18px; 
    font-size: 24px;
  }
}
.lineup_list_category::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 21px;
  height: 3px;
  background-color: #000;
}
@media (min-width: 768px) {
  .lineup_list_category::after {
    width: 30px;
    height: 4px;
  }
}

.lineup_list {
  margin-top: 40px;
}
@media (min-width: 1024px) {
  .lineup_list {
    display: -ms-grid;
    display: grid;

    -ms-grid-columns: (1fr)[3];

        grid-template-columns: repeat(3, 1fr);
    gap: 0 16px;
  }
}

.lineup_listItem + .lineup_listItem {
  margin-top: 55px;
}
@media (min-width: 1024px) {
  .lineup_listItem + .lineup_listItem {
    margin-top: 0;
  }
}

@media (min-width: 1024px) {
  .lineup_listItem:nth-child(n + 4) {
    margin-top: 60px;
  }
}

.lineup_listItem a {
  color: #000;
}

@media (min-width: 768px) {
  .lineup_listItem {
    display: -ms-grid;
    display: grid;

    -ms-grid-rows: subgrid;

        grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 0;
  }
}

.lineup_listItem_image_wrapp {
  overflow: hidden; 
  position: relative;
}

.lineup_listItem_icon_new {
  display: -ms-grid;
  display: grid;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 3.125rem;
  height: 1.25rem;
  background: #ae0000;
  color: #fff;
  font-family: "Roboto Condensed", sans-serif; 
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1;

  place-items: center;
}
@media (min-width: 768px) {
  .lineup_listItem_icon_new {
    width: 3.125rem;
    height: 1.25rem;
    font-size: 0.8125rem;
  }
}

.lineup_listItem_image {
  height: 273px;
  -webkit-transition: -webkit-transform 0.35s;
  transition: -webkit-transform 0.35s;
  transition: transform 0.35s;
  transition: transform 0.35s, -webkit-transform 0.35s; 
  background-color: #f5f4f5;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
@media (min-width: 768px) and (max-width: 1023.98px) {
  .lineup_listItem_image {
    height: 328px; 
    background-size: contain;
  }
}
@media (min-width: 1024px) {
  .lineup_listItem_image {
    height: 328px;
  }
  .lineup_listItem a:hover .lineup_listItem_image {
    -webkit-transform: scale(1.03);
        -ms-transform: scale(1.03);
            transform: scale(1.03);
  }
}
.is-touched .lineup_listItem_image {
  -webkit-transform: scale(1.03);
      -ms-transform: scale(1.03);
          transform: scale(1.03);
}
.lineup_listItem_image.img_large {
  background-size: 140%;
}
@media (min-width: 375px) {
  .lineup_listItem_image.img_large {
    background-size: cover;
  }
}
@media (min-width: 1024px) {
  .lineup_listItem_image.img_large {
    background-size: 150%;
  }
}

.lineup_listItem_detail {
  margin-top: 20px;
}

.lineup_listItem_detail_name {
  display: inline-block;
  position: relative;
  font-size: 1rem;
  font-weight: bold;
}
.lineup_listItem_detail_name:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: -4px;
  width: 0;
  height: 1px;
  -webkit-transition: width 0.35s;
  transition: width 0.35s; 
  background: #000;
}
.is-touched .lineup_listItem_detail_name:before {
  left: 0;
  width: 100%;
}
@media (min-width: 1024px) {
  .lineup_listItem_detail_name {
    font-size: 1.125rem;
  }
  .lineup_listItem a:hover .lineup_listItem_detail_name:before {
    left: 0;
    width: 100%;
  }
}
.lineup_listItem_detail_name:after {
  content: "";
  display: inline-block;
  margin-bottom: 2px;
  margin-left: 9px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  width: 8px;
  height: 8px;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.lineup_listItem_detail_name_lineFeed {
  display: none;
}
@media (min-width: 1024px) and (max-width: 1300px) {
  .lineup_listItem_detail_name_lineFeed {
    display: block;
  }
}

.lineup_listItem_detail_txt {
  margin-top: 8px;
  font-size: 0.875rem;
  line-height: 1.64286;
}

.lineup_listItem_lp {
  margin-top: 17px;
  pointer-events: none;
}
.lineup_listItem_lp a {
  display: block;
  width: 90%;
  pointer-events: all;
}
@media (min-width: 1024px) {
  .lineup_listItem_lp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: absolute;
    right: 0;
    bottom: 0;
    margin-top: 0;
    width: 100%;

    -webkit-box-pack: end;

        -ms-flex-pack: end;

            justify-content: flex-end;
  }
  .lineup_listItem_lp a {
    margin-left: 550px;
    width: auto;
    max-width: 506px;
    text-align: right;
  }
}

.lineup_listItem_tag {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 7px;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content; 

  -ms-flex-wrap: wrap; 

      flex-wrap: wrap;
  gap: 10px;
}
@media (min-width: 768px) {
  .lineup_listItem_tag {
    margin-top: 12px;
  }
}
.lineup_listItem_tag li {
  display: -ms-grid;
  display: grid;
  padding: 2px 8px 3px; 
  letter-spacing: 0;
  font-size: 12px;
  font-weight: bold;
  line-height: 1;

  place-items: center;
}
.lineup_listItem_tag .ingredient {
  border: 1px solid #000;
}
.lineup_listItem_tag .category {
  background-color: #efefef;
}

.lineup_listItem_bottom {
  -ms-flex-item-align: end;
      align-self: flex-end;
}

.lineup_listItem_informed {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 17px;

  gap: 16px;
}
.lineup_listItem_informed img {
  height: 35px;
}

.lineup_listItem_link {
  margin-top: 18px;
}
.lineup_listItem_link a {
  display: inline-block;
  position: relative;
  font-weight: bold;
}
.lineup_listItem_link a:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: -4px;
  width: 0;
  height: 1px;
  -webkit-transition: width 0.35s;
  transition: width 0.35s; 
  background: #000;
}
.lineup_listItem_link a.is-touched:before {
  left: 0;
  width: 100%;
}
.lineup_listItem_link a:after {
  content: "";
  display: inline-block;
  margin-left: 9px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  width: 8px;
  height: 8px;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media (min-width: 1024px) {
  .lineup_listItem_link a:after.is-touched:before {
    left: 0;
    width: 100%;
  }
}

.lineup_informed {
  margin: 105px 0 -20px;
}
@media (min-width: 1024px) {
  .lineup_informed {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 120px 0 70px;
    width: 100%; 

    -webkit-box-pack: center; 

        -ms-flex-pack: center; 

            justify-content: center;
    gap: 16px;
  }
}
.lineup_informed::after {
  content: none;
}

.lineup_informed_icon_wrapper {
  margin-top: 17px;
  padding: 32px 37px; 
  border: 2px solid #e5e5e5;
  width: 100%;
}
@media (min-width: 1024px) {
  .lineup_informed_icon_wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 auto;
    padding: 40px 50px 50px;
    border: 1px solid #e5e5e5;
    width: calc(100% / 2 - 36px / 2);
    min-width: 500px; 
    max-width: 614px;

    -webkit-box-pack: center;

        -ms-flex-pack: center;

            justify-content: center;
    gap: 36px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .lineup_informed_icon_wrapper::after {
    content: none;
  }
}

.lineup_informed_icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;

  -webkit-box-align: center;

      -ms-flex-align: center;

          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.lineup_informed_icon img {
  height: 74px;
}
@media (min-width: 1024px) {
  .lineup_informed_icon {
    display: block;
    text-align: right;

    -ms-flex-negative: 0;

        flex-shrink: 0;
  }
  .lineup_informed_icon img {
    height: 89px;
  }
}

.lineup_informed_iconTxt {
  margin-top: 13px; 
  line-height: 1.9;
}
@media (min-width: 1024px) {
  .lineup_informed_iconTxt {
    margin-top: 0;
  }
}
.lineup_informed_iconTxt p {
  width: 100%;
}
.lineup_informed_iconTxt a {
  font-size: 0.8125rem; 
  font-weight: bold;
}
.lineup_informed_iconTxt a::after {
  content: "";
  display: inline-block;
  margin-left: 9px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  width: 8px;
  height: 8px;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media (min-width: 1024px) {
  .lineup_informed_iconTxt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    letter-spacing: -0.04em;
    font-size: 0.875rem;
    line-height: 1.5; 

    -webkit-box-pack: center; 

        -ms-flex-pack: center; 

            justify-content: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .lineup_informed_iconTxt a {
    margin-top: 8px;
    text-align: left; 
    font-size: 0.875rem;
  }
}
.lineup_informed_iconTxt .lineup_listItem_link {
  margin-top: 7px; 
  text-align: center;
}
@media (min-width: 1024px) {
  .lineup_informed_iconTxt .lineup_listItem_link {
    text-align: left;
  }
}

/* --------------------------------
   movie
-------------------------------- */
.lineup_movie_wrapper {
  margin: 77px 20px 54px;
}
@media (min-width: 768px) {
  .lineup_movie_wrapper {
    margin: 24px auto 0;
    padding: 0 15px;
    max-width: 1270px;
  }
}
.lineup_movie_wrapper .lineup_heading {
  text-align: center; 
  font-size: 1.5rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .lineup_movie_wrapper .lineup_heading {
    font-size: 1.875rem;
  }
}
.lineup_movie_wrapper .lineup_heading small {
  display: block;
  margin-top: 11px;
  letter-spacing: 0.05em; 
  font-size: 50%;
  line-height: 1.7;
}
@media (min-width: 768px) {
  .lineup_movie_wrapper .lineup_heading small {
    letter-spacing: 0.07em; 
    line-height: normal;
  }
}

.lineup_movie_content {
  margin-top: 25px;
}
@media (min-width: 768px) {
  .lineup_movie_content {
    margin: 25px auto 0;
  }
}

.lineup_movie {
  overflow: hidden;
  position: relative;
  border: none;
  width: 100%;
  background: transparent;
}
@media (min-width: 768px) {
  .lineup_movie {
    cursor: pointer;
  }
}
.lineup_movie::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.24);
}
.lineup_movie:hover .movie_play {
  background: rgba(255, 255, 255, 0.8);
}
.lineup_movie:hover .movie_play::after {
  border-color: transparent transparent transparent #000;
}

.lineup_movie_inner {
  position: relative;
  padding: 0;
  border: none;
  width: 100%;
  height: 100%;
  cursor: pointer; 
  background: transparent;
}
.lineup_movie_inner img {
  -webkit-transition: -webkit-transform 0.35s;
  transition: -webkit-transform 0.35s;
  transition: transform 0.35s;
  transition: transform 0.35s, -webkit-transform 0.35s;
}
.lineup_movie_inner.is-touched img {
  -webkit-transform: scale(1.03);
      -ms-transform: scale(1.03);
          transform: scale(1.03);
}
.lineup_movie_inner::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: -20px;
  left: 0;
  width: 100%;
  height: 100%;
  background: repeating-linear-gradient(rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.15) 1px, transparent 2px, transparent 4px);
}
@media (min-width: 768px) {
  .lineup_movie_inner::before {
    top: 0;
  }
}

.movie_play {
  display: block;
  overflow: hidden;
  opacity: 0.85;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  margin: auto;
  border: 2px solid #fff;
  border-radius: 50%;
  width: 67px;
  height: 67px;
  -webkit-transition: background 0.35s;
  transition: background 0.35s; 
  white-space: nowrap;
  text-indent: 100%;
  font-size: 0;
}
.is-touched .movie_play {
  background: rgba(255, 255, 255, 0.8);
}
@media (min-width: 768px) {
  .movie_play {
    width: 80px;
    height: 80px;
  }
  .movie_listItem_thumb_btn:hover .movie_play {
    background: rgba(255, 255, 255, 0.8);
  }
}
.movie_play:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 4px;
  margin: auto;
  border-width: 8px 0 8px 18px;
  border-style: solid;
  border-color: transparent transparent transparent #fff;
  width: 0;
  height: 0;
  -webkit-transition: border 0.53s;
  transition: border 0.53s;
}
.is-touched .movie_play:after {
  border-color: transparent transparent transparent #000;
}
@media (min-width: 768px) {
  .movie_play:after {
    border-width: 11px 0 11px 24px;
  }
  .movie_listItem_thumb_btn:hover .movie_play:after {
    border-color: transparent transparent transparent #000;
  }
}

/* --------------------------------
   products nav
-------------------------------- */
.products_nav {
  margin-top: 54px;
}
@media (min-width: 768px) {
  .products_nav {
    margin-top: 92px;
    padding: 0 15px;
  }
}

.products_nav_heading {
  text-align: center; 
  font-size: 1.5rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .products_nav_heading {
    font-size: 1.875rem;
  }
}
.products_nav_heading small {
  display: block;
  margin-top: 14px;
  font-size: 50%;
}

@media (min-width: 768px) {
  .swiper-container {
    margin: 0 auto;
    max-width: 1258px;
  }
}

.products_nav_list {
  margin-top: 32px;
}
@media (min-width: 768px) {
  .products_nav_list {
    margin: 32px auto 0;

    -webkit-box-pack: center;

        -ms-flex-pack: center;

            justify-content: center;
  }
}
.products_nav_list li {
  width: 73.86667%;
}
@media (min-width: 768px) {
  .products_nav_list li {
    margin: 0 9px;
    width: calc(25% - 18px);
  }
}
.products_nav_list li a {
  display: block;
}
.products_nav_list li .is-current {
  pointer-events: none;
}
.products_nav_list li .is-current .products_nav_figure {
  position: relative;
}
.products_nav_list li .is-current .products_nav_figure:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
}

@media (min-width: 1024px) {
  .products_nav_figure {
    overflow: hidden;
  }
  .products_nav_figure img {
    -webkit-transition: -webkit-transform 0.35s;
    transition: -webkit-transform 0.35s;
    transition: transform 0.35s;
    transition: transform 0.35s, -webkit-transform 0.35s;
  }
  .products_nav_list li a:hover .products_nav_figure img {
    -webkit-transform: scale(1.03);
        -ms-transform: scale(1.03);
            transform: scale(1.03);
  }
}

.products_nav_title {
  display: inline-block;
  position: relative;
  margin-top: 8px;
  -webkit-transition: background-size 0.35s;
  transition: background-size 0.35s; 
  background: linear-gradient(0deg, #000 0, #000 2px, #fff 2px, #fff 100%);
  background-repeat: no-repeat;
  background-position: right bottom;
  background-size: 0 1px;
  color: #000;
  font-size: 1rem;
  font-weight: bold;
}
@media (min-width: 768px) {
  .products_nav_title {
    margin-top: 20px;
  }
}
.products_nav_title:after {
  content: "";
  display: inline-block;
  margin-bottom: 2px;
  margin-left: 0.5em;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  width: 8px;
  height: 8px;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
  vertical-align: middle;
}
@media (min-width: 1024px) {
  .products_nav_list li a:hover .products_nav_title {
    background-position: left bottom;
    background-size: 100% 1px;
  }
}
.is-current .products_nav_title {
  background-size: 100% 1px;
}

.products_top_btn {
  margin: 35px auto 70px;
  width: 220px;
}
@media (min-width: 768px) {
  .products_top_btn {
    margin: 40px auto 100px;
    width: 200px;
  }
}

/* --------------------------------
   MODAL
-------------------------------- */
.movie_modal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  visibility: hidden; 
  opacity: 0;
  position: fixed;
  z-index: 10000;
  top: 0;
  left: 0;
  padding: 20px;
  width: 100%;
  height: 100%;
  -webkit-transition: all 0.45s;
  transition: all 0.45s;

  -webkit-box-pack: center;

      -ms-flex-pack: center;

          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.movie_modal.is-active {
  visibility: visible; 
  opacity: 1;
}

.movie_modal_mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
}

.movie_modal_content {
  position: relative;
  width: 100%;
}
@media (min-width: 1024px) {
  .movie_modal_content {
    max-width: 960px;
  }
}

.movie_modal_closeBtn {
  display: block;
  overflow: hidden;
  position: absolute;
  z-index: 1;
  top: -59px;
  right: 0;
  border: 3px solid #fff;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  background: transparent; 
  white-space: nowrap;
  text-indent: 100%;
  font-size: 0;
}
@media (min-width: 1024px) {
  .movie_modal_closeBtn {
    top: -79px;
    width: 50px;
    height: 50px;
    cursor: pointer;
    -webkit-transition: background 0.35s;
    transition: background 0.35s;
  }
  .movie_modal_closeBtn:hover {
    background: #fff;
  }
  .movie_modal_closeBtn:hover:before,
  .movie_modal_closeBtn:hover:after {
    background: #000;
  }
}
.movie_modal_closeBtn:before,
.movie_modal_closeBtn:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 46%;
  height: 3px;
  -webkit-transition: background 0.35s;
  transition: background 0.35s; 
  background: #fff;
}
.movie_modal_closeBtn:before {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.movie_modal_closeBtn:after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.movie_modal_video {
  position: relative;
}