@charset "UTF-8";
/*変数設定用*/
img {
  max-width: 100%;
  height: auto;
  width: auto;
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}

li {
  list-style: none;
}

a {
  color: #666666;
  text-decoration: none;
}
a:hover {
  opacity: 0.7;
}
a:hover p:hover {
  opacity: 0.7;
}
a:hover img:hover {
  opacity: 0.7;
}

html {
  font-size: 0.5263157895vw;
  overflow-x: hidden;
}
@media (min-width: 768px) and (max-width: 999px) {
  html {
    font-size: 1vw;
  }
}
@media (max-width: 767px) {
  html {
    font-size: 1.3333333333vw;
  }
}
@media (min-width: 1001px) {
  html {
    font-size: 10px;
  }
}
html.is-fixed {
  height: 100%;
  overflow: hidden;
}
html.is-fixed body {
  height: 100%;
  overflow: hidden;
}

body {
  width: 100%;
  color: #000;
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", Osaka, Helvetica, Arial, sans-serif;
  overflow: visible;
}

.mainTtl {
  font-size: 22px;
  font-weight: bold;
  padding: 5px 2% 2px;
}
@media (max-width: 767px) {
  .mainTtl {
    font-size: 16px;
  }
}

.subMenuTtl {
  font-size: 14px;
}
@media (max-width: 767px) {
  .subMenuTtl {
    font-size: 16px;
  }
}

@media (max-width: 767px) {
  .subMenu ul li a:link {
    font-size: 2.5rem;
  }
}
#philosophy .philosophyList li {
  font-size: 16px;
}
@media (max-width: 767px) {
  #philosophy .philosophyList li {
    font-size: 16px;
  }
}

#philosophy .philosophyTtl {
  font-size: 28px;
}
@media (max-width: 767px) {
  #philosophy .philosophyTtl {
    font-size: 25px;
  }
}

#visionRow .mainHeading {
  font-size: 26px;
}
@media (max-width: 767px) {
  #visionRow .mainHeading {
    font-size: 25px;
  }
}

#pointRow li .pointHdr .boxHeading {
  font-size: 22px;
}
@media (max-width: 767px) {
  #pointRow li .pointHdr .boxHeading {
    font-size: 22px;
  }
}

.sp_br {
  display: none;
}
@media (max-width: 767px) {
  .sp_br {
    display: block;
  }
}

.pc_br {
  display: block;
}
@media (max-width: 767px) {
  .pc_br {
    display: none;
  }
}

#container {
  padding-bottom: 0;
  overflow-x: hidden;
}

header {
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  align-items: center;
  width: 100%;
  align-items: center;
}
@media (max-width: 767px) {
  header {
    box-sizing: border-box;
    height: 13.33vw;
    padding: 7px 0px;
    padding-bottom: 0;
    padding-top: 0px;
    align-items: center;
  }
}
header .header_logo {
  max-width: 173px;
  width: 100%;
  padding-left: 28px;
}
@media (max-width: 767px) {
  header .header_logo {
    width: 31.3043478261%;
  }
  header .header_logo img {
    width: 100%;
    height: auto;
  }
}
header .header_copy {
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", Osaka, Helvetica, Arial, sans-serif;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.7px;
  color: #e30934;
  padding-left: 15px;
  padding-top: 20px;
}
@media (max-width: 767px) {
  header .header_copy {
    font-size: 2rem;
    padding-top: 7px;
    font-weight: bold;
    letter-spacing: 1px;
    padding-left: 6.231884058%;
  }
}
header #hamburger {
  /* conversion btn
  ===================================== */
}
header #hamburger .btn-gNav {
  position: fixed;
  top: 0;
  right: 0;
  width: 80px;
  background: #e6002d;
  box-sizing: border-box;
  cursor: pointer;
  transition: all 400ms;
  z-index: 85;
}
@media (max-width: 767px) {
  header #hamburger .btn-gNav {
    width: 13.3333333333%;
  }
}
header #hamburger .btn-gNav .btn_content {
  padding-top: 100%;
}
header #hamburger .btn-gNav::after {
  position: absolute;
  content: "MENU";
  left: 50%;
  transform: translateX(-50%);
  bottom: 10%;
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", Osaka, Helvetica, Arial, sans-serif;
  font-size: 1.4rem;
  color: #fff;
}
@media (max-width: 767px) {
  header #hamburger .btn-gNav::after {
    font-size: 1.7rem;
  }
}
header #hamburger .btn-gNav span {
  position: absolute;
  width: 50%;
  left: 50%;
  transform: translateX(-50%);
  height: 2px;
  background: #fff;
  border-radius: 10px;
  transition: all 400ms;
}
header #hamburger .btn-gNav span:nth-child(1) {
  top: 20%;
}
header #hamburger .btn-gNav span:nth-child(2) {
  top: 35%;
}
header #hamburger .btn-gNav span:nth-child(3) {
  top: 50%;
}
header #hamburger .btn-gNav.open::after {
  content: "CLOSE";
}
header #hamburger .btn-gNav.open span:nth-child(1) {
  background: #fff;
  top: 30%;
  transform: translateX(-50%) rotate(-45deg);
}
header #hamburger .btn-gNav.open span:nth-child(2) {
  display: none;
}
header #hamburger .btn-gNav.open span:nth-child(3) {
  top: 30%;
  background: #fff;
  transform: translateX(-50%) rotate(45deg);
}
header #hamburger .conv_btn_section {
  position: fixed;
  z-index: 80;
  width: 7vh;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
}
@media (min-width: 1001px) {
  header #hamburger .conv_btn_section {
    top: 15vh;
    right: 0;
  }
}
@media (min-width: 1000px) and (max-width: 1900px) {
  header #hamburger .conv_btn_section {
    top: 15vh;
    right: 0;
  }
}
@media (min-width: 768px) and (max-width: 999px) {
  header #hamburger .conv_btn_section {
    top: 15vh;
    right: 0;
    width: 62px;
  }
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_section {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 13.3vw;
    background-color: transparent;
  }
}
header #hamburger .conv_btn_list {
  display: flex;
  flex-direction: column;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list {
    flex-direction: row;
    justify-content: space-around;
    align-items: center;
  }
}
header #hamburger .conv_btn_list .cov_btn {
  writing-mode: vertical-rl;
  border-radius: 10px 0 0 10px;
  width: 100%;
  height: 26.8vh;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 10000000;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn {
    writing-mode: horizontal-tb;
    border-radius: 10px;
    width: 100%;
    height: 10.67vw;
    text-align: center;
  }
}
header #hamburger .conv_btn_list .cov_btn a {
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", Osaka, Helvetica, Arial, sans-serif;
  display: block;
  margin: 0 auto;
  font-size: 2.5vmin;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
}
@media (min-width: 768px) and (max-width: 999px) {
  header #hamburger .conv_btn_list .cov_btn a {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn a {
    font-size: 2.4rem;
  }
}
header #hamburger .conv_btn_list .cov_btn:nth-child(1) {
  border-top: solid 1px #fff;
  border-left: solid 1px #fff;
  border-bottom: solid 1px #fff;
  background-color: #e30934;
  line-height: 1;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn:nth-child(1) {
    border: solid 1px #fff;
    padding: 0;
    line-height: 1.5;
  }
}
header #hamburger .conv_btn_list .cov_btn:nth-child(1) a {
  color: #fff;
}
header #hamburger .conv_btn_list .cov_btn:nth-child(1) a > .signup {
  font-size: 2vmin;
}
header #hamburger .conv_btn_list .cov_btn:nth-child(1) a > .mypage {
  font-size: 2.3vmin;
  text-orientation: upright;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn:nth-child(1) a > .mypage {
    font-size: 2.4rem;
  }
}
header #hamburger .conv_btn_list .cov_btn:nth-child(2) {
  margin: 8px 0;
  border-top: solid 1px #fff;
  border-left: solid 1px #fff;
  border-bottom: solid 1px #fff;
  background-color: #ff9b25;
  line-height: 1;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn:nth-child(2) {
    border: solid 1px #fff;
    padding: 0;
    line-height: 1.5;
  }
}
header #hamburger .conv_btn_list .cov_btn:nth-child(2) a {
  color: #fff;
}
header #hamburger .conv_btn_list .cov_btn:nth-child(2) a > .signup {
  font-size: 2vmin;
}
header #hamburger .conv_btn_list .cov_btn:nth-child(2) a > .mypage {
  font-size: 2.3vmin;
  text-orientation: upright;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn:nth-child(2) a > .mypage {
    font-size: 2.4rem;
  }
}
header #hamburger .conv_btn_list .cov_btn:nth-child(3) {
  border-top: solid 1px #e30934;
  border-left: solid 1px #e30934;
  border-bottom: solid 1px #e30934;
  background-color: #fff;
}
@media (max-width: 767px) {
  header #hamburger .conv_btn_list .cov_btn:nth-child(3) {
    border: solid 1px #e30934;
    padding: 0;
  }
}
header #hamburger .conv_btn_list .cov_btn:nth-child(3) a {
  color: #e30934;
}
header #gNav {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  font-size: 16px;
  box-sizing: border-box;
  z-index: -1;
  transition: 0.3s;
  padding: 75px 80px;
  overflow: scroll;
  opacity: 0;
}
@media (max-width: 767px) {
  header #gNav {
    padding: 4%;
    padding-bottom: 33vw;
    padding-top: 33vw;
  }
}
header #gNav.open {
  opacity: 1;
  z-index: 40;
}
header #gNav > ul {
  border: 1px solid #e6002d;
  max-width: 600px;
  margin: auto;
}
header #gNav > ul li {
  border-bottom: 1px solid #fff;
}
header #gNav > ul li:last-child {
  border-bottom: none;
}
header #gNav > ul li a {
  font-size: 1.6rem;
  color: #fff;
  display: block;
  padding: 20px;
  background: #e6002d;
}
@media (max-width: 767px) {
  header #gNav > ul li a {
    font-size: 2.6rem;
    padding: 4vw;
  }
}
header #gNav > ul li a.icon_link {
  position: relative;
}
header #gNav > ul li a.icon_link:after {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: transparent url(../image/new/menu_ico.png) no-repeat center center/contain;
  content: "";
}
@media (max-width: 767px) {
  header #gNav > ul li a.icon_link:after {
    width: 4.4vw;
    height: 4.4vw;
  }
}
header #gNav > ul li a.icon_aco {
  position: relative;
}
header #gNav > ul li a.icon_aco:after {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: transparent url(../image/new/plus_ico.png) no-repeat center center/contain;
  content: "";
}
@media (max-width: 767px) {
  header #gNav > ul li a.icon_aco:after {
    width: 4.4vw;
    height: 4.4vw;
  }
}
header #gNav > ul li a.icon_aco.op:after {
  content: "";
  background: transparent url(../image/new/minus_ico.png) no-repeat center center/contain;
}
header #gNav > ul li span {
  font-size: 1.6rem;
  color: #fff;
  display: block;
  padding: 20px;
  background: #e6002d;
}
header #gNav > ul li span:hover {
  opacity: 0.7;
  cursor: pointer;
}
@media (max-width: 767px) {
  header #gNav > ul li span {
    font-size: 2.6rem;
    padding: 4vw;
  }
}
header #gNav > ul li span.icon_link {
  position: relative;
}
header #gNav > ul li span.icon_link:after {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: transparent url(../image/new/menu_ico.png) no-repeat center center/contain;
  content: "";
}
@media (max-width: 767px) {
  header #gNav > ul li span.icon_link:after {
    width: 4.4vw;
    height: 4.4vw;
  }
}
header #gNav > ul li span.icon_aco {
  position: relative;
}
header #gNav > ul li span.icon_aco:after {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: transparent url(../image/new/plus_ico.png) no-repeat center center/contain;
  content: "";
}
@media (max-width: 767px) {
  header #gNav > ul li span.icon_aco:after {
    width: 4.4vw;
    height: 4.4vw;
  }
}
header #gNav > ul li span.icon_aco.op:after {
  content: "";
  background: transparent url(../image/new/minus_ico.png) no-repeat center center/contain;
}
header #gNav > ul li ul {
  display: none;
}
header #gNav > ul li ul li {
  border-bottom: 1px solid #e6002d;
}
header #gNav > ul li ul li:last-child {
  border-bottom: none;
}
header #gNav > ul li ul li a {
  background: #fff;
  color: #e6002d;
}

.footer_menu_item a {
  color: #666;
}

.section {
  padding: 0 0px;
}

.minTtl {
  font-size: 24px;
  margin-bottom: 10px;
}

.headingLine span {
  font-size: 22px;
  font-weight: bold;
}

#search-head h2 {
  font-size: 22px;
  font-weight: bold;
}
@media (max-width: 767px) {
  #search-head h2 {
    font-size: 18px;
  }
}

.boxSubHeading {
  font-size: 16px;
}

.mainTtl2 {
  font-size: 22px;
  font-weight: bold;
}

.tbl-col2 th {
  text-align: center;
}

.leftImgStyle .txtCol {
  width: 560px;
  margin-left: 20px;
}
@media (max-width: 767px) {
  .leftImgStyle .txtCol {
    width: 100%;
    margin-left: 0;
  }
}

.rightImgStyle .txtCol {
  width: 560px;
}
@media (max-width: 767px) {
  .rightImgStyle .txtCol {
    width: 100%;
    margin-left: 0;
  }
}

@media (max-width: 767px) {
  #search-head .search-text {
    font-size: 2.5rem;
  }
}

@media (max-width: 767px) {
  #search-head dl dt {
    font-size: 2.5rem;
  }
}

.textBtn._red .link._blank span {
  font-size: 24px;
}
@media (max-width: 767px) {
  .textBtn._red .link._blank span {
    font-size: 16px;
  }
}

@media (max-width: 767px) {
  .storyH2Txt .subTtl {
    font-size: 21px;
  }
}

@media (max-width: 767px) {
  .storyH2Txt .txt {
    font-size: 27px;
  }
}

@media (max-width: 767px) {
  #storiesBottomBtns .btnArea .link {
    font-size: 18px;
  }
}

@media (max-width: 767px) {
  #search-head .search-select-area .search-select-btn {
    font-size: 2.9375rem;
  }
}

#careerstep .inner {
  text-align: left;
}
#careerstep h3 {
  font-weight: bold;
}

#staff-schedule .inner {
  text-align: left;
}
#staff-schedule h3 {
  font-weight: bold;
}

.company-col h3,
.staff h3 {
  font-weight: bold;
}

#breadcramb a {
  color: #297acc;
}

#list-wrap .company a {
  background-size: 12.8px auto;
}

#detail-container h3 {
  font-weight: bold;
}/*# sourceMappingURL=under_page.css.map */