/* A            A A                 :                   A                   :                   A                   :                   A                   :                   */
#dhnco_sub10-2-1 {
  width: 100%;
  height: auto;
  text-align: center;
}

input[type="radio"] {
  -webkit-appearance: none;
  /* 사파리 */
  -moz-appearance: none;
  /* 파이어폭스 */
  appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid gray;
  border-radius: 50%;
  outline: none;
  cursor: pointer;
  position: relative;
  margin-right: 10px;
  vertical-align: middle;
  transition: all 0.3s;
}

/* 클릭된 상태 원 안 색상 채우기 */
input[type="radio"]:checked {
  background-color: #359993;
  border-color: #359993;
}

/* 내부 점 만들기 (옵션) */
input[type="radio"]:checked::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background: white;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#dhnco_sub10-2-2 {
  width: 100%;
  height: auto;
  text-align: center;
}

.logoBox {
  width: 100%;
  height: auto;
}

.logoBox img {
  width: clamp(35px, 10vw, 65px);
  height: auto;
}

.sectionTit {
  width: auto;
  height: auto;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  margin-top: clamp(3px, 1vw, 8px);
  margin-bottom: 10px;
  padding: 0 20px;
}

.dhncoSub .sectionTit.noMargin {
  display: flex;
}

.dhncoSub .sectionTit.noMargin .underLine {
  width: clamp(40px, 5vw, 90px);
  height: clamp(4px, 1vw, 6px);
  background: #31a09b;
}

.sectionTit p {
  font-size: clamp(23px, 2vw, 36px);
  font-weight: 700;
  color: #31a09b80;
  line-height: 2.1em;
}

.sectionTit .titB {
  font-size: clamp(20px, 2vw, 29px);
  font-weight: 700;
  color: #31a09b;
  line-height: 1em;
  margin: 0.7em 0;
}

.titC {
  font-size: 11px;
  font-weight: 700;
  color: #bbb;
  line-height: 1em;
  margin: 10px 0;
}

.sectionTit .underLine {
  width: 50%;
  height: clamp(4px, 1vw, 6px);
  background: #31a09b;
}

.sectionMainImgWrap {
  width: 100%;
  height: auto;
  display: flex;
  align-items: stretch;
  max-width: 1400px;
  margin: 0 auto;
  padding: clamp(40px, 8vw, 80px) 0px;
}

.sectionMainImgWrap .imgBox {
  width: 40%;
  height: auto;
}

.sectionMainImgWrap .imgBox img {
  width: 100%;
  height: auto;
}

.sectionMainImgWrap .textBox {
  width: 60%;
  height: auto;
  background: #F7F7F7;
  text-align: left;
  display: flex;
  align-content: center;
  flex-wrap: wrap;
  padding: clamp(20px, 3vw, 30px) clamp(20px, 3vw, 50px);
}

.sectionMainImgWrap .textBox .tit {
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 500;
  word-break: keep-all;
  line-height: 1em;
}

.sectionMainImgWrap .textBox .text {
  font-size: clamp(14px, 1.5vw, 18px);
  word-break: keep-all;
  margin: clamp(15px, 2vw, 25px) 0;
}

.sectionMainImgWrap .textBox .ps {
  width: auto;
  height: auto;
  display: inline-block;
  background: #31A09B;
  font-size: clamp(14px, 1.5vw, 18px);
  color: #fff;
  line-height: 1em;
  padding: 0.4em 1.2em;
  word-break: keep-all;
}

.grayBackWrap {
  width: 100%;
  height: auto;
  background: #EEEFEF;
  padding: clamp(40px, 8vw, 80px) 8px;
}

.whiteBackWrap {
  width: 100%;
  height: auto;
  background: #fff;
  padding: clamp(40px, 8vw, 80px) 8px;
}

.contentWrap {
  width: 100%;
  height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.contentWrap .tit {
  font-size: clamp(16px, 2vw, 24px);
  font-weight: 500;
  color: #fff;
  background: #31A09B;
  display: inline-block;
  line-height: 1em;
  padding: 0.5em 1em;
  word-break: keep-all;
}

.contentWrap .listBox {
  width: auto;
  height: auto;
  display: inline-flex;
  border: 1px solid #31A09B;
  padding: clamp(15px, 3vw, 25px) clamp(30px, 3vw, 50px);
  margin: 0 auto;
  flex-wrap: wrap;
  justify-content: center;
}

.contentWrap .listBox:last-child {
  max-width: 945px;
}

.contentWrap .listBox .pWrap {
  width: auto;
  display: inline-block;
  text-align: left;
}

.contentWrap .listBox .pWrap:first-child {
  margin-right: clamp(25px, 2vw, 38px);
}

.contentWrap .listBox .pWrap.noMargin {
  margin-right: 0;
}

.contentWrap .listBox .pWrap p {
  font-size: clamp(14px, 2vw, 18px);
  word-break: keep-all;
}

.contentWrap .listBox .pWrap p span {
  font-size: clamp(14px, 2vw, 18px);
  word-break: keep-all;
  color: red;
  font-weight: bold;
}

.contentWrap .listBox .pWrap .greenFont {
  color: #31A09B;
  font-weight: bold;
}

.thirdWrap {
  width: 100%;
  height: auto;
  padding: clamp(40px, 8vw, 80px) 20px;
}

.thirdWrap .contentWrap {
  width: 100%;
  height: auto;
  margin-top: clamp(20px, 3vw, 30px);
}

.thirdWrap .contentWrap .contentBox {
  width: 100%;
  height: auto;
  max-width: 1200px;
  display: inline-block;
  border-top: 2px solid #999;
  border-bottom: 2px solid #999;
}

.thirdWrap .contentWrap .contentBox .listWrap {
  width: 100%;
  height: auto;
  border-bottom: 1px solid #C9C9CA;
  padding: clamp(15px, 2vw, 25px) 0;
}

.thirdWrap .contentWrap .contentBox .listWrap:last-child {
  border-bottom: 0;
}

.thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: center;
  max-width: 740px;
  margin: 0 auto;
}

.thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .nameBox {
  width: clamp(280px, 19vw, 310px);
  height: auto;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .nameBox img {
  width: clamp(35px, 5vw, 55px);
  height: auto;
  margin-right: clamp(10px, 2vw, 15px);
}

.thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .nameBox p {
  font-size: clamp(15px, 2vw, 21px);
  color: #31A09B;
}

.thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .textWrap {
  width: auto;
  display: flex;
  align-items: center;
  flex-grow: 1;
}

.thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .textWrap p {
  font-size: clamp(14px, 2vw, 20px);
  word-break: keep-all;
  text-align: left;
}

.tableWrap {
  width: 100%;
  height: auto;
  margin-top: clamp(20px, 9vw, 20px);
  /* overflow-x: scroll; */
}

.tableWrap::-webkit-scrollbar {
  height: 8px;
}

.tableWrap::-webkit-scrollbar-thumb {
  background: #d3d3d3;
  border-radius: 5px;
}

.tableWrap::-webkit-scrollbar-thumb:hover {
  background: #b5b5b5;
}

.result_table {
  width: 600px;
  height: auto;
  display: inline-block;
  margin-bottom: 10px;
  border: 1px solid #bbb;
  border-bottom: none;
}

.table {
  width: 600px;
  height: auto;
  display: inline-block;
  margin-bottom: 10px;
  border: 1px solid #bbb;
  border-bottom: none;
}

.btnWrap {
  margin-top: 10px;
  text-align: end;
  width: 600px;
  display: inline-block;
}

.btnWrap p {
  text-align: left;
  font-size: clamp(14px, 2vw, 16px);
  color: #666;
}

.btnWrap p strong {
  text-align: left;
  font-size: clamp(14px, 2vw, 16px);
  color: #666;
}

.tableTitWrap {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: flex-end;
  align-items: stretch;
  text-align: center;
}

.tableTit {
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid #bbb;
  padding: 10px 0;
  background: #359993;
}

.tableTit:last-child {
  margin-right: 0;
  border-right: none;
}

.tableTit.black {
  background: #323333;
}

.tableTit p {
  font-size: clamp(14px, 2vw, 16px);
  font-weight: 500;
  color: #fff;
  text-align: center;
}

.tableTit.tableTit_1 {
  width: 40%;
}

.tableTit.tableTit_2 {
  width: 60%;
}

.tableTit.tableTit_3 {
  width: 36%;
  display: table-cell;
  padding: 0;
}

.tableTit.tableTit_3 .top {
  border-bottom: 1px solid #bbb;
  padding: 5px;
}

.tableTit.tableTit_3 .bottom {
  display: flex;
}

.tableTit.tableTit_3 .bottom .sub {
  flex: 1;
  border-right: 1px solid #bbb;
  padding: 5px;
}

.tableTit.tableTit_3 .bottom .sub:last-child {
  border-right: none;
}

.tableTit.tableTit_4 {
  width: 25%;
}

.tableTit.tableTit_35 {
  width: 35%;
}

.tableTit.tableTit_40 {
  width: 40%;
}

.tableTit.tableTit_30 {
  width: 30%;
}

.tableTit.tableTit_7 {
  width: 33%;
}

.tableTit.tableTit_10 {
  width: 16%;
}

.tableTit.tableTit_11 {
  width: 20%;
}

.tableTit.tableTit_half {
  width: 50%;
}

.tableValueWrap {
  width: 100%;
  height: auto;
  display: flex;
  /* flex */
  justify-content: flex-end;
  align-items: stretch;
  text-align: center;
}

.tableValue {
  display: flex;
  /* flex */
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  background: #FFFFFF;
  border-right: 1px solid #bbb;
  border-bottom: 1px solid #bbb;
}

.tableValue input.cala_input {
  width: 80%;
  height: clamp(20px, 2vw, 30px);
  font-size: clamp(14px, 2vw, 16px);
  color: #000;
  margin-left: clamp(4px, 2vw, 6px);
  text-align: end;
  border: 2px solid #359993;
  border-radius: 5px;
  padding-left: clamp(5px, 2vw, 8px);
}

.tableValue input.date_input {
  width: 80%;
  height: clamp(20px, 2vw, 30px);
  font-size: clamp(14px, 2vw, 16px);
  color: #000;
  margin-left: clamp(4px, 2vw, 6px);
  text-align: end;
  border: none;
  padding-left: clamp(5px, 2vw, 8px);
}

.tableValue:last-child {
  margin-right: 0;
  border-right: none;
}

.tableValue p {
  font-size: clamp(14px, 2vw, 16px);
  font-weight: 500;
  color: #666;
  text-align: center;
  padding: 0;
}

.tableValue p span.icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-left: 6px;
  border-radius: 50%;
  background-color: #359993;
  color: #FFFFFF;
  font-size: 12px;
  font-weight: bold;
  cursor: pointer;
  line-height: 1;
}

.tableValue.tableValue_1,
.tableValue.tableValue_40 {
  position: relative;
  /* popover 위치 기준 */
  display: inline-block;
}

.tableValue.tableValue_1 .popover,
.tableValue.tableValue_40 .popover {
  position: absolute;
  top: 50%;
  right: 120%;
  /* 아이콘 오른쪽 */
  transform: translateY(-50%);
  border: 2px solid #359993;
  background: #359993;
  color: #FFFFFF;
  padding: 8px 12px;
  border-radius: 5px;
  white-space: nowrap;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.2s ease;
  height: auto;
  z-index: 10;
}

.tableValue.tableValue_1:hover .popover,
.tableValue.tableValue_40:hover .popover {
  visibility: visible;
  opacity: 1;
}

.tableValue p.bold {
  font-weight: 700;
  color: #000000;
}

.tableValue label {
  font-size: 16px;
  color: #666;
}

.tableValue .radioArea {
  width: 80%;
  display: flex;
  justify-content: end;
}

.tableValue p.error_bold {
  font-weight: 700;
  color: #cc5c5c;
}

.tableValue p.total {
  font-weight: 700;
  color: #359993;
  margin-left: auto;
  margin-right: 20px;
  text-align: end;
  padding-right: 10px;
}

.tableValue p.error {
  font-weight: 700;
  color: #cc5c5c;
  margin-left: auto;
  margin-right: 20px;
}

.tableValue.tableValue_1 {
  width: 40%;
}

.tableValue.tableValue_2 {
  width: 60%;
}

.tableValue.tableValue_3 {
  width: 18%;
}

.tableValue.tableValue_4 {
  width: 18%;
}

.tableValue.tableValue_5 {
  width: 25%;
}

.tableValue.tableValue_7 {
  width: 33%;
}

.tableValue.tableValue_10 {
  width: 16%;
}

.tableValue.tableValue_11 {
  width: 20%;
}

.tableValue.tableValue_35 {
  width: 35%;
}

.tableValue.tableValue_40 {
  width: 40%;
}

.tableValue.tableValue_30 {
  width: 30%;
}

.tableValue.tableValue_half {
  width: 50%;
}

.tableValue.tableValue_all {
  width: 100%;
}

.tableB .tableValue.tableValue_2 p {
  color: #34699a;
}

.tableB .tableValue.tableValue_3 p {
  color: #d68230;
}

.tableBot {
  width: 1180px;
  font-size: clamp(14px, 2vw, 16px);
  color: #666666;
  margin: 10px auto 15px;
  text-align: left;
}

.print {
  font-size: clamp(16px, 2vw, 20px);
  color: #fff;
  line-height: 1em;
  padding: 0.7em 1.8em;
  background: #000000;
  display: inline-block;
  transition: .3s;
  /* margin: clamp(30px, 3vw, 50px) 20px 0; */
  border-radius: 10px;
}

.clas {
  font-size: clamp(16px, 2vw, 20px);
  color: #fff;
  line-height: 1em;
  padding: 0.7em 1.8em;
  background: #31A09B;
  display: inline-block;
  transition: .3s;
  /* margin: clamp(30px, 3vw, 50px) 20px 0; */
  border-radius: 10px;
}

.fadeWrap {
  width: 100%;
  height: auto;
}

.mouse_notice {
  width: 100%;
  height: auto;
  text-align: center;
  overflow: hidden;
}

.mouse_notice p {
  font-size: 14px;
  color: #999;
  font-weight: 400;
}

.mouse_notice .pointerWrap {
  width: 60%;
  height: 35px;
  display: inline-block;
  transform: scale(1.3);
  position: relative;
  margin-top: 10px;
}

.mouse_notice .pointerWrap img {
  height: 30px;
  position: absolute;
  transition: 0.6s;
  opacity: 0;
  animation-duration: 8s;
  animation-iteration-count: infinite;
}

.mouse_notice .pointerWrap img.pointer_left {
  animation-name: pointer_left;
}

.mouse_notice .pointerWrap img.pointer_right {
  animation-name: pointer_right;
}

.mouse_notice .pointerWrap img.pointer_center {
  animation-name: pointer_center;
}

@keyframes pointer_left {
  0% {
    left: 0;
    opacity: 0;
  }

  45% {
    left: calc(100% - 45px);
    opacity: 0;
  }

  50% {
    left: calc(100% - 45px);
    opacity: 1;
  }

  95% {
    left: 0;
    opacity: 1;
  }

  100% {
    left: 0;
    opacity: 0;
  }
}

@keyframes pointer_right {
  0% {
    left: 45px;
    opacity: 1;
  }

  45% {
    left: 100%;
    opacity: 1;
  }

  50% {
    left: 100%;
    opacity: 0;
  }

  95% {
    left: 45px;
    opacity: 0;
  }

  100% {
    left: 45px;
    opacity: 1;
  }
}

@keyframes pointer_center {
  0% {
    left: 18px;
    opacity: 1;
  }

  45% {
    left: calc(100% - 25px);
    opacity: 1;
  }

  50% {
    left: calc(100% - 25px);
    opacity: 1;
  }

  95% {
    left: 18px;
    opacity: 1;
  }

  100% {
    left: 18px;
    opacity: 1;
  }
}

@media (min-width:641px) and (max-width:1024px) {

  /* **************************************************************************************************************************************************************************** */
  /*                                                                                                                                                                              */
  /*                                                                                                                                                                              */
  /*                                                                             1단 배경 Fixed                                                                                   */
  /*                                                                                                                                                                              */
  /*                                                                                                                                                                              */
  /* **************************************************************************************************************************************************************************** */
  /* A            A A                 :                   A                   :                   A                   :                   A                   :                   */
  .sectionMainImgWrap {
    flex-direction: column;
    align-items: center;
  }

  .sectionMainImgWrap .imgBox {
    width: 80%;
    height: 240px;
    overflow: hidden;
  }

  .sectionMainImgWrap .imgBox img {
    width: 100%;
    height: 150%;
    object-fit: cover;
  }

  .sectionMainImgWrap .textBox {
    width: 80%;
  }

  .contentWrap .tit {
    padding: 0.7em 1em;
  }

  .thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth {
    width: 90%;
  }

  .thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .nameBox {
    width: clamp(215px, 30vw, 290px);
  }
}

@media (max-width:640px) {


  /* **************************************************************************************************************************************************************************** */
  /*                                                                                                                                                                              */
  /*                                                                                                                                                                              */
  /*                                                                             1단 배경 Fixed                                                                                   */
  /*                                                                                                                                                                              */
  /*                                                                                                                                                                              */
  /* **************************************************************************************************************************************************************************** */
  /* A            A A                 :                   A                   :                   A                   :                   A                   :                   */

  .sectionTit .titB {
    line-height: 1.2em;
  }

  .sectionMainImgWrap {
    flex-direction: column;
  }

  .sectionMainImgWrap .imgBox {
    width: 100%;
  }

  .sectionMainImgWrap .textBox {
    width: 100%;
  }

  .sectionMainImgWrap .textBox .ps {
    line-height: 1.3em;
  }

  .contentWrap .tit {
    width: 100%;
    line-height: 1.4em;
  }

  .contentWrap .listBox {
    width: 100%;
    padding: clamp(15px, 3vw, 25px) clamp(20px, 3vw, 50px);
  }



  .thirdWrap .contentWrap .contentBox .listWrap {
    padding: clamp(15px, 2vw, 25px) 20px;
  }

  .thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth {
    flex-direction: column;
  }

  .thirdWrap .contentWrap .contentBox .listWrap .listMaxWidth .nameBox {
    width: 100%;
    margin-bottom: 8px;
  }

  .tableWrap {
    margin-top: 10px;
  }

  .result_table {
    width: 600px;
  }

  .table {
    width: 890px;
  }

  .tableB {
    width: 550px;
  }

  .tableBot {
    width: 550px;
  }

  .tableTit,
  .tableValue {
    margin-right: 4px;
  }

  .tableValueWrap {
    margin-top: 7px;
  }

}