@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100;300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap");
* {
  box-sizing: border-box;
}

img {
  display: block;
  width: 100%;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font-family: "Noto Sans KR", "Roboto", sans-serif;
  line-height: 1.4;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

a {
  all: unset;
}

#loadingModal, #alertModal {
  display: none;
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: black;
  background-color: rgba(0, 0, 0, 0.4);
}

#loadingModal .modal-content {
  max-width: 300px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  font-size: 4rem;
  color: white;
}

#alertModal .modal-content {
  width: calc(100% - 30px);
  max-width: 600px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  font-size: 1em;
  color: rgb(191, 211, 48);
  background: rgb(0, 40, 85);
  padding: 20px;
  border-radius: 20px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 3px 2px;
}

#alertModal .close-btn {
  text-align: center;
  font-weight: bold;
  font-size: 1em;
  letter-spacing: 0;
  display: inline-block;
  padding: 10px 20px;
  color: #002855;
  background: #c8d300;
  animation-delay: 0.8s;
  border-radius: 50px;
  transition: 0.5s;
  width: 100%;
  max-width: 280px;
  cursor: pointer;
  margin-top: 30px;
}

.red {
  color: #f00;
}

.small {
  font-size: 0.8em;
  font-weight: 400;
}

.flex-between {
  display: flex;
  flex-direction: row !important;
  justify-content: space-between;
}

.flex-between-center {
  display: flex;
  flex-direction: row !important;
  justify-content: space-between;
  align-items: center;
}

.flex-align-center {
  display: flex;
  align-items: center;
  gap: 5px;
}

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

i.star::after {
  content: "*";
  display: inline-flex;
  width: 24px;
  height: 24px;
  color: var(--color-main);
  position: relative;
  top: 4px;
}

i.info {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/info.svg") no-repeat center;
  background-size: 100%;
}

i.person {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/person.svg") no-repeat center;
  background-size: 100%;
}

i.visible_lock {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/visibility_lock.svg") no-repeat center;
  background-size: 100%;
}

i.visible {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/visibility.svg") no-repeat center;
  background-size: 100%;
}

i.visible_off {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/visibility_off.svg") no-repeat center;
  background-size: 100%;
}

i.post_add {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/post_add.svg") no-repeat center;
  background-size: 100%;
}

i.location {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/location.svg") no-repeat center;
  background-size: 100%;
}

i.call {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/call.svg") no-repeat center;
  background-size: 100%;
}

i.shopping {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/shopping.svg") no-repeat center;
  background-size: 100%;
}

i.receipt {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/receipt.svg") no-repeat center;
  background-size: 100%;
}

i.credit {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/credit_card.svg") no-repeat center;
  background-size: 100%;
}

i.list {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/list.svg") no-repeat center;
  background-size: 100%;
}

i.mail {
  display: inline-flex;
  width: 24px;
  height: 24px;
  background: url("../images/mail_white.svg") no-repeat center;
  background-size: 100%;
}

.loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  z-index: 9999;
}

.loader::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 50px;
  padding: 8px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--color-main);
  --_m:
    conic-gradient(#0000 10%,#000),
    linear-gradient(#000 0 0) content-box;
  -webkit-mask: var(--_m);
  mask: var(--_m);
  -webkit-mask-composite: source-out;
  mask-composite: subtract;
  animation: l3 1s infinite linear;
}

.loader.hide {
  display: none;
}

@keyframes l3 {
  to {
    transform: rotate(1turn);
  }
}
.red {
  color: var(--color-main);
}

:root {
  --max-width: 1000px;
  --color-main: #98264e;
  --color-pink: #e3007f;
  --color-purple: #8d1d78;
}