@charset "UTF-8";

/* CSS Document */
.xs_none {
  display: none !important;
}

.txt100xs {
  font-size: 1em !important;
}

.txt140xs {
  font-size: 1.4em !important;
}

.txt150xs {
  font-size: 1.5em !important;
}

.txt160xs {
  font-size: 1.6em !important;
}

.xs_txt_fff {
  color: #fff !important;
}

.xs_txt_center {
  text-align: center !important;
}

.xs_txt_left {
  text-align: left !important;
}

.xs_w100 {
  width: 100% !important;
}

.xs_mt30 {
  margin-top: 30px !important;
}

.xs_mb20 {
  margin-bottom: 20px !important;
}

.xs_mb30 {
  margin-bottom: 30px !important;
}

.xs_mb40 {
  margin-bottom: 40px !important;
}

.xs_pt0 {
  padding-top: 0 !important;
}

.xs_pt40 {
  padding-top: 40px !important;
}

.anchor_point {
  padding-top: 55px;
  margin-top: -55px;
}

/*------------------------------*/

body {}



.main_menu_link_type_02 {
  margin-top: .5em;
  margin-left: 0;
}

.main_menu_title {
  display: block;
}

.main_menu_title_flex {
  display: block;
  text-align: center;
}

.main_menu_title img {
  width: 170px;
  margin-right: 0;
  margin-bottom: 10px;
}

.toppage_main .movie_container{
  min-height: 300px;
}

.toppage_main .logo{
  transform: translate(-50%, -50%) scale(1.3);
}
.toppage_main .catch{
  width: 80%;
}

.header_menu_btn_a {
  width: 50px;
}

.header_menu_btn {
  width: 50px;
  height: 50px;
  padding-bottom: 5px;
}

.header_menu_btn>* {
  transform: scale(.8);
}

.header_top_flex {
  display: flex;
  color: #7F7F5F !important;
  flex-direction: column-reverse;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.header_body{
}

header{
  height: 80px;
}
body{
  padding-top: 80px;
}

.header_site_name a .img img{
  max-width: 150px;
}

.header_site_name a .txt{
  margin-top: 5px;
}



#main_menu .uk-offcanvas-bar {
  padding: 25px 0 30px;
}

.main_menu_content_body {
  width: calc(100% - 40px);
}

.main_menu_content_body .base_width{
  padding: 0 30px;
}

.main_menu_title {
  width: 170px;
  margin-left: auto;
  margin-right: auto;
}


.footer_address>div {
  font-size: .9em;
}

.footer_content_01_flex {
  display: block;
}

.footer_content_01_flex>*.footer_content_01_flex_left,
.footer_content_01_flex>*.footer_content_01_flex_right {
  width: 100%;
}

.footer_content_01_flex_left_bg {
  padding: 30px 0;
}

.footer_content_01_flex_right_bg {
  padding: 30px 0;
  font-size: .9em;
}

.footer_content_01_flex_left_bg {
  font-size: .9em;
}

.base_under_list {
  grid-template-columns: 1fr;
}

.base_under_list_title {
  font-size: 1.7rem;
}

.base_under_list_img::after {
  width: 37px;
  height: 37px;
  transform: translate(23%, 55%);
}

.base_under_list li a:hover .base_under_list_img::after {
  transform: translate(30%, 55%);
}

.base_under_sec_padding {
  padding: 60px 0;
}

.under_mv {
  height: 200px;
}

.under_mv_title {
  font-size: 3.6rem;
}

.under_mv_title_en {
  font-size: 1.6rem;
}

.locations_list_bl {
  grid-template-columns: 1fr;
  gap: 10px;
}

.locations_list_table {
  grid-template-columns: 80px 1fr;
  font-size: 1.6rem;
}

.base_unchor_links li a {
  text-align: left;
  padding: 10px 0;
}

.locations_list li:last-of-type {
  padding-bottom: 60px;
}

.sp_txt16px {
  font-size: 1.6rem !important;
}

.message_name_address {
  font-size: 1.5rem;
}

.message_interview_sec {
  padding: 60px 0;
}

.base_flex_title_bl {
  margin-bottom: 30px;
}

.interview_item+.interview_item {
  margin-top: 30px;
}

.page_small_links_sec {
  padding: 60px 0;
}

.page_small_links {
  grid-template-columns: 1fr;
}

.base_30_70_table tr {
  display: flex;
  flex-direction: column;
}

.base_30_70_table th,
.base_30_70_table td {
  width: 100%;
  display: block;
  padding: 15px;
}

.base_30_70_table th {
  border-bottom: none;
}

.under_mv_title_bl_small .under_mv_title_en::after {
  width: 70px;
}

.under_mv_title_bl_small .under_mv_title_en {
  padding-bottom: 20px;
}

.box_bg_gray_txt {
  height: 200px;
}

.xs_br {
  display: inline-block;
}

.history_list_year_bl {
  width: 165px;
  padding-left: 60px;
}

.history_list_year_bl::before {
  width: 46px;
  top: 12px;
}

.history_list li::before {
  top: 12px;
}

.history_list li::after {
  top: 5.5px;
}

.history_list_txt {
  width: calc(100% - 165px);
  font-size: 14px;
}

.base_detail_link_list {
  grid-template-columns: 1fr;
  gap: 50px;
}

.base_harf_table th,
.base_harf_table td {
  padding: 15px;
}

.health_images {
  grid-template-columns: 1fr;
}

.toppage_company_white_box {
  padding: 30px 0;
}

.toppage_company_list-title {
  font-size: 1.6rem;
}

.toppage_company_list {
  gap: 25px 6%;
  margin-top: 30px;
}

.toppage_company_list_ig {
  margin-bottom: 10px;
}

.toppage_company_list-title::after {
  width: 30px;
  height: 30px;
}

.section_padding {
  padding-top: 50px;
  padding-bottom: 60px;
}

.toppage_company_section_bg_01 {
  height: calc(100% - 50px);
}



.toppage_service_section {
  padding: 50px 0 0;
}

.toppage_service_list {
  grid-template-columns: 1fr;
  margin-top: 35px;
}

.toppage_service_list li a {
  height: 200px;
}

.toppage_service_list li a img {
  object-fit: cover;
  object-position: center;
  height: 100%;
}

.toppage_initiative_section {
  padding: 60px 0 30px;
}

.toppage_initiative_cont_bl {
  margin-top: 90px;
}

.toppage_initiative_cont_bl::before {
  height: 500px;
  top: -55px;
}

.toppage_initiative_list_title {
  font-size: 1.6rem;
}

.toppage_initiative_list {
  gap: 30px 6%;
}

.toppage_initiative_list_title::after {
  width: 30px;
  height: 30px;
  transform: translate(45%, -60%);
}

a:hover .toppage_initiative_list_title::after {
  transform: translate(48%, -60%);
}

.toppage_initiative_cont_white_bl {
  padding: 40px 7%;
}

.toppage_recruit_section .common_title {
  font-size: 5rem;
}

.toppage_recruit_section .common_sub_title {
  font-size: 1.8rem;
}

.toppage_recruit_section {
  padding: 50px 0 50px;
  background-position: top 0 left 77%;
}


.base_unchor_links.recruit_interview_links {
  grid-template-columns: auto
}


.toppage_company_section:before{
  width: auto;
  height: 60%;
}


.toppage_recruit_cont{
  width: 280px;
  margin-left: auto;
  margin-right: auto;
}