@charset "UTF-8";
/****** Reset ******/
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, textarea, p, blockquote, th, td, input, select, button {
  margin: 0;
  padding: 0;
}

fieldset, img {
  border: 0 none;
}

dl, ul, ol, menu, li {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

input, select, textarea, button {
  vertical-align: middle;
  font-size: 100%;
}

button {
  border: 0 none;
  background-color: transparent;
  cursor: pointer;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

body {
  background-color: #fff;
  -webkit-text-size-adjust: none;
}

input:checked[type=checkbox] {
  background-color: #666;
  -webkit-appearance: checkbox;
}

input[type=text], input[type=password], input[type=submit], input[type=search], input[type=tel], input[type=email], html input[type=button], input[type=reset] {
  -webkit-appearance: none;
  border-radius: 0;
}

input[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

body, th, td, input, select, textarea, button {
  font-size: 14px;
  line-height: 1.5;
  font-family: "Pretendard", "Apple SD Gothic Neo", "Malgun Gothic", "맑은 고딕", system-ui, sans-serif;
  color: #000;
}

a {
  color: #005a96;
  text-decoration: none;
}

a:active, a:hover {
  text-decoration: none;
}

button, a, img {
  -webkit-user-drag: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

button:focus, a:focus, img:focus {
  outline: none !important;
}

address, caption, cite, code, dfn, em, var {
  font-style: normal;
  font-weight: normal;
}

hr {
  border: 0 none;
}

img {
  width: 100%;
}

.modal-table {
  display: table;
  width: 100%;
  height: 100%;
  table-layout: fixed;
}

.modal-cell {
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle;
  text-align: center;
}

.ir {
  display: block;
  font-size: 0;
  text-indent: -99999px;
  height: 0;
}

#kakaoHead {
  padding: 40px 0 60px;
}

#kakaoHead .img_title {
  position: relative;
  display: block;
  width: 100%;
  padding-top: 55%;
  background-size: contain;
}

#kakaoHead .img-date {
  padding-top: 15px;
}

:root {
  --vh: 1%;
  /* 기본색상 */
  --border-r14: 14px;
  --border-r18: 18px;
  /* floating btn */
  --wrap_apply--color: #fff;
  --wrap_apply--bg: #000;
}

.right {
  float: right;
}

.clearfix::after {
  display: block;
  content: "";
  clear: both;
}

video {
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
}

img {
  max-width: 375px;
}

/* guide padding */
[data-view-guide=true] .inner {
  position: relative;
}

[data-view-guide=true] .inner:not(.no-wrap):before,
[data-view-guide=true] .inner:not(.no-wrap):after {
  content: "";
  display: block;
  width: 35px;
  height: 100%;
  position: absolute;
  top: 0;
  background: #ffb2b2;
  opacity: 0.3;
}

[data-view-guide=true] .inner:not(.no-wrap):before {
  left: 0;
}

[data-view-guide=true] .inner:not(.no-wrap):after {
  right: 0;
}

/* design-guide */
.inner {
  width: 100%;
  max-width: 884px;
  margin: 0 auto;
  padding-right: 24px;
  padding-left: 24px;
  box-sizing: border-box;
  overflow: hidden;
}

.inner.no-wrap {
  padding: 0;
  /*max-width: unset;*/
  overflow: inherit;
}

/* 유의사항 */
/** @@TEST iOS 플로팅버튼 여백 대응 */
#eventInfo {
  min-height: fit-content !important;
  overflow: initial;
  height: 100vh;
}

#eventInfo .inner {
  padding: 0 30px;
}

#eventInfo .info-tit {
  padding-top: 60px;
  font-weight: 700;
  font-size: 20px;
  line-height: 24px;
}

#eventInfo .info-cont {
  margin-top: 25px;
  padding-bottom: 16px;
}

#eventInfo .info-stit {
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
}

#eventInfo .info-stit + .info-list {
  margin-top: 16px;
}

#eventInfo .info-list {
  word-break: keep-all;
}

#eventInfo .noline .info-list {
  margin-top: 0;
}

#eventInfo .info-list li {
  position: relative;
  padding-left: 10px;
  font-size: 14px;
  line-height: 24px;
}

#eventInfo .info-list li::before {
  /*content: "・";*/
  content: "";
  position: absolute;
  top: 11px;
  left: 0;
  display: inline-block;
  width: 3px;
  height: 3px;
  border-radius: 50%;
}

.accordion-block {
  padding: 16px 0;
  padding-bottom: 0;
  overflow: hidden;
}

.accordion-block.noline {
  padding: 40px 0 30px;
}

.accordion-block .b-line {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #444;
}

.accordion-block .accordion-btn {
  position: relative;
  width: 100%;
  text-align: left;
  color: var(--Black-90, #222);
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 24px; /* 150% */
  padding-bottom: 16px;
}

.accordion-block .accordion-btn span {
  vertical-align: middle;
}

.accordion-block .accordion-btn .title {
  display: inline-block;
  width: calc(100% - 25px);
}

.accordion-block .accordion-btn .icon-arrow {
  position: absolute;
  right: 0;
  line-height: 0;
  font-size: 0;
}

.accordion-block .accordion-btn .icon-arrow svg {
  transform: rotate(0deg);
  transition: transform 0.3s;
}

.accordion-block .accordion-btn.is-active .icon-arrow svg {
  transform: rotate(180deg);
  transition: transform 0.3s;
}

.accordion-block .accordion-content {
  display: none;
  padding-bottom: 16px;
}

.accordion-block .accordion-content .tit {
  margin-top: 24px;
  padding-bottom: 16px;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 24px; /* 150% */
}

.accordion-block.unfold .accordion-content {
  display: block;
}

.accordion-block.unfold .accordion-btn {
  pointer-events: none;
}

.accordion-block.unfold .icon-arrow {
  display: none;
}

/* 심의필 */
#eventInfo .serial {
  padding-bottom: 140px;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
}

#eventInfo.lose .serial {
  padding-bottom: 180px;
}

#eventInfo .serial .info-list li::before {
  width: 3px;
  height: 3px;
}

#eventInfo .serial.serial-tline {
  margin-top: 16px;
  font-size: 16px;
}

#eventInfo .serial.serial-tline .info-list {
  margin-top: 0;
}

/* 플로팅 버튼 */
.wrap_apply {
  position: fixed;
  bottom: 34px;
  z-index: -1;
  width: 100%;
  text-align: center;
  box-sizing: border-box;
  visibility: hidden;
  opacity: 0;
  /* transition:all 0.3s 1s; */
  transition: all 0.3s;
  transform: translateY(var(--apply-translateY, 0));
}

.wrap_apply.is-active {
  z-index: 9;
  opacity: 1;
  visibility: visible;
  display: block;
  transition: all 0.5s;
  transform: translateY(var(--apply-translateY-active, 0));
}

.wrap_apply .inner {
  padding: 0 16px;
}

.wrap_apply .link_apply {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 60px;
  margin: 0 auto;
  font-size: 17px;
  font-weight: 700;
  line-height: 21px;
  color: var(--wrap_apply--color, #000);
  text-align: center;
  border-radius: var(--Radius-R12, 12px);
  text-decoration: none;
  background-color: var(--wrap_apply--bg, #ffe300);
}

.wrap_apply .link_apply .ico_arrow {
  display: inline-block;
  width: 7px;
  height: 13px;
  margin: 27px 0 0 4px;
}

/* theme color */
.theme-default #eventInfo {
  background: #f9f9f9;
}

.theme-default #eventInfo * {
  color: #444;
}

.theme-default #eventInfo .info-tit,
.theme-default #eventInfo .info-stit,
.theme-default #eventInfo .accordion-block .tit {
  color: #222;
}

.theme-default #eventInfo .info-cont,
.theme-default #eventInfo .accordion-block {
  border-bottom: 1px solid #444;
}

.theme-default #eventInfo .info-list li::before {
  background: #333;
}

.theme-default #eventInfo .accordion-block .accordion-btn span:first-child {
  color: #222;
}

.theme-default #eventInfo .accordion-block .accordion-btn.is-active .icon-arrow svg path {
  stroke: #000;
}

.theme-dark #eventInfo {
  background: #444444;
}

.theme-dark #eventInfo * {
  color: #f1f1f1;
}

.theme-dark #eventInfo .info-tit,
.theme-dark #eventInfo .info-stit {
  color: #f1f1f1;
}

.theme-dark #eventInfo .info-cont,
.theme-dark #eventInfo .accordion-block {
  border-bottom: 1px solid #f1f1f1;
}

.theme-dark #eventInfo .info-list li::before {
  background: #f1f1f1;
}

.theme-dark #eventInfo .accordion-block .accordion-btn span:first-child {
  color: #f1f1f1;
}

.theme-dark #eventInfo .accordion-block .accordion-btn .icon-arrow svg path {
  stroke: #f1f1f1;
}

.accordion-block.noline {
  border-top: none;
}

/* 팝업 */
.popups {
  /*display: none;*/
  visibility: hidden;
  opacity: 0;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 999;
  transition: all 0.4s;
}

.popups.on {
  /*display: block;*/
  visibility: visible;
  opacity: 1;
}

/* 팝업 노출시 스크롤방지 */
body:has(.popups.on) {
  overflow: hidden;
}

.popups .dimmed {
  position: absolute;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.6;
}

.popups .modal-table {
  display: table;
  width: 100%;
  height: 100%;
  table-layout: fixed;
}

.popups .modal-cell {
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle;
  text-align: center;
}

.popups .modal-content {
  position: relative;
  max-width: 327px;
  margin: 0 auto;
  padding: 36px 16px 16px;
  box-sizing: border-box;
  border-radius: 24px;
  background: #fff;
}

.popups .title {
  margin: 0 auto;
  font-weight: 700;
  font-size: 16px;
  text-align: center;
  line-height: 21.5px;
  color: #222;
}

.popups .modal-image:not(.d-none) + .title {
  margin-top: 20px;
}

.popups .copy[class*="--b"],
.popups .desc {
  margin: 20px auto 0;
}

.popups .sub {
  display: block;
  font-weight: 400;
  font-size: 13px;
  line-height: 18px;
  color: #666;
}

.popups .desc {
  padding: 20px;
  border-radius: 8px;
  background: #f7f7f7;
  box-sizing: border-box;
}

.popups .sub:not([class*="--b"]) {
  margin: 12px auto 0;
}

.popups .okay-btn {
  width: 100%;
}

.popups .okay-btn .btn-ok {
  display: inline-block;
  padding: 17.5px 0;
  width: 100%;
  text-align: center;
  line-height: 24px;
  border-radius: 10px;
  font-size: 16px;
  line-height: 19px;
  font-weight: 400;
  color: #222;
  background: #ddd; /* custom */
  box-sizing: border-box;
}

.popups .okay-btn.cnt-2 .btn-ok {
  display: inline-block;
  width: 49%; /* 버튼 두개일 때 디자인 필요 */
}

.popup-single .modal-content .modal-image {
  line-height: 0;
  font-size: 0;
}

.popup-single .modal-content .modal-image > img,
.popup-single .modal-content .modal-image .pu-img {
  width: 55px;
  height: 55px;
}

.popup-single .modal-btn {
  display: flex;
  gap: 8px;
  margin-top: 32px;
}

.popup-single .modal-btn .okay-btn:not([class*="--info"]) {
  /* flex:0 0 115px;     */
  flex: 0 0 calc(40% - 4px);
}

.popup-single .modal-btn .okay-btn .btn-ok[class*="--info"] {
  background-color: #ffd600;
}

.popup-single .modal-btn .close-on {
  display: none;
}

/* bottomsheet 팝업  */
.popup-bottom .pop-content {
  position: absolute;
  left: 0;
  bottom: -500px;
  width: 100%;
  transition: bottom 0.3s;
}

.popup-bottom.on .pop-content {
  bottom: 0;
}

.popup-bottom:not(.type-close) .btn-close {
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 35px;
  height: 5px;
  border-radius: 20px;
  text-indent: -99999px;
  background-color: #eaecef;
}

.popup-bottom.type-close .btn-close {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 26px;
  height: 26px;
  text-indent: -99999px;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/icon_close.png') no-repeat center/100%;
}

.popup-bottom .pop-content-inner {
  position: relative;
  margin: 0 auto;
  padding: 50px 30px 54px;
  max-height: 482px;
  max-height: 60vh;
  height: 100%;
  background: #fff;
  border-radius: 30px 30px 0 0;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;
}

.popup-bottom:not(.type-close) .pop-content-inner {
  padding-top: 30px;
  /* padding-top:20px; */
}

.popup-bottom .detail {
  text-align: left;
  padding-top: 20px;
  height: calc(60vh - 40px);
  overflow-y: auto;
}
.popup-bottom .detail::before {
  content: "";
  position: absolute;
  top: 18px;
  top: 26px;
  right: 0;
  left: 0;
  display: inline-block;
  height: 36px;
  height: 30px;
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, #fff 60%);
}

.popup-bottom .detail .title {
  display: block;
  margin-top: 0;
  color: #000;
  font-size: 20px;
  line-height: 24px;
  text-align: left;
}

.popup-bottom .detail .title + .cont {
  margin-top: 30px;
  font-size: 15px;
  line-height: 26px;
  padding-bottom: 130px;
}

.popup-bottom .detail .cont-tit + .cont-box,
.popup-bottom .detail .cont-box + .cont-box {
  margin-top: 24px;
}

.popup-bottom .detail .cont-box p + p,
.popup-bottom .detail .cont-box p + .ul-list,
.popup-bottom .detail .cont-box .ul-list + p {
  margin-top: 6px;
}

.popup-bottom .detail .ul-list li {
  position: relative;
  padding-left: 10px;
  color: var(--Black-80, #444);
  font-size: 14px;
  font-weight: 400;
  line-height: 24px; /* 171.429% */
}

.popup-bottom .detail .ul-list li::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  display: inline-block;
  width: 3px;
  height: 3px;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 50%;
}

.popup-bottom .detail .ul-list li + li {
  margin-top: 6px;
}

.popup-bottom .wrap_btn {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 36px 16px 34px;
  z-index: 9;
  opacity: 1;
  visibility: visible;
  display: block;
  transition: all 0.5s;
  background: linear-gradient(rgba(255, 255, 255, 0) 0%, #fff 30%);
}

.popup-bottom .wrap_btn .btn {
  display: block;
  width: 100%;
  height: 60px;
  font-size: 17px;
  font-weight: 400;
  text-align: center;
  color: #222;
  border-radius: 12px;
  background-color: #ffe300;
}

/*  default motion */
/* .inmotion {
    opacity: 0;
    transform: translateY(var(--y));
  } */
.inmotion-section {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.3s;
}

.inmotion-section.play {
  transform: translateY(0);
  opacity: 1;
  transition: all 0.3s;
}

.inmotion {
  --y: 20px;
  transform: translate(0, var(--y));
  opacity: 0;
}

.play-inmotion.inmotion,
.play.inmotion {
  transform: translate(0, 0);
  opacity: 1;
  transition: transform 0.6s var(--play-inmotion-delay, 0.1s), opacity 0.6s var(--play-inmotion-delay, 0.1s);
  /* transition:transform 0.6s 0.1s, opacity 0.6s 0.1s; 
    -webkit-transition:transform 0.6s 0.1s, opacity 0.6s 0.1s; 
    -moz-transition:transform 0.6s 0.1s, opacity 0.6s 0.1s; 
    -ms-transition:transform 0.6s 0.1s, opacity 0.6s 0.1s; 
    -o-transition:transform 0.6s 0.1s, opacity 0.6s 0.1s;  */
}

@media screen and (max-width: 375px) {
  .inner.no-wrap {
    overflow: hidden;
  }
}
@media screen and (max-width: 360px) {
  /* .inner {padding: 0 25px;} */
  .popups .modal-content {
    min-width: 272px;
    /* max-width:312px; */
    max-width: calc(100% - 48px);
  }
  #share .share-btn .btn {
    padding: 25px 28px;
  }
}
/** 공유하기 - 버튼 **/
#share {
  width: 100%;
  padding: 0 16px 60px;
  text-align: center;
  box-sizing: border-box;
}

#share .share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 64px;
  padding: 20px 30px;
  background: #fff;
  color: #000;
  border-radius: 40px;
  font-size: 18px;
  font-weight: 700;
  box-sizing: border-box;
}

#share .share-btn svg {
  margin-right: 10px;
}

/* theme color */
/* .theme-default #share {background:#FFD600;}
.theme-dark #share {background:#fff;} */
.theme-default #share .share-btn {
  background: #555555;
  color: #fff;
}

.theme-dark #share .share-btn {
  background: #555555;
  color: #fff;
}

/* .theme-default #share .share-btn svg {stroke: #333333;} 
.theme-dark #share .share-btn svg {stroke: #ffffff;}*/
/** 공유하기 - 팝업 **/
.popup-share .pop-content {
  position: absolute;
  left: 0;
  bottom: -500px;
  width: 100%;
  transition: bottom 0.3s;
}

.popup-share .pop-content-inner {
  position: relative;
  margin: 0 auto;
  padding: 10px 18px 34px;
  background: #fff;
  border-radius: 30px 30px 0 0;
  text-align: center;
  box-sizing: border-box;
}

.popup-share .btn-close {
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 35px;
  height: 5px;
  border-radius: 20px;
  text-indent: -9999px;
  background-color: #EAECEF;
}

.popup-share .pop-share-btn-list {
  margin-top: 35px;
}

.popup-share li + li {
  margin-top: 10px;
}

.popup-share .pop-share-btn-list a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 60px;
  background: #F1F1F1;
  border-radius: 15px;
  font-size: 15px;
  font-family: "Pretendard", "Apple SD Gothic Neo", "Malgun Gothic", "맑은 고딕", system-ui, sans-serif;
  font-weight: 600;
  color: #000;
}

.popup-share .pop-share-btn-icon {
  margin-right: 6px;
  width: 26px;
  height: 26px;
}

.popup-share .pop-share-btn-list button:after {
  content: none;
}

.popup-share .pop-share-btn-list .kakaotalk {
  background: #FAE200;
}

.popup-share .pop-share-btn-list .facebook {
  background: #1877F2;
  color: #fff;
}

.popup-share .pop-share-btn-list .twitter {
  background: #1D9BF0;
  color: #fff;
}

.popup-share .pop-share-btn-list .x {
  background: #000;
  color: #fff;
}

.popup-share .pop-share-btn-list .copy {
  margin: 0;
}

.popup-share.on {
  visibility: visible;
  opacity: 1;
}

.popup-share.on .pop-content {
  bottom: 0;
}

/** 공유하기 - 팝업 **/
.type-bottom .pop-content {
  position: absolute;
  left: 0;
  bottom: -500px;
  width: 100%;
  transition: bottom 0.7s;
}

.type-bottom .pop-content-inner {
  margin: 0 auto;
  padding: 0 30px 44px;
  background: #fff;
  border-radius: 30px 30px 0 0;
  text-align: center;
}

/* .type-bottom .btn-close {
  position: relative;
  width: 35px;
  height: 5px;
  border-radius: 20px;
  text-indent: -9999px;
  background: #799FAD;
} */
.type-bottom.on {
  visibility: visible;
  opacity: 1;
}

.type-bottom.on .pop-content {
  bottom: 0;
}

html,
body {
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: -moz-none;
  -o-user-select: none;
  user-select: none;
  min-width: initial;
}

* {
  font-family: "Pretendard", "Apple SD Gothic Neo", "Malgun Gothic", "맑은 고딕", system-ui, sans-serif;
}

section,
.section {
  position: relative;
  z-index: 2;
  box-sizing: border-box;
}

body {
  position: relative;
  /* overflow: hidden; */
  height: auto !important;
  overflow-y: auto;
  color: #000;
  background: #fff;
}

/** @@TEST iOS 플로팅버튼 여백 대응 */
main {
  min-height: 100vh;
}

::-webkit-scrollbar {
  display: none;
  /* Chrome, Safari, Opera*/
  scrollbar-width: none;
  /* Firefox */
  scroll-behavior: smooth;
}

.d-none {
  display: none !important;
}

/* cta 버튼  */
.wrap_apply {
  --y: 30px;
}

.draws-text {
  font-size: 22px;
  line-height: 30px;
  font-weight: 700;
}

/* popups */
.popup-more .btn-close {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 26px;
  height: 26px;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/icon_close.png') no-repeat 0 0/100%;
  text-indent: -99999px;
}

.popup-more.type-bottom .pop-content-inner {
  padding-top: 40px;
}

.popup-more .detail {
  text-align: left;
}

.popup-more .detail .title {
  display: block;
  margin-bottom: 30px;
  font-size: 20px;
  line-height: 24px;
  font-weight: 800;
  text-align: left;
}

.popup-more .detail img {
  width: 54px;
}

/* .popup-more .detail li {
  font-size:0;
  margin-top:20px;
} 
.popup-more .detail li:first-child {
  margin-top:0;
}
.popup-more .detail li span {
  display: inline-block;
  vertical-align: top;
  font-size:15px;
  line-height: 22px;
  font-weight: 600;
  padding:5px 0 0 18px;
}*/
.popup-more .ul-list li {
  position: relative;
  padding-left: 15px;
  color: #444;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px; /* 171.429% */
}

.popup-more .ul-list li::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 5px;
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #444;
}

/* 공통 */
/* logo */
.logo {
  display: block;
  margin: 0 auto;
  width: 137px;
  height: 15px;
  opacity: var(--logo-opacity, 1);
}

/* 인트로, draw 롤링text 메시지 : main.html, draw.html */
.rolling-text-wrapper {
  margin: 0 auto;
  width: 256px;
  height: 40px;
  color: #222;
  font-size: 15px;
  font-weight: 700;
  line-height: 20px; /* 133.333% */
  box-sizing: border-box;
  overflow: hidden;
}
.rolling-text-wrapper .txt-first {
  padding: 10px;
}

.rolling-text-container {
  position: relative;
  width: 100%;
  transition: transform ease-in-out;
}

.rolling-text-item {
  color: #222;
  font-weight: 700;
  line-height: 20px; /* 142.857% */
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

/* text.title 롤링 :: main.html - 기준:main*/
.txt-scroller {
  width: 100%;
  color: var(--txt-scroller-color, #322821);
  font-size: var(--txt-scroller-size, 17px);
  font-weight: 700;
  line-height: var(--txt-scroller-line-height, 25px);
  letter-spacing: 0px;
}

.txt-scroller .txt-scroller-item {
  --txt-scroller-delay: 3s;
  position: absolute;
  width: 100%;
  white-space: nowrap;
  opacity: 0;
}

.txt-scroller .txt-scroller-item.item1 {
  -webkit-animation: ani-txt-scroller 0.3s ease-in forwards 0s, ani-txt-scroller 0.5s ease-in-out forwards reverse var(--txt-scroller-delay, 2.67s);
  animation: ani-txt-scroller 0.3s ease-in forwards 0s, ani-txt-scroller 0.5s ease-in-out forwards reverse var(--txt-scroller-delay, 2.67s);
}

.txt-scroller .txt-scroller-item.item2 {
  -webkit-animation: ani-txt-scroller 0.5s ease-in forwards var(--txt-scroller-delay, 2.67s);
  animation: ani-txt-scroller 0.5s ease-in forwards var(--txt-scroller-delay, 2.67s);
}

@-webkit-keyframes ani-txt-scroller {
  0% {
    opacity: var(--ani-txt-opacity, 0);
    -webkit-transform: translateY(var(--ani-card-y, 0));
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(var(--ani-card-y2, 0));
  }
}
@keyframes ani-txt-scroller {
  0% {
    opacity: var(--ani-txt-opacity, 0);
    transform: translateY(var(--ani-card-y, 0));
  }
  100% {
    opacity: 1;
    transform: translateY(var(--ani-card-y2, 0));
  }
}
.txt-scroller .txt-scroller-item > span {
  color: #a0241b;
}

.txt-scroller-up {
  display: inline-block;
  height: 50px;
  overflow: hidden;
  font-weight: 700;
  font-size: 17px;
  line-height: 25px;
}

.txt-scroller-up .txt-scroller-item {
  white-space: nowrap;
  -webkit-animation: scroll-ani 3.5s cubic-bezier(0.645, 0.045, 0.355, 1) forwards;
  animation: scroll-ani 3.5s cubic-bezier(0.645, 0.045, 0.355, 1) forwards;
}
.txt-scroller-up .txt-scroller-item > span {
  color: #a0241b;
}

@-webkit-keyframes scroll-ani {
  0%, 80% {
    -webkit-transform: translateY(0px);
  }
  100% {
    -webkit-transform: translateY(-50px);
  }
}
@keyframes scroll-ani {
  0%, 80% {
    transform: translateY(0px);
  }
  100% {
    transform: translateY(-50px);
  }
}
/* 하단으로 이동 */
.scroll-down {
  position: absolute;
  bottom: 40px;
  left: calc(50% - 9px);
  width: 17px;
  height: 8px;
  -webkit-animation: mouseloop 0.8s 2s infinite alternate;
  animation: mouseloop 0.8s 2s infinite alternate;
  z-index: 10;
  margin: 0 auto 0;
}

@keyframes mouseloop {
  0% {
    transform: translateY(0);
    opacity: 0.85;
  }
  to {
    transform: translateY(-12px);
    opacity: 1;
  }
}
@-webkit-keyframes mouseloop {
  0% {
    -webkit-transform: translateY(0);
    opacity: 0.85;
  }
  to {
    -webkit-transform: translateY(-12px);
    opacity: 1;
  }
}
/* 컨텐츠 공통 */
.wrap_apply {
  --apply-translateY: 30px;
}

.wrap_apply:not(.type-b) .link_apply {
  --wrap_apply--color: #fff;
  --wrap_apply--bg: #000;
}

.wrap_apply.type-b .link_apply {
  --wrap_apply--color: #fff;
  --wrap_apply--bg: #01317b;
}

#output {
  min-height: 100vh;
}

main {
  overflow-x: hidden;
  min-height: 667px;
}

.game-section.active {
  z-index: 1;
}

.step-0-active .game-section .jjordy {
  visibility: hidden !important;
}
.step-0-active .bottom-box {
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
}

.step-0-active .tit-box {
  visibility: visible !important;
}

.step-container .step1,
.step-container .step2,
.step-container .step3 {
  opacity: 0;
  height: 0;
  transform: translateY(10px);
}
.step-container.step-1-active .bottom-box {
  opacity: 1;
  pointer-events: auto;
  overflow: hidden;
  transition: all 0.3s ease-out 1.7s;
}
.step-container.step-1-active .step1 {
  opacity: 1;
  transform: translateY(0);
  transition: all 0.6s ease-out 0.3s;
}
.step-container.step-2-active .step1 {
  opacity: 0;
  height: 0;
}
.step-container.step-2-active .step2 {
  opacity: 1;
  transform: translateY(0);
  transition: all 0.6s ease-out 0.3s;
}
.step-container.step-3-active .step2 {
  opacity: 0;
  height: 0;
}
.step-container.step-3-active .step3 {
  display: block;
  opacity: 1;
  transform: translateY(0);
  transition: all 0.6s ease-out 0.3s;
}
.step-container.step-3-active .bottom-box {
  pointer-events: none;
}
.step-container.step-3-active .bottom-box.hide {
  opacity: 0;
  transform: translate(-50%, 40px);
  transition: all 0.3s ease-out;
}

.game-section {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: -1;
  height: 100vh;
  background-color: #cdeeff;
}
.game-section .jjordy-cage {
  top: 50%;
  position: absolute;
  width: 100%;
  height: 45%;
  transform: translateY(-50%);
  max-height: 286px;
}
.game-section .jjordy {
  opacity: 0;
  position: absolute;
  transform: translateY(10px);
  height: 135px;
}
.game-section::before {
  content: "";
  display: block;
  background-image: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/bg.png');
  background-size: 787px 812px;
  height: 812px;
  left: 50%;
  bottom: 0;
  position: absolute;
  transform: translate(-394.5px, 0);
  width: 787px;
}
.game-section .skin1 {
  position: absolute;
  top: 0;
  left: 33%;
}
.game-section .skin2 {
  position: absolute;
  top: 44%;
  left: initial;
  left: 0%;
}
.game-section .skin3 {
  position: absolute;
  bottom: 0;
  right: 0;
}
.game-section.loaded .jjordy {
  transform: translateY(0);
  opacity: 1;
  transition: all 0.3s ease-out 0.1s;
}
.game-section.loaded .jjordy.clicked:before {
  content: "";
  display: block;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/popcash.png') no-repeat;
  animation: popcash-loop 0.6s forwards;
  background-size: contain;
  background-position: 0 17px;
  height: 135px;
}
.game-section.loaded .clicked .name {
  visibility: hidden;
  transition: none !important;
}
.game-section.loaded .skin2 {
  transition: all 0.3s ease-out 0.2s;
}
.game-section.loaded .skin3 {
  transition: all 0.3s ease-out 0.4s;
}
.game-section.loaded .jjordy::before {
  opacity: 1;
}
.game-section.loaded .jjordy .name {
  opacity: 0;
  font-size: 16px;
  font-weight: 700;
}
.game-section.loaded .skin1:before {
  content: "";
  display: block;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/jjordy1.png') no-repeat;
  background-size: contain;
  background-position: center;
  width: 165px;
  height: 111px;
}
.game-section.loaded .skin2:before {
  content: "";
  display: block;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/jjordy2.png') no-repeat;
  background-size: contain;
  background-position: center;
  width: 165px;
  height: 111px;
}
.game-section.loaded .skin3:before {
  content: "";
  display: block;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/jjordy3.png') no-repeat;
  background-size: contain;
  background-position: center;
  width: 183.92px;
  height: 121px;
}
.game-section.move-start .jjordy {
  transform: translateY(0);
  opacity: 1;
  transition: all 0.3s ease-out;
}
.game-section.move-start .jjordy .name {
  opacity: 1;
  transition: all 0.3s 0.2s ease-out;
}
.game-section.move-start .skin1:before {
  animation: jjordy1-loop 6s infinite 0.1s;
}
.game-section.move-start .skin2:before {
  animation: jjordy2-loop 5.2s infinite 0.1s;
}
.game-section.move-start .skin3:before {
  animation: jjordy3-loop 4.1s infinite 0.1s;
}

/* 반복 애니메이션 (4.1초 주기) */
@keyframes jjordy1-loop {
  /* 0~0.1초: 정지 */
  0%, 2.44% {
    transform: translateY(0) scaleX(-1);
  }
  /* 0.1~1.1초: 좌로 20픽셀 이동 */
  26.83% {
    transform: translateY(0) translateX(20px) scaleX(-1);
  }
  /* 1.1~3.1초: 정지 */
  75.61% {
    transform: translateY(0) translateX(20px) scaleX(-1);
  }
  /* 3.1초: 좌우반전 (즉시) */
  78.04% {
    transform: translateY(0) translateX(20px) scaleX(-1);
  }
  78.05% {
    transform: translateY(0) translateX(20px);
  }
  /* 3.2~4.2초: 우로 20픽셀 이동 */
  100% {
    transform: translateY(0) translateX(0);
  }
}
/* jjordy2 반복 애니메이션 (5.2초 주기) */
@keyframes jjordy2-loop {
  /* 0.2~1.0초: 정지 */
  0%, 19.23% {
    transform: translateY(0);
  }
  /* 1.0~2.0초: 우로 20픽셀 이동 */
  38.46% {
    transform: translateY(0) translateX(-20px);
  }
  /* 2.0~4.1초: 정지 */
  78.85% {
    transform: translateY(0) translateX(-20px);
  }
  /* 4.1초: 좌우반전 (즉시) */
  80.76% {
    transform: translateY(0) translateX(-20px);
  }
  80.77% {
    transform: translateY(0) translateX(-20px) scaleX(-1);
  }
  /* 4.1~5.1초: 좌로 20픽셀 이동 */
  100% {
    transform: translateY(0) translateX(0) scaleX(-1);
  }
}
/* jjordy3 반복 애니메이션 (4.1초 주기) */
@keyframes jjordy3-loop {
  /* 1.0~1.1초: 정지 */
  0%, 26.83% {
    transform: translateY(0) scaleX(-1);
  }
  /* 1.1~2.1초: 우로 20픽셀 이동 */
  51.22% {
    transform: translateY(0) translateX(-20px) scaleX(-1);
  }
  /* 2.1~3.0초: 정지 */
  73.17% {
    transform: translateY(0) translateX(-20px) scaleX(-1);
  }
  /* 3.0초: 좌우반전 (즉시) */
  75.60% {
    transform: translateY(0) translateX(-20px) scaleX(-1);
  }
  75.61% {
    transform: translateY(0) translateX(-20px);
  }
  /* 3.0~4.0초: 좌로 20픽셀 이동 */
  100% {
    transform: translateY(0) translateX(0);
  }
}
.container {
  width: 100%;
  height: 100vh;
}

.animate {
  transform: translate(0, 10px);
  opacity: 0;
}

.play.animate {
  transform: translate(0, 0);
  opacity: 1;
  transition: transform 0.6s 0.1s, opacity 0.6s 0.1s;
  -webkit-transition: transform 0.6s 0.1s, opacity 0.6s 0.1s;
  -moz-transition: transform 0.6s 0.1s, opacity 0.6s 0.1s;
  -ms-transition: transform 0.6s 0.1s, opacity 0.6s 0.1s;
  -o-transition: transform 0.6s 0.1s, opacity 0.6s 0.1s;
}

.step-container .step1,
.step-container .step2,
.step-container .step3,
.step-container .step4 {
  opacity: 0;
  z-index: -2;
  transform: translateY(10px);
}

.step-1-active .step1 {
  opacity: 1;
  z-index: 1;
  transform: translateY(0);
  transform: all 0.5s ease-in;
}

.tit-box {
  visibility: hidden;
  position: absolute;
  width: 265px;
  bottom: 196px;
  left: 0;
  width: 100%;
  height: 279px;
}
.tit-box .inner-box {
  position: relative;
}
.tit-box:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 265px;
  height: 279px;
  border-radius: 72px;
  background: #ffd1c3;
  filter: blur(23px);
  z-index: -1;
}
.tit-box::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
  display: block;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/ir-img-jorddy.webp') no-repeat center;
  background-size: contain;
  margin: 0 auto;
  width: 375px;
  height: 210px;
}
.tit-box .title {
  color: #000;
  font-size: 25.5px;
  display: block;
  text-align: center;
  font-style: normal;
  font-weight: 700;
  margin-top: 132px;
  line-height: 43px; /* 167.979% */
}
.tit-box .date {
  color: rgba(0, 0, 0, 0.46);
  display: block;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 24px;
  margin-top: 6px;
}

.img-open-event {
  display: block;
  margin: 14px auto 0;
  width: 140px;
  height: 32px;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/ir-img-open-event.png') no-repeat center;
  background-size: contain;
}

.bottom-box {
  width: 100%;
  height: 137px;
  padding: 0 20px;
  bottom: 40px;
  position: absolute;
  font-size: 17px;
  font-style: normal;
  font-weight: 700;
  box-sizing: border-box;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
  z-index: 2;
}
.bottom-box .box-inner {
  display: block;
  border-radius: 20px;
  padding: 24px 18px 0 30px;
  border: 2.5px solid #000;
  height: 137px;
  background: #fff;
  color: #000;
  box-sizing: border-box;
}
.bottom-box .next-button .continue {
  position: absolute;
  bottom: 23px;
  right: 43px;
  color: #00b2ff;
  font-size: 17px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

@keyframes popcash-loop {
  0% {
    opacity: 0;
    transform: scale(0.8);
  }
  20% {
    opacity: 0;
    transform: scale(1);
  }
  30% {
    opacity: 0;
    transform: scale(0.9);
  }
  50% {
    opacity: 1;
    transform: scale(1);
  }
  70% {
    opacity: 1;
    transform: scale(0.8);
  }
  85% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 1;
    transform: scale(0.9);
  }
}
.wrap_apply {
  padding: 0 16px;
}

@media screen and (max-height: 700px) {
  .game-section::before {
    height: 800px;
    transform: translate(-393.5px, 85px);
  }
  .game-section .jjordy-cage {
    top: 45%;
  }
}
.outro.before #share {
  padding: 108px 0 88px;
}
.outro.before .before-cashback {
  opacity: 1;
}
.outro.before .before-cashback .title {
  padding-top: 88px;
}
.outro.before .after-cashback {
  opacity: 0;
  display: none;
}
.outro.before .after-cashback .title {
  padding-top: 88px;
}
.outro.after .before-cashback {
  opacity: 0;
  display: none;
}
.outro.after .after-cashback {
  opacity: 1;
}

.gbox {
  border-radius: 23px;
  width: 100%;
  margin: 52px auto 0;
  text-align: center;
  border-radius: 24px;
  max-width: 327px;
  height: 470px;
  padding: 50px 0 37px;
  background: #e0f7e5;
  box-sizing: border-box;
  overflow: hidden;
}
.gbox::after {
  content: "";
  width: 724px;
  height: 306px;
  display: block;
  background: url('https://kakaobankcontent.com/public/statics/events/jjordy/images/alljjody.png') no-repeat center;
  background-size: 724px 306px;
  animation: rolling 20s linear infinite;
}
.gbox .sub {
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 24px;
  margin-bottom: 8px;
  display: block;
}
.gbox strong {
  color: #000;
  text-align: center;
  font-size: 19px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: -0.095px;
}

.img-cash-inmotion {
  width: 148px;
  display: block;
  height: 186px;
  margin: 38px auto 0;
}

.outro .wrap_apply .inner {
  padding: 0;
}
.outro .title {
  color: #000;
  font-size: 24px;
  font-style: normal;
  font-weight: 700;
  line-height: 30px;
  text-align: center;
}
.outro .title strong {
  color: #0040ff;
  font-weight: 700;
}
.outro .first-info {
  display: block;
  text-align: center;
  color: #4f4f4f;
  margin: 27px auto 10px;
  line-height: 24px;
}
.outro .first-info svg {
  vertical-align: text-top;
}
.outro .first-info span {
  margin: 27px auto 10px;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 24px;
}
.outro #share {
  text-align: center;
  padding: 63px 0 103px;
}
.outro #share a {
  display: inline-flex;
  padding: 20px 30px 20px 28px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 40px;
  background: #555;
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  color: #fff;
}

@keyframes rolling {
  0% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(-382px);
  }
  100% {
    transform: translateX(0);
  }
}