:root {
  --color-base01: #EB1A3B;
  --color-base02: #270707;
}

html {
  font-size: calc(100vw / 100);
  /* 1rem = 1% viewport 宽度 */
}

body {
  font-size: 1rem;
  /* 会随屏幕缩放 */
  color: var(--color-base02);
  font-family: 'gothambook', sans-serif !important;
}

.color-base01 {
  color: var(--color-base01);
}

a {
  text-decoration: none !important;
}

a:hover {
  text-decoration: underline;
}

p {
  font-size: .9rem;
}

.rLink {
  position: fixed;
  bottom: 20%;
  right: 20px;
  z-index: 1001;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.rLink img {
  width: 2rem;
  height: 2rem;
  transition: all 0.2s ease;
}

.rMenu {
  position: fixed;
  top: 20%;
  right: 2%;
  z-index: 1001;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}

.rMenu a {
  transition: all 0.2s ease;
}

.rMenu a.dot {
  display: block;
  width: .6rem;
  height: .6rem;
  border-radius: .8rem;
  border: .2rem solid rgba(255, 255, 255, 1);
}

.rMenu a.dot:hover {
  background-color: #fff;
}

.rMenu a.dot.active {
  background-color: #fff;
  width: .8rem;
  height: .8rem;
}

.rMenu a img {
  width: .8rem;
  object-fit: cover;
}

.bottomTel {
  position: fixed;
  bottom: 10px;
  left: 10px;
  right: 10px;
  z-index: 1000;
  height: 10%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, .6);
  backdrop-filter: blur(5px);
  border-radius: 100px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.6);
}

.bottomTel a {
  color: #fff;
}

.bottomTel .line {
  width: 1px;
  height: 55%;
  background-color: #fff;
  opacity: .3;
}

.bottomTel>img {
  height: 3rem;
}

.bottomTel .erweima {
  height: 100%;
}

.bottomTel .erweima img {
  height: 3.5rem;
  object-fit: cover;
}

@font-face {
  font-family: 'gothamblack';
  src: url('../webfonts/gotham-black-webfont.woff2') format('woff2'),
    url('../webfonts/gotham-black-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

.gothamblack {
  font-family: 'gothamblack', sans-serif;
}

@font-face {
  font-family: 'gothambold';
  src: url('../webfonts/gotham-bold-webfont.woff2') format('woff2'),
    url('../webfonts/gotham-bold-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

.gothambold {
  font-family: 'gothambold', sans-serif;
}

@font-face {
  font-family: 'gothambook';
  src: url('../webfonts/gotham-book-webfont.woff2') format('woff2'),
    url('../webfonts/gotham-book-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

.gothambook {
  font-family: 'gothambook', sans-serif;
}

@font-face {
  font-family: 'gothammedium';
  src: url('../webfonts/gotham-medium-webfont.woff2') format('woff2'),
    url('../webfonts/gotham-medium-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

.gothammedium {
  font-family: 'gothammedium', sans-serif;
}

@font-face {
  font-family: 'gothamxnarrow_black';
  src: url('../webfonts/gothamxnarrow-black-webfont.woff2') format('woff2'),
    url('../webfonts/gothamxnarrow-black-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

.gothamxnarrow_black {
  font-family: 'gothamxnarrow_black', sans-serif;
}

#mainMenu {
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}

#mainMenu .logo img {
  height: 1rem;
  transition: all 0.2s ease;
}

#mainMenu.miniMenu .logo img {
  height: .8rem;
}

#mainMenu .menu a {
  color: var(--color-base02);
  font-size: .8rem;
  transition: all 0.2s ease;
  padding: 1.4rem 0;
  border-bottom: 3px solid #fff;
  font-family: 'gothammedium', sans-serif;
}

#mainMenu.miniMenu .menu a {
  padding: 1rem 0;
}

#mainMenu .menu a:hover {
  color: var(--color-base01);
}

#mainMenu .menu a.active {
  color: var(--color-base01);
  border-bottom: 4px solid var(--color-base01);
}

#mainMenu .langue {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .8rem;
  color: var(--color-base02);
  cursor: pointer;
}

#mainMenu .langue i {
  font-size: .6rem;
}

#mainMenu .dropdown-item {
  display: flex;
  align-items: center;
  gap: .3rem;
}

#mainMenu .dropdown-item strong {
  font-size: .8rem !important;
  color: var(--color-base02);
}

#mainMenu .joinLink {
  background-color: var(--color-base01);
  color: #fff !important;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: .3rem;
  padding: .2rem .8rem;
  font-size: .8rem;
  transition: all 0.2s ease;
  font-family: 'gothammedium', sans-serif;
  border: 1px solid var(--color-base01);
}

#mainMenu .joinLink:hover i {
  /* 摇晃起来 */
  animation: shake 0.2s;
  animation-iteration-count: infinite;
}

#mainMenu .joinLink:hover {
  background-color: #fff;
  color: var(--color-base01) !important;
  border: 1px solid var(--color-base01);
}

@keyframes shake {
  0% {
    transform: rotate(0deg);
  }

  25% {
    transform: rotate(10deg);
  }

  50% {
    transform: rotate(0deg);
  }

  75% {
    transform: rotate(-10deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

.homeSwiper {
  max-height: 100vh;
  position: relative;
}

.homeSwiper::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 50%;
  height: 50%;
  transform: translateX(-50%) translateY(-50%);
  background: url('text01.svg') no-repeat center center;
  background-size: contain;
  z-index: 2;
  pointer-events: none;
}

.homeSwiper .swiper-pagination {
  bottom: 15% !important;
}

.homeSwiper .swiper-pagination-bullet {
  border: 2px solid #fff;
  width: 10px;
  opacity: 1;
  height: 10px;
  background-color: rgba(255, 255, 255, 0);
}

.homeSwiper .swiper-pagination-bullet-active {
  background-color: #fff;
}

.homeSwiper .swiper-slide {
  display: flex;
  justify-content: center;
}

.homeSwiper .swiper-slide img {
  min-width: 100%;
  max-width: 100%;
}

.ibox02 {
  background: linear-gradient(180deg, #EC1A3B 0%, #EF4953 100%);
  position: relative;
}

.ibox02 .container-fluid {
  position: absolute;
  left: 50%;
  top: 40%;
  transform: translateX(-50%) translateY(-50%);
}

.ibox02 .imgs {
  width: 80%;
}

.ibox03 {
  height: 100vh;
  background-color: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

.ibox03 .cpList {
  display: flex;
  flex: 0 0 25%;
  height: 100%;
  transition: all 0.3s ease !important;
  background-size: auto 100%;
  background-position: top center;
}

.ibox03 .cpList h6 {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.ibox03 .cpList h6 img {
  height: 2rem;
}

.ibox03 .cpList:not(:last-child):hover {
  flex: 0 0 30%;
}

.ibox03 .cpList:last-child {
  flex: 0 0 25%;
  transition: none;
}

.ibox03 .class01 {
  background-image: url(milktea.webp);
}

.ibox03 .class02 {
  background-image: url(yofilp.webp);
}

.ibox03 .class03 {
  background-image: url(icecream.webp);
}

.productSwiper {
  position: relative;
}

.productSwiper .swiper-slide>div {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateY(-50%)
}

.productSwiper .swiper-slide picture img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
}

.productSwiper .swiper-slide-active .slide-text {
  animation: fadeInUp .5s ease forwards;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20%);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.productSwiper .productSwiperNext,
.productSwiper .productSwiperPrev {
  width: 30px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  transition: all 0.2s ease;
}

.productSwiper .productSwiperNext:hover,
.productSwiper .productSwiperPrev:hover {
  transform: translateY(-50%) scale(1.2);
}

.productSwiper .productSwiperNext img,
.productSwiper .productSwiperPrev img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: pointer;
  transition: all 0.2s ease;
}

.productSwiper .productSwiperNext {
  left: 4rem;
}

.productSwiper .productSwiperPrev {
  right: 4rem;
}

.ibox04 {
  height: 100vh;
  width: 100%;
  background: url('storeBg.webp') no-repeat center center;
  background-size: cover;
}

.storeSwiper div.swiper-slide {
  transition: all 0.3s ease;
}

.storeSwiper div.swiper-slide:not(.swiper-slide-active) {
  transform: scale(0.8);
}

#storeMenu strong {
  cursor: pointer;
  transition: all 0.3s ease;
  font-family: 'gothambold', sans-serif;
}

#storeMenu strong:hover,
#storeMenu strong.active {
  color: #ffc107 !important;
}

.banner {
  margin-top: 2rem;
  position: relative;
}

.banner picture {
  display: flex;
  align-items: center;
  justify-content: center;
}

.banner img {
  width: 80%;
  margin: 0px auto;
}

.banner h1 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  color: #fff;
  font-size: 3rem;
  z-index: 2;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.6);
  font-family: 'gothambold', sans-serif;
}

.about-box01 {
  background: linear-gradient(320deg, #EF4953 0%, #EC1A3B 50%);
  border-radius: 500px;
}

.foot {
  background-color: #000;
  color: #fff;
  padding-bottom: 200px;
}

.newsDetail img {
  width: 100%;
  margin-bottom: 1rem;
  border-radius: 10px;
}

.newsBody {
  width: 50%;
  margin: 0 auto;
  margin-top: 6rem;
  padding-bottom: 4rem;
}

#mainMenu .dropdown-item small {
  font-size: .7rem !important;
}

.active>.page-link,
.page-link.active {
  background-color: #000 !important;
  border-color: #000 !important;
}


@media (max-width: 768px) {

  .newsBody {
    width: 100%;
    padding: 0 1rem 4rem 1rem;
  }

  .about-box01 {
    border-radius: 0;
    height: auto;
  }

  .foot {
    padding-bottom: 100px;
  }

  html {
    font-size: 14px;
  }

  #mainMenu .logo img {
    height: 15px;
  }

  .homeSwiper::after {
    width: 80%;
    height: 80%;
  }

  .homeSwiper .swiper-pagination {
    bottom: 13% !important;
  }

  .homeSwiper .swiper-slide img {
    height: 100vh;
    object-fit: cover;
  }

  .rLink {
    top: 40%;
    right: 1rem;
    gap: 1rem;
  }

  .rLink img {
    width: 3rem;
  }

  .mBottomTel {
    height: 3rem;
    width: 50%;
    background-color: rgba(0, 0, 0, .6);
    border: 2px solid #fff;
    position: fixed;
    z-index: 1000;
    bottom: 1rem;
    left: 25%;
    border-radius: 3rem;
    backdrop-filter: blur(5px);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: space-between;
    overflow: hidden;
    align-items: center;
    color: #fff;
    padding: 0 1rem;
    animation: bounce 2s infinite;
  }

  @keyframes bounce {

    0%,
    100% {
      transform: scale(1);
    }

    50% {
      transform: scale(1.1);
    }
  }

  .mBottomTel::after {
    content: "";
    position: absolute;
    left: -50px;
    top: 0;
    width: 50px;
    height: 100px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 100%);
    animation: shine 2s infinite;
    transform: skewX(-20deg);
    z-index: 3;
    mix-blend-mode: screen;
  }

  .mBottomTel img {
    height: 50%;
  }

  @keyframes shine {
    0% {
      left: -50px;
    }

    100% {
      left: 100%;
    }
  }

  #mainMenu .langue {
    border-left: none;
  }

  .mobileMenu {
    width: 50vw !important;
  }

  #mobileMenuList a {
    color: var(--color-base02);
    padding: .2em 0;
    width: 100%;
    font-weight: bold;
  }

  .ibox02 .container-fluid {
    position: relative;
    left: 0%;
    top: 0%;
    transform: translateX(0%) translateY(0%);
  }

  .ibox02 .imgs {
    width: 100%;
  }

  .ibox03 {
    flex-wrap: wrap;
    flex-direction: row;
  }

  .ibox03 .cpList {
    display: flex;
    height: 30vh;
    flex: 0 0 33.33%;
  }

  .ibox03 .cpList:hover {
    flex: 0 0 33.33% !important;
  }

  .ibox03 .cpList:last-child {
    flex: 0 0 100%;
    height: auto;
    transition: none;
  }

  .ibox03 .cpList:last-child:hover {
    flex: 0 0 100% !important;
  }

  .productSwiper .productSwiperNext,
  .productSwiper .productSwiperPrev {
    width: 20px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    transition: all 0.2s ease;
  }

  .productSwiper .productSwiperNext {
    left: .5rem;
  }

  .productSwiper .productSwiperPrev {
    right: .5rem;
  }

  .ibox04 {
    height: auto;
    padding-bottom: 5rem;
  }

  .mobileTel small {
    font-size: .7rem !important;
    line-height: .7rem;
  }

  .productSwiper .swiper-slide>div {
    left: 0%;
    top: 25%;
  }
}

/* @media (min-width: 769px) and (max-width: 1600px) {} */