@charset "UTF-8";
/*==================================
      レスポンシブ設定 マップ型変数breakpointsを定義
      =================================*/
/*==================================
      common(一般) - 全体に共通するスタイル
      =================================*/
@media screen and (max-width: 767px) {
  .is-pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .is-sp {
    display: none !important;
  }
}
.inner {
  max-width: 1100px;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  .inner {
    padding: 0 20px;
  }
}

input[type=text],
input[type=email],
input[type=submit],
select,
textarea {
  -webkit-box-shadow: none;
          box-shadow: none;
  border: 1px solid #707070;
  background: #fff;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  width: 100%;
  padding: 10px;
  margin: 0;
  outline: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/*==================================
      レスポンシブ設定 マップ型変数breakpointsを定義
      =================================*/
/*==================================
      common(一般) - 全体に共通するスタイル
      =================================*/
@media screen and (max-width: 767px) {
  .is-pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .is-sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  /* 초기화 */
  html {
    overflow-y: scroll;
  }
  body {
    margin: 0;
    padding: 0;
    font-size: 0.75em;
    min-width: 320px;
    font-family: sans-serif;
    height: 100%;
  }
  html,
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  form,
  fieldset,
  img {
    margin: 0;
    padding: 0;
    border: 0;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-size: 1em;
  }
  article,
  aside,
  details,
  figcaption,
  figure,
  footer,
  header,
  hgroup,
  menu,
  nav,
  section {
    display: block;
  }
  #hd ul,
  nav ul,
  #ft ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }
  legend {
    position: absolute;
    font-size: 0;
    line-height: 0;
    text-indent: -9999em;
    overflow: hidden;
  }
  label,
  input,
  button,
  select,
  img {
    vertical-align: middle;
  }
  input,
  button {
    margin: 0;
    padding: 0;
    font-size: 1em;
    border-radius: 0;
  }
  button {
    cursor: pointer;
  }
  input[type=text],
  input[type=password],
  input[type=submit],
  input[type=image],
  button {
    font-size: 1em;
    border-radius: 0;
  }
  textarea,
  select {
    font-size: 1em;
    font-family: dotum;
  }
  textarea {
    border-radius: 0;
  }
  select {
    margin: 0;
  }
  p {
    margin: 0;
    padding: 0;
    word-break: break-all;
  }
  hr {
    display: none;
  }
  pre {
    overflow-x: scroll;
    font-size: 1.1em;
  }
  a:link,
  a:visited {
    color: #000;
    text-decoration: none;
  }
  a:hover,
  a:focus,
  a:active {
    color: #000;
    text-decoration: none;
  }
  ul,
  li {
    padding: 0;
    margin: 0;
    list-style: none;
  }
  /* 팝업레이어 */
  #hd_pop {
    z-index: 1000;
    position: relative;
    margin: 0 auto;
    width: 100%;
    height: 1px;
  }
  #hd_pop h2 {
    position: absolute;
    font-size: 0;
    text-indent: -9999em;
    line-height: 0;
    overflow: hidden;
  }
  .hd_pops {
    position: absolute;
    border: 1px solid #e9e9e9;
    background: #fff;
  }
  .hd_pops_footer {
    padding: 10px 0;
    background: #000;
    color: #fff;
    text-align: right;
  }
  .hd_pops_footer button {
    margin-right: 5px;
    padding: 5px 10px;
    border: 0;
    background: #393939;
    color: #fff;
  }
  /* 상단 레이아웃 */
  #hd {
    background: #fff;
    width: 100%;
    z-index: 9999;
    height: 60px;
    position: absolute;
    top: 0;
    left: 0;
    border-bottom: 1px solid #eee;
  }
  #hd:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
  }
  #hd_h1 {
    position: absolute;
    font-size: 0;
    text-indent: -9999em;
    line-height: 0;
    overflow: hidden;
  }
  #logo {
    padding: 5px 10px 5px;
    z-index: 9999;
  }
  #gnb_open {
    position: absolute;
    top: 0px;
    right: 0px;
    background: url(../img/mobile/menu.png) no-repeat 50% 50%;
    width: 60px;
    height: 60px;
    border: none;
    text-indent: -9999px;
    overflow: hidden;
  }
  #gnb_close {
    display: block;
    border: 0;
    position: absolute;
    top: 0;
    right: 0;
    background: url(../img/mobile/btn_cl.png) 50% 50% no-repeat;
    width: 50px;
    height: 50px;
    text-indent: -999999px;
    overflow: hidden;
  }
  #gnb {
    display: none;
    text-align: center;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 99999;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  #gnb > ul#gnb_1dul {
    overflow-y: auto;
    height: 65%;
  }
  #gnb ul#gnb_1dul li {
    width: 100%;
    text-align: center;
    font-weight: bold;
  }
  #gnb #gnb_1dul a:hover,
  #gnb a:focus {
    color: #3d96d6;
    text-decoration: none;
  }
  #gnb .gnb_1dli > a {
    font-size: 1.833em;
    line-height: 42px;
    display: inline-block;
    color: #fff;
    vertical-align: middle;
  }
  #gnb .gnb_2dul {
    display: none;
  }
  #gnb #gnb_1dul .gnb_2dli a {
    font-size: 1.25em;
    color: #979797;
    line-height: 1.7em;
    display: inline-block;
  }
  #gnb .gnb_op {
    background: url(../img/mobile/gnb_bg.gif) no-repeat 5px 50%;
    width: 30px;
    height: 30px;
    height: 42px;
    text-indent: -999px;
    overflow: hidden;
    border: none;
    vertical-align: middle;
  }
  #hd_sch {
    height: 23%;
  }
  #hd_sch form {
    margin-top: 40px;
    padding: 0;
    border: 1px solid #fff;
    width: 50%;
    position: relative;
    display: inline-block;
    text-align: center;
  }
  #hd_sch h2 {
    position: absolute;
    font-size: 0;
    text-indent: -9999em;
    line-height: 0;
    overflow: hidden;
  }
  #hd_sch legend {
    position: absolute;
    margin: 0;
    padding: 0;
    font-size: 0;
    line-height: 0;
    text-indent: -9999em;
    overflow: hidden;
  }
  #hd_sch #sch_stx {
    padding-left: 5px;
    width: 100%;
    height: 27px;
    border: 0;
    background: none !important;
    line-height: 27px !important;
    line-height: 1.6em;
    color: #fff;
  }
  #hd_sch #sch_submit {
    padding: 0 5px;
    height: 27px;
    border: 0;
    background: url(../img/mobile/sch_btn.png) no-repeat 50% 50%;
    color: #fff;
    cursor: pointer;
    text-indent: -9999px;
    overflow: hidden;
    width: 30px;
    position: absolute;
    top: 0;
    right: 0;
  }
  #hd_nb {
    height: 12%;
  }
  #hd_nb {
    text-align: center;
    width: 100%;
  }
  #hd_nb li {
    display: inline-block;
  }
  #hd_nb li a {
    color: #fff;
    background: #3C95D5;
    padding: 5px;
    display: inline-block;
    border-radius: 3px;
    display: inline-block;
    margin-top: 10px;
  }
  #hd_nb li a:hover,
  #hd_nb li a:focus {
    color: #fff;
    background: #0071C2;
    text-decoration: none;
  }
  #hd_nb #snb_adm {
    color: #3C95D5;
    border: 1px solid #3C95D5;
    background: #fff;
  }
  /*메인이미지*/
  .swiper-container {
    width: 100%;
    height: 330px;
  }
  .swiper-slide {
    /* Center slide text vertically */
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .swiper-bg1 {
    background: url(../images/mbn1.jpg) no-repeat 50% 50%;
    background-size: cover;
    height: 330px;
  }
  .swiper-bg2 {
    background: url(../images/mbn2.jpg) no-repeat 50% 50%;
    background-size: cover;
    height: 330px;
  }
  .swiper-bg3 {
    background: url(../images/mbn3.jpg) no-repeat 50% 50%;
    background-size: cover;
    height: 330px;
  }
  .swiper-container .bn_txt {
    background-color: rgba(39, 120, 197, 0.8);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#902778c5, endColorstr=#902778c5);
    width: 250px;
    height: 200px;
    padding: 25px;
    color: #fff;
  }
  .swiper-container .bn_txt h2 {
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
    color: #fff;
    font-size: 2.4em;
    line-height: 40px;
    margin-top: 10px;
  }
  .swiper-container .bn_txt p {
    color: #fff;
    background: url(../img/bn_pbg.jpg) no-repeat top left;
    padding-top: 20px;
    margin-top: 20px;
    font-size: 1.34em;
    line-height: 23px;
  }
  .swiper-container .swiper-pagination-bullet {
    opacity: 1;
    border-radius: 0;
    margin: 0 !important;
    border: none;
    text-indent: -9999px;
    width: 48px;
    height: 4px;
    background: #3e3c52;
    overflow: hidden;
    display: inline-block;
    margin: 0;
    zoom: 1;
    display: inline;
  }
  .swiper-container .swiper-pagination-bullet-active {
    background: #3d96d6;
  }
  /*메인 회사소개링크*/
  #comp_if {
    padding: 20px;
  }
  #comp_if:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
  }
  #comp_if li {
    width: 33%;
    float: left;
    position: relative;
    text-align: center;
  }
  #comp_if li h2 {
    font-size: 1.333em;
    margin-top: 10px;
    color: #3d96d6;
  }
  #comp_if li p {
    color: #566472;
    font-size: 1.083em;
    line-height: 1.4em;
  }
  #comp_if li {
    width: 27%;
    margin: 3%;
  }
  #comp_if li a img {
    width: 100%;
  }
  #comp_if li h2 {
    font-size: 1.167em;
  }
  #comp_if li p {
    display: none;
  }
  /* 중간 레이아웃 */
  #wrapper {
    margin: 0 0 10px;
    z-index: 99;
    background: #fff;
    width: 100%;
    position: relative;
    padding-top: 50px;
  }
  #wrapper:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
  }
  #container {
    position: relative;
    min-height: 300px;
  }
  #container:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
  }
  #container_title {
    margin: 20px 10px 15px;
    font-size: 1.3em;
    font-weight: bold;
  }
  .ind02 {
    width: 100%;
    background: #fff;
    padding: 0 0 50px;
  }
  .ind02 h2 {
    padding: 10px 20px;
    font-size: 20px;
  }
  .ind02 ul::after {
    display: block;
    content: "";
    clear: both;
  }
  .ind02 ul li {
    width: 90%;
    height: 400px;
    border: 1px solid #ddd;
    margin: 10px auto;
  }
  .ind02 ul li.ind2_01 {
    background: url("/theme/basic/images/1.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_02 {
    background: url("/theme/basic/images/2.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_03 {
    background: url("/theme/basic/images/3.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_04 {
    background: url("/theme/basic/images/4.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_05 {
    background: url("/theme/basic/images/5.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_06 {
    background: url("/theme/basic/images/6.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_07 {
    background: url("/theme/basic/images/7.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li.ind2_08 {
    background: url("/theme/basic/images/8.jpg") no-repeat 50% 50%;
  }
  .ind02 ul li a {
    display: block;
    width: 100%;
    height: 100%;
  }
  /* 텍스트 크기 조절 */
  #text_size {
    margin: 0 0 10px;
    text-align: center;
  }
  #text_size button {
    margin: 0;
    padding: 2px 2px 1px;
    border: 1px solid #c3c6ca;
    background: transparent;
    vertical-align: middle;
  }
  .ts_up {
    font-size: 1.167em !important;
  }
  .ts_up2 {
    font-size: 1.3em !important;
  }
  /* 하단 레이아웃 */
  #ft {
    background: #262439;
    text-align: center;
    padding-bottom: 20px;
    z-index: 98;
  }
  #ft h1 {
    width: 0;
    height: 0;
    font-size: 0;
    line-height: 0;
    overflow: hidden;
  }
  #ft p.copyright {
    margin: 0;
    padding: 10px 0 0;
    line-height: 1.8em;
    color: #75738c;
    border-top: 1px solid #3c3a4d;
  }
  #ft_copy {
    padding: 10px 20px;
    color: #fff;
    line-height: 2em;
  }
  #ft_copy #ft_company a {
    display: inline-block;
    padding: 0 5px;
    line-height: 1.05em;
    color: #bebebe;
    border-left: 1px solid #888;
  }
  #ft_copy #ft_company a:first-child {
    border: none;
  }
  #ft_copy b {
    color: inherit;
  }
  #ft_copy a {
    color: #fff;
  }
  .top_btn {
    background: url("../img/mobile/top_btn.png") no-repeat;
    text-indent: -999px;
    overflow: hidden;
    width: 50px;
    height: 50px;
    position: fixed;
    bottom: 10px;
    right: 10px;
  }
  .ft_info {
    color: #bebebe;
    line-height: 19px;
    padding: 0 0 10px;
  }
  /* 게시물 선택복사 선택이동 */
  .copymove_current {
    float: right;
    color: #ff3061;
  }
  .copymove_currentbg {
    background: #f4f4f4;
  }
  /* 화면낭독기 사용자용 */
  #hd_login_msg {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    overflow: hidden;
  }
  .msg_sound_only,
  .sound_only {
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
    margin: 0 !important;
    padding: 0 !important;
    width: 1px !important;
    height: 1px !important;
    font-size: 0 !important;
    line-height: 0 !important;
    overflow: hidden;
  }
  /* 본문 바로가기 */
  .to_content a {
    z-index: 100000;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    font-size: 0;
    line-height: 0;
    overflow: hidden;
  }
  /* 이미지 등비율 리사이징 */
  .img_fix {
    width: 100%;
    height: auto;
  }
  /* 캡챠 자동등록(입력)방지 기본 */
  #captcha {
    display: inline-block;
    position: relative;
  }
  #captcha legend {
    position: absolute;
    margin: 0;
    padding: 0;
    font-size: 0;
    line-height: 0;
    text-indent: -9999em;
    overflow: hidden;
  }
  #captcha audio {
    display: block;
    margin: 0 0 5px;
    width: 187px;
  }
  #captcha #captcha_img {
    width: 60px;
    height: 30px;
    border: 1px solid #e9e9e9;
  }
  #captcha #captcha_reload {
    margin: 0;
    padding: 0 5px;
    height: 32px;
    border: 0;
    background: #e4eaec;
    vertical-align: middle;
    overflow: hidden;
    cursor: pointer;
  }
  #captcha #captcha_key {
    margin: 0 0 0 4px;
    padding: 0 5px;
    width: 50px;
    height: 30px;
    border: 1px solid #b8c9c2;
    background: #f7f7f7;
    font-size: 1.333em;
    font-weight: bold;
    text-align: center;
    line-height: 2em;
  }
  #captcha #captcha_info {
    display: block;
    margin: 5px 0 0;
    font-size: 0.95em;
    letter-spacing: -0.1em;
  }
  #captcha #captcha_mp3 {
    margin: 0;
    padding: 0 5px;
    height: 32px;
    border: 0;
    background: #e4eaec;
    vertical-align: middle;
    overflow: hidden;
    cursor: pointer;
  }
  /*단축키일람 */
  .btn_cke_sc {
    background: #333;
    color: #fff;
    padding: 5px;
    border: none;
    margin-bottom: 5px;
  }
  .cke_sc_def {
    margin: 0 0 5px;
    padding: 10px;
    border: 1px solid #ccc;
    background: #f7f7f7;
    text-align: center;
  }
  .cke_sc_def dl {
    margin: 0 0 5px;
    text-align: left;
    zoom: 1;
  }
  .cke_sc_def dl:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
  }
  .cke_sc_def dt,
  .cke_sc_def dd {
    float: left;
    margin: 0;
    padding: 5px 0;
    border-bottom: 1px solid #e9e9e9;
  }
  .cke_sc_def dt {
    width: 50%;
    font-weight: bold;
  }
  .cke_sc_def dd {
    width: 50%;
  }
  .btn_cke_sc_close {
    background: #333;
    padding: 5px;
    border: none;
    color: #fff;
  }
  /* 버튼 */
  a.btn01 {
    display: inline-block;
    padding: 7px;
    border: 1px solid #ccc;
    background: #fafafa;
    color: #000;
    text-decoration: none;
    vertical-align: middle;
    border-radius: 5px;
  }
  a.btn01:focus,
  a.btn01:hover {
    text-decoration: none;
  }
  button.btn01 {
    display: inline-block;
    margin: 0;
    padding: 9px;
    border: 1px solid #ccc;
    background: #fafafa;
    color: #000;
    text-decoration: none;
  }
  a.btn02 {
    display: inline-block;
    padding: 7px;
    border: 1px solid #3b3c3f;
    background: #4b545e;
    color: #fff;
    text-decoration: none;
    vertical-align: middle;
    border-radius: 5px;
  }
  a.btn02:focus,
  .btn02:hover {
    text-decoration: none;
  }
  button.btn02 {
    display: inline-block;
    margin: 0;
    padding: 7px;
    border: 1px solid #3b3c3f;
    background: #4b545e;
    color: #fff;
    text-decoration: none;
  }
  .btn_confirm {
    text-align: center;
  }
  /* 서식단계 진행 */
  .btn_submit {
    background: #3c95d5;
    border: none;
    border-radius: 3px !important;
    padding: 11px 20px;
    color: #fff;
    display: inline-block;
  }
  fieldset .btn_submit {
    padding: 0 7px;
    height: 24px;
    line-height: 1em;
  }
  .btn_submit:hover {
    background: #0071c2;
  }
  a.btn_cancel {
    border-radius: 3px;
    padding: 10px 20px;
    background: #fff;
    border: 1px solid #3c95d5;
    color: #3c95d5;
    display: inline-block;
    vertical-align: middle;
  }
  .btn_cancel:hover,
  .btn_cancel:focus {
    background: #eef7fd;
  }
  button.btn_cancel {
    display: inline-block;
    border-radius: 3px;
    padding: 9px 20px;
    background: #fff;
    border: 1px solid #3c95d5;
    color: #3c95d5;
    display: inline-block;
  }
  a.btn_frmline,
  button.btn_frmline {
    display: inline-block;
    padding: 0 5px;
    height: 24px;
    border: 0;
    background: #333;
    color: #fff;
    letter-spacing: -0.1em;
    text-decoration: none;
    vertical-align: top;
  }
  /* 우편번호검색버튼 등 */
  a.btn_frmline {
    line-height: 24px;
  }
  button.btn_frmline {
    font-size: 1em;
  }
  /* 게시판용 버튼 */
  a.btn_b01 {
    border-radius: 3px;
    padding: 9px 20px;
    background: #fff;
    border: 1px solid #3c95d5;
    color: #3c95d5;
    display: inline-block;
  }
  a.btn_b01:focus,
  a.btn_b01:hover {
    background: #eef7fd;
  }
  a.btn_b02 {
    background: #3c95d5;
    border: none;
    border-radius: 3px;
    padding: 10px 20px;
    color: #fff;
    display: inline-block;
  }
  a.btn_b02:focus,
  a.btn_b02:hover {
    background: #0071c2;
  }
  a.btn_admin {
    border: none;
    border-radius: 3px;
    padding: 10px 20px;
    background: #fff;
    background: red;
    color: #fff;
    display: inline-block;
  }
  /* 관리자 전용 버튼 */
  /* 댓글 스타일 */
  .cnt_cmt {
    display: inline-block;
    margin: 0 0 0 3px;
    font-weight: bold;
  }
  /* 기본테이블 */
  .tbl_wrap {
    margin: 0 10px 10px;
  }
  .tbl_wrap table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
  }
  .tbl_wrap caption {
    padding: 0 0 10px;
    color: #4b8b99;
    font-weight: bold;
    text-align: left;
  }
  .tbl_head01 caption {
    padding: 0 0 10px;
    color: #777;
    text-align: left;
  }
  .tbl_head01 thead th {
    padding: 12px 0;
    border-top: 1px solid #d1dee2;
    border-bottom: 1px solid #d1dee2;
    background: #e5ecef;
    color: #383838;
    font-size: 0.95em;
    text-align: center;
    letter-spacing: -0.1em;
  }
  .tbl_head01 thead a {
    color: #383838;
  }
  .tbl_head01 thead th input {
    vertical-align: top;
  }
  /* middle 로 하면 게시판 읽기에서 목록 사용시 체크박스 라인 깨짐 */
  .tbl_head01 tfoot th {
    border-top: 1px solid #666;
    border-bottom: 1px solid #666;
    background: #484848;
    color: #fff;
  }
  .tbl_head01 tfoot td {
    border-color: #666;
    background: #484848;
    color: #fff;
    font-weight: bold;
    text-align: center;
  }
  .tbl_head01 tbody th {
    padding: 5px 0;
    border-top: 1px solid #e9e9e9;
    border-bottom: 1px solid #e9e9e9;
  }
  .tbl_head01 td {
    padding: 5px;
    border-top: 1px solid #e9e9e9;
    border-bottom: 1px solid #e9e9e9;
    line-height: 1.5em;
    word-break: break-all;
  }
  .tbl_head02 caption {
    padding: 0 0 10px;
    color: #777;
    text-align: left;
  }
  .tbl_head02 thead th {
    padding: 5px 0;
    border-top: 1px solid #d1dee2;
    border-bottom: 1px solid #d1dee2;
    background: #e5ecef;
    color: #383838;
    font-size: 0.95em;
    text-align: center;
    letter-spacing: -0.1em;
  }
  .tbl_head02 thead a {
    color: #383838;
  }
  .tbl_head02 thead th input {
    vertical-align: top;
  }
  /* middle 로 하면 게시판 읽기에서 목록 사용시 체크박스 라인 깨짐 */
  .tbl_head02 tfoot th {
    border-top: 1px solid #666;
    border-bottom: 1px solid #666;
    background: #484848;
    color: #fff;
  }
  .tbl_head02 tfoot td {
    border-color: #666;
    background: #484848;
    color: #fff;
    font-weight: bold;
    text-align: center;
  }
  .tbl_head02 tbody th {
    padding: 5px 0;
    border-top: 1px solid #e9e9e9;
    border-bottom: 1px solid #e9e9e9;
  }
  .tbl_head02 td {
    padding: 5px 3px;
    border-top: 1px solid #e9e9e9;
    border-bottom: 1px solid #e9e9e9;
    line-height: 1.4em;
    word-break: break-all;
  }
  /* 폼 테이블 */
  .tbl_frm01 th {
    padding: 10px 0;
    width: 90px;
    border: 1px solid #e9e9e9;
    border-left: 0;
    text-align: left;
  }
  .tbl_frm01 td {
    padding: 10px 5px;
    border-top: 1px solid #e9e9e9;
    border-bottom: 1px solid #e9e9e9;
    background: transparent;
  }
  .tbl_frm01 textarea,
  .frm_input {
    border: 1px solid #e4eaec;
    background: #f7f7f7;
    vertical-align: middle;
    line-height: 1.8em;
  }
  .tbl_frm01 textarea {
    width: 100%;
    height: 100px;
  }
  .tbl_frm01 a {
    text-decoration: none;
  }
  .tbl_frm01 .frm_file {
    display: block;
    margin-bottom: 5px;
    width: 100%;
  }
  .tbl_frm01 .frm_info {
    display: block;
    padding: 5px 0 0;
    color: #666;
    line-height: 1.3em;
  }
  /* 자료 없는 목록 */
  .empty_table {
    padding: 20px 0 !important;
    text-align: center;
  }
  .empty_list {
    padding: 20px 0 !important;
    text-align: center;
  }
  /* 필수입력 */
  .required,
  textarea.required {
    background: url("../img/wrest.gif") #fff top right no-repeat !important;
  }
  /* 테이블 항목별 정의 */
  .td_board {
    width: 120px;
    text-align: center;
  }
  .td_category {
    width: 80px;
    text-align: center;
  }
  .td_chk {
    width: 30px;
    text-align: center;
  }
  .td_date {
    width: 60px;
    text-align: center;
  }
  .td_datetime {
    width: 150px;
    text-align: center;
  }
  .td_group {
    width: 100px;
    text-align: center;
  }
  .td_mb_id {
    width: 100px;
    text-align: center;
  }
  .td_mng {
    width: 80px;
    text-align: center;
  }
  .td_name {
    width: 100px;
    text-align: left;
  }
  .td_nick {
    width: 100px;
    text-align: center;
  }
  .td_num {
    width: 50px;
    text-align: center;
  }
  .td_numbig {
    width: 80px;
    text-align: center;
  }
  .td_stat {
    width: 60px;
    text-align: center;
  }
  .txt_active {
    color: #5d910b;
  }
  .txt_done {
    color: #e8180c;
  }
  .txt_expired {
    color: #ccc;
  }
  .txt_rdy {
    color: #8abc2a;
  }
  /* 새창 기본 스타일 */
  .new_win #win_title {
    margin: 0 0 20px;
    padding: 20px;
    border-top: 3px solid #4e5d60;
    border-bottom: 1px solid #e9e9e9;
    font-size: 1.2em;
  }
  .new_win #win_title .sv {
    font-size: 0.75em;
    line-height: 1.2em;
  }
  .new_win .tbl_wrap {
    margin: 0 20px;
  }
  .new_win .win_ul {
    margin: -20px 0 20px 0;
    padding: 0 20px;
    border-bottom: 1px solid #455255;
    background: #484848;
    list-style: none;
  }
  .new_win .win_ul:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
  }
  .new_win .win_ul li {
    float: left;
    margin-left: -1px;
  }
  .new_win .win_ul a {
    display: block;
    padding: 10px;
    border-right: 1px solid #455255;
    border-left: 1px solid #455255;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
  }
  .new_win .win_desc {
    padding: 10px 20px;
  }
  .new_win .win_btn {
    clear: both;
    margin: 20px;
    text-align: center;
  }
  .new_win .win_btn a {
    display: inline-block;
    padding: 0 10px;
    height: 2.5em;
    background: #666;
    color: #fff;
    text-decoration: none;
    vertical-align: middle;
    line-height: 2.5em;
  }
  .new_win .win_btn button {
    display: inline-block;
    padding: 0 10px;
    height: 2.5em;
    border: 0;
    background: #666;
    color: #fff;
    text-decoration: none;
    line-height: 2.5em;
  }
  .new_win .win_btn input {
    padding: 0 10px;
    height: 2.5em;
    line-height: 2.5em;
  }
  /* 검색결과 색상 */
  .sch_word {
    color: #ff3061;
  }
  /* 사이드뷰 */
  .sv_wrap {
    display: inline-block;
    position: relative;
    font-weight: normal;
  }
  .sv_wrap .sv {
    z-index: 1000;
    display: none;
    margin: 5px 0 0;
    border: 1px solid #283646;
  }
  .sv_wrap .sv a {
    display: inline-block;
    margin: 0;
    padding: 3px;
    width: 94px;
    border-bottom: 1px solid #283646;
    background: #111;
    color: #fff !important;
  }
  .sv_wrap a:focus,
  .sv_wrap a:hover,
  .sv_wrap a:active {
    text-decoration: none;
  }
  .sv_on {
    display: block !important;
    position: absolute;
    top: 10px;
    left: 20px;
    width: auto;
    height: auto;
  }
  .sv_nojs .sv {
    display: block;
  }
  /* 페이징 */
  .pg_wrap {
    clear: both;
    margin: 0px 0 20px;
    padding: 0 0;
    text-align: center;
    font-size: 1.083em;
  }
  .pg_page,
  .pg_current {
    display: inline-block;
    padding: 0 8px;
    height: 30px;
    color: #000;
    letter-spacing: 0;
    line-height: 30px;
    vertical-align: middle;
  }
  .pg a:focus,
  .pg a:hover {
    text-decoration: none;
  }
  .pg_page {
    text-decoration: none;
  }
  .pg_start {
    background: url(../img/page_btn.gif) no-repeat 0 0;
    text-indent: -9999px;
    overflow: hidden;
    width: 30px;
    height: 30px;
    border: 1px solid #eee;
    padding: 0;
  }
  .pg_prev {
    background: url(../img/page_btn.gif) no-repeat -30px 0;
    text-indent: -9999px;
    overflow: hidden;
    width: 30px;
    height: 30px;
    border: 1px solid #eee;
    padding: 0;
  }
  .pg_end {
    background: url(../img/page_btn.gif) no-repeat -93px 0;
    text-indent: -9999px;
    overflow: hidden;
    width: 30px;
    height: 30px;
    border: 1px solid #eee;
    padding: 0;
  }
  .pg_next {
    background: url(../img/page_btn.gif) no-repeat -63px 0;
    text-indent: -9999px;
    overflow: hidden;
    width: 30px;
    height: 30px;
    border: 1px solid #eee;
    padding: 0;
  }
  .pg_current {
    display: inline-block;
    margin: 0 4px 0 0;
    color: #3c95d5;
    text-decoration: underline;
    font-weight: bold;
    font-weight: bold;
  }
  /* TEL */
  .tel {
    text-align: center;
    clear: both;
  }
  .tel h2 {
    color: #fff;
    font-size: 2.4em;
    padding: 10px;
    border: 1px solid #eee;
  }
  /* PC화면으로 */
  #device_change {
    display: inline-block;
    margin: 0 20px;
    padding: 5px 15px;
    border: 1px solid #5c5a6d;
    border-radius: 2em;
    color: #fff;
    font-size: 1em;
    text-decoration: none;
    text-align: center;
    background: #171528;
  }
  #device_change:hover,
  #device_change:focus {
    background: #171528;
  }
}
@media screen and (max-width: 767px) {
  #hd_wrapper {
    width: 100%;
    min-width: initial;
  }
  #ft {
    min-width: initial;
  }
  #hd {
    min-width: initial;
  }
  #device_change {
    width: 100%;
  }
  #hd_wrapper {
    padding-top: 0;
  }
  #ft #ft_copy {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .footer-ul a {
    width: 50%;
    text-align: center;
    padding: 5px 0;
  }
  #ft #ft_copy a {
    padding: 0;
    font-size: 12px;
    border-left: none;
  }
  #ft #ft_copy {
    -webkit-box-pack: justify !important;
        -ms-flex-pack: justify !important;
            justify-content: space-between !important;
  }
  #ft_copy {
    padding: 10px 20px !important;
    color: #fff;
    line-height: 2em;
  }
  #ft_copy {
    padding: 10px 20px !important;
    color: #fff;
    line-height: 2em;
  }
  #ft_copy2 {
    padding: 10px 20px !important;
    color: #fff;
    line-height: 2em;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #ft_copy #ft_company a {
    display: inline-block;
    padding: 0 5px;
    line-height: 1.05em;
    color: #bebebe;
    padding: 0 5px;
    line-height: 1.05em;
    color: #bebebe;
    border-left: 1px solid #888;
  }
  #ft_cop2 a {
    display: inline-block;
    padding: 0 5px;
    line-height: 1.05em;
    color: #bebebe;
    padding: 0 5px;
    line-height: 1.05em;
    color: #bebebe;
    border-left: 1px solid #888;
  }
  #ft_company {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  #ft_copy {
    -webkit-box-pack: center !important;
        -ms-flex-pack: center !important;
            justify-content: center !important;
  }
  #ft p.copyright {
    width: 100%;
  }
  #ft_copy2 a {
    color: #bebebe;
  }
  #ft_company {
    -webkit-box-pack: center !important;
        -ms-flex-pack: center !important;
            justify-content: center !important;
  }
  #ft_copy2 #ft_company a {
    display: inline-block;
    padding: 0 5px;
    line-height: 1.05em;
    color: #bebebe;
    border-left: 1px solid #888;
  }
  #ft_copy2 #ft_company a:first-child {
    border-left: none;
  }
  #gnb_open {
    position: absolute;
    top: 0px;
    right: 0px;
    background: url(http://fluorotechnology.co.kr/theme/basic/img/mobile/menu.png) no-repeat 50% 50%;
    width: 60px;
    height: 60px;
    border: none;
    text-indent: -9999px;
    overflow: hidden;
  }
  #hd_sch {
    display: none;
  }
  #gnb .gnb_op {
    background: url(http://fluorotechnology.co.kr/theme/basic/img/mobile/gnb_bg.gif) no-repeat 5px 50%;
    width: 30px;
    height: 30px;
    height: 42px;
    text-indent: -999px;
    overflow: hidden;
    border: none;
    vertical-align: middle;
  }
  #gnb > ul#gnb_1dul {
    padding-top: 200px;
  }
  #gnb .gnb_op {
    position: relative;
    top: -8px;
  }
  .gnb_2dul {
    position: initial;
    text-align: center;
    width: 100%;
  }
  #gnb #gnb_1dul .gnb_2dli a {
    padding: 0;
  }
  #gnb .gnb_1dli > a {
    margin-bottom: -10px;
  }
  #gnb_close {
    display: block;
    border: 0;
    position: absolute;
    top: 0;
    right: 0;
    background: url(http://fluorotechnology.co.kr/theme/basic/img/mobile/btn_cl.png) 50% 50% no-repeat;
    width: 50px;
    height: 50px;
    text-indent: -999999px;
    overflow: hidden;
  }
}
.contact {
  padding: 100px 0;
}
@media screen and (max-width: 767px) {
  .contact {
    padding: 100px 0 50px;
  }
}

body {
  overflow-x: hidden;
}

div#mfp_hidden {
  overflow: hidden;
  width: 1px;
  height: 1px;
  padding: 0px;
  margin: 0px;
}

div#mfp_hidden input {
  margin: 10px;
}

div.mfp_thanks {
  padding: 30px;
}

div.mfp_thanks p {
  line-height: 1.7em;
}

div.mfp_thanks ul.mfp_caution {
  margin: 0px;
  padding: 0px;
}

div.mfp_thanks ul.mfp_caution li {
  display: block;
  color: #C00;
  margin: 0px;
  padding: 5px 0px;
}

div#mfp_thanks {
  text-align: center;
  font-size: 18px;
  padding: 20px 0px;
}

div#mfp_thanks strong {
  color: #C00;
  font-size: 24px;
}

form#mailformpro {
  padding: 10px 0px;
}

form#mailformpro dl dt {
  float: left;
  width: 160px;
  clear: both;
  font-size: 12px;
  padding: 10px 0px;
  text-align: right;
  border-top: solid 1px #CCC;
  margin: 0px;
}

form#mailformpro dl dd {
  border-top: solid 1px #CCC;
  margin: 0px;
  padding: 10px 5px 20px 170px;
  font-size: 12px;
  line-height: 1.5em;
  text-align: left;
}

form#mailformpro dl dd ul, form#mailformpro dl dd ol {
  margin: 0px;
  padding: 0px;
}

form#mailformpro dl dd ul li, form#mailformpro dl dd ol li {
  margin: 0px;
  padding: 0px;
  list-style: none;
}

.must {
  display: block;
  background-color: #C00;
  border: solid 2px #C00;
  text-shadow: 0px 1px 2px #933;
  padding: 2px 5px;
  font-size: 10px;
  color: #FFF;
  float: left;
  margin: 0px 5px;
  border-radius: 4px;
  -webkit-box-shadow: 0px 0px 5px #CCC;
          box-shadow: 0px 0px 5px #CCC;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
}

.optionally {
  display: block;
  background-color: #06C;
  border: solid 2px #06C;
  text-shadow: 0px 1px 2px #933;
  padding: 2px 5px;
  font-size: 10px;
  color: #FFF;
  float: left;
  margin: 0px 5px;
  border-radius: 4px;
  -webkit-box-shadow: 0px 0px 5px #CCC;
          box-shadow: 0px 0px 5px #CCC;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
}

form#mailformpro label {
  border-radius: 3px;
  margin: 3px;
  display: inline-block;
  white-space: nowrap;
}

form#mailformpro label.mfp_checked {
  padding: 3px;
  border: solid 1px #CCC;
  background-color: #E8EEF9;
  -webkit-box-shadow: 0px 1px 3px #CCC inset;
          box-shadow: 0px 1px 3px #CCC inset;
}

form#mailformpro label.mfp_not_checked {
  padding: 3px;
  border: solid 1px #EEE;
}

table#mfp_confirm_table {
  border-spacing: 0px;
  border-collapse: collapse;
  width: 100%;
}

table#mfp_confirm_table tr.mfp_colored {
  background-color: #F6F7F9;
}

table#mfp_confirm_table tr.mfp_achroma {
  background-color: #FFF;
}

table#mfp_confirm_table tr th, table#mfp_confirm_table tr td {
  text-align: left;
  font-size: 12px;
  border-top: solid 1px #CCC;
  padding: 5px 10px;
}

table#mfp_confirm_table tr th {
  white-space: nowrap;
  width: 200px;
}

table#mfp_confirm_table tr td {
  line-height: 1.5em;
  word-break: break-all;
}

div#mfp_phase_confirm {
  clear: both;
}

div#mfp_phase_confirm h4 {
  font-size: 36px;
  padding: 10px 0px 0px 0px;
  text-align: center;
}

div#mfp_overlay {
  position: absolute;
  display: none;
  z-index: 10001;
}

div#mfp_overlay_inner {
  background-color: #FFF;
  padding: 15px;
  margin: 0px auto;
  border-radius: 5px;
  -webkit-box-shadow: 0px 0px 10px #000;
          box-shadow: 0px 0px 10px #000;
  width: 640px;
  max-width: 90%;
}

div#mfp_overlay_background {
  background-color: #000;
  position: absolute;
  display: none;
  z-index: 10000;
}

div#mfp_loading_screen {
  z-index: 20000;
  opacity: 0.8;
  display: none;
  background-color: #000;
  position: absolute;
}

div#mfp_loading {
  z-index: 20001;
  position: absolute;
  display: none;
  width: 40px;
  height: 40px;
  background-image: url(_images/mfp_loading.gif);
}

.mfp_colored {
  background-color: #F6F7F9;
}

.mfp_achroma {
  background-color: #FFF;
}

div.mfp_err {
  clear: both;
  display: none;
  text-align: left;
  margin: 5px 0px 0px 0px;
  padding: 3px 0px 5px 17px;
  color: #F00;
  font-size: 12px;
  line-height: normal;
  background-image: url(_images/mfp_error.gif);
  background-repeat: no-repeat;
  background-position: 0px 1px;
}

.mfp_parent_error {
  border: solid 2px #F00;
}

.problem {
  background-color: #FCC;
}

div#mfp_error {
  background-color: #FEE;
  border: solid 1px #F00;
  padding: 10px;
  display: none;
}

div#mfp_error p {
  padding: 0px;
  margin: 0px;
  font-size: 14px;
  text-align: center;
}

div#mfp_error p strong {
  font-size: 18px;
  color: #F00;
}

div#mfp_warning {
  background-color: #FEE;
  border: solid 1px #F00;
  padding: 10px;
  display: none;
  border-radius: 5px;
}

div#mfp_warning p {
  padding: 0px;
  margin: 0px;
  font-size: 14px;
  text-align: center;
}

div#mfp_warning p strong {
  font-size: 18px;
  color: #F00;
}

div#mfp_price {
  color: #C00;
  font-size: 36px;
  padding: 10px;
  font-weight: bolder;
}

div#mfp_price span {
  color: #666;
  font-size: 12px;
  font-weight: normal;
}

button.mfp_next, button.mfp_prev {
  font-size: 18px;
  margin: 10px;
  padding: 5px 10px;
}

button.mfp_next {
  float: right;
}

button.mfp_prev {
  float: left;
}

ul#mfp_phase_stat {
  padding: 10px;
  text-align: center;
}

ul#mfp_phase_stat li {
  display: inline-block;
  padding: 8px 15px;
  border-radius: 5px;
  margin: 0px 5px;
  list-style: none;
  font-size: 14px;
}

ul#mfp_phase_stat li.mfp_phase_arrow {
  -webkit-box-shadow: none;
          box-shadow: none;
  color: #999;
  padding: 8px 0px;
}

ul#mfp_phase_stat li.mfp_active_phase {
  -webkit-box-shadow: 0px 1px 6px #000;
          box-shadow: 0px 1px 6px #000;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  background-color: #0068B7;
  border: solid 2px #0068B7;
  font-weight: bolder;
  color: #FFF;
  text-shadow: 0px 1px 3px #000;
}

ul#mfp_phase_stat li.mfp_inactive_phase {
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  background-color: #EEE;
  border: solid 2px #EEE;
  color: #999;
  -webkit-box-shadow: 0px 1px 6px #CCC;
          box-shadow: 0px 1px 6px #CCC;
}

div#mfp_shopping_cart {
  border: solid 1px #CCC;
  margin: 0px;
  padding: 0px;
}

div#mfp_shopping_cart p {
  margin: 0px;
  text-align: center;
  padding: 20px 10px;
  font-size: 12px;
  background-color: #FEE;
}

table.mfp_shoppingcart {
  border-spacing: 0px;
  border-collapse: collapse;
  width: 100%;
}

table.mfp_shoppingcart thead tr td {
  background-color: #EEE;
  border-bottom: solid 1px #CCC;
  text-align: center;
  font-size: 12px;
  padding: 5px;
}

table.mfp_shoppingcart tbody tr th, table.mfp_shoppingcart tbody tr td {
  font-size: 12px;
  padding: 5px;
  border-bottom: solid 1px #CCC;
}

table.mfp_shoppingcart tbody tr td select {
  display: block;
  margin: 0px auto;
  text-align: center;
}

table.mfp_shoppingcart tbody tr td select option {
  text-align: center;
}

table.mfp_shoppingcart tbody tr th span {
  display: block;
  font-weight: normal;
  font-size: 10px;
  color: #666;
  padding: 3px 0px;
}

table.mfp_shoppingcart tfoot tr td {
  padding: 5px;
  font-size: 16px;
  font-weight: bolder;
  color: #900;
}

td.msc_price {
  font-size: 12px;
  text-align: right;
}

div.mfp_buttons {
  clear: both;
  padding: 10px 0px;
  text-align: center;
}

.imagebutton {
  margin: 0px;
  padding: 0px;
  border: none;
  outline: none;
  background: none;
}

.mfp_element_all {
  max-width: 90%;
}

.mfp_element_text,
.mfp_element_number,
.mfp_element_select-one,
.mfp_element_email,
.mfp_element_tel,
.mfp_element_textarea,
.mfp_element_date,
.mfp_element_password {
  border: solid 1px #CCC;
  border-radius: 3px;
  -webkit-box-shadow: 0px 0px 5px #CCC inset;
          box-shadow: 0px 0px 5px #CCC inset;
  padding: 3px 8px;
  margin: 2px;
  vertical-align: middle;
}

.mfp_element_checkbox,
.mfp_element_radio {
  vertical-align: middle;
  margin: 0px 2px;
}

.mfp_element_file {
  font-size: 12px;
  display: inline-block;
  padding: 10px 10px;
  vertical-align: middle;
  border: solid 1px #CCC;
  border-radius: 3px;
  -webkit-box-shadow: 0px 0px 5px #CCC inset;
          box-shadow: 0px 0px 5px #CCC inset;
  background: #EEE;
}

.mfp_element_submit, .mfp_element_reset, .mfp_element_button, button.mfp_next, button.mfp_prev {
  border-radius: 5px;
  padding: 5px 10px;
  border: solid 1px #CCC;
  background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
  text-shadow: 0px 2px 0px #FFF;
  font-size: 18px;
  cursor: pointer;
  outline: none;
}

.mfp_element_reset {
  color: #333;
}

.mfp_element_submit:hover, .mfp_element_reset:hover, .mfp_element_button:hover, button.mfp_next:hover, button.mfp_prev:hover {
  background: gradient(linear, center top, center bottom, from(#FFF), to(#CCC));
  background: -ms-linear-gradient(top, #FFF 0%, #CCC 100%);
  -webkit-box-shadow: 0px 2px 15px #CCC;
          box-shadow: 0px 2px 15px #CCC;
}

button.mfp_next, button.mfp_prev {
  font-size: 14px;
}

input#mfp_reserve_item, input#mfp_reserve_date {
  display: none;
}

div#mfp_reserve_wrapper {
  position: relative;
  overflow: hidden;
  border: solid 1px #CCC;
}

div#mfp_reserve_inner {
  position: relative;
  padding: 0px 0px 0px 100px;
  overflow: auto;
}

div#mfp_reserve_wrapper table {
  border-spacing: 0px;
  border-collapse: collapse;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_label {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100px;
  background-color: #FEE;
  z-index: 100;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value {
  padding: 0px 0px 0px 0px;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning {
  cursor: pointer;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active:hover,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning:hover {
  background-color: #E8EEF9;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_current {
  background-color: #0068B7;
  color: #FFF;
}

td.mfp_reserve_disabled {
  background-color: #CCC;
}

td.mfp_reserve_warning {
  background-color: #FFC;
}

div#mfp_reserve_wrapper table tr td, div#mfp_reserve_wrapper table tr th {
  border: solid 1px #CCC;
  padding: 0px 5px;
  font-size: 12px;
  text-align: center;
  font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  font-weight: normal;
  height: 20px;
  text-align: left;
}

td.mfp_reserve_week_0 {
  color: #F00;
  background-color: #FEE;
}

td.mfp_reserve_week_6 {
  color: #00F;
  background-color: #EEF;
}

div.mfp_ok {
  border-radius: 5px;
  background-color: #090;
  border: solid 1px #090;
  display: inline-block;
  line-height: 1.5em;
  padding: 0px 5px;
  margin: 0px 2px;
  color: #FFF;
  font-size: 10px;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  display: none;
}

div.prefcodeWrapper {
  position: relative;
}

div.prefcodeResult {
  position: absolute;
  top: 0px;
  left: 0px;
  padding: 5px;
  border: solid 1px #CCC;
  background-color: #FFF;
  -webkit-box-shadow: 0px 0px 5px #CCC;
          box-shadow: 0px 0px 5px #CCC;
  display: none;
}

div.prefcodeResult div {
  cursor: pointer;
}

div.prefcodeResult div:hover {
  background-color: #C9EBFB;
}

div.prefcodeResult div.prefcodeNext {
  background-color: #EEE;
  text-align: center;
}

div.prefLoading {
  padding: 60px 100px;
  background: url(_images/mfp_zip_loading.gif) no-repeat center center;
}

.hidefield {
  height: 0px;
  overflow: hidden;
}

.showfield {
  height: auto;
  overflow: visible;
}

div.mfp_attached_thumbnails {
  display: none;
  padding: 5px;
  margin: 5px auto;
  border: solid 1px #CCC;
  border-radius: 3px;
  -webkit-box-shadow: 0px 0px 5px #CCC inset;
          box-shadow: 0px 0px 5px #CCC inset;
  background: #EEE;
}

div.mfp_attached_thumbnails ul {
  margin: 0px;
  padding: 0px;
}

form#mailformpro dl dd div.mfp_attached_thumbnails ul li {
  display: inline-block;
  vertical-align: top;
  padding: 0px;
  border: solid 4px #FFF;
  margin: 5px;
  -webkit-box-shadow: 0px 2px 5px #999;
          box-shadow: 0px 2px 5px #999;
}

form#mailformpro dl dd div.mfp_attached_thumbnails ul li a {
  display: block;
  max-height: 100px;
  overflow: hidden;
}

div.mfp_attached_thumbnails ul li a img {
  display: block;
  max-width: 80px;
}

button.mfp_attached_reset {
  font-size: 14px;
}

div.mfp_guide {
  position: relative;
  width: 1px;
  height: 1px;
}

div.mfp_guide div {
  position: absolute;
  bottom: 0px;
  left: 0px;
  margin-top: -2em;
  white-space: nowrap;
  border-radius: 5px;
  padding: 5px 10px;
  line-height: 1em;
  font-size: 12px;
  color: #FFF;
  font-weight: bolder;
  background: #F00;
  display: none;
}

.mfp_ok {
  background-color: rgba(0, 255, 0, 0.2);
}

.mfp_ng {
  background-color: rgba(255, 0, 0, 0.2);
}

div#mfp_OperationCheck div#mfp_OperationCheck_inner {
  display: none;
}

div#mfp_OperationCheck strong {
  background: #090;
  display: block;
  color: #222;
  text-align: center;
  border-radius: 3px;
}

div#mfp_OperationCheck * {
  padding: 0px;
  margin: 0px;
  font-size: 12px;
}

div#mfp_OperationCheck p {
  padding: 0px 5px;
  margin: 0px;
  font-size: 12px;
}

div#mfp_OperationCheck p a {
  color: #0C0;
  text-decoration: none;
}

div#mfp_OperationCheck p a:hover,
div#mfp_OperationCheck p button:hover {
  text-decoration: underline;
}

div#mfp_OperationCheck p button {
  border: none;
  background: none;
  color: #0C0;
  cursor: pointer;
}

div#mfp_OperationCheck ul li,
div#mfp_OperationCheck ul li label,
div#mfp_OperationCheck ul li label input {
  line-height: 12px;
  font-size: 12px;
  list-style: none;
  vertical-align: middle;
}

div#mfp_OperationCheck ul li {
  padding: 5px 10px;
}

div#mfp_OperationCheck ul li label {
  text-decoration: underline;
}

button#mfp_recorder_record,
button#mfp_recorder_clear,
button#mfp_recorder_restore {
  border-radius: 5px;
  padding: 5px 10px 5px 2em;
  border: solid 1px #CCC;
  background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
  text-shadow: 0px 2px 0px #FFF;
  font-size: 16px;
  cursor: pointer;
  outline: none;
  display: inline-block;
  margin: 5px auto;
}

button#mfp_recorder_record {
  background: url(_images/mfp_record_disabled.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

button#mfp_recorder_clear {
  background: url(_images/mfp_record_remove.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

button#mfp_recorder_restore {
  background: url(_images/mfp_record_restore.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

button.enabled#mfp_recorder_record,
button.enabled#mfp_recorder_clear,
button.enabled#mfp_recorder_restore {
  background: url(_images/mfp_record_enabled.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

div#mfp_recorder_wrap {
  border: solid 1px #CCC;
  padding: 10px;
  text-align: center;
  margin: 5px auto;
}

td.request_image {
  width: 100px;
}

td.request_image img {
  max-width: 100px;
}

button.mfp_submit_enable {
  background: none;
  background: #000090;
}

button.mfp_submit_disable {
  background: none;
  background: #FD8282;
}

span.mfp_tips {
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  background-color: #FCC;
  display: block;
  border-radius: 5px;
  padding: 10px;
  margin: 2px;
  -webkit-box-shadow: 0px 2px 10px #999;
          box-shadow: 0px 2px 10px #999;
}

span.mfp_tips strong {
  color: #800040;
}

span.mfp_tips span {
  display: block;
  padding: 10px;
  color: #008080;
}

span.mfp_tips em {
  font-style: normal;
  color: #090;
  font-weight: bold;
}

@media screen and (max-width: 800px) {
  form#mailformpro dl dt {
    float: none;
    width: auto;
    font-size: 12px;
    padding: 5px;
    text-align: left;
  }
  form#mailformpro dl dd {
    clear: both;
    border-top: none;
    padding: 5px 15px;
    font-size: 12px;
    line-height: 1.5em;
  }
  div.mfp_buttons button {
    font-size: 14px;
  }
  div#mfp_phase_confirm h4 {
    font-size: 18px;
  }
  ul#mfp_phase_stat {
    padding: 0px;
    text-align: left;
  }
  ul#mfp_phase_stat li {
    text-align: center;
    padding: 5px 0px;
    border-radius: 3px;
    margin: 5px;
    list-style: none;
    font-size: 14px;
    width: 28%;
  }
  ul#mfp_phase_stat li.mfp_phase_arrow {
    bos-shadow: none;
    display: none;
  }
  table#mfp_confirm_table tr th {
    white-space: nowrap;
    width: 100px;
  }
  div#mfp_thanks {
    text-align: center;
    font-size: 18px;
    padding: 20px 0px;
  }
  div#mfp_thanks strong {
    color: #C00;
    font-size: 24px;
    display: block;
  }
}
form#mailformpro dl dd {
  border-top: solid 1px #CCC;
  margin: 0px;
  padding: 10px 5px 20px 170px;
  font-size: 12px;
  line-height: 1.5em;
  text-align: left;
}

.contact, form#mailformpro dl dt, form#mailformpro dl dd {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .contact, form#mailformpro dl dt, form#mailformpro dl dd {
    font-size: 14px;
  }
}

@media screen and (max-width: 767px) {
  form#mailformpro dl dd {
    border-top: none !important;
  }
  form#mailformpro dl dd {
    padding-left: 0;
  }
}
.flex-name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.flex-name .item {
  width: 48%;
}

.must {
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .must {
    font-size: 10px;
  }
}

.contact .inner {
  max-width: 900px;
}

.mfp_buttons {
  margin-top: 30px;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .mfp_buttons {
    margin-top: 20px;
    margin-bottom: 30px;
  }
}
.mfp_buttons button {
  background: #1c4587;
  padding: 10px 30px;
  border: none;
  color: #fff;
  font-size: 18px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.mfp_buttons button:hover {
  opacity: 0.6;
}

.c-large_headline {
  font-size: 20px;
  color: #1c4587;
  text-align: center;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .c-large_headline {
    font-size: 16px;
    margin-bottom: 20px;
  }
}

.thnaks {
  padding: 200px 0;
}
@media screen and (max-width: 767px) {
  .thnaks {
    padding: 100px 0;
  }
}

.c-lead {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .c-lead {
    font-size: 12px;
  }
}

.thanks-text {
  text-align: center;
  font-size: 20px;
}
@media screen and (max-width: 767px) {
  .thanks-text {
    font-size: 14px;
  }
}

.back-btn {
  margin-top: 60px;
  text-align: center;
}
.back-btn a {
  color: #000090;
  font-weight: 600;
  text-decoration: underline;
  font-size: 18px;
}

.c-enclosure {
  font-size: 14px;
  padding: 20px;
  margin-top: 20px;
  background-color: #f4e2e2;
  border: 1px solid #ff0000;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .c-enclosure {
    font-size: 14px;
  }
}