@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://og.kakaobank.io/view/f3ed8fff-fc7b-40c9-8d60-1bc9802673f4") 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://og.kakaobank.io/view/f3ed8fff-fc7b-40c9-8d60-1bc9802673f4") 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: #000;
  --wrap_apply--bg: #ffe300;
}

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

.tit-box {
  --ani-card-y:20px;
  color: var(--color-tit-box, #1E1E1E);
  text-align: var(--text-align-tit, center);
  line-height: 1;
}
.tit-box .title {
  font-weight: var(--font-weight-title, 700);
  font-size: var(--font-size-title, 28px);
  line-height: 40px;
}
.tit-box .title span {
  color: var(--color-mtxt, #949494);
}
.tit-box .desc {
  --txt-scroller-delay: 0.5s;
  margin-top: 16px;
  color: var(--color-tit-desc);
  font-weight: 600;
  font-size: var(--font-size-desc, 16px);
  line-height: 28px;
}
.tit-box .date {
  font-weight: 500;
  font-size: 15px;
  line-height: 100%;
  letter-spacing: 1px;
  color: rgba(0, 0, 0, 0.5);
}

.donation-box {
  margin: 40px auto 0;
  padding: 163px 27px 30px;
  width: 275px;
  text-align: center;
  border: 1.5px solid var(--donation-border-color, transparent);
  border-radius: 26px;
  background: #fff url("https://og.kakaobank.io/view/a730bcd4-9a45-48de-ab6f-700f44ac1c1c") no-repeat center 20px/120px;
  box-sizing: border-box;
}
.donation-box .desc {
  color: rgba(0, 0, 0, 0.4);
  font-weight: 400;
  font-size: 13px;
  line-height: 20px;
  letter-spacing: -0.15px;
}
.donation-box .title {
  margin-top: 8px;
  color: #111;
  font-weight: 700;
  font-size: 16px;
  line-height: 22px;
  letter-spacing: 0px;
}
.donation-box .title + .donation-info {
  margin-top: 30px;
}
.donation-box .donation-info {
  height: 48px;
  line-height: 48px;
  color: #376CC8;
  border-radius: 100px;
  background: #DEEBFF;
}
.donation-box .donation-info > p {
  display: inline-block;
  padding-left: 28px;
  background: url("https://og.kakaobank.io/view/839a6dc1-83dd-4a6c-9f11-7dc566452e23") no-repeat 0 center/22px;
}

/* 컨텐츠 영역 */
/* 컨텐츠 공통 */
.m-visual {
  position: relative;
  height: 100vh;
  min-height: 700px;
  overflow-x: hidden;
  background: linear-gradient(180deg, rgba(255, 158, 160, 0.3) 33.36%, rgba(108, 167, 255, 0.3) 70.01%, rgba(255, 255, 255, 0.3) 100%);
}
.m-visual .img-visual {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, calc(-50% - 44px));
  transform: translate(-50%, calc(-50% - 44px));
  z-index: 2;
}
.m-visual .img-visual img {
  --ani-txt-opacity:1;
  --ani-card-y: -30px;
  width: 200px;
  -webkit-animation: ani-txt-scroller 0.8s ease-in-out 0s forwards;
  animation: ani-txt-scroller 0.8s ease-in-out 0s forwards;
}
.m-visual .img-bg {
  position: absolute;
  top: 0;
  top: -88px;
  max-width: 663px;
  width: 663px;
  -webkit-animation: ani-txt-scroller 0.8s ease-in-out 0s forwards;
  animation: ani-txt-scroller 0.8s ease-in-out 0s forwards;
}
.m-visual .tit-box {
  position: absolute;
  right: 0;
  bottom: 112px;
  left: 0;
  z-index: 2;
  -webkit-animation: ani-txt-scroller 0.8s ease-in-out 0s forwards;
  animation: ani-txt-scroller 0.8s ease-in-out 0s forwards;
}
.m-visual .tit-box .title {
  margin-top: 10px;
  margin-bottom: 22px;
  line-height: 38px;
}

.m-heritage .inner {
  padding-top: 80px;
  padding-bottom: 63px;
  width: 100%;
}
.m-heritage .list-type {
  margin-top: 48px;
}
.m-heritage .list-type .item-list {
  display: flex;
  align-items: center;
  padding: 0 24px;
  height: 86px;
  color: #444;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px; /* 150% */
  letter-spacing: -0.25px;
  border-radius: 20px;
  background: #F5F5F5;
}
.m-heritage .list-type .item-list::before {
  content: "";
  display: inline-block;
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  background: var(--item-list-bg) no-repeat center/100%;
}
.m-heritage .list-type .item-list + .item-list {
  margin-top: 16px;
}
.m-heritage .list-type .item-list > p {
  padding-left: 20px;
}
.m-heritage .list-type .item-list > p strong {
  color: #111111;
}

.m-heritage .swiper,
.m-heritage .swiper-container {
  overflow: visible !important;
}

.m-heritage .swiper {
  margin-top: 20px;
}

.m-heritage .swiper .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 244px;
  -webkit-transition: all 0.4s linear;
  transition: all 0.4s linear;
}
.m-heritage .swiper .swiper-slide.swiper-slide-active {
  -webkit-transform: scale(1.25);
  transform: scale(1.25);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 218px 218px;
}
.m-heritage .swiper .swiper-slide.swiper-slide-active.item1 {
  background-image: url("https://og.kakaobank.io/view/8066b001-a6a1-4d97-ae90-36da27efc88e");
}
.m-heritage .swiper .swiper-slide.swiper-slide-active.item2 {
  background-image: url("https://og.kakaobank.io/view/ebf2a71f-adb1-4bf6-9abc-39e214ac6c95");
}
.m-heritage .swiper .swiper-slide.swiper-slide-active.item3 {
  background-image: url("https://og.kakaobank.io/view/cc4d8b66-3e71-46f3-a79d-ab925022a8de");
}
.m-heritage .swiper .swiper-slide.swiper-slide-active.item4 {
  background-image: url("https://og.kakaobank.io/view/9e721b28-0fd7-4481-8b96-a056a3edf4a1");
}
.m-heritage .swiper .swiper-slide.swiper-slide-active.item5 {
  background-image: url("https://og.kakaobank.io/view/3ef173d2-5bfb-49b7-b5a0-ab2a3de4ec35");
}
.m-heritage .swiper .swiper-slide > img {
  width: 135px;
}

@media screen and (max-width: 360.98px) {
  .m-heritage .list-type .item-list {
    padding-right: 18px;
    padding-left: 18px;
  }
  .m-heritage .list-type .item-list > p {
    padding-left: 12px;
  }
}
.m-donation {
  background: #345685;
}
.m-donation .inner {
  padding-top: 60px;
  padding-bottom: 60px;
}

/** 기존 MAIN CSS */
@-webkit-keyframes gradient-ani {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
@keyframes gradient-ani {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
/* 컨텐츠 영역 */
.section.steps:not(.main1) {
  display: none;
  opacity: 0;
}
.section.steps:not(.main1).on {
  display: block;
  -webkit-animation: ani-txt-scroller 0.9s ease-in-out 0.1s forwards;
  animation: ani-txt-scroller 0.9s ease-in-out 0.1s forwards;
}

.section.steps.off {
  display: none;
}

/* 컨텐츠 공통 */
.main-bg {
  margin: 0 auto;
  height: 100%;
  overflow-x: hidden;
  width: 100%;
  background-color: #c9b095;
}
.main-bg::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.75);
  opacity: 0;
  -webkit-animation: ani-txt-scroller 0.8s ease-in-out 0.1s forwards;
  animation: ani-txt-scroller 0.8s ease-in-out 0.1s forwards;
}
.main-bg.off {
  display: none;
}
.main-bg > .inner {
  max-width: 500px;
  padding-right: 0;
  padding-left: 0;
  background: url("https://kakaobankcontent.com/public/statics/events/liberation815/bg_main.png") no-repeat center/100% 100%;
}
.main-bg > .inner.kakaobankqa {
  background: url("https://stg.kakaobankcontent.com/public/statics/events/liberation815/bg_main.png") no-repeat center/100% 100%;
}
.main-bg > .inner .masking-area {
  position: relative;
  width: 100%;
  height: 100%;
}
.main-bg > .inner .masking-area .masking-bg {
  position: relative;
  width: 100%;
  height: 100%;
  max-width: 100%;
  -webkit-mask-image: url("https://og.kakaobank.io/view/ab67be44-8554-49d4-95a0-490d46c5eb7b");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 300px;
  -webkit-mask-position: calc(50% + 72px) calc(50% - 218px);
  mask-image: url("https://og.kakaobank.io/view/ab67be44-8554-49d4-95a0-490d46c5eb7b");
  mask-repeat: no-repeat;
  mask-size: 300px;
  mask-position: calc(50% + 72px) calc(50% - 218px);
  -webkit-animation: ani-bg-mask 4.5s ease-in-out 0.6s forwards;
  animation: ani-bg-mask 4.5s ease-in-out 0.6s forwards;
  z-index: 2;
}

@-webkit-keyframes ani-bg-mask {
  25% {
    opacity: 1;
    -webkit-mask-position: calc(50% + 72px) calc(50% - 218px);
  }
  45%, 50% {
    -webkit-mask-position: calc(50% - 114px) calc(50% - 85px);
  }
  70%, 75% {
    -webkit-mask-position: calc(50% + 114px) calc(50% + 3px);
  }
  100% {
    opacity: 1;
    -webkit-mask-position: 50% calc(50% - 78px);
  }
}
@keyframes ani-bg-mask {
  25% {
    opacity: 1;
    mask-position: calc(50% + 72px) calc(50% - 218px);
  }
  45%, 50% {
    mask-position: calc(50% - 114px) calc(50% - 85px);
  }
  70%, 75% {
    mask-position: calc(50% + 114px) calc(50% + 3px);
  }
  100% {
    opacity: 1;
    mask-position: 50% calc(50% - 78px);
  }
}
.steps {
  margin: auto;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
  min-height: 100vh;
  overflow: hidden;
}
.steps > .inner {
  position: relative;
  height: 100%;
  padding-right: 0;
  padding-left: 0;
}

.main1 .wrap_apply {
  max-width: 500px;
  padding-right: 24px;
  padding-left: 24px;
}
.main1 .wrap_apply.is-active {
  visibility: hidden;
  -webkit-animation: ani-btn-slideup 0.5s ease-in-out 4.2s forwards;
  animation: ani-btn-slideup 0.5s ease-in-out 4.2s forwards;
}

@keyframes ani-btn-slideup {
  0% {
    visibility: hidden;
    opacity: 0;
    -webkit-transform: translateY(20px);
    transform: translateY(20px);
  }
  100% {
    visibility: visible;
    opacity: 1;
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }
}
.title-box {
  --ani-card-y: 20px;
  display: flex;
  align-items: center;
  position: fixed;
  right: 20px;
  bottom: 62px;
  left: 20px;
  margin: 0 auto;
  padding: 0 24px;
  max-width: 452px;
  width: calc(100% - 40px);
  height: 96px;
  color: #322821;
  font-weight: 700;
  font-size: 17px;
  line-height: 25px;
  border-radius: 20px;
  border: 3px solid #d2baab;
  background-color: #f3ede7;
  box-sizing: border-box;
  opacity: 0;
  z-index: 5;
}

.main1 .title-box {
  -webkit-animation: ani-txt-scroller 0.3s ease-in-out 0.1s forwards, ani-txt-scroller-slideup 0.6s ease-in-out 4.2s forwards;
  animation: ani-txt-scroller 0.3s ease-in-out 0.1s forwards, ani-txt-scroller-slideup 0.6s ease-in-out 4.2s forwards;
}

.title-box .txt-scroller {
  display: flex;
  align-items: center;
}

@-webkit-keyframes ani-txt-scroller-slideup {
  0% {
    bottom: 62px;
  }
  100% {
    bottom: 112px;
  }
}
@keyframes ani-txt-scroller-slideup {
  0% {
    bottom: 62px;
  }
  100% {
    bottom: 112px;
  }
}
/* heritage */
.heritage .heritage-box {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, calc(-50% - 32px));
  transform: translate(-50%, calc(-50% - 32px));
  width: 280px;
  height: 280px;
}

.heritage .heritage-box .light {
  position: absolute;
  top: 0;
  display: inline-block;
  width: 280px;
  height: 280px;
  background: url("https://og.kakaobank.io/view/4142bcd3-e878-4536-a586-d1ca763c174d") no-repeat center/100%;
  opacity: 0;
  -webkit-animation: ani-txt-scroller 0.5s ease-in-out 0s forwards;
  animation: ani-txt-scroller 0.5s ease-in-out 0s forwards;
}

.heritage-img {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  margin-left: 56px;
  display: flex;
  gap: 20px;
  z-index: 2;
  -webkit-animation: ani-heritage-img 3.2s ease-in-out 1.2s forwards;
  animation: ani-heritage-img 3.2s ease-in-out 1.2s forwards;
}
.heritage-img > img {
  width: 160px;
}

@-webkit-keyframes ani-heritage-img {
  0% {
    margin-left: 56px;
  }
  100% {
    margin-left: -660px;
  }
}
@keyframes ani-heritage-img {
  0% {
    margin-left: 56px;
  }
  100% {
    margin-left: -660px;
  }
}
.heritage .title-box {
  -webkit-animation: ani-txt-scroller 0.3s ease-in-out 0.1s forwards;
  animation: ani-txt-scroller 0.3s ease-in-out 0.1s forwards;
}

.heritage .title-box .item-area {
  /** 토니 추가 */
  display: flex;
  justify-content: center;
  align-items: center;
}

.heritage .title-box .item-area > p > span {
  color: #a0241b;
}

/** 토니 추가 */
.countdown-container {
  position: absolute;
  right: 26px;
  width: 49.811px;
  height: 49.811px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.countdown-number {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  user-select: none;
  color: #a0241b;
  text-align: center;
  font-size: 22.886px;
  font-weight: 700;
  line-height: 100%; /* 22.886px */
}

.countdown-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 49.811px;
  height: 49.811px;
  z-index: 1;
  scale: 1.28;
}

/* 게임영역 */
.step {
  display: none;
  margin: 0 auto;
  height: 100vh;
  overflow-x: hidden;
  width: 100%;
  background-color: #c9b095;
}
.step.on {
  display: block;
  -webkit-animation: ani-txt-scroller 0.7s ease-in-out 0s forwards;
  animation: ani-txt-scroller 0.7s ease-in-out 0s forwards;
}
.step > .inner {
  position: relative;
  max-width: 500px;
  height: 100%;
  padding-right: 0;
  padding-left: 0;
  z-index: -1;
}
.step > .inner .step-area {
  width: 100%;
  height: 100%;
}
.step > .inner .step-area .step-bg {
  position: relative;
  max-width: 100%;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.timer-wrapper {
  position: absolute;
  top: 15px;
  left: 15px;
  width: 143px;
  height: 42px;
  z-index: 5;
}

.timer-wrapper::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  display: inline-block;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #fff;
}

.timer-wrapper span {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  display: inline-block;
  width: 133px;
  height: 16px;
  border-radius: 42px;
  border: 5px solid #fff;
  background-color: #d3d3d3;
  z-index: 1;
}

.timer-wrapper span::before {
  content: "";
  position: absolute;
  width: 133px;
  height: 16px;
  background: url("https://og.kakaobank.io/view/319a3043-0bcf-4c08-b469-a2c389a8b8b6") no-repeat center/100%;
  z-index: 2;
}

.timer-wrapper span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  display: inline-block;
  width: 32px;
  height: 32px;
  background: url("https://og.kakaobank.io/view/933bfe4b-4437-4b23-818a-d2f25524edae") no-repeat center/32px;
  z-index: 3;
}

.timer {
  position: absolute;
  top: 2px;
  left: 28px;
  width: 100%;
  width: calc(100% - 28px);
  -webkit-appearance: none;
  appearance: none;
  z-index: 1;
}

.timer::-webkit-progress-bar {
  height: 12px;
  border-top-right-radius: 13px;
  border-bottom-right-radius: 13px;
  background-color: var(--color-white);
}

.timer::-webkit-progress-value {
  width: var(--progress-value);
  height: 12px;
  border-top-right-radius: 13px;
  border-bottom-right-radius: 13px;
  background: linear-gradient(270deg, #017fff 0%, #01b1ff 100%);
}

.timer.danger-time::-webkit-progress-value {
  background: linear-gradient(270deg, #ff0109 0%, #d37d88 100%);
}

/* 맵에서 선택 */
.item-box {
  position: absolute;
  width: 70px;
  height: 70px;
  margin: 0;
  padding: 0;
}

.b-item1,
.b-item2,
.b-item3,
.b-item4,
.b-item5 {
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
  will-change: transform;
  display: flex;
  justify-content: center;
  align-items: center;
}

.item-box .item {
  position: absolute;
  display: inline-block;
  width: inherit;
  height: inherit;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 60px;
  z-index: 5;
}

.item-box .item.active {
  position: absolute;
  display: inline-block;
  width: 140%;
  height: 140%;
  background: url("https://og.kakaobank.io/view/d98b6026-4a83-4750-9699-63671bbfb22e") no-repeat center/100%;
  -webkit-animation: ani-check 0.3s ease-out forwards;
  animation: ani-check 0.3s ease-out forwards;
}

.fail-area {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 4;
}

.fail-mark {
  position: absolute;
  /* transform으로 완전히 중앙 정렬 */
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  /* 터치 이벤트가 하위 요소에 영향주지 않도록 */
  pointer-events: none;
}

.fail-mark::after {
  content: "";
  width: inherit;
  height: inherit;
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  background: url("https://og.kakaobank.io/view/4332247e-be9e-44d9-bb13-f76296897774") no-repeat center/100%;
  -webkit-animation: ani-check 0.3s ease-out forwards;
  animation: ani-check 0.3s ease-out forwards;
}

@-webkit-keyframes ani-check {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.55);
  }
  70% {
    -webkit-transform: scale(0.95);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
  }
}
@keyframes ani-check {
  0% {
    opacity: 0;
    transform: scale(1.55);
  }
  70% {
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.item-list-wrapper {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  padding: 10px 10px 0;
  width: 100%;
  height: 118px;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  background: #fff;
  box-sizing: border-box;
  z-index: 5;
}

.item-list-wrapper .item-list-box {
  display: flex;
  align-items: center;
  gap: 5px;
  height: 77px;
}
.item-list-wrapper .item-list-box .item-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  position: relative;
  padding-top: 4px;
  height: 100%;
}
.item-list-wrapper .item-list-box .item-list::before {
  content: "";
  display: inline-block;
  width: 67px;
  height: 60px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 60px;
  border-radius: 10px;
}
.item-list-wrapper .item-list-box .item-list.on {
  opacity: 1;
  border-radius: 10px;
  -webkit-transition: all 0.3s ease-in 0.3s;
  transition: all 0.3s ease-in 0.3s;
}
.item-list-wrapper .item-list-box .item-list.on::before {
  background-color: #ffe1cf;
  -webkit-transition: all 0.3s ease-in 0.3s;
  transition: all 0.3s ease-in 0.3s;
}
.item-list-wrapper .item-list-box .item-list.on::after {
  content: "";
  position: absolute;
  top: 9px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  display: inline-block;
  width: 50px;
  height: 50px;
  background: url("https://og.kakaobank.io/view/bfea0ff1-5a8c-47e4-8526-d8237f0de64f") no-repeat center/100%;
  opacity: 0;
  -webkit-animation: ani-on 0.3s ease-in 0.34s forwards;
  animation: ani-on 0.3s ease-in 0.34s forwards;
}
.item-list-wrapper .item-list-box .item-list.item1::before {
  background-image: url("https://og.kakaobank.io/view/25114650-e5c8-4d7b-9f78-bd6307928f5f");
}
.item-list-wrapper .item-list-box .item-list.item2::before {
  background-image: url("https://og.kakaobank.io/view/a083bfd8-edb9-4b57-840f-1da28963b994");
}
.item-list-wrapper .item-list-box .item-list.item3::before {
  background-image: url("https://og.kakaobank.io/view/3fc54c7f-35eb-4999-b616-f6a01a174ef6");
}
.item-list-wrapper .item-list-box .item-list.item4::before {
  background-image: url("https://og.kakaobank.io/view/5a6fcb6a-b762-4bd9-8eb4-c318e491b0e7");
}
.item-list-wrapper .item-list-box .item-list.item5::before {
  background-image: url("https://og.kakaobank.io/view/91c88735-4599-487f-bc86-942caf5bd14c");
}

.item-title {
  display: inline-block;
  margin-top: 5px;
  color: #000;
  font-weight: 500;
  font-size: 11px;
  line-height: 100%;
  letter-spacing: 0px;
}

@-webkit-keyframes ani-bl-txt {
  0% {
    width: 0;
  }
  100% {
    width: calc(100% - 4px);
  }
}
@keyframes ani-bl-txt {
  0% {
    width: 0;
  }
  100% {
    width: calc(100% - 4px);
  }
}
@-webkit-keyframes ani-on {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes ani-on {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.end-heritage {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.7);
  opacity: 0;
  display: none;
}
.end-heritage .title-box {
  opacity: 1;
}
.end-heritage.on {
  z-index: 5;
  display: block;
  -webkit-animation: ani-txt-scroller 0.5s ease-in-out 0s forwards;
  animation: ani-txt-scroller 0.5s ease-in-out 0s forwards;
}

@media screen and (max-width: 360.98px) {
  .timer-wrapper {
    left: 10%;
  }
  .title-box {
    padding-right: 18px;
    padding-left: 18px;
  }
  .title-box .countdown-container {
    right: 18px;
  }
  .steps .txt-scroller-up,
  .steps .txt-scroller {
    font-size: 16px;
  }
  .item-list-wrapper .item-list-box {
    gap: 3px;
  }
  .item-list-wrapper .item-list-box .item-list::before {
    width: 100%;
    background-size: 50px;
  }
}
@media screen and (min-width: 500px) {
  .main-bg > .inner,
  .main1 .wrap_apply,
  .step > .inner {
    max-width: 375px;
  }
  .title-box {
    max-width: 327px;
  }
}
/* 슬라이드업 모션 공통 */
.result .tit-box .title,
.result .tit-box .desc,
.result .visual-box {
  --ani-card-y: 20px;
  opacity: 0;
  -webkit-animation: ani-txt-scroller 0.3s ease-in-out var(--txt-scroller-delay, 0.4s) forwards;
  animation: ani-txt-scroller 0.3s ease-in-out var(--txt-scroller-delay, 0.4s) forwards;
}

/* section1 : 4개 미션영역 */
.result {
  height: 100vh;
  background: linear-gradient(180deg, rgba(255, 158, 160, 0.3) -11.81%, rgba(108, 167, 255, 0.3) 66.16%);
  -webkit-animation: ani-card-slidup 0.5s ease-in forwards 0s;
  animation: ani-card-slidup 0.5s ease-in forwards 0s;
}
.result::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 375px;
}
.result.win::before {
  background-image: url("https://kakaobankcontent.com/public/statics/events/liberation815/success_bg.gif");
}
.result.win.kakaobankqa::before {
  background-image: url("https://stg.kakaobankcontent.com/public/statics/events/liberation815/success_bg.gif");
}
.result.lose::before {
  background-image: url("https://kakaobankcontent.com/public/statics/events/liberation815/fail_bg.gif");
}
.result.lose.kakaobankqa::before {
  background-image: url("https://stg.kakaobankcontent.com/public/statics/events/liberation815/fail_bg.gif");
}

.result .inner {
  /* padding: 62px 0 0; */
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, calc(-50% - 55px));
  transform: translate(-50%, calc(-50% - 55px));
  text-align: center;
}

.result .visual-box {
  margin-top: 69px;
  min-height: 298px;
}

.result .visual-box img {
  margin-top: var(--visual-img-mtop, 0px);
  width: var(--visual-img-width, 190px);
}

.result .off,
.txt-bubble.off {
  display: none;
}

.btn-box {
  position: fixed;
  bottom: 30px;
  bottom: 0;
  z-index: -1;
  width: 100%;
  text-align: center;
  box-sizing: border-box;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: translateY(var(--apply-translateY, 0));
  transform: translateY(var(--apply-translateY, 0));
  height: 168px;
}
.btn-box.is-active {
  z-index: 9;
  opacity: 1;
  visibility: visible;
  display: block;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  -webkit-transform: translateY(var(--apply-translateY-active, 0));
  transform: translateY(var(--apply-translateY-active, 0));
}
.btn-box .inner {
  position: relative;
  padding: 0 16px;
  height: 100%;
}
.btn-box .inner .wrap_apply {
  position: absolute;
  width: calc(100% - 32px);
}
.btn-box .inner .txt-bubble {
  position: absolute;
  bottom: 110px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 303px;
  height: 53px;
  color: #34455f;
  font-weight: 600;
  font-size: 15px;
  line-height: 53px;
  border-radius: 40px;
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(7.5px);
  -webkit-backdrop-filter: blur(7.5px);
}

@media screen and (max-height: 699.98px) {
  .result .inner {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  .result .visual-box {
    margin-top: 45px;
  }
}
.section.story {
  background: linear-gradient(180deg, rgba(255, 158, 160, 0.3) -11.81%, rgba(108, 167, 255, 0.3) 100%);
  overflow-x: hidden;
}
.section.story .inner {
  padding-top: 30px;
  padding-bottom: 99px;
  overflow: visible;
}
.section.story.on {
  display: block;
  -webkit-animation: desc-animation 0.9s ease-in-out 0.7s forwards;
  animation: desc-animation 0.9s ease-in-out 0.7s forwards;
}

@-webkit-keyframes desc-animation {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
  }
}
@keyframes desc-animation {
  0% {
    opacity: 0;
    transform: translateY(50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
.story .swiper,
.story .swiper-container {
  overflow: visible !important;
}

.story .swiper {
  padding-top: 73px;
}

.story .swiper .swiper-slide {
  max-width: 304px;
  width: 100%;
}

.story .swiper .swiper-slide .slide-box {
  position: relative;
  width: 100%;
  height: 329px;
  padding: 50px 0 0 32px;
  border-radius: 22px;
  border: 2px solid rgba(0, 0, 0, 0.17);
  background: var(--slide-box-bg, #fff);
  box-sizing: border-box;
}

.story .swiper .swiper-slide .slide-box::before {
  content: "";
  position: absolute;
  top: -62px;
  right: 0;
  display: inline-block;
  width: 152px;
  height: 152px;
  background-image: var(--box-img);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}

.story .swiper .swiper-slide .slide-box .title {
  color: var(--slide-title);
  font-weight: 700;
  font-size: 20px;
  line-height: 24px;
  letter-spacing: 0px;
}

.story .swiper .swiper-slide .slide-box .desc {
  margin-top: 40px;
  color: var(--slide-desc);
  font-weight: 500;
  font-size: 14px;
  line-height: 17px;
  letter-spacing: 0px;
}

.story .swiper .swiper-slide .slide-box .cont {
  margin-top: 15px;
  color: var(--slide-cont);
  font-weight: 700;
  font-size: 15px;
  line-height: 22px;
  letter-spacing: 0px;
}

.story .story-info {
  position: relative;
  margin-top: 60px;
  padding-left: 24px;
  color: #393939;
  font-weight: 600;
  font-size: 17px;
  line-height: 28px;
  letter-spacing: 0px;
}

.story .story-info::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  display: inline-block;
  width: 3px;
  background: rgba(6, 50, 27, 0.2);
}

.story .story-info p + p {
  margin-top: 30px;
}

.section.donation {
  background: #FAE2E6;
}

.section.donation .inner {
  padding-top: 60px;
  padding-bottom: 60px;
}

@media screen and (max-width: 360.98px) {
  .story .swiper .swiper-slide .slide-box {
    padding-left: 20px;
    padding-right: 20px;
    word-break: auto-phrase;
  }
  .story .swiper .swiper-slide .slide-box::before {
    top: -54px;
    width: 145px;
    height: 145px;
  }
}
@media screen and (max-width: 343.98px) {
  .story .swiper .swiper-slide .slide-box br {
    display: none;
  }
}