@import url("https://cdnjs.cloudflare.com/ajax/libs/meyer-reset/2.0/reset.min.css");
* {
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}
html,
body {
  margin: 0px;
  height: 100%;
}
button:focus-visible {
  outline: 2px solid #4a90e2;
  outline-offset: 2px;
}
a {
  text-decoration: none;
}
@font-face {
  font-family: "Pretendard-Medium";
  src: local("Pretendard Medium"), local("Pretendard-Medium"),
    url("../font/Pretendard-Medium.woff") format("woff");
  font-weight: 500;
  font-display: swap;
}

/* 잘난체: 로컬 미설치 시 CDN(여기어때 잘난체, @noonnu/yg-jalnan MIT) */
@font-face {
  font-family: "Jalnan 2-Regular";
  src: local("Jalnan 2"), local("Jalnan 2-Regular"),
    url("https://cdn.jsdelivr.net/npm/@noonnu/yg-jalnan@0.1.0/fonts/yg-jalnan-normal.woff")
      format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Pretendard-SemiBold";
  src: local("Pretendard SemiBold"), local("Pretendard-SemiBold"),
    url("../font/Pretendard-SemiBold.woff") format("woff");
  font-weight: 600;
  font-display: swap;
}

@font-face {
  font-family: "Pretendard-Bold";
  src: local("Pretendard Bold"), local("Pretendard-Bold"),
    url("../font/Pretendard-Bold.woff") format("woff");
  font-weight: 700;
  font-display: swap;
}

@font-face {
  font-family: "Pretendard-Regular";
  src: local("Pretendard Regular"), local("Pretendard-Regular"),
    url("../font/Pretendard-Regular.woff") format("woff");
  font-weight: 400;
  font-display: swap;
}

.screen {
  background-color: #1e1f23;
  width: 100%;
  min-height: 4748px;
  position: relative;
}

.screen .rectangle {
  position: absolute;
  top: 470px;
  left: calc(50.00% - 170px);
  width: 341px;
  height: 3691px;
  background-color: #ffffff;
  border-radius: 23px;
  box-shadow: 1px 3px 10.4px 1px #0000000d;
}

/* 히어로 장식 4종: 375px 아트보드를 화면 가로 중앙에 */
.screen .guide-hero-deco {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 375px;
  max-width: calc(100% - 16px);
  top: 0;
  height: 430px;
  pointer-events: none;
}

.screen .rb {
  position: absolute;
  top: 1px;
  left: 0;
  width: 180px;
  height: 264px;
  object-fit: cover;
}

.screen .img {
  position: absolute;
  top: 100px;
  left: 289px;
  width: 81px;
  height: 81px;
}

.screen .element {
  position: absolute;
  top: 275px;
  left: 50%;
  transform: translateX(-50%);
  width: max-content;
  max-width: calc(100% - 24px);
  height: 19px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Pretendard-Medium", Helvetica;
  font-weight: 500;
  color: #2eff96;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: normal;
  white-space: nowrap;
  box-sizing: border-box;
}

.screen .div {
  position: absolute;
  top: 338px;
  left: calc(50.00% - 170px);
  width: 341px;
  height: 116px;
  background-color: #e6ffeb;
  border-radius: 23px;
  box-shadow: 1px 3px 10.4px 1px #0000000d;
  overflow: hidden;
}

/* 배너 안 요소는 .div 기준 좌표 (기존 값은 .screen 기준이라 흰 카드에 가려짐) */
.screen .div .banner-globe {
  position: absolute;
  right: 6px;
  bottom: 4px;
  width: min(42%, 120px);
  height: auto;
  max-height: 92px;
  object-fit: contain;
  pointer-events: none;
}

.screen .text-wrapper {
  position: absolute;
  top: 26px;
  left: 0;
  right: 72px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Pretendard-Medium", Helvetica;
  font-weight: 500;
  color: #191f28;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: 22px;
  white-space: nowrap;
}

.screen .element-2 {
  position: absolute;
  top: 50px;
  left: 0;
  right: 72px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Jalnan 2-Regular", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 26px;
  letter-spacing: 0;
  line-height: 33px;
  white-space: nowrap;
}

/* 민트 배너 안 문구: 박스 전체 너비 기준 가운데 */
.screen .div .text-wrapper,
.screen .div .element-2 {
  left: 0;
  right: 0;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box;
  justify-content: center;
  white-space: nowrap;
}

.screen .rectangle-2 {
  position: absolute;
  top: 525px;
  left: calc(50.00% - 96px);
  width: 193px;
  height: 13px;
  background-color: #2eff96;
}

.screen .frame {
  top: 568px;
  display: flex;
  flex-direction: column;
  width: 67px;
  height: 24px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: absolute;
  left: calc(50.00% - 34px);
  background-color: #363636;
  border-radius: 100px;
}

.screen .element-3 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  margin-top: -11.50px;
  margin-bottom: -9.50px;
  font-family: "Pretendard-SemiBold", Helvetica;
  font-weight: 600;
  color: #ffffff;
  font-size: 14px;
  text-align: center;
  letter-spacing: 0;
  line-height: 25px;
}

.screen .p {
  position: absolute;
  top: 616px;
  left: calc(50.00% - 122px);
  height: 60px;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 22px;
  text-align: center;
  letter-spacing: 0;
  line-height: 30px;
}

.screen .image {
  position: absolute;
  top: 686px;
  left: calc(50.00% - 108px);
  width: 217px;
  height: 470px;
  aspect-ratio: 0.46;
  object-fit: cover;
}

.screen .group {
  position: absolute;
  top: 1177px;
  left: calc(50.00% - 142px);
  width: 290px;
  height: 110px;
}

.screen .group-2 {
  position: absolute;
  top: 0;
  left: calc(50.00% - 145px);
  width: 286px;
  height: 110px;
  background-color: #f2f5fd;
  border-radius: 18px;
}

.screen .element-4 {
  position: absolute;
  top: 15px;
  left: calc(50.00% - 106px);
  height: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: 25px;
  white-space: nowrap;
}

.screen .element-5 {
  top: 43px;
  left: calc(50.00% - 131px);
  height: 50px;
  font-size: 16px;
  position: absolute;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  letter-spacing: 0;
  line-height: 25px;
}

.screen .bell {
  position: absolute;
  width: 8.28%;
  height: 19.78%;
  top: 13.64%;
  left: 4.14%;
}

.screen .ellipse {
  position: absolute;
  width: 22.88%;
  height: 22.88%;
  top: 70.64%;
  left: 38.57%;
  border-radius: 2.75px / 2.49px;
  background: radial-gradient(
      50% 50% at 54% 57%,
      rgba(234, 128, 89, 0) 44%,
      rgba(194, 112, 104, 1) 100%
    ),
    linear-gradient(
      172deg,
      rgba(229, 115, 86, 1) 19%,
      rgba(229, 115, 86, 0) 100%
    ),
    radial-gradient(
      50% 50% at 113% 57%,
      rgba(255, 194, 109, 1) 0%,
      rgba(246, 141, 97, 1) 100%
    );
}

.screen .rectangle-3 {
  position: absolute;
  width: 7.53%;
  height: 13.63%;
  top: 6.44%;
  left: 46.24%;
  border-radius: 1.2px;
  background: radial-gradient(
      50% 50% at 61% 39%,
      rgba(223, 144, 87, 0) 0%,
      rgba(223, 144, 87, 0.24) 82%,
      rgba(223, 144, 87, 1) 100%
    ),
    linear-gradient(
      90deg,
      rgba(223, 144, 87, 1) 0%,
      rgba(223, 144, 87, 0.24) 64%,
      rgba(223, 144, 87, 0) 100%
    ),
    radial-gradient(
      50% 50% at 50% 20%,
      rgba(255, 233, 87, 1) 0%,
      rgba(247, 166, 48, 1) 100%
    );
}

.screen .union {
  position: absolute;
  width: 90.50%;
  height: 86.75%;
  top: 13.25%;
  left: 9.50%;
}

.screen .element-wrapper {
  top: 1347px;
  display: flex;
  flex-direction: column;
  width: 67px;
  height: 24px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: absolute;
  left: calc(50.00% - 34px);
  background-color: #363636;
  border-radius: 100px;
}

.screen .element-6 {
  position: absolute;
  top: 1391px;
  left: calc(50.00% - 98px);
  height: 60px;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 22px;
  text-align: center;
  letter-spacing: 0;
  line-height: 30px;
}

.screen .image-2 {
  position: absolute;
  top: 1463px;
  left: calc(50.00% - 108px);
  width: 217px;
  max-width: min(217px, calc(100% - 24px));
  height: 296px;
  aspect-ratio: 0.73;
  object-fit: cover;
}

.screen .div-wrapper {
  top: 1824px;
  display: flex;
  flex-direction: column;
  width: 67px;
  height: 24px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: absolute;
  left: calc(50.00% - 34px);
  background-color: #363636;
  border-radius: 100px;
}

.screen .element-7 {
  top: 1869px;
  left: calc(50.00% - 108px);
  height: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  text-align: center;
  white-space: nowrap;
  position: absolute;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  letter-spacing: 0;
  line-height: 25px;
}

.screen .image-3 {
  position: absolute;
  top: 1911px;
  left: calc(50.00% - 108px);
  width: 217px;
  height: 470px;
  aspect-ratio: 0.46;
  object-fit: cover;
}

.screen .rectangle-4 {
  position: absolute;
  top: 2197px;
  left: 85px;
  width: 205px;
  height: 42px;
  border: 2px solid;
  border-color: #ff0000;
}

.screen .rectangle-5 {
  position: absolute;
  top: 1574px;
  left: 85px;
  width: 205px;
  height: 41px;
  border: 2px solid;
  border-color: #ff0000;
}

.screen .rectangle-6 {
  position: absolute;
  top: 1620px;
  left: 85px;
  width: 205px;
  height: 37px;
  border: 2px solid;
  border-color: #ff0000;
}

.screen .group-3 {
  position: absolute;
  top: 2398px;
  left: calc(50.00% - 142px);
  width: 288px;
  height: 77px;
}

.screen .group-4 {
  position: absolute;
  top: 0;
  left: calc(50.00% - 144px);
  width: 286px;
  height: 77px;
  background-color: #f2f5fd;
  border-radius: 18px;
}

.screen .element-8 {
  position: absolute;
  top: 15px;
  left: calc(50.00% - 122px);
  height: 50px;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 16px;
  letter-spacing: 0;
  line-height: 25px;
}

.screen .frame-2 {
  top: 2540px;
  display: flex;
  flex-direction: column;
  width: 67px;
  height: 24px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: absolute;
  left: calc(50.00% - 34px);
  background-color: #363636;
  border-radius: 100px;
}

.screen .element-9 {
  position: absolute;
  top: 2583px;
  left: calc(50.00% - 126px);
  height: 60px;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 22px;
  text-align: center;
  letter-spacing: 0;
  line-height: 30px;
}

.screen .image-4 {
  position: absolute;
  top: 2654px;
  left: calc(50.00% - 108px);
  width: 217px;
  height: 247px;
  aspect-ratio: 0.88;
}

.screen .rectangle-7 {
  position: absolute;
  top: 2744px;
  left: 85px;
  width: 205px;
  height: 62px;
  border: 2px solid;
  border-color: #ff0000;
}

.screen .group-5 {
  position: absolute;
  top: 2920px;
  left: calc(50.00% - 142px);
  width: 288px;
  height: 77px;
}

.screen .frame-3 {
  top: 3062px;
  display: flex;
  flex-direction: column;
  width: 67px;
  height: 24px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: absolute;
  left: calc(50.00% - 34px);
  background-color: #363636;
  border-radius: 100px;
}

.screen .element-10 {
  position: absolute;
  top: 3105px;
  left: calc(50.00% - 122px);
  height: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 22px;
  text-align: center;
  letter-spacing: 0;
  line-height: 25px;
  white-space: nowrap;
}

.screen .span {
  color: #e25f5f;
}

.screen .text-wrapper-2 {
  color: #191f28;
}

.screen .image-5 {
  position: absolute;
  top: 3146px;
  left: calc(50.00% - 108px);
  width: 216px;
  height: 230px;
  aspect-ratio: 0.94;
}

.screen .rectangle-8 {
  position: absolute;
  top: 3261px;
  left: 85px;
  width: 205px;
  height: 35px;
  border: 2px solid;
  border-color: #ff0000;
}

.screen .group-6 {
  position: absolute;
  top: 3395px;
  left: calc(50.00% - 142px);
  width: 288px;
  height: 77px;
}

.screen .element-11 {
  top: 13px;
  left: calc(50.00% - 122px);
  height: 50px;
  font-size: 16px;
  position: absolute;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  letter-spacing: 0;
  line-height: 25px;
}

.screen .frame-4 {
  top: 3537px;
  display: flex;
  flex-direction: column;
  width: 67px;
  height: 24px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: absolute;
  left: calc(50.00% - 34px);
  background-color: #363636;
  border-radius: 100px;
}

.screen .element-12 {
  position: absolute;
  top: 3576px;
  left: calc(50.00% - 100px);
  height: 60px;
  font-family: "Pretendard-Bold", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 22px;
  text-align: center;
  letter-spacing: 0;
  line-height: 30px;
}

.screen .image-6 {
  position: absolute;
  top: 3647px;
  left: calc(50.00% - 108px);
  width: 216px;
  height: 467px;
  aspect-ratio: 0.46;
  object-fit: cover;
}

.screen .element-13 {
  position: absolute;
  top: 172px;
  left: 50%;
  transform: translateX(-50%);
  width: min(340px, calc(100% - 32px));
  height: auto;
  min-height: 92px;
  font-family: "Jalnan 2-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 36px;
  text-align: center;
  letter-spacing: 0;
  line-height: 46px;
  box-sizing: border-box;
}

.screen .rb-2 {
  position: absolute;
  top: 236px;
  left: 248px;
  width: 127px;
  height: 189px;
  object-fit: cover;
}

.screen .element-14 {
  position: absolute;
  top: 506px;
  left: calc(50.00% - 88px);
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Jalnan 2-Regular", Helvetica;
  font-weight: 400;
  color: #191f28;
  font-size: 24px;
  text-align: center;
  letter-spacing: 0;
  line-height: 36px;
  white-space: nowrap;
}

.screen .group-7 {
  position: absolute;
  top: 4181px;
  left: calc(50.00% - 170px);
  width: 345px;
  height: 500px;
}

.screen .rectangle-9 {
  position: absolute;
  top: 0;
  left: calc(50.00% - 172px);
  width: 341px;
  height: 500px;
  background-color: #ffffff;
  border-radius: 23px;
  box-shadow: 1px 3px 10.4px 1px #0000000d;
  overflow: visible;
}

.screen .element-15 {
  position: absolute;
  top: 104px;
  left: 20px;
  right: 20px;
  width: auto;
  max-width: none;
  height: auto;
  min-height: 0;
  font-family: "Pretendard-Regular", Helvetica;
  font-weight: 400;
  color: #191f28;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 24px;
  list-style: disc;
  list-style-position: outside;
  padding-left: 1.35em;
  margin: 0;
  box-sizing: border-box;
}

.screen .group-7 .element-15 {
  overflow: visible;
}

.screen .element-15 li {
  margin: 0 0 12px 0;
  padding-left: 0;
  text-align: left;
  display: list-item;
  width: 100%;
  box-sizing: border-box;
}

.screen .element-15 li:last-child {
  margin-bottom: 0;
}

.screen .element-16 {
  position: absolute;
  top: 52px;
  left: 50%;
  transform: translateX(-50%);
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Jalnan 2-Regular", Helvetica;
  font-weight: 700;
  color: #191f28;
  font-size: 26px;
  letter-spacing: 0;
  line-height: 32px;
  white-space: nowrap;
  text-align: center;
}

/* 유의사항: 형광펜처럼 글자 아래쪽만 색이 겹침 */
.screen .group-7 .element-16 .notice-title-highlight {
  display: inline-block;
  padding: 0 10px 1px;
  background: linear-gradient(
    180deg,
    transparent 0,
    transparent 50%,
    #2eff96 65%,
    #2eff96 100%
  );
  border-radius: 2px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.screen .rectangle-11 {
  position: absolute;
  top: 980px;
  left: 86px;
  width: 205px;
  height: 153px;
  border: 2px solid;
  border-color: #ff0000;
}

.step-section {
  position: static;
}

body.guide-page {
  margin: 0;
  background-color: #1e1f23;
  min-height: 100vh;
}

.guide-page .screen {
  margin-left: auto;
  margin-right: auto;
  max-width: 430px;
  width: 100%;
  min-width: 0;
}

/* STEP 안내 문구: 동일한 세로축(중앙) 정렬 — 제각각이던 left 오프셋 제거 */
.screen > .p,
.screen > .element-6,
.screen > .element-7,
.screen > .element-9,
.screen > .element-12 {
  left: 50% !important;
  transform: translateX(-50%);
  width: min(302px, calc(100% - 24px));
  max-width: 100%;
  box-sizing: border-box;
}

.screen > .element-10 {
  left: 50% !important;
  transform: translateX(-50%);
  max-width: min(302px, calc(100% - 24px));
}
