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

li {
  list-style: none;
}

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

img {
  vertical-align: top;
  max-width: 100%;
  filter: none;
}

button {
  background-color: inherit;
  cursor: pointer;
  font-family: "Noto Sans KR", sans-serif;
  color: #000;
}

html, body {
  font-family: "Noto Sans KR", sans-serif;
  color: #000;
  overflow-x: hidden;
  max-width: 480px;
  width: 100%;
  margin: 0 auto;
  letter-spacing: -1px;
}

input, select, textarea {
  font-family: "Noto Sans KR", sans-serif;
  color: #000;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 2px;
}

.top_contents {
  position: relative;
  width: 100%;
  height: 430px;
}
.top_contents .logo {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 150px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 11;
}
.top_contents .logo img {
  width: 55%;
  max-height: 50px;
  object-fit: contain;
}
.top_contents .back_bg {
  width: 100%;
  height: 100%;
}
.top_contents .back_bg .back_img {
  width: 100%;
  height: 100%;
}
.top_contents .back_bg .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  opacity: 0.25;
}

.right_fix, .left_fix, .left_fix01 {
  position: absolute;
  bottom: 20px;
  right: 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  z-index: 20;
}
.right_fix a, .left_fix a, .left_fix01 a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
}
.right_fix a img, .left_fix a img, .left_fix01 a img {
  width: 25px;
}
.right_fix a p, .left_fix a p, .left_fix01 a p {
  font-size: 10px;
  color: #fff;
}

.information {
  width: 100%;
  padding: 60px 0;
}
.information > h2 {
  font-size: 20px;
  line-height: 20px;
  text-align: center;
  margin-bottom: 25px;
}
.information .contents {
  display: flex;
  max-width: 300px;
  width: 100%;
  margin: 10px auto 0;
}
.information .contents:first-child {
  margin: 0 auto;
}
.information .contents h2 {
  font-size: 12px;
  line-height: 16px;
  width: 80px;
}
.information .contents > a {
  font-size: 12px;
  line-height: 16px;
  word-break: break-all;
  width: calc(100% - 80px);
}
.information .contents div {
  display: flex;
  gap: 10px;
  width: calc(100% - 80px);
}
.information .contents div a,
.information .contents div p {
  position: relative;
  font-size: 12px;
  line-height: 16px;
  word-break: break-all;
  width: 100%;
}
.information .contents div a::before,
.information .contents div p::before {
  content: "/";
  position: absolute;
  top: 1px;
  left: -7px;
  font-size: 12px;
  line-height: 16px;
}
.information .contents div a:first-child::before,
.information .contents div p:first-child::before {
  display: none;
}

.reference {
  position: relative;
  width: 100%;
  padding: 60px 0;
}
.reference h2 {
  font-size: 20px;
  line-height: 20px;
  text-align: center;
  margin-bottom: 25px;
}
.reference .prev_btn,
.reference .next_btn {
  position: absolute;
  top: 53%;
  transform: translateY(-50%);
  width: 20px;
}
.reference .prev_btn {
  left: 0;
  width: 0;
  height: 0;
  border-bottom: 15px solid transparent;
  border-top: 15px solid transparent;
  border-left: 25px solid transparent;
}
.reference .next_btn {
  right: 0;
  width: 0;
  height: 0;
  border-bottom: 15px solid transparent;
  border-top: 15px solid transparent;
  border-right: 25px solid transparent;
}

.gallery {
  width: 100%;
  padding: 60px 0 110px;
}
.gallery h2 {
  font-size: 20px;
  line-height: 20px;
  text-align: center;
  margin-bottom: 25px;
}
.gallery .contents {
  max-width: 343px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 11px;
}
.gallery .contents img {
  width: 107px;
  height: 107px;
  object-fit: cover;
  cursor: pointer;
}

.gal_bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  opacity: 0.4;
  z-index: 101;
  display: none;
}

.gal_pop {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 343px;
  height: 343px;
  border-radius: 20px;
  background-color: #fff;
  z-index: 102;
  display: none;
}
.gal_pop img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  height: 90%;
  object-fit: cover;
}
.gal_pop .close {
  position: absolute;
  top: -50px;
  right: 0;
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 50%;
  cursor: pointer;
}
.gal_pop .close span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 25px;
  height: 3px;
  border-radius: 3px;
  background-color: #000;
}
.gal_pop .close span:first-child {
  transform: translate(-50%, -50%) rotate(45deg);
}
.gal_pop .close span:last-child {
  transform: translate(-50%, -50%) rotate(-45deg);
}

footer,
.footer {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  max-width: 480px;
  width: 100%;
  box-shadow: 0px -5px 10px rgba(0, 0, 0, 0.2);
  z-index: 100;
  padding: 10px 0;
}
footer .inner,
.footer .inner {
  width: 100%;
  height: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
footer .inner a,
.footer .inner a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
}
footer > a,
.footer > a {
  display: block;
  font-size: 10px;
  line-height: 12px;
  text-align: center;
  margin-top: 5px;
}
footer .visitor,
.footer .visitor {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 10px;
  line-height: 12px;
  gap: 10px;
  margin-top: 5px;
}

.example01_top_contents {
  height: 450px;
}

.swiper_inner .top_slide_01 {
  position: relative;
  width: 100%;
  position: absolute;
  bottom: 0;
  height: 375px;
}
.swiper_inner .top_slide_01 .swiper-slide {
  width: 100%;
}
.swiper_inner .top_slide_01 .swiper-slide div {
  max-width: 210px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  height: 375px;
}
.swiper_inner .top_slide_01 .swiper-slide div p {
  font-size: 16px;
  line-height: 19px;
  position: absolute;
  top: 20px;
  left: 0;
  word-break: keep-all;
}
.swiper_inner .top_slide_01 .swiper-slide div img {
  display: block;
  height: 280px;
  position: absolute;
  right: -40px;
  bottom: 0;
}
.swiper_inner .top_slide_01 .swiper-pagination {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 15;
  display: flex;
  align-items: center;
}
.swiper_inner .top_slide_01 .swiper-pagination-bullet {
  width: 6px;
  height: 6px;
  border: 1px solid #000;
  background-color: transparent;
  margin: 0 2px;
  opacity: 1;
}
.swiper_inner .top_slide_01 .swiper-pagination-bullet:last-child {
  margin-right: 0;
}
.swiper_inner .top_slide_01 .swiper-pagination-bullet-active {
  background-color: #000;
  width: 6px;
  height: 6px;
}

.left_fix, .left_fix01 {
  left: 16px;
  right: auto;
}

.left_fix01 {
  bottom: auto;
  top: 50%;
  transform: translateY(-50%);
  z-index: 15;
}

.refer_slide_01 {
  width: 240px;
  margin: 0 auto;
}
.refer_slide_01 .swiper-slide {
  position: relative;
  width: 100%;
}
.refer_slide_01 .swiper-slide > img {
  width: 100%;
  height: 430px;
  object-fit: cover;
}
.refer_slide_01 .swiper-slide p {
  font-size: 12px;
  text-align: center;
  margin: 10px auto;
}
.refer_slide_01 .swiper-slide a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 130px;
  height: 40px;
  border-radius: 40px;
  margin: 0 auto;
}
.refer_slide_01 .swiper-slide a img {
  height: 20px;
}
.refer_slide_01 .swiper-slide a span {
  font-size: 10px;
  position: relative;
  top: -1px;
}

.reference01 > .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  opacity: 0.3;
}
.reference01 .prev_btn, .reference01 .next_btn {
  position: absolute;
  top: 48%;
  transform: translateY(-50%);
  width: 20px;
}

.information01 {
  width: 100%;
  padding: 60px 0;
}
.information01 > h2 {
  font-size: 20px;
  line-height: 20px;
  margin-bottom: 25px;
  padding: 0 16px;
}
.information01 .contents {
  display: flex;
  max-width: 300px;
  width: 100%;
  margin: 10px auto 0;
}
.information01 .contents:first-child {
  margin: 0 auto;
}
.information01 .contents h2 {
  font-size: 12px;
  line-height: 16px;
  width: 80px;
}
.information01 .contents a {
  font-size: 12px;
  line-height: 16px;
  word-break: keep-all;
}
.information01 .contents div {
  display: flex;
  gap: 10px;
}
.information01 .contents div a {
  position: relative;
}
.information01 .contents div a::before {
  content: "/";
  position: absolute;
  top: 1px;
  left: -7px;
  font-size: 12px;
  line-height: 16px;
}
.information01 .contents div a:first-child::before {
  display: none;
}
.information01 .contents p {
  font-size: 12px;
  line-height: 16px;
  word-break: keep-all;
  width: calc(100% - 80px);
}
.information01 .contents div {
  display: flex;
  gap: 10px;
}
.information01 .contents div p {
  position: relative;
}
.information01 .contents div p::before {
  content: "/";
  position: absolute;
  top: 1px;
  left: -7px;
  font-size: 12px;
  line-height: 16px;
}
.information01 .contents div p:first-child::before {
  display: none;
}
.information01 .contents01 {
  max-width: 100%;
  padding: 0 16px;
}

.gallery01 {
  padding: 0 0 118px;
}
.gallery01 .contents {
  max-width: 100%;
  gap: 0;
}
.gallery01 .contents img {
  width: 33.33%;
  height: auto;
}

/*# sourceMappingURL=style01.css.map */
