.sub_title {
  font-size: 3.125rem;
}

.sub_fo {
  font-size: 2.5rem;
}

.sub_small {
  font-size: 0.875rem;
}

.sub_fox {
  font-size: 1.875rem;
}

.sib_his {
  font-size: 2.1875rem;
}

.s_txt {
  font-size: 1.5625rem;
}

.sub_tex {
  font-size: 1.375rem;
}

.s_nomal {
  font-size: 1.25rem;
}

.sub_p {
  font-size: 1.125rem;
}

#sub_contents {
  padding-top: 150px;
}
#sub_contents .inner {
  width: 73%;
}
#sub_contents .tab {
  display: flex;
  justify-content: flex-start;
  margin: 50px 0;
  flex-wrap: wrap;
}
#sub_contents .tab li {
  padding: 0 40px 0 0;
  position: relative;
}
#sub_contents .tab li.hole:after {
  right: 7%;
}
#sub_contents .tab li:after {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  background: #858585;
  border-radius: 100px;
  position: absolute;
  top: 50%;
  right: 13%;
  transform: translate(0, -50%);
}
#sub_contents .tab li:last-child {
  margin: 0;
}
#sub_contents .tab li:last-child:after {
  display: none;
}
#sub_contents .tab li a {
  font-weight: 600;
  color: #858585;
}
#sub_contents .tab li.active a {
  color: #0099FF;
}

.customsub p {
  margin: 50px 0;
}

.about_area {
  background: url("/img/about_bg.jpg") no-repeat center/cover;
  width: 100%;
}
.about_area .txt {
  padding: 100px 100px 50px 100px;
}
.about_area .txt p {
  color: #2D2D2D;
  margin: 50px 0;
  font-weight: 600;
}
.about_area .ceo_area {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 50px 0 0;
}
.about_area .ceo_area span {
  margin: 0 20px 0 0;
}

.history_area, .patent_area {
  background: url("/img/history_bg.jpg") no-repeat center/cover;
  width: 100%;
  height: 485px;
}
.history_area .txt, .patent_area .txt {
  color: #fff;
  padding: 0 100px;
  display: flex;
  justify-content: center;
  height: 100%;
  flex-direction: column;
}
.history_area .txt h3, .patent_area .txt h3 {
  margin: 0 0 10px 0;
}

.business_area {
  background: url("/img/business_bg.jpg") no-repeat center/cover;
  width: 100%;
  height: 485px;
}
.business_area .txt {
  color: #fff;
  padding: 0 100px;
  display: flex;
  justify-content: center;
  height: 100%;
  flex-direction: column;
}
.business_area .txt h3 {
  margin: 0 0 10px 0;
}

#about01 {
  width: 50%;
  margin: 150px auto 10%;
}
#about01 .cho {
  position: relative;
  width: 80%;
  max-width: 750px;
  margin: 0 auto;
}
#about01 .cho .max01 {
  width: 100%;
  height: 0;
  padding-bottom: 98%;
  border-radius: 100%;
  margin: 0 auto;
  border: 8px solid #E1CBCB;
}
#about01 .cho .max02 {
  background: #EAEFFB;
  width: 74%;
  height: 0;
  padding-bottom: 73.34%;
  border-radius: 100%;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#about01 .cho .max03 {
  width: 48%;
  border-radius: 100%;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#about01 .cho .sv_box {
  position: relative;
}
#about01 .cho .balance {
  position: absolute;
  top: 5%;
  left: -142px;
  width: 38%;
}
#about01 .cho .balance svg {
  position: relative;
  width: 100%;
}
#about01 .cho .balance .box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
#about01 .cho .balance span {
  margin: 15px 0 0;
  font-weight: 600;
}
#about01 .cho .balance .s_txt {
  color: #0099FF;
  font-weight: 600;
}
#about01 .cho .speed {
  position: absolute;
  top: 5%;
  right: -142px;
  width: 38%;
}
#about01 .cho .speed svg {
  position: relative;
  width: 100%;
}
#about01 .cho .speed .box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
#about01 .cho .speed span {
  margin: 15px 0 0;
  font-weight: 600;
}
#about01 .cho .speed .s_txt {
  color: #FF0000;
  font-weight: 600;
}
#about01 .cho .being {
  position: absolute;
  bottom: -200px;
  left: 50%;
  transform: translate(-50%, 0);
  width: 38%;
}
#about01 .cho .being svg {
  position: relative;
  width: 100%;
}
#about01 .cho .being .box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
#about01 .cho .being span {
  margin: 15px 0 0;
  font-weight: 600;
}
#about01 .cho .being .s_txt {
  font-weight: 600;
  color: #0C6638;
}

#about02 .inner {
  padding: 100px;
}
#about02 li {
  padding: 30px 0;
  border-bottom: 1px solid #ddd;
}
#about02 li:last-child {
  border-bottom: 0;
  padding: 30px 0 0;
}
#about02 .detail {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#about02 .detail figure {
  width: 45%;
}
#about02 .detail .tit {
  width: 45%;
  color: #2D2D2D;
}
#about02 .detail .tit .s_txt {
  display: block;
  margin: 0 0 10px 0;
}
#about02 .detail .tit p {
  display: flex;
}
#about02 .detail .tit p span:first-child {
  width: 20px;
}
#about02 .detail .tit p span:last-child {
  width: 100%;
}

#history01 {
  background: url("/img/history_bg02.png") no-repeat right bottom/670px auto;
  width: 100%;
}
#history01 .inner {
  padding: 100px;
}
#history01 .div {
  position: relative;
  display: flex;
}
#history01 .div.last ol:before {
  display: none;
}
#history01 .div h2 {
  width: 120px;
  color: #5F86D1;
  margin: 0 50px 0 0;
}
#history01 .div ol {
  position: relative;
  width: 100%;
  padding: 15px 0 50px 100px;
  color: #00143B;
  font-weight: 600;
}
#history01 .div ol li {
  margin: 0 0 10px 0;
}
#history01 .div ol::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 25px;
  width: 2px;
  height: 100%;
  background: #5F86D1;
}
#history01 .div ol:after {
  content: "";
  position: absolute;
  left: 0;
  top: 25px;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 100%;
  background: #5F86D1;
  border: 5px solid #5F86D1;
  box-sizing: border-box;
}

#patent01 .th_box {
  padding: 100px;
}
#patent01 .th_box ul {
  display: flex;
  flex-wrap: wrap;
}
#patent01 .th_box ul li {
  width: 15%;
  margin: 0 2% 2% 0;
}
#patent01 .th_box ul li:nth-of-type(6n) {
  margin: 0 0 2% 0;
}

#location01 .map_area {
  display: flex;
  justify-content: space-between;
  margin: 100px;
}
#location01 .map_area .map_box {
  width: 60%;
}
#location01 .map_area .map_box .root_daum_roughmap {
  width: 100% !important;
}
#location01 .map_area .map_box .root_daum_roughmap .wrap_map {
  height: 650px !important;
}
#location01 .map_area .address {
  width: 40%;
  margin: 0 0 0 5%;
}
#location01 .map_area .address h3 {
  position: relative;
  font-weight: 500 !important;
  padding: 0 0 10px 0;
}
#location01 .map_area .address h3:before {
  content: "";
  display: block;
  width: 300px;
  background: #858585;
  height: 2px;
  position: absolute;
  bottom: 0;
  left: 0;
}
#location01 .map_area .address h3:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 150px;
  background: #858585;
  height: 10px;
}
#location01 .map_area .address ul {
  margin: 30px 0 0;
}
#location01 .map_area .address li {
  display: flex;
  margin: 0 0 20px 0;
}
#location01 .map_area .address li .letter {
  letter-spacing: 16px;
}
#location01 .map_area .address li .mar {
  padding: 0 10px;
}

#business01 .diagram {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 100px 0;
}
#business01 .diagram h3 {
  position: relative;
  padding: 0 0 20px 0;
}
#business01 .diagram h3:after {
  content: "";
  display: inline-block;
  width: 130px;
  height: 5px;
  background: #0099FF;
  position: absolute;
  bottom: 0;
  left: 0;
}
#business01 .diagram p {
  margin: 20px 0 0;
}
#business01 .diagram figure {
  width: 50%;
  margin: 0 5% 0 0 !important;
}
#business01 .diagram .txt {
  width: 50%;
}

#business02 {
  background: #EDF7FF;
  padding: 100px 0;
  text-align: center;
}
#business02 h3 {
  margin: 0 0 10px 0;
}
#business02 .total_box {
  display: flex;
  justify-content: space-between;
}
#business02 .bubble strong {
  color: #0099FF;
  border-radius: 100%;
  background: #fff;
  display: inline-block;
  padding: 25px 30px;
  font-weight: 800;
  box-shadow: 0px 0px 0px 10px rgba(255, 255, 255, 0.5);
}
#business02 .table_area {
  position: relative;
  padding: 50px;
}
#business02 table {
  width: 100%;
  border-bottom: 1px solid #707070;
  margin: 0 0 70px 0;
}
#business02 table th {
  background: #fff;
  padding: 25px 0;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
}
#business02 table th.box {
  border-top: 0;
  border-top: 5px solid #0099FF;
  border-left: 5px solid #0099FF;
  border-right: 5px solid #0099FF;
}
#business02 table td {
  padding: 20px 0;
  font-weight: 600;
}
#business02 table td.box {
  border: 0;
  border-left: 5px solid #0099FF;
  border-right: 5px solid #0099FF;
}
#business02 table td.box.last {
  border-bottom: 5px solid #0099FF;
  position: relative;
}
#business02 table td.box.last:before {
  content: "";
  position: absolute;
  bottom: -60px;
  right: 50%;
  width: 2px;
  height: 60px;
  background: #0099FF;
}
#business02 table td.box.last:after {
  position: absolute;
  right: 50%;
  bottom: -56px;
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid #0099FF;
  border-right: 2px solid #0099FF;
  transform: rotate(135deg) translate(0, -50%);
}
#business02 .b_txt {
  text-align: left;
  margin: 0 5% 0 0;
  line-height: 1.8;
}
#business02 .b_txt h4 {
  color: #FF0000;
}
#business02 .b_txt div {
  font-weight: 600;
  color: #81A1FF;
}

#business03 {
  text-align: center;
  padding: 100px 0;
}
#business03 h3 {
  margin: 0 0 10px 0;
}
#business03 ul {
  display: flex;
  justify-content: space-between;
  margin: 100px 0 0;
}
#business03 ul li {
  width: 50%;
}
#business03 ul li:first-child {
  margin: 0 5% 0 0;
}
#business03 ul li b {
  color: #0099FF;
  display: block;
  margin: 0 0 20px 0;
}
#business03 ul li .box {
  background: #F8F8F8;
  border-radius: 40px;
  padding: 50px;
  height: 350px;
  display: flex;
  flex-direction: column;
  align-items: start;
  flex-wrap: wrap;
  justify-content: center;
}
#business03 ul li .box p {
  text-align: left;
  display: flex;
  margin: 0 0 15px 0;
}
#business03 ul li .box p:last-child {
  margin: 0;
}
#business03 ul li .box p span {
  width: 100%;
}
#business03 ul li .box p span:first-child {
  width: 20px;
}

#business04 {
  background: #EDF7FF;
  padding: 100px 0;
}
#business04 h3 {
  text-align: center;
  color: #0099FF;
  margin: 0 0 50px 0;
}
#business04 h4 {
  color: #373737;
  margin: 0 0 20px 0;
}
#business04 .table_area {
  margin: 0 0 50px 0;
}
#business04 .table_area.last {
  margin: 0;
}
#business04 .table_area table {
  width: 100%;
}
#business04 .table_area table th {
  padding: 20px 50px;
  background: #0099FF;
  color: #fff;
  width: 200px;
}
#business04 .table_area table td {
  border-top: 1px solid #707070;
  display: flex;
  width: 100%;
  padding: 20px 0 20px 10%;
  /* text-align: center; */
  justify-content: center;
  flex-direction: column;
  flex-wrap: wrap;
}
#business04 .table_area table td ol {
  display: flex;
  align-items: center;
}
#business04 .table_area table td ol li {
  width: 13%;
  text-align: center;
  min-width: 180px;
}
#business04 .table_area table td ol li .top {
  background: rgba(146, 157, 165, 0.5);
  color: #fff;
  border-radius: 0 20px 0 0;
  padding: 10px;
  font-weight: 600;
}
#business04 .table_area table td ol li .row {
  background: #62BFFE;
  color: #fff;
  padding: 10px;
  border-radius: 0 0 0 20px;
  font-weight: 600;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#business04 .table_area table td ol li.arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  min-width: 12px;
  border: 0;
  transform: rotate(-45deg);
  background: none;
}
#business04 .table_area table td ol li.arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  left: 0;
  position: absolute;
  top: 0;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
}
#business04 .table_area table td p {
  display: flex;
}
#business04 .table_area table td p.mar {
  margin: 0 0 20px 0;
}
#business04 .table_area table td p span {
  width: 100%;
}
#business04 .table_area table td p span:first-child {
  width: 20px;
}
#business04 .table_area table tr:last-child td {
  border-bottom: 1px solid #707070;
}
#business04 .procedure {
  padding: 100px 0 30px;
}
#business04 .procedure .m_first {
  display: none;
}
#business04 .procedure h3 {
  margin: 0 0 100px 0;
}
#business04 .procedure .first {
  display: flex;
  justify-content: space-between;
}
#business04 .procedure .first .deps01 {
  position: relative;
}
#business04 .procedure .first .deps_arrow {
  display: flex;
  align-items: center;
}
#business04 .procedure .first .deps_arrow .arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  border: 0;
  background: none;
  padding: 0;
}
#business04 .procedure .first .deps_arrow .arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  position: absolute;
  top: 50%;
  right: -50%;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
  transform: rotate(-45deg) translate(-50%, -50%);
}
#business04 .procedure .first .deps02 {
  margin: 0 10% 0 0;
}
#business04 .procedure .first .deps02 li {
  background: #81A1FF;
}
#business04 .procedure .first ul {
  width: 300px;
  text-align: center;
}
#business04 .procedure .first li {
  text-align: center;
  background: #0099FF;
  color: #fff;
  border-radius: 0 20px 0 20px;
  padding: 20px 10px;
}
#business04 .procedure .first li.round {
  border: 10px solid #0099FF;
  border-radius: 0 20px 0 20px;
  padding: 20px;
  background: none;
  color: #000;
  font-weight: 600;
}
#business04 .procedure .first li.round2 {
  border: 10px solid #81A1FF;
  border-radius: 0 20px 0 20px;
  padding: 20px;
  background: none;
  color: #000;
  font-weight: 600;
}
#business04 .procedure .first li.round3 {
  border: 10px solid #858585;
  border-radius: 0 20px 0 20px;
  padding: 20px;
  background: none;
  color: #000;
  font-weight: 600;
}
#business04 .procedure .first li.arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  border: 0;
  transform: rotate(45deg);
  background: none;
  padding: 0;
}
#business04 .procedure .first li.arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  left: 0;
  position: absolute;
  top: 0;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
}
#business04 .procedure .first li.none {
  display: none;
}
#business04 .procedure .first li.arrow {
  border: 0;
}
#business04 .procedure .cen {
  display: flex;
  justify-content: space-between;
}
#business04 .procedure .cen .deps01 {
  margin: 0 10% 0 0;
}
#business04 .procedure .cen ul {
  width: 300px;
  text-align: center;
}
#business04 .procedure .cen ul:first-child {
  width: 61%;
  min-width: 580px;
}
#business04 .procedure .cen ul li {
  text-align: center;
  background-image: linear-gradient(to right, #0099FF, #81A1FF);
  color: #fff;
  border-radius: 0 20px 0 20px;
  padding: 20px 10px;
  position: relative;
}
#business04 .procedure .cen ul li.arrow {
  margin: 25px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  border: 0;
  transform: rotate(45deg);
  background: none;
}
#business04 .procedure .cen ul li.arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  left: 0;
  position: absolute;
  top: 0;
  width: 12px;
  border-color: transparent;
  border-bottom-color: red;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
}
#business04 .procedure .last {
  display: flex;
  justify-content: space-between;
}
#business04 .procedure .last .deps_arrow {
  display: flex;
  align-items: center;
  visibility: hidden;
}
#business04 .procedure .last .deps_arrow .arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  border: 0;
  background: none;
  padding: 0;
}
#business04 .procedure .last .deps_arrow .arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  position: absolute;
  top: 50%;
  right: -50%;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
  transform: rotate(-45deg) translate(-50%, -50%);
}
#business04 .procedure .last .deps02 {
  margin: 0 10% 0 0;
}
#business04 .procedure .last ul {
  text-align: center;
  width: 300px;
}
#business04 .procedure .last ul li {
  text-align: center;
  background: #0099FF;
  color: #fff;
  border-radius: 0 20px 0 20px;
  padding: 20px 10px;
}
#business04 .procedure .last ul li.arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  border: 0;
  padding: 0;
  transform: rotate(45deg);
  background: none;
}
#business04 .procedure .last ul li.arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  left: 0;
  position: absolute;
  top: 0;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
}
#business04 .procedure .bir {
  text-align: center;
  background-image: linear-gradient(to right, #0099FF, #81A1FF);
  color: #fff;
  border-radius: 0 20px 0 20px;
  padding: 30px 10px;
  position: relative;
  width: 100%;
  margin: 50px 0 0;
}
#business04 .procedure p {
  text-align: center;
  background: #0099FF;
  color: #fff;
  border-radius: 0 20px 0 20px;
  padding: 20px 10px;
  position: relative;
}
#business04 p.sub_tex {
  color: #FF0000;
  font-weight: 600;
  display: flex;
}
#business04 p.sub_tex span {
  width: 100%;
}
#business04 p.sub_tex span:first-child {
  width: 20px;
}

#business05 {
  padding: 100px 0;
  background: url("/img/history_bg.jpg") no-repeat center/cover;
  background-attachment: fixed;
  height: auto;
}
#business05 .title {
  color: #fff;
  text-align: center;
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin: 0 0 20px 0;
}
#business05 .title h3 {
  margin: 0 0 10px 0;
}
#business05 table {
  width: 100%;
}
#business05 table th {
  background: #ECECEC;
  padding: 30px 0;
  border-bottom: 2px solid #707070;
}
#business05 table th.top {
  border-bottom: 0;
}
#business05 table td {
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  border-right: 1px solid rgba(255, 255, 255, 0.3);
  padding: 20px 0;
  text-align: center;
}
#business05 table tr.none td {
  background: #000;
  border: 0;
  color: #0099FF;
  font-weight: 600;
}

#caution {
  padding: 100px 0;
}
#caution h3 {
  margin: 0 0 10px 0;
}
#caution .bor {
  border: 5px solid #FF0000;
  border-radius: 50px;
  padding: 50px 18%;
  margin: 0 100px;
}
#caution .bor ul {
  color: #000;
  line-height: 1.8;
  font-weight: 600;
}
#caution .bor ul p {
  display: flex;
}
#caution .bor ul p span {
  width: 100%;
}
#caution .bor ul p span:first-child {
  width: 25px;
}

.support_area {
  background: url("/img/support_bg.jpg") no-repeat center/cover;
  width: 100%;
  height: 485px;
}
.support_area .txt {
  color: #fff;
  padding: 0 100px;
  display: flex;
  justify-content: center;
  height: 100%;
  flex-direction: column;
}
.support_area .txt h3 {
  margin: 0 0 10px 0;
}

.energy_area {
  background: url("/img/energy_bg.jpg") no-repeat center/cover;
  width: 100%;
  height: 485px;
}
.energy_area .txt {
  color: #fff;
  padding: 0 100px;
  display: flex;
  justify-content: center;
  height: 100%;
  flex-direction: column;
}
.energy_area .txt h3 {
  margin: 0 0 10px 0;
}

.rps_area {
  background: url("/img/rps_bg.jpg") no-repeat center/cover;
  width: 100%;
  height: 485px;
}
.rps_area .txt {
  color: #fff;
  padding: 0 100px;
  display: flex;
  justify-content: center;
  height: 100%;
  flex-direction: column;
}
.rps_area .txt h3 {
  margin: 0 0 10px 0;
}

#support01 .diagram {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 100px 0;
}
#support01 .diagram h3 {
  position: relative;
  padding: 0 0 20px 0;
}
#support01 .diagram h3:after {
  content: "";
  display: inline-block;
  width: 130px;
  height: 5px;
  background: #0099FF;
  position: absolute;
  bottom: 0;
  left: 0;
}
#support01 .diagram p {
  margin: 20px 0 0;
}
#support01 .diagram figure {
  width: 50%;
  margin: 0 5% 0 0 !important;
}
#support01 .diagram .txt {
  width: 50%;
}

#support02 {
  margin: 0 0 100px 0;
}
#support02 .title {
  text-align: center;
}
#support02 .title h3 {
  margin: 0 0 10px 0;
}
#support02 .t_box {
  margin: 100px 0 0;
  text-align: center;
}
#support02 h4 {
  color: #0099FF;
  display: block;
  margin: 0 0 20px 0;
}
#support02 .box {
  background: #F8F8F8;
  border-radius: 40px;
  padding: 100px;
  display: flex;
  color: #373737;
  flex-direction: column;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}

#support03 {
  padding: 100px 0;
  background: #EDF8FF;
}
#support03 table {
  width: 100%;
  text-align: center;
  border-top: 1px solid #707070;
}
#support03 table th {
  background: #fff;
  padding: 30px 0;
  border-bottom: 1px solid #BDBDBD;
}
#support03 table th.right {
  border-right: 1px solid #BDBDBD;
}
#support03 table td {
  padding: 25px 0;
  border-bottom: 1px solid #BDBDBD;
  border-right: 1px solid #BDBDBD;
}
#support03 table td.last {
  border-right: 0;
  border-top: 1px solid #BDBDBD;
}

#support04 {
  margin: 100px 0;
  text-align: center;
}
#support04 ol {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
  margin: 50px 0 0;
}
#support04 li {
  width: 15%;
}
#support04 li b {
  display: block;
  background: #62BFFE;
  border: 5px solid #62BFFE;
  color: #fff;
  border-radius: 0 0 0 30px;
  padding: 20px 0px;
}
#support04 li span {
  display: block;
  padding: 30px 0px;
  border: 5px solid #62BFFE;
  font-weight: 600;
  border-radius: 0 30px 0 0;
}
#support04 li.arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  min-width: 12px;
  border: 0;
  transform: rotate(-45deg);
  background: none;
}
#support04 li.arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  left: 0;
  position: absolute;
  top: 0;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
}

#energy01 .diagram {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 100px 0;
}
#energy01 .diagram h3 {
  position: relative;
  padding: 0 0 20px 0;
}
#energy01 .diagram h3:after {
  content: "";
  display: inline-block;
  width: 130px;
  height: 5px;
  background: #0099FF;
  position: absolute;
  bottom: 0;
  left: 0;
}
#energy01 .diagram p.first {
  margin: 20px 0;
}
#energy01 .diagram figure {
  width: 50%;
  margin: 0 5% 0 0 !important;
}
#energy01 .diagram .txt {
  width: 50%;
}

#energy02 {
  margin: 0 0 100px 0;
}
#energy02 .title {
  text-align: center;
}
#energy02 .title h3 {
  margin: 0 0 10px 0;
}
#energy02 .t_box {
  margin: 100px 100px 0;
  text-align: center;
}
#energy02 h4 {
  color: #0099FF;
  display: block;
  margin: 0 0 20px 0;
}
#energy02 .box {
  background: #F8F8F8;
  border-radius: 40px;
  padding: 100px 200px;
  display: flex;
  color: #373737;
  flex-direction: column;
  align-items: start;
  flex-wrap: wrap;
  justify-content: start;
  text-align: left;
}
#energy02 .box p {
  font-weight: 600;
  display: flex;
}
#energy02 .box p.for {
  margin: 0 0 20px 0;
}
#energy02 .box p span {
  width: 100%;
}
#energy02 .box p span:first-child {
  width: 25px;
}

#energy03 {
  padding: 100px 0;
  background: #EDF8FF;
}
#energy03 .table_area {
  margin: 0 100px;
}
#energy03 table {
  width: 100%;
  border-top: 1px solid #BDBDBD;
}
#energy03 table th {
  padding: 20px 50px;
  background: #0099FF;
  color: #fff;
  width: 200px;
}
#energy03 table td {
  padding: 25px 0;
  border-bottom: 1px solid #BDBDBD;
  padding: 20px 0 20px 10%;
  font-weight: 600;
}
#energy03 table td.last {
  border-right: 0;
  border-top: 1px solid #BDBDBD;
}
#energy03 .process {
  padding: 100px 100px 0;
}
#energy03 .process h4 {
  text-align: center;
  color: #0099FF;
}
#energy03 .process ol {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
  margin: 50px 0 0;
}
#energy03 .process li {
  width: 15%;
}
#energy03 .process li .box {
  text-align: center;
}
#energy03 .process li b {
  display: block;
  background: #62BFFE;
  border: 5px solid #62BFFE;
  color: #000;
  border-radius: 0 0 0 30px;
  padding: 20px 0px;
  height: 115px;
}
#energy03 .process li span {
  display: block;
  padding: 30px 0px;
  border: 5px solid #62BFFE;
  font-weight: 600;
  border-radius: 0 30px 0 0;
}
#energy03 .process li.arrow {
  margin: 15px;
  display: inline-block;
  height: 12px;
  position: relative;
  width: 12px;
  min-width: 12px;
  border: 0;
  transform: rotate(-45deg);
  background: none;
}
#energy03 .process li.arrow:after {
  content: "";
  display: inline-block;
  height: 12px;
  left: 0;
  position: absolute;
  top: 0;
  width: 12px;
  border-color: transparent;
  border-bottom-color: #0099FF;
  border-style: solid;
  border-width: 0 0 12px 12px;
  height: 0;
  width: 0;
}
#energy03 .b_row {
  display: flex;
  align-items: center;
  margin: 100px 100px 0;
}
#energy03 .b_row h5 {
  margin: 0 7% 0 0;
}
#energy03 .b_row p {
  color: #FF0000;
  font-weight: 600;
}

#energy04 {
  padding: 100px 100px 0;
}
#energy04 h4 {
  text-align: center;
  color: #0099FF;
  margin: 0 0 50px 0;
}
#energy04 li {
  margin: 0 0 30px 0;
}
#energy04 li:last-child {
  margin: 0;
}
#energy04 li:last-child .box .txt b {
  width: 100%;
}
#energy04 .box {
  display: flex;
  align-items: center;
}
#energy04 .box .num01 {
  background: #0099FF;
  color: #fff;
  font-weight: 600;
  border-radius: 100%;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#energy04 .box .num02 {
  background: #0687DC;
  color: #fff;
  border-radius: 100%;
  font-weight: 600;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#energy04 .box .num03 {
  background: #04609E;
  color: #fff;
  border-radius: 100%;
  font-weight: 600;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#energy04 .box .txt {
  display: flex;
  align-items: center;
  background: #ECEAEA;
  border-radius: 40px;
  padding: 30px 50px;
  width: 100%;
  color: #373737;
}
#energy04 .box .txt p {
  display: flex;
  flex-direction: column;
  line-height: 2;
}
#energy04 .box .txt b {
  width: 200px;
  margin: 0 30px 0 0;
}

#rps01 .diagram {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 100px 0;
}
#rps01 .diagram h3 {
  padding: 0 0 10px 0;
}
#rps01 .diagram .txt {
  width: 50%;
  margin: 0 5% 0 0;
}
#rps01 .diagram .num_box {
  width: 50%;
}
#rps01 .diagram .num_box li {
  display: flex;
  align-items: center;
}
#rps01 .diagram .num_box li p {
  font-weight: 600;
}
#rps01 .diagram .num_box li .num01 {
  background: #0099FF;
  color: #fff;
  font-weight: 600;
  border-radius: 100%;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#rps01 .diagram .num_box li .num02 {
  background: #0687DC;
  color: #fff;
  border-radius: 100%;
  font-weight: 600;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#rps01 .diagram .num_box li .num03 {
  background: #04609E;
  color: #fff;
  border-radius: 100%;
  font-weight: 600;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#rps01 .diagram .num_box li .num04 {
  background: #012034;
  color: #fff;
  border-radius: 100%;
  font-weight: 600;
  width: 90px;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 90px;
  margin: 0 3% 0 0;
}
#rps01 .diagram figure {
  width: 50%;
  margin: 0 5% 0 0 !important;
}
#rps01 .diagram .txt {
  width: 50%;
}

#rps02 {
  background: url("/img/rps_img01.jpg") no-repeat center/cover;
  width: 100%;
  padding: 100px 0;
}
#rps02 .title {
  text-align: center;
}
#rps02 .tree {
  display: flex;
  justify-content: center;
  margin: 50px 0 0;
  position: relative;
}
#rps02 .tree .big_line {
  width: 100%;
  height: 2px;
  position: absolute;
  top: 26%;
  background: #000;
}
#rps02 .tree .step {
  position: relative;
  width: 20%;
}
#rps02 .tree .step:after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #000;
  position: absolute;
  top: 62px;
  left: 50%;
}
#rps02 .tree .step.step01 .line2 {
  left: 57px;
}
#rps02 .tree .step.step07:after {
  display: none;
}
#rps02 .tree .step b {
  color: #0099FF;
  display: block;
  text-align: center;
  margin: 0 0 20px 0;
}
#rps02 .tree .step p {
  color: #000;
  font-weight: 600;
  text-align: center;
  margin: 100px 0 0;
}
#rps02 .tree .step .line {
  background: #0099FF;
  border: 3px solid #000;
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  margin: 0 auto;
  position: relative;
}
#rps02 .tree .step .line:before {
  content: "";
  border-style: none none none dashed;
  height: 85px;
  width: 1px;
  position: absolute;
  left: 0;
  top: 0;
}
#rps02 .tree .step .line2 {
  border-style: none none none dashed;
  height: 85px;
  width: 1px;
  position: relative;
  left: 7px;
  display: none;
}

#rps03 {
  margin: 100px 0;
}
#rps03 .title {
  text-align: center;
}
#rps03 ul {
  display: flex;
  justify-content: space-between;
  margin: 150px 150px 0;
}
#rps03 ul li {
  width: 300px;
  margin: 0 5% 0 0;
}
#rps03 ul li:last-child {
  margin: 0;
}
#rps03 ul li .bo_box {
  position: relative;
}
#rps03 ul li .bo_box i {
  background: #fff;
  position: absolute;
  top: -65px;
  left: 50%;
  transform: translate(-50%);
}
#rps03 ul li .bo_box .txt {
  position: absolute;
  left: 0;
  width: 100%;
  top: 50%;
  padding: 15px 0;
}
#rps03 ul li .bo_box .txt b {
  display: block;
  margin: 0 0 20px 0;
}
#rps03 ul i {
  width: 200px;
  height: 200px;
  border: 5px solid #0099FF;
  display: block;
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
#rps03 ul .txt {
  text-align: center;
}

#rps04 {
  margin: 100px 0;
}
#rps04 .f_img {
  display: flex;
  margin: 0 100px;
}
#rps04 .f_img figure {
  margin: 0 5% 0 0 !important;
}
#rps04 .f_img figure:nth-child(2) {
  margin: 100px 5% 0 0 !important;
}
#rps04 .f_img figure:last-child {
  margin: 0 !important;
}

#rps05 {
  padding: 100px 0;
  background: url("/img/rps_img05.jpg") no-repeat center/cover;
  background-attachment: fixed;
  height: auto;
}
#rps05 .title {
  color: #fff;
  width: 50%;
  margin: 0 5% 0 0;
}
#rps05 .title h3 {
  margin: 0 0 10px 0;
  color: #0099FF;
}
#rps05 .title p {
  font-weight: 600;
}
#rps05 .title b {
  background: #0099FF;
}
#rps05 .inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#rps05 .inner .txt {
  width: 50%;
  background: rgba(82, 80, 79, 0.5);
  color: #fff;
  text-align: center;
  padding: 100px 50px;
}
#rps05 .inner .txt p:first-child {
  margin: 0 0 100px 0;
}

#rps06 {
  margin: 100px 0;
}
#rps06 ul {
  display: flex;
  justify-content: space-between;
}
#rps06 ul li {
  width: 50%;
}
#rps06 ul li:first-child {
  margin: 0 5% 0 0;
}
#rps06 ul .top {
  text-align: center;
}
#rps06 ul .top h3 {
  color: #0099FF;
  position: relative;
}
#rps06 ul .top h3:after {
  content: "";
  display: block;
  background: #0099FF;
  height: 5px;
  width: 80%;
  margin: 20px auto 30px;
}
#rps06 ul .txt {
  background: #DEF2FF;
  border-radius: 40px;
  padding: 30px;
}
#rps06 ul .txt p {
  font-weight: 600;
  margin: 0 0 30px 0;
  display: flex;
}
#rps06 ul .txt p span {
  width: 100%;
}
#rps06 ul .txt p span:first-child {
  width: 20px;
}
#rps06 ul .txt p:last-child {
  margin: 0;
}

#rps07 {
  background: #EDF7FF;
  padding: 100px;
}
#rps07 h3 {
  margin: 0 0 100px 0;
  text-align: center;
}
#rps07 table {
  width: 100%;
}
#rps07 table thead {
  border: 5px solid #0099FF;
}
#rps07 table thead th {
  background: #fff;
  width: 33.33%;
  padding: 30px 0;
}
#rps07 table tbody th {
  background: #F8F8F8;
  padding: 20px 0;
  font-weight: 600;
  border-bottom: 1px solid #CCCCCC;
}
#rps07 table tbody td {
  font-weight: 600;
  border-bottom: 1px solid #CCCCCC;
  text-align: center;
  padding: 20px 0;
}

#rps08 {
  margin: 100px 0;
}
#rps08 ul {
  display: flex;
  justify-content: space-between;
}
#rps08 ul li {
  width: 50%;
  text-align: center;
  position: relative;
}
#rps08 ul li:first-child {
  margin: 0 10% 0 0;
}
#rps08 ul li:last-child .txt {
  padding: 75px 50px;
}
#rps08 ul li i {
  position: relative;
  z-index: 1;
}
#rps08 ul li .box {
  background: #fff;
  border: 5px solid #21C0FF;
  margin-top: -100px;
}
#rps08 ul li .box .top {
  background: #21C0FF;
  position: relative;
  padding: 100px 0 30px;
}
#rps08 ul li .box .top:after {
  content: "";
  display: inline-block;
  height: 30px;
  position: absolute;
  width: 30px;
  border-color: transparent;
  border-bottom-color: #21C0FF;
  border-style: solid;
  border-width: 0 0 25px 25px;
  height: 0;
  width: 0;
  bottom: -11px;
  left: 50%;
  transform: rotate(45deg);
}
#rps08 ul li .txt {
  text-align: left;
  padding: 50px;
  font-weight: 600;
}

#rps09 {
  background: #EDF7FF;
  padding: 100px;
}
#rps09 h3 {
  margin: 0 0 100px 0;
  text-align: center;
}
#rps09 table {
  width: 100%;
}
#rps09 table thead {
  border: 5px solid #0099FF;
}
#rps09 table thead th {
  background: #fff;
  padding: 20px 0;
  border-right: 1px solid #CCCCCC;
}
#rps09 table thead th:last-child {
  border-right: 0;
}
#rps09 table thead th.bot {
  border-bottom: 1px solid #ccc;
}
#rps09 table tbody th {
  font-weight: 600;
  padding: 20px 0;
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}
#rps09 table tbody td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
  text-align: center;
  font-weight: 600;
  padding: 20px 0;
}
#rps09 table tbody td.last {
  border-right: 0;
}

#rps10 {
  margin: 100px 0;
  width: 73%;
}
#rps10 .title {
  margin: 0 0 50px 0;
}
#rps10 .title p {
  margin: 0 0 10px 0 !important;
  border: 0 !important;
  padding: 0 !important;
}
#rps10 .title h3 {
  line-height: 1.3;
}
#rps10 .rps_box {
  display: flex;
  align-items: center;
  text-align: center;
}
#rps10 .rps_box img {
  margin: 0 0 0 -10%;
}
#rps10 .rps_box p {
  font-weight: 800;
  border-bottom: 1px solid #ddd;
  padding: 0 0 20px 0;
  margin: 0 0 20px 0;
}
#rps10 .rps_box p:last-child {
  margin: 0;
  padding: 0;
  border: 0;
}
#rps10 .rps_box p b {
  background: #0099FF;
  color: #fff;
  padding: 5px;
}
#rps10 .rps_box p span {
  display: block;
  font-size: 1rem;
  margin: 20px 0 0;
}

#rps11 {
  background: #EDF7FF;
  padding: 100px;
}
#rps11 h3 {
  text-align: center;
  margin: 0 0 100px 0;
}
#rps11 .box {
  display: flex;
  align-items: center;
  margin: 0 0 50px 0;
}
#rps11 .box .txt {
  background: #0099FF;
  color: #fff;
  font-weight: 600;
  padding: 50px 50px 50px 12%;
  width: 100%;
  border-radius: 0 50px 50px 0;
  margin-left: -100px;
}
#rps11 .box i {
  width: 200px;
  height: 180px;
  background: #fff;
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: relative;
}
#rps11 .box i b {
  display: block;
  color: #28336E;
}

.contact_area {
  background: url("/img/contact_bg.jpg") no-repeat center/cover;
  width: 100%;
  height: 485px;
}
.contact_area .txt {
  color: #fff;
  padding: 0 100px;
  display: flex;
  justify-content: center;
  height: 100%;
  flex-direction: column;
}

#contact01 {
  margin: 100px 0;
}
#contact01 ul {
  display: flex;
  justify-content: space-between;
}
#contact01 ul li {
  color: #474747;
  width: 33.33%;
}
#contact01 ul li .txt b {
  display: block;
  margin: 0 0 10px 0;
}
#contact01 ul li.line {
  width: 1px;
  height: 100px;
  background: #474747;
  margin: 0 50px;
}
#contact01 .form_area {
  margin: 100px 0 0;
}
#contact01 .form_area form {
  text-align: center;
}
#contact01 .form_area form .tox {
  display: flex;
  justify-content: space-between;
  margin: 0 0 100px 0;
}
#contact01 .form_area form .cont {
  width: 34%;
}
#contact01 .form_area form .cont label {
  display: block;
  text-align: left;
}
#contact01 .form_area form .cont input {
  width: 100%;
  border: 0;
  border-bottom: 1px solid #707070;
  height: 45px;
  padding: 0 20px;
  margin: 0 0 30px 0;
}
#contact01 .form_area form .cont textarea {
  resize: none;
  width: 100%;
  height: 100px;
  padding: 20px;
  border: 0;
  border-bottom: 1px solid #707070;
}
#contact01 .form_area form .cont .agree {
  margin: 20px 0 0;
}
#contact01 .form_area form .cont .agree input {
  width: 20px;
  height: 20px;
  margin: 0 10px 0 0;
}
#contact01 .form_area form .cont .agree label {
  display: flex;
  align-items: center;
}
#contact01 .form_area form button {
  background: #fff;
  border: 2px solid #5E5959;
  padding: 20px;
  margin: 0 auto;
  width: 220px;
  text-align: center;
  transition: all 500ms ease-in-out;
}
#contact01 .form_area form button:hover {
  background: #5E5959;
  color: #fff;
}
#contact01 .form_area form figure {
  width: 70%;
  margin: 0 0 0 5% !important;
}
#contact01 .form_area form figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

#board01 {
  margin: 100px 0;
}
#board01 .tab {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 100px;
  display: none;
}
#board01 .tab li {
  height: 70px;
  line-height: 70px;
  width: 50%;
  text-align: center;
  border: 1px solid #5F86D1;
  padding: 0;
}
#board01 .tab li a {
  color: #5F86D1;
  font-weight: 600;
}
#board01 .tab li.on {
  background: #5F86D1;
}
#board01 .tab li.on a {
  font-weight: 600;
  color: #fff;
}

@media (max-width: 1920px) {
  #business02 .bubble strong {
    padding: 25px 20px;
  }
  #business02 .bubble .sub_fox {
    font-size: 1.3rem;
  }
  #business04 .table_area table td {
    padding: 20px 20px 30px;
  }
  #business04 .table_area table td ol li.mar {
    margin: 20px 0 0;
  }
  #energy03 table td {
    padding: 20px 20px 30px;
  }
  #rps10 {
    width: 70%;
  }
}
@media (max-width: 1600px) {
  #location01 .map_area .map_box .root_daum_roughmap .wrap_map {
    height: 400px !important;
  }
  #business02 .bubble .sub_fox {
    font-size: 1rem;
  }
  #business04 .table_area table td ol {
    flex-wrap: wrap;
  }
  #business04 .table_area table td ol li {
    width: 35%;
  }
  #business05 .title {
    flex-direction: column;
  }
  #support04 li {
    width: 28%;
  }
  #support04 li.top {
    margin: 30px 0 0;
  }
  #support04 li.none {
    display: none;
  }
  #energy03 .process li {
    width: 28%;
  }
  #energy03 .process li.top {
    margin: 30px 0 0;
  }
  #energy03 .process li.none {
    display: none;
  }
  #rps02 .tree .step:after {
    top: 22%;
  }
  #rps03 ul {
    margin: 150px 0 0;
  }
  #rps03 ul i {
    width: 150px;
    height: 150px;
  }
  #rps08 ul li img {
    width: 250px;
  }
  #rps10 {
    width: 80%;
  }
  #rps11 .box .txt {
    padding: 25px 25px 25px 16%;
  }
}
@media (max-width: 1440px) {
  #patent01 .th_box ul li {
    width: 23%;
  }
  #patent01 .th_box ul li:nth-of-type(4n) {
    margin: 0 0 2% 0;
  }
  #patent01 .th_box ul li:nth-of-type(6n) {
    margin: 0 2% 2% 0;
  }
  #business03 ul li .box {
    height: 400px;
  }
  #energy02 .box {
    padding: 100px;
  }
  #rps02 .tree {
    flex-wrap: wrap;
  }
  #rps02 .tree .step:after {
    top: 62px;
  }
  #rps02 .tree .step.step05:after {
    display: none;
  }
  #contact01 ul {
    flex-direction: column;
    align-items: start;
  }
  #contact01 ul li {
    width: 100%;
  }
  #contact01 ul li.line {
    width: 100%;
    height: 1px;
    margin: 30px 0;
  }
  #contact01 .form_area {
    margin: 50px 0 0;
  }
  #contact01 .form_area form .tox {
    flex-direction: column-reverse;
  }
  #contact01 .form_area form .tox .cont {
    width: 100%;
  }
  #contact01 .form_area form .tox figure {
    width: 100%;
    margin: 0 0 50px 0 !important;
  }
}
@media (max-width: 1360px) {
  #about01 .cho .box i {
    width: 80%;
  }
  #about01 .cho .balance {
    left: -30%;
    width: 45%;
  }
  #about01 .cho .balance .s_txt {
    font-size: 1.1rem;
  }
  #about01 .cho .speed {
    right: -30%;
    width: 45%;
  }
  #about01 .cho .speed .s_txt {
    font-size: 1.1rem;
  }
  #about01 .cho .being {
    width: 45%;
  }
  #about01 .cho .being .s_txt {
    font-size: 1.1rem;
  }
  #business04 .procedure .first, #business04 .procedure .cen, #business04 .procedure .last, #business04 .procedure .bir {
    display: none;
  }
  #business04 .procedure .m_first {
    display: block;
  }
  #business04 .procedure .m_first .deps01 {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
  }
  #business04 .procedure .m_first .deps01 li {
    background: #0099FF;
    color: #fff;
    border-radius: 0 20px 0 20px;
    padding: 15px;
    margin: 0 0 20px 0;
    text-align: center;
    width: 43%;
  }
  #business04 .procedure .m_first .deps01 li.round {
    border: 10px solid #0099FF;
    border-radius: 0 20px 0 20px;
    padding: 15px;
    background: none;
    color: #000;
    font-weight: 600;
  }
  #business04 .procedure .m_first .deps01 li.m_first {
    background: #81A1FF;
  }
  #business04 .procedure .m_first .deps01 li.m_cen {
    background-image: linear-gradient(to right, #0099FF, #81A1FF);
  }
  #business04 .procedure .m_first .deps01 li.m_cen.max {
    width: 92%;
  }
  #business04 .procedure .m_first .deps01 li.m_last {
    background: #858585;
  }
  #business04 .procedure .m_first .deps01 li.arrow {
    margin: 15px;
    display: inline-block;
    height: 12px;
    position: relative;
    width: 12px;
    border: 0;
    transform: rotate(-45deg);
    background: none;
    padding: 0;
  }
  #business04 .procedure .m_first .deps01 li.arrow.none {
    display: none;
  }
  #business04 .procedure .m_first .deps01 li.arrow:after {
    content: "";
    display: inline-block;
    height: 12px;
    left: 0;
    position: absolute;
    top: 0;
    width: 12px;
    border-color: transparent;
    border-bottom-color: #0099FF;
    border-style: solid;
    border-width: 0 0 12px 12px;
    height: 0;
    width: 0;
  }
  #business04 .procedure .m_first .deps02 {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 50px 0 0;
  }
  #business04 .procedure .m_first .deps02 li {
    background: #0099FF;
    color: #fff;
    border-radius: 0 20px 0 20px;
    padding: 15px;
    margin: 0 0 20px 0;
    text-align: center;
    width: 43%;
  }
  #business04 .procedure .m_first .deps02 li.round {
    border: 10px solid #0099FF;
    border-radius: 0 20px 0 20px;
    padding: 15px;
    background: none;
    color: #000;
    font-weight: 600;
  }
  #business04 .procedure .m_first .deps02 li.m_first {
    background: #81A1FF;
  }
  #business04 .procedure .m_first .deps02 li.m_cen {
    background-image: linear-gradient(to right, #0099FF, #81A1FF);
  }
  #business04 .procedure .m_first .deps02 li.m_cen.max {
    width: 92%;
  }
  #business04 .procedure .m_first .deps02 li.m_last {
    background: #858585;
  }
  #business04 .procedure .m_first .deps02 li.arrow {
    margin: 15px;
    display: inline-block;
    height: 12px;
    position: relative;
    width: 12px;
    border: 0;
    transform: rotate(-45deg);
    background: none;
    padding: 0;
  }
  #business04 .procedure .m_first .deps02 li.arrow.none {
    display: none;
  }
  #business04 .procedure .m_first .deps02 li.arrow:after {
    content: "";
    display: inline-block;
    height: 12px;
    left: 0;
    position: absolute;
    top: 0;
    width: 12px;
    border-color: transparent;
    border-bottom-color: #0099FF;
    border-style: solid;
    border-width: 0 0 12px 12px;
    height: 0;
    width: 0;
  }
  #business04 .procedure .m_first .deps03 {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 50px 0 0;
  }
  #business04 .procedure .m_first .deps03 li {
    background: #0099FF;
    color: #fff;
    border-radius: 0 20px 0 20px;
    padding: 15px;
    margin: 0 0 20px 0;
    text-align: center;
    width: 43%;
  }
  #business04 .procedure .m_first .deps03 li.round {
    border: 10px solid #0099FF;
    border-radius: 0 20px 0 20px;
    padding: 15px;
    background: none;
    color: #000;
    font-weight: 600;
  }
  #business04 .procedure .m_first .deps03 li.m_first {
    background: #81A1FF;
  }
  #business04 .procedure .m_first .deps03 li.m_cen {
    background-image: linear-gradient(to right, #0099FF, #81A1FF);
  }
  #business04 .procedure .m_first .deps03 li.m_cen.max {
    width: 92%;
  }
  #business04 .procedure .m_first .deps03 li.m_last {
    background: #858585;
  }
  #business04 .procedure .m_first .deps03 li.arrow {
    margin: 15px;
    display: inline-block;
    height: 12px;
    position: relative;
    width: 12px;
    border: 0;
    transform: rotate(-45deg);
    background: none;
    padding: 0;
  }
  #business04 .procedure .m_first .deps03 li.arrow.none {
    display: none;
  }
  #business04 .procedure .m_first .deps03 li.arrow:after {
    content: "";
    display: inline-block;
    height: 12px;
    left: 0;
    position: absolute;
    top: 0;
    width: 12px;
    border-color: transparent;
    border-bottom-color: #0099FF;
    border-style: solid;
    border-width: 0 0 12px 12px;
    height: 0;
    width: 0;
  }
}
@media (max-width: 1280px) {
  .about_area .txt {
    padding: 100px 0;
  }
  .business_area,
  .support_area,
  .energy_area {
    height: 385px;
  }
  .business_area .txt,
  .support_area .txt,
  .energy_area .txt {
    padding: 0;
  }
  #about02 .inner {
    padding: 100px 0;
  }
  #about02 .inner .detail figure {
    width: 50%;
  }
  #about02 .inner .detail .tit {
    width: 50%;
    margin: 0 0 0 5%;
  }
  .history_area, .patent_area, .contact_area {
    height: 385px;
  }
  .history_area .txt, .patent_area .txt, .contact_area .txt {
    padding: 0;
  }
  #history01 .inner {
    padding: 100px 0;
  }
  #patent01 .th_box {
    padding: 100px 0;
  }
  #location01 .map_area {
    margin: 100px 0;
  }
  #business02 .table_area {
    padding: 50px 0;
  }
  #caution .bor {
    padding: 50px 10%;
  }
  #support02 .box br {
    display: none;
  }
  #energy02 .t_box {
    margin: 100px 0px 0;
  }
  #energy03 .table_area {
    margin: 0;
  }
  #energy03 .process {
    padding: 100px 0px 0;
  }
  #energy03 .b_row {
    margin: 100px 0px 0;
  }
  #energy04 {
    padding: 100px 0 0;
  }
  #caution .bor {
    margin: 0;
  }
  .rps_area .txt {
    padding: 0;
  }
  #rps02 .tree .step p.s_txt {
    font-size: 1.2rem;
  }
  #rps07 {
    padding: 100px 0;
  }
  #rps08 ul li:first-child {
    margin: 0 3% 0 0;
  }
  #rps09 {
    padding: 100px 0;
  }
  #rps10 {
    width: 90%;
  }
  #rps10 .rps_box {
    flex-direction: column;
  }
  #rps10 .rps_box .txt {
    margin: 100px;
  }
  #rps11 {
    padding: 100px 0;
  }
  #contact01 .form_area form figure {
    width: 60%;
  }
  #contact01 .form_area form .cont {
    width: 50%;
  }
  #board01 .tab {
    margin: 0;
  }
  #board01 .tab li {
    height: 55px;
    line-height: 55px;
  }
}
@media (max-width: 1114px) {
  #business03 ul li .box {
    height: 470px;
  }
}
@media (max-width: 1024px) {
  #sub_contents {
    padding-top: 100px;
  }
  #sub_contents .inner {
    width: 90%;
  }
  .sub_title.inner {
    width: 90%;
  }
  .about_area .txt {
    width: 90%;
  }
  #about01 {
    width: 60%;
    margin: 250px auto 10%;
  }
  #about01 .cho {
    width: 100%;
  }
  #about01 .cho .balance {
    left: 50%;
    width: 41%;
    top: -200px;
    transform: translate(-50%, 0);
  }
  #about01 .cho .speed {
    right: 0%;
    width: 41%;
    top: auto;
    bottom: -153px;
  }
  #about01 .cho .being {
    left: 20%;
    width: 41%;
    top: auto;
    bottom: -153px;
  }
  #about02 .inner {
    width: 90%;
  }
  #location01 .map_area {
    flex-direction: column-reverse;
  }
  #location01 .map_area .map_box {
    width: 100%;
  }
  #location01 .map_area .address {
    width: 100%;
    margin: 0 0 30px 0;
  }
  #rps03 ul li .bo_box .txt {
    top: 40%;
  }
  #rps04 .f_img {
    margin: 0 50px;
  }
  #rps08 ul {
    flex-direction: column;
  }
  #rps08 ul li {
    width: 80%;
    margin: 0 auto;
  }
  #rps08 ul li:first-child {
    margin: 0 auto 50px;
  }
}
@media (max-width: 768px) {
  .history_area, .patent_area, .contact_area {
    height: 285px;
  }
  .business_area,
  .support_area,
  .energy_area {
    height: 285px;
  }
  #about01 {
    width: 70%;
  }
  #about02 .inner .detail {
    flex-direction: column;
  }
  #about02 .inner .detail figure {
    width: 100%;
  }
  #about02 .inner .detail .tit {
    margin: 30px 0 0;
    width: 100%;
  }
  #history01 .div {
    flex-direction: column;
    padding: 0 0 0 10%;
  }
  #history01 .div.last::before {
    display: none;
  }
  #history01 .div:before {
    content: "";
    position: absolute;
    left: 5px;
    top: 25px;
    width: 2px;
    height: 100%;
    background: #5F86D1;
  }
  #history01 .div:after {
    content: "";
    position: absolute;
    left: 0;
    top: 25px;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 100%;
    background: #5F86D1;
    border: 5px solid #5F86D1;
    box-sizing: border-box;
  }
  #history01 .div h2 {
    width: auto;
    margin: 0;
  }
  #history01 .div ol {
    padding: 15px 0 50px;
  }
  #history01 .div ol::before {
    display: none;
  }
  #history01 .div ol::after {
    display: none;
  }
  #business01 .diagram {
    flex-direction: column-reverse;
  }
  #business01 .diagram figure {
    width: 100%;
    margin: 50px 0 0 !important;
  }
  #business01 .diagram .txt {
    width: 100%;
  }
  #business02 .table_area {
    overflow: scroll;
  }
  #business02 .table_area table {
    width: 750px;
  }
  #business02 .table_area .total_box {
    width: 750px;
  }
  #business03 ul {
    flex-direction: column;
    margin: 50px 0 0;
  }
  #business03 ul li {
    width: 100%;
  }
  #business03 ul li:first-child {
    margin: 0 0 50px 0;
  }
  #business03 ul li .box {
    height: auto;
  }
  #business04 .table_area table th {
    width: auto;
  }
  #business04 .table_area table td ol {
    flex-direction: column;
  }
  #business04 .table_area table td ol li {
    min-width: 200px;
  }
  #business04 .table_area table td ol li.arrow {
    transform: rotate(45deg);
  }
  #business04 .procedure {
    padding: 50px 0 30px;
  }
  #business04 .procedure h3 {
    margin: 0 0 50px 0;
  }
  #business04 .procedure .m_first .deps01 {
    justify-content: center;
  }
  #business04 .procedure .m_first .deps01 li {
    margin: 0;
    width: 100%;
  }
  #business04 .procedure .m_first .deps01 li.arrow {
    transform: rotate(45deg);
  }
  #business04 .procedure .m_first .deps01 li.arrow.none {
    display: block;
  }
  #business04 .procedure .m_first .deps01 li.m_cen.max {
    width: 100%;
  }
  #business04 .procedure .m_first .deps02 {
    margin: 100px 0 0;
    justify-content: center;
  }
  #business04 .procedure .m_first .deps02 li {
    margin: 0;
    width: 100%;
  }
  #business04 .procedure .m_first .deps02 li.arrow {
    transform: rotate(45deg);
  }
  #business04 .procedure .m_first .deps02 li.arrow.none {
    display: block;
  }
  #business04 .procedure .m_first .deps02 li.m_cen.max {
    width: 100%;
  }
  #business04 .procedure .m_first .deps03 {
    margin: 100px 0 0;
    justify-content: center;
  }
  #business04 .procedure .m_first .deps03 li {
    margin: 0;
    width: 100%;
  }
  #business04 .procedure .m_first .deps03 li.arrow {
    transform: rotate(45deg);
  }
  #business04 .procedure .m_first .deps03 li.arrow.none {
    display: block;
  }
  #business04 .procedure .m_first .deps03 li.m_cen.max {
    width: 100%;
  }
  #business05 .table_area {
    overflow-x: scroll;
  }
  #business05 table {
    width: 900px;
  }
  #support01 .diagram {
    flex-direction: column-reverse;
  }
  #support01 .diagram figure {
    width: 100%;
    margin: 50px 0 0 !important;
  }
  #support01 .diagram .txt {
    width: 100%;
  }
  #support02 .t_box {
    margin: 50px 0 0;
  }
  #support02 .box {
    padding: 50px;
  }
  #support03 .table_area {
    overflow: scroll;
  }
  #support03 .table_area table {
    width: 1000px;
  }
  #support04 {
    margin: 100px 0 0;
  }
  #support04 ol {
    flex-direction: column;
  }
  #support04 ol li {
    width: 65%;
  }
  #support04 ol li.arrow {
    transform: rotate(45deg);
  }
  #support04 ol li.none {
    display: block;
  }
  #support04 ol li.top {
    margin: 0;
  }
  #energy01 .diagram {
    flex-direction: column-reverse;
  }
  #energy01 .diagram figure {
    width: 100%;
    margin: 50px 0 0 !important;
  }
  #energy01 .diagram .txt {
    width: 100%;
  }
  #energy03 table th {
    width: auto;
  }
  #energy03 .b_row {
    margin: 50px 0 0;
    flex-direction: column;
  }
  #energy03 .b_row h5 {
    margin: 0 0 30px 0;
  }
  #energy03 .b_row p {
    text-align: center;
  }
  #energy03 .process ol {
    flex-direction: column;
  }
  #energy03 .process ol li {
    width: 65%;
  }
  #energy03 .process ol li.arrow {
    transform: rotate(45deg);
  }
  #energy03 .process ol li.none {
    display: block;
  }
  #energy03 .process ol li.top {
    margin: 0;
  }
  #energy02 .t_box {
    margin: 50px 0 0;
  }
  #energy02 .box {
    padding: 50px;
  }
  #energy04 .box {
    flex-direction: column;
  }
  #energy04 .box .num01 {
    margin: 0 0 30px 0;
    width: 60px;
    height: 60px;
    min-width: 60px;
  }
  #energy04 .box .num02 {
    margin: 0 0 30px 0;
    width: 60px;
    height: 60px;
    min-width: 60px;
  }
  #energy04 .box .num03 {
    margin: 0 0 30px 0;
    width: 60px;
    height: 60px;
    min-width: 60px;
  }
  #energy04 .box .txt {
    flex-direction: column;
    text-align: center;
  }
  #energy04 .box .txt b {
    width: auto;
    margin: 0 0 20px 0;
  }
  #rps01 .diagram {
    flex-direction: column;
  }
  #rps01 .diagram .txt {
    width: 100%;
    margin: 0 0 50px 0;
  }
  #rps01 .diagram .num_box {
    width: 100%;
  }
  #rps02 .tree .step {
    width: 50%;
  }
  #rps02 .tree .step.step02:after, #rps02 .tree .step.step04:after, #rps02 .tree .step.step06:after {
    display: none;
  }
  #rps02 .tree .step.step05:after {
    display: block;
  }
  #rps03 ul {
    flex-direction: column;
  }
  #rps03 ul li {
    margin: 0 auto 100px;
  }
  #rps03 ul li:last-child {
    margin: 0 auto;
  }
  #rps04 .f_img {
    flex-direction: column;
    margin: 0 150px;
  }
  #rps04 .f_img figure {
    margin: 0 0 50px 0 !important;
  }
  #rps04 .f_img figure:nth-child(2) {
    margin: 0 0 50px 0 !important;
  }
  #rps05 .inner {
    flex-direction: column;
  }
  #rps05 .inner .title {
    width: 100%;
    margin: 0 0 50px 0;
  }
  #rps05 .inner .txt {
    width: 100%;
  }
  #rps05 .inner .txt p:first-child {
    margin: 0 0 50px 0;
  }
  #rps06 {
    margin: 50px 0;
  }
  #rps06 ul {
    flex-direction: column;
  }
  #rps06 ul li {
    width: 100%;
  }
  #rps06 ul li:first-child {
    margin: 0 0 50px 0;
  }
  #rps06 ul li i img {
    width: 70px;
  }
  #rps07 h3 {
    margin: 0 0 50px 0;
  }
  #rps07 .table_area {
    overflow-x: scroll;
  }
  #rps07 table {
    width: 750px;
  }
  #rps09 h3 {
    margin: 0 0 50px 0;
  }
  #rps09 .table_area {
    overflow-x: scroll;
  }
  #rps09 table {
    width: 750px;
  }
  #rps10 .rps_box .txt {
    margin: 100px 50px;
  }
  #rps11 h3 {
    margin: 0 0 50px 0;
  }
  #rps11 .box {
    flex-direction: column;
  }
  #rps11 .box i {
    width: 150px;
    height: 150px;
  }
  #rps11 .box i img {
    width: 60px;
  }
  #rps11 .box .txt {
    padding: 70px 25px 60px;
    margin: -50px 0 0;
    border-radius: 50px;
  }
  #board01 {
    margin: 50px 0;
  }
  #contact01 .form_area form button {
    width: 180px;
    padding: 10px;
  }
}
@media (max-width: 640px) {
  #about01 {
    width: 90%;
  }
}
@media (max-width: 540px) {
  .sub_title {
    font-size: 2.125rem;
  }
  .sib_his {
    font-size: 1.5rem;
  }
  .sub_fo {
    font-size: 1.8rem;
  }
  .s_txt {
    font-size: 1.3rem;
  }
  #sub_contents {
    padding-top: 65px;
  }
  #patent01 .th_box ul li {
    width: 30%;
    margin: 0 3% 3% 0;
  }
  #patent01 .th_box ul li:nth-of-type(3n) {
    margin: 0 0 3% 0;
  }
  #patent01 .th_box ul li:nth-of-type(4n) {
    margin: 0 3% 3% 0;
  }
  #business04 .table_area table th {
    padding: 20px 10px;
  }
  #energy03 table th {
    padding: 20px 10px;
  }
  #rps02 .tree .step:after {
    top: 55px;
  }
  #rps04 .f_img {
    margin: 0 50px;
  }
  #rps08 ul li {
    width: 100%;
  }
  #rps08 ul li .txt {
    padding: 50px 30px;
  }
  #rps08 ul li img {
    width: 200px;
  }
  #rps08 ul li .box {
    margin-top: -70px;
  }
  #board01 .tab li {
    height: 45px;
    line-height: 45px;
  }
}
@media (max-width: 480px) {
  #about01 {
    margin: 100px auto 0;
  }
  #about01 .cho .max02 {
    top: 4.5%;
    left: 13%;
    transform: none;
  }
  #about01 .cho .max03 {
    top: 9%;
    left: 27%;
    transform: none;
  }
  #about01 .cho .balance {
    position: relative;
    left: 50%;
    top: -68px;
    width: 60%;
  }
  #about01 .cho .balance svg {
    height: auto;
  }
  #about01 .cho .speed {
    position: relative;
    left: 50%;
    top: -68px;
    width: 60%;
    bottom: 0;
    transform: translate(-50%);
  }
  #about01 .cho .speed svg {
    height: auto;
  }
  #about01 .cho .being {
    position: relative;
    left: 50%;
    top: -68px;
    bottom: 0;
    width: 60%;
  }
  #about01 .cho .being svg {
    height: auto;
  }
  #about02 .inner {
    padding: 0 0 100px 0;
  }
}
@media (max-width: 414px) {
  #business04 .table_area table td ol li {
    min-width: 160px;
  }
}
@media (max-width: 360px) {
  #about01 .cho .balance {
    top: -45px;
    width: 70%;
  }
  #about01 .cho .speed {
    top: -45px;
    width: 70%;
  }
  #about01 .cho .being {
    top: -45px;
    width: 70%;
  }
}/*# sourceMappingURL=sub.css.map */