@charset "utf-8";

/* footer 스크롤 전환 */
html {
	overflow-y: scroll;
}
html::-webkit-scrollbar {
	width: 6px;
}
html::-webkit-scrollbar-track {
	background-color: #000;
}
html::-webkit-scrollbar-thumb {
	background-color: #555;
	border-radius: 3px;
}
.tourfits-campaign {
	overflow: hidden !important;
	height: 100vh !important;
}
.tourfits-campaign .new-header {
	top: -125px !important;
}
.tourfits-campaign.header-show .new-header {
	top: 0 !important;
}
.tourfits-campaign #container,
.tourfits-campaign > footer {
	margin-top: 0 !important;
}
/* comment-wrap 이하 일반 스크롤 전환 */
.tourfits-campaign.show-comment {
	overflow-y: auto !important;
	height: auto !important;
}

/* fade-up 모션 */
[data-motion="fade-in"] {
	opacity: 0;
	transition: opacity 1000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.motion-finish [data-motion="fade-in"] {
	opacity: 1;
}
[data-motion="fade-up"] {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1000ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
	transform 1000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.motion-finish [data-motion="fade-up"] {
	opacity: 1;
	transform: translateY(0);
}
/* 요소별 시간차 */
[data-motion="fade-up"]:nth-child(1) { transition-delay: 0ms; }
[data-motion="fade-up"]:nth-child(2) { transition-delay: 250ms; }
[data-motion="fade-up"]:nth-child(3) { transition-delay: 500ms;}

[data-motion="fade-in"]:nth-child(1) { transition-delay: 250ms; }
[data-motion="fade-in"]:nth-child(2) { transition-delay: 500ms; }
[data-motion="fade-in"]:nth-child(3) { transition-delay: 750ms; }
[data-motion="fade-in"]:nth-child(4) { transition-delay: 1000ms; }
[data-motion="fade-in"]:nth-child(5) { transition-delay: 1250ms; }


.contents {
	padding-bottom: 90px;
	color:#fff;
	font-family: 'Pretendard';
}
.campaign-swiper {
	width: 100%;
	height: 100vh;
}

/* HERO */
.campaign-swiper > .swiper-wrapper > .swiper-slide {
	overflow: hidden;
	width: 100%;
	height: 100%;
	text-align: center;
}
.slide-hero {
	position: relative;
	background-color: #000;
}
.campaign-swiper .img-hero {
	height: 100%;
	object-fit: cover;
}
.hero-cont {
	position: absolute;
	bottom: 2.604vw;
	left: 50%;
	padding-bottom: 3.542vw;
	transform: translateX(-50%);
	z-index: 1;
}
.hero-logo {
	height: 1.927vw;
	margin-bottom: 2.396vw;
}
.hero-logo img {
	height: 100%;
}
.hero-text {
	font-size: 1.25vw;
	line-height: 1.3;
}
.slide-hero .ico-arrow {
	position: absolute;
	bottom: 0vw;
	left: 50%;
	display: inline-block;
	width: 0.833vw;
	height: 1.042vw;
	background: url('../images/event/tourfits-campaign/ico_hero_arrow.png') no-repeat 50% 50% / cover;
	transform: translateX(-50%);
}

/* X-FACTOR */
.slide-x-factor {
	padding-top: min(5.208vw, 100px);
	text-align: center;
	background: url('../images/event/tourfits-campaign/bg_x_factor.png') no-repeat 50% 0% / cover;
}
.slide-x-factor .section-title {
	position: absolute;
	bottom: 185px;
	left: 26vw;
	font-family: 'NovaECEB';
	color: #fff;
}
.slide-x-factor .section-desc {
	position: absolute;
	bottom: 90px;
	left: 26vw;
	color: #fff;
	text-align: left;
}
.section-title {
	font-size: clamp(50px, 3.333vw, 64px);
	color: #111;
	line-height: 1;
}
.section-desc {
	margin-top: min(2.188vw, 42px);;
	font-size: clamp(20px, 1.25vw, 24px);
	color: #111;
	line-height: 1.5;
	word-break: break-word;
}
.x-factor-feature {
	position: absolute;
	top: 17%;
	left: 50%;
	width: 764px;
	height: 584px;
	text-align: center;
	transform: translateX(-50%);
	z-index: 1;
}
.feature-bg {
	display: inline-block;
	width: 548px;
	height: 584px;
	background: url('../images/event/tourfits-campaign/bg_feature.png') no-repeat 50% 50% / cover;
}
.feature-text {
	position: absolute;
	color: #CBFF30;
	font-size: max(15px, 1.042vw);
	text-align: left;
	z-index: 1;
}
.feature-text.text-01 {
	top: 21%;
	right: 0;
}
.feature-text.text-02 {
	top: 45%;
	left: 9%;
}
.feature-text.text-03 {
	top: 53%;
	right: 3%;
}
.feature-text.text-04 {
	top: 76%;
	right: 7%;
}

/* TOUR-FIT S */
.slide-torufitS {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-top: min(5.208vw, 100px);
	text-align: center;
	background: #fff;
}
.slide-torufitS .section-title {
	font-size: 0;
}
.flow-swiper {
	overflow: hidden;
	margin: 60px 0;
}
.flow-track {
	display: flex;
	align-items: center;
	width: max-content;
	will-change: transform;
	animation: flowMarquee 100s linear infinite;
}
@keyframes flowMarquee {
	0% { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}
.flow-item {
	overflow: hidden;
	display: inline-block;
	width: auto;
	height: clamp(480px, 26.458vw, 508px);
	margin-left: 1.25vw;
	flex-shrink: 0;
}
.flow-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.flow-item.img-h {
	height: clamp(400px, 22.292vw, 428px);
}

/* QUIZ */
.slide-quiz {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background:url('../images/event/tourfits-campaign/bg_quiz.png') no-repeat 50% 50% / cover;
}
.quiz-wrapper {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}
.quiz-banner {
	width: 62.5vw;
	height: 31.25vw;
	padding: 6.25vw 0 5.208vw;
	text-align: center;
	background:url('../images/event/tourfits-campaign/bg_quiz_banner.png') no-repeat 50% 50% / cover;
}
.quiz-banner .logo {
	height: 44px;
}
.quiz-banner .quiz-title {
	font-size: 2.813vw;
	font-weight: 700;
	color: #fff;
	line-height: 1;
}
.quiz-copy {
	margin-top: 3.125vw;
	font-size: 1.667vw;
	font-weight: 600;
	line-height: 1.3;
}
.quiz-desc {
	margin-top: 2.604vw;
	font-size: 1.25vw;
	line-height: 1.3;
}
.quiz-desc strong {
	font-weight: 600;
}
.btn-start-quiz {
	margin-top: 3.229vw;
	padding: 0 3.229vw;
	font-size: 0.938vw;
	color: #fff;
	line-height: 3.021vw;
	border-radius: 100px;
	background: #BE2126 url('../images/common/bg_btn_right.png') no-repeat 100% 50% / auto 3.021vw;
}

/* COMMENT */
.comment-wrap {
	padding: 3.125vw 0 2.083vw;
	background: #fff;
}
.comment-area {
	width: 72.917vw;
	margin: 0 auto;
	padding: 0;
	border: none;
}
.comment-list-title {
	align-items: flex-end;
	margin: 0 0 1.042vw;
}
.comment-list-title .title {
	font-size: 1.667vw;
	font-weight: 700;
	line-height: 1;
	color: #111;
}
.comment-list-title .count {
	font-weight: 500;
	color: #4C4C4C;
}
/* 배너 영역 */
.comment-more {
	margin-bottom: -2.083vw;
}
.campaign-banner {
	width: 100%;
	height: 16.667vw;
	margin: 2.083vw auto 0;
	padding: 4.792vw;
	background:url('../images/event/tourfits-campaign/bg_banner.png') no-repeat 50% 50% / cover;
}
.campaign-banner .banner-title {
	display: block;
	margin-bottom: 2.083vw;
	font-size: 1.458vw;
	font-weight: 700;
	color: #fff;
	text-align: center;
}
.btn-link-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.833vw;
}
.btn-link-wrap a {
	display: inline-block;
	width: 13.542vw;
	font-size: 0.938vw;
	font-weight: 600;
	line-height: 2.708vw;
	border-radius: 100px;
	text-align: center;
}
.btn-link-w {
	border: 2px solid #E32338;
	background-color: #fff;
	color: #E32338;
}
.btn-link-r {
	border: 2px solid #E32338;
	background-color: #E32338;
	color: #fff
}



/* 퀴즈 참여 레이어 */
.layer-question .layer-pop {
	overflow: hidden;
	width: 53.333vw;
	color: #fff;
	text-align: center;
	background-color: transparent;
	border-radius: 2.083vw;
}
.layer-question:before {
	background: rgba(0, 0, 0, 0.6);/* 260226_v3 */
}
.layer-question .layer-inner {
	background: url('../images/event/tourfits-campaign/bg_quize_layer_v2.png') 50% 0 no-repeat;
	background-size: cover;
}
.layer-question .layer-content {
	padding: 3.125vw 0 2.083vw;
}
.layer-question .layer-inner > .ui-close-pop {
	position: absolute;
	top: 1.25vw;
	right: 1.25vw;
	width: 2.083vw;
	height: 2.083vw;
}
.layer-question .layer-inner .ico-x-white {
	display: block;
	width: 100%;
	height: 100%;
	mask: url('../images/common/ico_close_black.png') no-repeat 50% 50% / cover;
	background-color: #fff;
}
.layer-question .question-tit {
	display: block;
	margin-bottom: 1.563vw;
	font-size: 1.875vw;
	font-weight: 700;
	line-height: 1;
}
/* 260226_v2 */
.question-cont-wrap {
	padding: 6px 10px;
	background: rgba(0, 0, 0, 0.6);
}
.layer-question .question-cont {
	font-size: 0.938vw;
	line-height: 1.5;
	color: #fff;
}
.layer-question .question-last {
	margin-top: 0.625vw;
}
.layer-question .answer-wrap {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.417vw;
	width: 27.083vw;
	margin: 1.563vw auto 0;
}
.layer-question .answer-item {
	position: relative;
	display: block;
	line-height: 2.396vw;
	text-align: left;
}
.layer-question .answer-item input {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.layer-question .answer-label {
	display: block;
	padding: 0 1.25vw;
	border-radius: 0.625vw;
	border: 2px solid transparent;
	font-size: 0.833vw; /* 260226_v3 */
	color: #111; /* 260226_v3 */
	background-color: #ccc;
}
.layer-question .answer-label strong {
	padding-left: 0.625vw;
	font-weight: 700;
}
.layer-question .answer-item input:checked + .answer-label {
	color: #111;
	background: #fff url('../images/event/tourfits-campaign/ico_check.png') no-repeat right 0.677vw top 50% / 1.25vw auto;
}
.layer-question .answer-label:disabled {
	cursor: default
}
.layer-question .btn-wrap {
	margin-top: 1.563vw;
}
.layer-question .btn-next,
.layer-question .btn-complete {
	position: relative;
	display: inline-block;
	min-width: 200px;
	padding: 0 3.229vw 0 2.604vw;
	font-size: 0.833vw;
	font-weight: 600;
	color: #111;
	line-height: 2.5vw;
	border-radius: 100px;
	text-align: center;
	box-sizing: border-box;
	background-color: #fff;
}
.layer-question .btn-complete {
	padding: 0 3.75vw;
}
.layer-question .btn-next-quiz {
	color: #fff;
	background-color: #E32338;
}
.layer-question .btn-next::after {
	content: "";
	position: absolute;
	top: 0.729vw;
	right: 1.25vw;
	width: 1.042vw;
	height: 1.042vw;
	mask: url('../images/common/icon_arrow_w_up.png') no-repeat 100% 50% / cover;
	background-color: #fff;
	transform: rotate(90deg);
}
.layer-question .btn-next-quiz::after {
	background-color: #fff;
}
.layer-question .btn-next:disabled,
.layer-question .btn-complete:disabled {
	color: #666666;
	background: #808080;
	cursor: default;
}
.layer-question .btn-next:disabled::after {
	background: #666;
}
.quiz-progress {
	overflow-y: auto;
	max-height: 70vh;
}
.quiz-progress::-webkit-scrollbar-track{
	border-radius:5px;
	background-color:#949494;
}
.quiz-progress::-webkit-scrollbar{
	width:6px;
	border-radius:5px;
	opacity:0;
}
.quiz-progress::-webkit-scrollbar-thumb{
	width:5px;
	margin:0 auto;
	border-radius:5px;
	background-color:#5a5858;
}

.quiz-progress.is-correct .desc-tit {
	color: #22D265;
}
.quiz-progress .answer-label.right-answer,
.quiz-progress input:checked + .answer-label.right-answer {
	color: #111;
	border: 2px solid #22D265;
	background: #fff url('../images/event/tourfits-campaign/ico_correct.png') no-repeat right 0.677vw top 50% / 1.25vw auto;
}
.quiz-progress.is-wrong .answer-label.right-answer {
	color: #fff;
	border: 2px solid #22D265;
	background: rgba(0,0,0,0.7);
}
.quiz-progress.is-wrong .answer-item input:checked + .answer-label {
	color: #111;
	background: #fff url('../images/event/tourfits-campaign/ico_wrong.png') no-repeat right 0.677vw top 50% / 1.25vw auto;
	border-color: #E32338;
}
.layer-question .answer-txt {
	font-size: 16px;
	font-weight: 7001;
}
.layer-question .answer-description {
	width: 35.417vw;
	margin: 1.563vw auto 0;
	padding: 0.833vw 2.604vw;
	background: rgba(0,0,0,0.7); /* 260226_v3 */
	border-radius: 0.625vw;
}
.layer-question .desc-tit {
	font-size: 0.938vw;
	font-weight: 700;
	color: #E32338;
}
.layer-question .desc-tit.is-correct {
	font-size: 0.938vw;
	font-weight: 700;
	color: #579ee6;
}
.layer-question .desc-txt {
	margin-top: 6px;
	font-size: 0.729vw;
	line-height: 1.5;
	color: #ccc;
	text-align: center;
}
.correct-answer {
	display: block;
	margin: 0.417vw auto;
	font-size: 0.729vw;
	font-weight: 700;
	color: #fff;
}

.layer-question .success-cont {
	font-size: 24px;
	line-height: 36px;
	color: #fff;
}

.layer-question .video-wrap {
	position: relative;
	width: 30.521vw;
	height: 15.729vw;
	margin: 2.604vw auto 0;
}
.layer-question .video-wrap video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.layer-question .video-wrap .btn-play {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 2.917vw;
	height: 2.917vw;
	transform: translate(-50%, -50%);
	background: url('../images/event/tourfits-campaign/btn_play.png') no-repeat 50% 50% / cover;
}

.form-wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 1.25vw 1.042vw;
	width: 38.542vw;
	margin: 1.563vw auto 0;
	padding: 1.25vw 1.563vw;
	background-color: #fff;
	border-radius: 1.25vw;
}
.form-wrap ~ .btn-wrap .btn-complete.is-active{
	color: #fff;
	background-color: #E32338;
}
.form-wrap ~ .btn-wrap .btn-complete {
	color: #666666;
	background: #808080;
}
.form-wrap .form-control {
	font-family: 'Pretendard';
	font-size: 0.729vw;
}
.form-wrap .input-group {
	flex-basis: calc(50% - (1.042vw / 2)); /* 260226_v2 */
	position: relative;
	margin-top: 0;
	text-align: left;
	font-size: 0;
}
.form-wrap .input-group.full-size {
	flex-basis: 100%;
}
.form-wrap .input-group .form-control::placeholder {
	font-size: 0.729vw;
}
.form-wrap .input-group .textarea {
	height: 5.99vw;
	font-size: 0.625vw;
}
.form-wrap .input-group label {
	font-size: 0.729vw;
	font-weight: 500;
	color: #111;
}
.form-wrap .count {
	position: absolute;
	right: 0;
	font-size: 0.625vw;
	color: #989898;
}
.form-wrap .count em {
	color: #111;
}
.require {
	color: #E32338;
}
.ico-alert {
	display:block;
	margin-top: 0.208vw;
	padding-left: 1.042vw;
	background: url('../images/event/tourfits-campaign/ico_alert_red.png') no-repeat 0 50% / cover;
	background-size: 0.833vw auto;
	color:#e32338;
	font-size: 0.625vw;
	line-height: 0.833vw;
	text-align:left;
	text-indent: initial;
}
.quiz-complete {
	padding-top: 3.906vw;
	padding-bottom: 6.146vw;
}
.quiz-complete .complete-tit {
	display: block;
	padding-top: 4.948vw;
	font-size: 2.083vw;
	font-weight: 700;
	line-height: 1;
	background: url('../images/event/tourfits-campaign/ico_complete.png') no-repeat 50% 0 / 3.75vw auto;
}
.complete-cont {
	margin-top: 3.125vw;
	margin-bottom: 2.083vw;
	font-size: 1.25vw;
	font-weight: 600;
	line-height: 1;
}
.quiz-complete .btn-link-wrap a {
	width: 10.417vw;
	font-size: 0.833vw;
	line-height: 2.292vw;
}
/* 260226_v3 */
.quiz-complete .btn-link-wrap .btn-link-w {
	border-color: #fff;
}
/* 260226_v3 */
.quiz-complete .btn-link-wrap .btn-link-r {
	border-color: #E32338;
}
/* 260226_v2 */
.cf-cont {
	margin-top: -14px;
	font-size: 0.625vw;
	color: #4C4C4C;
	text-align: left;
}
/* 260226_v3 */
.notice-info {
	display: inline-block;
	margin-top: 0.729vw;
	padding-left: 1.25vw;
	font-size: 0.729vw;
	font-weight: 600;
	background: url('../images/event/tourfits-campaign/ico_sound.png') no-repeat 0 -0.104vw / 1.042vw auto;
}