div {
  box-sizing: border-box;
}

@font-face {
  src: url("fonts/icons.woff") format("woff");
  font-family: "Icons";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-decoration: inherit;
  text-transform: none;
}
.visual {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 10vw;
  border-bottom: 1px solid #e0e0e0;
}
.visual .inner .header {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  row-gap: 1.8vw;
}
.visual .inner .header h3 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 3vw;
  width: -moz-fit-content;
  width: fit-content;
  font-family: "KTB";
  font-weight: 700;
  font-size: 6vw;
  color: #000;
}
.visual .inner .header h3 span {
  position: absolute;
  top: 0;
  right: -8vw;
  width: 6.5vw;
  height: 6.5vw;
  background-image: url("/static/images/mobile/btn_share.jpg");
  background-repeat: no-repeat;
  background-size: contain;
}
.visual .inner .header p {
  font-size: 3.45vw;
  color: #222;
}

.tabCont {
  display: flex;
  align-items: center;
  -moz-column-gap: 4vw;
       column-gap: 4vw;
  padding: 0 4.0625vw;
  border-bottom: 1px solid #e0e0e0;
}
.tabCont li {
  flex-grow: 1;
  display: flex;
  align-items: center;
  width: 100%;
  height: 12vw;
}
.tabCont li button {
  position: relative;
  width: 100%;
  height: 100%;
  font-size: 3.67vw;
  color: #666;
  line-height: 1.2;
  word-break: keep-all;
}
.tabCont li button.current {
  font-weight: 500;
  font-size: 3.67vw;
  color: #d71826;
}
.tabCont li button.current:after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2.5px;
  background-color: #d71826;
}
.tabCont.info button.current {
  color: #00a69e;
}
.tabCont.info button.current:after {
  background-color: #00a69e;
}

.tabChild {
  display: none;
}
.tabChild.current {
  display: block;
}

.invisible {
  position: absolute;
  left: -1000%;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

ul.sns {
  position: absolute;
  top: 10vw;
  left: -50%;
  z-index: 5;
  display: none;
  padding: 3vw 2vw;
  border: 1px solid #bfbfbf;
  background-color: #fff;
}
ul.sns:before {
  position: absolute;
  top: -9px;
  left: calc(50% - 6px);
  z-index: 5;
  content: "";
  display: block;
  width: 12px;
  height: 9px;
  background-image: url("/static/images/mobile/arrow-sns.jpg");
  background-repeat: no-repeat;
  background-size: contain;
}
ul.sns li + li {
  margin-top: 2.3vw;
}
ul.sns li button {
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 0.5vw;
  font-weight: 700;
  font-size: 2.8vw;
  color: #666;
  text-align: center;
  letter-spacing: -0.15vw;
}
ul.sns li button:before {
  content: "";
  display: block;
  width: 10vw;
  height: 10vw;
  background-repeat: no-repeat;
  background-size: contain;
}
ul.sns li.kakao button:before {
  background-image: url("/static/images/mobile/btn_kakao.jpg");
}
ul.sns li.facebook button:before {
  background-image: url("/static/images/mobile/btn_fb.jpg");
}
ul.sns li.x button:before {
  background-image: url("/static/images/mobile/btn_twitter.jpg");
}
ul.sns li.line button:before {
  background-image: url("/static/images/mobile/btn_line.jpg");
}

.cont {
  padding: 8vw 3vw;
}
.cont.view {
  padding: 0;
}
.cont .list + .list {
  margin-top: 8vw;
}
.cont .list dd {
  margin-top: 3vw;
}/*# sourceMappingURL=benefit.css.map */