@charset "UTF-8";
/* =================================================================
   1. [SCSS Variables] Raw Data Definition
   * 이곳은 '순수 값'만 정의합니다. 실제 코드에서는 사용하지 않는 것을 권장합니다.
   * 브랜드 컬러 코드가 바뀌면 여기만 수정하세요.
   ================================================================= */
/* 드롭다운,멀티포함 */
/**
 * @mixin responsive
 * 모바일 시안(375px) 기준의 수치를 입력받아 모바일~태블릿 구간을 처리합니다.
 * @param $property : CSS 속성 (font-size, margin, padding 등)
 * @param $values : 적용할 값 (375px 시안 기준 px값 입력)
 * * [구간별 동작]
 * 1. Mobile (~767px): 375px 기준 VW 단위 (화면 폭에 비례하여 유동적 스케일링)
 * 2. Tablet (768px ~ 1199px): REM 단위 (가독성 유지를 위해 폰트 베이스로 고정)
 * 3. PC (1200px~): PX 단위 (원래는 고정되나, 보통 이 구간부터는 pc-scale 믹스인으로 덮어씀)
 */
/**
 * @mixin pc-scale
 * PC 시안(1440px) 기준의 수치를 입력받아 노트북 배율 환경에 대응합니다.
 * (수정됨: padding: 15px 25px 처럼 다중 값을 받을 수 있도록 업그레이드)
 * @param $property : CSS 속성
 * @param $values : 적용할 값 (1440px 시안 기준 다중 px값 입력 가능)
 */
html,
body {
  font-size: var(--text-base);
  font-family: Pretendard, sans-serif;
}

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: inherit;
  font-family: inherit;
  font-size: inherit;
  vertical-align: baseline;
  -webkit-text-size-adjust: none;
  box-sizing: border-box;
  letter-spacing: -0.02em;
  word-break: keep-all;
  line-height: 1.5;
  font-synthesis: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, div {
  position: relative;
  display: block;
}

body {
  line-height: 1;
  color: black;
}

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 {
  color: inherit;
  font: inherit;
  text-decoration: none;
}

strong {
  font: inherit;
}

label,
button,
input[type=submit],
input[type=checkbox],
input[type=radio],
input[type=button] {
  padding: 0px;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  cursor: pointer;
}

input[type=text],
input[type=password],
input[type=number] {
  padding: 0px;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

input,
button,
textarea,
select {
  box-sizing: border-box;
  border: none;
  font-family: inherit;
  font-size: inherit;
}

input[type=submit],
button[type=submit] {
  font-family: inherit;
  font-size: inherit;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  margin: 0;
  -webkit-appearance: none;
}

button:focus,
textarea:focus,
input:focus {
  outline: none;
}

button,
textarea,
input,
select,
a,
label {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

img {
  vertical-align: middle;
}

button {
  background: transparent;
  color: inherit;
}

input,
textarea {
  border: 1px solid transparent;
  transition: border 0.3s ease-in-out;
}

::-moz-placeholder {
  color: var(--PlaceColor);
  font-family: inherit;
  font-size: inherit;
}

::placeholder {
  color: var(--PlaceColor);
  font-family: inherit;
  font-size: inherit;
}

.no-scroll {
  overflow: hidden !important;
}
.no-scroll .scroll-frame {
  overflow: hidden !important;
}

span,
h1, h2, h3, h4, h5, h6,
p, a, strong, b,
dt, dd, li {
  padding: 0.1em 0;
  line-height: 1.5;
  text-box-trim: trim-both;
  text-box-edge: cap alphabetic;
}

/* =================================================================
   [Utility] Helper Classes
   * 모바일/PC 시안 공통 1배수 수치를 클래스명으로 사용합니다.
   * 내부적으로 responsive() 믹스인을 호출하여 모바일 vw, 태블릿 rem, PC px로 자동 변환합니다.
   ================================================================= */
.m-0 {
  margin: 0vw;
}
@media (min-width: 768px) {
  .m-0 {
    margin: 0rem;
  }
}
@media (min-width: 1200px) {
  .m-0 {
    margin: 0px;
  }
}

.mt-0 {
  margin-top: 0vw;
}
@media (min-width: 768px) {
  .mt-0 {
    margin-top: 0rem;
  }
}
@media (min-width: 1200px) {
  .mt-0 {
    margin-top: 0px;
  }
}

.mb-0 {
  margin-bottom: 0vw;
}
@media (min-width: 768px) {
  .mb-0 {
    margin-bottom: 0rem;
  }
}
@media (min-width: 1200px) {
  .mb-0 {
    margin-bottom: 0px;
  }
}

.ml-0 {
  margin-left: 0vw;
}
@media (min-width: 768px) {
  .ml-0 {
    margin-left: 0rem;
  }
}
@media (min-width: 1200px) {
  .ml-0 {
    margin-left: 0px;
  }
}

.mr-0 {
  margin-right: 0vw;
}
@media (min-width: 768px) {
  .mr-0 {
    margin-right: 0rem;
  }
}
@media (min-width: 1200px) {
  .mr-0 {
    margin-right: 0px;
  }
}

.mx-0 {
  margin-left: 0vw;
}
@media (min-width: 768px) {
  .mx-0 {
    margin-left: 0rem;
  }
}
@media (min-width: 1200px) {
  .mx-0 {
    margin-left: 0px;
  }
}
.mx-0 {
  margin-right: 0vw;
}
@media (min-width: 768px) {
  .mx-0 {
    margin-right: 0rem;
  }
}
@media (min-width: 1200px) {
  .mx-0 {
    margin-right: 0px;
  }
}

.my-0 {
  margin-top: 0vw;
}
@media (min-width: 768px) {
  .my-0 {
    margin-top: 0rem;
  }
}
@media (min-width: 1200px) {
  .my-0 {
    margin-top: 0px;
  }
}
.my-0 {
  margin-bottom: 0vw;
}
@media (min-width: 768px) {
  .my-0 {
    margin-bottom: 0rem;
  }
}
@media (min-width: 1200px) {
  .my-0 {
    margin-bottom: 0px;
  }
}

.p-0 {
  padding: 0vw;
}
@media (min-width: 768px) {
  .p-0 {
    padding: 0rem;
  }
}
@media (min-width: 1200px) {
  .p-0 {
    padding: 0px;
  }
}

.pt-0 {
  padding-top: 0vw;
}
@media (min-width: 768px) {
  .pt-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 1200px) {
  .pt-0 {
    padding-top: 0px;
  }
}

.pb-0 {
  padding-bottom: 0vw;
}
@media (min-width: 768px) {
  .pb-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 1200px) {
  .pb-0 {
    padding-bottom: 0px;
  }
}

.pl-0 {
  padding-left: 0vw;
}
@media (min-width: 768px) {
  .pl-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 1200px) {
  .pl-0 {
    padding-left: 0px;
  }
}

.pr-0 {
  padding-right: 0vw;
}
@media (min-width: 768px) {
  .pr-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 1200px) {
  .pr-0 {
    padding-right: 0px;
  }
}

.px-0 {
  padding-left: 0vw;
}
@media (min-width: 768px) {
  .px-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 1200px) {
  .px-0 {
    padding-left: 0px;
  }
}
.px-0 {
  padding-right: 0vw;
}
@media (min-width: 768px) {
  .px-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 1200px) {
  .px-0 {
    padding-right: 0px;
  }
}

.py-0 {
  padding-top: 0vw;
}
@media (min-width: 768px) {
  .py-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 1200px) {
  .py-0 {
    padding-top: 0px;
  }
}
.py-0 {
  padding-bottom: 0vw;
}
@media (min-width: 768px) {
  .py-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 1200px) {
  .py-0 {
    padding-bottom: 0px;
  }
}

.m-4 {
  margin: 1.0667vw;
}
@media (min-width: 768px) {
  .m-4 {
    margin: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .m-4 {
    margin: 4px;
  }
}

.mt-4 {
  margin-top: 1.0667vw;
}
@media (min-width: 768px) {
  .mt-4 {
    margin-top: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .mt-4 {
    margin-top: 4px;
  }
}

.mb-4 {
  margin-bottom: 1.0667vw;
}
@media (min-width: 768px) {
  .mb-4 {
    margin-bottom: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .mb-4 {
    margin-bottom: 4px;
  }
}

.ml-4 {
  margin-left: 1.0667vw;
}
@media (min-width: 768px) {
  .ml-4 {
    margin-left: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .ml-4 {
    margin-left: 4px;
  }
}

.mr-4 {
  margin-right: 1.0667vw;
}
@media (min-width: 768px) {
  .mr-4 {
    margin-right: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .mr-4 {
    margin-right: 4px;
  }
}

.mx-4 {
  margin-left: 1.0667vw;
}
@media (min-width: 768px) {
  .mx-4 {
    margin-left: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .mx-4 {
    margin-left: 4px;
  }
}
.mx-4 {
  margin-right: 1.0667vw;
}
@media (min-width: 768px) {
  .mx-4 {
    margin-right: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .mx-4 {
    margin-right: 4px;
  }
}

.my-4 {
  margin-top: 1.0667vw;
}
@media (min-width: 768px) {
  .my-4 {
    margin-top: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .my-4 {
    margin-top: 4px;
  }
}
.my-4 {
  margin-bottom: 1.0667vw;
}
@media (min-width: 768px) {
  .my-4 {
    margin-bottom: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .my-4 {
    margin-bottom: 4px;
  }
}

.p-4 {
  padding: 1.0667vw;
}
@media (min-width: 768px) {
  .p-4 {
    padding: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .p-4 {
    padding: 4px;
  }
}

.pt-4 {
  padding-top: 1.0667vw;
}
@media (min-width: 768px) {
  .pt-4 {
    padding-top: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .pt-4 {
    padding-top: 4px;
  }
}

.pb-4 {
  padding-bottom: 1.0667vw;
}
@media (min-width: 768px) {
  .pb-4 {
    padding-bottom: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .pb-4 {
    padding-bottom: 4px;
  }
}

.pl-4 {
  padding-left: 1.0667vw;
}
@media (min-width: 768px) {
  .pl-4 {
    padding-left: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .pl-4 {
    padding-left: 4px;
  }
}

.pr-4 {
  padding-right: 1.0667vw;
}
@media (min-width: 768px) {
  .pr-4 {
    padding-right: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .pr-4 {
    padding-right: 4px;
  }
}

.px-4 {
  padding-left: 1.0667vw;
}
@media (min-width: 768px) {
  .px-4 {
    padding-left: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .px-4 {
    padding-left: 4px;
  }
}
.px-4 {
  padding-right: 1.0667vw;
}
@media (min-width: 768px) {
  .px-4 {
    padding-right: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .px-4 {
    padding-right: 4px;
  }
}

.py-4 {
  padding-top: 1.0667vw;
}
@media (min-width: 768px) {
  .py-4 {
    padding-top: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .py-4 {
    padding-top: 4px;
  }
}
.py-4 {
  padding-bottom: 1.0667vw;
}
@media (min-width: 768px) {
  .py-4 {
    padding-bottom: 0.25rem;
  }
}
@media (min-width: 1200px) {
  .py-4 {
    padding-bottom: 4px;
  }
}

.m-5 {
  margin: 1.3333vw;
}
@media (min-width: 768px) {
  .m-5 {
    margin: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .m-5 {
    margin: 5px;
  }
}

.mt-5 {
  margin-top: 1.3333vw;
}
@media (min-width: 768px) {
  .mt-5 {
    margin-top: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .mt-5 {
    margin-top: 5px;
  }
}

.mb-5 {
  margin-bottom: 1.3333vw;
}
@media (min-width: 768px) {
  .mb-5 {
    margin-bottom: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .mb-5 {
    margin-bottom: 5px;
  }
}

.ml-5 {
  margin-left: 1.3333vw;
}
@media (min-width: 768px) {
  .ml-5 {
    margin-left: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .ml-5 {
    margin-left: 5px;
  }
}

.mr-5 {
  margin-right: 1.3333vw;
}
@media (min-width: 768px) {
  .mr-5 {
    margin-right: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .mr-5 {
    margin-right: 5px;
  }
}

.mx-5 {
  margin-left: 1.3333vw;
}
@media (min-width: 768px) {
  .mx-5 {
    margin-left: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .mx-5 {
    margin-left: 5px;
  }
}
.mx-5 {
  margin-right: 1.3333vw;
}
@media (min-width: 768px) {
  .mx-5 {
    margin-right: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .mx-5 {
    margin-right: 5px;
  }
}

.my-5 {
  margin-top: 1.3333vw;
}
@media (min-width: 768px) {
  .my-5 {
    margin-top: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .my-5 {
    margin-top: 5px;
  }
}
.my-5 {
  margin-bottom: 1.3333vw;
}
@media (min-width: 768px) {
  .my-5 {
    margin-bottom: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .my-5 {
    margin-bottom: 5px;
  }
}

.p-5 {
  padding: 1.3333vw;
}
@media (min-width: 768px) {
  .p-5 {
    padding: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .p-5 {
    padding: 5px;
  }
}

.pt-5 {
  padding-top: 1.3333vw;
}
@media (min-width: 768px) {
  .pt-5 {
    padding-top: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .pt-5 {
    padding-top: 5px;
  }
}

.pb-5 {
  padding-bottom: 1.3333vw;
}
@media (min-width: 768px) {
  .pb-5 {
    padding-bottom: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .pb-5 {
    padding-bottom: 5px;
  }
}

.pl-5 {
  padding-left: 1.3333vw;
}
@media (min-width: 768px) {
  .pl-5 {
    padding-left: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .pl-5 {
    padding-left: 5px;
  }
}

.pr-5 {
  padding-right: 1.3333vw;
}
@media (min-width: 768px) {
  .pr-5 {
    padding-right: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .pr-5 {
    padding-right: 5px;
  }
}

.px-5 {
  padding-left: 1.3333vw;
}
@media (min-width: 768px) {
  .px-5 {
    padding-left: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .px-5 {
    padding-left: 5px;
  }
}
.px-5 {
  padding-right: 1.3333vw;
}
@media (min-width: 768px) {
  .px-5 {
    padding-right: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .px-5 {
    padding-right: 5px;
  }
}

.py-5 {
  padding-top: 1.3333vw;
}
@media (min-width: 768px) {
  .py-5 {
    padding-top: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .py-5 {
    padding-top: 5px;
  }
}
.py-5 {
  padding-bottom: 1.3333vw;
}
@media (min-width: 768px) {
  .py-5 {
    padding-bottom: 0.3125rem;
  }
}
@media (min-width: 1200px) {
  .py-5 {
    padding-bottom: 5px;
  }
}

.m-8 {
  margin: 2.1333vw;
}
@media (min-width: 768px) {
  .m-8 {
    margin: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .m-8 {
    margin: 8px;
  }
}

.mt-8 {
  margin-top: 2.1333vw;
}
@media (min-width: 768px) {
  .mt-8 {
    margin-top: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .mt-8 {
    margin-top: 8px;
  }
}

.mb-8 {
  margin-bottom: 2.1333vw;
}
@media (min-width: 768px) {
  .mb-8 {
    margin-bottom: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .mb-8 {
    margin-bottom: 8px;
  }
}

.ml-8 {
  margin-left: 2.1333vw;
}
@media (min-width: 768px) {
  .ml-8 {
    margin-left: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .ml-8 {
    margin-left: 8px;
  }
}

.mr-8 {
  margin-right: 2.1333vw;
}
@media (min-width: 768px) {
  .mr-8 {
    margin-right: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .mr-8 {
    margin-right: 8px;
  }
}

.mx-8 {
  margin-left: 2.1333vw;
}
@media (min-width: 768px) {
  .mx-8 {
    margin-left: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .mx-8 {
    margin-left: 8px;
  }
}
.mx-8 {
  margin-right: 2.1333vw;
}
@media (min-width: 768px) {
  .mx-8 {
    margin-right: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .mx-8 {
    margin-right: 8px;
  }
}

.my-8 {
  margin-top: 2.1333vw;
}
@media (min-width: 768px) {
  .my-8 {
    margin-top: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .my-8 {
    margin-top: 8px;
  }
}
.my-8 {
  margin-bottom: 2.1333vw;
}
@media (min-width: 768px) {
  .my-8 {
    margin-bottom: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .my-8 {
    margin-bottom: 8px;
  }
}

.p-8 {
  padding: 2.1333vw;
}
@media (min-width: 768px) {
  .p-8 {
    padding: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .p-8 {
    padding: 8px;
  }
}

.pt-8 {
  padding-top: 2.1333vw;
}
@media (min-width: 768px) {
  .pt-8 {
    padding-top: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .pt-8 {
    padding-top: 8px;
  }
}

.pb-8 {
  padding-bottom: 2.1333vw;
}
@media (min-width: 768px) {
  .pb-8 {
    padding-bottom: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .pb-8 {
    padding-bottom: 8px;
  }
}

.pl-8 {
  padding-left: 2.1333vw;
}
@media (min-width: 768px) {
  .pl-8 {
    padding-left: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .pl-8 {
    padding-left: 8px;
  }
}

.pr-8 {
  padding-right: 2.1333vw;
}
@media (min-width: 768px) {
  .pr-8 {
    padding-right: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .pr-8 {
    padding-right: 8px;
  }
}

.px-8 {
  padding-left: 2.1333vw;
}
@media (min-width: 768px) {
  .px-8 {
    padding-left: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .px-8 {
    padding-left: 8px;
  }
}
.px-8 {
  padding-right: 2.1333vw;
}
@media (min-width: 768px) {
  .px-8 {
    padding-right: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .px-8 {
    padding-right: 8px;
  }
}

.py-8 {
  padding-top: 2.1333vw;
}
@media (min-width: 768px) {
  .py-8 {
    padding-top: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .py-8 {
    padding-top: 8px;
  }
}
.py-8 {
  padding-bottom: 2.1333vw;
}
@media (min-width: 768px) {
  .py-8 {
    padding-bottom: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .py-8 {
    padding-bottom: 8px;
  }
}

.m-10 {
  margin: 2.6667vw;
}
@media (min-width: 768px) {
  .m-10 {
    margin: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .m-10 {
    margin: 10px;
  }
}

.mt-10 {
  margin-top: 2.6667vw;
}
@media (min-width: 768px) {
  .mt-10 {
    margin-top: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .mt-10 {
    margin-top: 10px;
  }
}

.mb-10 {
  margin-bottom: 2.6667vw;
}
@media (min-width: 768px) {
  .mb-10 {
    margin-bottom: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .mb-10 {
    margin-bottom: 10px;
  }
}

.ml-10 {
  margin-left: 2.6667vw;
}
@media (min-width: 768px) {
  .ml-10 {
    margin-left: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .ml-10 {
    margin-left: 10px;
  }
}

.mr-10 {
  margin-right: 2.6667vw;
}
@media (min-width: 768px) {
  .mr-10 {
    margin-right: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .mr-10 {
    margin-right: 10px;
  }
}

.mx-10 {
  margin-left: 2.6667vw;
}
@media (min-width: 768px) {
  .mx-10 {
    margin-left: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .mx-10 {
    margin-left: 10px;
  }
}
.mx-10 {
  margin-right: 2.6667vw;
}
@media (min-width: 768px) {
  .mx-10 {
    margin-right: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .mx-10 {
    margin-right: 10px;
  }
}

.my-10 {
  margin-top: 2.6667vw;
}
@media (min-width: 768px) {
  .my-10 {
    margin-top: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .my-10 {
    margin-top: 10px;
  }
}
.my-10 {
  margin-bottom: 2.6667vw;
}
@media (min-width: 768px) {
  .my-10 {
    margin-bottom: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .my-10 {
    margin-bottom: 10px;
  }
}

.p-10 {
  padding: 2.6667vw;
}
@media (min-width: 768px) {
  .p-10 {
    padding: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .p-10 {
    padding: 10px;
  }
}

.pt-10 {
  padding-top: 2.6667vw;
}
@media (min-width: 768px) {
  .pt-10 {
    padding-top: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .pt-10 {
    padding-top: 10px;
  }
}

.pb-10 {
  padding-bottom: 2.6667vw;
}
@media (min-width: 768px) {
  .pb-10 {
    padding-bottom: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .pb-10 {
    padding-bottom: 10px;
  }
}

.pl-10 {
  padding-left: 2.6667vw;
}
@media (min-width: 768px) {
  .pl-10 {
    padding-left: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .pl-10 {
    padding-left: 10px;
  }
}

.pr-10 {
  padding-right: 2.6667vw;
}
@media (min-width: 768px) {
  .pr-10 {
    padding-right: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .pr-10 {
    padding-right: 10px;
  }
}

.px-10 {
  padding-left: 2.6667vw;
}
@media (min-width: 768px) {
  .px-10 {
    padding-left: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .px-10 {
    padding-left: 10px;
  }
}
.px-10 {
  padding-right: 2.6667vw;
}
@media (min-width: 768px) {
  .px-10 {
    padding-right: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .px-10 {
    padding-right: 10px;
  }
}

.py-10 {
  padding-top: 2.6667vw;
}
@media (min-width: 768px) {
  .py-10 {
    padding-top: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .py-10 {
    padding-top: 10px;
  }
}
.py-10 {
  padding-bottom: 2.6667vw;
}
@media (min-width: 768px) {
  .py-10 {
    padding-bottom: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .py-10 {
    padding-bottom: 10px;
  }
}

.m-12 {
  margin: 3.2vw;
}
@media (min-width: 768px) {
  .m-12 {
    margin: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .m-12 {
    margin: 12px;
  }
}

.mt-12 {
  margin-top: 3.2vw;
}
@media (min-width: 768px) {
  .mt-12 {
    margin-top: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .mt-12 {
    margin-top: 12px;
  }
}

.mb-12 {
  margin-bottom: 3.2vw;
}
@media (min-width: 768px) {
  .mb-12 {
    margin-bottom: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .mb-12 {
    margin-bottom: 12px;
  }
}

.ml-12 {
  margin-left: 3.2vw;
}
@media (min-width: 768px) {
  .ml-12 {
    margin-left: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .ml-12 {
    margin-left: 12px;
  }
}

.mr-12 {
  margin-right: 3.2vw;
}
@media (min-width: 768px) {
  .mr-12 {
    margin-right: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .mr-12 {
    margin-right: 12px;
  }
}

.mx-12 {
  margin-left: 3.2vw;
}
@media (min-width: 768px) {
  .mx-12 {
    margin-left: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .mx-12 {
    margin-left: 12px;
  }
}
.mx-12 {
  margin-right: 3.2vw;
}
@media (min-width: 768px) {
  .mx-12 {
    margin-right: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .mx-12 {
    margin-right: 12px;
  }
}

.my-12 {
  margin-top: 3.2vw;
}
@media (min-width: 768px) {
  .my-12 {
    margin-top: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .my-12 {
    margin-top: 12px;
  }
}
.my-12 {
  margin-bottom: 3.2vw;
}
@media (min-width: 768px) {
  .my-12 {
    margin-bottom: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .my-12 {
    margin-bottom: 12px;
  }
}

.p-12 {
  padding: 3.2vw;
}
@media (min-width: 768px) {
  .p-12 {
    padding: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .p-12 {
    padding: 12px;
  }
}

.pt-12 {
  padding-top: 3.2vw;
}
@media (min-width: 768px) {
  .pt-12 {
    padding-top: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .pt-12 {
    padding-top: 12px;
  }
}

.pb-12 {
  padding-bottom: 3.2vw;
}
@media (min-width: 768px) {
  .pb-12 {
    padding-bottom: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .pb-12 {
    padding-bottom: 12px;
  }
}

.pl-12 {
  padding-left: 3.2vw;
}
@media (min-width: 768px) {
  .pl-12 {
    padding-left: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .pl-12 {
    padding-left: 12px;
  }
}

.pr-12 {
  padding-right: 3.2vw;
}
@media (min-width: 768px) {
  .pr-12 {
    padding-right: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .pr-12 {
    padding-right: 12px;
  }
}

.px-12 {
  padding-left: 3.2vw;
}
@media (min-width: 768px) {
  .px-12 {
    padding-left: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .px-12 {
    padding-left: 12px;
  }
}
.px-12 {
  padding-right: 3.2vw;
}
@media (min-width: 768px) {
  .px-12 {
    padding-right: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .px-12 {
    padding-right: 12px;
  }
}

.py-12 {
  padding-top: 3.2vw;
}
@media (min-width: 768px) {
  .py-12 {
    padding-top: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .py-12 {
    padding-top: 12px;
  }
}
.py-12 {
  padding-bottom: 3.2vw;
}
@media (min-width: 768px) {
  .py-12 {
    padding-bottom: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .py-12 {
    padding-bottom: 12px;
  }
}

.m-15 {
  margin: 4vw;
}
@media (min-width: 768px) {
  .m-15 {
    margin: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .m-15 {
    margin: 15px;
  }
}

.mt-15 {
  margin-top: 4vw;
}
@media (min-width: 768px) {
  .mt-15 {
    margin-top: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .mt-15 {
    margin-top: 15px;
  }
}

.mb-15 {
  margin-bottom: 4vw;
}
@media (min-width: 768px) {
  .mb-15 {
    margin-bottom: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .mb-15 {
    margin-bottom: 15px;
  }
}

.ml-15 {
  margin-left: 4vw;
}
@media (min-width: 768px) {
  .ml-15 {
    margin-left: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .ml-15 {
    margin-left: 15px;
  }
}

.mr-15 {
  margin-right: 4vw;
}
@media (min-width: 768px) {
  .mr-15 {
    margin-right: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .mr-15 {
    margin-right: 15px;
  }
}

.mx-15 {
  margin-left: 4vw;
}
@media (min-width: 768px) {
  .mx-15 {
    margin-left: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .mx-15 {
    margin-left: 15px;
  }
}
.mx-15 {
  margin-right: 4vw;
}
@media (min-width: 768px) {
  .mx-15 {
    margin-right: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .mx-15 {
    margin-right: 15px;
  }
}

.my-15 {
  margin-top: 4vw;
}
@media (min-width: 768px) {
  .my-15 {
    margin-top: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .my-15 {
    margin-top: 15px;
  }
}
.my-15 {
  margin-bottom: 4vw;
}
@media (min-width: 768px) {
  .my-15 {
    margin-bottom: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .my-15 {
    margin-bottom: 15px;
  }
}

.p-15 {
  padding: 4vw;
}
@media (min-width: 768px) {
  .p-15 {
    padding: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .p-15 {
    padding: 15px;
  }
}

.pt-15 {
  padding-top: 4vw;
}
@media (min-width: 768px) {
  .pt-15 {
    padding-top: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .pt-15 {
    padding-top: 15px;
  }
}

.pb-15 {
  padding-bottom: 4vw;
}
@media (min-width: 768px) {
  .pb-15 {
    padding-bottom: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .pb-15 {
    padding-bottom: 15px;
  }
}

.pl-15 {
  padding-left: 4vw;
}
@media (min-width: 768px) {
  .pl-15 {
    padding-left: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .pl-15 {
    padding-left: 15px;
  }
}

.pr-15 {
  padding-right: 4vw;
}
@media (min-width: 768px) {
  .pr-15 {
    padding-right: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .pr-15 {
    padding-right: 15px;
  }
}

.px-15 {
  padding-left: 4vw;
}
@media (min-width: 768px) {
  .px-15 {
    padding-left: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .px-15 {
    padding-left: 15px;
  }
}
.px-15 {
  padding-right: 4vw;
}
@media (min-width: 768px) {
  .px-15 {
    padding-right: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .px-15 {
    padding-right: 15px;
  }
}

.py-15 {
  padding-top: 4vw;
}
@media (min-width: 768px) {
  .py-15 {
    padding-top: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .py-15 {
    padding-top: 15px;
  }
}
.py-15 {
  padding-bottom: 4vw;
}
@media (min-width: 768px) {
  .py-15 {
    padding-bottom: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .py-15 {
    padding-bottom: 15px;
  }
}

.m-16 {
  margin: 4.2667vw;
}
@media (min-width: 768px) {
  .m-16 {
    margin: 1rem;
  }
}
@media (min-width: 1200px) {
  .m-16 {
    margin: 16px;
  }
}

.mt-16 {
  margin-top: 4.2667vw;
}
@media (min-width: 768px) {
  .mt-16 {
    margin-top: 1rem;
  }
}
@media (min-width: 1200px) {
  .mt-16 {
    margin-top: 16px;
  }
}

.mb-16 {
  margin-bottom: 4.2667vw;
}
@media (min-width: 768px) {
  .mb-16 {
    margin-bottom: 1rem;
  }
}
@media (min-width: 1200px) {
  .mb-16 {
    margin-bottom: 16px;
  }
}

.ml-16 {
  margin-left: 4.2667vw;
}
@media (min-width: 768px) {
  .ml-16 {
    margin-left: 1rem;
  }
}
@media (min-width: 1200px) {
  .ml-16 {
    margin-left: 16px;
  }
}

.mr-16 {
  margin-right: 4.2667vw;
}
@media (min-width: 768px) {
  .mr-16 {
    margin-right: 1rem;
  }
}
@media (min-width: 1200px) {
  .mr-16 {
    margin-right: 16px;
  }
}

.mx-16 {
  margin-left: 4.2667vw;
}
@media (min-width: 768px) {
  .mx-16 {
    margin-left: 1rem;
  }
}
@media (min-width: 1200px) {
  .mx-16 {
    margin-left: 16px;
  }
}
.mx-16 {
  margin-right: 4.2667vw;
}
@media (min-width: 768px) {
  .mx-16 {
    margin-right: 1rem;
  }
}
@media (min-width: 1200px) {
  .mx-16 {
    margin-right: 16px;
  }
}

.my-16 {
  margin-top: 4.2667vw;
}
@media (min-width: 768px) {
  .my-16 {
    margin-top: 1rem;
  }
}
@media (min-width: 1200px) {
  .my-16 {
    margin-top: 16px;
  }
}
.my-16 {
  margin-bottom: 4.2667vw;
}
@media (min-width: 768px) {
  .my-16 {
    margin-bottom: 1rem;
  }
}
@media (min-width: 1200px) {
  .my-16 {
    margin-bottom: 16px;
  }
}

.p-16 {
  padding: 4.2667vw;
}
@media (min-width: 768px) {
  .p-16 {
    padding: 1rem;
  }
}
@media (min-width: 1200px) {
  .p-16 {
    padding: 16px;
  }
}

.pt-16 {
  padding-top: 4.2667vw;
}
@media (min-width: 768px) {
  .pt-16 {
    padding-top: 1rem;
  }
}
@media (min-width: 1200px) {
  .pt-16 {
    padding-top: 16px;
  }
}

.pb-16 {
  padding-bottom: 4.2667vw;
}
@media (min-width: 768px) {
  .pb-16 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 1200px) {
  .pb-16 {
    padding-bottom: 16px;
  }
}

.pl-16 {
  padding-left: 4.2667vw;
}
@media (min-width: 768px) {
  .pl-16 {
    padding-left: 1rem;
  }
}
@media (min-width: 1200px) {
  .pl-16 {
    padding-left: 16px;
  }
}

.pr-16 {
  padding-right: 4.2667vw;
}
@media (min-width: 768px) {
  .pr-16 {
    padding-right: 1rem;
  }
}
@media (min-width: 1200px) {
  .pr-16 {
    padding-right: 16px;
  }
}

.px-16 {
  padding-left: 4.2667vw;
}
@media (min-width: 768px) {
  .px-16 {
    padding-left: 1rem;
  }
}
@media (min-width: 1200px) {
  .px-16 {
    padding-left: 16px;
  }
}
.px-16 {
  padding-right: 4.2667vw;
}
@media (min-width: 768px) {
  .px-16 {
    padding-right: 1rem;
  }
}
@media (min-width: 1200px) {
  .px-16 {
    padding-right: 16px;
  }
}

.py-16 {
  padding-top: 4.2667vw;
}
@media (min-width: 768px) {
  .py-16 {
    padding-top: 1rem;
  }
}
@media (min-width: 1200px) {
  .py-16 {
    padding-top: 16px;
  }
}
.py-16 {
  padding-bottom: 4.2667vw;
}
@media (min-width: 768px) {
  .py-16 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 1200px) {
  .py-16 {
    padding-bottom: 16px;
  }
}

.m-20 {
  margin: 5.3333vw;
}
@media (min-width: 768px) {
  .m-20 {
    margin: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .m-20 {
    margin: 20px;
  }
}

.mt-20 {
  margin-top: 5.3333vw;
}
@media (min-width: 768px) {
  .mt-20 {
    margin-top: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .mt-20 {
    margin-top: 20px;
  }
}

.mb-20 {
  margin-bottom: 5.3333vw;
}
@media (min-width: 768px) {
  .mb-20 {
    margin-bottom: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .mb-20 {
    margin-bottom: 20px;
  }
}

.ml-20 {
  margin-left: 5.3333vw;
}
@media (min-width: 768px) {
  .ml-20 {
    margin-left: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .ml-20 {
    margin-left: 20px;
  }
}

.mr-20 {
  margin-right: 5.3333vw;
}
@media (min-width: 768px) {
  .mr-20 {
    margin-right: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .mr-20 {
    margin-right: 20px;
  }
}

.mx-20 {
  margin-left: 5.3333vw;
}
@media (min-width: 768px) {
  .mx-20 {
    margin-left: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .mx-20 {
    margin-left: 20px;
  }
}
.mx-20 {
  margin-right: 5.3333vw;
}
@media (min-width: 768px) {
  .mx-20 {
    margin-right: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .mx-20 {
    margin-right: 20px;
  }
}

.my-20 {
  margin-top: 5.3333vw;
}
@media (min-width: 768px) {
  .my-20 {
    margin-top: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .my-20 {
    margin-top: 20px;
  }
}
.my-20 {
  margin-bottom: 5.3333vw;
}
@media (min-width: 768px) {
  .my-20 {
    margin-bottom: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .my-20 {
    margin-bottom: 20px;
  }
}

.p-20 {
  padding: 5.3333vw;
}
@media (min-width: 768px) {
  .p-20 {
    padding: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .p-20 {
    padding: 20px;
  }
}

.pt-20 {
  padding-top: 5.3333vw;
}
@media (min-width: 768px) {
  .pt-20 {
    padding-top: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .pt-20 {
    padding-top: 20px;
  }
}

.pb-20 {
  padding-bottom: 5.3333vw;
}
@media (min-width: 768px) {
  .pb-20 {
    padding-bottom: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .pb-20 {
    padding-bottom: 20px;
  }
}

.pl-20 {
  padding-left: 5.3333vw;
}
@media (min-width: 768px) {
  .pl-20 {
    padding-left: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .pl-20 {
    padding-left: 20px;
  }
}

.pr-20 {
  padding-right: 5.3333vw;
}
@media (min-width: 768px) {
  .pr-20 {
    padding-right: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .pr-20 {
    padding-right: 20px;
  }
}

.px-20 {
  padding-left: 5.3333vw;
}
@media (min-width: 768px) {
  .px-20 {
    padding-left: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .px-20 {
    padding-left: 20px;
  }
}
.px-20 {
  padding-right: 5.3333vw;
}
@media (min-width: 768px) {
  .px-20 {
    padding-right: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .px-20 {
    padding-right: 20px;
  }
}

.py-20 {
  padding-top: 5.3333vw;
}
@media (min-width: 768px) {
  .py-20 {
    padding-top: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .py-20 {
    padding-top: 20px;
  }
}
.py-20 {
  padding-bottom: 5.3333vw;
}
@media (min-width: 768px) {
  .py-20 {
    padding-bottom: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .py-20 {
    padding-bottom: 20px;
  }
}

.m-24 {
  margin: 6.4vw;
}
@media (min-width: 768px) {
  .m-24 {
    margin: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .m-24 {
    margin: 24px;
  }
}

.mt-24 {
  margin-top: 6.4vw;
}
@media (min-width: 768px) {
  .mt-24 {
    margin-top: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .mt-24 {
    margin-top: 24px;
  }
}

.mb-24 {
  margin-bottom: 6.4vw;
}
@media (min-width: 768px) {
  .mb-24 {
    margin-bottom: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .mb-24 {
    margin-bottom: 24px;
  }
}

.ml-24 {
  margin-left: 6.4vw;
}
@media (min-width: 768px) {
  .ml-24 {
    margin-left: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .ml-24 {
    margin-left: 24px;
  }
}

.mr-24 {
  margin-right: 6.4vw;
}
@media (min-width: 768px) {
  .mr-24 {
    margin-right: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .mr-24 {
    margin-right: 24px;
  }
}

.mx-24 {
  margin-left: 6.4vw;
}
@media (min-width: 768px) {
  .mx-24 {
    margin-left: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .mx-24 {
    margin-left: 24px;
  }
}
.mx-24 {
  margin-right: 6.4vw;
}
@media (min-width: 768px) {
  .mx-24 {
    margin-right: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .mx-24 {
    margin-right: 24px;
  }
}

.my-24 {
  margin-top: 6.4vw;
}
@media (min-width: 768px) {
  .my-24 {
    margin-top: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .my-24 {
    margin-top: 24px;
  }
}
.my-24 {
  margin-bottom: 6.4vw;
}
@media (min-width: 768px) {
  .my-24 {
    margin-bottom: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .my-24 {
    margin-bottom: 24px;
  }
}

.p-24 {
  padding: 6.4vw;
}
@media (min-width: 768px) {
  .p-24 {
    padding: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .p-24 {
    padding: 24px;
  }
}

.pt-24 {
  padding-top: 6.4vw;
}
@media (min-width: 768px) {
  .pt-24 {
    padding-top: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .pt-24 {
    padding-top: 24px;
  }
}

.pb-24 {
  padding-bottom: 6.4vw;
}
@media (min-width: 768px) {
  .pb-24 {
    padding-bottom: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .pb-24 {
    padding-bottom: 24px;
  }
}

.pl-24 {
  padding-left: 6.4vw;
}
@media (min-width: 768px) {
  .pl-24 {
    padding-left: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .pl-24 {
    padding-left: 24px;
  }
}

.pr-24 {
  padding-right: 6.4vw;
}
@media (min-width: 768px) {
  .pr-24 {
    padding-right: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .pr-24 {
    padding-right: 24px;
  }
}

.px-24 {
  padding-left: 6.4vw;
}
@media (min-width: 768px) {
  .px-24 {
    padding-left: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .px-24 {
    padding-left: 24px;
  }
}
.px-24 {
  padding-right: 6.4vw;
}
@media (min-width: 768px) {
  .px-24 {
    padding-right: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .px-24 {
    padding-right: 24px;
  }
}

.py-24 {
  padding-top: 6.4vw;
}
@media (min-width: 768px) {
  .py-24 {
    padding-top: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .py-24 {
    padding-top: 24px;
  }
}
.py-24 {
  padding-bottom: 6.4vw;
}
@media (min-width: 768px) {
  .py-24 {
    padding-bottom: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .py-24 {
    padding-bottom: 24px;
  }
}

.m-30 {
  margin: 8vw;
}
@media (min-width: 768px) {
  .m-30 {
    margin: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .m-30 {
    margin: 30px;
  }
}

.mt-30 {
  margin-top: 8vw;
}
@media (min-width: 768px) {
  .mt-30 {
    margin-top: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .mt-30 {
    margin-top: 30px;
  }
}

.mb-30 {
  margin-bottom: 8vw;
}
@media (min-width: 768px) {
  .mb-30 {
    margin-bottom: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .mb-30 {
    margin-bottom: 30px;
  }
}

.ml-30 {
  margin-left: 8vw;
}
@media (min-width: 768px) {
  .ml-30 {
    margin-left: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .ml-30 {
    margin-left: 30px;
  }
}

.mr-30 {
  margin-right: 8vw;
}
@media (min-width: 768px) {
  .mr-30 {
    margin-right: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .mr-30 {
    margin-right: 30px;
  }
}

.mx-30 {
  margin-left: 8vw;
}
@media (min-width: 768px) {
  .mx-30 {
    margin-left: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .mx-30 {
    margin-left: 30px;
  }
}
.mx-30 {
  margin-right: 8vw;
}
@media (min-width: 768px) {
  .mx-30 {
    margin-right: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .mx-30 {
    margin-right: 30px;
  }
}

.my-30 {
  margin-top: 8vw;
}
@media (min-width: 768px) {
  .my-30 {
    margin-top: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .my-30 {
    margin-top: 30px;
  }
}
.my-30 {
  margin-bottom: 8vw;
}
@media (min-width: 768px) {
  .my-30 {
    margin-bottom: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .my-30 {
    margin-bottom: 30px;
  }
}

.p-30 {
  padding: 8vw;
}
@media (min-width: 768px) {
  .p-30 {
    padding: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .p-30 {
    padding: 30px;
  }
}

.pt-30 {
  padding-top: 8vw;
}
@media (min-width: 768px) {
  .pt-30 {
    padding-top: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .pt-30 {
    padding-top: 30px;
  }
}

.pb-30 {
  padding-bottom: 8vw;
}
@media (min-width: 768px) {
  .pb-30 {
    padding-bottom: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .pb-30 {
    padding-bottom: 30px;
  }
}

.pl-30 {
  padding-left: 8vw;
}
@media (min-width: 768px) {
  .pl-30 {
    padding-left: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .pl-30 {
    padding-left: 30px;
  }
}

.pr-30 {
  padding-right: 8vw;
}
@media (min-width: 768px) {
  .pr-30 {
    padding-right: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .pr-30 {
    padding-right: 30px;
  }
}

.px-30 {
  padding-left: 8vw;
}
@media (min-width: 768px) {
  .px-30 {
    padding-left: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .px-30 {
    padding-left: 30px;
  }
}
.px-30 {
  padding-right: 8vw;
}
@media (min-width: 768px) {
  .px-30 {
    padding-right: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .px-30 {
    padding-right: 30px;
  }
}

.py-30 {
  padding-top: 8vw;
}
@media (min-width: 768px) {
  .py-30 {
    padding-top: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .py-30 {
    padding-top: 30px;
  }
}
.py-30 {
  padding-bottom: 8vw;
}
@media (min-width: 768px) {
  .py-30 {
    padding-bottom: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .py-30 {
    padding-bottom: 30px;
  }
}

.m-40 {
  margin: 10.6667vw;
}
@media (min-width: 768px) {
  .m-40 {
    margin: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .m-40 {
    margin: 40px;
  }
}

.mt-40 {
  margin-top: 10.6667vw;
}
@media (min-width: 768px) {
  .mt-40 {
    margin-top: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .mt-40 {
    margin-top: 40px;
  }
}

.mb-40 {
  margin-bottom: 10.6667vw;
}
@media (min-width: 768px) {
  .mb-40 {
    margin-bottom: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .mb-40 {
    margin-bottom: 40px;
  }
}

.ml-40 {
  margin-left: 10.6667vw;
}
@media (min-width: 768px) {
  .ml-40 {
    margin-left: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .ml-40 {
    margin-left: 40px;
  }
}

.mr-40 {
  margin-right: 10.6667vw;
}
@media (min-width: 768px) {
  .mr-40 {
    margin-right: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .mr-40 {
    margin-right: 40px;
  }
}

.mx-40 {
  margin-left: 10.6667vw;
}
@media (min-width: 768px) {
  .mx-40 {
    margin-left: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .mx-40 {
    margin-left: 40px;
  }
}
.mx-40 {
  margin-right: 10.6667vw;
}
@media (min-width: 768px) {
  .mx-40 {
    margin-right: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .mx-40 {
    margin-right: 40px;
  }
}

.my-40 {
  margin-top: 10.6667vw;
}
@media (min-width: 768px) {
  .my-40 {
    margin-top: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .my-40 {
    margin-top: 40px;
  }
}
.my-40 {
  margin-bottom: 10.6667vw;
}
@media (min-width: 768px) {
  .my-40 {
    margin-bottom: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .my-40 {
    margin-bottom: 40px;
  }
}

.p-40 {
  padding: 10.6667vw;
}
@media (min-width: 768px) {
  .p-40 {
    padding: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .p-40 {
    padding: 40px;
  }
}

.pt-40 {
  padding-top: 10.6667vw;
}
@media (min-width: 768px) {
  .pt-40 {
    padding-top: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .pt-40 {
    padding-top: 40px;
  }
}

.pb-40 {
  padding-bottom: 10.6667vw;
}
@media (min-width: 768px) {
  .pb-40 {
    padding-bottom: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .pb-40 {
    padding-bottom: 40px;
  }
}

.pl-40 {
  padding-left: 10.6667vw;
}
@media (min-width: 768px) {
  .pl-40 {
    padding-left: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .pl-40 {
    padding-left: 40px;
  }
}

.pr-40 {
  padding-right: 10.6667vw;
}
@media (min-width: 768px) {
  .pr-40 {
    padding-right: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .pr-40 {
    padding-right: 40px;
  }
}

.px-40 {
  padding-left: 10.6667vw;
}
@media (min-width: 768px) {
  .px-40 {
    padding-left: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .px-40 {
    padding-left: 40px;
  }
}
.px-40 {
  padding-right: 10.6667vw;
}
@media (min-width: 768px) {
  .px-40 {
    padding-right: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .px-40 {
    padding-right: 40px;
  }
}

.py-40 {
  padding-top: 10.6667vw;
}
@media (min-width: 768px) {
  .py-40 {
    padding-top: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .py-40 {
    padding-top: 40px;
  }
}
.py-40 {
  padding-bottom: 10.6667vw;
}
@media (min-width: 768px) {
  .py-40 {
    padding-bottom: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .py-40 {
    padding-bottom: 40px;
  }
}

.m-50 {
  margin: 13.3333vw;
}
@media (min-width: 768px) {
  .m-50 {
    margin: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .m-50 {
    margin: 50px;
  }
}

.mt-50 {
  margin-top: 13.3333vw;
}
@media (min-width: 768px) {
  .mt-50 {
    margin-top: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .mt-50 {
    margin-top: 50px;
  }
}

.mb-50 {
  margin-bottom: 13.3333vw;
}
@media (min-width: 768px) {
  .mb-50 {
    margin-bottom: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .mb-50 {
    margin-bottom: 50px;
  }
}

.ml-50 {
  margin-left: 13.3333vw;
}
@media (min-width: 768px) {
  .ml-50 {
    margin-left: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .ml-50 {
    margin-left: 50px;
  }
}

.mr-50 {
  margin-right: 13.3333vw;
}
@media (min-width: 768px) {
  .mr-50 {
    margin-right: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .mr-50 {
    margin-right: 50px;
  }
}

.mx-50 {
  margin-left: 13.3333vw;
}
@media (min-width: 768px) {
  .mx-50 {
    margin-left: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .mx-50 {
    margin-left: 50px;
  }
}
.mx-50 {
  margin-right: 13.3333vw;
}
@media (min-width: 768px) {
  .mx-50 {
    margin-right: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .mx-50 {
    margin-right: 50px;
  }
}

.my-50 {
  margin-top: 13.3333vw;
}
@media (min-width: 768px) {
  .my-50 {
    margin-top: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .my-50 {
    margin-top: 50px;
  }
}
.my-50 {
  margin-bottom: 13.3333vw;
}
@media (min-width: 768px) {
  .my-50 {
    margin-bottom: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .my-50 {
    margin-bottom: 50px;
  }
}

.p-50 {
  padding: 13.3333vw;
}
@media (min-width: 768px) {
  .p-50 {
    padding: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .p-50 {
    padding: 50px;
  }
}

.pt-50 {
  padding-top: 13.3333vw;
}
@media (min-width: 768px) {
  .pt-50 {
    padding-top: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .pt-50 {
    padding-top: 50px;
  }
}

.pb-50 {
  padding-bottom: 13.3333vw;
}
@media (min-width: 768px) {
  .pb-50 {
    padding-bottom: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .pb-50 {
    padding-bottom: 50px;
  }
}

.pl-50 {
  padding-left: 13.3333vw;
}
@media (min-width: 768px) {
  .pl-50 {
    padding-left: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .pl-50 {
    padding-left: 50px;
  }
}

.pr-50 {
  padding-right: 13.3333vw;
}
@media (min-width: 768px) {
  .pr-50 {
    padding-right: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .pr-50 {
    padding-right: 50px;
  }
}

.px-50 {
  padding-left: 13.3333vw;
}
@media (min-width: 768px) {
  .px-50 {
    padding-left: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .px-50 {
    padding-left: 50px;
  }
}
.px-50 {
  padding-right: 13.3333vw;
}
@media (min-width: 768px) {
  .px-50 {
    padding-right: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .px-50 {
    padding-right: 50px;
  }
}

.py-50 {
  padding-top: 13.3333vw;
}
@media (min-width: 768px) {
  .py-50 {
    padding-top: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .py-50 {
    padding-top: 50px;
  }
}
.py-50 {
  padding-bottom: 13.3333vw;
}
@media (min-width: 768px) {
  .py-50 {
    padding-bottom: 3.125rem;
  }
}
@media (min-width: 1200px) {
  .py-50 {
    padding-bottom: 50px;
  }
}

.m-60 {
  margin: 16vw;
}
@media (min-width: 768px) {
  .m-60 {
    margin: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .m-60 {
    margin: 60px;
  }
}

.mt-60 {
  margin-top: 16vw;
}
@media (min-width: 768px) {
  .mt-60 {
    margin-top: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .mt-60 {
    margin-top: 60px;
  }
}

.mb-60 {
  margin-bottom: 16vw;
}
@media (min-width: 768px) {
  .mb-60 {
    margin-bottom: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .mb-60 {
    margin-bottom: 60px;
  }
}

.ml-60 {
  margin-left: 16vw;
}
@media (min-width: 768px) {
  .ml-60 {
    margin-left: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .ml-60 {
    margin-left: 60px;
  }
}

.mr-60 {
  margin-right: 16vw;
}
@media (min-width: 768px) {
  .mr-60 {
    margin-right: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .mr-60 {
    margin-right: 60px;
  }
}

.mx-60 {
  margin-left: 16vw;
}
@media (min-width: 768px) {
  .mx-60 {
    margin-left: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .mx-60 {
    margin-left: 60px;
  }
}
.mx-60 {
  margin-right: 16vw;
}
@media (min-width: 768px) {
  .mx-60 {
    margin-right: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .mx-60 {
    margin-right: 60px;
  }
}

.my-60 {
  margin-top: 16vw;
}
@media (min-width: 768px) {
  .my-60 {
    margin-top: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .my-60 {
    margin-top: 60px;
  }
}
.my-60 {
  margin-bottom: 16vw;
}
@media (min-width: 768px) {
  .my-60 {
    margin-bottom: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .my-60 {
    margin-bottom: 60px;
  }
}

.p-60 {
  padding: 16vw;
}
@media (min-width: 768px) {
  .p-60 {
    padding: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .p-60 {
    padding: 60px;
  }
}

.pt-60 {
  padding-top: 16vw;
}
@media (min-width: 768px) {
  .pt-60 {
    padding-top: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .pt-60 {
    padding-top: 60px;
  }
}

.pb-60 {
  padding-bottom: 16vw;
}
@media (min-width: 768px) {
  .pb-60 {
    padding-bottom: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .pb-60 {
    padding-bottom: 60px;
  }
}

.pl-60 {
  padding-left: 16vw;
}
@media (min-width: 768px) {
  .pl-60 {
    padding-left: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .pl-60 {
    padding-left: 60px;
  }
}

.pr-60 {
  padding-right: 16vw;
}
@media (min-width: 768px) {
  .pr-60 {
    padding-right: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .pr-60 {
    padding-right: 60px;
  }
}

.px-60 {
  padding-left: 16vw;
}
@media (min-width: 768px) {
  .px-60 {
    padding-left: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .px-60 {
    padding-left: 60px;
  }
}
.px-60 {
  padding-right: 16vw;
}
@media (min-width: 768px) {
  .px-60 {
    padding-right: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .px-60 {
    padding-right: 60px;
  }
}

.py-60 {
  padding-top: 16vw;
}
@media (min-width: 768px) {
  .py-60 {
    padding-top: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .py-60 {
    padding-top: 60px;
  }
}
.py-60 {
  padding-bottom: 16vw;
}
@media (min-width: 768px) {
  .py-60 {
    padding-bottom: 3.75rem;
  }
}
@media (min-width: 1200px) {
  .py-60 {
    padding-bottom: 60px;
  }
}

.m-80 {
  margin: 21.3333vw;
}
@media (min-width: 768px) {
  .m-80 {
    margin: 5rem;
  }
}
@media (min-width: 1200px) {
  .m-80 {
    margin: 80px;
  }
}

.mt-80 {
  margin-top: 21.3333vw;
}
@media (min-width: 768px) {
  .mt-80 {
    margin-top: 5rem;
  }
}
@media (min-width: 1200px) {
  .mt-80 {
    margin-top: 80px;
  }
}

.mb-80 {
  margin-bottom: 21.3333vw;
}
@media (min-width: 768px) {
  .mb-80 {
    margin-bottom: 5rem;
  }
}
@media (min-width: 1200px) {
  .mb-80 {
    margin-bottom: 80px;
  }
}

.ml-80 {
  margin-left: 21.3333vw;
}
@media (min-width: 768px) {
  .ml-80 {
    margin-left: 5rem;
  }
}
@media (min-width: 1200px) {
  .ml-80 {
    margin-left: 80px;
  }
}

.mr-80 {
  margin-right: 21.3333vw;
}
@media (min-width: 768px) {
  .mr-80 {
    margin-right: 5rem;
  }
}
@media (min-width: 1200px) {
  .mr-80 {
    margin-right: 80px;
  }
}

.mx-80 {
  margin-left: 21.3333vw;
}
@media (min-width: 768px) {
  .mx-80 {
    margin-left: 5rem;
  }
}
@media (min-width: 1200px) {
  .mx-80 {
    margin-left: 80px;
  }
}
.mx-80 {
  margin-right: 21.3333vw;
}
@media (min-width: 768px) {
  .mx-80 {
    margin-right: 5rem;
  }
}
@media (min-width: 1200px) {
  .mx-80 {
    margin-right: 80px;
  }
}

.my-80 {
  margin-top: 21.3333vw;
}
@media (min-width: 768px) {
  .my-80 {
    margin-top: 5rem;
  }
}
@media (min-width: 1200px) {
  .my-80 {
    margin-top: 80px;
  }
}
.my-80 {
  margin-bottom: 21.3333vw;
}
@media (min-width: 768px) {
  .my-80 {
    margin-bottom: 5rem;
  }
}
@media (min-width: 1200px) {
  .my-80 {
    margin-bottom: 80px;
  }
}

.p-80 {
  padding: 21.3333vw;
}
@media (min-width: 768px) {
  .p-80 {
    padding: 5rem;
  }
}
@media (min-width: 1200px) {
  .p-80 {
    padding: 80px;
  }
}

.pt-80 {
  padding-top: 21.3333vw;
}
@media (min-width: 768px) {
  .pt-80 {
    padding-top: 5rem;
  }
}
@media (min-width: 1200px) {
  .pt-80 {
    padding-top: 80px;
  }
}

.pb-80 {
  padding-bottom: 21.3333vw;
}
@media (min-width: 768px) {
  .pb-80 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 1200px) {
  .pb-80 {
    padding-bottom: 80px;
  }
}

.pl-80 {
  padding-left: 21.3333vw;
}
@media (min-width: 768px) {
  .pl-80 {
    padding-left: 5rem;
  }
}
@media (min-width: 1200px) {
  .pl-80 {
    padding-left: 80px;
  }
}

.pr-80 {
  padding-right: 21.3333vw;
}
@media (min-width: 768px) {
  .pr-80 {
    padding-right: 5rem;
  }
}
@media (min-width: 1200px) {
  .pr-80 {
    padding-right: 80px;
  }
}

.px-80 {
  padding-left: 21.3333vw;
}
@media (min-width: 768px) {
  .px-80 {
    padding-left: 5rem;
  }
}
@media (min-width: 1200px) {
  .px-80 {
    padding-left: 80px;
  }
}
.px-80 {
  padding-right: 21.3333vw;
}
@media (min-width: 768px) {
  .px-80 {
    padding-right: 5rem;
  }
}
@media (min-width: 1200px) {
  .px-80 {
    padding-right: 80px;
  }
}

.py-80 {
  padding-top: 21.3333vw;
}
@media (min-width: 768px) {
  .py-80 {
    padding-top: 5rem;
  }
}
@media (min-width: 1200px) {
  .py-80 {
    padding-top: 80px;
  }
}
.py-80 {
  padding-bottom: 21.3333vw;
}
@media (min-width: 768px) {
  .py-80 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 1200px) {
  .py-80 {
    padding-bottom: 80px;
  }
}

.m-100 {
  margin: 26.6667vw;
}
@media (min-width: 768px) {
  .m-100 {
    margin: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .m-100 {
    margin: 100px;
  }
}

.mt-100 {
  margin-top: 26.6667vw;
}
@media (min-width: 768px) {
  .mt-100 {
    margin-top: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .mt-100 {
    margin-top: 100px;
  }
}

.mb-100 {
  margin-bottom: 26.6667vw;
}
@media (min-width: 768px) {
  .mb-100 {
    margin-bottom: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .mb-100 {
    margin-bottom: 100px;
  }
}

.ml-100 {
  margin-left: 26.6667vw;
}
@media (min-width: 768px) {
  .ml-100 {
    margin-left: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .ml-100 {
    margin-left: 100px;
  }
}

.mr-100 {
  margin-right: 26.6667vw;
}
@media (min-width: 768px) {
  .mr-100 {
    margin-right: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .mr-100 {
    margin-right: 100px;
  }
}

.mx-100 {
  margin-left: 26.6667vw;
}
@media (min-width: 768px) {
  .mx-100 {
    margin-left: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .mx-100 {
    margin-left: 100px;
  }
}
.mx-100 {
  margin-right: 26.6667vw;
}
@media (min-width: 768px) {
  .mx-100 {
    margin-right: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .mx-100 {
    margin-right: 100px;
  }
}

.my-100 {
  margin-top: 26.6667vw;
}
@media (min-width: 768px) {
  .my-100 {
    margin-top: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .my-100 {
    margin-top: 100px;
  }
}
.my-100 {
  margin-bottom: 26.6667vw;
}
@media (min-width: 768px) {
  .my-100 {
    margin-bottom: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .my-100 {
    margin-bottom: 100px;
  }
}

.p-100 {
  padding: 26.6667vw;
}
@media (min-width: 768px) {
  .p-100 {
    padding: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .p-100 {
    padding: 100px;
  }
}

.pt-100 {
  padding-top: 26.6667vw;
}
@media (min-width: 768px) {
  .pt-100 {
    padding-top: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .pt-100 {
    padding-top: 100px;
  }
}

.pb-100 {
  padding-bottom: 26.6667vw;
}
@media (min-width: 768px) {
  .pb-100 {
    padding-bottom: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .pb-100 {
    padding-bottom: 100px;
  }
}

.pl-100 {
  padding-left: 26.6667vw;
}
@media (min-width: 768px) {
  .pl-100 {
    padding-left: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .pl-100 {
    padding-left: 100px;
  }
}

.pr-100 {
  padding-right: 26.6667vw;
}
@media (min-width: 768px) {
  .pr-100 {
    padding-right: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .pr-100 {
    padding-right: 100px;
  }
}

.px-100 {
  padding-left: 26.6667vw;
}
@media (min-width: 768px) {
  .px-100 {
    padding-left: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .px-100 {
    padding-left: 100px;
  }
}
.px-100 {
  padding-right: 26.6667vw;
}
@media (min-width: 768px) {
  .px-100 {
    padding-right: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .px-100 {
    padding-right: 100px;
  }
}

.py-100 {
  padding-top: 26.6667vw;
}
@media (min-width: 768px) {
  .py-100 {
    padding-top: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .py-100 {
    padding-top: 100px;
  }
}
.py-100 {
  padding-bottom: 26.6667vw;
}
@media (min-width: 768px) {
  .py-100 {
    padding-bottom: 6.25rem;
  }
}
@media (min-width: 1200px) {
  .py-100 {
    padding-bottom: 100px;
  }
}

.text-10 {
  font-size: 2.6667vw;
}
@media (min-width: 768px) {
  .text-10 {
    font-size: 0.625rem;
  }
}
@media (min-width: 1200px) {
  .text-10 {
    font-size: 10px;
  }
}

.text-11 {
  font-size: 2.9333vw;
}
@media (min-width: 768px) {
  .text-11 {
    font-size: 0.6875rem;
  }
}
@media (min-width: 1200px) {
  .text-11 {
    font-size: 11px;
  }
}

.text-12 {
  font-size: 3.2vw;
}
@media (min-width: 768px) {
  .text-12 {
    font-size: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .text-12 {
    font-size: 12px;
  }
}

.text-13 {
  font-size: 3.4667vw;
}
@media (min-width: 768px) {
  .text-13 {
    font-size: 0.8125rem;
  }
}
@media (min-width: 1200px) {
  .text-13 {
    font-size: 13px;
  }
}

.text-14 {
  font-size: 3.7333vw;
}
@media (min-width: 768px) {
  .text-14 {
    font-size: 0.875rem;
  }
}
@media (min-width: 1200px) {
  .text-14 {
    font-size: 14px;
  }
}

.text-15 {
  font-size: 4vw;
}
@media (min-width: 768px) {
  .text-15 {
    font-size: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .text-15 {
    font-size: 15px;
  }
}

.text-16 {
  font-size: 4.2667vw;
}
@media (min-width: 768px) {
  .text-16 {
    font-size: 1rem;
  }
}
@media (min-width: 1200px) {
  .text-16 {
    font-size: 16px;
  }
}

.text-18 {
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  .text-18 {
    font-size: 1.125rem;
  }
}
@media (min-width: 1200px) {
  .text-18 {
    font-size: 18px;
  }
}

.text-20 {
  font-size: 5.3333vw;
}
@media (min-width: 768px) {
  .text-20 {
    font-size: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .text-20 {
    font-size: 20px;
  }
}

.text-22 {
  font-size: 5.8667vw;
}
@media (min-width: 768px) {
  .text-22 {
    font-size: 1.375rem;
  }
}
@media (min-width: 1200px) {
  .text-22 {
    font-size: 22px;
  }
}

.text-24 {
  font-size: 6.4vw;
}
@media (min-width: 768px) {
  .text-24 {
    font-size: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .text-24 {
    font-size: 24px;
  }
}

.text-26 {
  font-size: 6.9333vw;
}
@media (min-width: 768px) {
  .text-26 {
    font-size: 1.625rem;
  }
}
@media (min-width: 1200px) {
  .text-26 {
    font-size: 26px;
  }
}

.text-28 {
  font-size: 7.4667vw;
}
@media (min-width: 768px) {
  .text-28 {
    font-size: 1.75rem;
  }
}
@media (min-width: 1200px) {
  .text-28 {
    font-size: 28px;
  }
}

.text-30 {
  font-size: 8vw;
}
@media (min-width: 768px) {
  .text-30 {
    font-size: 1.875rem;
  }
}
@media (min-width: 1200px) {
  .text-30 {
    font-size: 30px;
  }
}

.text-32 {
  font-size: 8.5333vw;
}
@media (min-width: 768px) {
  .text-32 {
    font-size: 2rem;
  }
}
@media (min-width: 1200px) {
  .text-32 {
    font-size: 32px;
  }
}

.text-36 {
  font-size: 9.6vw;
}
@media (min-width: 768px) {
  .text-36 {
    font-size: 2.25rem;
  }
}
@media (min-width: 1200px) {
  .text-36 {
    font-size: 36px;
  }
}

.text-40 {
  font-size: 10.6667vw;
}
@media (min-width: 768px) {
  .text-40 {
    font-size: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .text-40 {
    font-size: 40px;
  }
}

.text-48 {
  font-size: 12.8vw;
}
@media (min-width: 768px) {
  .text-48 {
    font-size: 3rem;
  }
}
@media (min-width: 1200px) {
  .text-48 {
    font-size: 48px;
  }
}

/*
영문 자간 다시 정의하기 위한 믹스인
사용 예시
.en-title {
  @include font-set('lg', 'eng');
}
*/
.text-left {
  text-align: left;
}

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

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

.fw-100 {
  font-weight: 100;
}

.fw-300 {
  font-weight: 300;
}

.fw-400 {
  font-weight: 400;
}

.fw-500 {
  font-weight: 500;
}

.fw-700 {
  font-weight: 700;
}

.fw-900 {
  font-weight: 900;
}

.d-flex {
  display: flex;
}

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

.flex-row {
  flex-direction: row;
}

.flex-row-reverse {
  flex-direction: row-reverse;
}

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

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

.flex-wrap {
  flex-wrap: wrap;
}

.flex-nowrap {
  flex-wrap: nowrap;
}

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

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

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

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

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

.items-start {
  align-items: flex-start;
}

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

.items-end {
  align-items: flex-end;
}

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

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

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

.flex-1 {
  flex: 1 1 0%;
}

.flex-auto {
  flex: 1 1 auto;
}

.flex-none {
  flex: none;
}

.w-full {
  width: 100%;
}

.h-full {
  height: 100%;
}

.w-auto {
  width: auto;
}

.d-block {
  display: block;
}

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

.d-none {
  display: none;
}

.text-cut1 {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.w-5p {
  width: 5%;
}

.w-10p {
  width: 10%;
}

.w-15p {
  width: 15%;
}

.w-20p {
  width: 20%;
}

.w-25p {
  width: 25%;
}

.w-30p {
  width: 30%;
}

.w-33p {
  width: 33%;
}

.w-40p {
  width: 40%;
}

.w-50p {
  width: 50%;
}

.w-60p {
  width: 60%;
}

.w-70p {
  width: 70%;
}

.w-75p {
  width: 75%;
}

.w-80p {
  width: 80%;
}

.w-90p {
  width: 90%;
}

.w-100p {
  width: 100%;
}

/*
================================================================================
   [Utility Classes 사용 가이드]
   * 핵심 규칙: 클래스명에 적힌 숫자는 "디자인 시안 기준(1배수) 픽셀"입니다.
   * 작동 원리: 내부적으로 responsive() 믹스인을 타서 모바일(vw) / 태블릿(rem) / PC(px)로 자동 스케일링됩니다.
================================================================================

   1. Spacing (여백)
   -----------------------------------------------------------------------------
   * Naming: {property}{side}-{size}
   * Property: m (margin), p (padding)
   * Side: t (top), b (bottom), l (left), r (right), x (left+right), y (top+bottom), 생략 (all)
   * Size: 0, 4, 5, 8, 10, 12, 15, 16, 20, 24, 30, 40, 50, 60, 80, 100

   [예시]
   .mt-20       => margin-top 20px (각 해상도에 맞게 변환)
   .px-10       => padding-left/right 10px
   .p-30        => padding 30px
   .mb-0        => margin-bottom: 0

   2. Typography (텍스트)
   -----------------------------------------------------------------------------
   * Naming: .text-{size}
   * Size: 10 ~ 48 (시안 기준 px)

   [예시]
   .text-16     => font-size 16px 기준 자동 스케일링
   .text-24     => font-size 24px 기준 자동 스케일링

   * 정렬: .text-left, .text-center, .text-right
   * 굵기: .fw-400, .fw-500, .fw-700 등

   3. Flexbox (레이아웃 배치)
   -----------------------------------------------------------------------------
   * 컨테이너: .d-flex, .d-inline-flex
   * 방향: .flex-row (기본), .flex-col (세로)
   * 줄바꿈: .flex-wrap, .flex-nowrap

   * 가로 정렬 (Justify):
     .justify-start, .justify-center, .justify-end, .justify-between, .justify-around

   * 세로 정렬 (Align):
     .items-start, .items-center, .items-end, .items-stretch

   4. 기타 유틸리티
   -----------------------------------------------------------------------------
   .w-full      => width: 100%
   .h-full      => height: 100%
   .d-none      => display: none
   .d-block     => display: block
   .sr-only     => 스크린 리더 전용 숨김
   .w-20p       => width: 20%

================================================================================
*/
.pagination-container {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 40px;
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  list-style: none;
  gap: 0.8vw;
}
@media (min-width: 768px) {
  .pagination {
    gap: 0.1875rem;
  }
}
@media (min-width: 1200px) {
  .pagination {
    gap: 3px;
  }
}

.page-item.pc-only {
  display: none;
}
@media screen and (min-width: 1200px) {
  .page-item.pc-only {
    display: flex;
  }
}
.page-item .page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  flex: 1;
  text-decoration: none;
  transition: all 0.2s ease;
  font-weight: 500;
  color: var(--text-sub, #666);
  height: 10.6667vw;
}
@media (min-width: 768px) {
  .page-item .page-link {
    height: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .page-item .page-link {
    height: 40px;
  }
}
.page-item .page-link {
  font-size: 4vw;
}
@media (min-width: 768px) {
  .page-item .page-link {
    font-size: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .page-item .page-link {
    font-size: 15px;
  }
}
.page-item .page-link {
  border-radius: 1.6vw;
}
@media (min-width: 768px) {
  .page-item .page-link {
    border-radius: 0.375rem;
  }
}
@media (min-width: 1200px) {
  .page-item .page-link {
    border-radius: 6px;
  }
}
.page-item .page-link {
  min-width: 10.6667vw;
}
@media (min-width: 768px) {
  .page-item .page-link {
    min-width: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .page-item .page-link {
    min-width: 40px;
  }
}
.page-item .page-link {
  max-width: 10.6667vw;
}
@media (min-width: 768px) {
  .page-item .page-link {
    max-width: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .page-item .page-link {
    max-width: 40px;
  }
}
@media screen and (min-width: 1200px) {
  .page-item .page-link {
    width: 40px;
    flex: none;
    min-width: auto;
    max-width: none;
  }
}
.page-item .page-link:hover {
  color: #000;
  background-color: rgba(0, 0, 0, 0.03);
}
.page-item .page-link .icon-svg svg {
  transform: rotate(-90deg);
}
.page-item .page-link[aria-label=Previous] .icon-svg svg {
  transform: rotate(90deg);
}
.page-item.active .page-link {
  background-color: #1f3556;
  color: #fff;
  font-weight: 700;
  cursor: default;
}
.page-item.control .page-link {
  background: transparent !important;
  font-family: inherit;
}
.page-item.control .page-link .btn-text {
  display: none;
  margin: 0 4px;
  font-size: 16px;
}
@media screen and (min-width: 1200px) {
  .page-item.control .page-link {
    width: auto;
    padding: 0 10px;
  }
  .page-item.control .page-link .btn-text {
    display: inline-block;
  }
}
.page-item.control .page-link:hover {
  color: #000;
}
.page-item.control .page-link:hover .btn-text {
  text-decoration: underline;
}
.page-item.ellipsis .page-link {
  background: transparent !important;
  cursor: default;
  pointer-events: none;
}

/* =================================================================
   [Component] Modal Layer
   * JS Class Mapping:
   * 1. 배경 (.modal-dim)
   * 2. 본체 (.modal-layer)
   * 3. 활성상태 (.is-active)
   ================================================================= */
.modal-dim {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.modal-dim.is-active {
  opacity: 1;
  visibility: visible;
}
.modal-dim.is-active .modal-layer {
  transform: translateY(0);
  opacity: 1;
}

.modal-layer {
  position: relative;
  display: flex;
  flex-direction: column;
  width: calc(100% - 40px);
  max-height: 85vh;
  background-color: #fff;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  transform: translateY(20px);
  opacity: 0;
  transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), opacity 0.3s;
  border-radius: 3.2vw;
}
@media (min-width: 768px) {
  .modal-layer {
    border-radius: 0.75rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer {
    border-radius: 12px;
  }
}
@media screen and (min-width: 768px) {
  .modal-layer {
    width: 100%;
  }
}
.modal-layer .modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #eee;
  padding: 5.3333vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-header {
    padding: 1.25rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-header {
    padding: 20px;
  }
}
.modal-layer .modal-header .tit {
  margin: 0;
  font-weight: 700;
  color: #000;
  line-height: 1.3;
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-header .tit {
    font-size: 1.125rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-header .tit {
    font-size: 18px;
  }
}
.modal-layer .modal-header .btn-close-modal {
  padding: 0;
  background: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  border: none;
  cursor: pointer;
  width: 6.4vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-header .btn-close-modal {
    width: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-header .btn-close-modal {
    width: 24px;
  }
}
.modal-layer .modal-header .btn-close-modal {
  height: 6.4vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-header .btn-close-modal {
    height: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-header .btn-close-modal {
    height: 24px;
  }
}
.modal-layer .modal-body {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  color: #666;
  line-height: 1.5;
  padding: 6.4vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-body {
    padding: 1.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-body {
    padding: 24px;
  }
}
.modal-layer .modal-body {
  font-size: 4vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-body {
    font-size: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-body {
    font-size: 15px;
  }
}
.modal-layer .modal-footer {
  display: flex;
  justify-content: flex-end;
  background-color: #f8f9fa;
  border-top: 1px solid #eee;
  padding: 4.2667vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-footer {
    padding: 1rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-footer {
    padding: 16px;
  }
}
.modal-layer .modal-footer {
  gap: 2.1333vw;
}
@media (min-width: 768px) {
  .modal-layer .modal-footer {
    gap: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .modal-footer {
    gap: 8px;
  }
}

/* =================================================================
   [웹폰트 선언 영역] 전달해주신 모든 @font-face 소스 통합
================================================================= */
/* 공통 1: Pretendard */
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-Thin.woff2") format("woff2");
  font-weight: 100;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-ExtraLight.woff2") format("woff2");
  font-weight: 200;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-Light.woff2") format("woff2");
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-Regular.woff2") format("woff2");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-Medium.woff2") format("woff2");
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-Bold.woff2") format("woff2");
  font-weight: 700;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-ExtraBold.woff2") format("woff2");
  font-weight: 800;
  font-display: swap;
}
@font-face {
  font-family: "Pretendard";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/pretendard@1.0/Pretendard-Black.woff2") format("woff2");
  font-weight: 900;
  font-display: swap;
}
/* 브랜드 1: 코젤 */
@font-face {
  font-family: "SillaGothic";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2206-02@1.0/Shilla_Gothic-Bold.woff2") format("woff2");
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "Poplar Std";
  src: url("/static/fonts/Poplar/Poplar.eot");
  src: url("/static/fonts/Poplar/Poplar.eot?#iefix") format("embedded-opentype"), url("/static/fonts/Poplar/Poplar.woff2") format("woff2"), url("/static/fonts/Poplar/Poplar.woff") format("woff"), url("/static/fonts/Poplar/Poplar.ttf") format("truetype");
  font-display: swap;
}
/* 브랜드 2: 필스너우르겔 */
@font-face {
  font-family: "Daeojamjil";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302_01@1.0/TheJamsil1Thin.woff2") format("woff2");
  font-weight: 100;
  font-display: swap;
}
@font-face {
  font-family: "Daeojamjil";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302_01@1.0/TheJamsil2Light.woff2") format("woff2");
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: "Daeojamjil";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302_01@1.0/TheJamsil3Regular.woff2") format("woff2");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Daeojamjil";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302_01@1.0/TheJamsil4Medium.woff2") format("woff2");
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: "Daeojamjil";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302_01@1.0/TheJamsil5Bold.woff2") format("woff2");
  font-weight: 700;
  font-display: swap;
}
@font-face {
  font-family: "Daeojamjil";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2302_01@1.0/TheJamsil6ExtraBold.woff2") format("woff2");
  font-weight: 800;
  font-display: swap;
}
/* 브랜드 3: 페로니 */
@font-face {
  font-family: "Cafe24Danjeonghae";
  src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_twelve@1.1/Cafe24Danjunghae.woff") format("woff");
  font-weight: normal;
  font-display: swap;
}
/* 브랜드 4: 런던프라이드 (Swagger) */
@font-face {
  font-family: "Swagger";
  src: url("/static/fonts/SDSwagger/SDSwaggerTTF.woff2") format("woff2"), url("/static/fonts/SDSwagger/SDSwaggerTTF.woff") format("woff"), url("/static/fonts/SDSwagger/SDSwaggerTTF.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
/* 브랜드 5: KGB */
@font-face {
  font-family: "LotteMartHappiness";
  src: url("/static/fonts/LotteMart/LotteMartHappyMedium.woff") format("woff2"), url("/static/fonts/LotteMart/LotteMartHappyMedium.woff2") format("woff");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "LotteMartHappiness";
  src: url("/static/fonts/LotteMart/LotteMartHappyBold.woff") format("woff2"), url("/static/fonts/LotteMart/LotteMartHappyBold.woff2") format("woff");
  font-weight: 700;
  font-display: swap;
}
/* =================================================================
   1. [CSS Variables] Global Settings
   ================================================================= */
:root {
  --font-common: 'Pretendard', sans-serif;
  --font-ink: 'InkLiquid', cursive;
  /* --------------------------------
     1-1. Color System (Base)
     -------------------------------- */
  --color-primary: #0C6FB8;
  --color-secondary: #AE8766;
  --color-tertiary: #87C33F;
  --color-error: #F82417;
  /* Grayscale Mapping */
  --gray-wh: #ffffff;
  --gray-bk: #000000;
  --gray1: #F3F3F3;
  --gray2: #EDEDED;
  --gray3: #DEDEDE;
  --gray4: #C4C4C4;
  --gray5: #9F9F9F;
  --gray6: #888888;
  --gray7: #616161;
  --gray8: #444444;
  --gray9: #2B2B2B;
  /* Backgrounds */
  --bg-page: var(--gray-wh);
  --bg-white: #ffffff;
  /* Texts */
  --text-main: var(--gray9);
  --text-sub: var(--gray6);
  --text-muted: var(--gray4);
  /* Borders & Lines */
  --line-light: var(--gray2);
  --line-basic: var(--gray5);
  --line-strong: var(--gray7);
  /* Forms (Inputs) */
  --input-height: 48px;
  --input-bg:#ffffff;
  --input-border-color: var(--line-basic);
  --input-radius: 6px;
  --input-bdw: 1px;
  --input-pad: 16px;
  --input-def-bdc: #9F9F9F;
  --input-lg-h: 64px;
  --input-lg-radius:16px;
  /* Tables */
  --table-th-bg: var(--gray1);
  --table-th-text: var(--gray7);
  --table-border: var(--gray2);
  /* Misc */
  --PlaceColor: var(--gray4);
  --color-primary-dark: rgb(7.3163265306, 67.6760204082, 112.1836734694);
  --color-primary-light: rgb(199.612244898, 229.4132653061, 251.387755102);
  --color-secondary-dark: rgb(130.4423076923, 97.1923076923, 69.0576923077);
  --color-secondary-light: rgb(235.7884615385, 226.5384615385, 218.7115384615);
  /* 버튼, 피그마 연동*/
  --btn-common-bw: 2px;
  --btn-lg-height: 64px;
  --btn-lg-v-pad: 16px;
  --btn-lg-h-pad: 32px;
  --btn-lg-gap: 8px;
  --btn-lg-radius: 16px;
  --btn-lg-radius-full: 64px;
  --btn-sm-height: 54px;
  --btn-sm-v-pad: 12px;
  --btn-sm-h-pad: 24px;
  --btn-sm-gap: 6px;
  --btn-sm-radius: 14px;
  --btn-sm-radius-full: 54px;
  --btn-xs-height: 40px;
  --btn-xs-v-pad: 8px;
  --btn-xs-h-pad: 16px;
  --btn-xs-gap: 5px;
  --btn-xs-radius: 10px;
  --btn-xs-radius-full: 40px;
  /* =================================================================
  Heading Typography & Variables (Figma var(--h2) 연결)
  ================================================================= */
  --text-h2: 8vw;
}
@media (min-width: 768px) {
  :root {
    --text-h2: 1.875rem;
  }
}
@media (min-width: 1200px) {
  :root {
    --text-h2: 30px;
  }
}
:root {
  --h2: var(--text-h2);
}
@media screen and (min-width: 1200px) {
  :root {
    --text-h2: 44px;
  }
}
:root {
  --text-h3: 6.9333vw;
}
@media (min-width: 768px) {
  :root {
    --text-h3: 1.625rem;
  }
}
@media (min-width: 1200px) {
  :root {
    --text-h3: 26px;
  }
}
:root {
  --h3: var(--text-h3);
}
@media screen and (min-width: 1200px) {
  :root {
    --text-h3: 38px;
  }
}
:root {
  --text-h4: 5.8667vw;
}
@media (min-width: 768px) {
  :root {
    --text-h4: 1.375rem;
  }
}
@media (min-width: 1200px) {
  :root {
    --text-h4: 22px;
  }
}
:root {
  --h4: var(--text-h4);
}
@media screen and (min-width: 1200px) {
  :root {
    --text-h4: 32px;
  }
}
:root {
  --text-h5: 4.8vw;
}
@media (min-width: 768px) {
  :root {
    --text-h5: 1.125rem;
  }
}
@media (min-width: 1200px) {
  :root {
    --text-h5: 18px;
  }
}
:root {
  --h5: var(--text-h5);
}
@media screen and (min-width: 1200px) {
  :root {
    --text-h5: 26px;
  }
}
:root {
  --text-h6: 4.2667vw;
}
@media (min-width: 768px) {
  :root {
    --text-h6: 1rem;
  }
}
@media (min-width: 1200px) {
  :root {
    --text-h6: 16px;
  }
}
:root {
  --h6: var(--text-h6);
}
@media screen and (min-width: 1200px) {
  :root {
    --text-h6: 24px;
  }
}

/* =================================================================
   2. [Theme] Dark Mode Override
   ================================================================= */
[data-theme=dark] {
  --bg-page: var(--gray9);
  --bg-white: var(--gray8);
  --text-main: var(--gray-wh);
  --text-sub: var(--gray4);
  --line-basic: var(--gray7);
}

/* =================================================================
   3. [Typography] Auto Responsive Variables
   ================================================================= */
/* 3-1. Mobile Default (vw) */
:root {
  --text-xs: 3.2vw;
  --text-sm: 3.7333vw;
  --text-base: 4.2667vw;
  --text-lg: 4.8vw;
  --text-xl: 5.3333vw;
  --text-2xl: 6.4vw;
  --text-3xl: 8vw;
}

/* 3-2. Tablet Override (rem) */
@media (min-width: 768px) {
  :root {
    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 1.875rem;
  }
}
/* 3-3. PC Override (px) */
@media (min-width: 1200px) {
  :root {
    --text-xs: 12px;
    --text-sm: 14px;
    --text-base: 16px;
    --text-lg: 18px;
    --text-xl: 20px;
    --text-2xl: 24px;
    --text-3xl: 30px;
  }
}
/* 3-4. 폰트사이즈 클래스화 */
.text-xs {
  font-size: var(--text-xs);
}

.text-sm {
  font-size: var(--text-sm);
}

.text-base {
  font-size: var(--text-base);
}

.text-lg {
  font-size: var(--text-lg);
}

.text-xl {
  font-size: var(--text-xl);
}

.text-2xl {
  font-size: var(--text-2xl);
}

.text-3xl {
  font-size: var(--text-3xl);
}

/* 스크롤바 커스텀 */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-thumb {
  background: #cccccc;
  border-radius: 0;
}

::-webkit-scrollbar-thumb:hover {
  background: #888888;
}

::-webkit-scrollbar-track {
  background: #eeeeee;
  border-radius: 0;
}

html,
body {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

hr {
  height: 1px;
  background-color: #EDEDED;
  margin: 0 auto;
  border: none;
}

br.mo {
  display: block;
}
@media screen and (min-width: 768px) {
  br.mo {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  br.mo {
    display: none;
  }
}
br.sm {
  display: none;
}
@media screen and (min-width: 768px) {
  br.sm {
    display: block;
  }
}
@media screen and (min-width: 1200px) {
  br.sm {
    display: none;
  }
}
br.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  br.pc {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  br.pc {
    display: block;
  }
}

.scroll {
  width: 100%;
  padding: 0;
  overflow-y: overlay;
  text-align: center;
}

h2 {
  font-weight: 700;
  line-height: 1.5;
  font-size: var(--h2);
}

h3 {
  font-weight: 700;
  line-height: 1.5;
  font-size: var(--h3);
}

h4 {
  font-weight: 700;
  line-height: 1.5;
  font-size: var(--h4);
}

h5 {
  font-weight: 700;
  line-height: 1.5;
  font-size: var(--h5);
}

h6 {
  font-weight: 700;
  line-height: 1.5;
  font-size: var(--h6);
}

.icon-svg {
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 10.6667vw;
}
@media (min-width: 768px) {
  .icon-svg {
    width: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .icon-svg {
    width: 40px;
  }
}
.icon-svg {
  height: 10.6667vw;
}
@media (min-width: 768px) {
  .icon-svg {
    height: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .icon-svg {
    height: 40px;
  }
}
.icon-svg svg {
  overflow: hidden;
  width: 100%;
}

.modal-layer .btn-close-modal {
  position: absolute;
  z-index: 99;
  right: 2.1333vw;
}
@media (min-width: 768px) {
  .modal-layer .btn-close-modal {
    right: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .btn-close-modal {
    right: 8px;
  }
}
.modal-layer .btn-close-modal {
  top: 2.1333vw;
}
@media (min-width: 768px) {
  .modal-layer .btn-close-modal {
    top: 0.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .btn-close-modal {
    top: 8px;
  }
}
.modal-layer .btn-close-modal {
  width: 10.6667vw;
}
@media (min-width: 768px) {
  .modal-layer .btn-close-modal {
    width: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .btn-close-modal {
    width: 40px;
  }
}
.modal-layer .btn-close-modal {
  height: 10.6667vw;
}
@media (min-width: 768px) {
  .modal-layer .btn-close-modal {
    height: 2.5rem;
  }
}
@media (min-width: 1200px) {
  .modal-layer .btn-close-modal {
    height: 40px;
  }
}
.modal-layer .btn-close-modal svg {
  color: black;
}

/*모션*/
.motion-fade {
  opacity: 0;
  transition: opacity 1s;
}
.motion-fade.active {
  opacity: 1;
}

.motion-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s, transform 0.7s;
}
.motion-up.active {
  opacity: 1;
  transform: translateY(0);
}

.motion-left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.7s, transform 0.7s;
}
.motion-left.active {
  opacity: 1;
  transform: translateX(0);
}

.motion-right {
  opacity: 0;
  transform: translateX(60px);
  transition: opacity 0.7s, transform 0.7s;
}
.motion-right.active {
  opacity: 1;
  transform: translateX(0);
}

#share_modal .modal-body, #event_view_modal .modal-body {
  padding: 13.3333vw 0vw;
}
@media (min-width: 768px) {
  #share_modal .modal-body, #event_view_modal .modal-body {
    padding: 3.125rem 0rem;
  }
}
@media (min-width: 1200px) {
  #share_modal .modal-body, #event_view_modal .modal-body {
    padding: 50px 0px;
  }
}
#share_modal h3, #event_view_modal h3 {
  display: block;
  width: 100%;
  font-weight: 600;
  color: #000;
  text-align: center;
  font-size: 6.4vw;
}
@media (min-width: 768px) {
  #share_modal h3, #event_view_modal h3 {
    font-size: 1.5rem;
  }
}
@media (min-width: 1200px) {
  #share_modal h3, #event_view_modal h3 {
    font-size: 24px;
  }
}
#share_modal h3, #event_view_modal h3 {
  margin-bottom: 8.5333vw;
}
@media (min-width: 768px) {
  #share_modal h3, #event_view_modal h3 {
    margin-bottom: 2rem;
  }
}
@media (min-width: 1200px) {
  #share_modal h3, #event_view_modal h3 {
    margin-bottom: 32px;
  }
}
#share_modal .share-row, #event_view_modal .share-row {
  flex-flow: wrap;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 21.3333vw;
}
@media (min-width: 768px) {
  #share_modal .share-row, #event_view_modal .share-row {
    gap: 5rem;
  }
}
@media (min-width: 1200px) {
  #share_modal .share-row, #event_view_modal .share-row {
    gap: 80px;
  }
}
#share_modal .share-row a, #event_view_modal .share-row a {
  flex-flow: wrap;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3.2vw;
}
@media (min-width: 768px) {
  #share_modal .share-row a, #event_view_modal .share-row a {
    gap: 0.75rem;
  }
}
@media (min-width: 1200px) {
  #share_modal .share-row a, #event_view_modal .share-row a {
    gap: 12px;
  }
}
#share_modal .share-row a, #event_view_modal .share-row a {
  width: 16.5333vw;
}
@media (min-width: 768px) {
  #share_modal .share-row a, #event_view_modal .share-row a {
    width: 3.875rem;
  }
}
@media (min-width: 1200px) {
  #share_modal .share-row a, #event_view_modal .share-row a {
    width: 62px;
  }
}
#share_modal .share-row a span, #event_view_modal .share-row a span {
  width: 100%;
  color: #000;
  text-align: center;
  font-weight: 600;
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  #share_modal .share-row a span, #event_view_modal .share-row a span {
    font-size: 1.125rem;
  }
}
@media (min-width: 1200px) {
  #share_modal .share-row a span, #event_view_modal .share-row a span {
    font-size: 18px;
  }
}

#event_view_modal .modal-body {
  padding: 0;
}
#event_view_modal .modal-body .view-row {
  padding-top: 4.2667vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row {
    padding-top: 1rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row {
    padding-top: 16px;
  }
}
#event_view_modal .modal-body .view-row .view-top {
  border-bottom: 1px solid #DEDEDE;
  padding: 8.5333vw 6.4vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row .view-top {
    padding: 2rem 1.5rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row .view-top {
    padding: 32px 24px;
  }
}
#event_view_modal .modal-body .view-row .view-top h3 {
  display: block;
  text-align: center;
  margin-bottom: 6.4vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row .view-top h3 {
    margin-bottom: 1.5rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row .view-top h3 {
    margin-bottom: 24px;
  }
}
#event_view_modal .modal-body .view-row .view-top p {
  text-align: center;
}
#event_view_modal .modal-body .view-row .view-bottom {
  line-height: 1.5;
  overflow-y: auto;
  height: 133.3333vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row .view-bottom {
    height: 31.25rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row .view-bottom {
    height: 500px;
  }
}
#event_view_modal .modal-body .view-row .view-bottom {
  padding: 8.5333vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row .view-bottom {
    padding: 2rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row .view-bottom {
    padding: 32px;
  }
}
#event_view_modal .modal-body .view-row .view-bottom img {
  max-width: 100%;
  margin: 4vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row .view-bottom img {
    margin: 0.9375rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row .view-bottom img {
    margin: 15px;
  }
}
#event_view_modal .modal-body .view-row .view-bottom p {
  line-height: 1.5;
  text-box-trim: unset;
  text-box-edge: unset;
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  #event_view_modal .modal-body .view-row .view-bottom p {
    font-size: 1.125rem;
  }
}
@media (min-width: 1200px) {
  #event_view_modal .modal-body .view-row .view-bottom p {
    font-size: 18px;
  }
}

.disabled {
  pointer-events: none;
  cursor: default !important;
  /*&::after {
      content: "COMING SOON";
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      background: rgba(0, 0, 0, 0.5);
      color: #fff;
      padding: 5px 10px;
      border-radius: 4px;
      font-size: 14px;
  }*/
}