@charset "UTF-8";

/*** J-Bridge Portal (English) ***/

/*--------- portal top ---------*/
#logout {
    position: absolute;
    top: 30px;
    right:calc((100% - 1000px) / 2);
    z-index: 3;

}
#logout.linkBox button {
    min-width: 120px !important; 
}
#logout.linkBox button.noarrow::after {
    display: none !important;
}

@media screen and (max-width: 640px) {
#logout {
  right: 10px;
}
}

/*--------- admin top ---------*/
.elem_heading_lv2 > .elem_text_list {
   margin: 5px 0;
}

@media print, screen and (min-width: 641px) {
   .form_select__item.var_right {
      justify-content: flex-end;
  }
}

.jform .elem_custom_input input.nobg {
    border: none  !important;
    background: none  !important;
}
.jform .linkBox {
    margin: 0 10px  !important;
}

.jform .linkBox a, .jform .linkBox button {
    min-width: auto !important;
}
.jform .linkBox a, .jform .linkBox button {
    border-radius: 5px !important;
    padding: 7px 12px 7px !important;
}
.jform .linkBox a.noarrow::after, .jform .linkBox button.noarrow::after {
    display: none !important;
}

/* -.elem_pagination - */
.elem_pagination {
  padding:35px 0;
}
.elem_pagination ol {
  text-align:center;
  letter-spacing: -0.4em;
}
.elem_pagination ol li {
  display:inline-block;
  vertical-align:top;
  padding:0 2px;
  margin-bottom: 4px;
  letter-spacing: normal;
}
.elem_pagination ol li {
  list-style:none;
  margin-left: 0;
}
.elem_pagination ol li a {
  display:block;
  padding:10px 14px;
  border:1px solid #dcdcdc;
  border-radius:4px;
  font-weight:bold;
  line-height:1;
}
.elem_pagination ol li.current a {
  background:#dcdcdc;
  border:2px solid #6c6c6c;
  padding:8px 14px;
  color:#000;
}
.elem_pagination ol li a:hover {
  background:#dcdcdc;
  color:#000;
  text-decoration:none;
}
.elem_pagination ol li span {
  display:block;
  padding:10px 10px;
  font-weight:bold;
  line-height:1;
}

/*--------- login page ---------*/

.comp_pagetitle_with_photo > div {
   justify-content: space-between;
}

.comp_pagetitle_with_photo_right_container {
    position: relative;
    z-index: 2;
    margin-right: 75px;
    width: 350px;
}
.comp_pagetitle_with_photo_right_container .comp_pagetitle_with_photo_right_container_inner {
    display: flex;
    background-color: rgba(255,255,255,0.8);
    padding: 30px;
    flex-direction: column;
}

@media screen and (max-width: 640px) {
  .form_text {
     margin: 0 auto 10px !important;
  }
   .comp_pagetitle_with_photo > div {
     justify-content: center;
   }
   .comp_pagetitle_with_photo.h480_sp > div {
      height: 480px !important;
      flex-flow: column;
   }
   .comp_pagetitle_with_photo.h480_sp .comp_pagetitle_with_photo_img_container img {
      height: 480px !important;
   }
   .comp_pagetitle_with_photo_right_container {
      width: 300px;
      margin-right: 0;
   }
   .comp_pagetitle_with_photo_txt_container {
      padding-bottom: 10px;
   }
   .comp_pagetitle_with_photo_txt_container::after {
      display: none;
   }
}

.linkBox.var_widthauto {
    margin: 0 10px  !important;
}
.linkBox.var_widthauto a, .linkBox.var_widthauto button {
    min-width: auto !important;
    margin-top:15px !important;
}


/*--------- japanese company finder ---------*/

.elem_flex_justify {
   display: flex;
   justify-content: space-between;
   max-width: 1000px;
   margin: 0 auto;
}
.elem_flex_justify > #elem_heading_lv1 {
   flex-grow: 1;
}
.elem_flex_justify > #elem_heading_lv1 + .elem_linkBox_list {
   margin-top: 30px;
}
@media screen and (max-width: 640px) {
  .elem_flex_justify.spv {
   display: block;
  }
  .elem_flex_justify > #elem_heading_lv1 + .elem_linkBox_list {
      margin-top: 0;
      width: fit-content;
  }
  .elem_flex_justify > #elem_heading_lv1 + .elem_linkBox_list.right {
   float: right;
  }
  .elem_flex_justify.spv .elem_linkBox_list ul li > a.witharrow {
   padding-bottom: 0;
  }
}
.font16 {
   font-size: 16px !important;
}
.cate.font16 {
   margin: 5px 3px 5px 0 !important;
}
.font18 {
   font-size: 18px !important;
}
.video-wrap {
   max-width: 1000px;
   margin: 0 auto;
}

[class^="cate tag"] {
  background: #434343;
  color: #fff;
  font-size: 0.75em;
  padding: 1px 8px !important;
  display: inline-block !important;
  margin-right: 2px !important;
  word-break: keep-all;
}
.cate.tag_grey {
 background: #cdcdcd !important;
 color: #000 !important;
}
[class^="cate tag"][class*="font16"] {
  margin-bottom: 5px;
}

.elem_content_divide_block.jb_company_title > .elem_content_divide_block_pad.content_divide_col2 > .elem_content_divide_box.logo {
   width: calc(25% - 30px);
}
.elem_content_divide_block.jb_company_title > .elem_content_divide_block_pad.content_divide_col2 > .elem_content_divide_box.logo img {
   width: 225px;
}
.elem_content_divide_block.jb_company_title > .elem_content_divide_block_pad.content_divide_col2 > .elem_content_divide_box.text {
   width: calc(75% - 30px);
}
@media screen and (max-width: 640px) {
  .elem_content_divide_block.jb_company_title > .elem_content_divide_block_pad.content_divide_col2 > .elem_content_divide_box.logo,
  .elem_content_divide_block.jb_company_title > .elem_content_divide_block_pad.content_divide_col2 > .elem_content_divide_box.text {
    width:100%;
  }
}
/* -.elem_text_list_note_flex > dl
----------------------------------------------------------- */
.elem_text_list_note_flex {
  padding: 0 0 10px 0;
}
.elem_text_list_note_flex  > dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
.elem_text_list_note_flex  > dl > *{
   box-sizing: border-box;
}
.elem_text_list_note_flex  > dl  > dt {
   flex-basis: 20%;
   padding: 5px 0;
}
.elem_text_list_note_flex  > dl  > dd {
   flex-basis: 80%;
   padding: 5px 0 5px 10px;
}
.elem_text_list_note_flex.var_border  > dl {
  border-top: 1px solid #efefef;
}
.elem_text_list_note_flex.var_border  > dl > * {
   border-bottom: 1px solid #efefef;
}
.elem_text_list_note_flex.var_border  > dl > dt {
  padding: 10px 0;
}
.elem_text_list_note_flex.var_border  > dl > dd {
  padding: 10px 0 10px 10px;
}

.elem_text_list_note_flex.var_col2  > dl > dd {
   flex-basis: 30%;
}
.elem_text_list_note_flex.var_col2  > dl > dd.fullwide {
   flex-basis: 80%;
}
.elem_linkBox_list ul li > a.witharrow {
  display: table-cell; 
  padding: 0 0 20px 24px;
  vertical-align: middle;
  background: url('/library/new/common/content_images/icon/icon_arrow_cb.png') no-repeat left 0.2em;
}

.elem_text_list_note_flex.var_dt30r  > dl  > dt {
   flex-basis: 30%;
}
.elem_text_list_note_flex.var_dt30r  > dl  > dd {
   flex-basis: 70%;
}


.elem_text_list_note_flex.var_border  > dl > dd {
  padding: 10px 15px 10px 10px;
}

.elem_text_list_note_flex .form_checkbox {
    margin: 0 auto 4px !important
}

@media screen and (max-width: 640px) {
  .elem_text_list_note_flex > dl > dt {
    flex-basis: 100%;
    background: #f0f0f0;
    padding-left: 10px !important;
  }
  .elem_text_list_note_flex > dl > dd, 
  .elem_text_list_note_flex.var_col2 > dl > dd, 
  .elem_text_list_note_flex.var_col2 > dl > dd.fullwide {
    flex-basis: 100%;
  }
}

.elem_heading_lv3 {
    position: relative !important;
}
.elem_heading_lv2 ul.button,
.elem_heading_lv3 ul.button { 
  position: absolute;
  right: 0;
  bottom: 12px;
}
.elem_heading_lv2 ul.button li a,
.elem_heading_lv3 ul.button li a {
  display:block;
  padding:3px 10px 6px 25px;
  background:#4b4b4b;
  color:#fff;
  text-align:center;
  white-space:nowrap;
   text-decoration: none !important;
}
#elem_heading_lv1 ul.button li a:hover, .elem_heading_lv2 ul.button li a:hover, .elem_heading_lv3 ul.button li a:hover  {
  text-decoration:none !important;
}
#elem_heading_lv1 ul.button li a:focus,
.elem_heading_lv2 ul.button li a:focus,
.elem_heading_lv3 ul.button li a:focus {
  outline: solid 1px #000000;
}

#elem_heading_lv1 ul.button li a.var_link,
.elem_heading_lv2 ul.button li a.var_link,
.elem_heading_lv3 ul.button li a.var_link {
  background:#006ec8 url(/library/new/common/content_images/arrow/arrow_right_small.png) 8px 50% no-repeat;
  font-weight: normal !important;
  margin-top: -5px;
  padding:8px 7px 8px 25px;
  color: #fff;
}
.elem_heading_lv2 ul.button li a.var_simple, 
.elem_heading_lv3 ul.button li a.var_simple,
.elem_heading_lv2 ul.button li a.no_arrow {
  padding:6px 10px;
  min-width: initial;
}

.elem_divide_content ul li.hide {
    overflow: hidden;
    width: 0px !important;
    height: 0px !important;
    margin: 0px;
    padding: 0px !important;
    visibility: hidden;
    display: none;
}

