@charset "UTF-8";
body,
div,
p,
h1,
h2,
h3,
h4,
h5,
h6,
ol,
ul,
li,
dl,
dt,
dd,
form,
nav,
header,
footer,
main,
article,
section,
aside,
figure,
figcaption,
button {
  margin: 0;
  padding: 0;
}
body {
  line-height: 1;
  -webkit-text-size-adjust: 100%;
}
ol,
ul,
li {
  list-style: none;
}
main {
  display: block;
}
main,
nav,
aside,
header,
article,
section,
footer,
figure,
ul,
li,
dl,
dt,
dd,
div,
p,
a,
span,
input,
select,
button {
  box-sizing: border-box;
}
img {
  border: 0;
}
a {
  color: #3483F4;
  text-decoration: underline;
  transition: color 0.2s, background-color 0.2s, opacity 0.2s;
}
a:hover {
  color: #0000cc;
  text-decoration: underline;
}
@media screen and (max-width: 500px) {
  a:hover {
    color: inherit;
  }
}
a[href^="tel:"] {
  text-decoration: none!important;
}
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
a > img {
  vertical-align: bottom;
}
@media screen and (max-width: 500px) {
  br.pc {
    display: none;
  }
}
* {
  box-sizing: border-box;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
table td,
table th {
  /* box-sizing: border-box */
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
li.L0,
li.L1,
li.L2,
li.L3,
li.L4,
li.L5,
li.L6,
li.L7,
li.L8,
li.L9 {
  list-style-type: decimal !important;
  list-style-position: outside;
  margin-left: 36px;
  padding-left: 16px;
}
li.L0,
li.L1,
li.L2,
li.L3,
li.L4,
li.L5,
li.L6,
li.L7,
li.L8,
li.L9 {
  background-color: #272822 !important;
}
pre.prettyprint {
  padding: 10px!important;
  margin-bottom: 30px!important;
}
.ac {
  text-align: center!important;
}
.ar {
  text-align: right!important;
}
.w330 {
  width: 330px!important;
}
.w100p {
  width: 100%!important;
}
.w90p {
  width: 90%!important;
}
.w80p {
  width: 80%!important;
}
.w70p {
  width: 70%!important;
}
.w60p {
  width: 60%!important;
}
.w50p {
  width: 50%!important;
}
.w40p {
  width: 40%!important;
}
.w30p {
  width: 30%!important;
}
.w20p {
  width: 20%!important;
}
.w10p {
  width: 10%!important;
}
.mb0 {
  margin-bottom: 0!important;
}
.mb5 {
  margin-bottom: 5px!important;
}
.mb10 {
  margin-bottom: 10px!important;
}
.mb20 {
  margin-bottom: 20px!important;
}
.mb30 {
  margin-bottom: 30px!important;
}
.mb40 {
  margin-bottom: 40px!important;
}
.mb50 {
  margin-bottom: 50px!important;
}
.mb60 {
  margin-bottom: 60px!important;
}
.mb70 {
  margin-bottom: 70px!important;
}
.mb80 {
  margin-bottom: 80px!important;
}
.mb90 {
  margin-bottom: 90px!important;
}
.mb100 {
  margin-bottom: 100px!important;
}
.mt10 {
  margin-top: 10px!important;
}
.mt20 {
  margin-top: 20px!important;
}
.mt30 {
  margin-top: 30px!important;
}
.mt40 {
  margin-top: 40px!important;
}
.mt50 {
  margin-top: 50px!important;
}
.mt60 {
  margin-top: 60px!important;
}
.mt70 {
  margin-top: 70px!important;
}
.mt80 {
  margin-top: 80px!important;
}
.mt90 {
  margin-top: 90px!important;
}
.mt100 {
  margin-top: 100px!important;
}
@media screen and (max-width: 768px) {
  .mb30 {
    margin-bottom: 20px!important;
  }
  .mb40 {
    margin-bottom: 30px!important;
  }
  .mb50 {
    margin-bottom: 30px!important;
  }
  .mb60 {
    margin-bottom: 30px!important;
  }
  .mb70 {
    margin-bottom: 30px!important;
  }
  .mb80 {
    margin-bottom: 50px!important;
  }
  .mb90 {
    margin-bottom: 50px!important;
  }
  .mb100 {
    margin-bottom: 50px!important;
  }
  .mt30 {
    margin-top: 20px!important;
  }
  .mt40 {
    margin-top: 30px!important;
  }
  .mt50 {
    margin-top: 30px!important;
  }
  .mt60 {
    margin-top: 30px!important;
  }
  .mt70 {
    margin-top: 30px!important;
  }
  .mt80 {
    margin-top: 30px!important;
  }
  .mt90 {
    margin-top: 30px!important;
  }
  .mt100 {
    margin-top: 30px!important;
  }
  .pbs10 {
    padding-bottom: 10px!important;
  }
}
@media screen and (max-width: 500px) {
  .w330 {
    width: 100%!important;
  }
  .w50p {
    width: inherit!important;
  }
}
html {
  height: 100%;
}
body,
button {
  font-family: 'Noto Sans JP', "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
  line-height: 1.3;
}
body.detail {
  padding-bottom: 170px;
}
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
em,
i {
  font-style: normal;
}
hr {
  border: none;
  border-top: 1px solid #C05389;
  margin-bottom: 20px;
}
#page {
  margin-top: 80px;
  min-height: calc(100vh - 210px);
}
.contents_in {
  width: 1020px;
  padding: 50px 20px;
  margin: 0 auto;
}
.contents_in.top {
  padding-bottom: 0;
}
.contents_in.list {
  width: 100%;
  max-width: 1100px;
  padding: 0 20px;
}
.contents_in.list.max {
  max-width: 1540px;
}
@media screen and (max-width: 1020px) {
  .contents_in.list {
    width: 1020px;
  }
  .contents_in.list.max {
    width: 1020px;
  }
}
.contents_in.bottom {
  padding-top: 0;
}
.contents_in p {
  margin-bottom: 1em;
}
.contents_in p:last-child {
  margin-bottom: 0;
}
.box {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}
.box_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
.pb110 {
  padding-bottom: 90px;
}
@media screen and (max-width: 768px) {
  .pb110 {
    padding-bottom: 39px;
  }
}
#header {
  border-bottom: 1px solid #F39500;
  background: #FFF;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 8;
  width: 100%;
  min-width: 1020px;
}
#header_in {
  height: 80px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
#header_in .logo {
  margin-right: 10px;
}
#header_in .logo a {
  width: 210px;
  height: 40px;
  display: block;
  /* 要素の中から文字だけを飛ばす */
  text-align: left;
  overflow: hidden;
  text-indent: 200%;
  white-space: nowrap;
  background: url(../img/logo.png);
  background-size: contain;
}
#header_in .mem_menu {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}
#header_in .mem_menu p {
  flex: 1;
  text-align: right;
  margin-right: 30px;
}
#header_in .mem_menu .btn_help {
  margin-right: 10px;
  font-size: 26px;
  color: #666;
}
#header_in .mem_menu .btn_help:hover {
  color: #F39500;
}
#header_in .mem_menu .btn_menu,
#header_in .mem_menu .btn_logout {
  display: block;
  text-align: center;
  border: 1px solid #333333;
  border-radius: 5px;
  text-decoration: none;
}
#header_in .mem_menu .btn_menu i,
#header_in .mem_menu .btn_logout i {
  margin-right: 3px;
}
#header_in .mem_menu .btn_menu:hover,
#header_in .mem_menu .btn_logout:hover {
  text-decoration: none;
}
#header_in .mem_menu .btn_menu span,
#header_in .mem_menu .btn_logout span {
  display: inline-block;
  padding: 7px 0;
  line-height: 26px;
}
#header_in .mem_menu .btn_menu {
  width: 170px;
  background: #F39500;
  border: 1px solid #F39500;
  color: #FFF;
  margin-right: 10px;
}
#header_in .mem_menu .btn_menu:hover {
  text-decoration: none;
  color: #FFF;
  background-color: chocolate;
}
#header_in .mem_menu .btn_logout {
  width: 130px;
  color: #000000;
  border: 1px solid #505050;
}
#header_in .mem_menu .btn_logout:hover {
  text-decoration: none;
  color: #FFF;
  background-color: #000;
}
#footer {
  min-width: 1020px;
}
#footer_in {
  border-top: 1px solid #F39500;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  height: 90px;
}
#footer_in h2 {
  font-size: 20px;
  margin-bottom: 5px;
}
#footer_in .contact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#footer_in .contact .tel {
  font-size: 18px;
  margin-right: 20px;
}
#footer .copyright {
  background: #F395001A;
  text-align: center;
  font-size: 14px;
  line-height: 1;
  padding: 13px 0;
}
.footer_btn {
  min-width: 1020px;
  background: #FEF5E6;
  border-top: 1px solid #F3950066;
  box-shadow: 0px -2px 5px rgba(0, 0, 0, 0.1);
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
}
.footer_btn_in {
  width: 800px;
  margin: 0 auto;
  height: 150px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.footer_btn_in .btn_menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 20px;
}
.footer_btn_in .btn_menu:last-child {
  margin-bottom: 0;
}
.footer_btn_in .btn_menu .lbl {
  width: 100px;
  font-weight: bold;
}
.footer_btn_in .btn_menu .icon_status {
  width: 100px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  margin-right: 20px;
}
.footer_btn_in .btn_menu .dl {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
}
.footer_btn_in .btn_menu .dl .btn_dl {
  width: calc((100% - 20px) / 2);
  margin-right: 20px;
}
.footer_btn_in .btn_menu .dl .btn_dl:last-child {
  margin: 0;
}
.footer_btn_in .btn_menu .btn_rep,
.footer_btn_in .btn_menu .btn_app_mod {
  flex: 1;
}
/* ===============================
フォームパーツ
================================== */
input[type="text"],
input[type="password"],
input[type="number"],
input[type="tel"] {
  outline: none;
  border: 1px solid #8C8A8A;
  height: 40px;
  border-radius: 6px;
  padding: 0 10px;
  font-size: 16px;
  background: linear-gradient(to bottom, rgba(120, 120, 120, 0.1), #FFF 6px);
}
input.num {
  text-align: right;
}
textarea {
  width: 100%;
  outline: none;
  border: 1px solid #8C8A8A;
  border-radius: 6px;
  font-size: 16px;
  background: linear-gradient(to bottom, rgba(120, 120, 120, 0.1), #FFF 6px);
  line-height: 20px;
  padding: 9px 10px;
}
input[type="radio"] {
  display: none;
}
.radio {
  display: block;
  position: relative;
  padding: 8px 8px 8px 40px;
  margin-bottom: 10px;
  background: #FFF;
  cursor: pointer;
}
.radio:last-child {
  margin-bottom: 0;
}
.radio:before {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  left: 10px;
  width: 20px;
  height: 20px;
  margin-top: -10px;
  background: #FFF;
  border-radius: 10px;
  border: 1px solid #000;
  z-index: 1;
}
input[type="radio"]:checked + .radio:after {
  content: "";
  position: absolute;
  display: block;
  left: 15px;
  top: 50%;
  width: 12px;
  height: 12px;
  margin-top: -5px;
  border-radius: 6px;
  background: #000;
  z-index: 2;
}
.select {
  position: relative;
}
.select:before {
  position: absolute;
  z-index: 2;
  content: "";
  top: 50%;
  right: 10px;
  background: url(../img/arrow_select.svg) no-repeat center center;
  background-size: contain;
  display: block;
  width: 10px;
  height: 18px;
  margin-top: -9px;
  pointer-events: none;
}
.select:after {
  position: absolute;
  z-index: 1;
  content: "";
  top: 6px;
  right: 1px;
  background: linear-gradient(to right, transparent, #FFF);
  display: block;
  width: 50px;
  height: 28px;
  pointer-events: none;
}
.select select {
  width: 100%;
  cursor: pointer;
  outline: none;
  border-radius: 6px;
  padding: 0 10px;
  font-size: 16px;
  text-overflow: '';
  vertical-align: middle;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  height: 40px;
  border: 1px solid #8C8A8A;
  background: linear-gradient(to bottom, rgba(120, 120, 120, 0.1), #FFF 6px);
}
.select select::ms-expand {
  display: none;
}
.select select:-moz-forcusring {
  color: transparent;
  text-shadow: 0 0 0;
}
.datepicker {
  width: 170px;
  display: inline-block;
  position: relative;
  margin-bottom: 0!important;
}
.datepicker:before {
  content: "";
  position: absolute;
  display: block;
  right: 10px;
  top: 50%;
  margin-top: -11px;
  width: 20px;
  height: 22px;
  z-index: 1;
  background: url(../img/icon_cal.svg) no-repeat center center;
  pointer-events: none;
}
.datepicker input {
  width: 100%;
  cursor: pointer;
}
.box_file_wrap {
  width: 660px;
  margin: 0 auto;
}
.box_file_wrap .box_file_select {
  height: 120px;
  background: #F5F5F5;
  border: dotted 2px #D2D2D2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-bottom: 10px;
}
.box_file_wrap .box_file_select.dragover:before {
  content: "ここへドロップしてください";
  color: #FFF;
  background: #000000bb;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
.box_file_wrap .box_file_select p {
  margin-bottom: 10px;
}
.box_file_wrap .box_file_select p small {
  font-size: 14px;
}
.box_file_wrap .box_file_select p.remarks {
  font-size: 14px;
  color: #505050;
}
.box_file_wrap .box_file_select label {
  display: block;
  width: 140px;
  height: 32px;
  background: #505050;
  color: #FFF;
  font-size: 12px;
  line-height: 32px;
  text-align: center;
  border-radius: 5px;
  cursor: pointer;
  margin-bottom: 10px;
}
.box_file_wrap .box_file_select label input[type="file"] {
  display: none;
}
.box_file_wrap .box_file_select label i {
  margin-right: 5px;
}
.box_file_wrap .fnarea {
  margin-bottom: 5px;
}
.box_file_wrap .fnarea + a {
  display: none;
}
.box_file_wrap .fnarea.selected + a {
  text-decoration: none;
  display: inline;
  margin-left: 5px;
  color: #666;
}
.box_file_wrap .fnarea.selected + a:hover {
  color: #900;
}
.box_file_wrap .file_card {
  display: inline-block;
  height: 28px;
  line-height: 26px;
  border-radius: 5px;
  font-size: 14px;
  padding: 0 10px;
  border: 1px solid #C4C4C4;
  margin: 0 5px 5px 0;
}
.box dl dd.err input[type="text"],
.box_login dl dd.err input[type="text"],
.box_input dl dd.err input[type="text"],
.box dl dd.err input[type="password"],
.box_login dl dd.err input[type="password"],
.box_input dl dd.err input[type="password"],
.box dl dd.err input[type="number"],
.box_login dl dd.err input[type="number"],
.box_input dl dd.err input[type="number"],
.box dl dd.err input[type="tel"],
.box_login dl dd.err input[type="tel"],
.box_input dl dd.err input[type="tel"] {
  border: 1px solid #900;
}
.box dl dd.err select,
.box_login dl dd.err select,
.box_input dl dd.err select {
  border: 1px solid #900;
}
.box dl dd.err .err_msg,
.box_login dl dd.err .err_msg,
.box_input dl dd.err .err_msg {
  margin-top: 5px;
  color: #900;
}
.box_file_wrap.err .box_file_select {
  border: 2px dotted #900;
}
.box_file_wrap .err_msg {
  margin: 5px 0;
  color: #900;
}
.msg_box {
  padding: 15px 20px;
  margin-bottom: 20px;
  border: 1px solid #00C;
  color: #00C;
}
.err_msg_box {
  padding: 15px 20px;
  margin-bottom: 20px;
  border: 1px solid #900;
  color: #900;
}
.w80 {
  width: 80px!important;
}
.w100 {
  width: 100px!important;
}
.w120 {
  width: 120px!important;
}
.w150 {
  width: 150px!important;
}
.w180 {
  width: 180px!important;
}
.w180-140 {
  width: 180px!important;
}
@media screen and (max-width: 500px) {
  .w180-140 {
    width: 140px!important;
  }
}
.w530 {
  max-width: 530px;
  width: 100%;
}
.w600 {
  max-width: 600px;
  width: 100%;
}
.w300 {
  max-width: 300px;
  width: 100%;
}
.w200 {
  max-width: 200px;
  width: 100%;
}
/* ===============================
汎用ボタン
================================== */
/* ===============================
汎用ボタン
================================== */
.btn_cmn {
  display: block;
  width: 400px;
  height: 70px;
  color: #FFF;
  text-align: center;
  line-height: 70px;
  font-size: 20px;
  font-weight: bold;
  background: #F8A129 url(../img/icon_btn_next.svg) no-repeat right 20px center;
  background-size: 24px 24px;
  margin-bottom: 20px;
  border: none;
  outline: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 10px;
  text-decoration: none;
}
.btn_cmn:hover {
  text-decoration: none;
  color: #FFF;
  background-color: chocolate;
}
.btn_cmn.green {
  background-color: #57A87B;
}
.btn_cmn.green:hover {
  background-color: darkgreen;
}
.btn_cmn.back {
  background: #FFF url(../img/icon_btn_prev.svg) no-repeat left 20px center;
  background-size: 24px 24px;
  border: 2px solid #F8A129;
  color: #F8A129;
  line-height: 66px;
}
.btn_cmn.back.noicon {
  background-image: none;
}
.btn_cmn.back:hover {
  color: #F8A129;
  background-color: #F8A12921;
}
.btn_cmn.back.green {
  border: 2px solid #57A87B;
  color: #57A87B;
  background: #FFF url(../img/icon_btn_prev_green.svg) no-repeat left 20px center;
  background-size: 24px 24px;
}
.btn_cmn.back.green:hover {
  background-color: rgba(87, 168, 123, 0.1);
}
.btn_cmn.disabled {
  pointer-events: none;
  background: #E8E8E8;
  color: #898989;
  box-shadow: none;
}
/* ===============================
コピーして申請
================================== */
.btn_copy {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 400px;
  height: 70px;
  color: #FFF;
  text-align: left;
  font-size: 20px;
  font-weight: bold;
  background: #F8A129 url(../img/icon_copy.svg) no-repeat left 80px center;
  margin-bottom: 20px;
  padding-left: 40px;
  border: none;
  outline: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 10px;
  text-decoration: none;
}
.btn_copy:hover {
  text-decoration: none;
  color: #FFF;
  background-color: chocolate;
}
.btn_copy.green {
  background-color: #57A87B;
}
.btn_copy.green:hover {
  background-color: darkgreen;
}
/* ===============================
ログインボタン
================================== */
.btn_login {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 400px;
  height: 90px;
  color: #FFF;
  text-align: center;
  font-size: 24px;
  font-weight: 500;
  background: #F8A129;
  margin-bottom: 20px;
  outline: none;
  border: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 3px;
  text-decoration: none;
}
.btn_login:hover {
  color: #FFF;
  text-decoration: none;
  opacity: 0.7;
}
/* ===============================
会員削除ボタン
================================== */
.btn_member_del {
  display: inline-block;
  border-radius: 5px;
  text-align: center;
  padding: 0 5px;
  color: #666;
  text-decoration: none;
  font-size: 28px;
  line-height: 1;
}
.btn_member_del i {
  margin-right: 5px;
}
.btn_member_del:hover {
  text-decoration: none;
  color: #990000;
}
/* ===============================
検索ボタン
================================== */
.btn_search {
  display: block;
  width: 200px;
  height: 50px;
  color: #FFF;
  text-align: center;
  line-height: 50px;
  font-size: 20px;
  font-weight: bold;
  background: #F8A129;
  background-size: 24px 24px;
  margin: 0 auto;
  border: none;
  outline: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 10px;
  text-decoration: none;
}
.btn_search i {
  margin-right: 15px;
}
.btn_search:hover {
  text-decoration: none;
  color: #FFF;
  background-color: chocolate;
}
/* ===============================
設計確認・依頼ボタン
================================== */
.btn_design {
  display: block;
  border: 2px solid #F8A129;
  border-radius: 10px;
  width: 360px;
  text-decoration: none;
}
.btn_design p {
  width: 100%;
  height: 70px;
  color: #FFF;
  text-align: center;
  line-height: 70px;
  font-size: 18px;
  font-weight: 500;
  background: #F8A129 url(../img/icon_btn_next.svg) no-repeat right 20px center;
  background-size: 24px 24px;
  margin-bottom: 20px;
  border: 1px solid #FFF;
  outline: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 9px;
  text-decoration: none;
}
.btn_design p span {
  margin-left: 3px;
  font-size: 28px;
}
.btn_design:hover {
  text-decoration: none;
  opacity: 0.7;
}
.btn_design.design01 {
  border: 2px solid #FFCB21;
}
.btn_design.design01 p {
  color: #704706;
  background: #FFCB21 url(../img/icon_btn_next_brown.svg) no-repeat right 20px center;
  background-size: 24px 24px;
}
.btn_design.design02 {
  border: 2px solid #F39500;
}
.btn_design.design02 p {
  background-color: #F39500;
}
/* ===============================
ダウンロードボタン
================================== */
.btn_dl {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  color: #FFF;
  text-align: center;
  font-size: 18px;
  background: #FFF;
  border: 2px solid #F8A129;
  color: #F8A129;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 10px;
  text-decoration: none;
}
.btn_dl:hover {
  color: #F8A129;
  background-color: #F8A12921;
  text-decoration: none;
}
.btn_dl i {
  font-size: 24px;
  margin-right: 6px;
}
/* ===============================
編集するボタン（詳細画面）
================================== */
.btn_app_mod {
  display: block;
  width: 400px;
  height: 50px;
  color: #FFF;
  text-align: center;
  line-height: 50px;
  font-size: 20px;
  font-weight: bold;
  background: #F8A129 url(../img/icon_btn_next.svg) no-repeat right 20px center;
  background-size: 24px 24px;
  border: none;
  outline: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 10px;
  text-decoration: none;
}
.btn_app_mod:hover {
  text-decoration: none;
  color: #FFF;
  background-color: chocolate;
}
.btn_app_mod.disabled {
  pointer-events: none;
  background: #999;
  color: 666;
}
/* ===============================
報告するボタン（詳細画面）
================================== */
.btn_rep {
  display: block;
  width: 400px;
  height: 50px;
  color: #FFF;
  text-align: center;
  line-height: 50px;
  font-size: 20px;
  font-weight: bold;
  background: #57A87B url(../img/icon_btn_next.svg) no-repeat right 20px center;
  background-size: 24px 24px;
  border: none;
  outline: none;
  transition: all 0.2s;
  cursor: pointer;
  border-radius: 10px;
  text-decoration: none;
}
.btn_rep:hover {
  text-decoration: none;
  color: #FFF;
  background-color: darkgreen;
}
.btn_rep.disabled {
  pointer-events: none;
  background: #999;
  color: 666;
}
/* ===============================
共通コンテンツ
================================== */
.hd01 {
  font-size: 24px;
  font-weight: bold;
  padding-bottom: 10px;
  border-bottom: 3px solid #C4C4C4;
  margin-bottom: 20px;
  padding-left: 3px;
  position: relative;
}
.hd01.top {
  margin-bottom: 40px;
}
.hd01:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  display: block;
  width: 200px;
  height: 3px;
  background-color: #F39500;
}
.hd02 {
  font-size: 20px;
  font-weight: 400;
  line-height: 30px;
  padding: 10px;
  background: #FEF5E6;
  margin-bottom: 20px;
  position: relative;
  padding-left: 30px;
}
.hd02:before {
  position: absolute;
  left: 10px;
  top: 17px;
  content: "●";
  line-height: 14px;
  margin-right: 5px;
  color: #F39500;
  font-size: 14px;
}
.hd03 {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 20px;
  padding-left: 8px;
  border-left: 10px solid #F8A129;
}
.contents.report .hd01:before {
  background-color: #57A87B;
}
.contents.report .hd02 {
  background: rgba(87, 168, 123, 0.1);
}
.contents.report .hd02:before {
  color: #57A87B;
}
.contents.report .hd03 {
  border-left: 10px solid #57A87B;
}
.notice {
  background: #f5f5f5;
  padding: 15px 15px 15px 45px;
  border-radius: 5px;
  margin-bottom: 30px!important;
  text-indent: -0.8em;
}
.notice i {
  color: #F39500;
  margin-right: 10px;
}
.file_link {
  margin-right: 30px;
}
.file_link i {
  color: #000;
  margin-right: 5px;
}
.ext_link i {
  color: #000;
  margin-right: 5px;
}
.status01 {
  background: #FFCB21;
}
.status02 {
  background: #89CD78;
}
.status03 {
  background: #D9D9D9;
}
.status04 {
  background: #E84747;
  color: #FFF;
}
.status05 {
  background: #87D1E9;
}
.order01 {
  background: #FFF;
}
.order02 {
  background: #000;
  color: #FFF;
}
.order03 {
  color: #000;
  border: 1px solid #87D1E9 !important;
}
.pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 40px;
}
.pagination li {
  margin-right: 10px;
}
.pagination li:last-child {
  margin-right: 0;
}
.pagination li a {
  font-weight: bold;
  display: block;
  width: 32px;
  height: 32px;
  line-height: 30px;
  text-align: center;
  text-decoration: none;
  background: #FFF;
  color: #555;
  border-radius: 50%;
}
.pagination li a:hover {
  background-color: #333;
  color: #FFF;
}
.pagination li a.active {
  background: #F39500;
  color: #FFF;
  pointer-events: none;
}
.pagination li a.none {
  color: #ccc;
  pointer-events: none;
}
.onlysp {
  display: none!important;
}
@media screen and (max-width: 768px) {
  .onlysp {
    display: block!important;
  }
}
#loader_wrap {
  position: fixed;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 100;
  left: 0;
  top: 0;
  display: none;
}
#loader_wrap.show {
  display: flex;
  justify-content: center;
  align-items: center;
}
.loader,
.loader:before,
.loader:after {
  background: #ffffff;
  animation: load1 1s infinite ease-in-out;
  width: 1em;
  height: 4em;
}
.loader {
  color: #ffffff;
  text-indent: -9999em;
  margin: 88px auto;
  position: relative;
  font-size: 11px;
  transform: translateZ(0);
  animation-delay: -0.16s;
}
.loader:before,
.loader:after {
  position: absolute;
  top: 0;
  content: '';
}
.loader:before {
  left: -1.5em;
  animation-delay: -0.32s;
}
.loader:after {
  left: 1.5em;
}
@keyframes load1 {
  0%,
  80%,
  100% {
    box-shadow: 0 0;
    height: 4em;
  }
  40% {
    box-shadow: 0 -2em;
    height: 5em;
  }
}
.box_login {
  width: 400px;
  margin: 0 auto 70px;
}
@media screen and (max-width: 768px) {
  .box_login {
    padding: 30px 20px;
  }
}
.box_login dl dt {
  font-size: 16px;
  margin-bottom: 5px;
}
.box_login dl dd {
  margin-bottom: 30px;
}
.box_login dl dd input {
  width: 100%;
}
.box_login .notice {
  font-size: 14px;
}
.box_ac {
  text-align: center;
}
.box_ac .btn_login,
.box_ac .btn_cmn {
  margin: 0 auto 20px;
}
.flex_btn_area {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.flex_btn_area .col {
  /* flex時の幅計算 */
  width: calc((100% - 20px) / 2);
  margin-right: 20px;
}
.flex_btn_area .col:nth-child(2n) {
  margin-right: 0;
}
@media screen and (max-width: 768px) {
  .flex_btn_area .col {
    width: 100%;
    margin-right: 0;
  }
}
.flex_btn_area .col .remarks {
  text-align: center;
  color: #555555;
}
.news_wrap {
  width: 100%;
  height: 260px;
  border: 1px solid #D4D4D4;
  overflow-y: auto;
  padding: 20px;
  margin-bottom: 10px;
}
.news_wrap ul li {
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px dashed #d4d4d4;
}
.news_wrap ul li:last-child {
  border: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.news_wrap ul li .date {
  font-weight: bold;
  margin-bottom: 5px;
}
.news_wrap ul li .hd {
  font-weight: bold;
  font-size: 16px;
  padding-left: 8px;
  border-left: 5px solid #F8A129;
  margin-bottom: 5px;
}
.news_wrap ul li .desc {
  margin-bottom: 5px;
  padding-left: 10px;
}
.news_wrap.full {
  margin-bottom: 40px;
  height: auto;
  border: none;
  overflow-y: inherit;
}
.news_wrap.full ul li:last-child {
  padding-bottom: 20px;
  border-bottom: 1px dashed #d4d4d4;
}
.app_wrap {
  background: #F4F4F4;
  display: flex;
  flex-wrap: wrap;
  padding: 50px 30px;
  justify-content: space-around;
}
.app_wrap .btn_cmn {
  width: 360px;
  margin-bottom: 0;
}
.search_wrap {
  background-color: #F4F4F4;
  padding: 20px;
  margin-bottom: 40px;
}
.search_wrap .hd {
  padding-left: 8px;
  border-left: 10px solid #F8A129;
  margin-bottom: 20px;
}
.search_wrap dl {
  margin-bottom: 30px;
}
.search_wrap dl div {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 15px;
}
.search_wrap dl div:last-child {
  margin-bottom: 0;
}
.search_wrap dl div dt {
  width: 120px;
}
.search_wrap dl div dd {
  width: calc(100% - 120px);
}
.search_wrap dl div dd.dp {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.search_wrap dl div dd.dp span {
  margin: 0 10px;
}
.app_list {
  width: 100%;
  margin-bottom: 50px;
}
.app_list tr {
  transition: background 0.2s;
}
.app_list tr:hover {
  background: #D9D9D93B;
}
.app_list tr:hover td:last-child:before {
  right: 15px;
}
.app_list tr th {
  background: #FEF5E6;
  text-align: center;
  font-size: 14px;
}
.app_list tr th:nth-child(4) {
  text-align: left;
}
.app_list tr th:nth-child(5) {
  padding-right: 60px;
}
.app_list tr td {
  border-bottom: 1px solid #CAC3B7;
  cursor: pointer;
}
.app_list tr td:last-child {
  position: relative;
}
.app_list tr td:last-child:before {
  content: "";
  display: block;
  width: 10px;
  height: 16px;
  position: absolute;
  right: 20px;
  top: 50%;
  margin-top: -8px;
  background: url(../img/arrow_next.svg);
  transition: all 0.2s;
}
.app_list tr th,
.app_list tr td {
  padding: 15px 10px;
}
.app_list tr th:first-child,
.app_list tr td:first-child {
  width: 110px;
  text-align: center;
}
.app_list tr th:nth-child(2),
.app_list tr td:nth-child(2) {
  width: 80px;
  padding: 15px 0;
}
.app_list tr th:nth-child(3),
.app_list tr td:nth-child(3) {
  width: 110px;
  text-align: center;
  padding: 15px 0;
}
.app_list tr th:last-child,
.app_list tr td:last-child {
  padding-left: 0;
  width: 140px;
}
.app_list tr th .icon_order,
.app_list tr td .icon_order {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  width: 70px;
  height: 22px;
  line-height: 1;
  text-align: center;
  border-radius: 5px;
  border: 1px solid #000;
  font-size: 14px;
}
.app_list tr th .icon_status,
.app_list tr td .icon_status {
  display: block;
  font-size: 12px;
  width: 80px;
  height: 26px;
  line-height: 26px;
  text-align: center;
}
.rep_list {
  width: 100%;
  margin-bottom: 50px;
}
.rep_list tr {
  transition: background 0.2s;
}
.rep_list tr:hover {
  background: #D9D9D93B;
}
.rep_list tr:hover td:last-child:before {
  right: 15px;
}
.rep_list tr th {
  background: rgba(87, 168, 123, 0.1);
  text-align: center;
  font-size: 14px;
}
.rep_list tr td {
  border-bottom: 1px solid #CAC3B7;
}
.rep_list tr th,
.rep_list tr td {
  padding: 15px 10px;
}
.rep_list tr th.nobb,
.rep_list tr td.nobb {
  padding-bottom: 0;
  border-bottom: none;
}
.rep_list tr th:nth-child(1),
.rep_list tr td:nth-child(1) {
  width: 100px;
  text-align: center;
}
.rep_list tr th:nth-child(3),
.rep_list tr td:nth-child(3) {
  width: 140px;
}
.rep_list tr th .rep_list_file,
.rep_list tr td .rep_list_file {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  padding-left: 10px;
}
.rep_list tr th .rep_list_file .constructor,
.rep_list tr td .rep_list_file .constructor,
.rep_list tr th .rep_list_file .select,
.rep_list tr td .rep_list_file .select {
  flex: 1;
  margin-right: 5px;
}
.rep_list tr th .rep_list_file .datepicker,
.rep_list tr td .rep_list_file .datepicker {
  width: 130px;
  margin-right: 5px;
}
@media screen and (max-width: 1300px) {
  .rep_list tr th .rep_list_file .constructor,
  .rep_list tr td .rep_list_file .constructor,
  .rep_list tr th .rep_list_file .select,
  .rep_list tr td .rep_list_file .select,
  .rep_list tr th .rep_list_file .datepicker,
  .rep_list tr td .rep_list_file .datepicker {
    margin-bottom: 5px;
  }
  .rep_list tr th .rep_list_file .datepicker,
  .rep_list tr td .rep_list_file .datepicker {
    margin-right: 0;
  }
}
.rep_list tr th .rep_list_file .lbl_file,
.rep_list tr td .rep_list_file .lbl_file {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: 40px;
  border-radius: 5px;
  border: 1px solid #57A87B;
  color: #57A87B;
  margin-right: 5px;
  padding-right: 0;
  background: #FFF;
  transition: all 0.2s;
  cursor: pointer;
}
.rep_list tr th .rep_list_file .lbl_file.hide,
.rep_list tr td .rep_list_file .lbl_file.hide {
  display: none;
}
.rep_list tr th .rep_list_file .lbl_file:hover,
.rep_list tr td .rep_list_file .lbl_file:hover {
  background: #57A87B;
  color: #FFF;
}
.rep_list tr th .rep_list_file .lbl_file input[type="file"],
.rep_list tr td .rep_list_file .lbl_file input[type="file"] {
  display: none;
}
.rep_list tr th .rep_list_file .lbl_file i,
.rep_list tr td .rep_list_file .lbl_file i {
  margin-right: 10px;
}
.rep_list tr th .rep_list_file .filename,
.rep_list tr td .rep_list_file .filename {
  line-height: 38px;
  padding: 0 0 0 10px;
  overflow: hidden;
  width: 160px;
  height: 40px;
  border-radius: 5px;
  border: 1px solid #ccc;
  margin-right: 5px;
  font-size: 14px;
  white-space: nowrap;
  text-overflow: ellipsis;
  cursor: pointer;
}
.rep_list tr th .rep_list_file .filename.hide,
.rep_list tr td .rep_list_file .filename.hide {
  display: none;
}
.rep_list tr th button,
.rep_list tr td button,
.rep_list tr th .btn_rep_list,
.rep_list tr td .btn_rep_list {
  display: block;
  outline: none;
  border: none;
  background: #57A87B url(../img/icon_btn_next.svg) no-repeat right 10px center;
  color: #FFF;
  border-radius: 5px;
  padding-right: 15px;
  width: 120px;
  height: 40px;
  line-height: 40px;
  text-decoration: none;
  text-align: center;
  font-size: 16px;
  transition: all 0.2s;
  font-weight: bold;
  cursor: pointer;
}
.rep_list tr th button i,
.rep_list tr td button i,
.rep_list tr th .btn_rep_list i,
.rep_list tr td .btn_rep_list i {
  margin-right: 10px;
}
.rep_list tr th button:hover,
.rep_list tr td button:hover,
.rep_list tr th .btn_rep_list:hover,
.rep_list tr td .btn_rep_list:hover {
  background: darkgreen url(../img/icon_btn_next.svg) no-repeat right 10px center;
}
.rep_list tr th button:disabled,
.rep_list tr td button:disabled,
.rep_list tr th .btn_rep_list:disabled,
.rep_list tr td .btn_rep_list:disabled {
  cursor: auto;
  background: #ccc;
  color: #999;
}
.member_info {
  margin-bottom: 50px;
  border-top: 1px solid #CAC3B7;
}
.member_info div {
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid #CAC3B7;
  padding: 20px 0;
}
.member_info div dt {
  width: 200px;
  padding: 0 20px;
}
.member_info div dd {
  width: calc(100% - 200px);
  padding-right: 20px;
  line-height: 24px;
}
.member_info div dd label {
  display: block;
  margin-bottom: 5px;
}
.member_info div.form dt {
  padding-top: 6.5px;
}
.member_info div.password dd input {
  margin-bottom: 10px;
}
.member_info div.password dd input:last-child {
  margin-bottom: 0;
}
.tanto_list {
  width: 100%;
  margin-bottom: 50px;
}
.tanto_list tr {
  transition: background 0.2s;
}
.tanto_list tr:hover {
  background: #D9D9D93B;
}
.tanto_list tr th {
  background: #FEF5E6;
  text-align: left;
}
.tanto_list tr td {
  border-bottom: 1px solid #CAC3B7;
  cursor: pointer;
}
.tanto_list tr td:last-child {
  width: 45px;
}
.tanto_list tr th,
.tanto_list tr td {
  padding: 15px 20px;
}
.box_search {
  background: #F8F7F7;
  padding: 24px 15px;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .box_search {
    padding: 30px 20px;
  }
}
.box_search_date {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 0 15px;
  border-bottom: 1px solid #E8E8E8;
}
@media screen and (max-width: 374px) {
  .box_search_date {
    padding: 0;
  }
}
.box_search_date p {
  margin: 0 10px 10px;
}
@media screen and (max-width: 374px) {
  .box_search_date p {
    margin: 0 5px 10px;
  }
}
.box_search_date .select {
  margin-bottom: 10px;
}
.box_search_date .year {
  width: 100px;
}
.box_search_date .month {
  width: 80px;
}
.box_search_date .pref {
  width: 180px;
}
.box_search dl {
  padding: 10px 15px;
  border-bottom: 1px solid #E8E8E8;
  margin-bottom: 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
@media screen and (max-width: 500px) {
  .box_search dl {
    display: block;
  }
}
@media screen and (max-width: 374px) {
  .box_search dl {
    padding: 10px 0;
  }
}
.box_search dl dt {
  font-size: 18px;
  margin-right: 20px;
}
@media screen and (max-width: 500px) {
  .box_search dl dt {
    margin: 0 0 10px;
  }
}
.box_search dl dd {
  flex: 1;
}
@media screen and (max-width: 500px) {
  .box_search dl dd {
    width: 100%;
  }
}
.box_search dl dd input {
  width: 100%;
}
.box_search .btn_search {
  margin: 0 auto;
  display: block;
  width: 140px;
  height: 40px;
  color: #FFF;
  text-align: center;
  line-height: 40px;
  font-size: 18px;
  font-weight: bold;
  background: #333333 url(../img/btn_search.svg) no-repeat left 20px center;
  background-size: 22px 22px;
  outline: none;
  border: none;
  transition: all 0.2s;
  padding-left: 30px;
  cursor: pointer;
  border-radius: 3px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  text-decoration: none;
}
.box_search .btn_search:hover {
  opacity: 0.7;
}
.box_num {
  text-align: center;
  margin-bottom: 10px;
}
.step_hd {
  font-size: 20px;
  font-weight: normal;
  margin-bottom: 20px;
  line-height: 1.3;
}
.step_hd span {
  border-top: 1px solid #F39500;
  border-bottom: 1px solid #F39500;
}
.step {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.step li {
  width: calc((100% - 180px) / 5);
  height: 55px;
  margin-right: 45px;
  position: relative;
}
.step li:after {
  content: "";
  position: absolute;
  top: 50%;
  right: -37px;
  display: block;
  width: 27px;
  height: 38px;
  background: url(../img/bg_step.svg) no-repeat center center;
  margin-top: -19px;
}
.step li:last-child {
  margin-right: 0;
}
.step li:last-child:after {
  display: none;
}
.step li a {
  padding: 0 15px;
  width: 100%;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  color: #333;
  pointer-events: none;
  border: 1px solid #C4C4C4;
}
@media screen and (max-width: 768px) {
  .step li a {
    padding: 0 10px 0 0;
    text-align: center;
  }
}
.step li a.active {
  color: #FFF;
  background-color: #F8A129;
  border: none;
}
.step li a.active span {
  display: inline;
  margin-right: 4px;
}
@media screen and (max-width: 768px) {
  .step li a.active span {
    display: none;
  }
}
.step li a.back {
  color: #FFF;
  background-color: #F8A129;
  border: none;
  pointer-events: inherit;
}
.step li a.disabled {
  background: #ccc;
  color: #999;
  text-decoration: line-through;
}
.step li:last-child a {
  background-image: none;
}
@media screen and (max-width: 768px) {
  .step li:last-child a {
    padding: 0;
  }
}
.lbl_step {
  font-size: 14px;
  font-weight: bold;
  color: #F8A129;
  margin-bottom: 6px;
}
.lbl_step span {
  font-size: 10px;
  font-weight: normal;
  color: #0A0A0A;
}
.btn_area {
  margin-top: 60px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.btn_area .btn_cmn {
  width: 360px;
  margin-right: 180px;
}
.btn_area .btn_cmn:last-child {
  margin-right: 0;
}
#template_parts_input {
  display: none;
}
.box_input {
  background: #F8F7F7;
  padding: 0px 15px;
  margin-bottom: 40px;
}
.box_input dl.pl {
  padding: 0 15px;
}
.box_input dl .row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 15px 15px;
  border-bottom: 1px solid #E8E8E8;
}
.box_input dl .row.plain {
  padding: 20px 15px;
}
.box_input dl .row.hide {
  display: none;
}
.box_input dl .row:last-child {
  border-bottom: none;
}
@media screen and (max-width: 768px) {
  .box_input dl .row {
    display: block;
  }
}
.box_input dl .row span {
  margin: 0 5px;
}
.box_input dl .row span:first-child {
  margin-left: 0;
}
.box_input dl .row dt {
  width: 250px;
}
@media screen and (max-width: 768px) {
  .box_input dl .row dt {
    width: 100%;
    margin-bottom: 6px;
  }
}
.box_input dl .row dd {
  width: calc(100% - 250px);
}
@media screen and (max-width: 768px) {
  .box_input dl .row dd {
    width: 100%;
  }
}
.box_input.white {
  background: transparent;
  margin-bottom: 60px;
}
.box_input.white dl {
  margin-bottom: 20px;
}
.box_input.white dl .row:last-child {
  border-bottom: 1px solid #E8E8E8;
}
.box_input.white dl .row dt {
  font-weight: bold;
}
.box_input.type02 {
  background: transparent;
}
.box_input.type02 dl .row {
  padding-top: 0;
  display: block;
}
.box_input.type02 dl .row dt {
  margin-bottom: 15px;
}
.box_input .del_area {
  text-align: right;
  margin-top: 10px;
}
.box_input:first-child .del_area {
  display: none;
}
.box_complete {
  width: 100%;
  height: 280px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #F4F4F4;
}
.box_complete span {
  font-size: 24px;
  border-bottom: 1px solid #F39500;
}
.box_complete.green span {
  border-bottom: 1px solid #57A87B;
}
.box_design {
  border: 2px solid #F39500;
  position: relative;
  padding: 60px 50px;
}
.box_design .hd {
  font-size: 20px;
  background: #FFF;
  width: 400px;
  text-align: center;
  line-height: 30px;
  position: absolute;
  top: -15px;
  left: 50%;
  margin-left: -200px;
}
.box_design .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
.box_design .flex div {
  text-align: center;
}
.box_message {
  padding: 20px;
  border: 1px solid #000;
  margin-bottom: 40px;
  position: relative;
}
.box_message .hd {
  position: absolute;
  display: inline-block;
  background: #FFF;
  height: 30px;
  line-height: 30px;
  top: -15px;
  left: 20px;
  padding: 0 20px;
}
.box_message .hd i {
  margin-right: 10px;
  color: #999;
}
.rep_list_flex {
  margin-bottom: 30px;
}
.rep_list_flex .head {
  display: flex;
  flex-wrap: wrap;
}
.rep_list_flex .head p {
  background: rgba(87, 168, 123, 0.1);
  text-align: center;
  font-size: 14px;
  margin: 0!important;
  height: 40px;
  line-height: 40px;
  font-weight: bold;
}
.rep_list_flex .head p:nth-child(1) {
  width: 100px;
}
.rep_list_flex .head p:nth-child(2) {
  width: calc(62% - 50px);
}
.rep_list_flex .head p:nth-child(3) {
  width: calc(38% - 50px);
}
.rep_list_flex .body {
  display: flex;
  flex-wrap: wrap;
  padding: 15px 0 15px 10px;
  border-bottom: 1px solid #CAC3B7;
  cursor: pointer;
}
.rep_list_flex .body:hover {
  background: #D9D9D93B;
}
.rep_list_flex .body p {
  margin: 0;
}
.rep_list_flex .body .aid {
  width: 100px;
}
.rep_list_flex .body .desc {
  width: calc(100% - 105px);
  overflow-y: hidden;
}
.rep_list_flex .body .row1 {
  display: flex;
  flex-wrap: wrap;
}
.rep_list_flex .body .row1 .name {
  width: 62%;
}
.rep_list_flex .body .row1 .address {
  width: 38%;
}
.rep_list_flex .body .row2 {
  padding-top: 15px;
  display: flex;
  flex-wrap: wrap;
  transition: all 0.4s;
}
.rep_list_flex .body .row2.hide {
  height: 0;
  padding: 0;
}
.rep_list_flex .body .row2 .col {
  width: calc(100% - 255px);
  margin-right: 5px;
}
.rep_list_flex .body .row2 .col .row21 {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 5px;
}
.rep_list_flex .body .row2 .col .row21 input,
.rep_list_flex .body .row2 .col .row21 .select {
  width: calc((100% - 140px) / 2);
  margin-right: 5px;
}
.rep_list_flex .body .row2 .col .row21 .datepicker {
  width: 130px;
}
.rep_list_flex .body .row2 .col .row22 {
  display: flex;
  flex-wrap: wrap;
}
.rep_list_flex .body .row2 .col .row22 .select {
  width: calc((100% - 250px) / 3);
  margin-right: 5px;
}
.rep_list_flex .body .row2 .col .row22 .height {
  width: 100px;
  margin-right: 5px;
}
.rep_list_flex .body .row2 .col .row22 .area {
  width: 130px;
}
.rep_list_flex .body .row2 .rep_btns {
  display: flex;
  flex-wrap: wrap;
  width: 245px;
}
.rep_list_flex .body .row2 .rep_btns .lbl_file {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: auto;
  border-radius: 5px;
  border: 1px solid #57A87B;
  color: #57A87B;
  margin-right: 5px;
  padding-right: 0;
  background: #FFF;
  transition: all 0.2s;
  cursor: pointer;
}
.rep_list_flex .body .row2 .rep_btns .lbl_file.hide {
  display: none;
}
.rep_list_flex .body .row2 .rep_btns .lbl_file:hover {
  background: #57A87B;
  color: #FFF;
}
.rep_list_flex .body .row2 .rep_btns .lbl_file input[type="file"] {
  display: none;
}
.rep_list_flex .body .row2 .rep_btns .lbl_file i {
  margin-right: 10px;
}
.rep_list_flex .body .row2 .rep_btns .filename {
  line-height: 38px;
  padding: 0 0 0 10px;
  overflow: hidden;
  width: 160px;
  height: auto;
  border-radius: 5px;
  border: 1px solid #ccc;
  margin-right: 5px;
  font-size: 14px;
  white-space: nowrap;
  text-overflow: ellipsis;
  cursor: pointer;
}
.rep_list_flex .body .row2 .rep_btns .filename.hide {
  display: none;
}
.rep_list_flex .body .row2 .rep_btns button {
  outline: none;
  border: none;
  background: #57A87B;
  color: #FFF;
  border-radius: 5px;
  width: 80px;
  height: auto;
  font-size: 16px;
  transition: all 0.2s;
  cursor: pointer;
}
.rep_list_flex .body .row2 .rep_btns button i {
  margin-right: 10px;
}
.rep_list_flex .body .row2 .rep_btns button:hover {
  background: darkgreen;
}
.rep_list_flex .body .row2 .rep_btns button:disabled {
  cursor: auto;
  background: #ccc;
  color: #999;
}
