.wrapper:before, .wrapper:after, .wrapper .frame_bottom, #explain .btn, #gift > *, .giftLink::before {
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;
}

.stroke {
  text-shadow: -2px -2px 0 white, -2px -1px 0 white, -2px 0px 0 white, -2px 1px 0 white, -2px 2px 0 white, -1px -2px 0 white, -1px -1px 0 white, -1px 0px 0 white, -1px 1px 0 white, -1px 2px 0 white, 0px -2px 0 white, 0px -1px 0 white, 0px 0px 0 white, 0px 1px 0 white, 0px 2px 0 white, 1px -2px 0 white, 1px -1px 0 white, 1px 0px 0 white, 1px 1px 0 white, 1px 2px 0 white, 2px -2px 0 white, 2px -1px 0 white, 2px 0px 0 white, 2px 1px 0 white, 2px 2px 0 white;
}

html,
body,
#main {
  background: #9d76dc;
  color: #230e11;
}

#header {
  transition: all 0.8s ease-out 0.3s !important;
  background: #153899;
}

#footer {
  margin-top: 0.5em;
}
#footer::after {
  background: #153899;
}

@media (max-width: 1200px) {
  #socials {
    left: 0;
  }
}
.no-listyStyle {
  margin: 0;
  padding: 0;
}
.no-listyStyle li {
  list-style: none;
}

img {
  max-width: 100%;
  display: block;
  width: auto;
  height: auto;
  margin: 0 auto;
}

.w100 {
  width: 100%;
}

.color-highlight {
  color: #ffec1b !important;
}

.color-red {
  color: #d0001f !important;
}

.fw-b {
  font-weight: bold !important;
}

.t-c {
  text-align: center !important;
}

.mt-0 {
  margin-top: 0 !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.mx-a {
  margin-right: auto;
  margin-left: auto;
}

.relative {
  position: relative;
}

.z1 {
  z-index: 1;
}

.z2 {
  z-index: 2;
}

.z3 {
  z-index: 3;
}

.btn {
  outline: none;
  border: none;
  background-color: transparent;
  box-shadow: none;
  cursor: pointer;
  position: relative;
}

select {
  /* Reset */
  appearance: none;
  border: 0;
  outline: 0;
  font: inherit;
  /* Personalize */
  width: 8em;
  height: 2.1em;
  padding: 0 2em 0 0.4em;
  color: #230e11;
  font-weight: bold;
  font-size: 0.55em;
  color: #fff;
  cursor: pointer;
  border: 2px solid rgba(255, 255, 255, 0.8);
  border-radius: 0.2em;
  position: relative;
  margin: 0;
  /* Remove focus outline */
  /* Remove IE arrow */
}
select option {
  color: #222;
  font-weight: bold;
}
select:focus {
  outline: none;
}
select::-ms-expand {
  display: none;
}
@media (max-width: 768px) {
  select {
    width: 8.5em;
    border: 2px solid #230e11;
    box-shadow: none;
  }
}

/*==============*/
/* PAGE CONTENT */
.bg-area {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 16em);
  z-index: -5;
  width: 1920px;
  margin: 0 auto;
  overflow: hidden;
  user-select: none;
  pointer-events: none;
}
@media (max-width: 1000px) {
  .bg-area {
    width: 192vw;
  }
}
.bg-area .repeat {
  flex: 1 1 auto;
  background-repeat: repeat-y;
  background-position: top center;
  background-size: 100% auto;
  position: relative;
  z-index: 1;
}
.bg-area img {
  width: 100%;
  display: block;
  object-fit: cover;
  position: relative;
}

#article {
  width: 100%;
  max-width: 970px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 768px) {
  #article {
    padding-left: 0;
    padding-right: 0;
  }
}

#main-banner {
  width: 100%;
  position: relative;
  padding: 8.6em 15px 0;
  z-index: 6;
}
#main-banner h1 {
  width: 100%;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
}

.dec {
  position: absolute;
}

section {
  width: 100%;
  margin: 0 auto;
}
section p,
section ul {
  font-size: .5em;
  font-weight: bold;
  line-height: 1.35;
  padding: 0 0.3em;
  margin-bottom: 0.5em;
  margin-top: 0;
}
@media (max-width: 768px) {
  section p,
  section ul {
    font-size: 0.55em;
  }
}

.content-area {
  width: 100%;
  max-width: 970px;
  padding: 1.8em 0.5em 0.3em 0.5em;
  margin-bottom: 1em;
  position: relative;
  z-index: 1;
}
.content-area:before, .content-area:after {
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% auto;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}
.content-area:before {
  width: 105%;
  height: 4.8em;
  background-image: url("../../../img/Event/Integral-2023/border-top%EF%B9%96v=2.png");
  top: -2.8em;
  left: -2.5%;
  z-index: 4;
}
.content-area:after {
  width: 92%;
  height: 95%;
  top: 0;
  background-image: url("../../../img/Event/Integral-2023/frame_body%EF%B9%96v=2.jpg");
  z-index: 0;
}
@media (max-width: 767px) {
  .content-area:after {
    top: -1em;
  }
}

.wrapper {
  width: 100%;
  position: relative;
  z-index: 2;
}
.wrapper:before, .wrapper:after, .wrapper .frame_bottom {
  content: "";
  display: block;
  position: absolute;
  margin: auto;
  z-index: 6;
}
.wrapper:before, .wrapper:after {
  width: 18%;
  top: -2.9em;
  height: 130%;
  background-position: top;
}
.wrapper:before {
  left: -0.5em;
}
.wrapper:after {
  right: -0.5em;
  transform: scaleX(-1);
}
.wrapper .frame_bottom {
  width: 100%;
  height: 4.5em;
  bottom: -1.7em;
  background-image: url("../../../img/Event/Integral-2023/frame_bottom.png");
  z-index: 0;
}

#explain {
  margin-top: 0.1em;
  z-index: 4;
}
#explain .wrapper:before, #explain .wrapper:after {
  background-image: url("../../../img/Event/Integral-2023/curtain-1.png");
}
#explain .explain-img {
  position: relative;
  z-index: 1;
}
#explain .explain-store {
  width: 69%;
}
@media (max-width: 768px) {
  #explain .explain-store {
    margin-top: 0.2em;
    margin-bottom: 0.2em;
  }
}
#explain .prize {
  width: 44%;
  position: relative;
}
#explain .btn {
  transition: all 0.2s;
}
#explain .btn:hover {
  animation: none;
  filter: drop-shadow(0 0 0.2em white) brightness(1.1);
}
#explain .btn-play {
  width: 48%;
  height: auto;
  padding-bottom: 17%;
  right: 1.6em;
  top: 0.2em;
  position: absolute;
  z-index: 3;
  animation: gifPlay 1.2s infinite step-end;
}
#explain .btn-play:hover {
  background-image: url("../../../img/Event/Integral-2023/btn-play_02.png");
}
#explain .btn-goMore {
  z-index: 1;
  display: block;
  width: max-content;
  margin-top: 0.2em;
  width: 6.5em;
  height: 2.85em;
  position: relative;
  background: url(../../../img/Event/Integral-2023/btn-play.png) top/100% auto no-repeat;
  transition: transition 1s, opacity 1s, filter .1s;
  animation: btnPlay 1.2s infinite step-end;
}
#explain .btn-goMore:hover, #explain .btn-goMore:active {
  background-position: bottom;
}

@keyframes btnPlay {
  0% {
    background-position: top;
  }

  50% {
    background-position: bottom;
  }
}
.list-winners {
  padding: 0 0 0.6em;
  margin-bottom: 0.1em;
  position: relative;
  z-index: 2;
}
.list-winners .data-box {
  width: 100%;
  padding: 0.7em 0.5em 0 0.5em;
}
.list-winners .data-box h3 {
  margin-right: 15px;
}
.list-winners .data-box p {
  margin-top: 8px;
  margin-bottom: 25px;
}
@media (max-width: 768px) {
  .list-winners .data-box h3 {
    width: 50%;
    margin-right: 5px;
    display: inline-block;
    text-align: right;
    position: relative;
    top: -3px;
  }
}

.list-name {
  width: 100%;
  margin-top: 0.3em;
  margin-bottom: 0.3em;
  position: relative;
  z-index: 1;
}
.list-name .box {
  width: 88%;
  padding: 0.3em 0 0.5em 0.3em;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 2;
  overflow: hidden;
}
.list-name ul {
  width: 100% !important;
  position: relative;
  z-index: 2;
}
.list-name ul li {
  width: 48.5%;
  text-align: center;
  display: inline-block;
  padding: 0.5em;
  background-color: #fff;
  border-radius: 99em;
  margin-bottom: 0.5em;
}
@media (max-width: 768px) {
  .list-name ul li {
    border-width: 2px;
  }
}
.mobile .list-name ul {
  max-height: 210px;
  overflow-y: scroll;
}
.list-name .scroll-wrapper {
  width: 100% !important;
  max-width: none !important;
  max-height: 450px;
  height: auto;
}
@media (max-width: 600px) {
  .list-name .scroll-wrapper {
    max-height: 350px;
  }
}
.list-name .scroll-wrapper ul {
  width: 100% !important;
}
.list-name .scrollbar-inner {
  padding-right: 1.1em;
}
.list-name .scrollbar-inner .scroll-element {
  width: 0.3em;
  right: 0;
  height: calc(100% - 6px);
}
.list-name .scrollbar-inner .scroll-element:hover .scroll-bar {
  background-color: #4557e2;
}
.list-name .scrollbar-inner .scroll-element_outer {
  border-radius: 0;
}
.list-name .scrollbar-inner .scroll-element_track {
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 0;
  opacity: 1;
}
.list-name .scrollbar-inner .scroll-bar {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  background-color: #5280de;
  border-radius: 0;
  opacity: 1;
  cursor: pointer;
}

#list-money {
  margin-bottom: 0.5em;
  z-index: 3;
}
#list-money .wrapper:before, #list-money .wrapper:after {
  background-image: url("../../../img/Event/Integral-2023/curtain-2.png");
}
#list-money .frame_bottom {
  bottom: -1.2em;
}
#list-money .data-box select {
  background: url("../../../img/Event/Integral-2023/select-arrow.png") no-repeat right 0.4em center/1em, #1627a1;
}
#list-money .data-box select option {
  background-color: #4784ff;
}
#list-money .data-box p {
  color: #1a2abc;
}
#list-money .list-name ul li {
  color: #1a2abc;
  border: 3px solid #0582ff;
}

#list-phone .wrapper:before, #list-phone .wrapper:after {
  height: 180%;
  background-image: url("../../../img/Event/Integral-2023/curtain-3.png");
}
#list-phone .wrapper.is-long:before, #list-phone .wrapper.is-long:after {
  background-size: auto 100%;
  height: calc(100% + 3.5em);
  background-image: url("../../../img/Event/Integral-2023/curtain-1.png");
}
#list-phone .data-box select {
  background: url("../../../img/Event/Integral-2023/select-arrow2.png") no-repeat right 0.4em center/1em, #a11616;
}
#list-phone .data-box select option {
  background-color: #ff7a7a;
}
@media (max-width: 768px) {
  #list-phone .data-box h3 {
    width: 30%;
  }
  #list-phone .data-box h3 img {
    display: inline-flex;
  }
}
#list-phone .list-name {
  margin-bottom: 0;
  z-index: 5;
}
#list-phone .list-name .box {
  padding-bottom: 0;
}
#list-phone .list-name ul li {
  color: #a11616;
  border: 3px solid #ff7a7a;
}
#list-phone .list-name p {
  text-align: center;
  font-size: 0.5em;
  position: relative;
  z-index: 2;
}
@media (max-width: 768px) {
  #list-phone .list-name p {
    font-size: 0.6em;
  }
}

.notice-prize {
  width: 100%;
  padding-top: 0.3em;
  padding-bottom: 1.3em;
  position: relative;
}
.notice-prize p {
  font-size: .6em;
  position: relative;
  margin-top: 0.6em;
  z-index: 2;
}
.notice-prize a {
  color: #d0001f;
}

#gift {
  width: 79%;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  bottom: -0.6em;
  z-index: 4;
}
#gift > * {
  position: relative;
}
#gift p {
  color: #fff;
  font-size: 0.7em;
  margin: 0;
  top: -0.2em;
}
#gift p .small {
  font-size: 0.85em;
  font-weight: normal;
}
#gift .gift-exhibit {
  width: 88%;
  padding-top: 15px;
}

.giftLink {
  display: inline-block;
  color: #ffec1b;
  position: relative;
}
.giftLink::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../../../img/Event/Integral-2023/dec-hand.png");
  width: 2.5em;
  height: 2.5em;
  bottom: -172%;
  right: -40%;
  z-index: 2;
  animation: aniHand 1.2s infinite step-end;
}

#rules {
  padding-left: 0.3em;
  padding-right: 0.3em;
  padding-bottom: 1em;
  margin-bottom: 0.5em;
}
@media (max-width: 768px) {
  #rules {
    margin-bottom: 0;
  }
}
#rules::before {
  content: "";
  display: block;
  position: absolute;
  background-color: #cfabf3;
  width: 97%;
  height: calc(100% + 5em);
  left: 1.5%;
  top: -5.5em;
  z-index: -1;
  border-bottom-left-radius: 0.4em;
  border-bottom-right-radius: 0.4em;
}
#rules h3 {
  font-size: 0.7em;
  font-weight: bold;
  width: 100%;
  text-align: center;
}
#rules ul,
#rules ol {
  font-size: .6em;
  font-weight: normal;
  text-align: justify;
  padding-left: 2em;
  padding-right: 1em;
  margin: .55em auto;
  line-height: 1.4;
}
#rules ul li,
#rules ol li {
  margin-bottom: 0.2em;
}
#rules ul li a,
#rules ol li a {
  color: #d0001f;
}
@media (max-width: 1000px) {
  #rules ul,
  #rules ol {
    font-size: 0.6em;
  }
}

/* ==================== */
/* JS ANIMATION CLASSES */
@keyframes aniHand {
  0%,
  100% {
    transform: translateX(0) translateY(0);
  }

  50% {
    transform: translateX(-5px) translateY(-4px);
  }
}
.fade-scale {
  transform: scale(1.3);
  opacity: 0;
  transition: opacity 0.8s, transform 0.7s ease-out;
}
.fade-scale.faded {
  transform: scale(1);
  opacity: 1;
}

.fade-down {
  transform: translateY(-3em);
  opacity: 0;
  transition: opacity 1s, transform 0.7s ease-out;
}
.fade-down.faded {
  transform: none;
  opacity: 1;
}

.fade-up {
  transform: translateY(2em);
  opacity: 0;
  transition: opacity 1s, transform 1s;
}
.fade-up.faded {
  transform: none;
  opacity: 1;
}

.fade-in {
  opacity: 0;
  transition: opacity 1.6s;
}
.fade-in.faded {
  opacity: 1;
}

.fade-left {
  opacity: 0;
  transform: translateZ(0) translateX(-100px);
  transition: opacity 1s, transform 1s;
}
.fade-left.faded {
  opacity: 1;
  transform: translateZ(0) translateX(0);
}

.fade-right {
  opacity: 0;
  transform: translateZ(0) translateX(100px);
  transition: opacity 1s, transform 1s;
}
.fade-right.faded {
  opacity: 1;
  transform: translateZ(0) translateY(0);
}

.d2 {
  transition-delay: 0.2s;
}

.d3 {
  transition-delay: 0.3s;
}

.d4 {
  transition-delay: 0.4s;
}

.d5 {
  transition-delay: 0.5s;
}

.d6 {
  transition-delay: 0.6s;
}

/*=====================*/
/* KEYFRAMES AND MEDIA */
@keyframes gifPlay {
  0% {
    background-image: url("../../../img/Event/Integral-2023/btn-play_01.png");
  }

  50% {
    background-image: url("../../../img/Event/Integral-2023/btn-play_02.png");
  }

  100% {
    background-image: url("../../../img/Event/Integral-2023/btn-play_01.png");
  }
}
@keyframes fade {
  0% {
    opacity: 0;
    backdrop-filter: blur(0);
  }

  to {
    opacity: 1;
    backdrop-filter: blur(8px);
  }
}
@keyframes fade-in-top {
  0% {
    transform: translateY(-50px);
    opacity: 0;
  }

  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

/*# sourceMappingURL=main.css.map */