:root {
  --header-h: 100px;
  --subheader-h: 50px;
  --lnb-h: 70px;
  --quick-size: 153px;
  --main-product-w: 220px;
  --main-product-h: 250px;
  --input-h: 45px;
  --side-pd: 20px;
  --c-txt: #3c444c;
  --c-txt-light: #606e7b;
  --c-darknavy: #01184c;
  --c-darknavy2: #293551;
  --c-blue: #014690;
  --c-blue-bd: #336ba5;
  --c-skyblue: #00bcff;
  --c-bg-gray: #f1f1f1;
}

@media screen and (max-width: 1239.9px) {
  :root {
    --side-pd: 20px;
  }
}
@media screen and (max-width: 1023.9px) {
  :root {
    --header-h: 50px;
    --side-pd: 20px;
    --quick-size: 50px;
    --lnb-h: 45px;
  }
}
.lnb .sub_visual {
  display: flex;
  align-items: center;
  flex-direction: column;
  width: 100%;
  height: 500px;
  background-position: center;
  background-size: cover;
}
@media screen and (max-width: 1023.9px) {
  .lnb .sub_visual {
    justify-content: center;
    height: 235px;
    padding: 20px;
  }
}
.lnb .sub_visual.img1 {
  background-image: url(../img/sub/sub_visual1.png);
}
@media screen and (max-width: 1023.9px) {
  .lnb .sub_visual.img1 {
    background-image: url(../img/sub/sub_visual1_m.png);
  }
}
.lnb .sub_visual.img2 {
  background-image: url(../img/sub/sub_visual2.png);
}
@media screen and (max-width: 1023.9px) {
  .lnb .sub_visual.img2 {
    background-image: url(../img/sub/sub_visual2_m.png);
  }
}
.lnb .sub_visual hgroup {
  display: flex;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  height: 100%;
}
.lnb .sub_visual h1 {
  font-size: 65px;
  letter-spacing: -0.075em;
  color: #fff;
  font-weight: 300;
  line-height: 1.2;
}
@media screen and (max-width: 1023.9px) {
  .lnb .sub_visual h1 {
    font-size: 27.5px;
    letter-spacing: -0.075em;
  }
}
.lnb .sub_visual h2 {
  margin-top: 36px;
  font-size: 24px;
  letter-spacing: -0.05em;
  color: #fff;
  font-weight: 300;
}
@media screen and (max-width: 1023.9px) {
  .lnb .sub_visual h2 {
    margin-top: 20px;
    font-size: 12px;
    letter-spacing: -0.025em;
    line-height: 1.4;
  }
}
.lnb nav {
  height: var(--lnb-h);
  background-color: var(--c-blue);
}
.lnb nav [type=checkbox] {
  position: absolute;
  left: -9999px;
}
.lnb nav [type=checkbox]:checked ~ .dep1_list, .lnb nav [type=checkbox]:checked ~ .dep2_list {
  max-height: none;
  background-color: #fff;
  z-index: 5;
}
.lnb nav [type=checkbox]:checked ~ .dep1_list > *, .lnb nav [type=checkbox]:checked ~ .dep2_list > * {
  color: #000;
  font-size: 14px;
  letter-spacing: -0.025em;
}
.lnb nav [type=checkbox]:checked ~ .dep1_list a, .lnb nav [type=checkbox]:checked ~ .dep2_list a {
  padding: 10px 0;
}
.lnb nav > ul {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
@media screen and (max-width: 1023.9px) {
  .lnb nav > ul {
    margin: 0 !important;
  }
}
.lnb nav > ul > li {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
@media screen and (max-width: 1023.9px) {
  .lnb nav > ul > li {
    position: relative;
    justify-content: space-between;
    font-size: 14px;
    letter-spacing: -0.025em;
    color: #fff;
    font-weight: 300;
    padding: 0 15px 0 21px;
  }
  .lnb nav > ul > li::after {
    content: "";
    display: inline-block;
    display: inline-block;
    display: inline-block;
    width: 15.75px;
    height: 10.25px;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 31.5 20.5'%3E%3Cpath stroke='%23fff' stroke-width='3' fill='none' d='M26.791 2.891 14.7 14.982 2.609 2.891'/%3E%3C/svg%3E");
  }
  .lnb nav > ul > li + li {
    border-left: 1px solid var(--c-blue-bd);
  }
}
.lnb nav .dep1 {
  width: 100%;
}
@media screen and (max-width: 1023.9px) {
  .lnb nav .dep1.non_dep2 + .dep2 {
    display: none;
  }
}
.lnb nav .dep2 {
  width: 100%;
}
.lnb nav .dep1_list, .lnb nav .dep2_list {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
@media screen and (min-width: 1023.9px) {
  .lnb nav .dep1_list, .lnb nav .dep2_list {
    height: 100%;
  }
}
@media screen and (max-width: 1023.9px) {
  .lnb nav .dep1_list, .lnb nav .dep2_list {
    position: absolute;
    left: 0;
    top: var(--lnb-h);
    flex-direction: column;
    max-height: 0;
    overflow: hidden;
    transition: all 0.3s;
  }
}
.lnb nav .dep1_list li, .lnb nav .dep2_list li {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 18px;
  letter-spacing: -0.05em;
  font-weight: 300;
}
@media screen and (min-width: 1023.9px) {
  .lnb nav .dep1_list li, .lnb nav .dep2_list li {
    width: 20%;
    color: #fff;
    border-right: 1px solid var(--c-blue-bd);
  }
  .lnb nav .dep1_list li:first-child, .lnb nav .dep2_list li:first-child {
    border-left: 1px solid var(--c-blue-bd);
  }
  .lnb nav .dep1_list li.active, .lnb nav .dep2_list li.active {
    background-color: #fff;
    color: #000;
    border-color: var(--c-blue);
    font-weight: 400;
  }
}
@media screen and (max-width: 1023.9px) {
  .lnb nav .dep1_list a, .lnb nav .dep2_list a {
    padding: 10px 15px 10px 21px !important;
    align-items: flex-start;
    justify-content: flex-start;
    border-bottom: 1px solid #e4e4e4;
  }
}
@media screen and (min-width: 1023.9px) {
  .lnb nav .dep1,
.lnb nav .lnb_dep2label {
    display: none;
  }
}

.lnb_dep2:checked ~ .dep2_list {
  opacity: 1 !important;
  z-index: 2 !important;
}

.sub_sec {
  padding: 90px 0;
}
@media screen and (max-width: 1023.9px) {
  .sub_sec {
    padding: 40px 0;
  }
}

.sub_title {
  font-size: 60px;
  letter-spacing: -0.075em;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 1023.9px) {
  .sub_title {
    font-size: 30px;
    letter-spacing: -0.075em;
  }
}
.sub_title::after {
  content: "";
  display: block;
  margin: 20px auto;
  width: 1px;
  height: 33px;
  background-color: #000;
}
@media screen and (max-width: 1023.9px) {
  .sub_title::after {
    margin: 10px auto;
    height: 16.5px;
  }
}
.sub_title_middle {
  font-size: 36px;
  letter-spacing: -0.075em;
  line-height: 1.4;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 1023.9px) {
  .sub_title_middle {
    font-size: 22px;
    letter-spacing: -0.05em;
  }
}
.sub_title_desc {
  font-size: 28px;
  letter-spacing: -0.075em;
  font-weight: 300;
  text-align: center;
}
@media screen and (max-width: 1023.9px) {
  .sub_title_desc {
    font-size: 14px;
    letter-spacing: -0.025em;
  }
}
.bg_img .sub_title {
  color: white;
}
.bg_img .sub_title::after {
  background-color: white;
}
.bg_img .sub_title_desc {
  color: white;
}

.sub_text {
  font-size: 20px;
  letter-spacing: -0.05em;
  line-height: 1.7;
  color: #666;
}
@media screen and (max-width: 1023.9px) {
  .sub_text {
    font-size: 13px;
    letter-spacing: -0.025em;
    line-height: 1.6;
  }
}

.root_daum_roughmap .map_border {
  display: none;
}
.root_daum_roughmap .wrap_controllers {
  display: none;
}

.bottom_big_btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto;
  width: 25%;
  height: 70px;
  padding: 0 40px;
  font-size: 22px;
  letter-spacing: -0.05em;
  font-weight: 500;
  color: #fff;
  background-color: var(--c-blue);
}
@media screen and (max-width: 1023.9px) {
  .bottom_big_btn {
    justify-content: center;
    width: 100%;
    height: 45px;
    font-size: 16px;
    letter-spacing: -0.025em;
  }
}
.bottom_big_btn i.arrow {
  width: 26px;
  transform: rotate(-90deg);
}
@media screen and (max-width: 1023.9px) {
  .bottom_big_btn i.arrow {
    width: 16px;
    margin-left: 10px;
  }
}

.non_list {
  display: block;
  width: 100% !important;
  font-size: 22px;
  letter-spacing: -1.1px;
  text-align: center;
  font-weight: 500;
  border-top: 2px solid #222;
  border-bottom: 1px solid #eee;
  padding: 60px 0;
}
@media screen and (max-width: 1023.9px) {
  .non_list {
    font-size: 16px;
    letter-spacing: -1.6px;
  }
}

.pgroup_company #sec1 hgroup {
  margin-bottom: 80px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec1 hgroup {
    margin-bottom: 30px;
  }
}
.pgroup_company #sec1 .cont_container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pgroup_company #sec1 .cont_container .sub_title_middle {
  text-align: left;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec1 .cont_container {
    flex-direction: column;
  }
}
.pgroup_company #sec1 .cont_container > div {
  width: 590px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec1 .cont_container > div {
    width: 100%;
    margin-top: 30px;
  }
}
.pgroup_company #sec1 .cont_container .sub_text {
  margin-top: 50px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec1 .cont_container .sub_text {
    margin-top: 30px;
  }
}
.pgroup_company #sec2 hgroup {
  margin-bottom: 60px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 hgroup {
    margin-bottom: 30px;
  }
}
.pgroup_company #sec2 .cont_container {
  position: relative;
}
.pgroup_company #sec2 .cont_container::before {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  display: inline-block;
  width: 4px;
  background-color: var(--c-blue);
  height: 100%;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .cont_container::before {
    width: 2px;
    left: 0;
    transform: none;
  }
}
.pgroup_company #sec2 .cont_container > li {
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 1023.9px) {
  .pgroup_company #sec2 .cont_container > li > div {
    width: 50%;
  }
}
.pgroup_company #sec2 .cont_container > li + li {
  margin-top: 50px;
}
@media screen and (min-width: 1023.9px) {
  .pgroup_company #sec2 .cont_container > li:nth-child(even) .img_area {
    order: 1;
    text-align: right;
  }
  .pgroup_company #sec2 .cont_container > li:nth-child(even) .text_area {
    justify-content: flex-end;
  }
  .pgroup_company #sec2 .cont_container > li:nth-child(even) .history_year {
    order: 1;
    margin-left: 0;
    margin-right: -16px;
  }
  .pgroup_company #sec2 .cont_container > li:nth-child(even) .history_year .dot {
    order: 1;
    margin-right: 0;
    margin-left: 52px;
    transform: rotate(180deg);
  }
  .pgroup_company #sec2 .cont_container > li:nth-child(even) li {
    padding-left: 0;
    padding-right: 62px;
    text-align: right;
  }
  .pgroup_company #sec2 .cont_container > li:nth-child(even) li .history_month {
    left: auto;
    right: 30px;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .cont_container > li {
    flex-direction: column;
  }
  .pgroup_company #sec2 .cont_container > li:first-of-type {
    padding-top: 36px;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .img_area {
    order: 1;
    margin-top: 20px;
    padding: 0 37px;
  }
}
.pgroup_company #sec2 .text_area {
  display: flex;
  align-items: flex-start;
  margin-top: 85px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .text_area {
    flex-direction: column;
    margin-top: 0;
  }
}
.pgroup_company #sec2 .text_area ul {
  margin-top: 12px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .text_area ul {
    padding-left: 37px;
  }
}
.pgroup_company #sec2 .text_area li {
  position: relative;
  font-size: 17px;
  letter-spacing: -0.05em;
  color: #666;
  line-height: 30px;
  padding-left: 62px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .text_area li {
    font-size: 13px;
    letter-spacing: -0.025em;
    line-height: 20px;
    padding-left: 24px;
  }
}
.pgroup_company #sec2 .history_year {
  display: flex;
  align-items: center;
  font-size: 40px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  color: var(--c-blue);
  margin-left: -16px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_year {
    margin-left: -7.5px;
    font-size: 30px;
  }
}
.pgroup_company #sec2 .history_year .dot {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 31px;
  min-width: 31px;
  height: 31px;
  border-radius: 50%;
  border: 2px solid var(--c-blue);
  background-color: #fff;
  margin-right: 52px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_year .dot {
    width: 15px;
    min-width: 15px;
    height: 15px;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_year .dot {
    border-width: 1px;
    margin-right: 30px;
  }
}
.pgroup_company #sec2 .history_year .dot::before {
  position: absolute;
  content: "";
  display: inline-block;
  width: 7px;
  min-width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--c-blue);
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_year .dot::before {
    width: 4px;
    min-width: 4px;
    height: 4px;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_year .dot::before {
    margin-left: 1px;
  }
}
.pgroup_company #sec2 .history_year .dot::after {
  position: absolute;
  left: 29px;
  content: "";
  display: inline-block;
  width: 42px;
  height: 1px;
  border-top: 1px dashed var(--c-blue);
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_year .dot::after {
    left: 14px;
    width: 21px;
  }
}
.pgroup_company #sec2 .history_month {
  position: absolute;
  font-size: 20px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  line-height: 1.5;
  color: #222;
  left: 30px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec2 .history_month {
    font-size: 13px;
    left: 0;
  }
}
.pgroup_company #sec3 hgroup {
  margin-bottom: 50px;
}
.pgroup_company #sec3 img {
  margin: 0 auto;
}
.pgroup_company #sec4 {
  background-image: url(../img/sub/company_bg1.png);
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec4 {
    background-image: url(../img/sub/company_bg1_m.png);
  }
}
.pgroup_company #sec4 hgroup {
  margin-bottom: 60px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec4 hgroup {
    margin-bottom: 20px;
  }
}
.pgroup_company #sec4 ul {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pgroup_company #sec4 ul li {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30%;
  height: 210px;
  background-color: #fff;
  padding: 10px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec4 ul li {
    height: 105px;
  }
}
.pgroup_company #sec4 ul li img {
  max-height: 100%;
}
.pgroup_company #sec5 {
  padding-bottom: 0;
}
.pgroup_company #sec5 hgroup {
  margin-bottom: 60px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec5 hgroup {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company #sec5 .root_daum_roughmap .wrap_map {
    height: 390px !important;
  }
}
.pgroup_company .location_box {
  position: absolute;
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding: 0 43px;
  width: 360px;
  height: 360px;
  background-color: var(--c-blue);
  color: white;
  z-index: 2;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company .location_box {
    width: 180px;
    height: 180px;
    padding: 0 22px;
  }
}
.pgroup_company .location_box h1 {
  font-size: 42px;
  letter-spacing: -0.075em;
  font-weight: 700;
  margin-bottom: 30px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company .location_box h1 {
    font-size: 25px;
    letter-spacing: -0.075em;
    margin-bottom: 12px;
  }
}
.pgroup_company .location_box p {
  font-size: 18px;
  letter-spacing: -0.05em;
  font-weight: 300;
  line-height: 1.5;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_company .location_box p {
    font-size: 12px;
    letter-spacing: -0.025em;
  }
}

@media screen and (max-width: 1023.9px) {
  .pgroup_business .sub_title_middle {
    font-size: 14px;
    letter-spacing: -0.025em;
  }
}
.pgroup_business .sub_text {
  text-align: center;
  margin-top: 38px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_business .sub_text {
    margin-top: 20px;
  }
}
.pgroup_business img {
  margin: 56px auto 0;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_business img {
    margin-top: 35px;
  }
}

@media screen and (max-width: 1023.9px) {
  .pgroup_product .sub_title_middle {
    font-size: 14px;
    letter-spacing: -0.025em;
  }
}
.pgroup_product .sub_text {
  text-align: center;
  margin-top: 38px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .sub_text {
    margin-top: 20px;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .tab {
    flex-wrap: wrap;
    margin: 0 -3px;
  }
  .pgroup_product .tab li {
    width: auto;
    margin: 0 3px;
    margin-top: 6px;
  }
}
.pgroup_product .tab-cont {
  margin-top: 70px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .tab-cont {
    margin-top: 35px;
  }
}
.pgroup_product .tab-cont .cont {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% + (15px * 2));
  margin-left: -15px;
}
.pgroup_product .tab-cont .cont > li,
.pgroup_product .tab-cont .cont > div,
.pgroup_product .tab-cont .cont > article,
.pgroup_product .tab-cont .cont > section,
.pgroup_product .tab-cont .cont > figure {
  width: calc(25% - (15px * 2));
  margin-left: 15px;
  margin-right: 15px;
}
.pgroup_product .tab-cont .cont > li:nth-child(n+5),
.pgroup_product .tab-cont .cont > div:nth-child(n+5),
.pgroup_product .tab-cont .cont > article:nth-child(n+5),
.pgroup_product .tab-cont .cont > section:nth-child(n+5),
.pgroup_product .tab-cont .cont > figure:nth-child(n+5) {
  margin-top: 85px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .tab-cont .cont {
    display: flex;
    flex-wrap: wrap;
    width: calc(100% + (8.25px * 2));
    margin-left: -8.25px;
  }
  .pgroup_product .tab-cont .cont > li,
.pgroup_product .tab-cont .cont > div,
.pgroup_product .tab-cont .cont > article,
.pgroup_product .tab-cont .cont > section,
.pgroup_product .tab-cont .cont > figure {
    width: calc(50% - (8.25px * 2));
    margin-left: 8.25px;
    margin-right: 8.25px;
  }
  .pgroup_product .tab-cont .cont > li:nth-child(n+3),
.pgroup_product .tab-cont .cont > div:nth-child(n+3),
.pgroup_product .tab-cont .cont > article:nth-child(n+3),
.pgroup_product .tab-cont .cont > section:nth-child(n+3),
.pgroup_product .tab-cont .cont > figure:nth-child(n+3) {
    margin-top: 39px;
  }
}
.pgroup_product .product_box {
  display: block;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.pgroup_product .product_box figure {
  max-width: 100%;
  height: 278px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .product_box figure {
    height: 159px;
  }
}
.pgroup_product .product_box img {
  max-height: 100%;
}
.pgroup_product .product_box .text_wrap {
  height: 100%;
}
.pgroup_product .product_box figure {
  border: 1px solid #e4e4e4;
  padding: 6px;
}
.pgroup_product .product_box h1 {
  font-size: 15px;
  letter-spacing: -0.025em;
  color: #666;
  margin-top: 24px;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-wrap: normal;
  overflow: hidden;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .product_box h1 {
    font-size: 11px;
    letter-spacing: -0.025em;
    margin-top: 14.5px;
  }
}
.pgroup_product .product_box h2 {
  font-size: 20px;
  letter-spacing: -0.05em;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-wrap: normal;
  overflow: hidden;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product .product_box h2 {
    font-size: 15px;
    letter-spacing: -0.025em;
    margin-top: 4px;
    -webkit-line-clamp: 2;
    white-space: normal;
    display: -webkit-box;
    -webkit-box-orient: vertical;
  }
}
.pgroup_product.p_product_view nav {
  position: absolute;
  top: -55px;
  display: flex;
  align-items: center;
  font-size: 18px;
  letter-spacing: -0.05em;
  color: #333;
}
.pgroup_product.p_product_view nav img {
  margin-right: 4px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view nav {
    display: none;
  }
}
.pgroup_product.p_product_view .btn {
  display: inline-flex;
  width: auto;
  min-width: 190px;
  height: 70px;
  font-size: 22px;
  letter-spacing: -0.05em;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .btn {
    min-width: 125px;
    height: 45px;
    font-size: 16px;
    letter-spacing: -0.025em;
  }
}
.pgroup_product.p_product_view .top_img_container {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container {
    flex-direction: column;
  }
}
.pgroup_product.p_product_view .top_img_container > * {
  width: 47.5%;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container > * {
    width: 100%;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container figure {
    padding: 21px 13.5px;
  }
}
.pgroup_product.p_product_view .top_img_container article {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.pgroup_product.p_product_view .top_img_container table {
  border-top: 1px solid #333;
}
.pgroup_product.p_product_view .top_img_container table tr {
  border-bottom: 1px solid #e4e4e4;
}
.pgroup_product.p_product_view .top_img_container table th {
  font-size: 20px;
  letter-spacing: -0.05em;
  padding: 0 17px;
  font-weight: 400;
  text-align: left;
  width: 130px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container table th {
    font-size: 13px;
    letter-spacing: -0.025em;
    width: 67.5px;
    padding: 0;
  }
}
.pgroup_product.p_product_view .top_img_container table td {
  font-size: 20px;
  letter-spacing: -0.05em;
  color: #666;
  padding: 25px 0;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container table td {
    padding: 12.5px 0;
    font-size: 13px;
    letter-spacing: -0.025em;
  }
}
.pgroup_product.p_product_view .top_img_container table td.p_name {
  font-size: 40px;
  letter-spacing: -0.075em;
  color: #2a2a2a;
  font-weight: 700;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container table td.p_name {
    font-size: 20px;
    letter-spacing: -0.05em;
  }
}
.pgroup_product.p_product_view .top_img_container .btn_wrap {
  display: flex;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container .btn_wrap {
    margin-top: 23px;
  }
}
.pgroup_product.p_product_view .top_img_container .btn_wrap .btn {
  width: 25%;
}
.pgroup_product.p_product_view .top_img_container .btn_wrap .btn .arrow {
  transform: rotate(-90deg);
  width: 26px;
  margin-left: 20px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .top_img_container .btn_wrap .btn .arrow {
    width: 16px;
    margin-left: 10px;
  }
}
.pgroup_product.p_product_view .top_img_container .btn_wrap .btn + .btn {
  width: 75%;
  margin-left: 10px;
}
.pgroup_product.p_product_view .product_detail_container {
  margin-top: 65px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container {
    margin-top: 50px;
  }
}
.pgroup_product.p_product_view .product_detail_container h1 {
  font-size: 26px;
  letter-spacing: -0.075em;
  color: #333;
  font-weight: 700;
  padding-bottom: 25px;
  border-bottom: 1px solid #e4e4e4;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container h1 {
    padding-bottom: 12px;
    font-size: 16px;
    letter-spacing: -0.025em;
  }
}
.pgroup_product.p_product_view .product_detail_container h2 {
  margin-top: 38px;
  font-size: 20px;
  letter-spacing: -0.05em;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container h2 {
    margin-top: 17px;
    font-size: 13px;
    letter-spacing: -0.025em;
  }
}
.pgroup_product.p_product_view .product_detail_container table {
  margin-top: 30px;
  border-top: 1px solid #000;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container table {
    margin-top: 26px;
  }
}
.pgroup_product.p_product_view .product_detail_container tr {
  border-bottom: 1px solid #e4e4e4;
}
.pgroup_product.p_product_view .product_detail_container th {
  width: 300px;
  background-color: #f5f7f7;
  font-size: 18px;
  letter-spacing: -0.05em;
  color: #666;
  padding: 0 40px;
  font-weight: 400;
  text-align: left;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container th {
    width: 68px;
    font-size: 13px;
    letter-spacing: -0.025em;
    padding: 0 10px;
  }
}
.pgroup_product.p_product_view .product_detail_container td {
  padding: 25px 17px;
  font-size: 18px;
  letter-spacing: -0.05em;
  color: #333;
  line-height: 1.2;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container td {
    padding: 12px 7px;
    font-size: 13px;
    letter-spacing: -0.025em;
  }
}
.pgroup_product.p_product_view .product_detail_container figure {
  margin-top: 50px;
  margin-bottom: 50px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .product_detail_container figure {
    margin: 30px 0;
  }
}
.pgroup_product.p_product_view .btn_wrap.bottom {
  border-top: 1px solid #e4e4e4;
  padding: 30px 0;
  text-align: center;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_product.p_product_view .btn_wrap.bottom {
    padding-top: 17px;
  }
}
.pgroup_product .paging_wrap + button {
  position: absolute;
  right: 0;
  bottom: -5px;
  height: 50px;
  width: 244px;
}
@media screen and (max-width: 1239.9px) {
  .pgroup_product .paging_wrap + button {
    position: relative;
  }
}

.pgroup_recruit.p_talent hgroup {
  margin-bottom: 50px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent hgroup {
    margin-bottom: 35px;
  }
}
.pgroup_recruit.p_talent .page_title {
  font-size: 30px;
  letter-spacing: -0.075em;
  font-weight: 700;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent .page_title {
    font-size: 15px;
    letter-spacing: -0.025em;
  }
}
.pgroup_recruit.p_talent .page_desc {
  font-size: 18px;
  letter-spacing: -0.05em;
  line-height: 1.666;
  color: #333;
  margin-top: 26px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent .page_desc {
    font-size: 13px;
    letter-spacing: -0.025em;
    margin-top: 12px;
  }
}
.pgroup_recruit.p_talent ul {
  display: flex;
  margin-top: 110px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent ul {
    flex-direction: column;
    margin-top: 32px;
  }
}
.pgroup_recruit.p_talent ul li {
  text-align: center;
}
@media screen and (min-width: 1023.9px) {
  .pgroup_recruit.p_talent ul li {
    width: 33.333%;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent ul li + li {
    margin-top: 55px;
  }
}
.pgroup_recruit.p_talent ul img {
  display: inline-block;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent ul img {
    width: 50%;
    max-width: 160px;
  }
}
.pgroup_recruit.p_talent ul h1 {
  font-size: 20px;
  letter-spacing: -0.05em;
  color: #333;
  font-weight: 700;
  text-align: center;
  margin-top: 26px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent ul h1 {
    font-size: 15px;
    letter-spacing: -0.025em;
    margin-top: 20px;
  }
}
.pgroup_recruit.p_talent ul h2 {
  font-size: 18px;
  letter-spacing: -0.05em;
  color: #333;
  text-align: center;
  margin-top: 20px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_talent ul h2 {
    font-size: 13px;
    letter-spacing: -0.025em;
    margin-top: 12px;
  }
}
.pgroup_recruit.p_benefits hgroup {
  margin-bottom: 90px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_benefits hgroup {
    margin-bottom: 45px;
  }
}
.pgroup_recruit.p_benefits hgroup .sub_text {
  color: #000;
  text-align: center;
}
.pgroup_recruit.p_benefits .benefit_container {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_container {
    flex-direction: column;
    align-items: flex-start;
  }
}
.pgroup_recruit.p_benefits .benefit_container .title {
  font-size: 30px;
  letter-spacing: -0.075em;
  font-weight: 700;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_container .title {
    position: relative;
    width: 100%;
    font-size: 15px;
    letter-spacing: -0.025em;
  }
  .pgroup_recruit.p_benefits .benefit_container .title::before {
    position: absolute;
    top: 50%;
    content: "";
    display: inline-block;
    width: 100%;
    height: 1px;
    background-color: #333;
    z-index: -1;
  }
}
.pgroup_recruit.p_benefits .benefit_container .title span {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
}
@media screen and (min-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_container .title span {
    min-width: 102px;
    display: inline-block;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_container .title span {
    padding-right: 20px;
    background-color: #fff;
  }
}
.pgroup_recruit.p_benefits .benefit_container + .benefit_container {
  margin-top: 68.5px;
}
.pgroup_recruit.p_benefits .benefit_circle_wrap {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-around;
  margin-left: 40px;
}
@media screen and (min-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_circle_wrap::before {
    position: absolute;
    top: 50%;
    content: "";
    display: inline-block;
    width: 100%;
    height: 1px;
    background-color: #333;
    z-index: -1;
  }
  .pgroup_recruit.p_benefits .benefit_circle_wrap:last-child::after {
    position: absolute;
    top: 50%;
    right: 0;
    content: "";
    display: inline-block;
    width: 200px;
    height: 1px;
    background-color: #fff;
    z-index: -1;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_circle_wrap {
    margin-left: 0;
    flex-wrap: wrap;
    justify-content: space-evenly;
  }
}
@media screen and (max-width: 767.9px) {
  .pgroup_recruit.p_benefits .benefit_circle_wrap {
    justify-content: space-between;
  }
}
.pgroup_recruit.p_benefits .benefit_circle {
  width: 242px;
  background-color: #f6f6f6;
  border-radius: 50%;
}
@media screen and (max-width: 1239.9px) {
  .pgroup_recruit.p_benefits .benefit_circle {
    width: 24%;
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit.p_benefits .benefit_circle {
    width: 34%;
    margin-top: 18px;
  }
}
@media screen and (max-width: 767.9px) {
  .pgroup_recruit.p_benefits .benefit_circle {
    width: 49%;
  }
}
.pgroup_recruit.p_benefits .benefit_circle__inner {
  display: flex;
  align-items: center;
  flex-direction: column;
  width: 100%;
  height: 0;
  padding-bottom: 100%;
}
.pgroup_recruit.p_benefits .benefit_circle img {
  margin-top: 40px;
}
@media screen and (max-width: 1023.9px) and (min-width: 400px) {
  .pgroup_recruit.p_benefits .benefit_circle img {
    margin-top: 34%;
    transform: translateY(-50%);
  }
}
@media screen and (max-width: 639.9px) and (min-width: 400px) {
  .pgroup_recruit.p_benefits .benefit_circle img {
    transform: translateY(-40%);
  }
  .pgroup_recruit.p_benefits .benefit_circle img + h1 {
    margin-top: -1%;
  }
}
@media screen and (max-width: 400px) {
  .pgroup_recruit.p_benefits .benefit_circle img {
    margin-top: 15%;
  }
}
.pgroup_recruit.p_benefits .benefit_circle img.type2 {
  margin-top: 47px;
  margin-bottom: 6px;
}
@media screen and (max-width: 1023.9px) and (min-width: 639.9px) {
  .pgroup_recruit.p_benefits .benefit_circle img.type2 {
    margin-top: 40%;
    transform: translateY(-50%);
  }
}
@media screen and (max-width: 639.9px) and (min-width: 400px) {
  .pgroup_recruit.p_benefits .benefit_circle img.type2 {
    margin-top: 40%;
    transform: translateY(-40%);
  }
  .pgroup_recruit.p_benefits .benefit_circle img.type2 + h1 {
    margin-top: -4%;
  }
}
@media screen and (max-width: 400px) {
  .pgroup_recruit.p_benefits .benefit_circle img.type2 {
    margin-top: 20%;
    margin-bottom: 0;
  }
}
.pgroup_recruit.p_benefits .benefit_circle h1 {
  font-size: 20px;
  letter-spacing: -0.05em;
  line-height: 30px;
  color: #333;
  font-weight: 700;
  text-align: center;
  margin-top: 16px;
}
@media screen and (max-width: 767.9px) {
  .pgroup_recruit.p_benefits .benefit_circle h1 {
    font-size: 13px;
    letter-spacing: -0.025em;
    line-height: 20px;
    margin-top: 12px;
  }
}
.pgroup_recruit.p_benefits .benefit_circle h2 {
  font-size: 18px;
  letter-spacing: -0.05em;
  line-height: 30px;
  text-align: center;
  color: #333;
}
@media screen and (max-width: 1239.9px) {
  .pgroup_recruit.p_benefits .benefit_circle h2 {
    font-size: 15px;
    letter-spacing: -0.025em;
    line-height: 1.6;
  }
}
@media screen and (max-width: 767.9px) {
  .pgroup_recruit.p_benefits .benefit_circle h2 {
    font-size: 13px;
    letter-spacing: -0.025em;
    line-height: 20px;
  }
}
.pgroup_recruit .recru_process {
  margin-top: 40px;
}
.pgroup_recruit .recru_process h1 {
  font-size: 30px;
  letter-spacing: -0.075em;
  font-weight: 700;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit .recru_process h1 {
    font-size: 15px;
    letter-spacing: -0.025em;
  }
}
.pgroup_recruit .process_circle_wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 40px 0 60px;
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit .process_circle_wrap {
    margin-top: 17.5px;
    margin-bottom: 0;
    flex-wrap: wrap;
  }
}
.pgroup_recruit .process_circle {
  position: relative;
  width: 171px;
  background-color: #f6f6f6;
  border-radius: 50%;
  margin-right: calc(25% - 171px);
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit .process_circle {
    margin-right: calc(50% - 171px);
    margin-bottom: 32px;
  }
}
@media screen and (max-width: 575.9px) {
  .pgroup_recruit .process_circle {
    width: 118px;
    margin-right: calc(50% - 118px);
  }
}
.pgroup_recruit .process_circle__inner {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: 0;
  padding-top: 100%;
}
.pgroup_recruit .process_circle p {
  margin-top: 16px;
  font-size: 16px;
  letter-spacing: -0.025em;
  color: #333;
  text-align: center;
}
@media screen and (max-width: 575.9px) {
  .pgroup_recruit .process_circle p {
    margin-top: 12px;
    font-size: 13px;
    letter-spacing: -0.025em;
  }
}
.pgroup_recruit .process_circle h1 {
  font-size: 20px;
  letter-spacing: -0.05em;
  color: #333;
  font-weight: 700;
  text-align: center;
  margin-bottom: 24px;
}
@media screen and (max-width: 575.9px) {
  .pgroup_recruit .process_circle h1 {
    font-size: 13px;
    letter-spacing: -0.025em;
    margin-bottom: 13.5px;
  }
}
@media screen and (min-width: 1023.9px) {
  .pgroup_recruit .process_circle:last-child {
    margin-right: 0;
  }
}
.pgroup_recruit .process_circle:last-child::after {
  display: none;
}
.pgroup_recruit .process_circle::after {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  left: calc(100% + 65px);
  content: ">";
  display: inline-block;
  font-size: 40px;
  letter-spacing: -0.075em;
  font-weight: 100;
  color: #333;
}
@media screen and (max-width: 1239.9px) {
  .pgroup_recruit .process_circle::after {
    left: calc(25vw - 54px);
  }
}
@media screen and (max-width: 1023.9px) {
  .pgroup_recruit .process_circle::after {
    left: calc(75vw + 54px);
    transform: translateY(-50%) translateX(-50vw);
  }
}
@media screen and (max-width: 575.9px) {
  .pgroup_recruit .process_circle::after {
    left: calc(75vw + 39px);
    transform: translateY(-50%) translateX(-50vw);
  }
}

[class*=view_] {
  display: none;
}

@media screen and (min-width: 1680px) {
  .view_full_up {
    display: block;
  }
  .view_full_up.none {
    display: none;
  }
  .view_full_up.inblock {
    display: inline-block;
  }
  .view_full_up.flex {
    display: flex;
  }
  .view_full_up.inflex {
    display: inline-flex;
  }
  .view_full_up.table {
    display: table;
  }
}
@media screen and (max-width: 1680px) {
  .view_full {
    display: block;
  }
  .view_full.none {
    display: none;
  }
  .view_full.inblock {
    display: inline-block;
  }
  .view_full.flex {
    display: flex;
  }
  .view_full.inflex {
    display: inline-flex;
  }
  .view_full.table {
    display: table;
  }
}
@media screen and (min-width: 1449.9px) {
  .view_xxl_up {
    display: block;
  }
  .view_xxl_up.none {
    display: none;
  }
  .view_xxl_up.inblock {
    display: inline-block;
  }
  .view_xxl_up.flex {
    display: flex;
  }
  .view_xxl_up.inflex {
    display: inline-flex;
  }
  .view_xxl_up.table {
    display: table;
  }
}
@media screen and (max-width: 1449.9px) {
  .view_xxl {
    display: block;
  }
  .view_xxl.none {
    display: none;
  }
  .view_xxl.inblock {
    display: inline-block;
  }
  .view_xxl.flex {
    display: flex;
  }
  .view_xxl.inflex {
    display: inline-flex;
  }
  .view_xxl.table {
    display: table;
  }
}
@media screen and (min-width: 1239.9px) {
  .view_xl_up {
    display: block;
  }
  .view_xl_up.none {
    display: none;
  }
  .view_xl_up.inblock {
    display: inline-block;
  }
  .view_xl_up.flex {
    display: flex;
  }
  .view_xl_up.inflex {
    display: inline-flex;
  }
  .view_xl_up.table {
    display: table;
  }
}
@media screen and (max-width: 1239.9px) {
  .view_xl {
    display: block;
  }
  .view_xl.none {
    display: none;
  }
  .view_xl.inblock {
    display: inline-block;
  }
  .view_xl.flex {
    display: flex;
  }
  .view_xl.inflex {
    display: inline-flex;
  }
  .view_xl.table {
    display: table;
  }
}
@media screen and (min-width: 1023.9px) {
  .view_l_up {
    display: block;
  }
  .view_l_up.none {
    display: none;
  }
  .view_l_up.inblock {
    display: inline-block;
  }
  .view_l_up.flex {
    display: flex;
  }
  .view_l_up.inflex {
    display: inline-flex;
  }
  .view_l_up.table {
    display: table;
  }
}
@media screen and (max-width: 1023.9px) {
  .view_l {
    display: block;
  }
  .view_l.none {
    display: none;
  }
  .view_l.inblock {
    display: inline-block;
  }
  .view_l.flex {
    display: flex;
  }
  .view_l.inflex {
    display: inline-flex;
  }
  .view_l.table {
    display: table;
  }
}
@media screen and (min-width: 767.9px) {
  .view_m_up {
    display: block;
  }
  .view_m_up.none {
    display: none;
  }
  .view_m_up.inblock {
    display: inline-block;
  }
  .view_m_up.flex {
    display: flex;
  }
  .view_m_up.inflex {
    display: inline-flex;
  }
  .view_m_up.table {
    display: table;
  }
}
@media screen and (max-width: 767.9px) {
  .view_m {
    display: block;
  }
  .view_m.none {
    display: none;
  }
  .view_m.inblock {
    display: inline-block;
  }
  .view_m.flex {
    display: flex;
  }
  .view_m.inflex {
    display: inline-flex;
  }
  .view_m.table {
    display: table;
  }
}
@media screen and (min-width: 639.9px) {
  .view_s_up {
    display: block;
  }
  .view_s_up.none {
    display: none;
  }
  .view_s_up.inblock {
    display: inline-block;
  }
  .view_s_up.flex {
    display: flex;
  }
  .view_s_up.inflex {
    display: inline-flex;
  }
  .view_s_up.table {
    display: table;
  }
}
@media screen and (max-width: 639.9px) {
  .view_s {
    display: block;
  }
  .view_s.none {
    display: none;
  }
  .view_s.inblock {
    display: inline-block;
  }
  .view_s.flex {
    display: flex;
  }
  .view_s.inflex {
    display: inline-flex;
  }
  .view_s.table {
    display: table;
  }
}
@media screen and (min-width: 575.9px) {
  .view_xs_up {
    display: block;
  }
  .view_xs_up.none {
    display: none;
  }
  .view_xs_up.inblock {
    display: inline-block;
  }
  .view_xs_up.flex {
    display: flex;
  }
  .view_xs_up.inflex {
    display: inline-flex;
  }
  .view_xs_up.table {
    display: table;
  }
}
@media screen and (max-width: 575.9px) {
  .view_xs {
    display: block;
  }
  .view_xs.none {
    display: none;
  }
  .view_xs.inblock {
    display: inline-block;
  }
  .view_xs.flex {
    display: flex;
  }
  .view_xs.inflex {
    display: inline-flex;
  }
  .view_xs.table {
    display: table;
  }
}
@media screen and (min-width: 359.9px) {
  .view_xxs_up {
    display: block;
  }
  .view_xxs_up.none {
    display: none;
  }
  .view_xxs_up.inblock {
    display: inline-block;
  }
  .view_xxs_up.flex {
    display: flex;
  }
  .view_xxs_up.inflex {
    display: inline-flex;
  }
  .view_xxs_up.table {
    display: table;
  }
}
@media screen and (max-width: 359.9px) {
  .view_xxs {
    display: block;
  }
  .view_xxs.none {
    display: none;
  }
  .view_xxs.inblock {
    display: inline-block;
  }
  .view_xxs.flex {
    display: flex;
  }
  .view_xxs.inflex {
    display: inline-flex;
  }
  .view_xxs.table {
    display: table;
  }
}
@media screen and (min-width: 319.9px) {
  .view_mini_up {
    display: block;
  }
  .view_mini_up.none {
    display: none;
  }
  .view_mini_up.inblock {
    display: inline-block;
  }
  .view_mini_up.flex {
    display: flex;
  }
  .view_mini_up.inflex {
    display: inline-flex;
  }
  .view_mini_up.table {
    display: table;
  }
}
@media screen and (max-width: 319.9px) {
  .view_mini {
    display: block;
  }
  .view_mini.none {
    display: none;
  }
  .view_mini.inblock {
    display: inline-block;
  }
  .view_mini.flex {
    display: flex;
  }
  .view_mini.inflex {
    display: inline-flex;
  }
  .view_mini.table {
    display: table;
  }
}