@charset "UTF-8";
@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&family=Noto+Serif+JP:wght@300;400;500;600;700;900&display=swap";
@import "https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&display=swap";
a, abbr, acronym, address, applet, big, blockquote, body, caption, cite, code, dd, del, dfn, div, dl, dt, em, fieldset, font, form, h1, h2, h3, h4, h5, h6, html, iframe, img, ins, kbd, label, legend, li, object, ol, p, pre, q, s, samp, small, span, strike, strong, sub, sup, tbody, tfoot, thead, tt, ul, var, b {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
  list-style: none;
}

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  clear: both;
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
}

.txt_center {
  text-align: center !important;
}

.block_center {
  margin-left: auto !important;
  margin-right: auto !important;
}

.txt_left {
  text-align: left !important;
}

.txt_right {
  text-align: right !important;
}

.fleft {
  display: block;
  float: left;
}

.fright {
  display: block;
  float: right;
}

.txt_red {
  color: #f33;
}

.pl0 {
  padding-left: 0 !important;
}

.pr0 {
  padding-right: 0 !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.ml5 {
  margin-left: 5px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.pl5 {
  padding-left: 5px !important;
}

.pr5 {
  padding-right: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.pt8 {
  padding-top: 8px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.pl15 {
  padding-left: 15px !important;
}

.pr15 {
  padding-right: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.pl25 {
  padding-left: 25px !important;
}

.pr25 {
  padding-right: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.ml35 {
  margin-left: 35px !important;
}

.mr35 {
  margin-right: 35px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.pl35 {
  padding-left: 35px !important;
}

.pr35 {
  padding-right: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.ml45 {
  margin-left: 45px !important;
}

.mr45 {
  margin-right: 45px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.pl45 {
  padding-left: 45px !important;
}

.pr45 {
  padding-right: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.mt75 {
  margin-top: 75px !important;
}

* {
  box-sizing: border-box;
}

button {
  background-color: rgba(0, 0, 0, 0);
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

img {
  max-width: 100%;
  height: auto;
  width: auto;
}
@keyframes icon02_slide {
  0% {
    opacity: 0;
    transform: translateY(-50%) translateX(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(-50%) translateX(-50%);
  }
}
@keyframes icon03_slide {
  0% {
    opacity: 0;
    transform: translateY(-50%) translateX(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(-50%) translateX(-50%);
  }
}
@media print, screen and (min-width: 768px) {
  body {
    position: relative;
    z-index: 1;
    overflow-x: hidden;
    padding-top: 61px;
  }
  .sp {
    display: none !important;
  }
  a {
    vertical-align: bottom;
  }
  #page_top {
    position: fixed;
    top: 30%;
    right: 0;
    z-index: 1;
    writing-mode: vertical-rl;
  }
  #page_top img {
    width: 40px;
  }
  #page_top a {
    transition: opacity 0.5s;
    display: block;
    padding: 24px 10px 10px 13px;
    font-size: 10px;
    letter-spacing: 1px;
    color: #fff;
    position: relative;
  }
  #page_top a svg {
    content: "";
    display: block;
    width: 13px;
    position: absolute;
    top: 5px;
    right: 10px;
  }
  #page_top a:hover {
    opacity: 0.6;
  }
  p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.84px;
  }
  a {
    text-decoration: none;
    color: #000;
  }
  .overlay {
    padding-top: 0 !important;
  }
  .overlay header {
    background-color: rgba(255, 255, 255, 0.4);
  }
  .contens_wrp {
    padding: 80px;
    padding-bottom: 180px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  .contens_wrp {
    padding: 80px 2em 180px;
  }
}
@media print, screen and (min-width: 768px) {
  .contens_wrp .contens_inner {
    max-width: 1200px;
    margin: 0 auto;
  }
  .common_layout01 {
    max-width: 860px;
    width: 100%;
    margin: 0 auto;
  }
  .common_layout02 {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
  }
  #common_main_visual {
    background-image: url("/lib/img/recruit/main_visual.png");
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 440px;
    position: relative;
  }
  #common_main_visual .common_main_visual_inner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 80px;
    padding: 3px 15px 6px;
  }
  .btn01 {
    display: inline-block;
    line-height: 1;
    padding: 20px 50px;
    font-size: 13px;
    color: #fff;
    border: 1px solid #fff;
    transition: opacity 0.5s;
    letter-spacing: 0.78px;
  }
  .btn01:hover {
    opacity: 0.6;
  }
  .btn02 {
    display: inline-block;
    background-color: #000;
    border: 1px solid #000;
    width: 480px;
    text-align: center;
    color: #fff;
    font-size: 24px;
    letter-spacing: 2.16px;
    font-weight: 600;
    position: relative;
    transition: 0.5s;
  }
  .btn02 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
    padding: 25px;
  }
  .btn02 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
  }
  .btn02 svg.hover {
    display: none;
  }
  .btn02:hover svg:not(.hover) {
    display: none;
  }
  .btn02:hover svg.hover {
    display: block;
  }
  .btn02:hover span {
    cursor: pointer;
    background-position: -100% 0;
    color: #000;
  }
  .icon01 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
    vertical-align: bottom;
  }
  .icon01 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon01 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .icon01 svg.hover {
    display: none;
  }
  .icon01:hover svg:not(.hover) {
    display: none;
  }
  .icon01:hover svg.hover {
    display: block;
  }
  .icon01:hover span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .icon02 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
  }
  .icon02 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon02 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .icon02 svg.hover {
    display: none;
  }
  .icon02:hover svg:not(.hover) {
    display: none;
  }
  .icon02:hover svg.hover {
    display: block;
  }
  .icon02:hover span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .icon03 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
  }
  .icon03 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon03 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .icon03 svg.hover {
    display: none;
  }
  .icon03:hover svg:not(.hover) {
    display: none;
  }
  .icon03:hover svg.hover {
    display: block;
  }
  .icon03:hover span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .icon04 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
  }
  .icon04 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon04:before {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 15px;
    height: 2px;
    background-color: #fff;
    transition: 0.2s;
    transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
  }
  .icon04:after {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 15px;
    height: 2px;
    background-color: #fff;
    transition: 0.3s;
  }
  .icon04.on span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .icon04.on:before {
    transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    background-color: #000;
  }
  .icon04.on:after {
    background-color: rgba(0, 0, 0, 0);
    background-color: #000;
  }
  .htxt01 {
    font-size: 40px;
    letter-spacing: 2.4px;
    line-height: 1.48;
    font-weight: 400;
    color: #fff;
  }
  .htxt02 {
    font-size: 24px;
    color: #fff;
    letter-spacing: 1.44px;
  }
  .htxt03 {
    font-size: 24px;
    color: #000;
    line-height: 0.67;
    letter-spacing: 1.44px;
  }
  .htxt04 {
    font-size: 24px;
    letter-spacing: 1.44px;
    color: #000;
    font-weight: 600;
  }
  .htxt05 {
    font-size: 36px;
    letter-spacing: 2.16px;
    line-height: 1.48;
    color: #000;
    font-weight: 400;
  }
  .htxt06 {
    font-size: 26px;
    letter-spacing: 1.44px;
    line-height: 1.48;
    color: #000;
    font-weight: 600;
  }
  .htxt07 {
    font-size: 32px;
    letter-spacing: 2.4px;
    line-height: 1.48;
    color: #000;
    font-weight: 600;
    text-align: center;
    position: relative;
    padding-bottom: 24px;
  }
  .htxt07:before {
    content: "";
    position: absolute;
    background-color: #707070;
    width: 40px;
    height: 2px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  .htxt08 {
    font-size: 40px;
    letter-spacing: 2.4px;
    line-height: 1.48;
    font-weight: 400;
    color: #fff;
  }
  .htxt09 {
    font-size: 24px;
    letter-spacing: 2.16px;
    line-height: 1;
    background-color: #f0f0f0;
    padding: 15px 20px;
  }
  .htxt10 {
    letter-spacing: 2.16px;
    color: #fff;
    line-height: 1.48;
    background-color: #000;
    font-weight: 400;
    display: inline-block;
    padding: 3px 15px;
  }
  .date_list li {
    display: flex;
    align-items: center;
    margin-bottom: 22px;
  }
  .date_list li:last-child {
    margin-bottom: 0;
  }
  .date_list li p {
    line-height: 1;
    font-size: 16px;
    color: #a8a8a8;
    letter-spacing: 0.96px;
    font-weight: 500;
    margin-right: 40px;
  }
  .date_list li a {
    line-height: 1;
    font-size: 14px;
    color: #222;
  }
  .date_list li a:hover {
    text-decoration: underline;
  }
  .contents_list li {
    min-height: 360px;
  }
  .contents_list .list01 .list01_link {
    display: flex;
    min-height: 360px;
    transition: opacity 0.5s;
  }
  .contents_list .list01 .list01_link.col_img_txt {
    flex-direction: row-reverse;
  }
  .contents_list .list01 .list01_link:hover {
    opacity: 0.6;
  }
  .contents_list .list01 .list01_link:hover .icon01 svg:not(.hover) {
    display: none;
  }
  .contents_list .list01 .list01_link:hover .icon01 svg.hover {
    display: block;
  }
  .contents_list .list01 .list01_link:hover .icon01 span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .contents_list .contents_list_box01 {
    width: 50%;
    background-color: #e6e6e6;
    position: relative;
    padding: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .contents_list .contents_list_box01 .contents_list_box01_txtbox {
    width: 410px;
  }
  .contents_list .contents_list_box01 .contents_list_box01_txtbox .htxt04 {
    margin-bottom: 20px;
  }
  .contents_list .contents_list_box01 .contents_list_box01_icon_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  .contents_list .contents_list_box02 {
    width: 50%;
    background-size: cover;
    background-position: center;
  }
  .top_interview_wrp {
    min-height: 540px;
    padding-left: 370px;
    position: relative;
    margin-right: calc((100% - 100vw) / 2);
    margin-bottom: 80px;
  }
  .top_interview_wrp .top_interview_box01 {
    background-color: #e6e6e6;
    padding: 30px;
    width: 370px;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .top_interview_wrp .top_interview_box01 .top_interview_box01_txtbox {
    width: 240px;
  }
  .top_interview_wrp .top_interview_box01 .top_interview_box01_txtbox .htxt04 {
    margin-bottom: 20px;
  }
  .top_interview_slide li {
    background-size: cover;
    background-position: center;
    max-width: 420px;
    width: 100%;
    height: 100%;
    min-height: 540px;
    position: relative;
    transition: opacity 0.5s;
  }
  .top_interview_slide li:hover {
    opacity: 0.6;
  }
  .top_interview_slide li a {
    display: block;
    min-height: 540px;
  }
  .top_interview_slide li .top_interview_slide_txtbox {
    position: absolute;
    left: 30px;
    bottom: 25px;
  }
  .top_interview_slide li .top_interview_slide_txtbox .top_interview_slide_txtbox_txt01 {
    font-size: 13px;
    letter-spacing: 0.78px;
    line-height: 1.48;
    color: #fff;
    font-weight: 500;
  }
  .top_interview_slide li .top_interview_slide_txtbox .top_interview_slide_txtbox_txt02 {
    font-size: 24px;
    line-height: 1.48;
    letter-spacing: 1.44px;
    font-weight: 600;
    color: #fff;
    margin: 15px 0 5px;
  }
  .top_interview_slide li .top_interview_slide_txtbox .top_interview_slide_txtbox_txt03 {
    font-size: 16px;
    line-height: 1.48;
    letter-spacing: 0.96px;
    color: #fff;
  }
  .top_interview_slide .prev_arrow {
    position: absolute;
    bottom: 0;
    left: -120px;
  }
  .top_interview_slide .next_arrow {
    position: absolute;
    bottom: 0;
    left: -60px;
  }
  .contents_list02 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .contents_list02 li {
    width: 48.5%;
  }
  .contents_list02 li a {
    display: block;
    height: 100%;
    transition: opacity 0.5s;
  }
  .contents_list02 li a:hover {
    opacity: 0.6;
  }
  .contents_list02 li a:hover .icon01 svg:not(.hover) {
    display: none;
  }
  .contents_list02 li a:hover .icon01 svg.hover {
    display: block;
  }
  .contents_list02 li a:hover .icon01 span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .contents_list02 li .htxt04 {
    margin-top: 5px;
  }
  .contents_list02 li .contents_list02_box {
    position: relative;
    min-height: 320px;
    height: 100%;
    background-size: cover;
    background-position: center;
  }
  .contents_list02 li .contents_list02_box .contents_list02_box_icon_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  #recommend {
    padding-top: 60px;
    padding-bottom: 120px;
  }
  #recommend .recommend_inner {
    max-width: 1200px;
    margin: 0 auto;
  }
  #recommend .htxt06 {
    text-align: center;
    margin-bottom: 55px;
  }
  .table01 {
    border: 1px solid #e0e0e0;
    border-collapse: collapse;
    width: 100%;
  }
  .table01 tr, .table01 td {
    border: 1px solid #e0e0e0;
    text-align: left;
  }
  .table01 th {
    width: auto;
    padding: 20px;
    font-size: 14px;
    white-space: nowrap;
    width: 20%;
    background-color: #f7f7f7;
  }
  .table01 td {
    padding: 20px;
    font-size: 14px;
    width: 80%;
  }
  .table01 td a {
    color: #0093ff;
  }
  .table01 td a:hover {
    text-decoration: underline;
  }
  .select_01 {
    position: relative;
  }
  .select_01 select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }
  .select_01 select:-ms-expand {
    display: none;
  }
  .select_01:before {
    position: absolute;
    top: 50%;
    right: 0.4em;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 4.5px solid rgba(0, 0, 0, 0);
    border-right: 4.5px solid rgba(0, 0, 0, 0);
    border-top: 7px solid #707070;
    pointer-events: none;
  }
  header {
    background-color: #fff;
    padding: 8px 25px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 61px;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 4999;
  }
  header .logo_wrp a {
    display: inline-block;
    transition: opacity 0.5s;
  }
  header .logo_wrp a:hover {
    opacity: 0.6;
  }
  header .logo_wrp a img {
    vertical-align: bottom;
    height: 44px;
    width: auto;
  }
  header .entry_btn_wrp {
    min-width: 170px;
    position: relative;
    margin-left: auto;
    margin-right: 25px;
  }
  header .entry_btn_wrp .entry_btn01 {
    font-size: 16px;
    color: #fff;
    letter-spacing: 0.96px;
    display: inline-block;
    background-color: #000;
    height: 45px;
    line-height: 45px;
    padding: 0 38px 0 18px;
    text-align: center;
    position: relative;
    width: 100%;
  }
  header .entry_btn_wrp .entry_btn01 svg {
    position: absolute;
    width: 11px;
    height: 7px;
    background-size: contain;
    background-repeat: no-repeat;
    top: 53%;
    transform: translateY(-50%);
    right: 24px;
  }
  header .entry_btn_wrp .entry_btn02 {
    position: absolute;
    left: 0;
    top: 45px;
    width: 100%;
    z-index: 99;
  }
  header .entry_btn_wrp .entry_btn02 a {
    display: block;
    min-height: 45px;
    line-height: 1.4;
    text-align: center;
    font-size: 16px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    padding: 10px 18px;
  }
  header .entry_btn_wrp .entry_btn02 .entry_btn02_01 {
    background-color: dimgray;
  }
  header .entry_btn_wrp .entry_btn02 .entry_btn02_02 {
    background-color: #525252;
  }
  header .entry_btn_wrp:not(.js_entry_btn_wrp) .entry_btn01 svg {
    transform: rotate(-90deg);
    top: 45%;
  }
  header .btn-trigger {
    position: relative;
    width: 40px;
    height: 22px;
    cursor: pointer;
  }
  header .btn-trigger:hover span {
    width: 100% !important;
  }
  header .btn-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #000;
  }
  header .btn-trigger span:nth-child(2) {
    width: 60%;
  }
  header .btn-trigger span:nth-child(3) {
    width: 70%;
  }
  header .btn-trigger, header .btn-trigger span {
    display: inline-block;
    transition: all 0.3s;
    box-sizing: border-box;
  }
  header .btn-trigger span:nth-of-type(1) {
    top: 0;
  }
  header .btn-trigger span:nth-of-type(2) {
    top: 10px;
  }
  header .btn-trigger span:nth-of-type(3) {
    bottom: 0;
  }
  #main_menu {
    max-width: 975px;
    width: 100%;
    background-color: #000;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 99999999999999;
    padding: 120px 80px;
    transform: translateX(100%);
    transition: transform 0.5s;
  }
  #main_menu .close_btn {
    position: absolute;
    right: 30px;
    top: 30px;
  }
  #main_menu .main_menu_link_list {
    margin-bottom: -40px;
    width: 100%;
    justify-content: space-between;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
  }
  #main_menu .main_menu_link_list::before {
    order: 1;
  }
  #main_menu .main_menu_link_list::before, #main_menu .main_menu_link_list::after {
    content: "";
    display: block;
    width: 200px;
  }
  #main_menu .main_menu_link_list li {
    width: 200px;
    margin-bottom: 40px;
    vertical-align: middle;
  }
  #main_menu .main_menu_link_list li a {
    font-size: 16px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
  }
  #main_menu .main_menu_link_list li a:hover {
    opacity: 0.6;
  }
  #main_menu .main_menu_link_list li span {
    font-size: 16px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    display: inline-block;
    cursor: pointer;
    padding-right: 0.5em;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list li {
    margin-bottom: 10px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list li:first-child {
    margin-top: 10px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list li a {
    font-size: 0.8em;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle {
    display: inline-block;
    width: 15px;
    height: 15px;
    cursor: pointer;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span {
    display: block;
    position: relative;
    width: 15px;
    height: 15px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span::before, #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span::after {
    content: "";
    display: block;
    width: 15px;
    height: 2px;
    border-radius: 5px;
    background: #fff;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span::after {
    background: #fff;
    transform: translateY(-50%) rotate(90deg);
    transition: 0.5s;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle .active::after {
    transform: translateY(-50%) rotate(0);
    transition: 0.5s;
  }
  #main_menu .main_menu_link_list02 li {
    margin-bottom: 20px;
  }
  #main_menu .main_menu_link_list02 li a {
    font-size: 14px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    display: block;
    text-align: right;
  }
  #main_menu .main_menu_link_list02 li a:hover {
    opacity: 0.6;
  }
  .active_menu {
    transform: translateX(0) !important;
  }
  footer #cookies_alert {
    position: fixed;
    bottom: 20px;
    left: 0;
    right: 0;
    padding: 0 80px;
    margin-right: auto;
    margin-left: auto;
    z-index: 99999999;
  }
  footer #cookies_alert .contens_inner {
    background-color: #fff;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
    max-width: 1200px;
    margin-right: auto;
    margin-left: auto;
    padding: 1em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: 0.25rem;
  }
  footer #cookies_alert .contens_inner .inner_txt {
    width: calc(100% - 104px);
  }
  footer #cookies_alert .contens_inner .inner_txt p {
    line-height: 1.3;
  }
  footer #cookies_alert .contens_inner .inner_txt a {
    text-decoration: underline;
  }
  footer #cookies_alert .contens_inner .inner_txt a:hover {
    text-decoration: none;
  }
  footer #cookies_alert .contens_inner .inner_remove #js_remove {
    background-color: #999595;
    border-radius: 5px;
    color: #fff;
    padding: 3px 15px;
    cursor: pointer;
    transition: all 0.2s;
  }
  footer #cookies_alert .contens_inner .inner_remove #js_remove:hover {
    background-color: rgba(153, 149, 149, 0.7);
  }
  footer .entry_wrp {
    display: flex;
    flex-wrap: wrap;
  }
  footer .entry_wrp div {
    width: 50%;
    flex-grow: 1;
  }
  footer .entry_wrp div a {
    width: 100%;
    height: 100%;
    display: block;
    text-align: center;
    font-size: 24px;
    letter-spacing: 1.44px;
    padding: 35px;
    color: #fff;
    font-weight: 600;
    transition: opacity 0.5s;
  }
  footer .entry_wrp div a:hover {
    opacity: 0.6;
  }
  footer .entry_wrp .entry_box01 a {
    background-color: dimgray;
  }
  footer .entry_wrp .entry_box02 a {
    background-color: #525252;
  }
  footer .footer_link {
    width: 100%;
    padding: 80px;
    background-color: #1d1d1d;
  }
  footer .footer_link .footer_link_inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
  footer .footer_link .footer_link_inner .footer_link_list {
    display: flex;
    flex-wrap: wrap;
    width: 70%;
    margin-bottom: -40px;
  }
  footer .footer_link .footer_link_inner .footer_link_list li {
    width: 200px;
    margin-bottom: 40px;
  }
  footer .footer_link .footer_link_inner .footer_link_list li a {
    font-size: 16px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
  }
  footer .footer_link .footer_link_inner .footer_link_list li a:hover {
    opacity: 0.6;
  }
  footer .footer_link .footer_link_inner .footer_link_list li span {
    font-size: 16px;
    color: #fff;
    letter-spacing: 0.96px;
    display: inline-block;
    cursor: pointer;
    padding-right: 0.5em;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list li {
    margin-bottom: 10px;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list li:first-child {
    margin-top: 10px;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list li a {
    font-size: 0.8em;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list_toggle {
    display: inline-block;
    width: 15px;
    height: 15px;
    cursor: pointer;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list_toggle span {
    display: block;
    position: relative;
    width: 15px;
    height: 15px;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list_toggle span::before, footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list_toggle span::after {
    content: "";
    display: block;
    width: 15px;
    height: 2px;
    border-radius: 5px;
    background: #fff;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list_toggle span::after {
    background: #fff;
    transform: translateY(-50%) rotate(90deg);
    transition: 0.5s;
  }
  footer .footer_link .footer_link_inner .footer_link_list li .sub_menu_link_list_toggle .active::after {
    transform: translateY(-50%) rotate(0);
    transition: 0.5s;
  }
  footer .footer_link .footer_link_inner .footer_link_list02 li {
    margin-bottom: 20px;
  }
  footer .footer_link .footer_link_inner .footer_link_list02 li a {
    font-size: 14px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    display: block;
    text-align: right;
  }
  footer .footer_link .footer_link_inner .footer_link_list02 li a:hover {
    opacity: 0.6;
  }
  footer .footer_copyright {
    text-align: center;
    background-color: #000;
    padding: 12px;
  }
  footer .footer_copyright p {
    font-size: 13px;
    color: #fff;
  }
  .content_with800px {
    background-color: #fff;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    width: 800px;
    padding: 0 80px;
  }
  .content_with1160px {
    background-color: #fff;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    max-width: 1160px;
    width: 100%;
    padding: 0 80px;
  }
  .gutenberg_content {
    line-height: 1.8;
    font-size: 14px;
  }
  .gutenberg_content a {
    text-decoration: underline;
  }
  .gutenberg_content h2 {
    font-size: 26px;
    text-align: center;
    padding-bottom: 35px;
    position: relative;
    margin-bottom: 1.5em;
  }
  .gutenberg_content h2::after {
    content: "";
    display: block;
    width: 40px;
    height: 2px;
    position: absolute;
    right: -100%;
    bottom: 0;
    left: -100%;
    margin-right: auto;
    margin-left: auto;
    background-color: #707070;
  }
  .gutenberg_content p {
    margin-bottom: 1em;
    line-height: 1.8;
  }
  .gutenberg_content .wp-block-image {
    text-align: center;
    margin-bottom: 1em;
  }
  .gutenberg_content .wp-block-image img {
    height: auto;
  }
  .gutenberg_content .wp-block-getwid-images-slider {
    margin-bottom: 1em;
  }
  .gutenberg_content .wp-block-getwid-table {
    margin-bottom: 1em;
    font-size: 14px;
  }
  .gutenberg_content .wp-block-getwid-table table {
    border-collapse: collapse;
    width: 100%;
  }
  .gutenberg_content .wp-block-getwid-table table th, .gutenberg_content .wp-block-getwid-table table td {
    padding: 0.6em 0.4em;
    border: 1px solid #e0e0e0;
    word-break: break-all;
  }
  .gutenberg_content .wp-block-getwid-table:not(.has-table-layout-fixed) table th, .gutenberg_content .wp-block-getwid-table:not(.has-table-layout-fixed) table td {
    white-space: nowrap;
  }
  .gutenberg_content .wp-block-image {
    text-align: center;
  }
  .gutenberg_content .wp-block-image figcaption {
    margin-bottom: 2px;
  }
  .gutenberg_content em {
    font-style: italic;
  }
  .gutenberg_content figcaption {
    font-size: 14px;
  }
  .gutenberg_content .wp-block-column:not(:first-child) {
    margin-left: 2em;
  }
  .wp-block-cover p {
    margin-bottom: 0;
  }
  #jobs .gutenberg_content h3 {
    font-weight: normal;
    margin-bottom: 24px;
    padding-left: 18px;
    font-size: 24px;
    position: relative;
  }
  #jobs .gutenberg_content h3::before {
    content: "";
    display: block;
    width: 4px;
    height: 100%;
    background-color: #707070;
    position: absolute;
    top: 0;
    left: 0;
  }
  #news .gutenberg_content h3 {
    font-weight: normal;
    background-color: #f0f0f0;
    margin-bottom: 24px;
    padding: 12px 18px;
    font-size: 24px;
  }
  #news .gutenberg_content .wp-block-getwid-table {
    margin-left: 0;
    margin-right: 0;
  }
  #pager_post {
    padding-top: 100px;
  }
  #pager_post .pager_post_inner .pager_post_row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 580px;
    margin-right: auto;
    margin-left: auto;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow {
    width: 100px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area {
    display: flex;
    align-items: center;
    transition: all 0.2s;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area:hover {
    opacity: 0.7;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area svg {
    width: 23px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area .pager_post_str {
    display: block;
    width: 65px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_col_prev .pager_post_area svg {
    margin-right: 11px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_next .pager_post_area svg {
    transform: scale(-1, 1);
    margin-left: 11px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list {
    width: 80px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area {
    display: block;
    text-align: center;
    transition: all 0.2s;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area:hover {
    opacity: 0.7;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area svg {
    display: inline-block;
    margin-bottom: 10px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area .pager_post_str {
    display: block;
  }
  #top_contents {
    margin-bottom: 160px;
  }
  #top_contents .contens_wrp {
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    margin: 80px 0;
  }
  #top_main_visual {
    background-size: cover !important;
    background-position: center !important;
    background-attachment: scroll !important;
    background-repeat: no-repeat !important;
    width: 100%;
    height: 660px;
    position: relative;
  }
  #top_main_visual .top_main_visual_htxt .top_main_visual_htxt_inner {
    padding: 3px 15px 6px;
    display: inline-block;
  }
  .top_about {
    background-image: url("/lib/img/about_bg.png");
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 450px;
    margin-top: 80px;
    position: relative;
  }
  .top_about p {
    color: #fff;
  }
  .top_about .top_about_inner {
    width: 410px;
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
  }
  .top_about .top_about_inner h2 {
    margin-bottom: 15px;
  }
  .top_about .top_about_inner p {
    margin-bottom: 40px;
  }
  .top_news {
    background-color: #f2f2f2;
    padding: 45px 0;
  }
  .top_news .top_news_inner {
    max-width: 1200px;
    padding-left: 5%;
    margin: 0 auto;
    position: relative;
  }
  .top_news .top_news_inner .date_list {
    margin-top: 30px;
  }
  .top_news .top_news_inner .news_icon_wrp {
    position: absolute;
    right: 0;
    bottom: -45px;
  }
  #interview #interview_other.contens_wrp {
    padding-top: 0;
  }
  #interview .interview_list_wrp .interview_list01 {
    padding: 80px 60px;
  }
  #interview .interview_list_wrp .interview_list01 .interview_list_txt01 {
    font-size: 18px;
    line-height: 2;
    letter-spacing: 1.44px;
    text-align: center;
  }
  #interview .interview_list_wrp .interview_list02 {
    background-color: #f0f0f0;
    padding: 120px 80px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_list_wrp .interview_list02 {
    padding: 120px 40px;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_list_wrp .interview_list02 .interview_list02_inner {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider {
    margin: 0 -20px;
    display: flex;
    flex-wrap: wrap;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li {
    margin-bottom: 60px;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div {
    padding: 41.49% 0;
    width: 100%;
    position: relative;
    overflow: hidden;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div img {
    position: absolute;
    top: -100%;
    right: -100%;
    bottom: -100%;
    left: -100%;
    margin: auto;
    max-width: none;
    display: none;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div img.img_hor {
    width: auto;
    height: 100%;
    display: block;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div img.img_ver {
    width: 100%;
    height: auto;
    display: block;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li {
    width: 44%;
    margin-bottom: 40px;
  }
}
@media print, screen and (min-width: 768px) {
  #interview #js_more_btn {
    text-align: center;
    margin-top: 3.5em;
  }
  #interview #js_more_btn button {
    padding: 1em 3em;
    background-color: #000;
    color: #fff;
    font-size: 1.1em;
    transition: all 0.2s;
  }
  #interview #js_more_btn button:hover {
    opacity: 0.7;
  }
  #interview #interview_main_visual {
    background-size: cover;
    background-position: top;
    width: 100%;
    height: 660px;
    position: relative;
  }
  #interview #interview_main_visual .interview_main_visual_htxt {
    left: 80px;
    bottom: 50px;
    position: absolute;
    padding: 3px 15px 6px;
  }
  #interview #interview_main_visual .interview_main_visual_htxt.txt_shadow {
    text-shadow: #333 2px 0px 2px, #333 -2px 0px 2px, #333 0px -2px 2px, #333 -2px 0px 2px, #333 2px 2px 2px, #333 -2px 2px 2px, #333 2px -2px 2px, #333 -2px -2px 2px, #333 1px 2px 2px, #333 -1px 2px 2px, #333 1px -2px 2px, #333 -1px -2px 2px, #333 2px 1px 2px, #333 -2px 1px 2px, #333 2px -1px 2px, #333 -2px -1px 2px, #333 1px 1px 2px, #333 -1px 1px 2px, #333 1px -1px 2px, #333 -1px -1px 2px;
  }
  #interview #interview_main_visual .interview_main_visual_htxt .interview_main_visual_htxt_txt01 {
    font-size: 20px;
    line-height: 1.48;
    letter-spacing: 1.2px;
    color: #fff;
    font-weight: 500;
  }
  #interview #interview_main_visual .interview_main_visual_htxt .interview_main_visual_htxt_txt02 {
    font-size: 40px;
    line-height: 1.48;
    letter-spacing: 2.4px;
    color: #fff;
    font-weight: 400;
    margin-top: 15px;
  }
  #interview #interview_main_visual .interview_main_visual_htxt .interview_main_visual_htxt_txt03 {
    font-size: 24px;
    letter-spacing: 1.44px;
    line-height: 1.8;
    color: #fff;
    margin-top: 35px;
  }
  #interview .interview_contents {
    padding-top: 60px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_contents {
    padding-top: 30px;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_contents .interview_layout_txt01 {
    font-size: 13px;
    letter-spacing: 0.78px;
    font-weight: 600;
  }
  #interview .interview_contents .htxt05 {
    margin-top: 15px;
    margin-bottom: 35px;
  }
  #interview .interview_contents .interview_layout {
    margin-bottom: 140px;
  }
  #interview .interview_contents .interview_layout:last-child {
    margin-bottom: 0;
  }
  #interview .interview_contents .interview_layout .youtube_wrp {
    position: relative;
    padding: 28.4% 0;
    overflow: hidden;
  }
  #interview .interview_contents .interview_layout .youtube_wrp iframe {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 100%;
  }
  #interview .interview_contents .interview_layout01 {
    display: flex;
    align-items: center;
  }
  #interview .interview_contents .interview_layout01 .interview_layout01_box01 {
    max-width: 540px;
    width: 100%;
    margin-right: 60px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_contents .interview_layout01 .interview_layout01_box01 {
    margin-right: 1.5em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_contents .interview_layout01 .interview_layout01_box02 {
    margin-right: -80px;
    max-width: 680px;
    width: 100%;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_contents .interview_layout01 .interview_layout01_box02 {
    margin-right: -2em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_contents .interview_layout02 .interview_layout02_box01 {
    margin-bottom: 55px;
  }
  #interview .interview_contents .interview_layout02 .interview_layout02_box02 {
    max-width: 620px;
    margin: 0 auto;
  }
  #interview .interview_contents .interview_layout03 {
    display: flex;
    align-items: center;
  }
  #interview .interview_contents .interview_layout03 .interview_layout03_box01 {
    margin-left: -80px;
    max-width: 680px;
    width: 100%;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_contents .interview_layout03 .interview_layout03_box01 {
    margin-left: -2em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_contents .interview_layout03 .interview_layout03_box02 {
    max-width: 540px;
    width: 100%;
    margin-left: 60px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_contents .interview_layout03 .interview_layout03_box02 {
    margin-left: 1.5em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview #interview_schedule {
    padding-bottom: 0;
    padding-top: 0;
    margin-bottom: 80px;
  }
  #interview #interview_schedule .contens_inner .interview_schedule_row1 {
    width: 202px;
  }
  #interview #interview_schedule .contens_inner .interview_schedule_row2 {
    background-color: #f7f7f7;
    padding: 0 20px;
  }
  #interview #interview_schedule .interview_schedule_ttl {
    background-color: #0a4b6a;
    color: #fff;
    text-align: center;
    font-weight: normal;
    line-height: 1;
    padding: 13.5px 0;
    font-size: 18px;
  }
  #interview #interview_schedule .interview_schedule_items {
    padding: 130px 0;
    max-width: 755px;
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    position: relative;
  }
  #interview #interview_schedule .interview_schedule_items::before {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    position: absolute;
    top: 0;
    left: 80px;
    background-color: #0a4b6a;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item:not(:last-child) {
    margin-bottom: 85px;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item .interview_schedule_item_row {
    display: flex;
    justify-content: space-between;
    width: 100%;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item .interview_schedule_item_row > .interview_schedule_item_col1 {
    min-width: 80px;
    padding-right: 20px;
    padding-top: 5px;
    position: relative;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item .interview_schedule_item_row > .interview_schedule_item_col1::after {
    content: "";
    display: block;
    width: 11px;
    height: 11px;
    background-color: #0a4b6a;
    border-radius: 50%;
    position: absolute;
    top: 11px;
    left: 75px;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item .interview_schedule_item_row > .interview_schedule_item_col2 {
    width: calc(100% - 80px);
    padding-left: 20px;
  }
  #interview #interview_schedule .interview_schedule_items .item_time {
    color: #0a4b6a;
    line-height: 1;
    font-size: 22px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  #interview #interview_schedule .interview_schedule_items .item_row > .item_col_width {
    width: 100%;
  }
  #interview #interview_schedule .interview_schedule_items .item_row > .item_col1 {
    max-width: calc(100% - 200px);
    width: 69.25%;
    padding-right: 15px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row > .item_col2 {
    max-width: 200px;
    width: 30.75%;
  }
  #interview #interview_schedule .interview_schedule_items .item_ttl {
    font-size: 24px;
    margin-bottom: 15px;
    font-weight: normal;
  }
  #interview #interview_schedule .interview_schedule_items .item_txt {
    font-size: 14px;
  }
  #interview #interview_schedule .interview_schedule_items .item_txt p:not(:last-child) {
    margin-bottom: 8px;
  }
  #interview #interview_schedule .interview_schedule_items .item_txt a {
    text-decoration: underline;
  }
  #interview #interview_schedule .interview_schedule_time {
    color: #0a4b6a;
    font-size: 22px;
    line-height: 1;
  }
  #interview .interview_other_wrp {
    padding: 120px 80px;
    margin: 0 -80px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_other_wrp {
    padding: 120px 2em;
    margin: 0 -2em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_other_wrp .htxt06 {
    text-align: center;
  }
  #interview .interview_other_slider {
    position: relative;
    margin-top: 55px;
  }
  #interview .interview_other_slider .prev_arrow {
    position: absolute;
    top: 120px;
    left: -80px;
    z-index: 99;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_other_slider .prev_arrow {
    left: -2em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_other_slider .next_arrow {
    position: absolute;
    top: 120px;
    right: -80px;
    z-index: 99;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #interview .interview_other_slider .next_arrow {
    right: -2em;
  }
}
@media print, screen and (min-width: 768px) {
  #interview .interview_other_slider li {
    max-width: 370px;
    width: 100%;
    margin: 0 20px;
  }
  #interview .interview_other_slider li a {
    transition: opacity 0.5s;
    display: block;
  }
  #interview .interview_other_slider li a:hover {
    opacity: 0.6;
  }
  #interview .interview_other_slider li a div {
    padding: 41.085% 0;
    width: 100%;
    position: relative;
    overflow: hidden;
  }
  #interview .interview_other_slider li a div img {
    position: absolute;
    top: -100%;
    right: -100%;
    bottom: -100%;
    left: -100%;
    margin: auto;
    max-width: none;
  }
  #interview .interview_other_slider li a div img.img_hor {
    width: auto;
    height: 100%;
  }
  #interview .interview_other_slider li a div img.img_ver {
    width: 100%;
    height: auto;
  }
  #interview .interview_other_slider li .interview_other_slider_txt01 {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.48;
    letter-spacing: 0.78px;
    margin-top: 25px;
  }
  #interview .interview_other_slider li .interview_other_slider_txt02 {
    font-size: 24px;
    line-height: 1.48;
    letter-spacing: 1.44px;
    font-weight: 600;
    margin: 15px 0 5px;
  }
  #interview .interview_other_slider li .interview_other_slider_txt03 {
    font-size: 16px;
    line-height: 1.48;
    letter-spacing: 0.96px;
    margin-top: 5px;
  }
  #entry .entry_form_wrp {
    max-width: 950px;
    margin: 0 auto;
    padding: 0 45px;
  }
  #entry .contens_wrp {
    padding-bottom: 100px;
  }
  #entry .recruit_select_wrp {
    background-color: #f0f0f0;
    padding: 100px 0;
    position: relative;
  }
  #entry .recruit_select_wrp:before {
    position: absolute;
    content: "";
    border-top: 16px solid #f0f0f0;
    border-right: 16px solid rgba(0, 0, 0, 0);
    border-bottom: 16px solid rgba(0, 0, 0, 0);
    border-left: 16px solid rgba(0, 0, 0, 0);
    left: 50%;
    transform: translateX(-50%);
    bottom: -32px;
  }
  #entry .recruit_select_wrp .recruit_select_inner {
    display: flex;
    justify-content: center;
    padding: 0 30px;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box {
    display: flex;
    align-items: center;
    margin-right: 50px;
  }
}
@media print and (max-width: 1280px), screen and (min-width: 768px) and (max-width: 1280px) {
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box {
    margin-right: 1em;
  }
}
@media print, screen and (min-width: 768px) {
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box:last-child {
    margin-right: 0;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box p {
    font-size: 18px;
    font-weight: 600;
    margin-right: 15px;
    white-space: nowrap;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box select {
    background-color: #fff;
    border: 1px solid #e0e0e0;
    padding: 8px 30px 8px 20px;
    font-size: 16px;
  }
  #entry .recruit_contents_list {
    margin-top: 70px;
  }
  #entry .recruit_contents_list li {
    position: relative;
    margin-bottom: 80px;
  }
  #entry .recruit_contents_list li:last-child {
    margin-bottom: 0;
  }
  #entry .recruit_contents_list li h3 {
    width: 100%;
    background-color: #f0f0f0;
    padding: 12px 20px;
  }
  #entry .recruit_contents_list li .recruit_contents_list_txtbox {
    display: flex;
    align-items: stretch;
    min-height: 58px;
    border: 1px solid #e0e0e0;
    box-sizing: border-box;
  }
  #entry .recruit_contents_list li .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt01 {
    background-color: #f7f7f7;
    width: 20%;
    padding: 12px 20px;
    font-size: 16px;
    font-weight: 600;
    min-height: 58px;
    border-right: 1px solid #e0e0e0;
  }
  #entry .recruit_contents_list li .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 {
    width: 80%;
    background-color: #fff;
    height: 100%;
    font-size: 14px;
    min-height: 58px;
    line-height: 2;
    letter-spacing: 0.84px;
    padding: 16px 30px;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 {
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 .txt_inner {
    width: calc(100% - 60px);
    padding-top: 16px;
    padding-bottom: 16px;
    padding-right: 30px;
    padding-left: 30px;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn {
    width: 60px;
    margin-right: -1px;
    align-self: flex-end;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn .btn_anchor::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn .btn_anchor:hover .icon01 span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn .btn_anchor:hover .icon01 svg:not(.hover) {
    display: none;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn .btn_anchor:hover .icon01 svg.hover {
    display: block;
  }
  #entry .recruit_contact {
    background-color: #f0f0f0;
    padding: 60px;
    text-align: center;
  }
  #entry .recruit_contact .recruit_contact_txt01 {
    font-size: 24px;
    font-weight: 600;
    letter-spacing: 2.16px;
    line-height: 1;
  }
  #entry .recruit_contact .recruit_contact_txt02 {
    font-size: 45px;
    font-weight: 600;
    letter-spacing: 3.6px;
    line-height: 1;
    margin: 20px 0 20px;
  }
  #entry .recruit_contact .recruit_contact_txt02 a:hover {
    text-decoration: underline;
  }
  #entry .recruit_contact .recruit_contact_txt03 {
    font-size: 14px;
    letter-spacing: 0.84px;
    line-height: 1;
  }
  #entry #area_btn {
    margin-top: 80px;
  }
  #entry #area_btn .fixed {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    padding-top: 2%;
    padding-right: 2em;
    padding-left: 2em;
  }
  #entry #area_btn .area_btn_shadow {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
  }
  #entry #area_btn .area_btn_shadow.show {
    opacity: 1;
    visibility: visible;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items {
    display: flex;
    width: 100%;
    align-items: center;
    max-width: 860px;
    margin-right: auto;
    margin-left: auto;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item {
    background-color: #fff;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item a {
    display: block;
    text-align: center;
    padding: 22px 0;
    position: relative;
    transition: all 0.2s;
    background-color: #ccc;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item a:hover {
    opacity: 0.7;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item a .area_btn_str {
    font-size: 24px;
    color: #fff;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item a svg {
    position: absolute;
    top: 0;
    right: 8%;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 15px;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num1 {
    justify-content: center;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num1 .area_btn_item {
    width: 55.815%;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 {
    justify-content: space-around;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 .area_btn_item {
    width: 38.3723%;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 {
    justify-content: space-between;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 .area_btn_item {
    width: 30.234%;
  }
  #entry .htxt09 {
    margin-bottom: 30px;
  }
  #entry .table01_02 {
    margin-top: 30px;
  }
  #entry .no_posts {
    text-align: center;
    font-size: 20px;
    padding-top: 40px;
  }
  #faq .faq_sumally {
    padding: 80px 80px 30px;
  }
  #faq .faq_sumally .contens_inner {
    max-width: 1200px;
    margin: 0 auto;
  }
  #faq .faq_sumally .contens_inner .sumally_inner ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  #faq .faq_sumally .contens_inner .sumally_inner ul li {
    margin-bottom: 1.5em;
  }
  #faq .faq_sumally .contens_inner .sumally_inner ul li:not(:last-child) {
    margin-right: 3em;
  }
  #faq .faq_sumally .contens_inner .sumally_inner ul li a {
    display: inline-block;
    padding-right: 1.3em;
    position: relative;
    font-size: 18px;
  }
  #faq .faq_sumally .contens_inner .sumally_inner ul li a svg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 0;
    height: 0;
    display: inline-block;
    width: 18px;
    height: 25px;
  }
  #faq .qa_list_wrp .qa_list {
    margin-top: 60px;
    margin-bottom: 140px;
  }
  #faq .qa_list_wrp .qa_list:last-child {
    margin-bottom: 0;
  }
  #faq .qa_list_wrp .qa_list li {
    position: relative;
    margin-bottom: 70px;
  }
  #faq .qa_list_wrp .qa_list li .qa_list_icon_wrp {
    position: absolute;
    right: 0;
    top: 0;
  }
  #faq .qa_list_wrp .qa_list li .question {
    min-height: 60px;
    background-color: #f0f0f0;
    font-size: 24px;
    letter-spacing: 2.16px;
    line-height: 1.48;
    padding: 11px 0;
    padding-left: 110px;
    position: relative;
  }
  #faq .qa_list_wrp .qa_list li .question span {
    display: block;
    padding-right: 80px;
  }
  #faq .qa_list_wrp .qa_list li .question:before {
    content: "Q";
    font-size: 40px;
    line-height: 1;
    font-weight: 600;
    position: absolute;
    left: 30px;
    top: 7px;
  }
  #faq .qa_list_wrp .qa_list li .question:after {
    content: "";
    width: 1px;
    height: 60%;
    position: absolute;
    background-color: #000;
    left: 86px;
    top: 50%;
    transform: translateY(-50%);
  }
  #faq .qa_list_wrp .qa_list li .answer {
    padding-left: 110px;
    position: relative;
    margin-top: 30px;
  }
  #faq .qa_list_wrp .qa_list li .answer:before {
    position: absolute;
    content: "A";
    color: #fff;
    border-radius: 50%;
    width: 70px;
    height: 70px;
    background-color: #6a6a6a;
    font-size: 40px;
    text-align: center;
    font-weight: 600;
    line-height: 66px;
    text-indent: 3px;
    left: 10px;
    top: 0;
  }
  #faq .qa_list_wrp .qa_list li .answer p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.84px;
    padding-top: 10px;
    padding-right: 90px;
  }
  #faq .qa_list_wrp .qa_list li .answer a {
    text-decoration: underline;
  }
  #data .data_contents_layout01 ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  #data .data_contents_layout01 ul li {
    box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.05);
    width: 48%;
    position: relative;
    padding: 100px 0 35px;
    margin-bottom: 40px;
    background-color: #fff;
  }
}
@media print and (max-width: 1000px), screen and (min-width: 768px) and (max-width: 1000px) {
  #data .data_contents_layout01 ul li {
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  #data .data_contents_layout01 ul li h2 {
    position: absolute;
    left: 10px;
    top: 10px;
    max-width: calc(100% - 20px);
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: auto;
    flex-wrap: wrap;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 .data_contents_layout01_box01_box01 {
    width: 160px;
    margin-right: 40px;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 .data_contents_layout01_box01_box02 p {
    font-family: "Oswald", sans-serif;
    font-weight: 400;
    font-size: 110px;
    line-height: 1;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 .data_contents_layout01_box01_box02 p span {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 40px;
    font-weight: 900;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box02 {
    padding: 0 50px;
    width: 100%;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_txt01 {
    line-height: 2;
    letter-spacing: 0.84px;
    padding: 0 50px;
    margin-top: auto;
    padding-top: 35px;
    width: 100%;
  }
  #data .data_contents_layout02 ul {
    display: flex;
    flex-wrap: wrap;
    margin-right: -40px;
    justify-content: center;
  }
  #data .data_contents_layout02 ul li {
    box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.05);
    position: relative;
    max-width: 270px;
    width: 100%;
    margin-right: 40px;
    padding: 80px 0 50px;
    margin-bottom: 40px;
    background-color: #fff;
  }
  #data .data_contents_layout02 ul li h2 {
    position: absolute;
    left: 10px;
    top: 10px;
    max-width: calc(100% - 20px);
  }
  #data .data_contents_layout02 ul li p {
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    font-size: 80px;
    line-height: 1;
    text-align: center;
  }
  #data .data_contents_layout02 ul li p span {
    padding-left: 5px;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 40px;
    font-weight: 900;
  }
  .fixed_contents .date_txt01 {
    font-size: 13px;
    font-weight: 600;
  }
  .fixed_contents h2 {
    font-size: 32px;
    font-weight: 600;
    letter-spacing: 2.16px;
    line-height: 1.48;
    border-bottom: 1px solid #000;
    padding-bottom: 15px;
  }
  .fixed_contents h3 {
    font-size: 24px;
    letter-spacing: 2.16px;
    line-height: 1.48;
    font-weight: 600;
    background-color: #f0f0f0;
    padding: 8px 20px 12px;
    margin-top: 80px;
    margin-bottom: 30px;
  }
  .fixed_contents h4 {
    font-size: 32px;
    line-height: 1;
    display: inline-block;
    padding: 10px 20px 13px;
    background-color: #000;
    color: #fff;
    font-weight: 500;
  }
  .fixed_contents .colmun_layout01 {
    display: flex;
    justify-content: space-between;
  }
  .fixed_contents .colmun_layout01 .colmun_layout01_box {
    width: 48%;
  }
  .fixed_contents .img_box01 {
    margin-bottom: 15px;
  }
  .fixed_contents .img_box01 img {
    vertical-align: bottom;
  }
  .fixed_contents .img_box01 p {
    font-size: 12px;
    margin-top: 2px;
  }
  .fixed_contents .anchor_wrp {
    padding: 80px 0;
  }
  .fixed_contents .anchor_wrp ul {
    display: flex;
    justify-content: center;
  }
  .fixed_contents .anchor_wrp ul li {
    margin: 0 25px;
  }
  .fixed_contents .anchor_wrp ul li a {
    font-size: 18px;
    font-weight: 600;
    position: relative;
    display: inline-block;
    padding-right: 18px;
    border-bottom: 1px solid #fff;
  }
  .fixed_contents .anchor_wrp ul li a:before {
    position: absolute;
    top: 11px;
    right: 0;
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 4.5px solid rgba(0, 0, 0, 0);
    border-right: 4.5px solid rgba(0, 0, 0, 0);
    border-top: 7px solid #707070;
    pointer-events: none;
  }
  .fixed_contents .anchor_wrp ul li a:hover {
    border-bottom: 1px solid #000;
  }
  .fixed_contents .news_layout01 {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -30px;
    margin-bottom: -60px;
  }
}
@media print and (max-width: 875px), screen and (min-width: 768px) and (max-width: 875px) {
  .fixed_contents .news_layout01 {
    justify-content: space-between;
    margin: 0;
    margin-bottom: -30px;
  }
}
@media print, screen and (min-width: 768px) {
  .fixed_contents .news_layout01 .news_layout01_list {
    margin: 0 30px;
    max-width: 360px;
    width: 100%;
    background-color: #fff;
    margin-bottom: 60px;
  }
}
@media print and (max-width: 875px), screen and (min-width: 768px) and (max-width: 875px) {
  .fixed_contents .news_layout01 .news_layout01_list {
    max-width: 100%;
    width: 48%;
    margin: 0;
    margin-bottom: 30px;
  }
}
@media print, screen and (min-width: 768px) {
  .fixed_contents .news_layout01 .news_layout01_list a {
    display: flex;
    flex-direction: column;
    transition: opacity 0.5s;
    height: 100%;
  }
  .fixed_contents .news_layout01 .news_layout01_list a:hover {
    opacity: 0.6;
  }
  .fixed_contents .news_layout01 .news_layout01_list a:hover .icon01:before {
    background-image: url("/lib/img/plus_black.svg");
  }
  .fixed_contents .news_layout01 .news_layout01_list a:hover .icon01 span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box01 {
    position: relative;
    border-bottom: 1px solid #ebebeb;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box01 img {
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: bottom;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box01 .news_layout01_box01_icon01_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 {
    padding: 30px;
    padding-bottom: 0;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt01 {
    font-size: 13px;
    letter-spacing: 0.84px;
    font-weight: 600;
    margin-bottom: 5px;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02 {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.96px;
    line-height: 1.48;
    position: relative;
    padding-left: 0.8em;
    margin-bottom: 40px;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #707070;
    width: 4px;
    height: 80%;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .tag_list_wrp {
    margin-top: auto;
    padding: 0 30px 30px;
  }
  .fixed_contents .tag_list {
    margin-right: -5px;
  }
  .fixed_contents .tag_list li {
    line-height: 1;
    display: inline-block;
    border: 1px solid #dedede;
    background-color: #f0f0f0;
    border-radius: 24px;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 8px 5px;
    margin-right: 5px;
  }
  .fixed_contents .news_contents_tag_list_wrp {
    margin-top: 13px;
  }
  .fixed_contents .main_art {
    margin-top: 30px;
  }
  .fixed_contents .fixed_layout {
    width: 100%;
  }
  .fixed_contents .fixed_layout .fixed_layout_visual {
    width: 100%;
    height: 420px;
    background-image: url("/lib/img/jobs/jobs_visual01.png");
    background-position: center;
    background-size: cover;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
    padding: 60px 80px 100px;
    text-align: left;
    background-color: #fff;
    margin-top: -145px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents p {
    text-align: left;
    margin-top: 30px;
    margin-bottom: 80px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents h4 {
    margin-bottom: 80px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents h5 {
    text-align: left;
    position: relative;
    padding-left: 0.8em;
    font-weight: 500;
    font-size: 24px;
    line-height: 1.48;
    letter-spacing: 1.44px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents h5:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #707070;
    width: 4px;
    height: 83%;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents .fixed_layout_contents_img01 {
    margin-top: 20px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents .colmun_layout01 {
    margin-top: 20px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents p + .fixed_layout_contents_img01 {
    margin-top: -50px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents p + .colmun_layout01 {
    margin-top: -50px;
  }
  .fixed_contents .fixed_layout02 h5 {
    display: inline;
    padding-left: 0 !important;
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #d6d6d6 0%) repeat scroll 0 0;
  }
  .fixed_contents .fixed_layout02 h5:before {
    position: relative;
    width: 0 !important;
    height: 0 !important;
  }
  .fixed_contents .fixed_layout03 h5 {
    display: inline-block;
    padding-left: 0 !important;
  }
  .fixed_contents .fixed_layout03 h5:before {
    position: relative;
    width: 0 !important;
    height: 0 !important;
  }
  #jobs .jobs_sumally {
    padding: 80px 80px 30px;
  }
  #jobs .jobs_sumally .contens_inner {
    max-width: 1200px;
    margin: 0 auto;
  }
  #jobs .jobs_sumally .contens_inner .sumally_inner ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  #jobs .jobs_sumally .contens_inner .sumally_inner ul li {
    margin-bottom: 1.5em;
  }
  #jobs .jobs_sumally .contens_inner .sumally_inner ul li:not(:last-child) {
    margin-right: 3em;
  }
  #jobs .jobs_sumally .contens_inner .sumally_inner ul li a {
    display: inline-block;
    padding-right: 1.3em;
    position: relative;
    vertical-align: middle;
    font-size: 18px;
  }
  #jobs .jobs_sumally .contens_inner .sumally_inner ul li a svg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 0;
    height: 0;
    display: inline-block;
    width: 18px;
    height: 25px;
  }
  #jobs .contens_wrp {
    padding: 80px 0 180px;
  }
  #jobs .contens_wrp .contens_inner {
    max-width: none;
  }
  #jobs .contens_wrp .contens_inner .entry_content {
    position: relative;
    padding-top: 280px;
  }
  #jobs .contens_wrp .contens_inner .entry_content::before {
    content: "";
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin-right: auto;
    margin-left: auto;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    padding: 420px 0 0;
  }
  #jobs .contens_wrp .contens_inner .entry_content:not(:last-child) .entry_content_inner {
    padding: 0 80px 135px;
  }
  #jobs .contens_wrp .contens_inner .entry_content .entry_content_inner {
    background-color: #fff;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    width: 800px;
    padding: 0 80px;
  }
  #jobs .contens_wrp .contens_inner .entry_content .entry_content_inner .entry_content_ttl {
    text-align: center;
    padding-top: 6%;
    margin-bottom: 4.5em;
  }
  #jobs .contens_wrp .contens_inner .entry_content .entry_content_inner .entry_content_ttl > .ttl_inner {
    display: inline-block;
    color: #fff;
    background-color: #000;
    padding: 0.5em;
    font-size: 26px;
  }
  #news .date_txt01 {
    font-size: 13px;
    font-weight: 600;
  }
  #news h2 {
    font-size: 32px;
    font-weight: 600;
    letter-spacing: 2.16px;
    line-height: 1.48;
    border-bottom: 1px solid #ebebeb;
    padding-bottom: 15px;
  }
  #news .news_layout01 {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -30px;
    margin-bottom: -60px;
  }
}
@media print and (max-width: 875px), screen and (min-width: 768px) and (max-width: 875px) {
  #news .news_layout01 {
    justify-content: space-between;
    margin: 0;
    margin-bottom: -30px;
  }
}
@media print, screen and (min-width: 768px) {
  #news .news_layout01 .news_layout01_list {
    margin: 0 30px;
    max-width: 360px;
    width: 100%;
    background-color: #fff;
    margin-bottom: 60px;
  }
}
@media print and (max-width: 875px), screen and (min-width: 768px) and (max-width: 875px) {
  #news .news_layout01 .news_layout01_list {
    max-width: 100%;
    width: 48%;
    margin: 0;
    margin-bottom: 30px;
  }
}
@media print, screen and (min-width: 768px) {
  #news .news_layout01 .news_layout01_list a {
    display: flex;
    flex-direction: column;
    transition: opacity 0.5s;
    height: 100%;
  }
  #news .news_layout01 .news_layout01_list a:hover {
    opacity: 0.6;
  }
  #news .news_layout01 .news_layout01_list a:hover .icon01 svg:not(.hover) {
    display: none;
  }
  #news .news_layout01 .news_layout01_list a:hover .icon01 svg.hover {
    display: block;
  }
  #news .news_layout01 .news_layout01_list a:hover .icon01 span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box01 {
    border-bottom: 1px solid #ebebeb;
    padding: 27.5% 0;
    width: 100%;
    position: relative;
    overflow: hidden;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box01 img {
    position: absolute;
    top: -100%;
    right: -100%;
    bottom: -100%;
    left: -100%;
    margin: auto;
    max-width: none;
    display: none;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box01 img.img_hor {
    width: auto;
    height: 100%;
    display: block;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box01 img.img_ver {
    width: 100%;
    height: auto;
    display: block;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box01 .news_layout01_box01_icon01_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box02 {
    padding: 30px;
    padding-bottom: 0;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt01 {
    font-size: 13px;
    letter-spacing: 0.84px;
    font-weight: 600;
    margin-bottom: 5px;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02 {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.96px;
    line-height: 1.48;
    position: relative;
    padding-left: 0.8em;
    margin-bottom: 40px;
  }
  #news .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #707070;
    width: 4px;
    height: 80%;
  }
  #news .news_layout01 .news_layout01_list a .tag_list_wrp {
    margin-top: auto;
    padding: 0 30px 30px;
  }
  #news #js_more_btn {
    text-align: center;
    margin-top: 3.5em;
  }
  #news #js_more_btn button {
    padding: 1em 3em;
    background-color: #000;
    color: #fff;
    font-size: 1.1em;
    transition: all 0.2s;
  }
  #news #js_more_btn button:hover {
    opacity: 0.7;
  }
  #news .tag_list {
    margin-right: -5px;
  }
  #news .tag_list li {
    line-height: 1;
    display: inline-block;
    border: 1px solid #dedede;
    background-color: #f0f0f0;
    border-radius: 24px;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 8px 5px;
    margin-right: 5px;
  }
  #news .news_contents_tag_list_wrp {
    margin-top: 13px;
  }
  #news .main_art {
    margin-top: 30px;
  }
  .form_wrp #common_main_visual {
    height: auto;
    margin-top: 0;
  }
  .form_wrp #common_main_visual .common_main_visual_inner {
    top: 0;
    transform: none;
  }
  .form_wrp .entry_form_wrp .contens_wrp {
    padding: 80px 0;
  }
  .form_wrp .entry_form_wrp .recruit_contents_list_wrp {
    padding-bottom: 0 !important;
    position: relative;
  }
  .form_wrp .entry_form_wrp .recruit_contents_list_wrp:before {
    position: absolute;
    width: 0;
    height: 0;
    border-left: 16px solid rgba(0, 0, 0, 0);
    border-right: 16px solid rgba(0, 0, 0, 0);
    border-top: 15px solid #e0e0e0;
    content: "";
    left: 50%;
    transform: translateX(-50%);
    bottom: -69px;
  }
  .form_wrp .entry_form_wrp .recruit_contents_list {
    margin-top: 30px !important;
  }
  .form_wrp .entry_form_wrp .entry_form {
    display: table;
    margin-top: 45px;
    position: relative;
    width: 100%;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .row {
    display: table-row;
  }
  .form_wrp .entry_form_wrp .entry_form .row:last-child .col {
    border-bottom: none !important;
  }
  .form_wrp .entry_form_wrp .entry_form .col {
    display: table-cell;
    padding: 15px 0;
    padding-left: 20px;
    border-bottom: 1px dotted #bfbfbf;
  }
  .form_wrp .entry_form_wrp .entry_form .col:first-child {
    font-weight: 600;
    vertical-align: top;
    padding-top: 24px;
    width: 180px;
  }
  .form_wrp .entry_form_wrp .entry_form .col:first-child .require {
    position: relative;
    padding-left: 35px;
    display: block;
  }
  .form_wrp .entry_form_wrp .entry_form .col:first-child .require:before {
    position: absolute;
    content: "必須";
    font-size: 12px;
    color: #fff;
    line-height: 1;
    background-color: #e35656;
    padding: 2px 3px 3px;
    left: 0;
    top: 4px;
    white-space: nowrap;
  }
  .form_wrp .entry_form_wrp .entry_form .col:last-child {
    width: calc(100% - 180px);
  }
  .form_wrp .entry_form_wrp .entry_form .col input {
    height: 45px;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    padding: 5px 11.5px;
    box-sizing: border-box;
    font-size: 16px;
    width: 310px;
  }
  .form_wrp .entry_form_wrp .entry_form .col select {
    height: 45px;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    padding: 5px 40px 5px 10px;
    box-sizing: border-box;
    background-color: #fff;
    -webkit-appearance: none;
    background-image: url(../img/arrow_down.svg);
    background-position: right 15px center;
    background-size: 13px 8px;
    background-repeat: no-repeat;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .col select.is_block {
    min-width: 285px;
    display: block;
  }
  .form_wrp .entry_form_wrp .entry_form .col textarea {
    width: 100%;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    padding: 5px 10px;
    box-sizing: border-box;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) > p {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) .birth_span {
    padding: 0 15px 0 10px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) .timing-year input {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) .timing-month input {
    width: 90px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-year] input {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-year] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-month] input {
    width: 90px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-month] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-date] input {
    width: 90px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-date] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=timing-year] input {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=timing-year] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) input[name=timing-month] {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=timing-month] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div {
    margin-bottom: 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div > p {
    display: flex;
    align-items: center;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div span[data-name=your-postal-code].wpcf7-form-control-wrap {
    display: inline-block;
    margin: 0 10px 0 5px;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div span[data-name=your-postal-code].wpcf7-form-control-wrap input {
    width: 140px;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div .address_search {
    font-size: 14px;
    color: #fff;
    line-height: 1;
    padding: 8px 20px 6px;
    background-color: #000;
    cursor: pointer;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div .address_search:hover {
    opacity: 0.6;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(1) {
    margin-bottom: 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(1) span:first-child {
    width: 60px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(2) {
    margin-bottom: 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(2) span:first-child {
    width: 60px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:first-child {
    display: inline-block;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:first-child input {
    width: 120px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:first-child .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:nth-child(2) {
    padding: 0 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:nth-child(4) {
    margin-left: 10px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:nth-child(4) select {
    width: 130px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col > div {
    margin-top: 8px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) input {
    border: none;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) input[type=file] {
    display: none;
    opacity: 0;
    visibility: hidden;
    height: 0;
    padding: 0;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) label {
    height: 30px;
    width: 144px;
    color: #fff;
    background-color: #000;
    cursor: pointer;
    display: inline-block;
    position: relative;
    white-space: nowrap;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) label:before {
    content: "ファイルを選択";
    color: #fff;
    position: absolute;
    left: 50%;
    top: 48%;
    transform: translateY(-50%) translateX(-50%);
    font-size: 13px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) label .wpcf7-not-valid-tip {
    margin-top: 9px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) p {
    display: inline-block;
    vertical-align: top;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) ul {
    padding-top: 10px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) ul li {
    font-size: 12px;
    margin-bottom: 4px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) ul li:last-child {
    margin-bottom: 0;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) .wpcf7-form-control-wrap + br {
    display: none;
  }
  .form_wrp .entry_form_wrp .privacy_box {
    width: 100%;
    background-color: #f7f7f7;
    height: 244px;
    margin-top: 60px;
    padding: 20px 0;
  }
  .form_wrp .entry_form_wrp .privacy_box .privacy_box_inner {
    overflow-y: auto;
    height: 100%;
  }
  .form_wrp .entry_form_wrp .privacy_box .gutenberg_content {
    padding: 0 40px 20px;
  }
  .form_wrp .entry_form_wrp .privacy_box .privacy_ttl {
    padding: 20px 40px;
  }
  .form_wrp .entry_form_wrp .confirm_box {
    margin-top: 60px;
    text-align: center;
  }
  .form_wrp .entry_form_wrp .confirm_box p {
    text-align: center;
    font-size: 12px;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label span {
    font-size: 16px;
    font-weight: 600;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label input[type=checkbox] {
    display: none;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label input[type=checkbox]:checked {
    display: none;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy .wpcf7-list-item-label::before {
    content: "";
    height: 18px;
    width: 18px;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    left: 5px;
    top: 4px;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy .wpcf7-list-item-label::after {
    border-left: 3px solid #ed7a9c;
    border-bottom: 3px solid #ed7a9c;
    top: -2px;
    left: 9px;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy .wpcf7-not-valid-tip {
    margin-right: auto;
    margin-left: auto;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn {
    display: inline-block;
    background-color: #000;
    border: 1px solid #000;
    width: 480px;
    text-align: center;
    color: #fff;
    font-size: 24px;
    letter-spacing: 2.16px;
    font-weight: 600;
    position: relative;
    transition: 0.5s;
    margin-top: 55px;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn p {
    display: -webkit-inline-box;
    width: 100%;
    margin-bottom: 0;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn input {
    border: none;
    margin: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: none;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
    padding: 25px;
    color: #fff;
    font-size: 24px;
    letter-spacing: 2.16px;
    font-weight: 600;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn svg.hover {
    display: none;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn:hover svg:not(.hover) {
    display: none;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn:hover svg.hover {
    display: block;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn:hover input {
    cursor: pointer;
    background-position: -100% 0;
    color: #000;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn .wpcf7-spinner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: -60px;
  }
  .form_wrp .entry_form_wrp .confirm_box .wpcf7-not-valid-tip {
    margin-right: auto;
    margin-left: auto;
  }
  .form_wrp .entry_form_wrp input[type=radio] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: none;
    opacity: 0;
    width: 1px;
    position: absolute;
    height: 1px;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    padding: 10px 11px 8px 23px;
    border-radius: 4px;
    font-weight: 500;
    font-size: 14px;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span::before, .form_wrp .entry_form_wrp input[type=radio] + span::after {
    position: absolute;
    content: "";
    display: block;
    border-radius: 50%;
    top: 2px;
    bottom: 0;
    margin: auto 10px auto 0;
    box-sizing: border-box;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span::before {
    width: 14px;
    height: 14px;
    background: #fff;
    border: 1px solid #e0e0e0;
    left: 0;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span::after {
    width: 8px;
    height: 8px;
    background: #999;
    left: 3px;
    opacity: 0;
  }
  .form_wrp .entry_form_wrp input[type=radio]:checked + span::before {
    border: 1px solid #e0e0e0;
  }
  .form_wrp .entry_form_wrp input[type=radio]:checked + span::after {
    background: #000;
    opacity: 1;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: none;
    opacity: 0;
    width: 1px;
    position: absolute;
    height: 1px;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    padding: 10px 11px 8px 32px;
    border-radius: 4px;
    font-weight: 500;
    font-size: 14px;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span::before, .form_wrp .entry_form_wrp input[type=checkbox] + span::after {
    position: absolute;
    content: "";
    display: block;
    top: 0;
    bottom: 0;
    margin: auto 10px auto 0;
    box-sizing: border-box;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span::before {
    width: 14px;
    height: 14px;
    background: #fff;
    border: 1px solid #e0e0e0;
    left: 0;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span::after {
    width: 12px;
    height: 8px;
    background-color: rgba(0, 0, 0, 0);
    border-left: 3px solid #000;
    border-bottom: 3px solid #000;
    top: -5px;
    left: 3px;
    opacity: 0;
    transform: rotate(-45deg);
  }
  .form_wrp .entry_form_wrp input[type=checkbox]:checked + span::before {
    border: 1px solid #e0e0e0;
  }
  .form_wrp .entry_form_wrp input[type=checkbox]:checked + span::after {
    opacity: 1;
  }
  .form_wrp .entry_form_wrp .wpcf7-custom-item-error {
    width: 100%;
  }
  .form_wrp .entry_form_wrp .wpcf7-not-valid-tip {
    color: #c00;
    padding: 5px 10px;
    background: #f4e4e4;
    display: inline-block;
    font-size: 14px;
    font-weight: bold;
    margin-top: 0.5em;
    min-width: 310px;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control {
    display: block;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control .wpcf7-list-item:first-child {
    margin-left: 0;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control .wpcf7-list-item label {
    display: flex;
    align-items: center;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control.item_block .wpcf7-list-item, .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control.item_block_pc .wpcf7-list-item {
    display: block;
    margin-left: 0;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control.wpcf7-not-valid {
    display: block !important;
  }
  #block_404 .layout_container {
    width: 1005px;
    margin-right: auto;
    margin-left: auto;
  }
  #block_404 .page_404 {
    width: 800px;
    margin: 70px auto;
    padding: 50px;
    background-color: #eee;
  }
  #block_404 .page_404_txt2 {
    margin-bottom: 50px;
  }
  #block_404 .page_404_txt3 {
    margin-bottom: 15px;
  }
  #block_404 .txt1_page_404 {
    font-size: 48px;
    font-weight: bold;
    text-align: center;
  }
  #block_404 .txt2_page_404 {
    text-align: center;
  }
  #block_404 .txt3_page_404 {
    text-align: center;
  }
  #block_404 .link_page_404 {
    text-align: center;
  }
  #block_404 .link_page_404 a {
    display: inline-block;
    transition: all 0.2s;
  }
  #block_404 .link_page_404 a:after {
    content: "";
    display: inline-block;
    margin-left: 6px;
    transition: all 0.2s;
  }
  #block_404 .link_page_404 a:hover {
    color: #7f7f7f;
  }
}
@media screen and (max-width: 767px) {
  body {
    position: relative;
    z-index: 2;
    overflow-x: hidden;
    padding-top: 56px;
    -webkit-text-size-adjust: 100%;
  }
  .pc {
    display: none !important;
  }
  a {
    vertical-align: bottom;
  }
  #page_top {
    display: none !important;
  }
  p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.84px;
  }
  a {
    text-decoration: none;
    color: #000;
  }
  .overlay {
    padding-top: 0 !important;
  }
  .overlay header {
    background-color: rgba(255, 255, 255, 0.4);
  }
  .contens_wrp .contens_inner {
    max-width: 1200px;
    margin: 0 auto;
  }
  #common_main_visual {
    background-image: url("/lib/img/recruit/main_visual.png");
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 160px;
    position: relative;
  }
  #common_main_visual .common_main_visual_inner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 20px;
    padding: 3px 15px 6px;
  }
  .btn01 {
    display: inline-block;
    line-height: 1;
    padding: 20px 50px;
    font-size: 13px;
    color: #fff;
    border: 1px solid #fff;
    transition: opacity 0.5s;
    letter-spacing: 0.78px;
  }
  .btn02 {
    display: inline-block;
    background-color: #000;
    border: 1px solid #000;
    width: 100%;
    text-align: center;
    padding: 15px;
    color: #fff;
    font-size: 20px;
    letter-spacing: 2.16px;
    font-weight: 600;
    position: relative;
    transition: 0.5s;
  }
  .btn02 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
  }
  .icon01 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
    vertical-align: bottom;
  }
  .icon01 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon01 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .icon01 svg.hover {
    display: none;
  }
  .icon02 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
  }
  .icon02 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon02 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .icon02 svg.hover {
    display: none;
  }
  .icon03 {
    display: inline-block;
    width: 60px;
    height: 60px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
  }
  .icon03 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon03 svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
  }
  .icon03 svg.hover {
    display: none;
  }
  .icon04 {
    display: inline-block;
    width: 50px;
    height: 50px;
    position: relative;
    background-color: #000;
    border: 1px solid #000;
  }
  .icon04 span {
    width: 100%;
    height: 100%;
    display: block;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
  }
  .icon04:before {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 15px;
    height: 2px;
    background-color: #fff;
    transition: 0.2s;
    transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
  }
  .icon04:after {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 15px;
    height: 2px;
    background-color: #fff;
    transition: 0.3s;
  }
  .icon04.on span {
    cursor: pointer;
    background-position: -100% 0;
    color: #fff;
  }
  .icon04.on:before {
    transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    background-color: #000;
  }
  .icon04.on:after {
    background-color: rgba(0, 0, 0, 0);
    background-color: #000;
  }
  .htxt01 {
    font-size: 40px;
    line-height: 1.48;
    font-weight: 400;
    color: #fff;
  }
  .htxt02 {
    font-size: 24px;
    color: #fff;
    letter-spacing: 1.44px;
  }
  .htxt03 {
    font-size: 24px;
    color: #000;
    line-height: 0.67;
    letter-spacing: 1.44px;
  }
  .htxt04 {
    font-size: 24px;
    letter-spacing: 1.44px;
    color: #000;
    font-weight: 600;
  }
  .htxt05 {
    font-size: 26px;
    letter-spacing: 1.44px;
    line-height: 1.48;
    color: #000;
    font-weight: 400;
  }
  .htxt06 {
    font-size: 26px;
    letter-spacing: 1.44px;
    line-height: 1.48;
    color: #000;
    font-weight: 600;
  }
  .htxt07 {
    font-size: 24px;
    letter-spacing: 1.44px;
    line-height: 1.48;
    color: #000;
    font-weight: 600;
    text-align: center;
    position: relative;
    padding-bottom: 15px;
  }
  .htxt07:before {
    content: "";
    position: absolute;
    background-color: #707070;
    width: 40px;
    height: 2px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  .htxt08 {
    font-size: 26px;
    line-height: 1.48;
    font-weight: 400;
    color: #fff;
  }
  .htxt09 {
    font-size: 20px;
    letter-spacing: 2.16px;
    line-height: 1;
    background-color: #f0f0f0;
    padding: 15px 20px;
  }
  .htxt10 {
    letter-spacing: 1.44px;
    color: #fff;
    line-height: 1.48;
    background-color: #000;
    font-weight: 400;
    display: inline-block;
    padding: 3px 15px;
  }
  .date_list li {
    margin-bottom: 20px;
  }
  .date_list li:last-child {
    margin-bottom: 0;
  }
  .date_list li p {
    line-height: 1;
    font-size: 16px;
    color: #a8a8a8;
    letter-spacing: 0.96px;
    font-weight: 500;
    margin-bottom: 3px;
  }
  .date_list li a {
    line-height: 1;
    font-size: 14px;
    color: #222;
  }
  .date_list li a:hover {
    text-decoration: underline;
  }
  .contents_list li {
    margin-bottom: 60px;
  }
  .contents_list .list01 .list01_link {
    display: flex;
  }
  .contents_list .list01 .list01_link.col_txt_img {
    flex-direction: column;
  }
  .contents_list .list01 .list01_link.col_img_txt {
    flex-direction: column-reverse;
  }
  .contents_list .contents_list_box01 {
    width: 100%;
    background-color: #e6e6e6;
    position: relative;
    padding: 30px;
    padding-bottom: 85px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .contents_list .contents_list_box01 .contents_list_box01_txtbox .htxt04 {
    margin-bottom: 20px;
  }
  .contents_list .contents_list_box01 .contents_list_box01_icon_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  .contents_list .contents_list_box02 {
    width: 100%;
    height: 300px;
    background-size: cover;
    background-position: center;
  }
  .top_interview_wrp {
    position: relative;
    margin: 0 -20px;
    margin-bottom: 80px;
  }
  .top_interview_wrp .top_interview_box01 {
    background-color: #e6e6e6;
    padding: 60px 50px 40px;
    width: 100%;
    height: 100%;
  }
  .top_interview_wrp .top_interview_box01 .top_interview_box01_txtbox .htxt04 {
    margin-bottom: 20px;
  }
  .top_interview_slide li {
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 100%;
    min-height: 500px;
    position: relative;
  }
  .top_interview_slide li a {
    min-height: 500px;
    display: block;
  }
  .top_interview_slide li .top_interview_slide_txtbox {
    position: absolute;
    left: 30px;
    bottom: 25px;
  }
  .top_interview_slide li .top_interview_slide_txtbox .top_interview_slide_txtbox_txt01 {
    font-size: 13px;
    letter-spacing: 0.78px;
    line-height: 1.48;
    color: #fff;
    font-weight: 500;
  }
  .top_interview_slide li .top_interview_slide_txtbox .top_interview_slide_txtbox_txt02 {
    font-size: 24px;
    line-height: 1.48;
    letter-spacing: 1.44px;
    font-weight: 600;
    color: #fff;
    margin: 15px 0 5px;
  }
  .top_interview_slide li .top_interview_slide_txtbox .top_interview_slide_txtbox_txt03 {
    font-size: 16px;
    line-height: 1.48;
    letter-spacing: 0.96px;
    color: #fff;
  }
  .top_interview_slide .prev_arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    z-index: 99;
  }
  .top_interview_slide .next_arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    z-index: 99;
  }
  .contents_list02 li {
    width: 100%;
    margin-bottom: 60px;
  }
  .contents_list02 li a {
    display: block;
    height: 100%;
  }
  .contents_list02 li:last-child {
    margin-bottom: 0;
  }
  .contents_list02 li .htxt04 {
    margin-top: 5px;
  }
  .contents_list02 li .contents_list02_box {
    position: relative;
    min-height: 320px;
    height: 100%;
    background-size: cover;
    background-position: center;
  }
  .contents_list02 li .contents_list02_box .contents_list02_box_icon_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  #recommend {
    padding: 80px 20px;
  }
  #recommend .htxt06 {
    text-align: center;
    margin-bottom: 40px;
  }
  .table01 {
    border: 1px solid #e0e0e0;
    border-collapse: collapse;
    width: 100%;
  }
  .table01 tr, .table01 td {
    border: 1px solid #e0e0e0;
    text-align: left;
  }
  .table01 th {
    display: block;
    width: auto;
    padding: 20px;
    font-size: 14px;
    white-space: nowrap;
    width: 100%;
    background-color: #f7f7f7;
  }
  .table01 td {
    display: block;
    padding: 20px;
    font-size: 14px;
    width: 100%;
    border: none;
    border-top: 1px solid #e0e0e0;
  }
  .table01 td a {
    color: #0093ff;
  }
  .table01 td a:hover {
    text-decoration: underline;
  }
  .select_01 {
    position: relative;
  }
  .select_01 select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }
  .select_01 select:-ms-expand {
    display: none;
  }
  .select_01:before {
    position: absolute;
    top: 50%;
    right: 0.4em;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 4.5px solid rgba(0, 0, 0, 0);
    border-right: 4.5px solid rgba(0, 0, 0, 0);
    border-top: 7px solid #707070;
    pointer-events: none;
  }
  header {
    background-color: #fff;
    padding: 8px 25px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 56px;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 4999;
  }
  header .logo_wrp a {
    display: inline-block;
    transition: opacity 0.5s;
  }
  header .logo_wrp a:hover {
    opacity: 0.6;
  }
  header .logo_wrp a img {
    vertical-align: bottom;
    height: 44px;
    width: auto;
  }
  header .btn-trigger {
    position: relative;
    width: 40px;
    height: 22px;
    cursor: pointer;
  }
  header .btn-trigger:hover span {
    width: 100% !important;
  }
  header .btn-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #000;
  }
  header .btn-trigger span:nth-child(2) {
    width: 60%;
  }
  header .btn-trigger span:nth-child(3) {
    width: 70%;
  }
  header .btn-trigger, header .btn-trigger span {
    display: inline-block;
    transition: all 0.3s;
    box-sizing: border-box;
  }
  header .btn-trigger span:nth-of-type(1) {
    top: 0;
  }
  header .btn-trigger span:nth-of-type(2) {
    top: 10px;
  }
  header .btn-trigger span:nth-of-type(3) {
    bottom: 0;
  }
  #main_menu {
    width: 100%;
    background-color: #000;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 9999999999999;
    padding: 60px 20px;
    transform: translateX(100%);
    transition: transform 0.5s;
    text-align: center;
    overflow-y: scroll;
  }
  #main_menu .close_btn {
    position: absolute;
    right: 20px;
    top: 20px;
  }
  #main_menu .main_menu_link_list {
    width: auto;
    margin: 0 auto;
    display: inline-block;
  }
  #main_menu .main_menu_link_list li {
    margin-bottom: 30px;
    display: block;
    text-align: left;
    position: relative;
  }
  #main_menu .main_menu_link_list li a {
    font-size: 18px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    font-weight: 600;
  }
  #main_menu .main_menu_link_list li a:hover {
    opacity: 0.6;
  }
  #main_menu .main_menu_link_list li > span {
    font-size: 18px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    font-weight: 600;
    display: inline-block;
    padding-right: 0.5em;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list li {
    margin-bottom: 10px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list li:first-child {
    margin-top: 10px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list li a {
    font-size: 0.8em;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle {
    display: inline-block;
    width: 15px;
    height: 15px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span {
    display: block;
    position: relative;
    width: 15px;
    height: 15px;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span::before, #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span::after {
    content: "";
    display: block;
    width: 15px;
    height: 3px;
    border-radius: 5px;
    background: #fff;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle span::after {
    background: #fff;
    transform: translateY(-50%) rotate(90deg);
    transition: 0.5s;
  }
  #main_menu .main_menu_link_list li .sub_menu_link_list_toggle .active::after {
    transform: translateY(-50%) rotate(0);
    transition: 0.5s;
  }
  #main_menu .main_menu_link_list02 {
    display: flex;
    justify-content: center;
    margin-top: 30px;
  }
  #main_menu .main_menu_link_list02 li {
    margin-bottom: 20px;
  }
  #main_menu .main_menu_link_list02 li:first-child {
    margin-right: 25px;
  }
  #main_menu .main_menu_link_list02 li a {
    font-size: 14px;
    color: #fff;
    letter-spacing: 0.96px;
    transition: opacity 0.5s;
    display: block;
    text-align: right;
    font-weight: 600;
  }
  #main_menu .main_menu_link_list02 li a:hover {
    opacity: 0.6;
  }
  #main_menu .main_menu_link_list03 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  #main_menu .main_menu_link_list03 li {
    width: 48%;
    flex-grow: 1;
    margin: 0 1% 2%;
  }
  #main_menu .main_menu_link_list03 li a {
    width: 100%;
    font-weight: 600;
    font-size: 18px;
    color: #fff;
    letter-spacing: 0.96px;
    display: inline-block;
    padding: 20px 10px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #main_menu .main_menu_link_list03 li .entry_btn02_01 {
    background-color: dimgray;
  }
  #main_menu .main_menu_link_list03 li .entry_btn02_02 {
    background-color: #525252;
  }
  .active_menu {
    transform: translateX(0) !important;
  }
  footer #cookies_alert {
    position: fixed;
    bottom: 20px;
    left: 0;
    right: 0;
    padding: 0 10px;
    margin-right: auto;
    margin-left: auto;
    z-index: 99999999;
  }
  footer #cookies_alert .contens_inner {
    background-color: #fff;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
    max-width: 1200px;
    margin-right: auto;
    margin-left: auto;
    padding: 1em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: 0.25rem;
  }
  footer #cookies_alert .contens_inner .inner_txt {
    width: calc(100% - 6em);
  }
  footer #cookies_alert .contens_inner .inner_txt p {
    line-height: 1.3;
    font-size: 0.8em;
  }
  footer #cookies_alert .contens_inner .inner_txt a {
    text-decoration: underline;
  }
  footer #cookies_alert .contens_inner .inner_remove #js_remove {
    background-color: #999595;
    border-radius: 5px;
    color: #fff;
    padding: 0.5em 1em;
    font-size: 0.8em;
  }
  footer .footer_copyright {
    text-align: center;
    background-color: #000;
    padding: 12px;
  }
  footer .footer_copyright p {
    font-size: 13px;
    color: #fff;
  }
  .content_with800px, .content_with1160px {
    background-color: #fff;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    padding: 0 0 25%;
  }
  .gutenberg_content {
    line-height: 1.8;
    font-size: 14px;
  }
  .gutenberg_content a {
    text-decoration: underline;
  }
  .gutenberg_content h2 {
    font-size: 26px;
    text-align: center;
    padding-bottom: 35px;
    position: relative;
    margin-bottom: 1.5em;
  }
  .gutenberg_content h2::after {
    content: "";
    display: block;
    width: 40px;
    height: 2px;
    position: absolute;
    right: -100%;
    bottom: 0;
    left: -100%;
    margin-right: auto;
    margin-left: auto;
    background-color: #707070;
  }
  .gutenberg_content p {
    margin-bottom: 1em;
    line-height: 1.8;
  }
  .gutenberg_content .wp-block-image {
    text-align: center;
    margin-bottom: 1em;
  }
  .gutenberg_content .wp-block-image img {
    height: auto;
  }
  .gutenberg_content .wp-block-image figcaption {
    margin-bottom: 2px;
  }
  .gutenberg_content .wp-block-getwid-table {
    margin-bottom: 1em;
    font-size: 14px;
  }
  .gutenberg_content .wp-block-getwid-table table {
    border-collapse: collapse;
    width: 100%;
  }
  .gutenberg_content .wp-block-getwid-table table th, .gutenberg_content .wp-block-getwid-table table td {
    padding: 0.6em 0.4em;
    border: 1px solid #e0e0e0;
    word-break: break-all;
  }
  .gutenberg_content .wp-block-getwid-table:not(.has-table-layout-fixed) table th, .gutenberg_content .wp-block-getwid-table:not(.has-table-layout-fixed) table td {
    white-space: nowrap;
  }
  .gutenberg_content em {
    font-style: italic;
  }
  .gutenberg_content figcaption {
    font-size: 14px;
  }
  .wp-block-cover p {
    margin-bottom: 0;
  }
  #jobs .gutenberg_content h3 {
    font-weight: normal;
    margin-bottom: 24px;
    padding-left: 18px;
    font-size: 24px;
    position: relative;
  }
  #jobs .gutenberg_content h3::before {
    content: "";
    display: block;
    width: 4px;
    height: 100%;
    background-color: #707070;
    position: absolute;
    top: 0;
    left: 0;
  }
  #news .gutenberg_content h3 {
    font-weight: normal;
    background-color: #f0f0f0;
    margin-bottom: 24px;
    padding: 12px 18px;
    font-size: 24px;
  }
  #pager_post {
    padding-top: 50px;
  }
  #pager_post .pager_post_inner .pager_post_row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 580px;
    margin-right: auto;
    margin-left: auto;
    font-size: 14px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow {
    width: 100px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area {
    display: flex;
    align-items: center;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area svg {
    width: 23px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_arrow .pager_post_area .pager_post_str {
    display: block;
    width: 65px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_col_prev .pager_post_area svg {
    margin-right: 11px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_col_prev .pager_post_area .pager_post_str {
    text-align: left;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_next .pager_post_area svg {
    transform: scale(-1, 1);
    margin-left: 11px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_next .pager_post_area .pager_post_str {
    text-align: right;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list {
    width: 80px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area {
    display: block;
    text-align: center;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area svg {
    display: inline-block;
    margin-bottom: 10px;
  }
  #pager_post .pager_post_inner .pager_post_row .pager_post_col.pager_post_list .pager_post_area .pager_post_str {
    display: block;
  }
  #contents {
    margin-bottom: 100px;
  }
  #contents .contens_wrp {
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    margin: 40px 0;
  }
  #top_contents .contens_wrp .contens_inner {
    padding: 0 20px;
  }
  #top_main_visual {
    background-size: cover !important;
    background-position: center !important;
    background-attachment: scroll !important;
    background-repeat: no-repeat !important;
    width: 100%;
    height: 520px;
    position: relative;
  }
  #top_main_visual .top_main_visual_htxt .top_main_visual_htxt_inner {
    padding: 3px 15px 6px;
    display: inline-block;
  }
  .top_about {
    background-image: url("/lib/img/about_bg.png");
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 450px;
    margin-top: 80px;
    position: relative;
  }
  .top_about p {
    color: #fff;
  }
  .top_about .top_about_inner {
    width: 100%;
    max-width: 410px;
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    padding: 0 25px;
  }
  .top_about .top_about_inner h2 {
    margin-bottom: 15px;
  }
  .top_about .top_about_inner p {
    margin-bottom: 40px;
  }
  .top_news {
    background-color: #f2f2f2;
    padding: 45px 0;
    padding-bottom: 90px;
  }
  .top_news .top_news_inner {
    max-width: 1200px;
    padding: 0 40px;
    margin: 0 auto;
    position: relative;
  }
  .top_news .top_news_inner .date_list {
    margin-top: 30px;
  }
  .top_news .top_news_inner .news_icon_wrp {
    position: absolute;
    right: 0;
    bottom: -90px;
  }
  #interview .contens_wrp .contens_inner {
    padding-right: 20px;
    padding-left: 20px;
  }
  #interview .interview_list_wrp .interview_list01 {
    padding: 40px 20px;
  }
  #interview .interview_list_wrp .interview_list01 .interview_list_txt01 {
    font-size: 14px;
    line-height: 1.8;
    letter-spacing: 0.96px;
    text-align: center;
  }
  #interview .interview_list_wrp .interview_list02 {
    background-color: #f0f0f0;
    padding: 60px 20px;
  }
  #interview .interview_list_wrp .interview_list02 .interview_list02_inner {
    width: 100%;
    margin: 0 auto;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li {
    width: 100%;
    margin-bottom: 30px;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div {
    padding: 41.49% 0;
    width: 100%;
    position: relative;
    overflow: hidden;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div img {
    position: absolute;
    top: -100%;
    right: -100%;
    bottom: -100%;
    left: -100%;
    margin: auto;
    max-width: none;
    display: none;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div img.img_hor {
    width: auto;
    height: 100%;
    display: block;
  }
  #interview .interview_list_wrp .interview_list02 .interview_other_slider li div img.img_ver {
    width: 100%;
    height: auto;
    display: block;
  }
  #interview .interview_list_wrp #js_more_btn {
    text-align: center;
    margin-top: 3.5em;
    padding-bottom: 3.5em;
  }
  #interview .interview_list_wrp #js_more_btn button {
    padding: 1em 3em;
    background-color: #000;
    color: #fff;
    font-size: 1.1em;
    transition: all 0.2s;
  }
  #interview #interview_main_visual {
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 520px;
    position: relative;
  }
  #interview #interview_main_visual .interview_main_visual_htxt {
    left: 20px;
    bottom: 20px;
    position: absolute;
    padding: 3px 15px 6px;
  }
  #interview #interview_main_visual .interview_main_visual_htxt.txt_shadow {
    text-shadow: #333 2px 0px 2px, #333 -2px 0px 2px, #333 0px -2px 2px, #333 -2px 0px 2px, #333 2px 2px 2px, #333 -2px 2px 2px, #333 2px -2px 2px, #333 -2px -2px 2px, #333 1px 2px 2px, #333 -1px 2px 2px, #333 1px -2px 2px, #333 -1px -2px 2px, #333 2px 1px 2px, #333 -2px 1px 2px, #333 2px -1px 2px, #333 -2px -1px 2px, #333 1px 1px 2px, #333 -1px 1px 2px, #333 1px -1px 2px, #333 -1px -1px 2px;
  }
  #interview #interview_main_visual .interview_main_visual_htxt .interview_main_visual_htxt_txt01 {
    font-size: 20px;
    line-height: 1.48;
    letter-spacing: 1.2px;
    color: #fff;
    font-weight: 500;
  }
  #interview #interview_main_visual .interview_main_visual_htxt .interview_main_visual_htxt_txt02 {
    font-size: 34px;
    line-height: 1.48;
    letter-spacing: 2.16px;
    color: #fff;
    font-weight: 400;
    margin-top: 10px;
  }
  #interview #interview_main_visual .interview_main_visual_htxt .interview_main_visual_htxt_txt03 {
    font-size: 20px;
    letter-spacing: 1.2px;
    line-height: 1.48;
    color: #fff;
    margin-top: 10px;
  }
  #interview .interview_contents .interview_layout_txt01 {
    font-size: 13px;
    letter-spacing: 0.78px;
    font-weight: 600;
  }
  #interview .interview_contents .htxt05 {
    margin-top: 15px;
    margin-bottom: 25px;
  }
  #interview .interview_contents .interview_layout {
    margin-bottom: 80px;
  }
  #interview .interview_contents .interview_layout:last-child {
    margin-bottom: 0;
  }
  #interview .interview_contents .interview_layout .youtube_wrp {
    position: relative;
    padding: 28.4% 0;
    overflow: hidden;
  }
  #interview .interview_contents .interview_layout .youtube_wrp iframe {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 100%;
  }
  #interview .interview_contents .interview_layout01 .interview_layout01_box01 {
    width: 100%;
    margin-bottom: 25px;
  }
  #interview .interview_contents .interview_layout01 .interview_layout01_box02 {
    width: 100%;
  }
  #interview .interview_contents .interview_layout02 .interview_layout02_box01 {
    margin: 0 -20px;
    margin-bottom: 25px;
  }
  #interview .interview_contents .interview_layout02 .interview_layout02_box02 {
    width: 100%;
  }
  #interview .interview_contents .interview_layout03 .interview_layout03_box01 {
    width: 100%;
    margin-bottom: 25px;
  }
  #interview .interview_contents .interview_layout03 .interview_layout03_box02 {
    width: 100%;
  }
  #interview #interview_schedule .contens_inner .interview_schedule_row1 {
    width: 202px;
  }
  #interview #interview_schedule .contens_inner .interview_schedule_row2 {
    background-color: #f7f7f7;
    padding: 60px 30px;
  }
  #interview #interview_schedule .interview_schedule_ttl {
    background-color: #0a4b6a;
    color: #fff;
    text-align: center;
    font-weight: normal;
    line-height: 1;
    padding: 12.5px 0;
    font-size: 16px;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item:not(:last-child) {
    margin-bottom: 50px;
  }
  #interview #interview_schedule .interview_schedule_items .interview_schedule_item .interview_schedule_item_row > .interview_schedule_item_col1 {
    margin-bottom: 15px;
  }
  #interview #interview_schedule .interview_schedule_items .item_time {
    color: #0a4b6a;
    line-height: 1;
    font-size: 20px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row > .item_col1 {
    margin-bottom: 10px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row .item_ttl {
    font-size: 24px;
    font-weight: normal;
    margin-bottom: 10px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row .item_txt {
    font-size: 13px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row .item_txt p:not(:last-child) {
    margin-bottom: 8px;
  }
  #interview #interview_schedule .interview_schedule_items .item_row .item_txt a {
    text-decoration: underline;
  }
  #interview #interview_schedule .interview_schedule_time {
    color: #0a4b6a;
    font-size: 20px;
    line-height: 1;
  }
  #interview .interview_other_wrp {
    padding: 80px 20px;
    margin: 0 -20px;
    margin-top: 80px;
  }
  #interview .interview_other_wrp .htxt06 {
    text-align: center;
  }
  #interview .interview_other_slider {
    position: relative;
    margin-top: 35px;
  }
  #interview .interview_other_slider .prev_arrow {
    position: absolute;
    top: 120px;
    left: -20px;
    z-index: 999;
  }
  #interview .interview_other_slider .next_arrow {
    position: absolute;
    top: 120px;
    right: -20px;
    z-index: 999;
  }
  #interview .interview_other_slider li {
    width: 100%;
  }
  #interview .interview_other_slider li div {
    padding: 41.085% 0;
    width: 100%;
    position: relative;
    overflow: hidden;
  }
  #interview .interview_other_slider li div img {
    position: absolute;
    top: -100%;
    right: -100%;
    bottom: -100%;
    left: -100%;
    margin: auto;
    max-width: none;
  }
  #interview .interview_other_slider li div img.img_hor {
    width: auto;
    height: 100%;
  }
  #interview .interview_other_slider li div img.img_ver {
    width: 100%;
    height: auto;
  }
  #interview .interview_other_slider li .interview_other_slider_txt01 {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.48;
    letter-spacing: 0.78px;
    margin-top: 20px;
  }
  #interview .interview_other_slider li .interview_other_slider_txt02 {
    font-size: 24px;
    line-height: 1.48;
    letter-spacing: 1.44px;
    font-weight: 600;
    margin: 10px 0 5px;
  }
  #interview .interview_other_slider li .interview_other_slider_txt03 {
    font-size: 16px;
    line-height: 1.48;
    letter-spacing: 0.96px;
    margin-top: 5px;
  }
  #entry #contents {
    margin-bottom: 60px;
  }
  #entry #contents .contens_wrp {
    margin: 0;
    padding: 55px 15px 0 !important;
  }
  #entry .reruit_btn02_bg {
    background-color: rgba(0, 0, 0, 0.7);
    height: 225px;
    width: 100%;
    position: fixed;
    bottom: 0;
    left: 0;
  }
  #entry .recruit_select_wrp {
    background-color: #f0f0f0;
    padding: 50px 0;
    position: relative;
  }
  #entry .recruit_select_wrp:before {
    position: absolute;
    content: "";
    border-top: 16px solid #f0f0f0;
    border-right: 16px solid rgba(0, 0, 0, 0);
    border-bottom: 16px solid rgba(0, 0, 0, 0);
    border-left: 16px solid rgba(0, 0, 0, 0);
    left: 50%;
    transform: translateX(-50%);
    bottom: -32px;
  }
  #entry .recruit_select_wrp .recruit_select_inner {
    padding: 0 15px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box:last-child {
    margin-bottom: 0;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box p {
    width: 80px;
    font-size: 18px;
    font-weight: 600;
    margin-right: 15px;
    white-space: nowrap;
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box .select_01 {
    width: calc(100% - 80px);
  }
  #entry .recruit_select_wrp .recruit_select_inner .recruit_select_box .select_01 select {
    background-color: #fff;
    border: 1px solid #e0e0e0;
    padding: 8px 30px 8px 20px;
    font-size: 16px;
    width: 100%;
  }
  #entry .recruit_contents_list {
    margin-top: 40px;
  }
  #entry .recruit_contents_list li {
    position: relative;
    margin-bottom: 80px;
  }
  #entry .recruit_contents_list li:last-child {
    margin-bottom: 0;
  }
  #entry .recruit_contents_list li h3 {
    width: 100%;
    background-color: #f0f0f0;
    padding: 12px 20px;
  }
  #entry .recruit_contents_list li .recruit_contents_list_txtbox {
    min-height: 58px;
    border: 1px solid #e0e0e0;
    box-sizing: border-box;
  }
  #entry .recruit_contents_list li .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt01 {
    background-color: #f7f7f7;
    width: 100%;
    padding-left: 20;
    padding: 12px 20px;
    font-size: 16px;
    font-weight: 600;
    min-height: 58px;
    border-bottom: 1px solid #e0e0e0;
  }
  #entry .recruit_contents_list li .recruit_contents_list_txtbox .recruit_contents_list_txtbox_txt02 {
    width: 100%;
    background-color: #fff;
    height: 100%;
    font-size: 13px;
    min-height: 58px;
    line-height: 2;
    letter-spacing: 0.84px;
    padding: 15px 20px;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox_txt02 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox_txt02 .txt_inner {
    width: calc(100% - 60px);
    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 20px;
    padding-left: 20px;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn {
    width: 60px;
    margin-right: -1px;
    align-self: flex-end;
  }
  #entry .recruit_contents_list li.have_entry_btn .recruit_contents_list_txtbox_txt02 .recruit_contents_list_btn .btn_anchor::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  #entry .recruit_contact {
    background-color: #f0f0f0;
    padding: 30px;
    text-align: center;
  }
  #entry .recruit_contact .recruit_contact_txt01 {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 1.44px;
    line-height: 1;
  }
  #entry .recruit_contact .recruit_contact_txt02 {
    font-size: 32px;
    font-weight: 600;
    letter-spacing: 2.16px;
    line-height: 1;
    margin: 20px 0 20px;
  }
  #entry .recruit_contact .recruit_contact_txt02 a {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  #entry .recruit_contact .recruit_contact_txt03 {
    font-size: 13px;
    letter-spacing: 0.84px;
    line-height: 1;
  }
  #entry #area_btn {
    margin-top: 60px;
  }
  #entry #area_btn .fixed {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    padding-top: 5%;
    padding-right: 20px;
    padding-left: 20px;
  }
  #entry #area_btn .area_btn_shadow {
    margin: 0 -15px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
  }
  #entry #area_btn .area_btn_shadow.show {
    opacity: 1;
    visibility: visible;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items {
    display: flex;
    width: 100%;
    align-items: center;
    max-width: 860px;
    margin-right: auto;
    margin-left: auto;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item {
    background-color: #fff;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item a {
    display: block;
    text-align: center;
    background-color: #ccc;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items .area_btn_item a .area_btn_str {
    font-size: 4vw;
    color: #fff;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num1 {
    justify-content: center;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num1 .area_btn_item {
    width: calc(100% - 40px);
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num1 .area_btn_item a {
    padding: 8.6% 0;
    position: relative;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num1 .area_btn_item a svg {
    position: absolute;
    top: 0;
    right: 8%;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 15px;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 {
    justify-content: space-between;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 .area_btn_item {
    width: 50%;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 .area_btn_item a {
    padding: 15% 0;
    position: relative;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 .area_btn_item a .area_btn_str {
    font-size: 4vw;
    color: #fff;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num2 .area_btn_item a svg {
    position: absolute;
    top: 0;
    right: 8%;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 15px;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 {
    justify-content: space-between;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 .area_btn_item {
    width: 33.3333333333%;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 .area_btn_item a {
    padding: 16% 0;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 .area_btn_item a .area_btn_str {
    display: block;
    margin-bottom: 5px;
  }
  #entry #area_btn .area_btn_shadow .area_btn_items.items_num3 .area_btn_item a svg {
    display: block;
    height: 13px;
    margin-left: auto;
    margin-right: auto;
  }
  #entry .htxt09 {
    margin-bottom: 30px;
  }
  #entry .table01_02 {
    margin-top: 30px;
  }
  #entry .no_posts {
    text-align: center;
    font-size: 17px;
  }
  #faq #contents {
    margin-bottom: 0;
  }
  #faq #contents .contens_wrp {
    padding: 0 20px;
  }
  #faq .faq_sumally {
    padding: 40px 20px;
    text-align: center;
  }
  #faq .faq_sumally .sumally_inner ul li:not(:last-child) {
    margin-bottom: 1.5em;
  }
  #faq .faq_sumally .sumally_inner ul li a {
    display: inline-block;
    padding-right: 1.3em;
    position: relative;
    font-size: 18px;
  }
  #faq .faq_sumally .sumally_inner ul li a svg {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 0;
    height: 0;
    display: inline-block;
    width: 12px;
    height: 20px;
  }
  #faq .qa_list_wrp .qa_list {
    margin-top: 40px;
    margin-bottom: 70px;
  }
  #faq .qa_list_wrp .qa_list:last-child {
    margin-bottom: 0;
  }
  #faq .qa_list_wrp .qa_list li {
    position: relative;
    margin-bottom: 40px;
  }
  #faq .qa_list_wrp .qa_list li .qa_list_icon_wrp {
    position: absolute;
    right: 0;
    top: 0;
  }
  #faq .qa_list_wrp .qa_list li .question {
    background-color: #f0f0f0;
    font-size: 18px;
    letter-spacing: 1.44px;
    line-height: 1.48;
    padding: 12px 0;
    padding-left: 80px;
    position: relative;
    padding-right: 60px;
    cursor: pointer;
  }
  #faq .qa_list_wrp .qa_list li .question span {
    display: block;
  }
  #faq .qa_list_wrp .qa_list li .question:before {
    content: "Q";
    font-size: 32px;
    line-height: 1;
    font-weight: 600;
    position: absolute;
    left: 20px;
    top: 8px;
  }
  #faq .qa_list_wrp .qa_list li .question:after {
    content: "";
    width: 1px;
    height: 60%;
    position: absolute;
    background-color: #000;
    left: 63px;
    top: 50%;
    transform: translateY(-50%);
  }
  #faq .qa_list_wrp .qa_list li .answer {
    padding-left: 80px;
    position: relative;
    margin-top: 20px;
  }
  #faq .qa_list_wrp .qa_list li .answer:before {
    position: absolute;
    content: "A";
    color: #fff;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    background-color: #6a6a6a;
    font-size: 32px;
    text-align: center;
    font-weight: 600;
    line-height: 46px;
    text-indent: 2px;
    left: 8px;
    top: 0;
  }
  #faq .qa_list_wrp .qa_list li .answer p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.84px;
    padding-top: 10px;
  }
  #faq .qa_list_wrp .qa_list li .answer a {
    text-decoration: underline;
  }
  #data #contents {
    margin-bottom: 0;
  }
  #data #contents .contens_wrp {
    margin: 0;
    padding: 40px 20px !important;
  }
  #data .data_contents_layout01 ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  #data .data_contents_layout01 ul li {
    box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.05);
    width: 100%;
    position: relative;
    padding: 80px 0 20px;
    margin-bottom: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: #fff;
  }
  #data .data_contents_layout01 ul li h2 {
    position: absolute;
    left: 10px;
    top: 10px;
    max-width: calc(100% - 20px);
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: auto;
    flex-wrap: wrap;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 .data_contents_layout01_box01_box01 {
    width: 100px;
    margin-right: 20px;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 .data_contents_layout01_box01_box02 p {
    font-family: "Oswald", sans-serif;
    font-weight: 400;
    font-size: 80px;
    line-height: 1;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box01 .data_contents_layout01_box01_box02 p span {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 40px;
    font-weight: 900;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_box02 {
    padding: 0 20px;
    width: 100%;
  }
  #data .data_contents_layout01 ul li .data_contents_layout01_txt01 {
    line-height: 2;
    letter-spacing: 0.84px;
    padding: 0 20px;
    margin-top: auto;
    padding-top: 20px;
    width: 100%;
  }
  #data .data_contents_layout02 ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  #data .data_contents_layout02 ul li {
    box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.05);
    position: relative;
    width: 100%;
    padding: 80px 0 20px;
    margin-bottom: 30px;
    background-color: #fff;
  }
  #data .data_contents_layout02 ul li h2 {
    position: absolute;
    left: 10px;
    top: 10px;
    max-width: calc(100% - 20px);
  }
  #data .data_contents_layout02 ul li p {
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    font-size: 80px;
    line-height: 1;
    text-align: center;
  }
  #data .data_contents_layout02 ul li p span {
    padding-left: 5px;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 40px;
    font-weight: 900;
  }
  .fixed_contents p {
    margin-bottom: 15px;
  }
  .fixed_contents .date_txt01 {
    font-size: 12px;
    font-weight: 600;
  }
  .fixed_contents h2 {
    font-size: 26px;
    font-weight: 600;
    letter-spacing: 2.16px;
    line-height: 1.48;
    border-bottom: 1px solid #000;
    padding-bottom: 6px;
  }
  .fixed_contents h3 {
    font-size: 18px;
    letter-spacing: 1.44px;
    line-height: 1.48;
    font-weight: 600;
    background-color: #f0f0f0;
    padding: 6px 15px 8px;
    margin-top: 40px;
    margin-bottom: 15px;
  }
  .fixed_contents h4 {
    font-size: 26px;
    line-height: 1;
    display: inline-block;
    padding: 5px 10px 8px;
    background-color: #000;
    color: #fff;
    font-weight: 500;
  }
  .fixed_contents .colmun_layout01 .colmun_layout01_box {
    width: 100%;
  }
  .fixed_contents .img_box01 {
    margin-top: 15px;
  }
  .fixed_contents .img_box01 img {
    vertical-align: bottom;
  }
  .fixed_contents .img_box01 p {
    font-size: 12px;
    margin-top: 2px;
  }
  .fixed_contents .anchor_wrp {
    padding: 40px 0;
  }
  .fixed_contents .anchor_wrp ul {
    text-align: center;
  }
  .fixed_contents .anchor_wrp ul li {
    margin: 0 25px;
    margin-bottom: 35px;
  }
  .fixed_contents .anchor_wrp ul li:last-child {
    margin-bottom: 0;
  }
  .fixed_contents .anchor_wrp ul li a {
    font-size: 18px;
    font-weight: 600;
    position: relative;
    display: inline-block;
    padding-right: 18px;
    border-bottom: 1px solid #fff;
  }
  .fixed_contents .anchor_wrp ul li a:before {
    position: absolute;
    top: 11px;
    right: 0;
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 4.5px solid rgba(0, 0, 0, 0);
    border-right: 4.5px solid rgba(0, 0, 0, 0);
    border-top: 7px solid #707070;
    pointer-events: none;
  }
  .fixed_contents .news_layout01 {
    justify-content: space-between;
  }
  .fixed_contents .news_layout01 .news_layout01_list {
    width: 100%;
    background-color: #fff;
    margin-bottom: 30px;
  }
  .fixed_contents .news_layout01 .news_layout01_list a {
    display: flex;
    flex-direction: column;
    transition: opacity 0.5s;
    height: 100%;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box01 {
    position: relative;
    border-bottom: 1px solid #ebebeb;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box01 img {
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: bottom;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box01 .news_layout01_box01_icon01_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 {
    padding: 15px;
    padding-bottom: 0;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt01 {
    font-size: 13px;
    letter-spacing: 0.84px;
    font-weight: 600;
    margin-bottom: 5px;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02 {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.96px;
    line-height: 1.48;
    position: relative;
    padding-left: 0.8em;
    margin-bottom: 20px;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #707070;
    width: 2px;
    height: 80%;
  }
  .fixed_contents .news_layout01 .news_layout01_list a .tag_list_wrp {
    margin-top: auto;
    padding: 0 15px 15px;
  }
  .fixed_contents .tag_list {
    margin-right: -5px;
  }
  .fixed_contents .tag_list li {
    line-height: 1;
    display: inline-block;
    border: 1px solid #dedede;
    background-color: #f0f0f0;
    border-radius: 24px;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 8px 5px;
    margin-right: 5px;
  }
  .fixed_contents .news_contents_tag_list_wrp {
    margin-top: 10px;
  }
  .fixed_contents .main_art {
    margin-top: 15px;
  }
  .fixed_contents .fixed_layout {
    width: 100%;
  }
  .fixed_contents .fixed_layout .fixed_layout_visual {
    width: 100%;
    height: 330px;
    background-image: url("/lib/img/jobs/jobs_visual01.png");
    background-position: center;
    background-size: cover;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents {
    margin: 0 20px;
    padding: 30px 0 60px;
    text-align: left;
    background-color: #fff;
    margin-top: -60px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents p {
    text-align: left;
    margin-top: 30px;
    margin-bottom: 60px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents h4 {
    margin-bottom: 50px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents h5 {
    text-align: left;
    position: relative;
    padding-left: 0.8em;
    font-weight: 500;
    font-size: 20px;
    line-height: 1.48;
    letter-spacing: 1.44px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents h5:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #707070;
    width: 2px;
    height: 95%;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents .fixed_layout_contents_img01 {
    margin-top: 20px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents .colmun_layout01 {
    margin-top: 20px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents p + .fixed_layout_contents_img01 {
    margin-top: -30px;
  }
  .fixed_contents .fixed_layout .fixed_layout_contents p + .colmun_layout01 {
    margin-top: -30px;
  }
  .fixed_contents .fixed_layout02 h5 {
    display: inline;
    padding-left: 0 !important;
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #d6d6d6 0%) repeat scroll 0 0;
  }
  .fixed_contents .fixed_layout02 h5:before {
    position: relative;
    width: 0 !important;
    height: 0 !important;
  }
  .fixed_contents .fixed_layout03 h5 {
    display: inline-block;
    padding-left: 0 !important;
  }
  .fixed_contents .fixed_layout03 h5:before {
    position: relative;
    width: 0 !important;
    height: 0 !important;
  }
  #jobs #common_main_visual {
    height: 160px;
  }
  #jobs .jobs_sumally {
    padding: 40px 20px;
    text-align: center;
  }
  #jobs .jobs_sumally .sumally_inner ul li:not(:last-child) {
    margin-bottom: 1.5em;
  }
  #jobs .jobs_sumally .sumally_inner ul li a {
    display: inline-block;
    padding-right: 1.3em;
    position: relative;
    vertical-align: middle;
    font-size: 18px;
  }
  #jobs .jobs_sumally .sumally_inner ul li a svg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    margin-top: auto;
    margin-bottom: auto;
    width: 0;
    height: 0;
    display: inline-block;
    width: 12px;
    height: 20px;
  }
  #jobs .contens_wrp {
    padding: 40px 0;
  }
  #jobs .contens_wrp .contens_inner {
    max-width: none;
  }
  #jobs .contens_wrp .contens_inner .entry_content {
    position: relative;
    padding-top: 90%;
  }
  #jobs .contens_wrp .contens_inner .entry_content::before {
    content: "";
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin-right: auto;
    margin-left: auto;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: auto 100%;
    padding: 50% 0;
  }
  #jobs .contens_wrp .contens_inner .entry_content:not(:last-child) .entry_content_inner {
    padding-bottom: 25%;
  }
  #jobs .contens_wrp .contens_inner .entry_content .entry_content_inner {
    background-color: #fff;
    margin-right: auto;
    margin-left: auto;
    padding-right: 15px;
    padding-left: 15px;
    position: relative;
    width: calc(100% - 40px);
  }
  #jobs .contens_wrp .contens_inner .entry_content .entry_content_inner .entry_content_ttl {
    text-align: center;
    padding-top: 6%;
    margin-bottom: 4.5em;
  }
  #jobs .contens_wrp .contens_inner .entry_content .entry_content_inner .entry_content_ttl > .ttl_inner {
    display: inline-block;
    color: #fff;
    background-color: #000;
    padding: 0.5em;
    font-size: 26px;
  }
  #news .date_txt01 {
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 15px;
  }
  #news h2 {
    font-size: 26px;
    font-weight: 600;
    letter-spacing: 2.16px;
    line-height: 1.48;
    border-bottom: 1px solid #ebebeb;
    padding-bottom: 6px;
  }
  #news .contens_wrp {
    padding-bottom: 40px !important;
    padding-top: 40px !important;
    padding-right: 20px;
    padding-left: 20px;
    margin: 0;
  }
  #news .contens_wrp .news_layout01 {
    justify-content: space-between;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list {
    width: 100%;
    background-color: #fff;
    margin-bottom: 30px;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a {
    display: flex;
    flex-direction: column;
    transition: opacity 0.5s;
    height: 100%;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box01 {
    border-bottom: 1px solid #ebebeb;
    padding: 27.5% 0;
    width: 100%;
    position: relative;
    overflow: hidden;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box01 img {
    position: absolute;
    top: -100%;
    right: -100%;
    bottom: -100%;
    left: -100%;
    margin: auto;
    max-width: none;
    display: none;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box01 img.img_hor {
    width: auto;
    height: 100%;
    display: block;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box01 img.img_ver {
    width: 100%;
    height: auto;
    display: block;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box01 .news_layout01_box01_icon01_wrp {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box02 {
    padding: 15px;
    padding-bottom: 0;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt01 {
    font-size: 13px;
    letter-spacing: 0.84px;
    font-weight: 600;
    margin-bottom: 5px;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02 {
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 0.96px;
    line-height: 1.48;
    position: relative;
    padding-left: 0.8em;
    margin-bottom: 20px;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .news_layout01_box02 .news_layout01_box02_txt02:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #707070;
    width: 2px;
    height: 80%;
  }
  #news .contens_wrp .news_layout01 .news_layout01_list a .tag_list_wrp {
    margin-top: auto;
    padding: 0 15px 15px;
  }
  #news #js_more_btn {
    text-align: center;
    margin-top: 3.5em;
    padding-bottom: 3.5em;
  }
  #news #js_more_btn button {
    padding: 1em 3em;
    background-color: #000;
    color: #fff;
    font-size: 1.1em;
    transition: all 0.2s;
  }
  #news .tag_list {
    margin-right: -5px;
  }
  #news .tag_list li {
    line-height: 1;
    display: inline-block;
    border: 1px solid #dedede;
    background-color: #f0f0f0;
    border-radius: 24px;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 8px 5px;
    margin-right: 5px;
  }
  #news .news_contents_tag_list_wrp {
    margin-top: 10px;
  }
  #news .main_art {
    margin-top: 15px;
  }
  .form_wrp #common_main_visual {
    height: auto;
    margin-top: 0;
  }
  .form_wrp #common_main_visual .common_main_visual_inner {
    top: 0;
    transform: none;
  }
  .form_wrp .entry_form_wrp {
    max-width: 950px;
    margin: 0 auto;
    padding: 0 20px;
  }
  .form_wrp .entry_form_wrp .contens_wrp {
    padding: 40px 0;
    margin-bottom: 120px;
  }
  .form_wrp .entry_form_wrp .recruit_contents_list_wrp {
    padding-bottom: 0 !important;
    margin-bottom: 0;
    position: relative;
  }
  .form_wrp .entry_form_wrp .recruit_contents_list_wrp:before {
    position: absolute;
    width: 0;
    height: 0;
    border-left: 16px solid rgba(0, 0, 0, 0);
    border-right: 16px solid rgba(0, 0, 0, 0);
    border-top: 15px solid #e0e0e0;
    content: "";
    left: 50%;
    transform: translateX(-50%);
    bottom: -47px;
  }
  .form_wrp .entry_form_wrp .recruit_contents_list {
    margin-top: 30px !important;
  }
  .form_wrp .entry_form_wrp .entry_form {
    margin-top: 15px;
    position: relative;
    width: 100%;
    overflow: hidden;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .row {
    border-bottom: 1px dotted #bfbfbf;
  }
  .form_wrp .entry_form_wrp .entry_form .row:last-child {
    border-bottom: none !important;
  }
  .form_wrp .entry_form_wrp .entry_form .col {
    display: block;
    padding: 15px 0;
    position: relative;
  }
  .form_wrp .entry_form_wrp .entry_form .col:first-child {
    font-weight: 600;
    vertical-align: top;
    padding-top: 24px;
    padding-bottom: 0;
  }
  .form_wrp .entry_form_wrp .entry_form .col:first-child .require {
    position: relative;
    padding-left: 35px;
  }
  .form_wrp .entry_form_wrp .entry_form .col:first-child .require:before {
    position: absolute;
    content: "必須";
    font-size: 12px;
    color: #fff;
    line-height: 1;
    background-color: #e35656;
    padding: 2px 3px 3px;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .form_wrp .entry_form_wrp .entry_form .col input {
    height: 45px;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    padding: 5px 11.5px;
    box-sizing: border-box;
    width: 100%;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .col input:focus {
    outline: none;
  }
  .form_wrp .entry_form_wrp .entry_form .col select {
    height: 45px;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    padding: 5px 40px 5px 10px;
    box-sizing: border-box;
    background-color: #fff;
    color: #000;
    background-image: url(../img/arrow_down.svg);
    background-position: right 15px center;
    background-size: 13px 8px;
    background-repeat: no-repeat;
    -webkit-appearance: none;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .col select:focus {
    outline: none;
  }
  .form_wrp .entry_form_wrp .entry_form .col select.is_block {
    display: block;
    width: 100%;
  }
  .form_wrp .entry_form_wrp .entry_form .col textarea {
    width: 100%;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    padding: 5px 10px;
    box-sizing: border-box;
    font-size: 16px;
  }
  .form_wrp .entry_form_wrp .entry_form .col textarea:focus {
    outline: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) > p {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) .birth_span {
    padding: 0 5px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) .timing-year input {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) .timing-month input {
    width: 45px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-year] input {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-year] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-month] input {
    width: 65px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-month] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-date] input {
    width: 65px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=your-birth-date] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=timing-year] input {
    width: 100px;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=timing-year] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .birth .col:nth-child(2) span[data-name=timing-month] .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div {
    margin-bottom: 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div > p {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div span[data-name=your-postal-code].wpcf7-form-control-wrap {
    display: inline-block;
    margin: 0 0 0 10px;
    width: calc(100% - 28px);
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div span[data-name=your-postal-code].wpcf7-form-control-wrap .wpcf7-form-control {
    width: 190px;
  }
  .form_wrp .entry_form_wrp .entry_form .address .col:nth-child(2) div .address_search {
    font-size: 14px;
    color: #fff;
    line-height: 1;
    padding: 8px 20px 6px;
    background-color: #000;
    cursor: pointer;
    margin-top: 15px;
    position: absolute;
    top: 23px;
    left: 223px;
    width: 110px;
    margin-top: 0;
    text-align: center;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div > p {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(1) {
    margin-bottom: 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(1) span {
    display: inline-block;
    padding-bottom: 5px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(2) {
    margin-bottom: 15px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(2) span {
    display: inline-block;
    padding-bottom: 5px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span {
    display: block;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:first-child {
    display: inline-block;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:first-child input {
    width: 120px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:first-child .wpcf7-not-valid-tip {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:nth-child(2) {
    margin: 10px 5px 10px;
  }
  .form_wrp .entry_form_wrp .entry_form .final_education .col:nth-child(2) div:nth-child(3) span:nth-child(4) select {
    width: 130px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) input {
    border: none;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) input[type=file] {
    display: none;
    opacity: 0;
    visibility: hidden;
    height: 0;
    padding: 0;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) label {
    cursor: pointer;
    display: block;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) label br {
    display: none;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) label:before {
    color: #fff;
    background-color: #000;
    height: 30px;
    width: 110px;
    content: "ファイルを選択";
    color: #fff;
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) p {
    display: block;
    vertical-align: top;
    margin: 3px 0 0 0;
    font-size: 13px;
    position: relative;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) .your-resume1_file, .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) .your-resume2_file {
    position: absolute;
    top: 17px;
    left: 120px;
    width: calc(100% - 120px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) ul {
    padding-top: 10px;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) ul li {
    font-size: 12px;
    margin-bottom: 4px;
    word-break: break-all;
    white-space: normal;
  }
  .form_wrp .entry_form_wrp .entry_form .file .col:nth-child(2) ul li:last-child {
    margin-bottom: 0;
  }
  .form_wrp .entry_form_wrp .privacy_box {
    width: 100%;
    background-color: #f7f7f7;
    height: 244px;
    margin-top: 30px;
    padding: 15px 0;
  }
  .form_wrp .entry_form_wrp .privacy_box .privacy_box_inner {
    overflow-y: auto;
    height: 100%;
  }
  .form_wrp .entry_form_wrp .privacy_box .gutenberg_content {
    padding: 0 20px 15px;
  }
  .form_wrp .entry_form_wrp .privacy_box .privacy_ttl {
    padding: 15px 20px;
  }
  .form_wrp .entry_form_wrp .confirm_box {
    margin-top: 30px;
    text-align: center;
  }
  .form_wrp .entry_form_wrp .confirm_box p {
    text-align: center;
    font-size: 12px;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label span {
    font-size: 16px;
    font-weight: 600;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label input[type=checkbox] {
    display: none;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label input[type=checkbox]:checked {
    display: none;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy label {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy .wpcf7-list-item-label::before {
    content: "";
    height: 18px;
    width: 18px;
    border-radius: 3px;
    border: solid 1px #e0e0e0;
    left: 5px;
    top: 4px;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy .wpcf7-list-item-label::after {
    border-left: 3px solid #ed7a9c;
    border-bottom: 3px solid #ed7a9c;
    top: -2px;
    left: 9px;
  }
  .form_wrp .entry_form_wrp .confirm_box .agree-privacy .active_label:after {
    opacity: 1;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn {
    display: inline-block;
    background-color: #000;
    border: 1px solid #000;
    max-width: 480px;
    text-align: center;
    width: 100%;
    color: #fff;
    font-size: 24px;
    letter-spacing: 2.16px;
    font-weight: 600;
    position: relative;
    transition: 0.5s;
    margin-top: 45px;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn p {
    display: -webkit-inline-box;
    width: 100%;
    margin-bottom: 0;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn input {
    border: none;
    margin: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: none;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #fff 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: all 0.3s ease 0s;
    text-decoration: none;
    padding: 15px 25px;
    color: #fff;
    font-size: 18px;
    letter-spacing: 1.44px;
    font-weight: 600;
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn svg {
    position: absolute;
    content: "";
    width: 16px;
    height: 15px;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
  }
  .form_wrp .entry_form_wrp .confirm_box .submit_btn .wpcf7-spinner {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -40px;
    margin: 0;
  }
  .form_wrp .entry_form_wrp input[type=radio] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: none;
    opacity: 0;
    width: 1px;
    position: absolute;
    height: 1px;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    padding: 10px 11px 8px 23px;
    border-radius: 4px;
    font-weight: 500;
    font-size: 14px;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span::before, .form_wrp .entry_form_wrp input[type=radio] + span::after {
    position: absolute;
    content: "";
    display: block;
    border-radius: 50%;
    top: 2px;
    bottom: 0;
    margin: auto 10px auto 0;
    box-sizing: border-box;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span::before {
    width: 14px;
    height: 14px;
    background: #fff;
    border: 1px solid #e0e0e0;
    left: 0;
  }
  .form_wrp .entry_form_wrp input[type=radio] + span::after {
    width: 8px;
    height: 8px;
    background: #999;
    left: 3px;
    opacity: 0;
  }
  .form_wrp .entry_form_wrp input[type=radio]:checked + span::before {
    border: 1px solid #e0e0e0;
  }
  .form_wrp .entry_form_wrp input[type=radio]:checked + span::after {
    background: #000;
    opacity: 1;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: none;
    opacity: 0;
    width: 1px;
    position: absolute;
    height: 1px;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    padding: 10px 11px 8px 32px;
    border-radius: 4px;
    font-weight: 500;
    font-size: 14px;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span::before, .form_wrp .entry_form_wrp input[type=checkbox] + span::after {
    position: absolute;
    content: "";
    display: block;
    top: 0;
    bottom: 0;
    margin: auto 10px auto 0;
    box-sizing: border-box;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span::before {
    width: 14px;
    height: 14px;
    background: #fff;
    border: 1px solid #e0e0e0;
    left: 3px;
  }
  .form_wrp .entry_form_wrp input[type=checkbox] + span::after {
    width: 12px;
    height: 8px;
    background-color: rgba(0, 0, 0, 0);
    border-left: 3px solid #000;
    border-bottom: 3px solid #000;
    top: -5px;
    left: 5px;
    opacity: 0;
    transform: rotate(-45deg);
  }
  .form_wrp .entry_form_wrp input[type=checkbox]:checked + span::before {
    border: 1px solid #e0e0e0;
  }
  .form_wrp .entry_form_wrp input[type=checkbox]:checked + span::after {
    opacity: 1;
  }
  .form_wrp .entry_form_wrp .wpcf7-custom-item-error {
    width: 100%;
  }
  .form_wrp .entry_form_wrp .wpcf7-not-valid-tip {
    color: #c00;
    padding: 5px 10px;
    background: #f4e4e4;
    display: inline-block;
    font-size: 14px;
    font-weight: bold;
    margin-top: 0.5em;
    width: calc(100vw - 40px);
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap {
    width: 100%;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control {
    display: block;
    width: 100%;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control .wpcf7-list-item:first-child {
    margin-left: 0;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control .wpcf7-list-item label {
    display: flex;
    align-items: center;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control.item_block .wpcf7-list-item, .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control.item_block_sp .wpcf7-list-item {
    display: block;
    margin-left: 0;
  }
  .form_wrp .entry_form_wrp .use-floating-validation-tip .wpcf7-not-valid-tip {
    position: absolute;
    left: 0;
    top: 1rem;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control {
    display: block;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control .wpcf7-list-item label {
    display: flex;
    align-items: center;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control.item_block .wpcf7-list-item, .form_wrp .entry_form_wrp .wpcf7-form-control-wrap .wpcf7-form-control.item_block_sp .wpcf7-list-item {
    display: block;
  }
  .form_wrp .entry_form_wrp .wpcf7-form-control.wpcf7-not-valid {
    display: block !important;
  }
  #block_404 .layout_container {
    width: calc(100% - 40px);
    margin-right: auto;
    margin-left: auto;
  }
  #block_404 .page_404 {
    margin: 70px auto;
    padding: 25px;
    background-color: #eee;
  }
  #block_404 .page_404_txt2 {
    margin-bottom: 25px;
  }
  #block_404 .page_404_txt3 {
    margin-bottom: 7.5px;
  }
  #block_404 .txt1_page_404 {
    font-size: 24px;
    font-weight: bold;
    text-align: center;
  }
  #block_404 .txt2_page_404 {
    text-align: center;
    font-size: 15px;
  }
  #block_404 .txt3_page_404 {
    font-size: 15px;
  }
  #block_404 .link_page_404 {
    text-align: center;
  }
  #block_404 .link_page_404 a {
    display: inline-block;
    transition: all 0.2s;
  }
  #block_404 .link_page_404 a:after {
    content: "";
    display: inline-block;
    margin-left: 6px;
    transition: all 0.2s;
  }
} 
/*
ミックスインメモ

・フォント自動計算（）にフォントサイズ1920準拠
    @include mixin.font-size(40);

・カーニング（）にline-heightを入れる
  @include mixin.line-height(44);

・メディアクエリ用
  @include mixin.mq-max('sp') {
  }

*/
/*基本スタイルここから*/
/* ===============================================
// Root & Variables
// =============================================== */
:root {
  --color-primary: #C9000E;
  --color-text: #333;
  --font-family-base: "Zen Kaku Gothic New", sans-serif;
}

/* ===============================================
// Reset & Base
// =============================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 100%;
}

body {
  color: var(--color-text);
  font-size: 1rem;
  font-family: var(--font-family-base);
  line-height: 1.7;
  font-weight: 500;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

a {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.3s;
}
a:hover {
  opacity: 0.7;
}

p {
  font-size: clamp(0.4rem, calc(0.254368932rem + 0.6213592233vw), 1.1rem);
}
@media screen and (max-width: 767px) {
  p {
    font-size: 14px;
    letter-spacing: 0;
  }
}

a:focus-visible,
button:focus-visible,
input:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ===============================================
// Utility Classes
// =============================================== */
.inner {
  max-width: 1920px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 9vw;
  padding-right: 9vw;
  padding-top: 10vw;
}
@media screen and (max-width: 767px) {
  .inner {
    padding-left: 6vw;
    padding-right: 6vw;
  }
}

.sp-none {
  display: block;
}
@media screen and (max-width: 767px) {
  .sp-none {
    display: none;
  }
}

.pc-none {
  display: none;
}
@media screen and (max-width: 767px) {
  .pc-none {
    display: block;
  }
}

section {
  position: relative;
}

.headline {
  width: 100%;
  margin-bottom: 5vw;
}
.headline .headline-en {
  font-size: clamp(2.15rem, calc(1.3672330097rem + 3.3398058252vw), 5.9125rem);
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
}
.headline .headline-ja {
  position: relative;
  font-size: clamp(0.625rem, calc(0.3974514563rem + 0.9708737864vw), 1.71875rem);
  font-weight: bold;
  color: #A41C20;
  padding-left: 2.5vw;
}
@media screen and (max-width: 767px) {
  .headline .headline-ja {
    padding-left: 7vw;
    font-size: 14px;
  }
}
.headline .headline-ja::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url("../img/recruit/common/title-icon.png");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .headline .headline-ja::before {
    width: 20px;
    height: 20px;
  }
}

@media screen and (max-width: 767px) {
  .flex-box {
    flex-direction: column;
  }
}

#top_contents {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  #top_contents {
    margin-bottom: 0;
  }
}

@media screen and (max-width: 767px) {
  #contents {
    margin-bottom: 0;
  }
}

.slick-next {
  display: none !important;
}

.slick-prev {
  display: none !important;
}

.under .mainvisual {
  width: 100%;
  height: 50vh;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: bottom;
}
@media screen and (max-width: 767px) {
  .under .mainvisual {
    margin-bottom: 60px;
  }
}
.under .mainvisual .under-headline {
  background: transparent linear-gradient(116deg, #C1272D 0%, #D78062 23%, rgba(215, 128, 98, 0) 65%) 0% 0% no-repeat padding-box;
  width: 100%;
  height: 100%;
  padding-top: 8vw;
  padding-left: 8vw;
  color: #fff;
}
.under .mainvisual .under-headline .headline-en {
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .under .mainvisual .under-headline .headline-en {
    font-size: 13px;
  }
}
.under .mainvisual .under-headline .headline-ja {
  font-size: clamp(1.7rem, calc(1.0810679612rem + 2.640776699vw), 4.675rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .under .mainvisual .under-headline .headline-ja {
    font-size: 28px;
  }
}
.under .mainvisual .under-headline .headline-txt {
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .under .mainvisual .under-headline .headline-txt {
    font-size: 13px;
  }
}
.under h2 {
  position: relative;
  font-size: clamp(1.05rem, calc(0.6677184466rem + 1.6310679612vw), 2.8875rem);
  font-weight: bold;
  padding-left: 40px;
  margin-bottom: 4vw;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .under h2 {
    font-size: 22px;
  }
}
.under h2::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url("../img/recruit/common/title-icon.png");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .under h2::before {
    width: 20px;
    height: 20px;
  }
}
.under h2::after {
  content: "";
  position: absolute;
  width: 100%;
  max-height: 200px;
  height: 12vw;
  top: -8vw;
  left: -9vw;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .under h2::after {
    height: 15vw;
    left: -5vw;
  }
}

/*基本スタイルここまで*/
#mv {
  position: relative;
  height: 90vh;
}
#mv::before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  background-image: url("../img/recruit/top/mv.webp");
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100vh;
  position: fixed;
}
@media screen and (max-width: 767px) {
  #mv::before {
    background-image: url("../img/recruit/top/mv-sp.jpg");
    height: 100vh;
    background-position: 0px -20px;
  }
}
#mv .part_982 .htxt03 {
  color: #A41C20;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  #mv .part_982 .htxt03 {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
#mv .part_982 .date_list li p {
  border-right: 1px solid #6f6f6f;
  padding-right: 20px;
}
@media screen and (max-width: 767px) {
  #mv .part_982 .date_list li p {
    border-right: none;
  }
}
#mv .inner {
  max-width: 1920px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2vw;
  padding-right: 2vw;
  padding-top: 0;
}
@media screen and (max-width: 767px) {
  #mv .inner {
    padding-left: 5vw;
    padding-top: 30px;
  }
}
#mv .mv-title_en {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.15rem, calc(1.3672330097rem + 3.3398058252vw), 5.9125rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #mv .mv-title_en {
    line-height: 40px;
    font-size: 28px;
  }
}
#mv .mv-title_ja {
  font-size: clamp(0.7rem, calc(0.4451456311rem + 1.0873786408vw), 1.925rem);
  font-weight: bold;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  #mv .mv-title_ja {
    margin-bottom: 30px;
    font-size: 16px;
  }
}
#mv .mv-text {
  font-size: clamp(0.375rem, calc(0.2384708738rem + 0.5825242718vw), 1.03125rem);
  line-height: clamp(15.2px, 1.9791666667vw, 38px);
}
@media screen and (max-width: 767px) {
  #mv .mv-text {
    font-size: 12px;
    line-height: 30px;
  }
}
#mv .top_news {
  position: absolute;
  bottom: 5vw;
  right: 2vw;
  background-color: rgba(255, 255, 255, 0.3);
  -webkit-backdrop-filter: blur(30px);
          backdrop-filter: blur(30px);
  max-width: 610px;
  width: 100%;
  padding: 37px 0;
  border-radius: 10px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #mv .top_news {
    width: 85%;
    padding: 16px 0;
    right: 0;
    left: 0;
  }
}
#mv .top_news .top_news_inner {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1vw;
}
@media screen and (max-width: 767px) {
  #mv .top_news .top_news_inner {
    flex-direction: column;
    align-items: normal;
  }
}
#mv .top_news .top_news_inner::after {
  content: "";
  position: absolute;
  right: 38px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url("../img/recruit/common/red-arrow.png");
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(10px);
}
@media screen and (max-width: 767px) {
  #mv .top_news .top_news_inner::after {
    width: 20px;
    height: 20px;
    right: 22px;
  }
}
#mv .top_news .top_news_inner .date_list {
  margin-top: 0;
}
#mv .top_news .top_news_inner .date_list p {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  #mv .top_news .top_news_inner .date_list p {
    margin-bottom: 0;
    font-size: 12px;
  }
}
#mv .top_news .top_news_inner .date_list .data-list-title {
  color: #000;
  border: none;
}
#mv .top_news .top_news_inner .date_list a {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  #mv .top_news .top_news_inner .date_list a {
    line-height: normal;
  }
}

#about {
  padding-top: 3vw;
  background-color: #EBF0F4;
  padding-bottom: 10vw;
}
@media screen and (max-width: 767px) {
  #about {
    padding-bottom: 100px;
  }
}
@media screen and (max-width: 767px) {
  #about .inner {
    padding-top: 0;
  }
}
#about .text-bg .marquee__track {
  --marquee-duration: 100s;
}
#about .marquee {
  position: relative;
  overflow: hidden;
}
#about .marquee__track {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  --marquee-duration: 40s;
  animation: marquee-animation var(--marquee-duration) linear infinite;
}
.marquee:hover #about .marquee__track {
  animation-play-state: paused;
}
#about .marquee__content {
  display: flex;
  align-items: center;
  gap: 30px;
  padding-right: 30px;
}
#about .marquee__content img {
  height: 250px;
  width: auto;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  #about .marquee__content img {
    height: 90px;
  }
}
@keyframes marquee-animation {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
#about .flex-box {
  display: flex;
  align-items: center;
  gap: 3vw;
}
#about .text-wrap {
  width: 55%;
}
@media screen and (max-width: 767px) {
  #about .text-wrap {
    width: 100%;
  }
}
#about .about-title {
  font-size: clamp(1.125rem, calc(0.7154126214rem + 1.7475728155vw), 3.09375rem);
  font-weight: bold;
  line-height: 60px;
}
@media screen and (max-width: 767px) {
  #about .about-title {
    font-size: 24px;
    line-height: 43px;
    margin-bottom: 30px;
  }
}
#about .about-text {
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  line-height: clamp(16px, 2.0833333333vw, 40px);
}
@media screen and (max-width: 767px) {
  #about .about-text {
    font-size: 15px;
    line-height: 32px;
  }
}
#about .about-list {
  display: flex;
  flex-wrap: wrap;
  gap: 2vw;
  text-align: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  #about .about-list {
    gap: 5vw;
  }
}
#about .about-list__item {
  position: relative;
  width: 46%;
  background-color: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  #about .about-list__item {
    width: 100%;
  }
}
#about .about-list__item a {
  display: block;
  padding: 1.5vw 2vw;
}
@media screen and (max-width: 767px) {
  #about .about-list__item a {
    padding: 1.5vw 2vw 8vw 2vw;
  }
}
#about .about-list__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 50px;
  height: 50px;
  background-color: #A41C20;
  border-radius: 10px 0 0 0;
  clip-path: polygon(0% 0, 100% 0, 0% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
  #about .about-list__item::before {
    width: 30px;
    height: 30px;
  }
}
#about .about-list__item::after {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0;
  right: 0;
  margin: auto;
  width: 20px;
  height: 20px;
  background-image: url(../img/recruit/common/under-arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  #about .about-list__item::after {
    bottom: 3px;
    width: 15px;
    height: 15px;
  }
}
#about .about-list__title {
  color: #A41C20;
  font-size: clamp(0.35rem, calc(0.2225728155rem + 0.5436893204vw), 0.9625rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #about .about-list__title {
    font-size: 14px;
  }
}
#about .about-list__text {
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #about .about-list__text {
    font-size: 16px;
  }
}

#appeal {
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  #appeal {
    overflow: hidden;
  }
}
#appeal::before {
  content: "";
  position: absolute;
  bottom: -34%;
  right: -46%;
  background-image: url(../img/recruit/top/top-appeal-bg.webp);
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  #appeal::before {
    width: 196vw;
    height: 427px;
    bottom: -10%;
    right: -69%;
  }
}
#appeal .inner {
  padding-bottom: 11vw;
}
@media screen and (max-width: 767px) {
  #appeal .inner {
    padding-bottom: 150px;
    padding-top: 50px;
  }
}
#appeal .flex-box {
  display: flex;
  align-items: flex-end;
  gap: 3vw;
  margin-bottom: 4vw;
}
#appeal .headline {
  margin-bottom: 0;
}
#appeal .appeal-text {
  width: 100%;
}
#appeal .appeal-img {
  display: flex;
  gap: 2vw;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img {
    flex-direction: column;
  }
}
#appeal .appeal-img-movie {
  cursor: pointer;
  position: relative;
  display: block;
  max-width: 841px;
  width: 100%;
  overflow: hidden;
  border-radius: 10px;
}
#appeal .appeal-img-movie:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-movie {
    height: 40vw;
  }
}
#appeal .appeal-img-movie iframe {
  width: 100%;
  height: 101%;
  transform: translate(-50%, -50%);
  position: absolute;
  left: 50%;
  top: 50%;
}
#appeal .appeal-img-movie_bg {
  background-image: url(../img/recruit/top/top-appeal-movie.webp);
  width: 100%;
  max-height: 473px;
  height: 26vw;
  border-radius: 10px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-movie_bg {
    top: 20px;
    height: 50vw;
  }
}
#appeal .appeal-img-movie_text {
  position: absolute;
  top: 76px;
  right: 0;
  left: 0;
  margin: auto;
  color: #fff;
  text-align: center;
  font-size: clamp(0.75rem, calc(0.4769417476rem + 1.1650485437vw), 2.0625rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-movie_text {
    top: 20px;
  }
}
#appeal .appeal-img-number {
  position: relative;
  display: block;
  max-width: 660px;
  width: 70%;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-number {
    width: 100%;
  }
}
#appeal .appeal-img-number_bg {
  background-image: url("../img/recruit/top/top-appeal-number.png");
  width: 100%;
  max-height: 473px;
  height: 26vw;
  border-radius: 10px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-number_bg {
    height: 40vw;
  }
}
#appeal .appeal-img-number_text {
  position: absolute;
  top: 10px;
  left: 30px;
  font-size: clamp(0.9rem, calc(0.5723300971rem + 1.3980582524vw), 2.475rem);
  font-weight: bold;
}
#appeal .appeal-img-number_more {
  position: absolute;
  bottom: 15px;
  right: 70px;
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-number_more {
    bottom: 10px;
    right: 45px;
  }
}
#appeal .appeal-img-number_more::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -45px;
  margin: auto;
  width: 30px;
  height: 8px;
  background-image: url(../img/recruit/common/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(2px);
}
@media screen and (max-width: 767px) {
  #appeal .appeal-img-number_more::after {
    width: 20px;
    height: 20px;
    right: -35px;
    transform: translateY(7px);
  }
}

#top-company {
  background-color: #EBF0F4;
}
@media screen and (max-width: 767px) {
  #top-company {
    overflow: hidden;
  }
}
#top-company::before {
  content: "";
  position: absolute;
  bottom: -32%;
  right: 29%;
  background-image: url(../img/recruit/top/top-compnay-bg.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  #top-company::before {
    width: 202vw;
    height: 100%;
    bottom: -42%;
    right: -19%;
  }
}
#top-company .inner {
  padding-bottom: 8vw;
}
#top-company .company-title {
  font-size: clamp(1.25rem, calc(0.7949029126rem + 1.9417475728vw), 3.4375rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #top-company .company-title {
    font-size: 23px;
  }
}
#top-company .company-text {
  margin-bottom: 20px;
}
#top-company .flex-box {
  display: flex;
  align-items: center;
  gap: 4vw;
  margin-bottom: 5vw;
}
@media screen and (max-width: 767px) {
  #top-company .flex-box {
    gap: 14vw;
  }
}
#top-company .text-wrap {
  width: 40%;
}
@media screen and (max-width: 767px) {
  #top-company .text-wrap {
    width: 100%;
    padding: 15px;
  }
}
#top-company .company-btn {
  position: relative;
  border-radius: 40px;
  background-color: #A41C20;
  color: #fff;
  padding: 0.7vw;
  display: block;
  width: 85%;
  padding-left: 1vw;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #top-company .company-btn {
    padding: 4vw;
    width: 90%;
    margin: 0 auto;
    padding-left: 15px;
    font-size: 14px;
  }
}
#top-company .company-btn::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url(../img/recruit/common/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(10px);
}
@media screen and (max-width: 767px) {
  #top-company .company-btn::after {
    width: 20px;
    height: 20px;
    right: 15px;
    transform: translateY(7px);
  }
}
#top-company .flex-box-item {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1vw;
  background-color: #fff;
  border-radius: 10px;
  padding-left: 3vw;
  width: 100%;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  #top-company .flex-box-item {
    flex-direction: column;
    margin-bottom: 30px;
  }
}
#top-company .company-flex-img {
  width: 50%;
  position: relative;
  top: -20px;
}
@media screen and (max-width: 767px) {
  #top-company .company-flex-img {
    width: 100%;
    top: 0;
  }
}
#top-company .btn-text {
  position: relative;
  color: #A41C20;
  font-size: clamp(0.4rem, calc(0.254368932rem + 0.6213592233vw), 1.1rem);
  font-weight: bold;
  display: block;
  margin: 0 auto;
  width: 36%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #top-company .btn-text {
    font-size: 15px;
    z-index: 0;
    width: 50%;
    left: -20px;
  }
}
#top-company .btn-text::after {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  right: -3vw;
  margin: auto;
  background-color: #A41C20;
  width: 3vw;
  height: 3vw;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  #top-company .btn-text::after {
    width: 30px;
    height: 30px;
    right: -20px;
  }
}
#top-company .btn-text::before {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  right: -2vw;
  margin: auto;
  width: 1vw;
  height: 1vw;
  background-image: url(../img/recruit/common/plus.png);
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #top-company .btn-text::before {
    width: 11px;
    height: 11px;
    right: -10px;
  }
}
#top-company .modal-wrap {
  width: 50%;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  #top-company .modal-wrap {
    width: 90%;
    margin-bottom: 50px;
  }
}
#top-company .modal-wrap:hover .btn-text::after {
  opacity: 0.7;
}
#top-company .modal-btn-img {
  position: relative;
  top: -20px;
}
@media screen and (max-width: 767px) {
  #top-company .modal-btn-img {
    top: 0;
    margin-bottom: 4vw;
  }
}
#top-company .company-img {
  position: relative;
  color: #fff;
  display: block;
}
#top-company .company-img_bg {
  background-image: url("../img/recruit/top/top-company-img.webp");
  width: 100%;
  max-height: 473px;
  height: 26vw;
  border-radius: 10px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (max-width: 767px) {
  #top-company .company-img_bg {
    height: 320px;
  }
}
#top-company .company-img_text {
  position: absolute;
  bottom: 10px;
  left: 30px;
  font-size: clamp(0.9rem, calc(0.5723300971rem + 1.3980582524vw), 2.475rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #top-company .company-img_text {
    font-size: 20px;
  }
}
#top-company .company-img_more {
  position: absolute;
  bottom: 25px;
  right: 100px;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #top-company .company-img_more {
    right: 40px;
    font-size: 0;
  }
}
#top-company .company-img_more::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -51px;
  margin: auto;
  width: 1.4vw;
  height: 0.4vw;
  background-image: url(../img/recruit/common/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  #top-company .company-img_more::after {
    width: 25px;
    height: 25px;
    transform: translateY(19px);
    right: -37px;
  }
}
#top-company .company-img_more::before {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  right: -60px;
  margin: auto;
  background-color: #A41C20;
  width: 2.5vw;
  height: 2.5vw;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  #top-company .company-img_more::before {
    width: 50px;
    height: 50px;
    right: -50px;
    top: auto;
    bottom: -35px;
  }
}
@media screen and (max-width: 767px) {
  #top-company .modal.is-active .modal__content {
    overflow-y: scroll;
    top: 5%;
  }
}
@media screen and (max-width: 767px) {
  #top-company .modal__close-btn::before {
    right: -12px;
  }
}
#top-company .modal__content {
  max-height: 82vh;
}
#top-company #modal .flex-item {
  display: flex;
  align-items: center;
  background-color: #fff;
  padding: 3vw;
}
@media screen and (max-width: 767px) {
  #top-company #modal .flex-item {
    flex-direction: column;
    gap: 1em;
    padding: 5vw;
    padding-top: 60px;
  }
}
#top-company #modal .headline-ja {
  position: relative;
  font-size: clamp(0.625rem, calc(0.3974514563rem + 0.9708737864vw), 1.71875rem);
  font-weight: bold;
  padding-left: 3vw;
  margin-bottom: 2vw;
}
@media screen and (max-width: 767px) {
  #top-company #modal .headline-ja {
    padding-left: 5vw;
    font-size: 18px;
    text-align: center;
  }
}
#top-company #modal .headline-ja::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url("../img/recruit/common/title-icon.png");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  #top-company #modal .headline-ja::before {
    width: 23px;
    height: 23px;
    right: 0;
    bottom: auto;
    top: -20px;
  }
}
#top-company #modal .logo-box {
  border-right: 1px solid #D7D8D8;
  margin-right: 1.5vw;
  padding-right: 1.5vw;
}
@media screen and (max-width: 767px) {
  #top-company #modal .logo-box {
    border-right: none;
    margin-right: 0;
    padding-right: 0;
    border-bottom: 1px solid #D7D8D8;
    padding-bottom: 50px;
    margin-bottom: 40px;
  }
}
#top-company #modal .logo-box, #top-company #modal .color-box {
  width: 50%;
}
@media screen and (max-width: 767px) {
  #top-company #modal .logo-box, #top-company #modal .color-box {
    width: 90%;
  }
}
#top-company #modal img {
  -o-object-fit: contain;
     object-fit: contain;
  max-height: 256px;
  height: 14vw;
  margin: 0 auto;
  width: 100%;
  margin-bottom: 2vw;
}
@media screen and (max-width: 767px) {
  #top-company #modal img {
    height: 35vw;
  }
}
#top-company #modal .modal-text span {
  color: #A41C20;
}
@media screen and (max-width: 767px) {
  #top-company #modal .color-box img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 30vw;
  }
}
@media screen and (max-width: 767px) {
  #top-company #modal .modal__close-btn {
    top: 83px;
    right: 15px;
  }
}

#job {
  background-color: #F5F8FA;
}
#job .inner {
  padding-bottom: 10vw;
}
#job .job-list {
  display: flex;
  justify-content: center;
  gap: 2vw;
}
@media screen and (max-width: 767px) {
  #job .job-list {
    flex-direction: column;
  }
}
#job .job-list span {
  position: absolute;
  top: 10px;
  left: 15px;
  color: #506986;
}
@media screen and (max-width: 767px) {
  #job .job-list span {
    top: 10px;
    left: 15px;
    font-size: 13px;
  }
}
#job .job-list-item {
  position: relative;
  width: 30%;
  padding: 2vw;
  padding-top: 5vw;
  background-color: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  #job .job-list-item {
    width: 90%;
    margin: 0 auto;
  }
}
#job .job-list-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 70px;
  height: 70px;
  background-color: #CDD7E3;
  border-radius: 10px 0 0 0;
  clip-path: polygon(0% 0, 100% 0, 0% 100%, 0 100%);
}
#job .job-list-item::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
}
#job .job-list-link {
  height: 100%;
  display: block;
  text-align: center;
}
#job .job-list-title {
  position: relative;
  font-size: clamp(0.7rem, calc(0.4451456311rem + 1.0873786408vw), 1.925rem);
  font-weight: bold;
  text-align: left;
}
@media screen and (max-width: 767px) {
  #job .job-list-title {
    font-size: 16px;
  }
}
#job .job-list-title::before {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  background-color: #A41C20;
  width: 60px;
  height: 60px;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  #job .job-list-title::before {
    width: 30px;
    height: 30px;
  }
}
#job .job-list-title::after {
  position: absolute;
  content: "";
  top: 43%;
  bottom: 0;
  right: 14px;
  width: 30px;
  height: 30px;
  margin: auto;
  background-image: url(../img/recruit/common/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  #job .job-list-title::after {
    top: 50%;
    right: 5px;
    width: 20px;
    height: 20px;
  }
}
#job .job-list-img {
  max-width: 235px;
  max-height: 160px;
  margin-bottom: 5vw;
}
@media screen and (max-width: 767px) {
  #job .job-list-img {
    max-width: 124px;
    max-height: 96px;
  }
}

#top-interview {
  background-color: #EBF0F4;
  padding: 0;
  margin: 0 auto !important;
}
#top-interview::before {
  content: "";
  position: absolute;
  bottom: 7%;
  right: -23%;
  background-image: url(../img/recruit/top/top-interview-bg.webp);
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  #top-interview::before {
    display: none;
  }
}
#top-interview .inner {
  padding-bottom: 10vw;
}
@media screen and (max-width: 767px) {
  #top-interview .inner {
    padding-bottom: 30vw;
  }
}
#top-interview .top_interview_wrp {
  padding-left: 0;
  margin-bottom: 0;
  margin: 0;
}
#top-interview .slick-list {
  overflow: visible;
}
@media screen and (max-width: 767px) {
  #top-interview .slick-list {
    overflow: hidden;
  }
}
#top-interview .top_interview_slide_txtbox {
  bottom: 5px;
}
#top-interview li a {
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
}
#top-interview .top-interview-textwrap {
  position: absolute;
  bottom: -65px;
  display: flex;
  gap: 1vw;
  align-items: center;
}
@media screen and (max-width: 767px) {
  #top-interview .top-interview-textwrap {
    bottom: -39px;
  }
}
#top-interview .top-interview-name {
  color: #A41C20;
  font-size: clamp(0.8rem, calc(0.5087378641rem + 1.2427184466vw), 2.2rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #top-interview .top-interview-name {
    font-size: 20px;
  }
}
#top-interview .top-interview-txt {
  font-size: clamp(0.4rem, calc(0.254368932rem + 0.6213592233vw), 1.1rem);
}
@media screen and (max-width: 767px) {
  #top-interview .top-interview-txt {
    font-size: 12px;
  }
}
#top-interview .top_interview_slide_wrap {
  margin: 0px -40px 0 -40px;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  #top-interview .top_interview_slide_wrap {
    margin: 0px -10px 0 -10px;
  }
}
#top-interview .slick-slide {
  margin: 0 40px 0 40px;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  #top-interview .slick-slide {
    margin: 0 10px 0 10px;
    min-height: 350px;
    margin-bottom: 2em;
  }
}
#top-interview .slick-slide a {
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  #top-interview .slick-slide a {
    min-height: 380px;
  }
}
#top-interview .top_interview_slide li .top_interview_slide_txtbox {
  left: 13px;
}
@media screen and (max-width: 767px) {
  #top-interview .top_interview_slide li .top_interview_slide_txtbox {
    left: 10px;
  }
}
@media screen and (max-width: 767px) {
  #top-interview .top_interview_slide_txtbox_txt02 {
    font-size: 16px;
  }
}
@media screen and (max-width: 767px) {
  #top-interview .slick-next {
    right: 10px;
  }
}
@media screen and (max-width: 767px) {
  #top-interview .slick-prev {
    left: -20px;
    z-index: 1;
  }
}
@media screen and (max-width: 767px) {
  #top-interview .slick-prev, #top-interview .slick-next {
    display: inline-block !important;
  }
  #top-interview .slick-prev::before, #top-interview .slick-next::before {
    color: rgba(0, 0, 0, 0.5);
    background-image: url(../img/recruit/top/interview-arrow-sp.png);
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    width: 50px;
    height: 50px;
    display: block;
  }
}
@media screen and (max-width: 767px) {
  #top-interview .slick-prev::before {
    transform: rotate(180deg);
  }
}

body.is-modal-active {
  overflow: hidden;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.4s, opacity 0.4s;
}
.modal.is-active {
  visibility: visible;
  opacity: 1;
}

.modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  cursor: pointer;
}

.modal__content {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  transform: scale(0.9);
  opacity: 0;
  transition: transform 0.4s, opacity 0.4s;
}
.modal.is-active .modal__content {
  transform: scale(1);
  opacity: 1;
  transition-delay: 0.1s;
}

.modal__close-btn {
  position: absolute;
  top: -10px;
  right: 0;
  width: 20px;
  height: 20px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 10;
}
.modal__close-btn::before {
  content: "";
  position: absolute;
  top: -11px;
  right: -13px;
  width: 45px;
  height: 45px;
  background-color: #B30000;
  border-radius: 50%;
}
.modal__close-btn span {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
}
.modal__close-btn span:nth-child(1) {
  transform: rotate(45deg);
}
.modal__close-btn span:nth-child(2) {
  transform: rotate(-45deg);
}

/* ===============================================
// Philosophy Section
// =============================================== */
.under-company {
  background-color: #F5F8FA;
  padding-bottom: 10vw;
  /* ===============================================
  // Business Section
  // =============================================== */
}
.under-company #un-company {
  background-image: url("../img/recruit/company/company-mv.jpg");
}
.under-company .philosophy h2::after {
  background-image: url("../img/recruit/company/Philosophy.png");
}
.under-company .philosophy__title {
  font-size: clamp(0.75rem, calc(0.4769417476rem + 1.1650485437vw), 2.0625rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__title {
    font-size: 18px;
    text-align: center;
  }
}
.under-company .philosophy__value-item .philosophy__value-title {
  position: relative;
  font-size: clamp(0.75rem, calc(0.4769417476rem + 1.1650485437vw), 2.0625rem);
  font-weight: bold;
  margin-left: 1em;
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__value-item .philosophy__value-title {
    font-size: 22px;
  }
}
.under-company .philosophy__value-item .philosophy__value-title::before {
  content: "➊";
  position: absolute;
  top: 21%;
  left: -22px;
  margin: auto;
  color: #A41C20;
  font-size: 0.7em;
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__value-item .philosophy__value-title::before {
    top: 3%;
    left: -24px;
    font-size: 1em;
  }
}
.under-company .philosophy__value-item:nth-of-type(2) .philosophy__value-title::before {
  content: "➋";
}
.under-company .philosophy__value-item:nth-of-type(3) .philosophy__value-title::before {
  content: "➌";
}
.under-company .philosophy__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.under-company .philosophy__item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2em;
  border-radius: 10px;
  background-color: #fff;
  position: relative;
  overflow: hidden;
}
.under-company .philosophy__item:not(:last-child) {
  margin-bottom: 2em;
}
.under-company .philosophy__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 50px;
  height: 50px;
  background-color: #A41C20;
  border-radius: 10px 0 0 0;
  clip-path: polygon(0% 0, 100% 0, 0% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__item::before {
    width: 30px;
    height: 30px;
  }
}
.under-company .philosophy__item--mission::before {
  background: transparent linear-gradient(180deg, #8ED3D2 0%, #B7DAD6 100%) 0% 0% no-repeat padding-box;
}
.under-company .philosophy__item--vision::before {
  background: transparent linear-gradient(180deg, #90CCD5 0%, #B5B6EE 58%, #C2C3F0 100%) 0% 0% no-repeat padding-box;
}
.under-company .philosophy__item--value::before {
  background: transparent linear-gradient(180deg, #C1272D 0%, #D78062 100%) 0% 0% no-repeat padding-box;
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__item {
    flex-direction: column;
    padding: 1.5em;
    align-items: flex-start;
  }
}
.under-company .philosophy__term-wrapper {
  flex-shrink: 0;
  width: 20%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__term-wrapper {
    width: 100%;
    margin-bottom: 1em;
  }
}
.under-company .philosophy__term {
  font-size: 1.8rem;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  margin: 0;
  line-height: normal;
}
.under-company .philosophy__sub-term {
  font-size: 0.9rem;
  color: #757575;
  margin: 0;
  font-weight: bold;
}
.under-company .philosophy__content {
  flex: 1;
  padding-left: 2em;
  border-left: 1px solid #DBE6ED;
  margin-left: 2em;
}
@media screen and (max-width: 767px) {
  .under-company .philosophy__content {
    padding-left: 0;
    border-left: none;
    margin-left: 0;
    border-top: 1px solid #DBE6ED;
    padding-top: 20px;
  }
}
.under-company .business {
  position: relative;
}
.under-company .business h2::after {
  background-image: url("../img/recruit/company/Business.png");
}
.under-company .business__feature-list {
  list-style: none;
  padding: 0;
  margin-top: 4em;
}
.under-company .feature-section {
  display: flex;
  align-items: center;
  gap: 4em;
  text-align: left;
  padding-top: 4vw;
  border-top: 1px solid #DBE6ED;
}
.under-company .feature-section:not(:last-child) {
  margin-bottom: 6em;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section {
    flex-direction: column;
    gap: 2em;
    margin-bottom: 4em;
  }
}
.under-company .feature-section__content {
  flex: 1;
  position: relative;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__content {
    order: 2;
  }
}
.under-company .feature-section__image-wrapper {
  flex-basis: 26%;
  flex-shrink: 0;
}
.under-company .feature-section__image-wrapper p, .under-company .feature-section__image-wrapper img {
  margin: 0;
  display: block;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__image-wrapper {
    order: 1;
    flex-basis: auto;
    width: 60%;
    margin: 0 auto;
  }
}
.under-company .feature-section__number {
  position: absolute;
  top: -8vw;
  font-size: clamp(2.825rem, calc(1.7964805825rem + 4.3883495146vw), 7.76875rem);
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
  color: #E4EEF5;
  margin: 0;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__number {
    position: static;
    margin-bottom: -0.9em;
    text-align: left;
    font-size: 80px;
  }
}
.under-company .feature-section__title {
  font-size: clamp(0.75rem, calc(0.4769417476rem + 1.1650485437vw), 2.0625rem);
  font-weight: bold;
  margin-top: -0.5em;
  margin-bottom: 1em;
  z-index: 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__title {
    font-size: 22px;
    margin-top: 0;
  }
}
.under-company .feature-section__description {
  line-height: 1.8;
  margin-bottom: 2em;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__description {
    line-height: 28px;
  }
}
.under-company .feature-section__examples {
  padding: 2vw;
  -moz-columns: 3;
       columns: 3;
  background-color: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__examples {
    -moz-columns: 1;
         columns: 1;
    padding: 1.5em;
  }
}
.under-company .feature-section__example-item {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 0.5em;
  font-size: clamp(0.4rem, calc(0.254368932rem + 0.6213592233vw), 1.1rem);
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__example-item {
    font-size: 16px;
    font-weight: bold;
  }
}
.under-company .feature-section__example-item::before {
  content: "";
  position: absolute;
  top: 0.5em;
  left: 0.5em;
  width: 10px;
  height: 10px;
  background-image: url("../img/recruit/common/arrow-tri.png");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .under-company .feature-section__example-item::before {
    width: 12px;
    height: 14px;
  }
}

.under-appeal {
  background-color: #F5F8FA;
  padding-bottom: 10vw;
  /* ===============================================
  // Data Infographics Section
  // =============================================== */
  /* --- Stat Card Component --- */
  /* --- Tech Stack Component --- */
  /* --- Company Charm Component --- */
}
.under-appeal #un-appeal {
  background-image: url("../img/recruit/appeal/appeal-mv.jpg");
}
.under-appeal h2::after {
  background-image: url("../img/recruit/appeal/book.png");
}
.under-appeal .data-infographics {
  /* ... */
}
.under-appeal .data-infographics__intro {
  margin-bottom: 5vw;
}
.under-appeal .card {
  position: relative;
  background-color: #fff;
  padding: 2vw 4vw;
  height: 100%;
  padding-top: 5vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .card {
    padding: 12vw 4vw;
    padding-top: 30vw;
  }
}
.under-appeal .card__heading {
  position: absolute;
  top: 1vw;
  left: 0;
  background-color: #A41C20;
  padding: 0.5vw 2vw;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .under-appeal .card__heading {
    font-size: 20px;
    padding: 3px 25px;
    top: 8vw;
  }
}
.under-appeal .item01 {
  text-align: left;
}
.under-appeal .item01 img {
  max-height: 400px;
  margin: 0 auto;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  height: 23vw;
  margin-bottom: 3vw;
  margin-top: 2vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item01 img {
    height: 50vw;
  }
}
.under-appeal .item02 {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .item02 {
    text-align: left;
  }
}
.under-appeal .item02 img {
  margin-bottom: 1vw;
  margin-top: 2vw;
}
.under-appeal .item03 {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .item03 {
    text-align: left;
  }
}
@media screen and (max-width: 767px) {
  .under-appeal .item03 .card {
    padding: 12vw 0;
  }
}
@media screen and (max-width: 767px) {
  .under-appeal .item03 .stat-card__description {
    padding: 0 4vw;
  }
}
.under-appeal .item03 img {
  max-height: 500px;
  margin: 0 auto;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  height: 25vw;
  margin-bottom: 3vw;
  margin-top: 2vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item03 img {
    height: 120vw;
  }
}
@media screen and (max-width: 767px) {
  .under-appeal .item10 img {
    height: 90vw !important;
  }
}
.under-appeal .item04, .under-appeal .item09 {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .item04, .under-appeal .item09 {
    text-align: left;
  }
}
.under-appeal .item04 img, .under-appeal .item09 img {
  max-height: 400px;
  margin: 0 auto;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  height: 21vw;
  margin-bottom: 3vw;
  margin-top: 2vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item04 img, .under-appeal .item09 img {
    height: 200vw;
    max-height: 100%;
  }
}
.under-appeal .item05 img {
  max-height: 400px;
  margin: 0 auto;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  height: 21vw;
  margin-bottom: 3vw;
  margin-top: 2vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item05 img {
    height: 170vw;
    max-height: 100%;
  }
}
.under-appeal .item06 {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .item06 {
    text-align: left;
  }
}
.under-appeal .item06 .card {
  background-color: transparent;
  padding-top: 0;
}
.under-appeal .item06 img {
  max-height: 500px;
  height: 26vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item06 img {
    height: 92vw;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
.under-appeal .item07 img {
  max-height: 541px;
  height: 26vw;
  margin: 0 auto;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  margin-bottom: 2vw;
  margin-top: 2vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item07 img {
    height: 50vw;
  }
}
.under-appeal .item08 {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .item08 {
    text-align: left;
  }
}
.under-appeal .item08 img {
  max-height: 400px;
  height: 21vw;
  margin: 0 auto;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  margin-bottom: 2vw;
  margin-top: 2vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .item08 img {
    height: 80vw;
  }
}
.under-appeal .data-infographics__grid {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2em;
}
@media screen and (max-width: 767px) {
  .under-appeal .data-infographics__grid {
    grid-template-columns: 1fr;
  }
}
.under-appeal .data-infographics__grid-item--full-width {
  grid-column: 1/-1;
}
.under-appeal .stat-card {
  list-style: none;
  padding: 2em;
  margin: 0;
  background-color: #f5f5f5;
  border-radius: 8px;
  text-align: center;
}
.under-appeal .tech-stack {
  list-style: none;
  padding: 2em;
  margin: 0;
}
.under-appeal .tech-stack__heading {
  font-size: 2rem;
  font-weight: bold;
  margin-top: 0;
  text-align: center;
}
.under-appeal .tech-stack__lead-list, .under-appeal .tech-stack__grid-item {
  list-style: none;
  padding: 2em;
  margin: 1em 0;
  background-color: #F5F8FA;
  border-radius: 10px;
}
.under-appeal .tech-stack__lead-title {
  font-size: clamp(0.85rem, calc(0.5405339806rem + 1.3203883495vw), 2.3375rem);
  font-weight: bold;
  color: #C1272D;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .tech-stack__lead-title {
    font-size: 24px;
    font-weight: 900;
  }
}
.under-appeal .tech-stack__grid {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2em;
}
@media screen and (max-width: 767px) {
  .under-appeal .tech-stack__grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.under-appeal .tech-stack__item-title {
  font-weight: bold;
  font-size: clamp(0.85rem, calc(0.5405339806rem + 1.3203883495vw), 2.3375rem);
  color: #C1272D;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .tech-stack__item-title {
    font-size: 24px;
    font-weight: 900;
  }
}
.under-appeal .tech-stack__footer {
  text-align: center;
  margin-top: 2em;
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
}
@media screen and (max-width: 767px) {
  .under-appeal .tech-stack__footer {
    font-size: 17px;
  }
}
.under-appeal .company-charm {
  list-style: none;
  padding: 2em;
  margin: 0;
}
.under-appeal .company-charm__main-item {
  display: flex;
  align-items: center;
  margin-top: 1vw;
}
@media screen and (max-width: 767px) {
  .under-appeal .company-charm__main-item {
    flex-direction: column;
  }
}
.under-appeal .company-charm__main-item img {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .under-appeal .company-charm__main-item img {
    width: 95%;
    margin-top: 15vw;
  }
}
.under-appeal .company-charm__heading {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  margin-top: 0;
  margin-bottom: 2em;
}
.under-appeal .company-charm__ranked-list {
  list-style: none;
  padding: 0;
  margin: 0 auto 2em;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 2em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-appeal .company-charm__ranked-list {
    align-items: center;
    flex-direction: column;
  }
}
.under-appeal .company-charm__rank {
  font-weight: bold;
  font-size: 1.5rem;
}
.under-appeal .company-charm__label {
  font-weight: bold;
}
.under-appeal .company-charm__description {
  margin: 0 auto;
  padding: 2em;
  border-radius: 8px;
  line-height: 1.8;
}
.under-appeal .company-charm__description a {
  color: #A41C20;
  text-decoration: underline;
}

/* ===============================================
// Philosophy Section
// =============================================== */
.under-field {
  background-color: #F5F8FA;
  padding-bottom: 10vw;
}
.under-field #un-field {
  background-image: url("../img/recruit/field/field-mv.jpg");
}
.under-field h2 {
  position: relative;
  font-size: clamp(1.05rem, calc(0.6677184466rem + 1.6310679612vw), 2.8875rem);
  font-weight: bold;
  padding-left: 40px;
  margin-bottom: 4vw;
  z-index: 0;
}
.under-field h2::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url("../img/recruit/common/title-icon.png");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .under-field h2::before {
    width: 15px;
    height: 15px;
  }
}
.under-field h2::after {
  content: "";
  position: absolute;
  width: 100%;
  max-height: 200px;
  height: 12vw;
  top: -8vw;
  left: -9vw;
  background-image: url("../img/recruit/appeal/Business-f.png");
  background-repeat: no-repeat;
  background-size: contain;
  z-index: -1;
}
.under-field .field-map {
  position: relative;
}
.under-field .field-map span {
  position: absolute;
}
.under-field .field-map span img {
  width: 6vw;
}
.under-field #field01 {
  top: 19vw;
  left: 10vw;
}
.under-field #field02 {
  top: 15vw;
  left: 47vw;
}
.under-field #field03 {
  top: 11vw;
  right: 21vw;
}
.under-field #field04 {
  top: 36vw;
  left: 32vw;
}
.under-field #field05 {
  top: 24vw;
  right: 9vw;
}
.under-field #field06 {
  top: 56vw;
  left: 17vw;
}
.under-field #field07 {
  top: 46vw;
  left: 48vw;
}
.under-field #field08 {
  top: 49vw;
  right: 19vw;
}
.under-field .modal__inner {
  position: relative;
}
.under-field .modal-title {
  position: absolute;
  top: 2vw;
  left: 0;
  background-color: #fff;
  color: #A41C20;
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
  padding: 0.5vw 2vw;
}
@media screen and (max-width: 767px) {
  .under-field .modal-title {
    font-size: 20px;
    padding: 0.5vw 8vw;
    top: 5vw;
  }
}
.under-field .flex-item {
  display: flex;
  min-height: 380px;
}
@media screen and (max-width: 767px) {
  .under-field .flex-item {
    flex-direction: column;
  }
}
.under-field .modal-left {
  width: 32%;
  background-color: #A41C20;
  border-radius: 10px 0px 0px 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  color: #fff;
  padding: 7vw 0;
}
@media screen and (max-width: 767px) {
  .under-field .modal-left {
    text-align: center;
    width: 100%;
    border-radius: 10px 10px 0px 0px;
    padding-top: 100px;
  }
}
.under-field .modal-left img {
  width: 80%;
  max-height: 300px;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 767px) {
  .under-field .modal-left img {
    width: 50%;
  }
}
.under-field .modal-left .left-title {
  font-size: clamp(1.05rem, calc(0.6677184466rem + 1.6310679612vw), 2.8875rem);
}
@media screen and (max-width: 767px) {
  .under-field .modal-left .left-title {
    font-size: 28px;
  }
}
.under-field .modal-left .left-text {
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  opacity: 0.4;
}
@media screen and (max-width: 767px) {
  .under-field .modal-left .left-text {
    font-size: 16px;
    line-height: 20px;
  }
}
.under-field .modal-right {
  width: 70%;
  background-color: #fff;
  border-radius: 0px 10px 10px 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  .under-field .modal-right {
    width: 100%;
    border-radius: 0 0 10px 10px;
    padding-bottom: 60px;
  }
}
.under-field .modal-right ul {
  display: flex;
  flex-wrap: wrap;
  padding: 3vw;
  gap: 2vw;
}
@media screen and (max-width: 767px) {
  .under-field .modal-right ul {
    flex-direction: column;
  }
}
.under-field .modal-right ul li {
  width: 47%;
  display: flex;
  align-items: center;
  gap: 1vw;
}
@media screen and (max-width: 767px) {
  .under-field .modal-right ul li {
    width: 90%;
    gap: 18px;
  }
}
.under-field .modal-right ul li img {
  width: 35%;
  max-width: 170px;
}
@media screen and (max-width: 767px) {
  .under-field .modal-right ul li img {
    width: 27%;
  }
}
.under-field .modal-right ul li p {
  font-size: clamp(0.4rem, calc(0.254368932rem + 0.6213592233vw), 1.1rem);
}
@media screen and (max-width: 767px) {
  .under-field .modal-right ul li p {
    font-size: 14px;
    line-height: 23px;
  }
}
.under-field .modal-right ul li p span {
  border-bottom: 1px solid #333;
  display: block;
  color: #A41C20;
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .under-field .modal-right ul li p span {
    font-size: 16px;
    line-height: 32px;
  }
}
.under-field .field02 ul, .under-field .field03 ul, .under-field .field04 ul, .under-field .field07 ul {
  justify-content: center;
}
.under-field .field02 ul li, .under-field .field03 ul li, .under-field .field04 ul li, .under-field .field07 ul li {
  width: 75%;
}
.under-field .field-wrap .field-list {
  max-width: 1920px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 9vw;
  padding-right: 9vw;
  padding-top: 3vw;
  display: flex;
  gap: 1vw;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .under-field .field-wrap .field-list {
    padding-bottom: 10vw;
    flex-wrap: wrap;
    justify-content: left;
    gap: 15px;
  }
}
@media screen and (max-width: 767px) {
  .under-field .field-wrap .modal-btn {
    width: 30%;
  }
}
.under-field .field-wrap .modal-title {
  position: relative;
  top: 0;
  background-color: #A41C20;
  color: #fff;
  font-size: clamp(0.3rem, calc(0.190776699rem + 0.4660194175vw), 0.825rem);
  text-align: center;
  width: 37%;
  padding: 0;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .under-field .field-wrap .modal-title {
    font-size: 12px;
  }
}
.under-field .field-wrap .modal-sub-title {
  font-size: clamp(0.6rem, calc(0.3815533981rem + 0.932038835vw), 1.65rem);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-field .field-wrap .modal-sub-title {
    font-size: 20px;
  }
}
.under-field .field-wrap .modal-en {
  font-size: clamp(0.3rem, calc(0.190776699rem + 0.4660194175vw), 0.825rem);
  text-align: center;
  color: #A41C20;
  border-bottom: #333 1px solid;
  padding-bottom: 0.5vw;
  margin-bottom: 0.5vw;
}
@media screen and (max-width: 767px) {
  .under-field .field-wrap .modal-en {
    font-size: 12px;
  }
}
.under-field .field-wrap .modal-text {
  text-align: left;
}
.under-field .field-wrap {
  position: relative;
}
.under-field .field-list {
  display: flex;
  justify-content: center;
  gap: 20px;
  list-style: none;
  padding: 0;
}
.under-field .modal-btn {
  cursor: pointer;
  transition: opacity 0.4s, transform 0.4s;
}
.under-field .modal-btn:hover {
  transform: translateY(-5px);
}
.under-field .field-wrap.is-popover-open .modal-btn {
  opacity: 0.5;
}
.under-field .field-wrap.is-popover-open .modal-btn.is-active {
  opacity: 1;
  transform: translateY(-10px);
}
.under-field .popover {
  position: absolute;
  bottom: 100%;
  left: 50%;
  z-index: 10;
  margin-bottom: 20px;
  visibility: hidden;
  opacity: 0;
  transform: translate(-50%, 10px);
  transition: opacity 0.4s, visibility 0.4s, transform 0.4s;
}
.under-field .popover.is-active {
  visibility: visible;
  opacity: 1;
  transform: translate(-50%, 0);
}
@media screen and (max-width: 767px) {
  .under-field .popover {
    bottom: auto;
    top: -33vh;
    left: 50%;
    margin-bottom: 0;
    transform: translate(-50%, -10px);
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .under-field .popover {
    top: -45%;
  }
}
@media screen and (max-width: 767px) {
  .under-field .popover.is-active {
    transform: translate(-50%, 0);
  }
}
.under-field .popover__inner {
  position: relative;
  background-color: #fff;
  padding: 20px;
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  width: 280px;
}
.under-field .popover__inner::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #fff transparent transparent transparent;
}
@media screen and (max-width: 767px) {
  .under-field .popover__inner::after {
    display: none;
  }
}
.under-field .popover__close-btn {
  position: absolute;
  top: -14px;
  right: -10px;
  width: 30px;
  height: 30px;
  background-color: #A41C20;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  transition: opacity 0.3s;
  z-index: 5;
}
.under-field .popover__close-btn:hover {
  opacity: 1;
}
.under-field .popover__close-btn::before, .under-field .popover__close-btn::after {
  content: "";
  position: absolute;
  top: 44%;
  left: 6px;
  width: 60%;
  height: 2px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .under-field .popover__close-btn::before, .under-field .popover__close-btn::after {
    top: 48%;
  }
}
.under-field .popover__close-btn::before {
  transform: rotate(45deg);
}
.under-field .popover__close-btn::after {
  transform: rotate(-45deg);
}
.under-field .modal__content {
  max-height: 82vh;
}
@media screen and (max-width: 767px) {
  .under-field .modal.is-active .modal__content {
    overflow-y: scroll;
    top: 6%;
  }
}
@media screen and (max-width: 767px) {
  .under-field .modal__close-btn {
    top: 100px;
    right: 0px;
  }
}
@media screen and (max-width: 767px) {
  .under-field .modal__close-btn::before {
    background-color: transparent;
  }
}
.under-field .modal-content-box {
  display: flex;
}

/* ===============================================
// Philosophy Section
// =============================================== */
.under-environment {
  background-color: #F5F8FA;
  /* ===============================================
  // Component: Training Plan
  // =============================================== */
  /* ===============================================
  // Component: Training Card
  // =============================================== */
  /* ===============================================
  // Component: Simple Slider
  // =============================================== */
}
.under-environment #un-environment {
  background-image: url("../img/recruit/environment/environment-mv.jpg");
}
.under-environment #un-environment p {
  margin-bottom: 0;
}
.under-environment h2::after {
  background-image: url("../img/recruit/environment/Development.png");
}
.under-environment p {
  margin-bottom: 3vw;
}
@media screen and (max-width: 767px) {
  .under-environment .development {
    margin-bottom: 100px;
  }
}
.under-environment .training-plan__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
@media screen and (max-width: 767px) {
  .under-environment .training-plan__list {
    grid-template-columns: 1fr;
  }
}
.under-environment .training-card {
  display: flex;
  flex-direction: column;
  background-color: #fff;
  border: 1px solid #f0f0f0;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.07);
  border-radius: 16px;
  padding: 2em;
  text-align: center;
}
.under-environment .training-card__header {
  min-height: 4.5em;
}
.under-environment .training-card__title {
  font-size: 1.5rem;
  font-weight: bold;
  margin: 0;
  color: #A41C20;
}
.under-environment .training-card__subtitle {
  font-size: 0.9rem;
  color: #A41C20;
  margin-top: 0.5em;
  margin-bottom: 0;
}
.under-environment .training-card__figure {
  margin: 2em 0;
}
@media screen and (max-width: 767px) {
  .under-environment .training-card__figure {
    border-bottom: 1px solid #DBE6ED;
    padding-bottom: 2em;
  }
}
.under-environment .training-card__figure img {
  max-height: 150px;
  width: auto;
}
.under-environment .training-card__menu {
  list-style: none;
  padding: 0;
  margin: 0 0 2em;
  -moz-columns: 2;
       columns: 2;
  gap: 2vw;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .under-environment .training-card__menu {
    -moz-columns: 1;
         columns: 1;
    margin-bottom: 1em;
    border-bottom: 1px solid #DBE6ED;
    padding-bottom: 2em;
  }
}
.under-environment .training-card__menu .other {
  width: 140%;
}
@media screen and (max-width: 767px) {
  .under-environment .training-card__menu .other {
    width: 100%;
  }
}
.under-environment .training-card__menu-item {
  position: relative;
  padding-left: 1.2em;
  font-size: clamp(0.35rem, calc(0.2225728155rem + 0.5436893204vw), 0.9625rem);
  width: 120%;
}
@media screen and (max-width: 767px) {
  .under-environment .training-card__menu-item {
    font-size: clamp(0.75rem, calc(0.4769417476rem + 1.1650485437vw), 2.0625rem);
    width: 100%;
  }
}
.under-environment .training-card__menu-item:not(:last-child) {
  margin-bottom: 0.8em;
}
.under-environment .training-card__menu-item::after {
  content: "";
  position: absolute;
  background-image: url(../img/recruit/common/arrow-icon.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 0.9vw;
  height: 0.5vw;
  margin: auto;
  left: 0;
  bottom: 0;
  top: 0;
  transform: rotate(-90deg);
}
@media screen and (max-width: 767px) {
  .under-environment .training-card__menu-item::after {
    width: 16px;
    height: 8px;
    margin: auto;
  }
}
.under-environment .training-card__description {
  margin-top: auto;
  padding-top: 2em;
  text-align: left;
  line-height: 1.8;
  color: #555;
}
@media screen and (max-width: 767px) {
  .under-environment .career {
    margin-bottom: 50px;
  }
}
.under-environment .career h2::after {
  background-image: url("../img/recruit/environment/career.png");
}
.under-environment .career .inner {
  padding-bottom: 7vw;
}
.under-environment .career .flex-box {
  display: flex;
  gap: 5vw;
}
@media screen and (max-width: 767px) {
  .under-environment .career .flex-box {
    flex-direction: column;
  }
}
.under-environment .career .career-text-box {
  flex: 1;
}
.under-environment .career .career-img-box {
  flex: 1;
}
.under-environment .career .career-link {
  position: relative;
  display: block;
}
.under-environment .career .career-link span {
  position: relative;
  background-color: #A41C20;
  color: #fff;
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
  padding: 20px;
  width: 75%;
  display: block;
  top: -35px;
}
@media screen and (max-width: 767px) {
  .under-environment .career .career-link span {
    padding: 10px;
    width: 90%;
    display: block;
    top: -20px;
    font-size: 14px;
  }
}
.under-environment .career .career-link span::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 50px;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url(../img/recruit/common/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(10px);
}
@media screen and (max-width: 767px) {
  .under-environment .career .career-link span::after {
    width: 20px;
    height: 20px;
    right: 15px;
    transform: translateY(7px);
  }
}
.under-environment .career .career-text {
  text-align: right;
  font-weight: 400;
}
.under-environment .slidearea {
  background-color: #fff;
}
.under-environment .slidearea .slidearea-title {
  background-color: #96A3B4;
  border-radius: 10px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  color: #fff;
  font-size: clamp(0.65rem, calc(0.4133495146rem + 1.0097087379vw), 1.7875rem);
  font-weight: bold;
  transform: translateY(-23px);
}
@media screen and (max-width: 767px) {
  .under-environment .slidearea .slidearea-title {
    font-size: 17px;
    transform: translateY(0px);
    width: 90%;
    padding: 5px 0;
  }
}
.under-environment .simple-slider {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: 2em auto;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  align-items: stretch;
}
.under-environment .simple-slider .swiper-slide img {
  width: 100%;
  max-height: 473px;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 767px) {
  .under-environment .simple-slider .swiper-slide img {
    max-height: 100%;
  }
}
.under-environment .simple-slider .swiper-button-prev,
.under-environment .simple-slider .swiper-button-next {
  color: #A41C20;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  transition: background-color 0.3s;
  bottom: -1%;
  top: auto;
}
@media screen and (max-width: 767px) {
  .under-environment .simple-slider .swiper-button-prev,
  .under-environment .simple-slider .swiper-button-next {
    bottom: auto;
    top: 50%;
  }
}
.under-environment .simple-slider .swiper-button-prev::after,
.under-environment .simple-slider .swiper-button-next::after {
  font-size: 1.2rem;
}
.under-environment .simple-slider .swiper-button-prev {
  left: 43%;
  right: auto;
}
@media screen and (max-width: 767px) {
  .under-environment .simple-slider .swiper-button-prev {
    left: 0;
  }
}
.under-environment .simple-slider .swiper-button-next {
  right: 43%;
  left: auto;
}
@media screen and (max-width: 767px) {
  .under-environment .simple-slider .swiper-button-next {
    right: 0;
  }
}
.under-environment .simple-slider .swiper-pagination-bullet {
  background-color: #DFE8EF;
  opacity: 0.7;
  transition: background-color 0.3s, opacity 0.3s;
}
.under-environment .simple-slider .swiper-pagination-bullet-active {
  background-color: #C1272D;
  opacity: 1;
}
.under-environment .env h2::after {
  background-image: url("../img/recruit/environment/environment.png");
}
.under-environment .env .env-box {
  position: relative;
  display: flex;
  background-color: #fff;
  padding: 3vw;
  margin-bottom: 2vw;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box {
    flex-direction: column;
    padding: 6vw;
    margin-bottom: 20px;
  }
}
.under-environment .env .env-box::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 70px;
  height: 70px;
  background-color: #CDD7E3;
  border-radius: 10px 0 0 0;
  clip-path: polygon(0% 0, 100% 0, 0% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box::after {
    width: 40px;
    height: 40px;
  }
}
.under-environment .env .env-box .env-img {
  position: absolute;
  right: 50px;
  top: -22px;
  max-height: 300px;
  height: 11vw;
  max-width: 286px;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box .env-img {
    position: relative;
    height: 41vw;
    right: 0;
    top: 0;
  }
}
.under-environment .env .env-box .item01 {
  top: 120px;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box .item01 {
    top: 0;
  }
}
.under-environment .env span {
  position: absolute;
  top: 5px;
  left: 15px;
  color: #506986;
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .under-environment .env span {
    font-size: 11px;
    top: 5px;
    left: 8px;
  }
}
.under-environment .env p {
  margin-bottom: 0;
}
.under-environment .env .env-textarea {
  width: 70%;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-textarea {
    width: 100%;
  }
}
.under-environment .env .env-title {
  font-size: clamp(0.65rem, calc(0.4133495146rem + 1.0097087379vw), 1.7875rem);
  margin-bottom: 1vw;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-title {
    font-size: 20px;
    text-align: center;
    margin-bottom: 30px;
  }
}
.under-environment .env .env-text-red {
  margin-top: 2vw;
  color: #A41C20;
}
.under-environment .env .env-list {
  display: flex;
  gap: 2vw;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-list {
    flex-direction: column;
  }
}
.under-environment .env .env-list .right {
  width: 75%;
  display: flex;
  gap: 2vw;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-list .right {
    width: 100%;
    flex-direction: column;
  }
}
.under-environment .env .env-box-line {
  text-align: center;
  position: relative;
  background-color: #fff;
  padding: 1vw;
  margin-bottom: 2vw;
  width: 25%;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line {
    width: 100%;
    padding: 5vw;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.under-environment .env .env-box-line::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 70px;
  height: 70px;
  background-color: #CDD7E3;
  border-radius: 10px 0 0 0;
  clip-path: polygon(0% 0, 100% 0, 0% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line::after {
    width: 40px;
    height: 40px;
  }
}
.under-environment .env .env-box-line .env-box-wrap {
  width: 40%;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line .env-box-wrap {
    width: 100%;
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line .env-text-box p {
    font-size: 12px;
  }
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line .env-text-box .env-title {
    width: 100%;
  }
}
.under-environment .env .env-box-line img {
  max-height: 300px;
  height: 7vw;
  max-width: 286px;
  -o-object-fit: contain;
  object-fit: contain;
  margin-bottom: 1vw;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line img {
    height: 20vw;
    width: 50%;
  }
}
.under-environment .env .env-box-line .env-title {
  font-size: clamp(0.55rem, calc(0.3497572816rem + 0.854368932vw), 1.5125rem);
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line .env-title {
    font-size: 19px;
    width: 50%;
  }
}
.under-environment .env .env-box-line ul {
  display: flex;
  flex-wrap: wrap;
}
.under-environment .env .env-box-line ul li {
  width: 50%;
  display: flex;
  align-items: center;
  gap: 1vw;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line ul li {
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line ul li h3 {
    font-size: 13px;
  }
}
.under-environment .env .env-box-line ul li img {
  height: 5vw;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .under-environment .env .env-box-line ul li img {
    height: 21vw;
  }
}
.under-environment .more {
  background-color: #DFE9EF;
  padding-bottom: 5vw;
}
.under-environment .more .career-link {
  position: relative;
  display: block;
}
.under-environment .more .career-link span {
  position: relative;
  background-color: #A41C20;
  color: #fff;
  font-size: clamp(0.5rem, calc(0.317961165rem + 0.7766990291vw), 1.375rem);
  font-weight: bold;
  padding: 20px;
  width: 50%;
  display: block;
  top: -35px;
}
@media screen and (max-width: 767px) {
  .under-environment .more .career-link span {
    font-size: 14px;
    padding: 10px;
    width: 90%;
    display: block;
    top: -20px;
  }
}
.under-environment .more .career-link span::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 50px;
  margin: auto;
  width: 30px;
  height: 30px;
  background-image: url(../img/recruit/common/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(10px);
}
@media screen and (max-width: 767px) {
  .under-environment .more .career-link span::after {
    width: 20px;
    height: 20px;
    right: 10px;
    transform: translateY(7px);
  }
}
.under-environment .more img {
  width: 100%;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .under-environment .more img {
    height: 170px;
    -o-object-fit: cover;
       object-fit: cover;
  }
}/*# sourceMappingURL=style.css.map */