@import "https://fonts.googleapis.com/css2?family=Noto+Serif+KR:wght@400;500;600;700;900&family=Gowun+Batang:wght@400;700&family=Nanum+Pen+Script&display=swap";
@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css";
/* [next]/internal/font/google/geist_a71539c9.module.css [app-client] (css) */
@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Geist Fallback;
  src: local(Arial);
  ascent-override: 95.94%;
  descent-override: 28.16%;
  line-gap-override: 0.0%;
  size-adjust: 104.76%;
}

.geist_a71539c9-module__T19VSG__className {
  font-family: Geist, Geist Fallback;
  font-style: normal;
}

.geist_a71539c9-module__T19VSG__variable {
  --font-geist-sans: "Geist", "Geist Fallback";
}

/* [next]/internal/font/google/geist_mono_8d43a2aa.module.css [app-client] (css) */
@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/5ce348bf30bf5439-s.0zgw-jeven.3w.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/4fa387ec64143e14-s.0wkzw~je483f-.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/6306c77e7c8268e4-s.0rhz0arwfsn~5.woff2") format("woff2");
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/7d817b4c03b0c5f1-s.0l76wvqk9d84w.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/bbc41e54d2fcbd21-s.0k4k9394f2q-k.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/797e433ab948586e-s.p.08e28id.o-okb.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Geist Mono Fallback;
  src: local(Arial);
  ascent-override: 74.67%;
  descent-override: 21.92%;
  line-gap-override: 0.0%;
  size-adjust: 134.59%;
}

.geist_mono_8d43a2aa-module__8Li5zG__className {
  font-family: Geist Mono, Geist Mono Fallback;
  font-style: normal;
}

.geist_mono_8d43a2aa-module__8Li5zG__variable {
  --font-geist-mono: "Geist Mono", "Geist Mono Fallback";
}

/* [project]/app/globals.css [app-client] (css) */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-duration: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --color-red-50: #fef2f2;
    --color-red-900: #82181a;
    --color-green-50: #f0fdf4;
    --color-green-900: #0d542b;
    --color-zinc-50: #fafafa;
    --color-zinc-500: #71717b;
    --color-zinc-700: #3f3f46;
    --color-zinc-800: #27272a;
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-2xl: 42rem;
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --leading-relaxed: 1.625;
    --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-geist-sans);
    --default-mono-font-family: var(--font-geist-mono);
  }

  @supports (color: lab(0% 0 0)) {
    :root, :host {
      --color-red-50: lab(96.5005% 4.18508 1.52328);
      --color-red-900: lab(28.5139% 44.5539 29.0463);
      --color-green-50: lab(98.1563% -5.60117 2.75915);
      --color-green-900: lab(30.797% -29.6927 17.382);
      --color-zinc-50: lab(98.26% 0 0);
      --color-zinc-500: lab(47.8878% 1.65477 -5.77283);
      --color-zinc-700: lab(26.8019% 1.35387 -4.68303);
      --color-zinc-800: lab(15.7305% .613764 -2.16959);
    }
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }

  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }

  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }

  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }

  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }

  b, strong {
    font-weight: bolder;
  }

  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }

  small {
    font-size: 80%;
  }

  sub, sup {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

  ol, ul, menu {
    list-style: none;
  }

  img, svg, video, canvas, audio, iframe, embed, object {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::file-selector-button {
    margin-inline-end: 4px;
  }

  ::placeholder {
    opacity: 1;
  }

  @supports (not ((-webkit-appearance: -apple-pay-button))) or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentColor;
    }

    @supports (color: color-mix(in lab, red, red)) {
      ::placeholder {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }

  textarea {
    resize: vertical;
  }

  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }

  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }

  ::-webkit-datetime-edit {
    display: inline-flex;
  }

  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }

  ::-webkit-datetime-edit {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }

  :-moz-ui-invalid {
    box-shadow: none;
  }

  button, input:where([type="button"], [type="reset"], [type="submit"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

  ::-webkit-inner-spin-button {
    height: auto;
  }

  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}

@layer components;

@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }

  .visible {
    visibility: visible;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .sticky {
    position: sticky;
  }

  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }

  .z-0 {
    z-index: 0;
  }

  .z-10 {
    z-index: 10;
  }

  .mx-auto {
    margin-inline: auto;
  }

  .my-1 {
    margin-block: calc(var(--spacing) * 1);
  }

  .my-2 {
    margin-block: calc(var(--spacing) * 2);
  }

  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }

  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }

  .mt-auto {
    margin-top: auto;
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }

  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }

  .ml-0\.5 {
    margin-left: calc(var(--spacing) * .5);
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline-block {
    display: inline-block;
  }

  .inline-flex {
    display: inline-flex;
  }

  .size-7 {
    width: calc(var(--spacing) * 7);
    height: calc(var(--spacing) * 7);
  }

  .h-full {
    height: 100%;
  }

  .min-h-\[200px\] {
    min-height: 200px;
  }

  .min-h-full {
    min-height: 100%;
  }

  .w-full {
    width: 100%;
  }

  .w-screen {
    width: 100vw;
  }

  .max-w-2xl {
    max-width: var(--container-2xl);
  }

  .max-w-\[82\%\] {
    max-width: 82%;
  }

  .max-w-\[88\%\] {
    max-width: 88%;
  }

  .flex-1 {
    flex: 1;
  }

  .flex-none {
    flex: none;
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .animate-pulse {
    animation: var(--animate-pulse);
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .resize {
    resize: both;
  }

  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .flex-col {
    flex-direction: column;
  }

  .items-center {
    align-items: center;
  }

  .justify-between {
    justify-content: space-between;
  }

  .justify-center {
    justify-content: center;
  }

  .justify-end {
    justify-content: flex-end;
  }

  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }

  .gap-\[3px\] {
    gap: 3px;
  }

  .overflow-hidden {
    overflow: hidden;
  }

  .overflow-y-auto {
    overflow-y: auto;
  }

  .rounded {
    border-radius: .25rem;
  }

  .rounded-full {
    border-radius: 3.40282e38px;
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .bg-black {
    background-color: var(--color-black);
  }

  .bg-green-50 {
    background-color: var(--color-green-50);
  }

  .bg-red-50 {
    background-color: var(--color-red-50);
  }

  .bg-zinc-50 {
    background-color: var(--color-zinc-50);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .p-4 {
    padding: calc(var(--spacing) * 4);
  }

  .p-8 {
    padding: calc(var(--spacing) * 8);
  }

  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }

  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }

  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }

  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }

  .py-3\.5 {
    padding-block: calc(var(--spacing) * 3.5);
  }

  .pt-5 {
    padding-top: calc(var(--spacing) * 5);
  }

  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }

  .pt-12 {
    padding-top: calc(var(--spacing) * 12);
  }

  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }

  .pb-6 {
    padding-bottom: calc(var(--spacing) * 6);
  }

  .pb-28 {
    padding-bottom: calc(var(--spacing) * 28);
  }

  .text-center {
    text-align: center;
  }

  .align-middle {
    vertical-align: middle;
  }

  .font-sans {
    font-family: var(--font-geist-sans);
  }

  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .tracking-\[0\.3em\] {
    --tw-tracking: .3em;
    letter-spacing: .3em;
  }

  .text-green-900 {
    color: var(--color-green-900);
  }

  .text-red-900 {
    color: var(--color-red-900);
  }

  .text-white {
    color: var(--color-white);
  }

  .text-zinc-500 {
    color: var(--color-zinc-500);
  }

  .text-zinc-700 {
    color: var(--color-zinc-700);
  }

  .italic {
    font-style: italic;
  }

  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  .sepia {
    --tw-sepia: sepia(100%);
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .filter {
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .duration-300 {
    --tw-duration: .3s;
    transition-duration: .3s;
  }

  .duration-500 {
    --tw-duration: .5s;
    transition-duration: .5s;
  }

  @media (hover: hover) {
    .hover\:bg-zinc-800:hover {
      background-color: var(--color-zinc-800);
    }
  }

  .active\:scale-\[0\.96\]:active {
    scale: .96;
  }

  .active\:scale-\[0\.98\]:active {
    scale: .98;
  }

  .active\:brightness-95:active {
    --tw-brightness: brightness(95%);
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .active\:brightness-150:active {
    --tw-brightness: brightness(150%);
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

  .disabled\:opacity-50:disabled {
    opacity: .5;
  }
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u00000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0-7FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u01800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+1800-1FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u02000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+2000-27FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u02800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+2800-2FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u03000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+3000-37FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u04800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+4800-4FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u05000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+5000-57FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u05800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+5800-5FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u06000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+6000-67FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u06800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+6800-6FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u07000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+7000-77FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u07800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+7800-7FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u08000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+8000-87FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u08800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+8800-8FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u09000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+9000-97FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u09800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+9800-9FFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0A800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+A800-AFFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0B000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+B000-B7FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0B800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+B800-BFFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0C000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+C000-C7FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0C800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+C800-CFFF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0D000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+D000-D7FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0E000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+E000-E7FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0F000.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+F000-F7FF;
}

@font-face {
  font-family: Galmuri11;
  src: url("/fonts/galmuri/Galmuri11-u0F800.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+F800-FFFF;
}

@font-face {
  font-family: "Press Start 2P";
  src: url("/fonts/PressStart2P.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --background: #120730;
  --foreground: #ededed;
  --lightningcss-light: ;
  --lightningcss-dark: initial;
  color-scheme: dark;
  --ink: #1a1814;
  --paper: #f5edd8;
  --paper-deep: #ece0c2;
  --paper-light: #fbf6e6;
  --vermilion: #a8312a;
  --vermilion-dark: #7a1f1a;
  --cheongwol: #3a5f7a;
  --gold: #b8893a;
  --muted: #6a6056;
  --jade: #4e6e5a;
  --night: #0f0e10;
  --night-soft: #1c1a1e;
  --font-joseon-serif: "Noto Serif KR", serif;
  --font-joseon-script: "Gowun Batang", serif;
  --font-joseon-pen: "Nanum Pen Script", cursive;
  --font-ui: "Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", sans-serif;
}

@keyframes fade-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.rise-in {
  animation: 1.1s cubic-bezier(.39, .575, .565, 1) both fade-in;
}

.slide-up-soft, .slide-down-soft {
  animation: 1.8s cubic-bezier(.39, .575, .565, 1) both fade-in;
}

.no-scrollbar::-webkit-scrollbar {
  display: none;
}

.underline-input {
  caret-color: #ffffffd9;
  outline: none;
}

.underline-input::placeholder {
  color: #ffffff52;
}

html {
  background: var(--background);
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  background: var(--background);
  color: var(--foreground);
  font-family: var(--font-ui), Arial, Helvetica, sans-serif;
  padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px));
  padding-top: env(safe-area-inset-top, 0px);
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
  overscroll-behavior-y: none;
}

body.no-bottom-nav {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

a, button, input, select, textarea, label, [role="button"] {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

button {
  -webkit-user-select: none;
  user-select: none;
}

@media (pointer: coarse) {
  input:not([type="checkbox"]):not([type="radio"]), select, textarea {
    font-size: 16px !important;
  }
}

:focus-visible {
  outline-offset: 2px;
  outline: 2px solid #b6ff3a;
}

body {
  animation: .4s both fade-in;
}

.vt-page {
  background: var(--background);
  flex-direction: column;
  flex: 1 0 auto;
  display: flex;
}

::view-transition-old(.nav-forward) {
  animation: .28s cubic-bezier(.4, 0, .2, 1) both vt-slide-out-left;
}

::view-transition-new(.nav-forward) {
  animation: .36s cubic-bezier(.16, 1, .3, 1) both vt-slide-in-right;
}

::view-transition-old(.nav-back) {
  animation: .3s cubic-bezier(.4, 0, .2, 1) both vt-slide-out-right;
}

::view-transition-new(.nav-back) {
  animation: .36s cubic-bezier(.16, 1, .3, 1) both vt-slide-in-left;
}

::view-transition-old(.fade) {
  animation: .22s both vt-fade-out;
}

::view-transition-new(.fade) {
  animation: .28s both vt-fade-in;
}

::view-transition-group(ppippi-bottomnav) {
  z-index: 2147483647;
  animation: none !important;
}

::view-transition-old(ppippi-bottomnav) {
  display: none;
}

::view-transition-new(ppippi-bottomnav) {
  animation: none !important;
}

::view-transition-old(root) {
  animation: none;
}

::view-transition-new(root) {
  animation: none;
}

::view-transition-old(.none) {
  animation: none !important;
}

::view-transition-new(.none) {
  animation: none !important;
}

@keyframes vt-slide-in-right {
  from {
    transform: translateX(100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes vt-slide-out-left {
  from {
    opacity: 1;
    transform: translateX(0);
  }

  to {
    opacity: .55;
    transform: translateX(-22%);
  }
}

@keyframes vt-slide-in-left {
  from {
    opacity: .55;
    transform: translateX(-22%);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes vt-slide-out-right {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(100%);
  }
}

@keyframes vt-fade-out {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes vt-fade-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  *, :before, :after {
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }

  ::view-transition-old(*) {
    animation-duration: .01ms !important;
    animation-delay: 0s !important;
  }

  ::view-transition-new(*) {
    animation-duration: .01ms !important;
    animation-delay: 0s !important;
  }

  ::view-transition-group(*) {
    animation-duration: .01ms !important;
    animation-delay: 0s !important;
  }
}

@property --tw-rotate-x {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-y {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-z {
  syntax: "*";
  inherits: false
}

@property --tw-skew-x {
  syntax: "*";
  inherits: false
}

@property --tw-skew-y {
  syntax: "*";
  inherits: false
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-leading {
  syntax: "*";
  inherits: false
}

@property --tw-font-weight {
  syntax: "*";
  inherits: false
}

@property --tw-tracking {
  syntax: "*";
  inherits: false
}

@property --tw-blur {
  syntax: "*";
  inherits: false
}

@property --tw-brightness {
  syntax: "*";
  inherits: false
}

@property --tw-contrast {
  syntax: "*";
  inherits: false
}

@property --tw-grayscale {
  syntax: "*";
  inherits: false
}

@property --tw-hue-rotate {
  syntax: "*";
  inherits: false
}

@property --tw-invert {
  syntax: "*";
  inherits: false
}

@property --tw-opacity {
  syntax: "*";
  inherits: false
}

@property --tw-saturate {
  syntax: "*";
  inherits: false
}

@property --tw-sepia {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false
}

@property --tw-duration {
  syntax: "*";
  inherits: false
}

@keyframes pulse {
  50% {
    opacity: .5;
  }
}

/* [project]/app/components/bottomnav.module.css [app-client] (css) */
.bottomnav-module__32v3ra__nav {
  z-index: 40;
  width: 100%;
  max-width: 480px;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  background: #160a2e;
  border-top: 2px solid #000;
  font-family: Galmuri11, monospace;
  display: flex;
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 -3px #0006, inset 0 2px #6b3bd659;
}

.bottomnav-module__32v3ra__tab {
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  background: none;
  border: none;
  flex-direction: column;
  flex: 1;
  justify-content: center;
  align-items: center;
  gap: 4px;
  min-width: 0;
  min-height: 56px;
  padding: 8px 1px 9px;
  display: flex;
  position: relative;
}

.bottomnav-module__32v3ra__tab:before {
  content: "";
  opacity: 0;
  background: #b6ff3a;
  width: 22px;
  height: 3px;
  margin-left: -11px;
  transition: opacity .18s, transform .18s;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateY(-4px);
  box-shadow: 0 0 8px #b6ff3ab3;
}

.bottomnav-module__32v3ra__on:before {
  opacity: 1;
  transform: translateY(0);
}

.bottomnav-module__32v3ra__iconWrap {
  transition: transform .16s;
  display: flex;
}

.bottomnav-module__32v3ra__tab:active .bottomnav-module__32v3ra__iconWrap {
  transform: translateY(2px)scale(.9);
}

.bottomnav-module__32v3ra__tab:active .bottomnav-module__32v3ra__label {
  transform: translateY(1px);
}

.bottomnav-module__32v3ra__on .bottomnav-module__32v3ra__iconWrap {
  animation: .34s steps(4, end) both bottomnav-module__32v3ra__navPop;
}

@keyframes bottomnav-module__32v3ra__navPop {
  0% {
    transform: translateY(0)scale(1);
  }

  40% {
    transform: translateY(-4px)scale(1.18);
  }

  100% {
    transform: translateY(0)scale(1);
  }
}

.bottomnav-module__32v3ra__label {
  color: #9a86d6;
  white-space: nowrap;
  font-size: 9px;
  transition: color .18s, transform .16s;
}

.bottomnav-module__32v3ra__on .bottomnav-module__32v3ra__label {
  color: #b6ff3a;
  text-shadow: 0 0 7px #b6ff3a8c;
}

.bottomnav-module__32v3ra__overlay {
  z-index: 90;
  background: #08070ab8;
  justify-content: center;
  align-items: center;
  padding: 18px;
  font-family: Galmuri11, monospace;
  display: flex;
  position: fixed;
  inset: 0;
}

.bottomnav-module__32v3ra__modal {
  text-align: center;
  color: #fff;
  background: linear-gradient(135deg, #3a1a7a, #241050);
  border: 2px solid #000;
  border-radius: 8px;
  flex-direction: column;
  gap: 12px;
  width: 320px;
  max-width: 100%;
  padding: 22px 18px;
  display: flex;
  box-shadow: 4px 4px #000, inset 0 0 0 2px #6b3bd6;
}

.bottomnav-module__32v3ra__mIcon {
  justify-content: center;
  display: flex;
}

.bottomnav-module__32v3ra__mTitle {
  color: #ffe14d;
  font-size: 17px;
}

.bottomnav-module__32v3ra__mSub {
  color: #dcccff;
  font-size: 12.5px;
  line-height: 1.7;
}

.bottomnav-module__32v3ra__mGo {
  color: #1a0b3d;
  cursor: pointer;
  background: #b6ff3a;
  border: 2px solid #000;
  border-radius: 4px;
  padding: 12px;
  font-family: Galmuri11, monospace;
  font-size: 14px;
  box-shadow: 3px 3px #000;
}

.bottomnav-module__32v3ra__mClose {
  color: #9a86d6;
  cursor: pointer;
  background: none;
  border: none;
  font-size: 11px;
}

/* [project]/app/components/login.module.css [app-client] (css) */
.login-module__Xqh1oq__overlay {
  z-index: 60;
  background: #0a041ccc;
  justify-content: center;
  align-items: center;
  padding: 20px;
  font-family: Galmuri11, monospace;
  display: flex;
  position: fixed;
  inset: 0;
}

.login-module__Xqh1oq__modal {
  text-align: center;
  color: #fff;
  background: linear-gradient(135deg, #3a1a7a, #241050);
  border: 2px solid #000;
  border-radius: 6px;
  flex-direction: column;
  gap: 11px;
  width: 320px;
  max-width: 100%;
  padding: 22px 18px;
  display: flex;
  box-shadow: 4px 4px #000, inset 0 0 0 2px #6b3bd6;
}

.login-module__Xqh1oq__emoji {
  font-size: 38px;
}

.login-module__Xqh1oq__title {
  color: #ffe14d;
  font-size: 17px;
}

.login-module__Xqh1oq__sub {
  color: #bda9ec;
  font-size: 11px;
  line-height: 1.7;
}

.login-module__Xqh1oq__btn {
  cursor: pointer;
  border: 2px solid #000;
  border-radius: 4px;
  width: 100%;
  padding: 12px;
  font-family: Galmuri11, monospace;
  font-size: 14px;
  box-shadow: 3px 3px #000;
}

.login-module__Xqh1oq__btn:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px #000;
}

.login-module__Xqh1oq__btn:disabled {
  opacity: .5;
}

.login-module__Xqh1oq__kakao {
  color: #3c1e1e;
  background: #fee500;
}

.login-module__Xqh1oq__naver {
  color: #fff;
  background: #03c75a;
}

.login-module__Xqh1oq__guest {
  color: #cdbcf5;
  background: #2a1660;
}

.login-module__Xqh1oq__hint {
  color: #8f7ed0;
  font-size: 10px;
  line-height: 1.5;
}

.login-module__Xqh1oq__divider {
  color: #9a86d6;
  margin: 4px 0 0;
  font-size: 10px;
}

.login-module__Xqh1oq__input {
  color: #fff;
  text-align: center;
  background: #1a0b3d;
  border: 2px solid #000;
  border-radius: 3px;
  outline: none;
  width: 100%;
  padding: 10px;
  font-family: Galmuri11, monospace;
  font-size: 13px;
  box-shadow: inset 0 0 0 1px #6b3bd6;
}

.login-module__Xqh1oq__input:focus {
  box-shadow: inset 0 0 0 1px #b6ff3a;
}

.login-module__Xqh1oq__consent {
  color: #9a86d6;
  text-align: center;
  font-size: 10px;
  line-height: 1.6;
}

.login-module__Xqh1oq__consent a {
  color: #4de8ff;
  text-decoration: underline;
}

.login-module__Xqh1oq__close {
  color: #9a86d6;
  cursor: pointer;
  background: none;
  border: none;
  font-size: 11px;
}

/* [project]/app/components/Toast.module.css [app-client] (css) */
.Toast-module__SXJvLW__host {
  top: calc(env(safe-area-inset-top, 0px) + 14px);
  z-index: 300;
  pointer-events: none;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  display: flex;
  position: fixed;
  left: 0;
  right: 0;
}

.Toast-module__SXJvLW__toast {
  pointer-events: auto;
  color: #e7dcff;
  width: 100%;
  max-width: 360px;
  font-family: "Galmuri11", var(--font-ui), sans-serif;
  letter-spacing: -.2px;
  cursor: pointer;
  background: #1c1147;
  border: 2px solid #4a2f9e;
  border-radius: 12px;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.5;
  animation: .26s cubic-bezier(.16, 1, .3, 1) both Toast-module__SXJvLW__toast-in;
  display: flex;
  box-shadow: 0 0 0 2px #120730, 0 8px 22px #00000073;
}

.Toast-module__SXJvLW__toast.Toast-module__SXJvLW__out {
  animation: .2s both Toast-module__SXJvLW__toast-out;
}

.Toast-module__SXJvLW__icon {
  flex-shrink: 0;
  align-items: center;
  display: flex;
}

.Toast-module__SXJvLW__msg {
  white-space: pre-line;
  word-break: keep-all;
  flex: 1;
}

.Toast-module__SXJvLW__error {
  border-color: #ff4d6d;
  box-shadow: 0 0 0 2px #120730, 0 0 14px #ff4d6d59, 0 8px 22px #00000073;
}

.Toast-module__SXJvLW__success {
  border-color: #6ee27a;
  box-shadow: 0 0 0 2px #120730, 0 0 14px #6ee27a4d, 0 8px 22px #00000073;
}

@keyframes Toast-module__SXJvLW__toast-in {
  from {
    opacity: 0;
    transform: translateY(-14px)scale(.96);
  }

  to {
    opacity: 1;
    transform: translateY(0)scale(1);
  }
}

@keyframes Toast-module__SXJvLW__toast-out {
  from {
    opacity: 1;
    transform: translateY(0)scale(1);
  }

  to {
    opacity: 0;
    transform: translateY(-10px)scale(.98);
  }
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__0vgier.._.css.map*/