@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: var(--popup-single-pu-img-width, 55px);
  height: var(--popup-single-pu-img-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: #FFE300;
}

.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/a63e6d17-3f6b-4702-abd6-6c157125d5fd") 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: 60px 16px;
  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;
}

.outros-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/a63e6d17-3f6b-4702-abd6-6c157125d5fd") 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);
}

/* 인트로, outro 롤링text 메시지 : main.html, outro.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);
  }
}
/* 하단으로 이동 */
/* 컨텐츠 공통 */
.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: 32px; /* 114.286% */
}
.tit-box .title span {
  color: var(--color-mtxt, #3ea986);
}
.tit-box .badge {
  display: inline-block;
  padding: 8px 14px;
  color: var(--color-badge, #fff);
  font-size: 14px;
  font-weight: 700;
  line-height: 18px; /* 128.571% */
  letter-spacing: -0.14px;
  border-radius: 100px;
  background: var(--bg-badge, #3ea986);
  box-sizing: border-box;
}
.tit-box .desc {
  display: block;
  --txt-scroller-delay: 0.5s;
  color: var(--color-tit-desc, #000);
  font-weight: 400;
  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);
}

#output {
  background: #f3f3f3;
}

/* 슬라이드업 모션 공통 */
.intro .tit-box .title,
.intro .tit-box .desc,
.intro .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 :  */
.intro {
  padding: 0;
}
.intro .inner {
  padding-right: 0;
  padding-left: 0;
}
.intro .m-visual {
  position: relative;
  text-align: center;
  overflow: hidden;
}
.intro .m-visual img {
  max-width: none;
}
.intro .scroll-down {
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  display: inline-block;
  width: 50px;
  height: 113px;
}
.intro .scroll-down .ico {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 50px;
  height: 50px;
  background: transparent url("https://og.kakaobank.io/view/0b73133d-c819-42fa-bfd8-267afb438398") no-repeat top/100%;
  -webkit-animation: airplaneloop 1.8s infinite;
  animation: airplaneloop 1.8s infinite;
  z-index: 1;
}
.intro .scroll-down svg {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(calc(-50% + 0.5px));
  transform: translateX(calc(-50% + 0.5px));
}

@-webkit-keyframes airplaneloop {
  0% {
    -webkit-transform: translateY(-90px) translateX(-50%);
    opacity: 0.25;
    scale: 0.9;
  }
  30% {
    opacity: 1;
    scale: 1;
  }
  60%, 100% {
    -webkit-transform: translateY(0px) translateX(-50%);
    opacity: 0;
    scale: 0.95;
  }
}
@keyframes airplaneloop {
  0% {
    transform: translateY(-90px) translateX(-50%);
    opacity: 0.25;
    scale: 0.9;
  }
  30% {
    opacity: 1;
    scale: 1;
  }
  60%, 100% {
    transform: translateY(0px) translateX(-50%);
    opacity: 0;
    scale: 0.95;
  }
}
@media screen and (min-width: 675px) {
  .intro .scroll-down {
    position: relative;
  }
}
@media screen and (max-width: 674.98px) {
  .intro {
    height: 100vh;
  }
  .intro .m-visual {
    height: 441px;
  }
  .intro .m-visual img {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 675px;
  }
  .intro .tit-box {
    position: absolute;
    bottom: 29vh;
    left: 50%;
    transform: translate(-50%, calc(-50% + 88px));
    width: 100%;
  }
  .intro .tit-box .desc + .title {
    margin-top: 15px;
  }
  .intro .scroll-down {
    position: absolute;
    bottom: 40px;
  }
}
@media screen and (max-height: 699.98px) {
  .intro .scroll-down {
    bottom: 0;
  }
}
@media screen and (max-height: 554.98px) {
  .intro .m-visual img {
    margin-top: -24%;
  }
}
.main {
  /* 탭 헤더 스타일 */
  /* 탭 콘텐츠 스타일 */
  /* 카드 스타일 */
  /* 애니메이션 */
}
.main .inner {
  padding-top: 40px;
  padding-bottom: 50px;
}
.main .tit-box .badge + .title {
  margin-top: 13px;
}
.main .tab-header {
  position: relative;
  display: flex;
  align-items: flex-start;
  align-self: stretch;
  margin-top: 45px;
  padding-top: 52px;
  height: 49px;
  /* 슬라이딩 배경 인디케이터 */
}
.main .tab-header::after {
  content: "";
  position: absolute;
  bottom: 0;
  display: inline-block;
  width: 100%;
  height: 49px;
  border-radius: 16px;
  background: #fff;
}
.main .tab-header .tab-indicator {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  align-self: stretch;
  gap: 4px;
  flex: 1 0 0;
  margin-top: 4px;
  margin-left: 4px;
  padding: 6px 16px;
  width: 87px;
  height: 29px;
  border-radius: 16px;
  background: linear-gradient(90deg, #52c8e5 0%, #4ed461 100%);
  -webkit-transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}
.main .tab-header .tab-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  padding: 10px 20px;
  height: 49px;
  border: none;
  color: #aaa;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 20px;
  cursor: pointer;
  white-space: nowrap;
  user-select: none;
  -webkit-user-select: none;
  background: transparent;
  z-index: 2;
}
.main .tab-header .tab-button::before {
  content: "";
  position: absolute;
  top: -52px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  display: inline-block;
  width: 52px;
  height: 52px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
.main .tab-header .tab-button[data-tab=first-week]::before {
  background-image: url("https://og.kakaobank.io/view/ed6c59bd-e98f-4ffe-b586-2e6ee3efa2da");
}
.main .tab-header .tab-button[data-tab=second-week]::before {
  background-image: url("https://og.kakaobank.io/view/52cbf139-fd30-4e03-879b-c4f76389bf9a");
}
.main .tab-header .tab-button[data-tab=third-week]::before {
  background-image: url("https://og.kakaobank.io/view/cc40cbec-e8d8-4d6e-ae9c-632cb907c5e8");
}
.main .tab-header .tab-button.active {
  color: #fff;
}
.main .tab-header .tab-button.active[data-tab=first-week]::before {
  background-image: url("https://og.kakaobank.io/view/9539114c-9609-48f5-91e9-91c3c4bba101");
}
.main .tab-header .tab-button.active[data-tab=second-week]::before {
  background-image: url("https://og.kakaobank.io/view/b6d01439-69cc-4f4a-b93b-2297f90d7043");
}
.main .tab-header .tab-button.active[data-tab=third-week]::before {
  background-image: url("https://og.kakaobank.io/view/8d1319f0-b233-464f-bfa0-53c26fb45c90");
}
.main .tab-content {
  position: relative;
  margin-top: 25px;
}
.main .tab-content .tab-panel {
  display: none;
  -webkit-animation: fadeIn 0.3s ease-in-out;
  animation: fadeIn 0.3s ease-in-out;
}
.main .tab-content .tab-panel.active {
  display: block;
}
.main .card {
  padding: 19px 19px 28px;
  border-radius: 20px;
  background: #fff;
}
.main .card .card-img {
  position: relative;
  width: 100%;
  height: 167px;
  border-radius: 10px;
  overflow: hidden;
}
.main .card .card-img > img {
  max-width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.main .card .card-img.end::after, .main .card .card-img.soon::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: inline-block;
  background: rgba(0, 0, 0, 0.7);
}
.main .card .card-img.end .txt, .main .card .card-img.soon .txt {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  color: #fff;
  font-size: var(--font-size-endsoon, 15px);
  font-weight: 700;
  text-align: center;
  line-height: 22px; /* 146.667% */
  z-index: 1;
  display: block;
}
.main .card .card-img.soon {
  --font-size-endsoon: 21px;
}
.main .card .card-img .txt {
  display: none;
}
.main .card .card-badge {
  margin: 15px 0 11px;
}
.main .card .card-badge > span {
  padding: 5px 6px 4px;
  color: var(--color-card-badge, #0083d1);
  font-size: 11px;
  font-weight: 700;
  border-radius: 6px;
  background: var(--bg-card-badge, #e1f1fa);
  box-sizing: border-box;
}
.main .card .card-badge > span.end {
  --color-card-badge: #eb2d2b;
  --bg-card-badge: #fdeaea;
  display: none;
}
.main .card .card-badge > span.end.active {
  display: inline;
}
.main .card .card-badge > span.off {
  --color-card-badge: #5f5f5f;
  --bg-card-badge: #ebebeb;
  display: none;
}
.main .card .card-badge > span.off.active {
  display: inline;
}
.main .card .card-title {
  display: flex;
  align-items: end;
  justify-content: space-between;
}
.main .card .card-title > div {
  flex: 1;
}
.main .card .card-title .tit {
  display: block;
  color: #000;
  font-size: 20px;
  font-weight: 700;
  line-height: 24px;
}
.main .card .card-title .schedule {
  color: #999;
  font-size: 13px;
  font-weight: 400;
  line-height: 19px;
  white-space: nowrap;
}
.main .card .card-title .schedule > span {
  position: relative;
  padding-left: 13px;
}
.main .card .card-title .schedule > span::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 5px;
  display: inline-block;
  width: 1px;
  height: 11px;
  background: #e6e6e6;
}
.main .card .card-title .title-button {
  height: 23.937px;
  margin-bottom: 2px;
  padding: 5.5px 8px;
  color: #222;
  font-size: 11.137px;
  line-height: 11px;
  font-weight: 400;
  border-radius: 6px;
  border: 0.428px solid #ccc;
  background: #fff;
}
.main .card-footer {
  display: none;
  position: relative;
  padding: 20px 19px 18px;
  border-radius: 20px;
  background: #fff;
}
.main .card-footer.active {
  display: block;
}
.main .card-footer::before {
  content: "";
  position: absolute;
  top: -1px;
  right: 20px;
  left: 20px;
  height: 2px;
  display: inline-block;
  --s: 4px;
  background: radial-gradient(circle closest-side, #eeeeee 98%, rgba(0, 0, 0, 0)) 0 0/var(--s) 100%, linear-gradient(90deg, #eeeeee 50%, rgba(0, 0, 0, 0) 0) calc(var(--s) / 2) 0/calc(2 * var(--s)) 100%;
}
.main .card-footer > p {
  color: #000;
  font-size: 13px;
  font-weight: 700;
  line-height: 19px; /* 146.154% */
}
.main .card-footer > p::before {
  content: "";
  display: inline-block;
  margin-right: 8px;
  width: 19px;
  height: 19px;
  vertical-align: middle;
  background: url("https://og.kakaobank.io/view/7948a5b9-83ee-4464-93d1-e97fb11429d3") no-repeat center/100%;
}
.main .card-footer > p > span {
  position: relative;
  display: inline-block;
  padding-left: 13px;
}
.main .card-footer > p > span::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 5px;
  display: inline-block;
  width: 1px;
  height: 11px;
  background: #bcbcbc;
}
.main .card-footer > p > span > span {
  color: #eb2d2b;
}
.main .card-btn {
  display: block;
  margin-top: 13px;
  height: 60px;
  color: var(--color-card-btn, #000);
  text-align: center;
  font-size: 17px;
  font-weight: 700;
  line-height: 60px;
  border-radius: 13px;
  background: var(--bg-card-btn, #ffe300);
}
.main .card-btn.end {
  --color-card-btn: #fff;
  --bg-card-btn: #b9b9b9;
}
.main .card-btn.soon {
  pointer-events: none;
  --color-card-btn: #a1a1a1;
  --bg-card-btn: #e1e1e1;
}
.main .card-btn + .tip {
  margin-top: 11px;
}
.main .tip {
  color: var(--TEXT-Gray-999, #999);
  font-size: 13px;
  font-weight: 400;
  text-align: center;
  line-height: 19px; /* 146.154% */
  display: none;
}
.main .tip.active {
  display: block;
}
@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
    -webkit-transform: translateY(10px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.popups.newyork .modal-sub,
.popups.hawaii .modal-sub,
.popups.sydney .modal-sub {
  margin-top: 20px;
}
.popups.newyork ul,
.popups.hawaii ul,
.popups.sydney ul {
  padding: 20px;
  border-radius: 8px;
  background: #f7f7f7;
  text-align: left;
}
.popups.newyork ul li,
.popups.hawaii ul li,
.popups.sydney ul li {
  position: relative;
  padding-left: 8px;
  word-break: keep-all;
}
.popups.newyork ul li::before,
.popups.hawaii ul li::before,
.popups.sydney ul li::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 0;
  display: inline-block;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: #666;
}
.popups.newyork ul li + li,
.popups.hawaii ul li + li,
.popups.sydney ul li + li {
  margin-top: 12px;
}
.popups.newyork .pu-img,
.popups.hawaii .pu-img,
.popups.sydney .pu-img {
  --popup-single-pu-img-width: 50px;
  --popup-single-pu-img-height: 52px;
  padding: 0 8.438px 0.193px 8px;
  align-items: center;
}

@media screen and (max-width: 360.98px) {
  .main .card .card-title .tit {
    font-size: 19px;
  }
  .main .card .card-img {
    padding-bottom: 57.9%;
    height: auto;
  }
}
@media screen and (max-width: 360.98px) {
  .main .inner {
    padding-right: 18px;
    padding-left: 18px;
  }
  .main .card .card-title .schedule > span {
    padding-left: 10px;
  }
  .main .card .card-title .schedule > span::before {
    left: 2px;
  }
}
@media screen and (max-height: 554.98px) {
  .popups.newyork ul,
  .popups.hawaii ul,
  .popups.sydney ul {
    max-height: 145px;
    overflow-y: auto;
  }
}
.section.outro .inner {
  position: relative;
  padding-top: 60px;
  overflow: visible;
}
.section.outro .inner::before {
  content: "";
  position: absolute;
  top: 0;
  right: 24px;
  left: 24px;
  display: inline-block;
  height: 1px;
  background: #DFDFDF;
}
.section.outro .tit-box .badge + .title {
  margin-top: 18px;
}
.section.outro .tit-box .title + .desc {
  margin-top: 11px;
}
.section.outro .img-box {
  margin-top: 31px;
  margin-bottom: 27px;
  text-align: center;
}
.section.outro .img-box img {
  width: 203px;
}
.section.outro .noti-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 32px;
}
.section.outro .noti-box p {
  color: #333;
  font-size: 15px;
  font-weight: 700;
  line-height: 20px; /* 133.333% */
}
.section.outro .noti-box p::before {
  content: "";
  display: inline-block;
  margin-right: 4px;
  width: 32px;
  height: 32px;
  vertical-align: middle;
  background: url("https://og.kakaobank.io/view/99bb9e0c-0d25-4fa8-9b4d-8ef22e4ffff7") no-repeat center/100%;
}
.section.outro .noti-box .noti-btn {
  width: 81px;
  height: 45px;
  color: var(--color-noti-btn, #fff);
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 45px;
  border-radius: 10px;
  background: var(--bg-noti-btn, #333B58);
}
.section.outro .noti-box .noti-btn.cancel {
  --color-noti-btn:#222222;
  --bg-noti-btn:#DDDDDD;
}

@media screen and (max-width: 360.98px) {
  .section.outro .inner {
    padding-right: 18px;
    padding-left: 18px;
  }
  .section.outro .noti-box p {
    font-size: 14px;
  }
}