@charset "utf-8";

* {
  box-sizing: border-box;
}
.main .tit-area {
  width: 100%;
  padding-bottom: 2rem;
  text-align: center;
}
.main .tit-area .secondary {
  font-weight: bold;
}
.main .tit-area h3 {
  font-size: 4.2rem;
  font-weight: bold;
  color: #111;
}

.box-shadow {
  box-shadow: 0 0 20px #ccc;
}

section {
  padding: 8rem 0;
}
.btn-area {
  width: 80%;
  margin: 0 auto;
}
.btn-area a {
  display: block;
  width: 100%;
  font-size: 3.6rem;
  padding: 2rem 0;
  background: #1960e7;
  border-radius: 10rem;
  text-align: center;
  font-weight: bold;
  color: #fff;
}
.btn-area a img {
  width: 30px;
  height: 30px;
  margin-right: 1rem;
}

#sec0 {
    background:url('../img/bg-sec0.png') center center no-repeat;
    background-size: cover;
    transition: 5s all;
    animation-name: move-bg 5s;
    padding-top: 10rem;
  color:#fff;
}

  #sec0 .m-txt-area{ text-align: center;}
  #sec0 .m-txt-area .txt-white {
  width:50rem;
  margin:3% auto;
}
#sec0 .btn-area{padding-top:5rem;}
#sec0 .m-txt-area .txt-white p {
  padding-bottom:1rem;
    font-size: 8rem;
  line-height:1.1;
}
#sec0 .m-txt-area p.hanel{color:#47d6ff}

#sec0 .m-txt-area .txt-impact{font-size:2.8rem;}
#sec0 .m-txt-area .line-round {
  display: inline-block;
  margin: 1rem auto;
  padding: 10px 30px 5px;
  /* border: 1px solid #fff; */
  border-radius: 50px;
  font-size: 2rem;
  text-align: center;
  background:rgba(0, 0, 0, 0.4);
  color:#eee;
}
#sec0 .m-img-area {
  position: relative;
  background: #1960e7;
  border-radius: 0 0 50% 50%;
  overflow: hidden;
}
#sec0 .m-img-area > .inner {
  position: relative;
}
#sec0 .m-img-area .txt-center {
  position: relative;
}
#sec0 .m-img-area .txt-center .human {
  display: block;
  position: relative;
  padding-top: 50%;
  background: url("../img/img-main.png") center 100% no-repeat;
  background-size: 40%;
  z-index: 10;
}
#sec0 .m-img-area .txt-center:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding-top: 30%;
  background: url("../img/bg-clean.png") center center no-repeat;
  background-size: contain;
  content: "";
}

#sec0 .m-img-area .round {
  position: absolute;
  padding: 1.2rem 5% 1rem;
  border-radius: 50px;
  font-size: 2rem;
  background: #fff;
  text-align: center;
  z-index: 1;
  animation: blink 3s infinite;
  transition: 1s all;
}


#sec0 .m-img-area .txt-left {
  left: 10%;
  animation-delay: 1s;
}
#sec0 .m-img-area .txt-left-bottom {
  left: 20%;
  top: 65%;
}
#sec0 .m-img-area .txt-right {
  right: 10%;
  top: 20%;
  animation-delay: 1.5s;
}

@keyframes blink {
  0% {
    opacity: 100%;
    scale: 1;
  }
  30% {
    opacity: 100%;
    background: #dde7ff;
  }
  40% {
    opacity: 80%;
    scale: 1.1;
  }
  70% {
    opacity: 100%;
    background: #dde7ff;
  }
  100% {
    opacity: 90%;
    scale: 1;
  }
}

#sec1 .cont-area li {
  width: 31%;
  margin: 1%;
}
#sec1 .cont-area li .box {
  box-shadow: 0px 0px 20px #ccc;
  border-radius: 1rem;
  padding: 2rem 4rem;
  height: 100%;
}
#sec1 .cont-area li .box .icon-area {
  width: 40%;
  padding-top: 40%;
  margin-left: 60%;
  background: url("../img/ico-sec1-1.png") center center no-repeat;
  background-size: 105%;
}
#sec1 .cont-area li:nth-child(2) .box .icon-area {
  background-image: url("../img/ico-sec1-2.png");
}
#sec1 .cont-area li:nth-child(3) .box .icon-area {
  background-image: url("../img/ico-sec1-3.png");
}
#sec1 .cont-area li:nth-child(4) .box .icon-area {
  background-image: url("../img/ico-sec1-4.png");
}
#sec1 .cont-area li:nth-child(5) .box .icon-area {
  background-image: url("../img/ico-sec1-5.png");
}
#sec1 .cont-area li:nth-child(6) .box .icon-area {
  background-image: url("../img/ico-sec1-6.png");
}
#sec1 .cont-area li:nth-child(7) .box .icon-area {
    background-image: url("../img/ico-sec1-7.png");
  }
  #sec1 .cont-area li:nth-child(8) .box .icon-area {
    background-image: url("../img/ico-sec1-8.png");
  }
#sec1 .cont-area li .box .primary {
  font-size: 4rem;
  font-weight: bold;
}
#sec1 .cont-area li .box p.bold {
  padding-top: 1rem;
  font-size: 2.8rem;
  color: #111;
}
#sec1 .cont-area li .box p.gray {
  font-size: 2rem;
}
#sec1 .call-area {
  width: 90%;
  margin: 2rem auto 0;
}
#sec1 .call-area > .flex {
  width: 80%;
  margin: 0 auto;
}
#sec1 .call-area .txt-area {
  width: 70%;
  font-size: 3rem;
}
#sec1 .call-area .img-area {
  width: 30%;
  padding-top: 28%;
  background: url("../img/img-sec1.png") left center no-repeat;
  background-size: contain;
}

#sec2 {
  background: #f5f5f5;
}
#sec2 .cont-area {
  position: relative;
  width: 80%;
  margin: 0 auto;
}
#sec2 .human-area {
  width: 50%;
  padding-top: 30%;
  background: url("../img/img-sec2.png") center center no-repeat;
  background-size: contain;
}
#sec2 .txt-round {
  display: flex;
}
#sec2 .txt-round p {
  display: inline-block;
  padding: 10px 40px;
  background: #fff;
  border-radius: 50px;
  font-size: 2rem;
}
#sec2 .txt-round.right {
  position: absolute;
  right: 0;
  margin-top: 10%;
  justify-content: end;
}
#sec2 .txt-round.right p {
  background: #dde7ff;
}

section#sec3 { padding: 0;}
#sec3 .black-area {
  padding: 1rem 0;
  font-size: 2.8rem;
  text-align: center;
  color: #fff;
  background:#1960e7;
}
#sec3 .black-area p{  line-height:1.2;}
#sec3 .bg-gray { padding: 8rem 0;}
#sec3 .bg-gray .box {
  width: 30%;
  margin: 1%;
  padding: 2% 1%;
  border-radius: 1rem;
  box-shadow: 0 0 20px #ccc;
  background: #fff;
  text-align: center;
  font-size: 2rem;
  color: #333;
}
#sec3 .bg-gray .box dl {
  height: 100%;
}
/* #sec3 .bg-gray .box dt .ico-box{width:50%; padding-top:50%; margin:0 auto; background: url('../img/ico-sec3-01.png') center center no-repeat; background-size:contain;}
#sec3 .bg-gray .box dt .ico-box.ico2{background-image: url('../img/ico-sec3-02.png');}
#sec3 .bg-gray .box dt .ico-box.ico3{background-image: url('../img/ico-sec3-03.png');}
#sec3 .bg-gray .box dt .ico-box.ico4{background-image: url('../img/ico-sec3-04.png');} */
#sec3 .bg-gray .box dt {
  padding: 1rem 0;
  font-size: 2.4rem;
  font-weight: bold;
  color: #222;
}
#sec3 .bg-gray .box dd {
  padding: 1rem 0;
  font-size: 1.8rem;
  color: #666;
}

/* #sec3 .map-area .map{width:100%; padding-top:45%; background: url('../img/bg-sec3-map.png') center center no-repeat; background-size:contain;} */
#sec3 .loca-area {
  padding: 8rem 0;
}
#sec3 .loca-area .map-area {
  background: url("../img/bg-sec3-gray.png") left bottom no-repeat;
  background-size: auto 70%;
}
#sec3 .loca-area .map-area .map {
  position: relative;
  width: 100%;
  padding-top: 45%;
  background: url("../img/bg-sec3-cont.png") center center no-repeat;
  background-size: contain;
}
#sec3 .loca-area .map-area .map .mcont {
  position: absolute;
  width: 13%;
  padding-top: 13%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  transition: 0.5s all !important;
  animation: blink-effect 5s ease-out infinite;
}
#sec3 .loca-area .map-area .map .car {
  left: 27%;
  bottom: 28%;
  background-image: url("../img/ico-loca-1.png");
}
#sec3 .loca-area .map-area .map .human1 {
  right: 50%;
  bottom: 50%;
  background-image: url("../img/ico-loca-2.png");
  animation-delay: 1s;
}
#sec3 .loca-area .map-area .map .human2 {
  left: 25%;
  bottom: 70%;
  background-image: url("../img/ico-loca-3.png");
  animation-delay: 2s;
}
#sec3 .loca-area .map-area .map .human3 {
  left: 60%;
  bottom: 70%;
  background-image: url("../img/ico-loca-4.png");
  animation-delay: 3s;
}
#sec3 .loca-area .map-area .map .human4 {
  left: 55%;
  bottom: 35%;
  background-image: url("../img/ico-loca-5.png");
  animation-delay: 4s;
}
@keyframes blink-effect {
  0% {
    opacity: 0;
  }
  21% {
    opacity: 100%;
  }
  24% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

#sec4 {
  border-top: 1px solid #eee;
}
#sec4 .swiper {
  width: 100%;
  height: 100%;
  min-height: 60rem;
  position: relative;
}
#sec4 .phoneSwiper {
  position: relative;
}
#sec4 .swiper-slide {
  padding: 4% 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec4 .tab-list {
  width: 40%;
  position: absolute;
  left: 43%;
  top: 35%;
  z-index: 10;
}
#sec4 .swiper-pagination-bullet {
  width: 52%;
  height: auto;
  background: #fff;
  box-shadow: 0 0 10px #aaa;
  opacity: 1;
  border-radius: 5px;
  display: block;
  line-height: 1;
  font-size: 2rem;
  text-align: center;
  padding: 14px;
  margin: 0.5rem 0;
  z-index: 1;
}
#sec4 .swiper-pagination-bullet-active {
  background: #1960e7;
  color: #fff;
}
.phone-cont {
  width: 25%;
  margin-right: 25%;
  padding: 4% 3%;
  background: url("../img/img-phone.png") center center no-repeat;
  background-size: 100% 100%;
}
.phone-cont .img-box {
  background: #f5f5f5;
  width: 100%;
  padding-top: 100%;
  position: relative;
  overflow: hidden;
}
.phone-cont .img-box img {
  width: 100%;
  min-height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.phone-cont dl {
  height: 22rem;
  overflow-y: scroll;
}
.phone-cont dl::-webkit-scrollbar {
  display: none;
}
.phone-cont dl {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.phone-cont dl dt {
  padding-bottom: 1rem;
}
.phone-cont dl dt .star {
  padding-top: 2rem;
  color: #ffdd00;
}
.phone-cont dl dt .name {
  font-size: 2rem;
}
.phone-cont dl dd {
  font-size: 1.6rem;
}
.phone-cont a {
  padding-top: 1.5rem;
  font-size: 1.6rem;
  color: #1960e7;
  padding-bottom: 1rem;
}


/*add review*/
#addreview {
    background: #f5f5f5;
  }
  
  #addreview .inner{  overflow: hidden;}
  #addreview .swiper2 {
    height:300px;
    margin:10px 0;
  }
  #addreview .swiper2 {
    position: relative;
  }
  #addreview .swiper-slide {
    padding: 2% 0;
    display: flex;
  }
  
  /* swiper-slide 기본 스타일 */
  #addreview .swiper-slide {
    background-color: white; /* 하얀색 배경 */
    border-radius: 10px; /* 둥근 모서리 */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* 연한 그림자 */
    transition: box-shadow 0.3s ease-in-out; /* 마우스 오버 시 효과 */
  }
  
  /* hover 시 그림자 효과 */
  #addreview .swiper-slide:hover {
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2); /* 마우스를 올렸을 때 그림자 강화 */
  }
  
  /* 리뷰 내용 스타일 */
  #addreview .review-cont-white {
    padding: 15px; /* 리뷰 내용 여백 */
    border-radius: 10px; /* 둥근 모서리 */
    background-color: white; /* 배경 하얀색 */
  }
  
  /* 별점 (★★★★★) 스타일 */
  #addreview .star {
    color: #f5a623; /* 별색을 노란색으로 */
    font-size: 16px;
    margin: 5px 0;
  }
  
  /* 리뷰 닉네임 스타일 */
  #addreview .review-cont-nick {
    font-weight: bold;
    font-size: 20px;
    color: #333; /* 닉네임 색상 */
    margin-bottom: 5px;
  }
  
  /* 리뷰 내용 텍스트 스타일 */
  #addreview .review-cont-txt {
    font-size: 14px;
    color: #666; /* 텍스트 색상 */
    line-height: 1.5;
    margin-bottom: 10px;
  }
  
  /* 네이버 / 당근 후기 링크 스타일 */
  #addreview .review-cont-link a {
    font-size: 14px;
    text-decoration: none;
    display: inline-block;
    margin-top: 10px;
    font-weight: normal; /* 기본 링크 두께 */
    transition: font-weight 0.2s ease; /* 두께 변화 애니메이션 */
  }
  
  /* 링크 hover 시 색상 및 두께 변경 */
  #addreview .review-cont-link a:hover {
    color: #005fa3; /* 링크 hover 색상 */
    font-weight: bold; /* 링크 hover 시 두꺼워짐 */
  }

#sec5 {
  background: #dde7ff;
}
#sec5 .cont-area .event-cont {
  width: 50%;
  border-radius: 20px;
  text-align: center;
}
#sec5 .cont-area .event-cont .coupon-area {
  background: url("../img/img-coupon.png") center center no-repeat;
  background-size: contain;
  padding: 10% 3%;
  border-radius: 5px;
}
#sec5 .cont-area .event-cont .icon-area {
  margin-bottom: 1rem;
  background: url("../img/logo-naver.png") center center no-repeat;
  width: 20%;
  padding-top: 20%;
  background-size: contain;
}
#sec5 .cont-area .event-cont.event-carrot .icon-area {
  background-image: url("../img/logo-dangg.png");
}
#sec5 .cont-area .event-cont dl dt {
  font-weight: bold;
  font-size: 2.8rem;
  color: #333;
}
#sec5 .cont-area .event-cont dl dd {
  padding-top: 2rem;
}
#sec5 .cont-area .event-cont .txt-area {
  padding-left: 10%;
  text-align: left;
}
#sec5 .cont-area .event-cont .txt-area ul.list li {
  position: relative;
}
#sec5 .cont-area .event-cont .txt-area ul.list li:before {
  position: absolute;
  top: 0%;
  left: -1rem;
  width: 5px;
  content: "-";
}
#sec6{background:url('../img/bg-sec6.png') left top no-repeat; background-size: contain; }
#sec6 .txt-area {
  padding: 2rem 0 1rem;
  text-align: center;
  font-size: 2rem;
}
#sec6 .btn-area {
  width: 50%;
  text-align: center;
}
#sec6 .btn-area a.btn {
  margin-bottom: 1rem;
  background: #f7b633;
  color: #fff;
}

@media screen and (max-width: 1240px) {
  .main .tit-area h3 {
    font-size: 4.4rem;
  }
  .btn-area a {
    font-size: 2.8rem;
  }

  #sec1 .cont-area li .box {
    padding: 2rem;
  }
  #sec1 .cont-area li .box .primary {
    font-size: 3.2rem;
  }
  #sec1 .cont-area li .box p.bold {
    font-size: 2.2rem;
    line-height: 1.2;
  }
  #sec1 .call-area .txt-area {
    font-size: 2.4rem;
  }

  #sec3 .loca-area .map-area .map {
    padding-top: 55%;
  }

  .phone-cont {
    width: 33%;
    margin-right: 33%;
  }
  #sec4 .tab-list {
    width: 50%;
    left: 40%;
  }
}

@media screen and (max-width: 1024px) {
  section {
    padding: 6rem 0;
  }
  .btn-area {
    width: 90%;
  }
  .main .tit-area h3 {
    font-size: 2.8rem;
  }

  #sec1 .cont-area li {
    width: 48%;
  }
  #sec1 .call-area .txt-area {
    font-size: 2rem;
  }

  #sec3 .loca-area .map-area {
    background: none;
  }
  #sec3 .loca-area .map-area .map {
    padding-top: 70%;
  }
  #sec3 .loca-area .map-area .map .mcont {
    width: 17%;
    padding-top: 17%;
  }
  #sec3 .loca-area .map-area .map .car {
    left: 18%;
  }
  #sec3 .loca-area .map-area .map .human2 {
    left: 16%;
  }
  #sec3 .loca-area .map-area .map .human3 {
    left: 70%;
  }
  #sec3 .loca-area .map-area .map .human4 {
    left: 65%;
  }
  #sec3 .bg-gray .box dt {
    font-size: 2rem;
  }
  #sec3 .bg-gray .box dd {
    padding: 0;
    font-size:1.6rem;
  }

  #sec4 .tab-list {
    width: 50%;
  }
  #sec4 .swiper-slide {
    padding: 0;
    top: 10%;
  }
  .phone-cont {
    width: 30%;
    margin-right: 30%;
  }
}

@media screen and (max-width: 900px) {
  #sec4 .tab-list {
    width: 60%;
  }
  .phone-cont {
    width: 40%;
    margin-right: 40%;
    padding: 6% 4%;
  }
  .phone-cont dl dt .star {
    padding-top: 1rem;
  }

  #sec3 .btn-area,
  #sec3 .btn-area a.btn {
    width: 100%;
  }
}

@media screen and (max-width: 740px) {
  .main .tit-area h3 {
    font-size: 2.8rem;
  }
  .main .btn-area {
    width: 100%;
  }
  .main section {
    padding: 6rem 0;
  }
  #sec0 .m-txt-area .line-round{font-size:1.6rem;}
  #sec0 .m-txt-area .txt-white {
    width:70%;
    min-width:26rem;
    margin:5% auto;
  }
  #sec0 .m-txt-area .txt-white p {
    font-size: 5.2rem;
  }
  #sec0 .m-img-area .round {
    font-size: 1.6rem;
  }
  #sec0 .m-txt-area .txt-impact{font-size:1.6rem;}
  #sec0 .m-img-area .txt-center .human {
    padding-top: 65%;
    background-size: 50%;
  }

  #sec1 .cont-area li .box {
    padding: 1rem 1rem;
  }
  #sec1 .cont-area li .box .primary {
    font-size: 2rem;
  }
  #sec1 .cont-area li .box p.bold {
    font-size: 1.6rem;
  }
  #sec1 .cont-area li .box p.gray {
    font-size: 1.4rem;
  }
  #sec1 .call-area > .flex {
    width: 100%;
    padding-top: 3rem;
    flex-direction: column-reverse;
  }
  #sec1 .call-area .img-area {
    width: 100%;
    padding-top: 62%;
    background-position: center bottom;
  }
  #sec1 .call-area .txt-area {
    width: 100%;
    font-size: 1.6rem;
  }
  /* #sec1 .cont-area li{width:98%; margin:3% 1%}
  #sec1 .cont-area li .box .icon-area{padding-top:36%;}
 */

  #sec2 .txt-round.right {
    position: relative;
    margin-top: 3%;
  }
  #sec2 .human-area {
    width: 70%;
    padding-top: 60%;
  }

  #sec3 .bg-gray {
    background: #f5f5f5;
    padding: 6rem 0;
  }
  #sec3 .bg-gray .tit-area h3 {
    text-align: left;
    line-height: 1.2;
  }
  #sec3 .bg-gray .inner > .flex {
    flex-wrap: wrap;
  }
  #sec3 .bg-gray .inner > .flex .box {
    width: 48%;
    margin: 2% 1%;
    padding:3% 1%;
  }
  #sec3 .bg-gray .inner > .flex .box:last-child{width:100%;}
  #sec3 .bg-gray .inner > .flex .box:last-child .br{display:none;}
  #sec3 .bg-gray .box dt{font-size:1.9rem;}
  #sec3 .loca-area .map-area .map {
    padding-top: 80%;
  }
  #sec3 .loca-area .map-area .map .mcont {
    width: 25%;
    padding-top: 25%;
  }
  #sec3 .loca-area .map-area .map .car {
    left: 6%;
    bottom: 15%;
  }
  #sec3 .loca-area .map-area .map .human1 {
    right: 40%;
  }
  #sec3 .loca-area .map-area .map .human2 {
    left: 7%;
    bottom: 73%;
  }
  #sec3 .loca-area .map-area .map .human3 {
    left: 69%;
    bottom: 65%;
  }
  #sec3 .loca-area .map-area .map .human4 {
    left: 66%;
    bottom: 20%;
  }

  #sec4 .phoneSwiper {
    display: flex;
    flex-direction: column;
  }
  #sec4 .tab-list {
    position: relative;
    width: 100%;
    top: 0;
    left: 0;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: space-between;
    margin-bottom: 1rem;
  }
  #sec4 .tab-list p {
    width: 48%;
    margin: 1%;
    font-size: 1.6rem;
    position: relative;
  }
  .phone-cont {
    width: 50%;
    margin-right: 0;
    padding: 4% 6%;
    padding-top: 5rem;
  }

  #sec5 .cont-area .event-cont .icon-area {
    width: 30%;
    padding-top: 30%;
  }
  #sec5 .cont-area > .flex {
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  #sec5 .cont-area .event-cont {
    width: 100%;
    margin: 0 auto 1rem;
  }
  #sec5 .cont-area .event-cont .txt-area{padding-left:1rem;}

  #sec6{background-position:left bottom; background-size:100% auto;}
  #sec6 .btn-area{width:100%;}

  
  #addreview .swiper2 {height:auto;}
}

@media screen and (max-width: 540px) {
  body {
    min-width: 360px;
  }
  #sec0 .m-txt-area .txt-white p {
    font-size: 4rem;
  }

  #sec4 .swiper-pagination-bullet {
    padding: 1rem;
  }
  .phone-cont {
    width: 75%;
    padding: 8% 9%;
    padding-top: 5rem;
    margin-top: 1rem;
  }
  #sec5 .cont-area .event-cont .coupon-area{padding:10% 12%;}
}
