@charset "UTF-8";
.relative {
  position: relative; }

.inner {
  max-width: 1200px;
  margin: 0 auto; }

.mobile {
  display: none; }

.ic {
  display: inline-block;
  vertical-align: middle; }

.sectionLine {
  height: 10px;
  width: 100%;
  background-color: #ededed; }

label {
  display: inline-block;
  vertical-align: middle;
  line-height: 1; }

.clearfix:after {
  content: '';
  display: block;
  clear: both; }

.ml5 {
  margin-left: 5px; }

.ml10 {
  margin-left: 10px; }

.mt10 {
  margin-top: 10px; }

.mt30 {
  margin-top: 20px; }

.mt40 {
  margin-top: 40px; }

.pt10 {
  padding-top: 10px; }

.pt40 {
  padding-top: 40px; }

.ic {
  display: inline-block;
  vertical-align: middle;
  font-size: 0; }

.overlay:before {
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  background: rgba(0, 0, 0, 0.75);
  position: fixed;
  z-index: 500; }

.overlay2:before {
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  background: rgba(0, 0, 0, 0.75);
  position: fixed;
  z-index: 550; }

/** 검색어 하이라이트 **/
.f_red {
  color: #ff3333; }

.btn {
  display: inline-block;
  vertical-align: middle;
  border-radius: 5px; }
  .btn.big {
    width: 145px;
    line-height: 52px;
    font-size: 20px;
    letter-spacing: -0.8px; }
  .btn.main_col {
    background-color: #154588;
    color: #fff; }
    .btn.main_col:hover {
      background-color: #0c2856; }
  .btn.negative_col {
    background-color: #788290;
    color: #fff; }
    .btn.negative_col:hover {
      background-color: #545c68; }

.btn.chkBtn {
  width: 75px;
  line-height: 34px;
  font-size: 15px;
  color: #ffffff;
  padding: 0 11px;
  background: #515461 url("../img/ic_chk_arrow.png") no-repeat center right 9px; }

article.pageMenu {
  height: 56px;
  position: relative;
  padding: 0 20px 0 0;
  box-shadow: inset 0 -1px 0 0 #dddddd; }

article.pageSelector {
  display: inline-block;
  vertical-align: middle; }
  article.pageSelector .selectorBox {
    display: inline-block;
    vertical-align: middle;
    position: relative;
    box-shadow: inset -1px 0 0 0 #dddddd;
    width: 420px; }
    article.pageSelector .selectorBox a.set {
      font-size: 15px;
      font-weight: 500;
      display: block;
      line-height: 56px;
      padding: 0 50px 0 20px;
      background: url("../img/ic_selector_arrow.png") no-repeat center right 14px/24px 24px; }
    article.pageSelector .selectorBox ul {
      display: none;
      position: absolute;
      left: 0;
      right: 1px;
      top: 56px;
      background-color: #fff;
      z-index: 10;
      max-height: calc(100vh - 170px);
      overflow-y: auto; }
      article.pageSelector .selectorBox ul li a {
        display: block;
        box-shadow: inset -1px 0 0 0 #dddddd, inset 0 -1px 0 0 #f3f3f3;
        line-height: 56px;
        padding: 0 20px;
        font-size: 15px; }
        article.pageSelector .selectorBox ul li a.on {
          font-weight: 500;
          color: #003bff; }
        article.pageSelector .selectorBox ul li a:last-child {
          box-shadow: inset 0 -1px 0 0 #dddddd; }
      article.pageSelector .selectorBox ul li:hover {
        background-color: #fafbff; }

article.spinner {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0;
  line-height: 56px;
  display: inline-block;
  vertical-align: middle; }
  article.spinner .spinnerTxt {
    display: inline-block;
    vertical-align: middle;
    font-size: 11px;
    opacity: 0.5;
    line-height: 24px;
    padding-right: 4px; }
  article.spinner .spinnerBox {
    display: inline-block;
    vertical-align: middle; }
    article.spinner .spinnerBox a {
      display: inline-block;
      vertical-align: middle;
      width: 24px;
      height: 24px; }
      article.spinner .spinnerBox a.minus {
        background: url("../img/ic_spinner_minus.png") no-repeat center/cover; }
      article.spinner .spinnerBox a.plus {
        background: url("../img/ic_spinner_plus.png") no-repeat center/cover; }
    article.spinner .spinnerBox input {
      display: inline-block;
      vertical-align: middle;
      height: 24px;
      width: 42px;
      box-shadow: inset 0 1px 0 0 #dddddd, inset 0 -1px 0 0 #dddddd;
      font-size: 11px;
      text-align: center;
      font-weight: 500; }

article.paging {
  font-size: 0;
  text-align: center; }
  article.paging ul {
    display: inline-block;
    vertical-align: middle; }
    article.paging ul li {
      display: inline-block;
      vertical-align: middle; }
      article.paging ul li a {
        display: inline-block;
        vertical-align: middle;
        width: 30px;
        height: 30px;
        border-radius: 5px; }
        article.paging ul li a.num {
          font-size: 16px;
          line-height: 30px;
          color: #494949;
          font-weight: 300;
          letter-spacing: -0.48px;
          margin: 0 3px; }
          article.paging ul li a.num:hover {
            color: #e55728;
            text-decoration: underline;
            text-underline-position: under; }
          article.paging ul li a.num.current {
            font-weight: 400;
            color: #fff;
            border-radius: 5px;
            background-color: #2daad3; }
            article.paging ul li a.num.current:hover {
              text-decoration: none; }
        article.paging ul li a.first {
          background: url("../img/ic_paging_first.png") no-repeat center; }
          article.paging ul li a.first:hover {
            border: 1px solid #ccc; }
        article.paging ul li a.prev {
          background: url("../img/ic_paging_prev.png") no-repeat center;
          margin-right: 17px; }
          article.paging ul li a.prev:hover {
            border: 1px solid #ccc; }
        article.paging ul li a.next {
          background: url("../img/ic_paging_next.png") no-repeat center;
          margin-left: 17px; }
          article.paging ul li a.next:hover {
            border: 1px solid #ccc; }
        article.paging ul li a.last {
          background: url("../img/ic_paging_last.png") no-repeat center; }
          article.paging ul li a.last:hover {
            border: 1px solid #ccc; }

.tbox {
  display: inline-block;
  vertical-align: middle;
  border-radius: 3px;
  border: solid 1px #dadada;
  padding: 0 10px;
  height: 34px;
  font-size: 15px;
  color: #000;
  outline: none;
  letter-spacing: -0.15px; }
  .tbox:read-only {
    background-color: #f5f5f5; }
  .tbox.full {
    width: 100%; }
  .tbox::placeholder {
    color: rgba(57, 57, 57, 0.4);
    letter-spacing: -0.3px; }
  .tbox.readonly {
    background-color: #f5f5f5;
    font-weight: 700;
    letter-spacing: -0.15px; }

.sbox {
  display: inline-block;
  vertical-align: middle;
  height: 50px;
  position: relative;
  text-align: left;
  width: 100%;
  border-radius: 25px;
  box-shadow: 0px 0px 19.8px 0.2px rgba(0, 0, 0, 0.09); }
  .sbox .set {
    border: 1px solid #c8c8c8;
    border-radius: 4px;
    font-size: 16px;
    color: #000;
    display: block;
    line-height: 43px;
    height: 43px;
    padding: 0 40px 0 10px;
    background: url("../img/ic_select_arrow.png") no-repeat top 19px right 15px;
    cursor: pointer;
    text-overflow: ellipsis;
    white-space: nowrap;
    word-wrap: normal;
    width: 100%;
    max-width: 100%;
    overflow: hidden; }
    .sbox .set.on {
      border: 1px solid #2daad3; }
  .sbox ul {
    display: none;
    position: absolute;
    left: 1px;
    right: 1px;
    top: 43px;
    border: 1px solid #767676;
    z-index: 10; }
    .sbox ul li:last-child a {
      border-bottom: 1px solid transparent; }
    .sbox ul li a {
      font-size: 16px;
      font-weight: 300;
      letter-spacing: -0.48px;
      padding: 0 15px;
      display: block;
      line-height: 40px;
      background-color: #fff;
      text-overflow: ellipsis;
      white-space: nowrap;
      word-wrap: normal;
      width: 100%;
      max-width: 100%;
      overflow: hidden; }
      .sbox ul li a:hover {
        background-color: #2daad3;
        color: #fff; }
  .sbox select {
    width: 100%;
    /* you should keep these firsts rules in place to maintain cross-browser behaviour */
    -webkit-appearance: none;
    -moz-appearance: none;
    -o-appearance: none;
    appearance: none;
    background: url("../img/ic_select_arrow.png") no-repeat top 19px right 15px/19px 8.5px;
    outline: none;
    padding: 0 58px 0 19px;
    height: 100%;
    font-size: 16px; }
  .sbox.smaller {
    width: 60px; }
  .sbox.big {
    width: 180px;
    height: 34px;
    font-size: 15px; }
    .sbox.big select {
      background: url("../img/ic_select_arrow.png") no-repeat center right 9px; }

table.form {
  border-top: 1px solid #3b3b3b; }
  table.form tr {
    border-bottom: 1px solid #d2d2d2; }
    table.form tr th {
      padding: 19px 33px;
      text-align: left;
      font-size: 14px; }
    table.form tr td {
      padding: 8px 0; }
      table.form tr td.left {
        text-align: left; }
      table.form tr td.center {
        text-align: center; }
      table.form tr td .box {
        font-size: 0; }
        table.form tr td .box .row + .row {
          margin-top: 10px; }
      table.form tr td .tbox {
        vertical-align: middle;
        height: 30px;
        border: 1px solid #d2d2d2;
        padding: 0 5px;
        width: 150px;
        font-size: 15px; }
        table.form tr td .tbox.small {
          width: 110px; }
        table.form tr td .tbox.smaller {
          width: 60px; }
        table.form tr td .tbox.long {
          width: 200px; }
      table.form tr td .unit {
        font-size: 15px;
        margin: 0 5px; }
    table.form tr .formBtn {
      background-color: #bfbfbf;
      font-weight: 700;
      color: #fff;
      line-height: 30px;
      text-align: center;
      font-weight: 300;
      font-size: 14px;
      display: inline-block;
      vertical-align: middle;
      padding: 0 10px; }

label.toggle {
  position: relative;
  height: 16px;
  cursor: pointer; }
  label.toggle input {
    display: none;
    cursor: pointer; }
    label.toggle input:checked ~ .handler {
      left: 14px;
      border-color: #ce2027;
      transition: left 0.3s ease-out; }
    label.toggle input:checked ~ .bg {
      background-color: #0b7af3; }
  label.toggle .handler {
    position: absolute;
    display: inline-block;
    width: 12px;
    height: 12px;
    background-color: #fff;
    border-radius: 50%;
    transition: left 0.3s ease-out;
    padding: 0;
    top: 50%;
    left: 2px;
    transform: translateY(-50%);
    z-index: 10; }
  label.toggle .bg {
    position: relative;
    display: inline-block;
    background-color: #dddee0;
    border-radius: 8px;
    width: 28px;
    height: 16px;
    z-index: 9; }

.rbox {
  display: inline-block;
  position: relative; }
  .rbox input[type=radio] {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    z-index: 100;
    cursor: pointer; }
  .rbox input[type=radio] + label {
    position: relative;
    padding-left: 20px; }
    .rbox input[type=radio] + label:before {
      content: '';
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 18px;
      height: 18px;
      display: inline-block;
      background: url(../img/ic_rbox_off.png) no-repeat center/cover; }
    .rbox input[type=radio] + label .txt {
      display: inline-block;
      vertical-align: middle;
      padding-left: 4px;
      font-size: 12px;
      line-height: 20px; }
  .rbox input[type=radio]:checked + label:before {
    background: url(../img/ic_rbox_on.png) no-repeat center/cover; }

.amountBox {
  font-size: 0;
  display: inline-block;
  vertical-align: middle;
  border: 1px solid #d2d2d2; }
  .amountBox .minus, .amountBox .plus {
    display: inline-block;
    vertical-align: middle;
    vertical-align: top;
    width: 36px;
    height: 32px;
    position: relative; }
  .amountBox .minus {
    background: #f2f3f5 url("../img/ic_amount_minus.png") no-repeat center center; }
  .amountBox .plus {
    background: #f2f3f5 url("../img/ic_amount_plus.png") no-repeat center center; }
  .amountBox .tbox {
    display: inline-block;
    vertical-align: middle;
    height: 32px;
    text-align: center;
    width: 40px;
    font-size: 12px;
    border-left: 1px solid #d2d2d2;
    border-right: 1px solid #d2d2d2;
    border-top: none;
    border-bottom: none;
    border-radius: 0; }

.rbox {
  position: relative;
  display: inline-block;
  font-size: 0; }
  .rbox label {
    display: inline-block;
    vertical-align: middle;
    cursor: pointer; }
    .rbox label input[type=radio] {
      position: absolute;
      left: -9999px; }
      .rbox label input[type=radio]:checked ~ i {
        background: url("../img/ic_chk_on.png") no-repeat center/cover; }
    .rbox label i {
      position: relative;
      width: 18px;
      height: 18px;
      line-height: 24px;
      display: inline-block;
      vertical-align: middle;
      background: url("../img/ic_chk_off.png") no-repeat center/cover; }
    .rbox label .txt {
      display: inline-block;
      vertical-align: middle;
      font-size: 18px;
      color: #222222;
      line-height: 20px;
      padding-left: 7px; }

.cbox {
  position: relative;
  display: inline-block;
  font-size: 0; }
  .cbox.type2 label input[type=checkbox]:checked ~ i {
    background: url("../img/ic_cbox2_on.png") no-repeat center/cover; }
  .cbox.type2 label i {
    position: relative;
    width: 18px;
    height: 18px;
    line-height: 24px;
    display: inline-block;
    vertical-align: middle;
    background: url("../img/ic_cbox2_off.png") no-repeat center/cover; }
  .cbox.type2 label .txt {
    display: inline-block;
    vertical-align: middle;
    font-size: 15px;
    color: #222222;
    line-height: 18px;
    padding-left: 7px; }
  .cbox label {
    display: inline-block;
    vertical-align: middle;
    cursor: pointer; }
    .cbox label input[type=checkbox] {
      position: absolute;
      left: -9999px; }
      .cbox label input[type=checkbox]:checked ~ i {
        background: url("../img/ic_cbox_on.png") no-repeat center/cover; }
    .cbox label i {
      position: relative;
      width: 18px;
      height: 18px;
      line-height: 24px;
      display: inline-block;
      vertical-align: middle;
      background: url("../img/ic_cbox_off.png") no-repeat center/cover; }
    .cbox label .txt {
      display: inline-block;
      vertical-align: middle;
      font-size: 18px;
      color: #222222;
      line-height: 20px;
      padding-left: 7px; }

label.check {
  cursor: pointer; }

label.chk {
  position: relative;
  cursor: pointer; }
  label.chk input[type=radio] {
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    display: inline-block;
    vertical-align: middle;
    border-radius: 50%;
    width: 16px;
    height: 16px;
    border: 1px solid #656d9a;
    position: relative; }
    label.chk input[type=radio]:checked {
      background-color: #0b7af3;
      border-color: transparent; }
      label.chk input[type=radio]:checked:before {
        content: '';
        position: absolute;
        left: 50%;
        top: 50%;
        width: 6px;
        height: 6px;
        border-radius: 50%;
        transform: translate(-50%, -50%);
        background: #fff; }

article.fontSetBox {
  display: inline-block;
  vertical-align: middle; }
  article.fontSetBox a {
    margin: 0 -1px 0 0;
    width: 35px;
    line-height: 20px;
    font-size: 12px;
    text-align: center;
    display: inline-block;
    vertical-align: middle;
    color: #333;
    opacity: 0.5;
    border: 1px solid #ccc; }
    article.fontSetBox a.on {
      opacity: 1; }

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