@import url("https://cdn.jsdelivr.net/gh/fonts-archive/Paperlogy/Paperlogy.css");

@font-face {
  font-family: "YPairing";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2601-4@1.1/YPairingFont.woff2") format("woff2");
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "YPairing";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2601-4@1.1/YPairingFont-Bd.woff2") format("woff2");
  font-weight: 700;
  font-display: swap;
}

#scratchPromotionApp {
  color: #222;
  background: #061f76;
  font-family: Inter, Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-synthesis: none;
  text-rendering: optimizeLegibility;
}

#scratchPromotionApp,
#scratchPromotionApp * {
  box-sizing: border-box;
}

#scratchPromotionApp {
  margin: 0;
  min-width: 320px;
  background: #fff;
  position: relative;
}

#scratchPromotionApp:is(.not-period, .event-end) {
  pointer-events: none;
}

#scratchPromotionApp:is(.not-period, .event-end)::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 997;
  display: block;
  background: rgba(0, 0, 0, .85);
}

#scratchPromotionApp:is(.not-period, .event-end)::after {
  position: fixed;
  inset: 0;
  z-index: 998;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
  font-family: "Paperlogy", Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 1.35;
  color: #fff;
}

#scratchPromotionApp.not-period::after {
  content: "이벤트 시작 전입니다.";
}

#scratchPromotionApp.event-end::after {
  content: "이벤트가 종료되었습니다.";
}

#scratchPromotionApp button {
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

#scratchPromotionApp img {
  display: block;
  max-width: none;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-touch-callout: none;
  pointer-events: none;
}

.figma-stage {
  overflow-x: hidden;
}

.mo-stage {
  display: none;
}

.design {
  position: relative;
  overflow: hidden;
  margin: 0 auto;
  background: #fff;
}

.design-pc {
  width: min(100vw, 1920px);
}

.design-mo {
  width: min(100vw, 720px);
}

.pc-section,
.mo-section {
  position: relative;
  overflow: hidden;
}

.pc-section {
  --s: var(--pc-scale, 1);
  width: 100%;
}

.mo-section {
  --s: var(--mo-scale, 1);
  width: 100%;
}

.pc-section.sec1 {
  aspect-ratio: 1920 / 1950;
}

.pc-section.sec2 {
  aspect-ratio: 1920 / 1309;
}

.pc-section.sec3 {
  aspect-ratio: 1920 / 1384;
}

.pc-section.sec4 {
  aspect-ratio: 1920 / 1892;
}

.pc-section.sec5 {
  aspect-ratio: 1920 / 1760;
}

.pc-section.sec6 {
  aspect-ratio: 1920 / 1101;
}

.mo-sec1 {
  aspect-ratio: 720 / 1648;
}

.mo-sec2 {
  aspect-ratio: 720 / 1041;
}

.mo-sec3 {
  aspect-ratio: 720 / 2181;
}

.mo-sec4 {
  aspect-ratio: 720 / 1924;
}

.mo-sec5 {
  aspect-ratio: 720 / 2652;
}

.mo-sec6 {
  aspect-ratio: 720 / 1399;
}

.bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}

.bg-top {
  object-position: top center;
}

.pc-no-purchase-sec1-bg {
  height: 163.85%;
  object-fit: fill;
  object-position: top left;
}

.pc-sec3-bg {
  inset: auto;
  top: 0;
  left: 0;
  width: 105.02%;
  height: 131.43%;
  object-fit: fill;
  object-position: top left;
}

.pc-event-detail {
  position: absolute;
  top: calc(853px * var(--s));
  left: 50%;
  display: grid;
  gap: calc(16px * var(--s));
  width: calc(646px * var(--s));
  transform: translateX(-50%);
}

.event-row {
  position: relative;
  width: 100%;
}

.event-row.pc {
  aspect-ratio: 646 / 74;
}

.event-row.mo {
  aspect-ratio: 567 / 63;
}

.event-row img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.event-row span,
.event-row strong {
  position: absolute;
  transform: none;
  font-family: Paperlogy, Inter, Pretendard, sans-serif;
  letter-spacing: -.2px;
  white-space: nowrap;
}

.event-row.pc span {
  top: calc(18px * var(--s));
  left: calc(42px * var(--s));
  color: #fff;
  font-size: calc(28px * var(--s));
  font-weight: 500;
  line-height: 1.4;
}

.event-row.pc strong {
  top: calc(20px * var(--s));
  color: #47578c;
  font-size: calc(24px * var(--s));
  font-weight: 600;
  line-height: 1.4;
}

.event-row.pc.event-date strong {
  left: calc(261px * var(--s));
}

.event-row.pc.winner-date strong {
  left: calc(326px * var(--s));
}

.pc-copy {
  position: absolute;
  top: calc(166px * var(--s));
  left: 50%;
  display: grid;
  justify-items: center;
  width: calc(619px * var(--s));
  transform: translateX(-50%);
}

.pc-subcopy {
  width: calc(349px * var(--s));
  height: calc(64px * var(--s));
  object-fit: cover;
}

.pc-maincopy {
  position: relative;
  overflow: hidden;
  width: calc(589px * var(--s));
  height: calc(370px * var(--s));
  margin-top: calc(48px * var(--s));
}

.main-copy-frame > img {
  position: absolute;
  top: -33.03%;
  left: 0;
  width: 100%;
  height: 132.97%;
  object-fit: fill;
}

.pc-section.no-purchase .main-copy-frame > img {
  top: 0;
  height: 100%;
  object-fit: cover;
}

.pc-bodycopy {
  width: calc(619px * var(--s));
  height: calc(77px * var(--s));
  margin-top: calc(64px * var(--s));
  object-fit: cover;
}

.pc-logo {
  position: absolute;
  top: calc(61px * var(--s));
  left: calc(1477px * var(--s));
  width: calc(146px * var(--s));
}

.pc-scratch {
  position: absolute;
  width: calc(1082px * var(--s));
  height: calc(547px * var(--s));
}

.pc-scratch-normal {
  top: calc(1095px * var(--s));
  left: 50%;
  transform: translateX(-50%);
}

.pc-scratch-order {
  top: calc(349px * var(--s));
  left: 50%;
  transform: translateX(-50%);
}

.scratch-base {
  position: absolute;
  top: calc(37px * var(--s));
  left: 50%;
  width: calc(970px * var(--s));
  height: calc(510px * var(--s));
  transform: translateX(-50%);
  object-fit: cover;
}

.scratch-locked-overlay {
  position: absolute;
  top: calc(37px * var(--s));
  left: 50%;
  z-index: 2;
  width: calc(970px * var(--s));
  height: calc(510px * var(--s));
  transform: translateX(-50%);
  object-fit: cover;
}

.scratch-prize-reveal {
  position: absolute;
  top: calc(93px * var(--s));
  left: 50%;
  z-index: 2;
  width: calc(837px * var(--s));
  height: calc(399px * var(--s));
  overflow: hidden;
  pointer-events: none;
  transform: translateX(-50%);
}

.scratch-prize-result,
.scratch-prize-cover,
.scratch-prize-texture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.scratch-prize-result {
  z-index: 2;
  border-radius: inherit;
  object-fit: contain;
}

.scratch-prize-result.prize-daiso,
.scratch-prize-result.prize-oliveyoung {
  inset: 7%;
  width: 86%;
  height: 86%;
  object-fit: contain;
}

.scratch-prize-result.prize-tamburins {
  object-fit: contain;
  transform: scale(.92);
}

.scratch-prize-cover {
  z-index: 0;
  background: transparent;
}

.scratch-prize-texture {
  z-index: 1;
  object-fit: cover;
}

.pc-scratch-order .scratch-base {
  top: calc(29px * var(--s));
  width: calc(989px * var(--s));
  height: calc(520px * var(--s));
}

.pc-scratch-order .scratch-prize-reveal {
  top: calc(90px * var(--s));
  left: 50%;
}

.scratch-tag {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 3;
  width: calc(330px * var(--s));
  height: calc(77px * var(--s));
  transform: translateX(-50%);
}

.scratch-coin {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
}

.scratch-canvas {
  position: absolute;
  top: calc(103px * var(--s));
  left: calc(122px * var(--s));
  z-index: 4;
  width: calc(837px * var(--s));
  height: calc(399px * var(--s));
  border-radius: calc(28px * var(--s));
  cursor: grab;
  touch-action: none;
  mix-blend-mode: normal;
}

.pc-button {
  position: absolute;
  z-index: 6;
  width: calc(699px * var(--s));
  height: calc(183px * var(--s));
  left: 50%;
  transform: translateX(-50%);
}

.pc-button-normal {
  top: calc(1674px * var(--s));
}

.pc-button-normal.is-unavailable {
  top: calc(1690px * var(--s));
}

.pc-button-order {
  top: calc(959px * var(--s));
}

.pc-button img,
.mo-button img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pc-button span,
.mo-button span {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #2a2a2a;
  font-family: Paperlogy, Inter, Pretendard, sans-serif;
  font-style: normal;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -.2px;
}

.pc-button span {
  font-size: calc(70px * var(--s));
}

.pc-button-order span {
  color: #491f05;
}

.pc-sec2-title {
  position: absolute;
  top: calc(80px * var(--s));
  left: 50%;
  display: grid;
  justify-items: center;
  gap: calc(28px * var(--s));
  width: calc(628px * var(--s));
  transform: translateX(-50%);
}

.pc-sec2-title img:first-child {
  width: 100%;
  height: calc(41px * var(--s));
  object-fit: cover;
}

.pc-sec2-title img:last-child {
  width: calc(581px * var(--s));
  height: calc(140px * var(--s));
  object-fit: cover;
}

.pc-caption {
  position: absolute;
  top: calc(1173px * var(--s));
  left: 50%;
  width: calc(562px * var(--s));
  transform: translateX(-50%);
}

.lock-stack {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 4;
  display: grid;
  justify-items: center;
  gap: calc(32px * var(--s));
  transform: translate(-50%, -50%);
}

.pc-scratch-order .lock-stack {
  top: calc(29px * var(--s) + 260px * var(--s));
}

.lock-stack img:first-child {
  width: calc(203px * var(--s));
}

.lock-stack img:last-child {
  width: calc(722px * var(--s));
}

.wide-title {
  position: absolute;
  left: 50%;
  width: calc(1495px * var(--s));
  transform: translateX(-50%);
}

.pc-sec3-title {
  top: calc(91px * var(--s));
}

.pc-prizes {
  position: absolute;
  top: calc(239px * var(--s));
  left: 50%;
  display: grid;
  gap: calc(52px * var(--s));
  width: calc(1301px * var(--s));
  transform: translateX(-50%);
}

.pc-prizes img {
  width: 100%;
}

.pc-review-title,
.pc-event-title {
  top: calc(88px * var(--s));
}

.pc-review-heading {
  position: absolute;
  top: calc(216px * var(--s));
  left: 50%;
  display: grid;
  justify-items: center;
  gap: calc(32px * var(--s));
  width: calc(701px * var(--s));
  transform: translateX(-50%);
}

.pc-review-heading img:nth-child(1) {
  width: calc(505px * var(--s));
  height: calc(46px * var(--s));
  object-fit: cover;
}

.pc-review-heading img:nth-child(2) {
  width: 100%;
  height: calc(81px * var(--s));
  object-fit: cover;
}

.pc-review-heading img:nth-child(3) {
  width: calc(481px * var(--s));
  height: calc(23px * var(--s));
  object-fit: cover;
}

.pc-review-image {
  position: absolute;
  top: calc(477px * var(--s));
  left: 50%;
  width: calc(958px * var(--s));
  transform: translateX(-50%);
}

.pc-event-box {
  position: absolute;
  top: calc(230px * var(--s));
  left: 50%;
  display: grid;
  gap: calc(31px * var(--s));
  width: calc(1200px * var(--s));
  transform: translateX(-50%);
}

.pc-event-box > img,
.app-card > img {
  width: 100%;
}

.app-card {
  position: relative;
}

.event-app-button {
  position: absolute;
  left: 50%;
  bottom: 10.2%;
  display: block;
  width: calc(381px * var(--s));
  aspect-ratio: 381 / 85;
  transform: translateX(-50%);
  cursor: pointer;
  text-decoration: none;
}

.event-app-button > img:first-child {
  width: 100%;
  height: 100%;
  object-fit: fill;
}

.event-app-button span {
  position: absolute;
  top: 50%;
  left: calc(86px / 381px * 100%);
  color: #fff;
  font-family: Paperlogy, Inter, Pretendard, sans-serif;
  font-size: calc(32px * var(--s));
  font-style: normal;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -.2px;
  white-space: nowrap;
  transform: translateY(-50%);
}

.event-app-chevron {
  position: absolute;
  top: 50%;
  left: calc(269px / 381px * 100%);
  width: calc(40px * var(--s));
  height: calc(40px * var(--s));
  transform: translateY(-50%);
}

.notice-box {
  position: absolute;
  top: calc(91px * var(--s));
  left: 50%;
  width: calc(1200px * var(--s));
  transform: translateX(-50%);
}

.notice-box > img {
  width: calc(167px * var(--s));
}

.notice-copy {
  margin-top: calc(24px * var(--s));
  color: rgba(255, 255, 255, .9);
  font-weight: 500;
  letter-spacing: -.2px;
}

.notice-copy.pc {
  font-size: calc(24px * var(--s));
  line-height: 1.8;
}

.notice-copy p {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .35em;
  margin: 0;
}

.notice-copy b {
  font: inherit;
}

.notice-copy p > span {
  min-width: 0;
}

.notice-copy p > span span {
  display: inline-block;
}

.mo-event-detail {
  position: absolute;
  top: calc(794px * var(--s));
  left: 50%;
  display: grid;
  gap: calc(18px * var(--s));
  width: calc(567px * var(--s));
  transform: translateX(-50%);
}

.event-row.mo span {
  top: calc(15px * var(--s));
  left: calc(36.86px * var(--s));
  color: #fff;
  font-size: calc(24px * var(--s));
  font-weight: 500;
  line-height: 1.4;
}

.event-row.mo strong {
  top: calc(17.55px * var(--s));
  color: #47578c;
  font-size: calc(22px * var(--s));
  font-weight: 600;
  line-height: 1.4;
}

.event-row.mo.event-date strong {
  left: calc(223.08px * var(--s));
}

.event-row.mo.winner-date strong {
  left: calc(283.08px * var(--s));
}

.mo-copy {
  position: absolute;
  top: calc(151px * var(--s));
  left: 50%;
  display: grid;
  justify-items: center;
  width: calc(619px * var(--s));
  transform: translateX(-50%);
}

.mo-subcopy {
  width: calc(278px * var(--s));
  height: calc(51px * var(--s));
  object-fit: cover;
}

.mo-maincopy {
  position: relative;
  overflow: hidden;
  width: calc(474px * var(--s));
  height: calc(298px * var(--s));
  margin-top: calc(60px * var(--s));
}

.mo-bodycopy {
  width: calc(563px * var(--s));
  height: calc(70px * var(--s));
  margin-top: calc(68px * var(--s));
  object-fit: cover;
}

.mo-scratch {
  position: absolute;
  width: calc(686px * var(--s));
  height: calc(347px * var(--s));
  left: 50%;
  transform: translateX(-50%);
}

.mo-scratch-normal {
  top: calc(1034px * var(--s));
}

.mo-scratch-order {
  top: calc(336px * var(--s));
}

.mo-scratch .scratch-base {
  top: calc(23px * var(--s));
  width: calc(614px * var(--s));
  height: calc(323px * var(--s));
}

.mo-scratch-order .scratch-base {
  top: calc(17px * var(--s));
  width: calc(588px * var(--s));
  height: calc(309px * var(--s));
}

.mo-scratch .scratch-prize-reveal {
  top: calc(59px * var(--s));
  left: 50%;
  width: calc(530px * var(--s));
  height: calc(253px * var(--s));
}

.mo-scratch-order .scratch-prize-reveal {
  top: calc(52px * var(--s));
  left: 50%;
  width: calc(530px * var(--s));
  height: calc(253px * var(--s));
}

.mo-scratch .scratch-tag {
  top: 0;
  width: calc(210px * var(--s));
  height: calc(49px * var(--s));
}

.mo-scratch-order .scratch-tag {
  top: calc(-3px * var(--s));
}

.mo-scratch .scratch-canvas {
  top: calc(59px * var(--s));
  left: calc(78px * var(--s));
  width: calc(530px * var(--s));
  height: calc(253px * var(--s));
  border-radius: calc(18px * var(--s));
}

.mo-button {
  position: absolute;
  z-index: 6;
  left: 50%;
  width: calc(440px * var(--s));
  height: calc(119px * var(--s));
  transform: translateX(-50%);
}

.mo-button-normal {
  top: calc(1420px * var(--s));
}

.mo-button-order {
  top: calc(715px * var(--s));
}

.mo-button span {
  font-size: calc(44px * var(--s));
}

.mo-button-order span {
  color: #491f05;
}

.mo-sec2-title {
  position: absolute;
  top: calc(98px * var(--s));
  left: 50%;
  display: grid;
  justify-items: center;
  gap: calc(28px * var(--s));
  width: calc(628px * var(--s));
  transform: translateX(-50%);
}

.mo-sec2-title img:first-child {
  width: 100%;
  height: calc(41px * var(--s));
  object-fit: cover;
}

.mo-sec2-title img:last-child {
  width: calc(480px * var(--s));
  height: calc(116px * var(--s));
  object-fit: cover;
}

.mo-caption {
  position: absolute;
  top: calc(885px * var(--s));
  left: 50%;
  width: calc(562px * var(--s));
  transform: translateX(-50%);
}

.mo-scratch .lock-stack {
  top: calc(17px * var(--s) + 154.5px * var(--s));
  gap: calc(19px * var(--s));
}

.mo-scratch .lock-stack img:first-child {
  width: calc(120px * var(--s));
}

.mo-scratch .lock-stack img:last-child {
  width: calc(429px * var(--s));
}

.mo-wide-title {
  position: absolute;
  top: calc(100px * var(--s));
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
}

.mo-prizes {
  position: absolute;
  top: calc(228px * var(--s));
  left: 50%;
  display: grid;
  gap: calc(52px * var(--s));
  width: calc(680px * var(--s));
  transform: translateX(-50%);
}

.mo-prizes img {
  width: 100%;
}

.mo-review-heading {
  position: absolute;
  top: calc(228px * var(--s));
  left: 50%;
  display: grid;
  justify-items: center;
  gap: calc(32px * var(--s));
  width: calc(672px * var(--s));
  transform: translateX(-50%);
}

.mo-review-heading img:nth-child(1) {
  width: calc(505px * var(--s));
  height: calc(46px * var(--s));
  object-fit: cover;
}

.mo-review-heading img:nth-child(2) {
  width: calc(660px * var(--s));
  height: calc(76px * var(--s));
  object-fit: cover;
}

.mo-review-heading img:nth-child(3) {
  width: calc(481px * var(--s));
  height: calc(23px * var(--s));
  object-fit: cover;
}

.mo-review-image {
  position: absolute;
  top: calc(456px * var(--s));
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
}

.scratch-comment-section {
  position: absolute;
  z-index: 4;
  left: 50%;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: calc(24px * var(--s));
  padding: calc(34px * var(--s));
  border: calc(2px * var(--s)) solid rgba(190, 148, 36, .55);
  border-radius: calc(22px * var(--s));
  background: #fff;
  box-shadow: 0 calc(14px * var(--s)) calc(28px * var(--s)) rgba(78, 49, 0, .12);
  box-sizing: border-box;
  transform: translateX(-50%);
}

.scratch-comment-pc {
  top: calc(900px * var(--s));
  width: calc(1003px * var(--s));
  height: auto;
  aspect-ratio: 1003 / 900;
  min-height: 0;
}

.pc-section.sec4 .scratch-comment-section {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.scratch-comment-mo {
  top: calc(844px * var(--s));
  width: calc(620px * var(--s));
  min-height: calc(810px * var(--s));
  gap: calc(18px * var(--s));
  padding: calc(24px * var(--s));
  border-radius: calc(18px * var(--s));
}

.scratch-comment-section .comment-form {
  display: grid;
  grid-template-columns: 1fr calc(190px * var(--s));
  gap: calc(16px * var(--s));
  align-items: stretch;
}

.scratch-comment-mo .comment-form {
  grid-template-columns: 1fr calc(132px * var(--s));
  gap: calc(10px * var(--s));
}

.scratch-comment-section .pmt-textarea {
  position: relative;
  min-height: calc(116px * var(--s));
}

.scratch-comment-section .pmt-button {
  display: block !important;
  min-height: calc(116px * var(--s));
}

.scratch-comment-mo .pmt-textarea {
  min-height: calc(96px * var(--s));
}

.scratch-comment-section textarea {
  width: 100%;
  height: 100%;
  padding: calc(22px * var(--s)) calc(28px * var(--s)) calc(34px * var(--s));
  resize: none;
  border: 0;
  border-radius: calc(14px * var(--s));
  background: #f4f4f4;
  color: #2a2a2a;
  font-family: Paperlogy, sans-serif;
  font-size: calc(22px * var(--s));
  font-weight: 500;
  line-height: 1.45;
  outline: 0;
  box-sizing: border-box;
}

.scratch-comment-mo textarea {
  padding: calc(16px * var(--s)) calc(18px * var(--s)) calc(30px * var(--s));
  border-width: calc(2px * var(--s));
  border-radius: calc(12px * var(--s));
  font-size: calc(22px * var(--s));
}

.scratch-comment-section .text-length {
  position: absolute;
  right: calc(22px * var(--s));
  bottom: calc(12px * var(--s));
  color: #777;
  font-family: Paperlogy, sans-serif;
  font-size: calc(16px * var(--s));
  line-height: 1;
}

.scratch-comment-section .pmt-button button {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: calc(116px * var(--s));
  padding: 0;
  border: 0;
  border-radius: calc(14px * var(--s));
  appearance: none;
  background: #d53410 !important;
  color: #fff !important;
  font-family: Paperlogy, sans-serif;
  font-size: calc(26px * var(--s));
  font-weight: 700;
  line-height: 1;
  box-shadow: none;
  text-indent: 0 !important;
  cursor: pointer;
}

.scratch-comment-section .pmt-button button:hover {
  background: #c22f0e !important;
}

.scratch-comment-section .pmt-button button:active {
  transform: none;
}

.scratch-comment-section .pmt-button button:disabled {
  background: #b7b7b7 !important;
  opacity: .8;
  transform: none;
  box-shadow: none;
  cursor: wait;
}

.scratch-comment-mo .pmt-button button {
  min-height: calc(96px * var(--s));
  border-radius: calc(12px * var(--s));
  font-size: calc(24px * var(--s));
}

.scratch-comment-mo .pmt-button {
  min-height: calc(96px * var(--s));
}

.scratch-comment-section .comment-list-wrap {
  height: 100%;
  min-height: calc(420px * var(--s));
  overflow: hidden;
  border: calc(1px * var(--s)) solid #efefef;
  background: #fff;
}

.scratch-comment-mo .comment-list-wrap {
  max-height: calc(360px * var(--s));
}

.scratch-comment-section .comment-list-wrap > ul {
  display: flex;
  flex-direction: column;
  gap: calc(10px * var(--s));
  width: 100%;
  height: 100%;
  margin: 0;
  padding: calc(10px * var(--s));
  overflow-y: auto;
  list-style: none;
}

.scratch-comment-section .comment-list-wrap li {
  padding: calc(20px * var(--s)) calc(24px * var(--s));
  display: flex;
  flex-direction: column;
  position: relative;
  border: calc(1px * var(--s)) solid #e6e6e6;
  border-radius: calc(8px * var(--s));
  background: #fff;
  font-family: Paperlogy, sans-serif;
}

.scratch-comment-section .comment-list-wrap li + li {
  border-top: calc(1px * var(--s)) solid #e6e6e6;
}

.scratch-comment-section .comment-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: calc(16px * var(--s));
  color: #2a2a2a;
  font-size: calc(18px * var(--s));
  line-height: 1.3;
}

.scratch-comment-section .comment-content {
  position: relative;
  margin-top: calc(12px * var(--s));
  padding-right: calc(32px * var(--s));
  color: #2a2a2a;
  font-size: calc(20px * var(--s));
  line-height: 1.5;
}

.scratch-comment-section .comment-content p {
  margin: 0;
  word-break: break-all;
}

.scratch-comment-section .btn-delete-comment {
  position: absolute;
  top: calc(2px * var(--s));
  right: 0;
  width: calc(22px * var(--s));
  height: calc(22px * var(--s));
  min-width: auto;
  border: 0;
  background: transparent;
  line-height: 1;
  cursor: pointer;
}

.scratch-comment-section .btn-delete-comment img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.scratch-comment-section .comment-like {
  display: flex;
  justify-content: flex-start;
  margin-top: calc(12px * var(--s));
}

.scratch-comment-section .btn-like {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: calc(5px * var(--s));
  min-width: auto;
  min-height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #767676;
  font-family: Paperlogy, sans-serif;
  font-size: calc(13px * var(--s));
  font-weight: 500;
  line-height: 1.4;
  cursor: pointer;
}

.scratch-comment-section .btn-like::before {
  content: "";
  display: inline-block;
  width: calc(12px * var(--s));
  height: calc(12px * var(--s));
  margin-top: calc(-1px * var(--s));
  background: url(/imgs/svg/icon/ico-like.svg) 50% 50% / contain no-repeat;
}

.scratch-comment-section .btn-like.active {
  color: #7a4b00;
}

.scratch-comment-section .btn-like.active::before {
  background-image: url(/imgs/svg/icon/ico-zzim-like.svg);
}

.scratch-comment-section .pagination-wrap {
  margin-top: calc(20px * var(--s));
}

.scratch-comment-section .pagination-wrap > ul {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: calc(7px * var(--s));
  margin: 0;
  padding: 0;
  list-style: none;
}

.scratch-comment-section .pagination-wrap .page-func {
  display: flex;
  align-items: center;
  gap: calc(6px * var(--s));
}

.scratch-comment-section .pagination-wrap > ul > li:first-child {
  margin-right: calc(10px * var(--s));
}

.scratch-comment-section .pagination-wrap > ul > li:last-child {
  margin-left: calc(10px * var(--s));
}

.scratch-comment-section .btn-page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: calc(33px * var(--s));
  height: calc(33px * var(--s));
  padding: 0 calc(4px * var(--s));
  border: calc(1px * var(--s)) solid transparent;
  border-radius: 0;
  background: transparent;
  color: #878787;
  font-family: Paperlogy, sans-serif;
  font-size: calc(15px * var(--s));
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
}

.scratch-comment-section .btn-page.active,
.scratch-comment-section .btn-page.current,
.scratch-comment-section .btn-page.on,
.scratch-comment-section .btn-page[aria-current="page"] {
  border-color: #d53410;
  background: #fff;
  color: #d53410;
  font-weight: 700;
}

.scratch-comment-section .page-disabled {
  opacity: .35;
  pointer-events: none;
}

.scratch-comment-section .page-first,
.scratch-comment-section .page-prev,
.scratch-comment-section .page-next,
.scratch-comment-section .page-last {
  border-color: #ccc;
  background: transparent;
}

.scratch-comment-section .page-first + .page-prev,
.scratch-comment-section .page-next + .page-last {
  margin-left: calc(-1px * var(--s));
}

.scratch-comment-section .page-first span,
.scratch-comment-section .page-prev span,
.scratch-comment-section .page-next span,
.scratch-comment-section .page-last span {
  display: none;
}

.scratch-comment-section .pagination-icon {
  width: calc(33px * var(--s));
  height: calc(33px * var(--s));
  object-fit: contain;
}

.comment-error {
  margin: 0;
  padding: calc(20px * var(--s));
  border-radius: calc(14px * var(--s));
  background: rgba(255, 255, 255, .9);
  color: #2a2a2a;
  text-align: center;
  font-family: Paperlogy, sans-serif;
  font-size: calc(18px * var(--s));
}

.mo-event-box {
  position: absolute;
  top: calc(228px * var(--s));
  left: 50%;
  display: grid;
  gap: calc(32px * var(--s));
  width: calc(680px * var(--s));
  transform: translateX(-50%);
}

.mo-event-box > img,
.mo-event-box .app-card > img {
  width: 100%;
}

.mo-event-box .event-app-button {
  bottom: 11.5%;
  width: calc(394px * var(--s));
}

.mo-event-box .event-app-button span {
  font-size: calc(32px * var(--s));
}

.mo-event-box .event-app-chevron {
  width: calc(40px * var(--s));
  height: calc(40px * var(--s));
}

.mo-notice {
  top: calc(80px * var(--s));
  width: calc(680px * var(--s));
}

.mo-notice > img {
  width: calc(172px * var(--s));
}

.notice-copy.mo {
  margin-top: calc(23px * var(--s));
  font-size: calc(20px * var(--s));
  line-height: 1.68;
}

#scratchPromotionApp .modal-promotion {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(0, 0, 0, .55);
}

#scratchPromotionApp .modal-promotion[hidden] {
  display: none;
}

#scratchPromotionApp .modal-box {
  position: relative;
  width: min(716px, calc(100vw - 32px));
  box-sizing: border-box;
  padding: 48px 60px;
  border-radius: 12px;
  background: #fff;
  text-align: center;
  box-shadow: 0 24px 80px rgba(0, 0, 0, .32);
}

#scratchPromotionApp .modal-box-alert {
  min-height: min(348px, calc((100vw - 32px) * .486));
  padding: 0;
}

#scratchPromotionApp .modal-box-alert-participation {
  min-height: min(606px, calc((100vw - 32px) * .846));
  padding: 0;
}

#scratchPromotionApp .modal-box-alert-exhausted {
  min-height: min(348px, calc((100vw - 32px) * .486));
  padding: 0;
}

#scratchPromotionApp .modal-box-login {
  min-height: min(700px, calc((100vw - 32px) * .978));
  padding: 0;
}

#scratchPromotionApp .modal-box-scratch {
  min-height: min(680px, calc((100vw - 32px) * .95));
}

#scratchPromotionApp .modal-box-result {
  min-height: min(780px, calc((100vw - 32px) * 1.089));
  padding: 0;
}

#scratchPromotionApp .modal-close {
  position: absolute;
  top: min(32px, 4.47vw);
  right: min(32px, 4.47vw);
  z-index: 2;
  width: min(23px, 5.4vw);
  height: min(23px, 5.4vw);
  background: transparent;
}

#scratchPromotionApp .modal-close:disabled {
  cursor: default;
  opacity: .35;
  pointer-events: none;
}

#scratchPromotionApp .modal-close-icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

#scratchPromotionApp .modal-content {
  width: 100%;
  height: auto;
}

#scratchPromotionApp .alert-message {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  gap: 4px;
  width: min(484px, calc(100% - 80px));
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(20px, 3.91vw, 28px);
  line-height: 1.4;
  letter-spacing: -.2px;
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .alert-message p,
#scratchPromotionApp .alert-message strong {
  margin: 0;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}

#scratchPromotionApp .alert-message p {
  font-weight: 400;
}

#scratchPromotionApp .alert-message strong {
  font-weight: 700;
}

#scratchPromotionApp .alert-message .alert-subcopy {
  display: block;
  margin-top: 8px;
  font-size: .78em;
  font-weight: 400;
}

#scratchPromotionApp .alert-nowrap {
  display: block;
  white-space: nowrap;
}

#scratchPromotionApp .alert-message-exhausted {
  width: min(520px, calc(100% - 80px));
  font-size: clamp(20px, 3.91vw, 28px);
}

#scratchPromotionApp .modal-participation-check {
  position: absolute;
  top: min(93px, 13vw);
  left: 50%;
  width: min(139px, 19.4vw);
  height: min(139px, 19.4vw);
  object-fit: contain;
  transform: translateX(-50%);
}

#scratchPromotionApp .participation-alert {
  position: absolute;
  top: min(270px, 37.7vw);
  left: 50%;
  display: grid;
  justify-items: center;
  width: min(560px, calc(100% - 64px));
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  line-height: 1.4;
  letter-spacing: -.2px;
  transform: translateX(-50%);
}

#scratchPromotionApp .participation-alert strong {
  display: block;
  margin: 0 0 min(28px, 3.9vw);
  font-size: clamp(26px, 5.03vw, 36px);
  font-weight: 700;
  line-height: 1.4;
}

#scratchPromotionApp .participation-alert p {
  margin: 0 0 min(28px, 3.9vw);
  font-size: clamp(24px, 5.03vw, 36px);
  font-weight: 400;
  line-height: 1.4;
}

#scratchPromotionApp .participation-alert small {
  color: #3f3f3f;
  font-size: clamp(15px, 3.35vw, 24px);
  font-weight: 400;
  line-height: 1.4;
}

#scratchPromotionApp .modal-alert-icon {
  position: absolute;
  top: min(93px, 13vw);
  left: 50%;
  width: min(139px, 19.4vw);
  height: min(139px, 19.4vw);
  object-fit: contain;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-box-login h2 {
  position: absolute;
  top: min(276px, 38.55vw);
  left: 50%;
  margin: 0;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(26px, 5.03vw, 36px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  white-space: nowrap;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-actions {
  position: absolute;
  top: min(421px, 58.8vw);
  left: 50%;
  display: grid;
  gap: min(16px, 2.23vw);
  width: min(401px, calc(100% - 80px));
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-image-button {
  position: relative;
  width: 100%;
  aspect-ratio: 401 / 89.46;
}

#scratchPromotionApp .modal-image-button img {
  width: 100%;
  height: 100%;
  object-fit: fill;
}

#scratchPromotionApp .modal-image-button span {
  position: absolute;
  top: 50%;
  left: 50%;
  color: #fff;
  font-family: Inter, Pretendard, sans-serif;
  font-size: clamp(20px, 3.91vw, 28px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  white-space: nowrap;
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-scratch-heading {
  position: absolute;
  top: min(55px, 7.68vw);
  left: 50%;
  display: grid;
  gap: min(10px, 1.4vw);
  width: min(420px, calc(100% - 96px));
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-box .modal-scratch-heading h2 {
  margin: 0;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(28px, 5.03vw, 36px);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -.2px;
  white-space: nowrap;
}

#scratchPromotionApp .modal-scratch-heading p {
  margin: 0;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(18px, 3.35vw, 24px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  white-space: nowrap;
}

#scratchPromotionApp .modal-scratch-card {
  position: absolute;
  top: min(181px, 25.28vw);
  left: 50%;
  width: min(590px, calc(100% - 80px));
  aspect-ratio: 590 / 310;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-scratch-surface {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
}

#scratchPromotionApp .modal-scratch-base,
#scratchPromotionApp .modal-scratch-coin,
#scratchPromotionApp .modal-scratch-result-layer,
#scratchPromotionApp .modal-scratch-result-bg,
#scratchPromotionApp .modal-scratch-result-prize,
#scratchPromotionApp .modal-scratch-result-frame,
#scratchPromotionApp .modal-scratch-result-brush,
#scratchPromotionApp .modal-scratch-result-prize,
#scratchPromotionApp .modal-result-frame,
#scratchPromotionApp .modal-result-brush {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

#scratchPromotionApp .modal-scratch-base,
#scratchPromotionApp .modal-scratch-result-bg,
#scratchPromotionApp .modal-scratch-result-frame,
#scratchPromotionApp .modal-scratch-result-brush,
#scratchPromotionApp .modal-result-frame,
#scratchPromotionApp .modal-result-brush {
  object-fit: cover;
}

#scratchPromotionApp .modal-scratch-result-layer {
  z-index: 1;
  overflow: hidden;
  opacity: 0;
  transition: opacity .38s ease;
}

#scratchPromotionApp .modal-scratch-result-layer.is-visible {
  opacity: 1;
}

#scratchPromotionApp .modal-scratch-result-prize {
  object-fit: contain;
}

#scratchPromotionApp .modal-scratch-result-prize.is-prize {
  top: 50%;
  right: auto;
  bottom: auto;
  left: 50%;
  width: auto;
  max-width: 86.27%;
  height: 78.39%;
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-scratch-result-prize.is-prize.prize-daiso,
#scratchPromotionApp .modal-scratch-result-prize.is-prize.prize-oliveyoung {
  width: 56%;
  max-width: none;
  height: auto;
  max-height: 92%;
}

#scratchPromotionApp .modal-scratch-result-prize.is-no-prize {
  top: 50%;
  right: auto;
  bottom: auto;
  left: 50%;
  width: min(223px, 37.8%);
  height: min(223px, 71.94%);
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-result-prize.is-no-prize,
#scratchPromotionApp .modal-scratch-result-prize.is-no-prize {
  z-index: 2;
}

#scratchPromotionApp .modal-scratch-coin {
  top: 60.32%;
  right: -7.46%;
  bottom: auto;
  left: auto;
  z-index: 5;
  width: 21.53%;
  height: 51.29%;
  object-fit: contain;
  pointer-events: none;
}

#scratchPromotionApp .modal-scratch-card.is-complete .modal-scratch-coin {
  display: none;
}

#scratchPromotionApp .modal-scratch-waiting {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 7;
  min-width: 190px;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(18, 18, 18, .82);
  color: #fff;
  font-family: Paperlogy, Pretendard, sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

#scratchPromotionApp .modal-scratch-waiting[hidden] {
  display: none;
}

#scratchPromotionApp .modal-scratch-card .scratch-canvas {
  position: absolute;
  inset: 0;
  z-index: 4;
  width: 100%;
  height: 100%;
  border-radius: 18px;
  cursor: grab;
  touch-action: none;
}

#scratchPromotionApp .modal-scratch-card.is-waiting-result .scratch-canvas {
  cursor: wait;
  pointer-events: none;
}

#scratchPromotionApp .modal-scratch-card.is-complete .scratch-canvas {
  cursor: default;
  pointer-events: none;
}

#scratchPromotionApp .modal-box-scratch .modal-confirm {
  position: absolute;
  top: min(545px, 76.12vw);
  left: 50%;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-confirm.modal-scratch-confirm {
  padding: 0;
  border-radius: 9px;
  background: #121212;
}

#scratchPromotionApp .modal-confirm.modal-scratch-confirm span {
  position: absolute;
  top: 50%;
  left: 50%;
  color: #fff;
  font-family: Inter, Pretendard, sans-serif;
  font-size: clamp(20px, 3.91vw, 28px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-box-scratch-result {
  min-height: min(780px, calc((100vw - 32px) * 1.089));
}

#scratchPromotionApp .modal-box-scratch-result .modal-scratch-heading {
  width: min(560px, calc(100% - 96px));
}

#scratchPromotionApp .modal-box-scratch-result .modal-scratch-heading h2 {
  font-weight: 400;
}

#scratchPromotionApp .modal-box-scratch-result .modal-scratch-heading p {
  display: block;
  justify-content: center;
  gap: min(8px, 1.12vw);
  font-size: clamp(28px, 5.03vw, 36px);
  line-height: 1.25;
  white-space: normal;
  word-break: break-all;
  overflow-wrap: anywhere;
}

#scratchPromotionApp .modal-box-scratch-result .modal-scratch-heading p span {
  display: inline;
}

#scratchPromotionApp .modal-scratch-result-copy {
  position: absolute;
  top: min(517px, 72.2vw);
  left: 50%;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(22px, 3.91vw, 28px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  text-align: center;
  white-space: nowrap;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-scratch-result-copy[hidden] {
  display: none;
}

#scratchPromotionApp .modal-scratch-result-copy p {
  margin: 0;
}

#scratchPromotionApp .modal-box-scratch-result .modal-confirm.modal-scratch-confirm {
  top: min(631px, 88.13vw);
}

#scratchPromotionApp .modal-result-heading {
  position: absolute;
  top: min(55px, 7.68vw);
  left: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(28px, 5.03vw, 36px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  white-space: normal;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-result-heading p {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(8px, 1.12vw);
  margin: 0;
  max-width: 100%;
  word-break: break-all;
  overflow-wrap: anywhere;
}

#scratchPromotionApp .modal-result-body {
  position: absolute;
  top: min(181px, 25.28vw);
  left: 50%;
  display: grid;
  justify-items: center;
  gap: min(38px, 5.31vw);
  width: min(590px, calc(100% - 126px));
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-result-card {
  position: relative;
  flex: 0 0 auto;
  overflow: hidden;
  width: min(590px, 100%);
  aspect-ratio: 590 / 310;
  border-radius: 28px;
}

#scratchPromotionApp .modal-result-scratch {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#scratchPromotionApp .modal-result-prize {
  position: absolute;
  object-fit: contain;
}

#scratchPromotionApp .modal-result-prize.is-prize {
  top: 50%;
  left: 50%;
  width: 86.27%;
  height: 78.39%;
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-result-prize.is-prize.prize-daiso,
#scratchPromotionApp .modal-result-prize.is-prize.prize-oliveyoung {
  width: 56%;
  max-width: none;
  height: auto;
  max-height: 92%;
}

#scratchPromotionApp .modal-result-prize.is-no-prize {
  top: 50%;
  left: 50%;
  width: min(223px, 37.8%);
  height: min(223px, 71.94%);
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-result-copy {
  width: min(590px, 100%);
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(22px, 3.91vw, 28px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  text-align: center;
  white-space: nowrap;
}

#scratchPromotionApp .modal-result-copy p {
  margin: 0;
}

#scratchPromotionApp .modal-confirm.modal-result-confirm {
  position: absolute;
  top: min(631px, 88.13vw);
  left: 50%;
  padding: 0;
  border-radius: 9px;
  background: #111;
  transform: translateX(-50%);
}

#scratchPromotionApp .modal-confirm.modal-result-confirm span {
  position: absolute;
  top: 50%;
  left: 50%;
  color: #fff;
  font-family: Inter, Pretendard, sans-serif;
  font-size: clamp(20px, 3.91vw, 28px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -.2px;
  transform: translate(-50%, -50%);
}

#scratchPromotionApp .modal-image img {
  width: min(590px, 100%);
  max-height: 310px;
  margin: 0 auto;
  object-fit: contain;
}

#scratchPromotionApp .modal-box h2 {
  margin: 0 0 26px;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(26px, 5.03vw, 36px);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -.2px;
}

#scratchPromotionApp .modal-copy {
  margin: 22px auto 30px;
  max-width: 507px;
  color: #000;
  font-family: YPairing, Paperlogy, Pretendard, sans-serif;
  font-size: clamp(18px, 3.35vw, 24px);
  line-height: 1.4;
  letter-spacing: -.2px;
}

#scratchPromotionApp .modal-confirm {
  position: relative;
  width: min(258px, 60%);
  min-height: min(77px, 17.9vw);
  border-radius: 8px;
  background: #1b55e5;
  color: #fff;
  font-family: Inter, Pretendard, sans-serif;
  font-size: clamp(20px, 3.91vw, 28px);
  font-weight: 400;
}

#scratchPromotionApp .modal-confirm:disabled {
  cursor: default;
  opacity: .6;
  pointer-events: none;
}

#scratchPromotionApp .modal-box-scratch,
#scratchPromotionApp .modal-box-result {
  height: auto;
  min-height: 0;
}

#scratchPromotionApp .modal-box-scratch .modal-content,
#scratchPromotionApp .modal-box-result .modal-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
  row-gap: 16px;
  column-gap: 0;
}

#scratchPromotionApp .modal-box-scratch .modal-scratch-heading,
#scratchPromotionApp .modal-box-result .modal-result-heading {
  position: static;
  width: 100%;
  max-width: 590px;
  transform: none;
}

#scratchPromotionApp .modal-box-scratch .modal-scratch-card {
  position: relative;
  top: auto;
  left: auto;
  flex: 0 0 auto;
  width: min(590px, 100%);
  margin-top: 0;
  transform: none;
}

#scratchPromotionApp .modal-box-scratch .modal-scratch-result-copy {
  position: static;
  width: min(590px, 100%);
  margin-top: 0;
  transform: none;
}

#scratchPromotionApp .modal-box-scratch .modal-confirm.modal-scratch-confirm {
  position: relative;
  top: auto;
  left: auto;
  flex: 0 0 auto;
  margin-top: 0;
  transform: none;
}

#scratchPromotionApp .modal-box-scratch-result .modal-confirm.modal-scratch-confirm {
  top: auto;
}

#scratchPromotionApp .modal-box-result .modal-result-body {
  position: static;
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 16px;
  column-gap: 0;
  width: min(590px, 100%);
  margin-top: 0;
  transform: none;
}

#scratchPromotionApp .modal-box-result .modal-confirm.modal-result-confirm {
  position: relative;
  top: auto;
  left: auto;
  flex: 0 0 auto;
  margin-top: 0;
  transform: none;
}

@media (max-width: 760px) {
  body {
    background: #fff;
  }

  .pc-stage {
    display: none;
  }

  .mo-stage {
    display: block;
  }

  #scratchPromotionApp .modal-promotion {
    padding: 14px;
  }

  #scratchPromotionApp .modal-box {
    width: min(345px, calc(100dvw - 28px));
    padding: 32px;
    overflow: hidden;
    border-radius: 10px;
  }

  #scratchPromotionApp .modal-close {
    top: 16px;
    right: 16px;
    width: 18px;
    height: 18px;
  }

  #scratchPromotionApp .modal-box-alert {
    min-height: 230px;
    padding: 0;
  }

  #scratchPromotionApp .modal-box-alert-participation {
    min-height: min(420px, calc(100dvh - 28px));
    padding: 0;
  }

  #scratchPromotionApp .modal-box-alert-exhausted {
    min-height: 230px;
    padding: 0;
  }

  #scratchPromotionApp .modal-box-login {
    min-height: min(560px, calc((100vw - 28px) * 1.34));
    padding: 0;
  }

  #scratchPromotionApp .modal-box-scratch {
    height: auto;
    max-height: calc(100dvh - 28px);
    min-height: 0;
  }

  #scratchPromotionApp .modal-box-result,
  #scratchPromotionApp .modal-box-scratch-result {
    height: auto;
    max-height: calc(100dvh - 28px);
    min-height: 0;
  }

  #scratchPromotionApp .alert-message {
    width: calc(100% - 48px);
    font-size: 20px;
  }

  #scratchPromotionApp .alert-message.has-nowrap {
    width: calc(100% - 36px);
    font-size: 18px;
  }

  #scratchPromotionApp .modal-alert-icon {
    top: 54px;
    width: 82px;
    height: 82px;
  }

  #scratchPromotionApp .modal-participation-check {
    top: 60px;
    width: 92px;
    height: 92px;
  }

  #scratchPromotionApp .participation-alert {
    top: 185px;
    width: calc(100% - 48px);
  }

  #scratchPromotionApp .participation-alert strong {
    margin-bottom: 16px;
    font-size: 24px;
  }

  #scratchPromotionApp .participation-alert p {
    margin-bottom: 16px;
    font-size: 23px;
  }

  #scratchPromotionApp .participation-alert small {
    font-size: 16px;
  }

  #scratchPromotionApp .modal-box-login h2 {
    top: 180px;
    font-size: 23px;
  }

  #scratchPromotionApp .modal-actions {
    top: 300px;
    width: min(320px, calc(100% - 56px));
  }

  #scratchPromotionApp .modal-image-button span,
  #scratchPromotionApp .modal-confirm.modal-scratch-confirm span,
  #scratchPromotionApp .modal-confirm.modal-result-confirm span {
    font-size: 20px;
  }

  #scratchPromotionApp .modal-scratch-heading,
  #scratchPromotionApp .modal-result-heading {
    gap: 6px;
    width: 100%;
  }

  #scratchPromotionApp .modal-box .modal-scratch-heading h2,
  #scratchPromotionApp .modal-result-heading {
    font-size: 22px;
  }

  #scratchPromotionApp .modal-scratch-heading p {
    font-size: 16px;
    white-space: normal;
  }

  #scratchPromotionApp .modal-box-scratch-result .modal-scratch-heading p {
    row-gap: 0;
    font-size: 18px;
    line-height: 1.2;
    white-space: normal;
  }

  #scratchPromotionApp .modal-box-scratch-result .modal-scratch-heading {
    gap: 4px;
  }

  #scratchPromotionApp .modal-result-heading p {
    flex-wrap: wrap;
    row-gap: 0;
  }

  #scratchPromotionApp .modal-box-scratch:not(.modal-box-scratch-result) .modal-scratch-card {
    margin-top: 0;
  }

  #scratchPromotionApp .modal-box-scratch-result .modal-scratch-card,
  #scratchPromotionApp .modal-box-result .modal-result-body {
    width: 100%;
  }

  #scratchPromotionApp .modal-box-result .modal-result-body {
    display: flex;
    width: 100%;
  }

  #scratchPromotionApp .modal-box-scratch-result .modal-scratch-card {
    margin-top: 0;
  }

  #scratchPromotionApp .modal-box-result .modal-result-body {
    margin-top: 0;
  }

  #scratchPromotionApp .modal-scratch-card,
  #scratchPromotionApp .modal-result-card {
    border-radius: 16px;
  }

  #scratchPromotionApp .modal-result-body {
    row-gap: 16px;
    column-gap: 0;
  }

  #scratchPromotionApp .modal-scratch-result-copy,
  #scratchPromotionApp .modal-result-copy {
    width: calc(100% - 54px);
    font-size: 16px;
    line-height: 1.25;
    white-space: normal;
  }

  #scratchPromotionApp .modal-scratch-result-copy {
    margin-top: 0;
  }

  #scratchPromotionApp .modal-result-copy {
    width: 100%;
  }

  #scratchPromotionApp .modal-box-scratch:not(.modal-box-scratch-result) .modal-confirm {
    width: 198px;
    height: 58px;
    min-height: 0;
  }

  #scratchPromotionApp .modal-confirm.modal-result-confirm {
    width: 198px;
    height: 58px;
    min-height: 0;
  }

  #scratchPromotionApp .modal-box-scratch-result .modal-confirm.modal-scratch-confirm {
    width: 198px;
    height: 58px;
    min-height: 0;
  }

  #scratchPromotionApp .modal-box-scratch-result {
    height: auto;
    max-height: calc(100dvh - 28px);
    min-height: 0;
  }

}

#scratchPromotionApp.preview-pc .pc-stage {
  display: block;
}

#scratchPromotionApp.preview-pc .mo-stage {
  display: none;
}

#scratchPromotionApp.preview-mo .pc-stage {
  display: none;
}

#scratchPromotionApp.preview-mo .mo-stage {
  display: block;
}
