@charset "utf-8";

/* 색상 정의 변수 css */
@import url('./variables.css');

/* 리셋 */
@import url('./reset.css');

/* 웹폰트 */
@import url('./font_spoqa.css');

/* 레이아웃 */
@import url('./layout.css');

/* swiper */
@import url('./swiper.min.css');

/* 서브 */
@import url('./sub_style.css');

/* 서브 - 이벤트 상세 전용 템플릿 관련 css (진행중, 종료된 전체 해당) */
@import url('./sub_eventview.css');

a[href^='tel'] {
  vertical-align: baseline;
}

.logo {
  font-size: 17px;
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  line-height: 56px;
  padding: 0 54px;
  z-index: -1;
}

.btn-back {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  background: url('/assets/images/btn/btn-back.svg') no-repeat center / 100%;
}

.btn-gnb-open {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  background: url('/assets/images/btn/btn-gnb-open.svg') no-repeat center / 100%;
}

.btn-filter {
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
  background: url('/assets/images/btn/btn-filter.svg') no-repeat center / 100%;
}

.btn-refresh {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  background: url('/assets/images/btn/btn-refresh.svg') no-repeat center / 100%;
}

.btn-search {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  background: url('/assets/images/btn/btn-search.svg') no-repeat center / 100%;
}

/* floating button */
.floating-bottom-area {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  z-index: 50;
  background-color: var(--bg);
  display: flex !important;
  justify-content: center;
  padding: 24px 20px;
}/* 2025-09-17 : flex에 important 추가 */

.floating-bottom-area:before {
  content: '';
  width: 100%;
  height: 12px;
  position: absolute;
  left: 0;
  top: -12px;
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, var(--bg) 100%);
}

.floating-bottom-area.eventview {
  background-color: #fff;
}
.floating-bottom-area.eventview:before {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 100%);
}

.floating-bottom-area.noshadow:before {
  display: none;
}

.floating-bottom-area > *:not(:first-child) {
  margin-left: 8px;
}

.btn-floating {
  display: block;
  flex: 1 1 auto;
  text-align: center;
  height: 52px;
  font-size: 17px;
  line-height: 52px;
  border-radius: 70px;
  padding: 0 15px;
  font-weight: 700;
}

button.btn-floating {
  width: 100%;
}

.btn-floating.type01 {
  background-color: var(--primary-01);
  color: #fff;
}

.btn-floating.type02 {
  background-color: var(--button-01);
  color: var(--grayscale-03);
}

.btn-floating.type03 {
  background-color: #fff;
  color: var(--primary-01);
  border: 1px solid var(--primary-01);
}

/* 2024-12 S */
.btn-floating.ic-qr, .btn-floating.ic-barcode { 
  position:relative; 
}

.btn-floating.ic-qr:before {
  content: '';
  position:absolute;
  top: 0;
  bottom: 0;
  left: 24px;
  width: 24px;
  height: 24px;
  margin: auto 0;
  vertical-align: middle;
  background: url('/assets/images/icon/icon-qr.svg') no-repeat center / 100%; 
}

.btn-floating.ic-barcode:before {
  content: '';
  position:absolute;
  top: 0;
  bottom: 0;
  left: 24px;
  width: 24px;
  height: 24px;
  margin: auto 0;
  vertical-align: middle;
  background: url('/assets/images/icon/icon-barcode.svg') no-repeat center / 100%; 
}
/* 2024-12 E */

.btn-layer {
  display: inline-block;
  flex: 0 0 auto;
  padding: 0 22px;
  height: 41px;
  text-align: center;
  border-radius: 100px;
  font-size: 14px;
}

.btn-layer.type01 {
  color: #fff;
  font-weight: 700;
  background-color: var(--primary-01);
}

.btn-layer.type02 {
  color: var(--grayscale-01);
  background-color: #fff;
}

/* layer */
.layer-wrap {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  padding: 50px 40px;
  display: none;
  place-items: center;
  background-color: var(--dim-01);
  z-index: 1000;
}

.layer-wrap[aria-hidden='true'] {
  display: none;
}

.layer-wrap[aria-hidden='false'] {
  display: flex !important;
}

.layer-wrap .layer-container {
  padding: 26px 24px 16px 24px;
  background-color: #fff;
  box-shadow: 6px 14px 16px rgba(15, 21, 34, 0.25);
  border-radius: 14px;
  flex: 1 1 auto;
}

.layer-wrap .layer-title {
  font-size: 17px;
  font-weight: 700;
  margin-bottom: 10px;
}

.layer-wrap .layer-body {
  font-size: 15px;
  margin-bottom: 32px;
  color: var(--grayscale-03);
}

.layer-wrap .layer-body > p:not(:last-child) {
  margin-bottom: 24px;
}

.layer-wrap .layer-footer {
  display: flex;
  flex-direction: row-reverse;
}

.layer-wrap .layer-footer > *:not(:first-child) {
  margin-right: 12px;
}

.layer-wrap *:not(.layer-close-area) > .layer-close-btn {
  position: absolute;
  top: 12px;
  right: 14px;
}

.layer-close-btn {
  display: inline-block;
  width: 40px;
  height: 40px;
  background: url('/assets/images/btn/btn-close.svg') no-repeat center / 100%;
}

.layer-wrap.type02 {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: none;
  place-items: initial;
  padding: 0;
  background-color: var(--bg);
  z-index: 1000;
}

.layer-wrap.type02 .layer-container {
  display: flex;
  flex-direction: column;
  box-shadow: none;
  background-color: var(--bg);
  padding: 0;
  width: 100%;
}

.layer-wrap.type02 .layer-container .layer-header {
  flex: 0 0 56px;
  line-height: 56px;
  text-align: center;
  padding: 0 54px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.layer-wrap.type02 .layer-container .layer-title {
  margin: 0;
}

.layer-wrap.type02 .layer-container .layer-body {
  padding: 32px 20px;
  margin: 0;
  flex: 1 1 auto;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
}

.layer-wrap.type02 .layer-container .layer-footer {
  flex: 0 0 76px;
  flex-direction: row;
  align-items: center;
  padding: 24px 20px;
  position: relative;
  background-color: var(--bg);
}

.layer-wrap.type02 .layer-container .layer-footer:before {
  content: '';
  width: 100%;
  height: 12px;
  position: absolute;
  left: 0;
  top: -12px;
  background: linear-gradient(180deg, rgba(249, 250, 252, 0) 0%, var(--bg) 100%);
}

.layer-wrap.type02 .layer-container .layer-footer > * {
  flex: 1 1 100%;
}

.layer-wrap.type02 .layer-close-btn {
  top: 8px;
  right: 14px;
}

.layer-wrap.type03 {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: none;
  flex-direction: column-reverse;
  place-items: initial;
  padding: 0;

  z-index: 1000;
}

.layer-wrap.type03 .layer-container {
  padding: 64px 20px 20px 20px;
  border-radius: 20px 20px 0 0;
  flex: 0 0 auto;
  position: relative;
  box-shadow: 0 4px 4px rgb(0 0 0 / 25%);
}

.layer-wrap.type03 .layer-close-btn {
  position: absolute;
  top: 12px;
  right: 14px;
}

.layer-wrap.type03 .layer-body {
  margin-bottom: 40px;
}

.layer-wrap.type04 {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: none;
  flex-direction: column-reverse;
  place-items: initial;
  padding: 0;

  z-index: 1000;
}

.layer-wrap.type04 .layer-container {
  padding: 0;
  border-radius: 20px 20px 0 0;
  flex: 0 0 auto;
  position: relative;
  box-shadow: none;
}

.layer-wrap.type04 .layer-header {
  border-radius: 20px 20px 0 0;
  padding: 0 24px;
  height: 64px;

  color: var(--grayscale-01);
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--grayscale-10);
}

.layer-wrap.type04 .layer-header .layer-title {
  font-size: 17px;
  font-weight: 400;
  margin: 0;
}

.layer-wrap.type04 .layer-body {
  padding: 24px 24px 16px 24px;
  margin-bottom: 0;
  overflow-y: auto;
  max-height: calc(100vh - 212px);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: none;
}

.layer-wrap.type04 .layer-footer {
  padding: 20px 24px;
  position: relative;
}

.layer-wrap.type04 .layer-footer:before {
  content: '';
  width: 100%;
  height: 12px;
  position: absolute;
  left: 0;
  top: -12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 100%);
}

.layer-wrap.type04 .layer-close-area {
  position: absolute;
  top: 12px;
  right: 14px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

/* 2024-12 S */
.layer-wrap.barcode-pop .pop-gray-box { 
  margin-top: 0
}
.layer-wrap .circle-full {
 position: relative;
 padding-left: 12.5px;
 margin-top: 12px;
 text-align: left;
}

.layer-wrap .circle-full::before {
 content: '';
 position: absolute;
 top: 10px;
 left: 0;
 width: 3px;
 height: 3px;
 border-radius: 50%;
 background-color: var(--grayscale-04);
}
.layer-wrap .point-breakdown-list li {
 padding: 16px 20px;
 border-radius: 14px;
 border: 0;
 background: #f2faf6 
}
.layer-wrap .point-breakdown-list li .point-num, .layer-wrap .point-breakdown-list li .point-num b {
 font-size:18px
}
/* 2024-12 E */

/* radio button */
.btn-radio {
  background-color: #fff;
  border: 1px solid var(--grayscale-03);
  border-radius: 6px;
  color: var(--grayscale-01);
  height: 53px;
  line-height: 53px;
  padding: 0 15px;
  flex: 0 0 94px;
  width: auto;
  font-weight: 700;
  font-size: 15px;
  text-align: center;
}

.btn-radio.small {
  flex: 0 0 80px;
  height: 37px;
  line-height: 37px;
}

.btn-radio.disabled,
.btn-radio:disabled {
  background-color: var(--button-01);
  border-color: var(--button-02);
  color: var(--grayscale-08);
}

/* input */

.input-wrap {
  position: relative;
  margin: 8px 0;
}

.input-wrap:first-child,
.input-wrap:first-child .input-title {
  margin-top: 0;
}

.input-wrap:last-of-type,
.input-wrap:last-child {
  margin-bottom: 0;
}

.input-dropdown-btn,
.input-wrap .fake-input,
.input-wrap input[inputmode],
.input-wrap input[type='text'],
.input-wrap input[type='password'],
.input-wrap input[type='email'],
.input-wrap input[type='tel'],
.input-wrap input[type='number'],
.input-wrap input[type='search'] {
  color: var(--grayscale-03);
  font-size: 17px;
  border: 1px solid var(--grayscale-11);
  border-radius: 6px;
  padding: 0px 16px;
  flex: 1 1 auto;
  width: 100%;
  height: 53px;
  text-align: left;
  background-color: #fff;
}

.input-wrap .fake-input {
  display: flex;
  align-items: center;
  background-color: transparent;
}

.input-wrap .small input[inputmode],
.input-wrap .small input[type='text'],
.input-wrap .small input[type='password'],
.input-wrap .small input[type='email'],
.input-wrap .small input[type='tel'],
.input-wrap .small input[type='number'],
.input-wrap .small input[type='search'] {
  padding: 0px 8px;
  height: 37px;
  font-size: 14px;
}

/* fullsize 인풋인경우 clear버튼 들어가는 여백 설정 */
.input-wrap input[inputmode].fullsize,
.input-wrap input[type='text'].fullsize,
.input-wrap input[type='password'].fullsize,
.input-wrap input[type='email'].fullsize,
.input-wrap input[type='tel'].fullsize,
.input-wrap input[type='number'].fullsize,
.input-wrap input[type='search'] .fullsize {
  padding-right: 46px;
  /* 인풋 clear 버튼 여백*/
}

.input-wrap input[inputmode][readonly],
.input-wrap input[type='text'][readonly],
.input-wrap input[type='password'][readonly],
.input-wrap input[type='email'][readonly],
.input-wrap input[type='tel'][readonly],
.input-wrap input[type='number'][readonly],
.input-wrap input[type='search'][readonly] {
  pointer-events: none;
  caret-color: transparent;
  background-color: var(--bg);
  color: var(--grayscale-03);
}

.input-wrap input[inputmode]::-webkit-input-placeholder,
.input-wrap input[type='text']::-webkit-input-placeholder,
.input-wrap input[type='password']::-webkit-input-placeholder,
.input-wrap input[type='email']::-webkit-input-placeholder,
.input-wrap input[type='tel']::-webkit-input-placeholder,
.input-wrap input[type='number']::-webkit-input-placeholder,
.input-wrap input[type='search']::-webkit-input-placeholder {
  opacity: 1;
  color: var(--grayscale-08);
  font-size: inherit;
}

.input-wrap input[type='password'][readonly].securekeypad {
  background-color: #fff;
  pointer-events: initial;
}

.input-wrap .input-wrap-group.balance > * {
  flex: 1 1 50%;
}
.input-wrap .input-wrap-group.balance > * + * {
  margin-left: 8px !important;
  margin-right: 0;
}

.input-wrap .input-wrap-group.search input {
  padding-right: 85px;
}

.input-wrap .input-wrap-group.search .btn-search {
  margin: 0;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
}

.input-wrap .input-wrap-group.search .btn-input-clear {
  right: 54px;
}

.input-wrap .input-wrap-group.error input[inputmode],
.input-wrap .input-wrap-group.error input[type='text'],
.input-wrap .input-wrap-group.error input[type='password'],
.input-wrap .input-wrap-group.error input[type='email'],
.input-wrap .input-wrap-group.error input[type='tel'],
.input-wrap .input-wrap-group.error input[type='number'],
.input-wrap .input-wrap-group.error input[type='search'] {
  border-color: var(--etc-01) !important;
}

.input-wrap input[inputmode]:focus-visible,
.input-wrap input[type='text']:focus-visible,
.input-wrap input[type='password']:focus-visible,
.input-wrap input[type='email']:focus-visible,
.input-wrap input[type='tel']:focus-visible,
.input-wrap input[type='number']:focus-visible,
.input-wrap input[type='search']:focus-visible {
  border-color: var(--grayscale-01);
}

.input-wrap .input-wrap-label {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -999;
  opacity: 0;
  font-size: 0;
  line-height: 0;
}

.input-wrap .input-wrap-group {
  display: flex;
  align-items: center;
  margin: 8px 0;
  position: relative;
  flex: 1 1 auto;
}

.input-wrap .input-wrap-group input {
  margin-left: 8px;
}

.input-wrap .input-wrap-group input:first-of-type {
  margin-left: 0;
}

.input-wrap .input-wrap-group input ~ .btn-radio {
  margin-left: 8px;
}

.input-wrap .input-wrap-group:last-child {
  margin-bottom: 0;
}

.input-wrap .input-wrap-group .btn-input-clear {
  position: absolute;
  top: 15px;
  right: 16px;
  opacity: 0;
  margin: 0;
  visibility: hidden;
  z-index: 1;
}
.input-wrap .input-wrap-group.small .btn-input-clear {
  top: 7px;
}

.input-wrap .input-wrap-group > input.active ~ .btn-input-clear {
  opacity: 1;
  visibility: visible;
}

.input-wrap .essential-message > *,
.input-wrap p.message > * {
  font-size: inherit;
  color: inherit;
}

.input-wrap .essential-message,
.input-wrap p.message {
  flex: 1 1 100%;
  font-size: 13px;
  line-height: 19px;
  margin: 8px 0 16px 0;
}

.input-wrap .essential-message,
.input-wrap .error ~ p.message,
.input-wrap-group.error p.message {
  color: var(--etc-01);
}

.input-wrap .valid + p.message {
  color: var(--primary-01);
}

.input-wrap .input-wrap-group .essential-message,
.input-wrap .input-wrap-group.valid ~ p.message,
.input-wrap .input-wrap-group.error ~ p.message {
  display: block;
}

.input-wrap.birth-number {
  display: flex;
  flex-wrap: wrap;
}

.input-wrap.birth-number .input-title {
  margin-bottom: 8px;
  flex: 0 0 100%;
}

.input-wrap.birth-number .input-wrap-group:first-of-type {
  margin-right: 8px;
}

.input-wrap.birth-number .input-title {
  flex: 0 0 100%;
}

.input-wrap.birth-number .input-wrap-group {
  margin: 0;
  flex-wrap: wrap;
  align-items: flex-start;
  flex: 1 1 0;
}

.input-wrap.birth-number .input-wrap-group > * {
  flex: 1 1 50%;
}

.input-wrap.birth-number .input-wrap-group .message {
  flex: 1 1 100%;
}

.input-birth-sex {
  position: relative;
  display: flex;
  align-items: center;
}

.input-birth-sex label span:first-child {
  background-color: transparent;
}

.input-birth-sex input {
  flex: 0 0 100%;
  color: transparent !important;
  background: #fff url('/assets/images/bg/bg-birth-default.svg') no-repeat 14px center;
}

.input-birth-sex input:focus {
  color: transparent !important;
  caret-color: transparent;
}

.input-birth-sex input.complete {
  color: transparent !important;
  background: #fff url('/assets/images/bg/bg-birth-done.svg') no-repeat 14px center;
}

.input-birth-sex input.complete + label span:first-child {
  border: 1px solid var(--grayscale-02);
  background-color: var(--grayscale-02);
}

.input-wrap.phoneAuth .input-wrap-group {
  flex-wrap: wrap;
}

.input-wrap.phoneAuth .input-wrap-group > input {
  flex: 0 1 calc(100% - 102px);
  margin-right: 0;
}
.input-wrap.phoneAuth .btn-radio {
  margin-left: 8px;
}

.input-wrap.phoneAuth .authSend > input {
  flex: 1 1 auto;
}

.input-wrap.phoneAuth .authSend .btn-radio {
  display: none;
}

.input-title {
  display: block;
  margin-top: 24px;
  margin-bottom: 8px;
  color: var(--grayscale-04);
}

.input-title * {
  font-size: inherit;
}

.input-title .tooltip .tooltip-title {
  font-size: 15px;
  color: var(--grayscale-04);
}

.input-wrap.multibox {
  display: flex;
  align-items: flex-start;
}

.input-wrap.multibox .input-wrap-group {
  margin: 0;
  flex-wrap: wrap;
  flex-basis: 100%;
}

.input-wrap.multibox .input-wrap-group {
  margin-left: 8px;
}
.input-wrap.multibox .input-wrap-group:first-child {
  margin-left: 0;
}

.input-wrap.multibox .input-wrap-group > input {
  flex-basis: 0;
  margin: 0;
}

.input-wrap.multibox > span {
  align-self: center;
  margin-left: 8px;
}

.input-wrap .input-wrap-group.error p.message {
  color: var(--etc-01);
}

.input-dropdown-wrap .input-dropdown-btn {
  position: relative;
  color: rgba(0, 0, 0, 0.3);
  padding-right: 54px;
  line-height: 1;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.input-dropdown-btn.readonly {
  pointer-events: none;
  background-color: var(--bg);
  color: var(--button-02);
}

.input-dropdown-wrap .input-dropdown-btn:after {
  position: absolute;
  right: 6px;
  top: 50%;
  content: '';
  width: 32px;
  height: 32px;
  background: url('/assets/images/icon/icon-dropdown-arrow-both.svg') no-repeat center / 100%;
  transform: translateY(-50%);
}

.input-dropdown-wrap .input-dropdown-btn.selected {
  color: var(--grayscale-03);
}

.input-dropdown-wrap .input-dropdown-expand {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 600;
  background-color: var(--dim-01);
  width: 100%;
  height: 100%;
  display: none;
  flex-direction: column-reverse;
  align-items: flex-start;
}

.input-dropdown-wrap .input-dropdown-btn.active + .input-dropdown-expand {
  display: flex;
}

.input-dropdown-wrap .input-dropdown-expand-group {
  width: 100%;
  background-color: #fff;
  border-radius: 20px 20px 0 0;
  isolation: isolate;
  position: relative;
}

.input-dropdown-wrap .input-dropdown-expand-title {
  font-style: normal;
  display: block;
  height: 63px;
  line-height: 63px;
  padding-left: 24px;
  padding-right: 66px;
  border-bottom: 1px solid var(--button02);
}

.input-dropdown-wrap .cash-transfer-bank-group {
  max-height: calc(100vh - 119px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: none;
  border-top: 1px solid var(--grayscale-10);
}

.input-dropdown-wrap .input-dropdown-expand-list {
  overflow-y: auto;
  overscroll-behavior-y: none;
  -webkit-overflow-scrolling: touch;
  max-height: 344px;
}

.input-dropdown-wrap .input-dropdown-expand-list .input-dropdown-expand-listitem {
  position: relative;
  width: 100%;
  min-height: 52px;
  padding: 0 44px 0 24px;
}

.input-dropdown-wrap .input-dropdown-expand-list .input-dropdown-expand-listitem button {
  font-size: 15px;
  color: var(--sub-body-color);
  background-color: transparent;
  width: 100%;
  text-align: left;
  padding: 15px 0;
  padding-right: 15px;
}

.input-dropdown-wrap .input-dropdown-expand-list .input-dropdown-expand-listitem.active {
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.02)), #ffffff;
}

.input-dropdown-wrap .input-dropdown-expand-list .input-dropdown-expand-listitem.active button {
  color: var(--grayscale-03);
}

.input-dropdown-wrap .input-dropdown-expand-list .input-dropdown-expand-listitem.active:after {
  position: absolute;
  content: '';
  right: 20px;
  top: 50%;
  width: 24px;
  height: 24px;
  background: url('/assets/images/icon/icon-green-check.svg') no-repeat right center / 100%;
  transform: translateY(-50%);
}

.input-dropdown-wrap .input-dropdown-expand-close-btn {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 40px;
  height: 40px;
  background: url('/assets/images/btn/btn-close.svg') no-repeat center / 100%;
}

.cash-transfer-bank-list {
  display: grid;
  gap: 8px;
  grid-gap: 8px;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  padding: 32px 20px;
}

.cash-transfer-bank-list .bank-item {
  position: relative;
}

.cash-transfer-bank-list .bank-item input {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-appearance: none;
  cursor: pointer;
}

.cash-transfer-bank-list .bank-item label {
  display: flex;
  flex-direction: column;
  place-content: center;
  place-items: center;
  font-size: 12px;
  color: var(--grayscale-03);
  border: 1px solid var(--grayscale-10);
  line-height: 24px;
  height: 74px;
  border-radius: 6px;
}

.cash-transfer-bank-list .bank-item input:checked + label {
  border-color: var(--grayscale-01);
  font-weight: 700;
}

.cash-transfer-bank-list .bank-item label img {
  flex: 0 0 24px;
  max-width: 24px;
  margin-top: 16px;
  margin-bottom: 6px;
}

.authTimer {
  position: absolute;
  font-size: 14px;
  top: 16px;
  color: var(--etc-01);
  left: calc(100% - 157px);
}

/* tooltip */

.tooltip {
  position: relative;
}

.tooltip .tooltip-title {
  font-size: 13px;
  color: var(--grayscale-07);
  display: flex;
  align-items: center;
}

.tooltip.rightalign .tooltip-title {
  margin-left: auto;
  width: auto;
}

.tooltip .tooltip-title:after {
  content: '';
  margin-left: 7px;
  width: 18px;
  height: 18px;
  background: url('/assets/images/btn/btn-tooltip.svg') no-repeat center / 100%;
}

.tooltip .tooltip-detail {
  display: none;
  position: absolute;
  width: 100%;
  background-color: rgba(64, 66, 76, 0.9);
  box-shadow: 0px 8px 16px rgba(15, 21, 34, 0.08);
  border-radius: 14px;
  padding: 20px 48px 20px 24px;
  z-index: 20;
}

.tooltip.up .tooltip-detail {
  bottom: 26px;
}

.tooltip.down .tooltip-detail {
  top: 26px;
}

.tooltip .tooltip-title.active + .tooltip-detail {
  display: block;
}

.tooltip .tooltip-detail-list {
  color: #fff;
  font-size: 15px;
  text-align: left;
}

.tooltip .tooltip-detail-listitem {
  position: relative;
  margin-bottom: 12px;
  padding-left: 12px;
  font-weight: 400;  
}

.tooltip .tooltip-detail-listitem.nobullet {
  padding-left: 0;
}

.tooltip .tooltip-detail-listitem:not(.nobullet):before {
  content: '';
  left: 0;
  top: 10px;
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 10px;
  background-color: var(--grayscale-07);
}

.tooltip .tooltip-detail-listitem:last-child {
  margin-bottom: 0;
}

.tooltip-detail-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  background: url('/assets/images/btn/btn-close-tooltip.svg') no-repeat center / 100%;
}

/* checkbox / 전체약관동의 */

.btn-input-clear {
  width: 24px;
  height: 24px;
  background: url('/assets/images/btn/btn-input-clear.svg') no-repeat center / 100%;
}

.btn-arrow {
  width: 24px;
  height: 24px;
  background: url('/assets/images/icon/icon-arrow.svg') no-repeat center / 100%;
}

.btn-arrow.btn-arrow-darkgray {
  background: url('/assets/images/icon/icon-arrow-darkgray.svg') no-repeat center / 100%;
}

.btn-arrow.left {
  transform: rotate(180deg);
}

.btn-arrow.top {
  transform: rotate(270deg);
}

.btn-arrow.down {
  transform: rotate(90deg);
}

.checkbox-group-item {
  display: flex;
  align-items: center;
}

.checkbox-group-item [class^='input-checkbox-type'] {
  display: flex;
  align-items: center;
  position: relative;
  flex: 1 1 auto;
}

.checkbox-group-item [class^='input-checkbox-type'] label {
  cursor: pointer;
}

.checkbox-group-item input[type='checkbox'],
.checkbox-group-item input[type='radio'] {
  opacity: 0;
  border: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.checkbox-group-item label {
  padding-left: 34px;
  font-size: 15px;
  color: var(--grayscale-06);
}

.checkbox-group-item .btn-arrow {
  flex: 0 0 28px;
  align-self: flex-start;
}

.checkbox-group-item label:before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
}

.input-checkbox-type1 label:before {
  width: 24px;
  height: 24px;
  background: url('/assets/images/icon/icon-checkbox-type1-off.svg') no-repeat center/100%;
}

.input-checkbox-type1 input:disabled + label:before {
  background-image: url('/assets/images/icon/icon-checkbox-type1-disabled.svg');
}

.input-checkbox-type1 input:checked + label:before {
  background-image: url('/assets/images/icon/icon-checkbox-type1-on.svg');
}

.input-checkbox-type2 label:before {
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: url('/assets/images/icon/icon-checkbox-type2-off.svg') no-repeat center / 100%;
}

.input-checkbox-type2 input:checked + label:before {
  background-image: url('/assets/images/icon/icon-checkbox-type2-on.svg');
}

.input-checkbox-type3 label:before {
  width: 22px;
  height: 22px;
  background: url('/assets/images/icon/icon-checkbox-type3-off.svg') no-repeat center / 100%;
}

.input-checkbox-type3 input:checked + label:before {
  background-image: url('/assets/images/icon/icon-checkbox-type3-on.svg');
}

.checkbox-group-item .input-checkbox-type4 {
  display: inline-block;
}

.input-checkbox-type4 label {
  position: relative;
  display: inline-block;
  width: 51px;
  height: 31px;
  border-radius: 16px;
  vertical-align: top;
  background-color: var(--grayscale-09);
  transition: background 0.3s;
}

.input-checkbox-type4 label:before {
  position: absolute;
  left: 2px;
  top: 2px;
  width: 27px;
  height: 27px;
  border-radius: 50%;
  border: 0.5px solid rgba(0, 0, 0, 0.4);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15), 0 3px 1px rgba(0, 0, 0, 0.06);
  background-color: #fff;
  transition: all 0.3s;
}

.input-checkbox-type4 input:checked + label {
  background-color: var(--primary-01);
}

.input-checkbox-type4 input:checked + label:before {
  left: 22px;
  border-color: transparent;
}

.radiobtn-group {
  margin-bottom: 24px;
}

.radiobtn-group:last-of-type {
  margin-bottom: 0;
}

.radiobtn-group-title {
  font-size: 15px;
  color: var(--grayscale-03);
  margin-bottom: 16px;
}

.radiobtn-group-item {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px 4px;
  grid-gap: 8px 4px;
}

.input-radio-type {
  text-align: center;
  border-radius: 6px;
}

.input-radio-type input {
  position: absolute;
  inset: 0;
  -webkit-appearance: none;
  z-index: -1;
}

.input-radio-type label {
  flex: 1 1 100%;
  display: flex;

  height: 40px;
  border-radius: inherit;
  color: inherit;
  border: 1px solid var(--grayscale-10);
  transition: background 0.3s, border 0.3s;

  justify-content: center;
  align-items: center;
  cursor: pointer;
}

.input-radio-type input:checked + label {
  color: #fff;
  font-weight: 700;
  background-color: var(--grayscale-03);
  border-color: var(--grayscale-01);
}

.agreement-group {
  margin: 24px 0;
}

.agreement-group .checkboxAll + label {
  color: var(--grayscale-01);
}

.agreement-group .checkbox-all-group .checkboxAll + label {
  color: var(--grayscale-06);
}

.agreement-group .checkbox-all-group .checkbox-all-group {
  padding-left: 28px;
}

.checkbox-all-group {
  margin-top: 12px;
}

.checkbox-all-group h3 {
  margin: 24px 0 12px;
  font-size: 14px;
  color: var(--grayscale-04);
}

.checkbox-all-group h3:first-child {
  margin-top: 0;
}

.agreement-group .checkbox-group-item {
  margin-bottom: 17px;
}

.agreement-group .checkbox-all-group .checkbox-all-group .checkbox-group-item {
  margin-bottom: 10px;
}

.agreement-group .checkbox-all-group .checkbox-all-group .checkbox-group-item:last-child,
.agreement-group .checkbox-group-item:last-child {
  margin-bottom: 0;
}

/* tab menu */
.tab-menu {
  width: calc(100% + 40px);
  position: relative;
  left: -20px;
  padding: 0 20px;
  overflow-x: hidden;
}

.tab-menu-contents > div {
  display: none;
}

.tab-menu-contents > div.active {
  display: block;
}

.tab-menu.type01 .tab-item {
  position: relative;
  margin-right: 26px;
  font-size: 17px;
  line-height: 25px;
  text-align: center;
  padding-top: 15px;
  padding-bottom: 10px;
  color: var(--grayscale-04);
  width: auto;
  flex: 0 0 auto;
  display: inline-block;
}

.tab-menu.type01 .tab-item:last-child {
  margin-right: 0;
}

.tab-menu.type01 .tab-item.active {
  font-weight: 700;
  color: var(--grayscale-01);
}

.tab-menu.type01 .tab-item:after {
  display: none;
  content: '';
  width: 100%;
  height: 2px;
  position: absolute;
  bottom: 0;
  background-color: var(--grayscale-01);
}

.tab-menu.type01 .tab-item.active:after {
  display: block;
}

.tab-menu.type02 .tab-item {
  width: auto;
  margin-right: 5px;
  white-space: nowrap;
  font-size: 14px;
  line-height: 38px;
  text-align: center;
  padding: 0 13px;
  border-radius: 100px;
  border: 1px solid var(--grayscale-10);
  color: var(--grayscale-04);
  background-color: #fff;
}

.tab-menu.type02 .tab-item:last-child {
  margin-right: 5px;
}

.tab-menu.type02 .tab-item.active {
  font-weight: 700;
  color: #fff;
  border-color: var(--grayscale-03);
  background-color: var(--grayscale-03);
}

.tab-menu.type03 .tab-item {
  width: auto;
  margin-right: 5px;
  white-space: nowrap;
  font-size: 14px;
  line-height: 40px;
  text-align: center;
  padding: 0 13px;
  border-radius: 100px;
  color: var(--grayscale-04);
  background-color: var(--button-01);
}

.tab-menu.type03 .tab-item:last-child {
  margin-right: 0;
}

.tab-menu.type03 .tab-item.active {
  font-weight: 700;
  color: var(--grayscale-01);
}

.tab-menu.type04 {
  border-radius: 100px;
  background-color: #fff;
  display: flex;
  align-items: center;
  height: 32px;
  padding: 0 16px;
  width: 100%;
  left: 0;
}

.tab-menu.type04 .tab-item {
  font-size: 13px;
  color: var(--grayscale-04);
  white-space: nowrap;
  flex-shrink: 1;
}

.tab-menu.type04 .tab-item:last-child {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow-x: hidden;
}

.tab-menu.type04 .tab-item:not(:first-child):before {
  content: '';
  width: 1px;
  height: 10px;
  margin: 0 9.5px;
  display: inline-block;
  vertical-align: middle;
  background-color: var(--grayscale-11);
}

[data-cd_mapp_id]::after,
.badge {
  display: inline-flex;
  height: 19px;
  border-radius: 100px;
  padding: 0 10px;
  line-height: 16px;
  border-width: 0.5px;
  border-style: solid;
  font-size: 12px;
  align-items: center;
  text-align: center;
}

.badge.badge-notice {
  color: var(--grayscale-01);
  border-color: var(--grayscale-01);
}

.badge.badge-news {
  color: var(--badge-color-news);
  border-color: var(--badge-color-news);
}

.badge.badge-eventresult {
  color: var(--primary-01);
  border-color: var(--primary-01);
}

.checkbox-group-item label[data-cd_mapp_id] {
  display: flex;
  align-items: baseline;
}

[data-cd_mapp_id='안심']::after,
[data-cd_mapp_id='다소안심']::after,
[data-cd_mapp_id='보통']::after,
[data-cd_mapp_id='신중']::after,
[data-cd_mapp_id='주의']::after {
  content: attr(data-cd_mapp_id);
  margin-left: 8px;
}

[data-cd_mapp_id='안심']::after,
.badge[data-color='#6788d8'] {
  color: #6788d8;
  border-color: #6788d8;
}

[data-cd_mapp_id='다소안심']::after,
.badge[data-color='#30b23c'] {
  color: #30b23c;
  border-color: #30b23c;
}

[data-cd_mapp_id='보통']::after,
.badge[data-color='#ffbd5a'] {
  color: #ffbd5a;
  border-color: #ffbd5a;
}

[data-cd_mapp_id='신중']::after,
.badge[data-color='#ff7940'] {
  color: #ff7940;
  border-color: #ff7940;
}

[data-cd_mapp_id='주의']::after,
.badge[data-color='#ff3f53'] {
  color: #ff3f53;
  border-color: #ff3f53;
}

/* icon */

.icon-nothing-gray {
  display: inline-block;
  vertical-align: top;
  width: 72px;
  height: 72px;
  background: url('/assets/images/icon/icon-nothing-gray.svg') no-repeat center / 100%;
}

.icon-checked-green-circle {
  display: inline-block;
  vertical-align: top;
  width: 72px;
  height: 72px;
  background: url('/assets/images/icon/icon-checked-green-circle.svg') no-repeat center / 100%;
}

.icon-agreement-check {
  display: inline-block;
  width: 40px;
  height: 40px;
  border-radius: 40px;
  background-image: url('/assets/images/icon/icon-agreement-check.svg');
  background-color: var(--grayscale-10);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 25px;
}

.icon-checked-green-circle {
  display: inline-block;
  width: 72px;
  height: 72px;
  background: url('/assets/images/icon/icon-checked-green-circle.svg') no-repeat center / 100%;
}

.icon-auth-phone {
  display: inline-block;
  width: 32px;
  height: 32px;
  background: url('/assets/images/icon/icon-auth-phone.png') no-repeat center / 100%;
}

.icon-creditcard {
  display: inline-block;
  width: 32px;
  height: 32px;
  background: url('/assets/images/icon/icon-creditcard.png') no-repeat center / 100%;
}

.icon-notice-important {
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url('/assets/images/icon/icon-notice-important.png') no-repeat center / 100%;
}

.icon-point-green {
  display: inline-block;
  vertical-align: top;
  width: 72px;
  height: 72px;
  background: url('/assets/images/icon/icon-point-green.svg') no-repeat center / 100%;
}

.icon-badpoint-gray {
  display: inline-block;
  vertical-align: top;
  width: 72px;
  height: 72px;
  background: url('/assets/images/icon/icon-badpoint-gray.svg') no-repeat center / 100%;
}

.icon-no-product {
  display: inline-block;
  vertical-align: top;
  width: 72px;
  height: 72px;
  background: url('/assets/images/icon/icon-no-product.svg') no-repeat center / 100%;
}

.icon-arrow-wide {
  display: inline-block;
  vertical-align: top;
  width: 30px;
  height: 12px;
  background: url('/assets/images/icon/icon-arrow-wide.svg') no-repeat center / 100%;
}

/* 데이터 없음 */
.no-data {
  padding: 36px 0;
  text-align: center;
}

.no-data p {
  font-size: 16px;
  font-weight: 700;
}

.no-data .btn-wrap {
  margin-top: 40px;
  text-align: center;
}

.no-data .btn-wrap .btn-floating {
  display: inline-block;
  width: auto;
  padding: 0 32px;
  height: 48px;
  font-size: 16px;
  line-height: 46px;
}

.subtitle-01 {
  color: var(--grayscale-04);
  margin-bottom: 16px;
}

.accordian-type01 summary {
  font-size: 16px;
  font-weight: 700;
  line-height: 60px;
  padding-left: 4px;
  padding-right: 4px;
  color: var(--grayscale-03);

  display: flex;
  align-items: center;
  min-width: 0;
  position: relative;
}

.accordian-type01 summary span {
  flex: 1 1 auto;
  display: block;
  align-items: center;
  height: 60px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: calc(100% - 36px);
  font-size: 16px;
  line-height: 60px;
}

.accordian-type01 summary::after {
  content: '';
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  transform: rotate(90deg);
  background: url('/assets/images/icon/icon-arrow.svg') no-repeat center / 100%;
  position: absolute;
  top: 14px;
  right: 0;
}

.accordian-type01[open] summary::after {
  transform: rotate(-90deg);
}

.accordian-type01[open] {
  padding-bottom: 24px;
}

.accordian-type01 .bullet-type01 .link-txt {
  vertical-align: 0px;
  font-weight: 700;
  text-decoration: underline;
}

.accordian-type02 summary {
  font-size: 16px;
  font-weight: 700;
  line-height: 56px;
  padding-left: 4px;
  padding-right: 4px;
  color: var(--grayscale-03);
  display: flex;
  align-items: center;
  border-bottom: 0.5px solid var(--grayscale-10);
  min-width: 0;
  position: relative;
}

.accordian-type02 summary span {
  flex: 1 1 auto;
  display: block;
  align-items: center;
  height: 53px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: calc(100% - 32px);
  line-height: 53px;
  font-size: inherit;
}

.accordian-type02 summary::after {
  content: '';
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  transform: rotate(90deg);
  background: url('/assets/images/icon/icon-arrow-darkgray.svg') no-repeat center / 100%;
  position: absolute;
  top: 10px;
  right: 0;
}

.accordian-type02[open] summary::after {
  transform: rotate(-90deg);
}

.accordian-type02[open] summary {
  border-bottom: none;
}

.accordian-type02[open] > .accordian-detail,
.accordian-type02[open] > ul {
  background: #fff;
  width: calc(100% + 40px);
  position: relative;
  left: -20px;
  padding: 24px 30px;
  margin-top: 0;
}

.accordian-type02[open] ul li {
  font-size: 15px;
  color: var(--grayscale-01);
}

.accordian-type02[open] ul li + li {
  margin-top: 12px;
}

.accordian-type02[open] .bullet-type01 {
  margin-bottom: 0;
}

.accordian-type02[open] .bullet-type01:before {
  background-color: var(--grayscale-01);
  top: 9px;
}

.accordian-type03 {
  width: 100vw;
  margin-left: -20px;
}

.accordian-type03 summary {
  position: relative;
  padding: 18px 52px 18px 24px;
  color: var(--grayscale-03);
  border-bottom: 1px solid var(--grayscale-10);
}

.accordian-type03 summary span {
  display: block;
  font-size: 18px;
  font-weight: 700;
}

.accordian-type03 summary::marker {
  content: '';
  display: none;
}

.accordian-type03 summary::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 20px;
  width: 28px;
  height: 28px;
  margin-top: -14px;
  transform: rotate(90deg);
  background: url('/assets/images/icon/icon-arrow.svg') no-repeat center / 100%;
}

.accordian-type03[open] summary::after {
  transform: rotate(-90deg);
}

.accordian-type03[open] .accordian-detail {
  padding: 24px 20px;
  margin-top: 0;
}

.bullet-type01 {
  position: relative;
  padding-left: 13px;
  margin-bottom: 20px;
  font-size: 15px;
  color: var(--grayscale-04);
}

.bullet-type01:last-child {
  margin-bottom: 0;
}

.bullet-type01:before {
  content: '';
  position: absolute;
  left: 0;
  top: 11px;
  width: 3px;
  height: 3px;
  border-radius: 100px;
  background-color: var(--grayscale-04);
}

/* 공유하기, top 버튼 */
.floating-btn-box {
  position: fixed;
  bottom: 40px;
  right: 20px;
  z-index: 100;
}

.floating-btn-box a {
  display: block;
  width: 44px;
  height: 44px;
  margin-bottom: 4px;
  border-radius: 50%;
}

.floating-btn-box a:last-child {
  margin-bottom: 0;
}

.floating-btn-box a.btn-top {
  opacity: 0;
  visibility: hidden;
  margin-bottom: -44px;
  border: 1px solid var(--primary-01);
  background: #fff url('/assets/images/btn/btn-top.svg') no-repeat center;
  transition: all 0.3s;
}

.floating-btn-box a.btn-top.active {
  margin-bottom: 0;
  opacity: 1;
  visibility: visible;
}

.floating-btn-box a.btn-share {
  background-image: url('/assets/images/btn/btn-share.svg');
  background-color: var(--primary-01);
  background-repeat: no-repeat;
  background-position: center;
  transition: all 0.3s;
}

.floating-btn-box.open a.btn-share {
  background-image: url('/assets/images/btn/btn-share-close.svg');
}

.floating-btn-box .share-list {
  position: relative;
  top: 48px;
  height: 44px;
  opacity: 0;
  z-index: -1;
  overflow: hidden;
  visibility: hidden;
  transition: all ease 0.5s;
}

.floating-btn-box.open .share-list {
  height: auto;
  top: 0;
  visibility: visible;
  opacity: 1;
  margin-bottom: 4px;
}

.floating-btn-box .share-list li:not(:last-child) {
  margin-bottom: 4px;
}

.floating-btn-box .share-list li > a {
  border: 1px solid var(--grayscale-10);
}

.floating-btn-box a.btn-kakao {
  background: #fff url('/assets/images/btn/btn-kakao.svg') no-repeat center;
}

.floating-btn-box a.btn-url {
  background: #fff url('/assets/images/btn/btn-url.svg') no-repeat center;
}

/* id 찾기 */
.column-between {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: calc(100vh - 180px);
}

.column-between-con {
  flex: 0 0 auto;
}

.link-type01 {
  display: inline-block;
  align-items: center;
  color: var(--grayscale-03);
}

.link-type01:after {
  content: '';
  display: inline-block;
  margin-left: 4px;
  width: 12px;
  height: 12px;
  background: url('/assets/images/icon/icon-view-more.svg') no-repeat center / 100%;
}

.text-type01 {
  display: inline-block;
  font-size: 13px;
  color: var(--grayscale-07);
}

.title-type01 {
  padding: 0 4px;
  font-size: 20px;
  font-weight: 700;
  color: var(--grayscale-01);
}

.highlight {
  font-weight: 700;
  color: var(--primary-01);
}

.highlight.type02 {
  color: var(--primary-02);
  font-weight: 400;
}

.highlight.type03 {
  color: var(--etc-01);
  font-weight: 700;
}

.sub-dl {
  padding: 0 4px;
  color: var(--grayscale-01);
}

.sub-dl + .sub-dl {
  margin-top: 16px;
}

.sub-dt {
  margin-bottom: 12px;
  font-weight: 700;
  font-size: 18px;
}

.sub-dd {
  font-size: 16px;
  margin-bottom: 8px;
  color: inherit;
}

.sub-dd strong {
  color: inherit;
}

.sub-dd .btn-mini {
  margin-top: 6px;
}
