:root {
  --color-main: #ba152d;
  --color-accent: #3a3f8e;
  --color-accent-dark: #1c2652;
}

/* ************************************************************************
   ************************************************************************

    COMMON SETTINGS

   ************************************************************************
   ************************************************************************ */
/* ------------------------------
    RESPONSIVE SETTINGS
  ------------------------------ */
/* ------------------------------
    FONT
  ------------------------------ */
@font-face {
  font-family: "quentin";
  src: url("../fonts/Quentin.otf") format("opentype");
}
@font-face {
  font-family: "neueplak";
  src: url("../fonts/NeuePlak-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "neueplak";
  src: url("../fonts/NeuePlak-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "neueplak";
  src: url("../fonts/NeuePlak-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeuePlakCondensed";
  src: url("../fonts/NeuePlakCondensed-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeuePlakCondensed";
  src: url("../fonts/NeuePlakCondensed-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeuePlakCondensed";
  src: url("../fonts/NeuePlakCondensed-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "neueplak-wide";
  src: url("../fonts/NeuePlak-WideBold.eot");
  src: local("Neue Plak Wide Bold"), local("NeuePlak-WideBold"), url("../fonts/NeuePlak-WideBold.eot?#iefix") format("embedded-opentype"), url("../fonts/NeuePlak-WideBold.woff2") format("woff2"), url("../fonts/NeuePlak-WideBold.woff") format("woff"), url("../fonts/NeuePlak-WideBold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "neueplak-wide";
  src: url("../fonts/NeuePlak-WideBlack.eot");
  src: local("Neue Plak Wide Black"), local("NeuePlak-WideBlack"), url("../fonts/NeuePlak-WideBlack.eot?#iefix") format("embedded-opentype"), url("../fonts/NeuePlak-WideBlack.woff2") format("woff2"), url("../fonts/NeuePlak-WideBlack.woff") format("woff"), url("../fonts/NeuePlak-WideBlack.ttf") format("truetype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
/* ------------------------------
    COLOR SETTINGS
  ------------------------------ */
/* ------------------------------
    MIXIN
  ------------------------------ */
/* ------------------------------
    KEYFRAMES
  ------------------------------ */
@-webkit-keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@-webkit-keyframes loopClY {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@keyframes loopClY {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@-webkit-keyframes loopClYRv {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
}
@keyframes loopClYRv {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
}
@-webkit-keyframes scrbarY {
  0% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: center top;
            transform-origin: center top;
  }
  45% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: center top;
            transform-origin: center top;
  }
  55% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
  100% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
}
@keyframes scrbarY {
  0% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: center top;
            transform-origin: center top;
  }
  45% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: center top;
            transform-origin: center top;
  }
  55% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
  100% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
}
@-webkit-keyframes textGradient {
  0% {
    color: #81adef;
  }
  20% {
    color: #0090f1;
  }
  40% {
    color: #4746f3;
  }
  60% {
    color: #1ccaee;
  }
  100% {
    color: #81adef;
  }
}
@keyframes textGradient {
  0% {
    color: #81adef;
  }
  20% {
    color: #0090f1;
  }
  40% {
    color: #4746f3;
  }
  60% {
    color: #1ccaee;
  }
  100% {
    color: #81adef;
  }
}
.tagSlider {
  width: 100%;
  overflow: hidden;
}
.tagSlider__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-animation: loopCl 80000ms linear infinite both;
          animation: loopCl 80000ms linear infinite both;
}
.tagSlider__wrapper.isMiddle {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-animation: loopClRv 80000ms linear infinite both;
          animation: loopClRv 80000ms linear infinite both;
}
@media screen and (min-width: 320px) {
  .tagSlider__wrapper.isMiddle {
    margin: 6px 0;
  }
}
@media screen and (min-width: 600px) {
  .tagSlider__wrapper.isMiddle {
    margin: 6px 0;
  }
}
.tagSlider__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 320px) {
  .tagSlider__listitem {
    margin-right: 6px;
  }
}
@media screen and (min-width: 600px) {
  .tagSlider__listitem {
    margin-right: 6px;
  }
}
.tagSlider__listlink {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border: solid 1px black;
  background: white;
  padding-top: 2px;
  -webkit-transition: -webkit-transform 300ms ease;
  transition: -webkit-transform 300ms ease;
  transition: transform 300ms ease;
  transition: transform 300ms ease, -webkit-transform 300ms ease;
}
@media screen and (min-width: 320px) {
  .tagSlider__listlink {
    width: 16.8rem;
    height: 5.4rem;
    gap: 4px;
    border-radius: 6px 0 6px 0;
  }
}
@media screen and (min-width: 600px) {
  .tagSlider__listlink {
    width: 16.8rem;
    height: 5.4rem;
    gap: 4px;
    border-radius: 12px 0 12px 0;
  }
}
.tagSlider__listlink:hover {
  z-index: 1;
  -webkit-transform: scale(0.92);
          transform: scale(0.92);
}
.tagSlider__listicon svg {
  display: block;
}
@media screen and (min-width: 320px) {
  .tagSlider__listicon svg {
    width: 2.2rem;
    height: 2.2rem;
  }
}
@media screen and (min-width: 600px) {
  .tagSlider__listicon svg {
    width: 2.2rem;
    height: 2.2rem;
  }
}
.tagSlider__listlabel {
  font-weight: 700;
  padding-bottom: 3px;
}
@media screen and (min-width: 320px) {
  .tagSlider__listlabel {
    font-size: 2.2rem;
  }
}
@media screen and (min-width: 600px) {
  .tagSlider__listlabel {
    font-size: 2.2rem;
  }
}

.tagSlider__listitem:nth-child(8n+1) .tagSlider__listicon {
  color: #ef5b00;
}
.tagSlider__listitem:nth-child(8n+2) .tagSlider__listicon {
  color: #38c8bb;
}
.tagSlider__listitem:nth-child(8n+3) .tagSlider__listicon {
  color: #ff6680;
}
.tagSlider__listitem:nth-child(8n+4) .tagSlider__listicon {
  color: #9b2f9b;
}
.tagSlider__listitem:nth-child(8n+5) .tagSlider__listicon {
  color: #f7b916;
}
.tagSlider__listitem:nth-child(8n+6) .tagSlider__listicon {
  color: #4c7ee8;
}
.tagSlider__listitem:nth-child(8n+7) .tagSlider__listicon {
  color: #ff4f00;
}
.tagSlider__listitem:nth-child(8n+8) .tagSlider__listicon {
  color: #ffbf24;
}
.tagSlider__listicon {
  color: #ef5b00;
}
.tagSlider__listicon svg {
  display: block;
}
.tagSlider__listicon svg path {
  fill: currentColor;
  stroke: currentColor;
}

.lowerHero {
  position: relative;
  color: white;
  overflow: hidden;
}
@media screen and (min-width: 320px) {
  .lowerHero {
    padding: 22rem 0 32px;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero {
    padding: 22rem 0 32px;
  }
}
.lowerHero__inner {
  margin: 0 auto;
}
@media screen and (min-width: 320px) {
  .lowerHero__inner {
    width: 90%;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero__inner {
    width: 90%;
  }
}
.lowerHero__label {
  font-family: var(--font-en);
  font-weight: 900;
  line-height: 1;
}
@media screen and (min-width: 320px) {
  .lowerHero__label {
    font-size: 16.4rem;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero__label {
    font-size: 16.4rem;
  }
}
.lowerHero__label span {
  display: block;
}
@media screen and (min-width: 320px) {
  .lowerHero__label.--soratabi {
    font-size: 3.2rem;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero__label.--soratabi {
    font-size: 3.2rem;
  }
}
.lowerHero__title {
  margin-top: 10px;
  font-weight: 900;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 320px) {
  .lowerHero__title {
    font-size: 3.2rem;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero__title {
    font-size: 3.2rem;
  }
}
.lowerHero__title.--soratabi {
  line-height: 1.24;
  margin-bottom: 24px;
  letter-spacing: 0;
}
@media screen and (min-width: 320px) {
  .lowerHero__title.--soratabi {
    font-size: 8rem;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero__title.--soratabi {
    font-size: 8rem;
  }
}
.lowerHero__price {
  font-family: var(--font-en);
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.24;
}
@media screen and (min-width: 320px) {
  .lowerHero__price {
    font-size: 6.4rem;
    margin: 8px 0 -8px;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero__price {
    font-size: 6.4rem;
    margin: 8px 0 -8px;
  }
}
.lowerHero__lead {
  margin-top: 8px;
  font-weight: 700;
  line-height: 1.9;
  font-size: clamp(1.4rem, 1.5vw, 1.7rem);
}
.lowerHero img {
  position: absolute;
}
@media screen and (min-width: 320px) {
  .lowerHero img {
    inset: auto -20rem 4rem auto;
    width: 72%;
  }
}
@media screen and (min-width: 600px) {
  .lowerHero img {
    inset: auto -20rem 4rem auto;
    width: 72%;
  }
}

.topSearch__vid {
  background: rgba(var(--color-pk)/0.12);
}
@media screen and (min-width: 320px) {
  .topSearch__vid {
    border-radius: 16px 16px 0 0;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vid {
    border-radius: 32px 32px 0 0;
  }
}
@media screen and (min-width: 320px) {
  .topSearch__vidMain {
    padding: 0 5vw;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidMain {
    padding: 0 5vw;
  }
}
.topSearch__vidMaininner {
  background: rgb(var(--color-pk));
}
@media screen and (min-width: 320px) {
  .topSearch__vidMaininner {
    border-radius: 32px;
    padding: 3.5vw;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidMaininner {
    border-radius: 32px;
    padding: 3.5vw;
  }
}
.topSearch__vidList {
  display: grid;
}
@media screen and (min-width: 320px) {
  .topSearch__vidList {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidList {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
}
.topSearch__vidListitem {
  background: rgb(var(--color-wh));
}
@media screen and (min-width: 320px) {
  .topSearch__vidListitem {
    border-radius: 12px;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidListitem {
    border-radius: 12px;
  }
}
.topSearch__vidLink {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  font-weight: 700;
}
@media screen and (min-width: 320px) {
  .topSearch__vidLink {
    padding: 32px;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidLink {
    padding: 32px;
  }
}
.topSearch__vidLink:hover .topSearch__vidFigure img {
  -webkit-transform: scale(1.04);
          transform: scale(1.04);
}
.topSearch__vidLink:hover .topSearch__vidFigure .icon {
  opacity: 0;
}
.topSearch__vidFigure {
  position: relative;
  width: 100%;
}
.topSearch__vidFigure .img {
  position: relative;
  width: 100%;
}
.topSearch__vidFigure .imgWrapper {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 66.67%;
  overflow: hidden;
}
@media screen and (min-width: 320px) {
  .topSearch__vidFigure .imgWrapper {
    border-radius: 12.4rem;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidFigure .imgWrapper {
    border-radius: 12.4rem;
  }
}
.topSearch__vidFigure .imgWrapper img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 400ms ease;
  transition: -webkit-transform 400ms ease;
  transition: transform 400ms ease;
  transition: transform 400ms ease, -webkit-transform 400ms ease;
}
.topSearch__vidFigure .icon {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: opacity 300ms ease;
  transition: opacity 300ms ease;
}
.topSearch__vidFigure .icon svg {
  display: block;
  fill: rgb(var(--color-yt-red));
}
@media screen and (min-width: 320px) {
  .topSearch__vidFigure .icon svg {
    width: 40%;
    height: 40%;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidFigure .icon svg {
    width: 40%;
    height: 40%;
  }
}
.topSearch__vidFigure figcaption {
  color: rgb(var(--color-pk));
  line-height: 1.24;
  margin: 18px 0 4px;
}
@media screen and (min-width: 320px) {
  .topSearch__vidFigure figcaption {
    font-size: 2.8rem;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidFigure figcaption {
    font-size: 2.8rem;
  }
}
@media screen and (min-width: 320px) {
  .topSearch__vidDesc {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 600px) {
  .topSearch__vidDesc {
    font-size: 1.8rem;
  }
}

.cButton__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 320px) {
  .cButton__wrapper {
    padding: 24px 0;
  }
}
@media screen and (min-width: 600px) {
  .cButton__wrapper {
    padding: 24px 0;
  }
}

.cButton {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1.4rem;
  overflow: hidden;
  border-radius: 999px;
  background: #fff;
  color: #251e1c;
  text-decoration: none;
  -webkit-box-shadow: 0 1.2rem 3rem rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(var(--color-aqua)/0.12);
          box-shadow: 0 1.2rem 3rem rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(var(--color-aqua)/0.12);
  -webkit-transition: -webkit-transform 0.28s ease, -webkit-box-shadow 0.28s ease;
  transition: -webkit-transform 0.28s ease, -webkit-box-shadow 0.28s ease;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
  transition: transform 0.28s ease, box-shadow 0.28s ease, -webkit-transform 0.28s ease, -webkit-box-shadow 0.28s ease;
}
@media screen and (min-width: 320px) {
  .cButton {
    padding: 6px 6px 6px 32px;
  }
}
@media screen and (min-width: 600px) {
  .cButton {
    padding: 6px 6px 6px 32px;
  }
}
.cButton::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(var(--color-aqua)/0.12), rgba(255, 255, 255, 0));
  opacity: 0;
  -webkit-transition: opacity 0.28s ease;
  transition: opacity 0.28s ease;
}
.cButton:hover {
  -webkit-transform: translateY(-0.3rem);
          transform: translateY(-0.3rem);
  -webkit-box-shadow: 0 1.8rem 4rem rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(var(--color-aqua)/0.2);
          box-shadow: 0 1.8rem 4rem rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(var(--color-aqua)/0.2);
}
.cButton:hover::before {
  opacity: 1;
}
.cButton:hover .cButton__icon {
  -webkit-transform: translateX(0.4rem);
          transform: translateX(0.4rem);
}
.cButton__label {
  position: relative;
  z-index: 1;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1;
}
@media screen and (min-width: 320px) {
  .cButton__label {
    font-size: 1.6rem;
    padding-right: 16px;
  }
}
@media screen and (min-width: 600px) {
  .cButton__label {
    font-size: 2.2rem;
    padding-right: 16px;
  }
}
.cButton__icon {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgb(var(--color-aqua));
  color: #fff;
  -webkit-transition: -webkit-transform 0.28s ease;
  transition: -webkit-transform 0.28s ease;
  transition: transform 0.28s ease;
  transition: transform 0.28s ease, -webkit-transform 0.28s ease;
}
@media screen and (min-width: 320px) {
  .cButton__icon {
    width: 4.2rem;
    height: 4.2rem;
  }
}
@media screen and (min-width: 600px) {
  .cButton__icon {
    width: 6.4rem;
    height: 6.4rem;
  }
}
.cButton__icon svg {
  width: 56%;
  height: 56%;
  display: block;
}/*# sourceMappingURL=components.css.map */