@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&family=Noto+Serif+TC:wght@200;300;400;500;600;700;900&display=swap");
html,
body {
  font-family: "Noto Sans TC", sans-serif;
  overflow-x: hidden;
  min-width: auto;
}

#content {
  color: #000000;
  font-size: 18px;
  line-height: 1.6;
  background: #0f171e;
}
@media screen and (max-width: 640px) {
  #content {
    font-size: 14px;
  }
}
#content .inner {
  width: auto;
  max-width: 1110px;
}
#content .sct:not(#att) {
  padding-right: 0.5em;
  padding-left: 0.5em;
}
#content #headArea .inner {
  white-space: nowrap;
  text-indent: -9999em;
}
#content .fade-enter-active,
#content .fade-leave-active {
  opacity: 1;
  transition: opacity 0.25s ease;
}
#content .fade-enter-from,
#content .fade-leave-to {
  opacity: 0;
}
#content .bounce-enter-active,
#content .bounce-leave-active {
  opacity: 1;
  animation: bounce-in 0.5s;
}
#content .bounce-enter-from,
#content .bounce-leave-to {
  opacity: 0;
  animation: none;
}
#content #cover,
#content #msg .msg__bg {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9998;
}
#content #connecting {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9997;
}
#content #connecting div {
  height: 100px;
  width: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 0.8rem;
  color: #fff;
  animation: fade-in 1s infinite alternate;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
}
#content #msg {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
}
#content #msg.open {
  z-index: 9999;
}
#content #msg .msg__bg {
  background: rgba(0, 0, 0, 0.5);
}
#content #msg .msg__main {
  z-index: 9999;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  height: auto;
  width: 80%;
  max-width: 500px;
  text-align: center;
}
#content #msg .msg__btn {
  position: absolute;
  top: 30px;
  right: 30px;
  height: 50px;
  width: 50px;
  text-indent: -999em;
  background: none;
}
#content #msg .msg__btn i {
  position: absolute;
  top: 50%;
  left: 50%;
  height: 80%;
  width: 80%;
  margin-top: -20px;
  margin-left: -20px;
  z-index: 999;
  cursor: pointer;
  transition: all 0.3s ease;
  transform: rotate(45deg);
}
#content #msg .msg__btn i::before, #content #msg .msg__btn i::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  height: 2px;
  width: 100%;
  margin-top: -1px;
  margin-left: -20px;
  width: 100%;
  height: 2px;
  background: rgba(255, 255, 255, 0.5);
}
#content #msg .msg__btn i::after {
  transform: rotate(90deg);
}
#content #msg .msg__btn i:hover {
  transform: rotate(225deg);
}
@media screen and (max-width: 960px) {
  #content #msg .msg__btn {
    height: 25px;
    width: 25px;
    top: 20px;
    right: 20px;
  }
  #content #msg .msg__btn i {
    margin-top: -10px;
    margin-left: -9px;
  }
  #content #msg .msg__btn i::before, #content #msg .msg__btn i::after {
    margin-left: -10px;
  }
}

a {
  text-decoration: none;
}

i {
  font-style: normal;
}

img {
  max-width: 100%;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  font-size: inherit;
}

button:disabled {
  cursor: default;
}

.text--white {
  color: #fff;
}

.text--red {
  color: #ff0000;
}

.text--yellow {
  color: #fdd95d;
}

.text--ivory {
  color: #f3eedb;
}

.text--xs {
  font-size: 0.8em;
}

.text--sm {
  font-size: 0.9em;
}

.text--md {
  font-size: 1em;
}

.text--lg {
  font-size: 1.15em;
}

.text--xl {
  font-size: 1.25em;
}

.text--serif,
.text--serif * {
  font-family: "Noto Serif TC", serif;
  font-weight: 400;
}

#loadingBg {
  position: fixed;
  top: 0;
  left: 0;
  height: auto;
  width: auto;
  min-width: 100%;
  min-height: 100%;
  background: #000;
  z-index: 99998;
}

#loading {
  height: 92px;
  width: 210px;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: url(https://image.tw.ncsoft.com/bns/pc/common/loader_bns_off.png) center/contain no-repeat;
  z-index: 99999;
}
#loading.active {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9999;
}
#loading #gauge {
  height: 0;
  width: 210px;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: all 0.3s ease;
  overflow: hidden;
}
#loading #gauge::before {
  content: "";
  height: 92px;
  width: 210px;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: all 0.3s ease;
  background: url(https://image.tw.ncsoft.com/bns/pc/common/loader_bns_on.png) center no-repeat;
}

@-webkit-keyframes button-shine {
  50%, to {
    left: 125%;
  }
}
@keyframes button-shine {
  50%, to {
    left: 125%;
  }
}
@keyframes kirakira {
  0%, 100% {
    filter: brightness(100%);
  }
  50% {
    filter: brightness(150%);
  }
}
@-webkit-keyframes kirakira {
  0%, 100% {
    filter: brightness(100%);
  }
  50% {
    filter: brightness(150%);
  }
}
@-webkit-keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.anime-vertical {
  -webkit-animation: vertical 1s ease-in-out infinite alternate;
  animation: vertical 1s ease-in-out infinite alternate;
}

@-webkit-keyframes vertical {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-5px);
  }
}
@keyframes vertical {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-5px);
  }
}
@-webkit-keyframes bounce-in {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes bounce-in {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
  }
}
body::after {
  content: "";
  position: absolute;
  height: 0;
  width: 0;
  overflow: hidden;
  z-index: -1;
  background-image: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_att.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_1.jpg"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_2.jpg"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_3.jpg"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_4.jpg"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_th.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bnr_shop.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/btn_active.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/btn_disabled.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/btn_login.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_bg_bottom.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_bg_middle.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_bg_top.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_eff_bottom.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_eff_top.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_01.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_02.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_03.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_04.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_05.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_06.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_07.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_08.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/title_badge.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/sub_title_01.png"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/main.jpg"), url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/main_sp.jpg");
}

#content #headArea {
  height: 950px;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/main.jpg") center top no-repeat;
}
@media screen and (max-width: 1110px) {
  #content #headArea {
    height: 100vw;
    max-height: 950px;
    background-size: cover;
  }
}
@media screen and (max-width: 640px) {
  #content #headArea {
    height: 125vw;
    background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/main_sp.jpg") center top/cover no-repeat;
  }
}
#content #bodyArea {
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_1.jpg") center top no-repeat, url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_2.jpg") center 2000px no-repeat, url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_3.jpg") center bottom 2000px no-repeat, url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_body_4.jpg") center bottom no-repeat, #0e161d;
}
@media screen and (max-width: 640px) {
  #content #bodyArea {
    background: #131d26;
  }
}
#content #att {
  position: relative;
  color: rgba(255, 255, 255, 0.5);
  background: #182a39;
}
#content #att::before {
  content: "";
  position: absolute;
  top: -120px;
  left: 0;
  height: 120px;
  width: 100%;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_att.png") center bottom/cover no-repeat;
}
#content #att .att__title {
  color: rgba(255, 255, 255, 0.7);
}
#content #fix-shop-bnr {
  z-index: 19;
  position: absolute;
  top: 935px;
  right: 10px;
  animation: vertical 1s ease-in-out infinite alternate;
}
#content #fix-shop-bnr:hover {
  filter: brightness(120%);
}
#content #fix-shop-bnr.move {
  position: fixed;
  top: 50px;
}
#content #fix-shop-bnr a {
  display: block;
  transition: all 0.3s ease;
  animation: vertical 1s ease-in-out infinite alternate;
}
@media screen and (max-width: 640px) {
  #content #fix-shop-bnr {
    position: absolute;
    top: 75vw;
    right: 0;
  }
  #content #fix-shop-bnr.move {
    position: absolute;
    top: 75vw;
  }
  #content #fix-shop-bnr a {
    height: 30vw;
    width: 30vw;
  }
}
@media screen and (max-width: 1110px) {
  #content #fix-shop-bnr {
    position: absolute;
    top: 85vw;
    right: 0;
    width: 30vw;
    max-width: 194px;
  }
  #content #fix-shop-bnr.move {
    position: absolute;
    top: 85vw;
    right: 0;
  }
}
@media screen and (max-width: 640px) {
  #content #fix-shop-bnr {
    top: 80vw;
  }
  #content #fix-shop-bnr.move {
    top: 80vw;
  }
}
@media screen and (max-width: 1110px) {
  #content .text--lg {
    font-size: inherit;
  }
}
#content .title {
  position: relative;
}
#content .title--badge span {
  position: absolute;
  top: 0;
  left: 0;
  margin-top: -65px;
  margin-left: -10px;
}
@media screen and (max-width: 960px) {
  #content .title--badge span {
    margin-top: -2.5em;
  }
}
@media screen and (max-width: 640px) {
  #content .title--badge span {
    margin-top: -1.5em;
  }
}
@media screen and (max-width: 1110px) {
  #content .title--badge span img {
    height: 4em;
  }
}
@media screen and (max-width: 640px) {
  #content .title--badge span img {
    height: 3em;
  }
}
@media screen and (max-width: 640px) {
  #content .title > img {
    height: 1.35em;
  }
}
@media screen and (max-width: 640px) {
  #content .sub-title img {
    height: 2em;
  }
}
#content .inner {
  padding: 5em 2.5em 7em;
}
@media screen and (max-width: 960px) {
  #content .inner {
    padding-right: 1em;
    padding-left: 1em;
  }
}
@media screen and (max-width: 640px) {
  #content .inner {
    padding: 2em 1em 3em;
  }
}
#content .frame {
  pointer-events: none;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin-top: 200px;
  margin-bottom: 200px;
  margin-left: -55px;
  height: calc(100% - 400px);
  width: calc(100% + 110px);
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_bg_middle.png") center repeat-y;
}
@media screen and (max-width: 640px) {
  #content .frame {
    height: 100%;
    width: 100%;
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 0;
    box-shadow: 0 0 4vw rgba(255, 255, 255, 0.5) inset;
  }
}
#content .frame::before, #content .frame::after {
  content: "";
  position: absolute;
  left: 0;
  height: 200px;
  width: 100%;
}
@media screen and (max-width: 640px) {
  #content .frame::before, #content .frame::after {
    display: none;
  }
}
#content .frame::before {
  top: -200px;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_bg_top.png") center bottom no-repeat;
}
#content .frame::after {
  bottom: -200px;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_bg_bottom.png") center top no-repeat;
}
#content .frame-eff::before, #content .frame-eff::after {
  content: "";
  z-index: 3;
  position: absolute;
  left: 0;
  width: calc(100% + 190px);
  margin-left: -95px;
  mix-blend-mode: plus-lighter;
}
#content .frame-eff::before {
  top: -250px;
  height: 250px;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_eff_top.png") center bottom no-repeat;
}
#content .frame-eff::after {
  bottom: -250px;
  height: 320px;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/frame_eff_bottom.png") center top no-repeat;
}
#content .inner-frame {
  position: relative;
  z-index: 2;
}
#content .desc {
  font-size: 1.25em;
  color: #fff;
}
#content .list-area {
  color: #fff;
  background: #205682;
  border: 1px solid #396e9a;
  padding: 1em 2em;
}
@media screen and (max-width: 640px) {
  #content .list-area {
    padding: 1em;
  }
}
#content .list-area .list-cst-num li {
  position: relative;
  text-indent: -1.65em;
  padding-left: 1.65em;
}
#content .list-area .list-cst-num li::before {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  height: 1.35em;
  width: 1.35em;
  color: #000;
  background: #ffd500;
  border-radius: 50%;
  text-indent: 0;
  margin-right: 0.3em;
}
#content .list-area .list-cst-num li:nth-child(1)::before {
  content: "1";
}
#content .list-area .list-cst-num li:nth-child(2)::before {
  content: "2";
}
#content .list-area .list-cst-num li:nth-child(3)::before {
  content: "3";
}
#content .list-area .list-cst-num li:nth-child(4)::before {
  content: "4";
}
#content .list-area .list-cst-num li:nth-child(5)::before {
  content: "5";
}
#content .list-area .list-cst-num li:nth-child(6)::before {
  content: "6";
}
#content .list-area .list-cst-num li:nth-child(7)::before {
  content: "7";
}
#content .list-area .list-cst-num li:nth-child(8)::before {
  content: "8";
}
#content .list-area .list-cst-num li:nth-child(9)::before {
  content: "9";
}
#content .table-area {
  border: 2px solid #cbcece;
  border-radius: 3px;
}
@media screen and (max-width: 960px) {
  #content .table-area.is-scroll {
    overflow-x: auto;
  }
  #content .table-area.is-scroll th,
  #content .table-area.is-scroll td {
    white-space: nowrap;
  }
  #content .table-area.is-scroll::before {
    content: "SCROLL >";
    display: inline-block;
    width: 100%;
    text-align: left;
  }
}
#content .table-area .table {
  width: 100%;
  border-bottom: solid 1px #000;
  border-left: solid 1px #000;
}
#content .table-area .table th,
#content .table-area .table td {
  height: 45px;
  border-top: solid 1px #000;
  border-right: solid 1px #000;
  padding: 0.25em 1em;
}
@media screen and (max-width: 640px) {
  #content .table-area .table th,
  #content .table-area .table td {
    font-size: 0.8em;
    padding: 0.25em 0.5em;
  }
  #content .table-area .table th img,
  #content .table-area .table td img {
    width: 1em;
  }
}
#content .table-area .table th .coin,
#content .table-area .table td .coin {
  display: inline-block;
  text-align: left;
  width: 6em;
}
#content .table-area .table thead th {
  color: #000;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/bg_th.png") 0 center/cover no-repeat;
  border-top: 1px solid;
}
#content .table-area .table tbody th {
  background: #c2f1ff;
}
#content .table-area .table tbody td {
  background: #ffffff;
}
#content .table-area .table tbody tr:nth-child(2n) th {
  background: #b0ebff;
}
#content .table-area .table tbody tr:nth-child(2n) td {
  background: #e1f9ff;
}
#content .table-area .table--2 tbody th,
#content .table-area .table--2 tbody td {
  background: #282763;
}
#content .table-area .table--2 tbody tr:nth-child(2n) th,
#content .table-area .table--2 tbody tr:nth-child(2n) td {
  background: #222154;
}
#content .table-area .table--2 tbody tr.bg--2 th,
#content .table-area .table--2 tbody tr.bg--2 td {
  background: #532763;
}
#content .table-area .table--2 tbody tr.bg--3 th,
#content .table-area .table--2 tbody tr.bg--3 td {
  background: #635027;
}
#content .table-area .table--2 tbody tr.bg--4 th,
#content .table-area .table--2 tbody tr.bg--4 td {
  background: #465928;
}
#content .btn {
  display: inline-block;
  height: 64px;
  width: 264px;
  font-size: 1.15em;
  color: #fff;
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/btn_active.png") center/contain no-repeat;
  padding: 3px;
}
@media screen and (max-width: 640px) {
  #content .btn {
    height: 32px;
    width: 100px;
    padding: 4px;
  }
}
#content .btn[disabled] {
  color: rgba(255, 255, 255, 0.5);
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/btn_disabled.png") center/contain no-repeat;
}
#content .btn.is-login {
  background: url("https://image.tw.ncsoft.com/bns/pc/event/2412/water/img/btn_login.png") center/contain no-repeat;
}
#content .btn b {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
  border-radius: 7px;
  overflow: hidden;
}
#content .btn:not([disabled]) {
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
#content .btn:not([disabled]) b:before {
  content: "";
  position: absolute;
  top: 0;
  left: -75%;
  z-index: 2;
  height: 100%;
  width: 50%;
  background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
  -webkit-transform: skewX(-25deg);
  transform: skewX(-25deg);
  -webkit-animation: button-shine 2.5s infinite;
  animation: button-shine 2.5s infinite;
}
#content .btn:not([disabled]):hover {
  filter: brightness(120%);
}
#content #msg .msg__main {
  font-size: 1.25em;
  color: #fff;
  background: #143b5c;
  box-shadow: 0 0 4vw rgba(255, 255, 255, 0.5) inset;
  height: auto;
  width: 80%;
  padding: 3em 1em;
  max-width: 600px;
}
#content #msg .msg__main::before {
  display: none;
}