@charset "UTF-8";
/*
** import core file
*/
/*
** -- two point
*/
/*---------------
  subnav
----------------*/
/*
** -- three point
@mixin break-pc {//pcのみ
	@media screen and (min-width:961px) {
		@content;
	}
}
@mixin break-pc-tab {//pcとtab共通
	@media screen and (min-width:768px) {
		@content;
	}
}
@mixin break-tab-sp {//tabとsp共通
	@media screen and (max-width:960px) {
		@content;
	}
}
@mixin break-tab {//tabのみ
	@media screen and (max-width:960px) and (min-width:768px) {
		@content;
	}
}
@mixin break-sp {//spのみ
	@media screen and (max-width:767px) {
		@content;
	}
}
@mixin break-sps {//iphone5/SE
	@media screen and (max-width:374px) { @content; }
}
*/
/*
** -- two point
*/
/*---------------
  subnav
----------------*/
/*
** -- three point
@mixin break-pc {//pcのみ
	@media screen and (min-width:961px) {
		@content;
	}
}
@mixin break-pc-tab {//pcとtab共通
	@media screen and (min-width:768px) {
		@content;
	}
}
@mixin break-tab-sp {//tabとsp共通
	@media screen and (max-width:960px) {
		@content;
	}
}
@mixin break-tab {//tabのみ
	@media screen and (max-width:960px) and (min-width:768px) {
		@content;
	}
}
@mixin break-sp {//spのみ
	@media screen and (max-width:767px) {
		@content;
	}
}
@mixin break-sps {//iphone5/SE
	@media screen and (max-width:374px) { @content; }
}
*/
/*
@include animation(scrollpoint,2.5,ease,0,infinite,normal,forwards);
<div class="scroll">
	<a href="#indexSolving">scroll</a>
	<span class="bar"></span>
</div>
*/
/*
&:before {
	content:'';
	@include sizes(1px,50px);
	display: block;
	background: #333;
	position: absolute;
	top:0;left:0;right:0;
	margin:auto;
	@include animation ( down-border, 2, ease, 0, infinite,normal,forwards);
	@include transform( translate3d(0,0,0) );
}
*/
/*==================================================

** job
==================================================*/
#jobSearch .termsec h3 {
  background: #006bb4;
  color: #fff;
  text-align: left;
  padding: 20px 50px;
  position: relative;
  cursor: pointer; }
  #jobSearch .termsec h3:before {
    content: "";
    font: normal normal 900 1em "Font Awesome 5 Free";
    line-height: inherit;
    margin-right: 15px; }
  #jobSearch .termsec h3:after {
    content: '';
    display: block;
    width: 17px;
    height: 17px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(135deg);
    transition: all 0.3s;
    position: absolute;
    top: 30px;
    right: 50px; }
  #jobSearch .termsec h3.open:after {
    transform: rotate(-45deg);
    transition: all 0.6s;
    top: 37px; }
#jobSearch .search-term {
  display: none;
  padding: 50px 49px;
  border: 1px solid #ccc;
  border-top: 0;
  margin-top: 0; }
  #jobSearch .search-term .termbox {
    padding-bottom: 24px;
    border-bottom: 1px dashed #eee; }
    #jobSearch .search-term .termbox + .termbox {
      padding: 24px 0; }
  #jobSearch .search-term dt {
    font-family: "Noto Serif JP", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "MS PMincho", "MS 明朝", serif;
    font-size: 1.8rem;
    width: 185px;
    line-height: 46px; }
  #jobSearch .search-term dd {
    width: 915px; }
  #jobSearch .search-term .termlist {
    margin-top: -15px; }
    #jobSearch .search-term .termlist li {
      min-width: 217px;
      margin: 15px 15px 0 0; }
      #jobSearch .search-term .termlist li:nth-of-type(4n) {
        margin-right: 0; }
  #jobSearch .search-term label {
    position: relative; }
    #jobSearch .search-term label span {
      display: block;
      border: 1px solid #ccc;
      padding: 10px 16px;
      transition: all 0.3s;
      cursor: pointer; }
      #jobSearch .search-term label span:hover {
        background: #e8eef9;
        color: #006bb4;
        transition: all 0.6s; }
  #jobSearch .search-term input {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    opacity: 0;
    padding: 0; }
    #jobSearch .search-term input:checked + span {
      background: #e8eef9;
      color: #006bb4;
      transition: all 0.6s; }

#jobResults .resultbox {
  margin-top: 120px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 20px; }
#jobResults .result {
  font-weight: 500; }
  #jobResults .result .num {
    display: inline-block;
    font-size: 3.2rem;
    color: #006bb4;
    letter-spacing: 0.08em;
    font-weight: 700;
    margin: 0 3px 0 15px;
    line-height: 1;
    vertical-align: -5px; }
  #jobResults .result .ken {
    vertical-align: middle; }
#jobResults .resultlist {
  margin-top: 0; }
  #jobResults .resultlist .item {
    margin-top: 60px;
    border-bottom: 1px solid #ccc;
    padding-bottom: 59px; }
    #jobResults .resultlist .item.disnon {
      display: none; }
  #jobResults .resultlist .job {
    display: inline-block;
    background: #006bb4;
    color: #fff;
    padding: 5px 6px 6px;
    font-size: 1.2rem; }
  #jobResults .resultlist h3 {
    text-align: left;
    color: #006bb4;
    margin-top: 5px; }
  #jobResults .resultlist .detailbox {
    margin-top: 32px; }
  #jobResults .resultlist .imgbox {
    width: 420px;
    aspect-ratio: 70/43;
    overflow: hidden; }
    #jobResults .resultlist .imgbox img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  #jobResults .resultlist .txtbox {
    width: 740px; }
    #jobResults .resultlist .txtbox h4 {
      text-align: left; }
    #jobResults .resultlist .txtbox table {
      border: 1px solid #ccc; }
      #jobResults .resultlist .txtbox table th {
        background: #e5f5ff;
        color: #006bb4;
        border-right: 1px solid #ccc;
        padding: 14px 19px;
        width: 150px; }
      #jobResults .resultlist .txtbox table td {
        padding: 14px 19px; }
    #jobResults .resultlist .txtbox .map {
      display: inline-block;
      margin-left: 12px;
      line-height: 1;
      width: 50px;
      text-align: center;
      padding: 3px 0;
      background: #006bb4;
      color: #fff;
      font-size: 1.2rem;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid #006bb4; }
      #jobResults .resultlist .txtbox .map:hover {
        color: #006bb4;
        background: #fff; }
    #jobResults .resultlist .txtbox p {
      line-height: 1.4; }
      #jobResults .resultlist .txtbox p + p {
        margin-top: 10px; }
  #jobResults .resultlist .linkbtn {
    margin-top: 40px;
    width: 300px; }
    #jobResults .resultlist .linkbtn + .linkbtn {
      margin-left: 30px; }

@media screen and (max-width: 600px) {
  #jobSec .recruitnav {
    margin-top: 70px; }

  #jobSearch .termsec h3 {
    margin-top: 40px;
    padding: 18px 20px; }
    #jobSearch .termsec h3:before {
      margin-right: 10px; }
    #jobSearch .termsec h3:after {
      width: 12px;
      height: 12px;
      top: 27px;
      right: 20px; }
    #jobSearch .termsec h3.open:after {
      top: 32px; }
  #jobSearch .search-term {
    display: none;
    padding: 38px 5.5%; }
    #jobSearch .search-term dt {
      font-size: 1.6rem;
      width: 100%;
      line-height: 1.6; }
    #jobSearch .search-term dd {
      width: 100%; }
    #jobSearch .search-term .termlist {
      margin-top: 0; }
      #jobSearch .search-term .termlist li {
        min-width: 100%;
        margin: 15px 0 0; }

  #jobResults .resultbox {
    margin-top: 80px; }
  #jobResults .result .num {
    font-size: 2.6rem;
    margin: 0 3px 0 10px;
    vertical-align: -2px; }
  #jobResults .result .ken {
    vertical-align: -1px; }
  #jobResults .resultlist .item {
    margin-top: 40px;
    padding-bottom: 39px; }
  #jobResults .resultlist h3 {
    font-size: 2.6rem; }
  #jobResults .resultlist .imgbox {
    width: 100%; }
  #jobResults .resultlist .txtbox {
    width: 100%; }
    #jobResults .resultlist .txtbox h4 {
      margin-top: 35px; }
    #jobResults .resultlist .txtbox table th {
      border-right: 0;
      border-bottom: 1px solid #ccc;
      width: 100%; }
  #jobResults .resultlist .linkbtn {
    margin-top: 30px;
    width: 100%; }
    #jobResults .resultlist .linkbtn + .linkbtn {
      margin: 20px 0 0; } }
/*==================================================

** - single
==================================================*/
#jobIntro h2 .job {
  display: block;
  margin-bottom: 4px; }
  #jobIntro h2 .job span {
    display: inline-block;
    background: #006bb4;
    color: #fff;
    padding: 2px 6px;
    font-size: 1.2rem;
    letter-spacing: 0em; }
#jobIntro .introbox .imgslide {
  width: 540px; }
#jobIntro .introbox .img {
  aspect-ratio: 135/83;
  overflow: hidden; }
  #jobIntro .introbox .img img {
    width: 100%;
    height: 100%;
    object-fit: cover; }
#jobIntro .introbox .txtbox {
  width: 610px; }
  #jobIntro .introbox .txtbox h3 {
    color: #006bb4;
    text-align: left; }
#jobIntro .slick-dots {
  position: static;
  margin-top: 30px;
  text-align: center; }
  #jobIntro .slick-dots li {
    display: inline-block;
    margin: 0 6px;
    padding: 0;
    width: 12px;
    line-height: 0; }
    #jobIntro .slick-dots li:before {
      content: none; }
    #jobIntro .slick-dots li button {
      text-indent: 100%;
      white-space: nowrap;
      overflow: hidden;
      width: 12px;
      height: 12px;
      border: none;
      border-radius: 1000px;
      background: #d9d3c7;
      transition: all 0.5s; }
      #jobIntro .slick-dots li button:hover {
        background: #006bb4;
        transition: all 0.3s; }
    #jobIntro .slick-dots li.slick-active button {
      background: #006bb4; }

#jobSingle table p {
  line-height: 1.5; }
  #jobSingle table p + p {
    margin-top: 10px; }
#jobSingle table .map {
  display: inline-block;
  margin-left: 12px;
  line-height: 1;
  width: 50px;
  text-align: center;
  padding: 3px 0;
  background: #006bb4;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid #006bb4; }
  #jobSingle table .map:hover {
    color: #006bb4;
    background: #fff; }
#jobSingle .linkbtn a {
  margin: 50px auto 0; }

#jobYoutube .moviebox {
  width: 360px;
  margin: 60px auto 0; }
  #jobYoutube .moviebox .movie {
    aspect-ratio: 9/16; }
    #jobYoutube .moviebox .movie iframe {
      width: 100%;
      height: 100%; }

@media screen and (max-width: 600px) {
  #jobIntro h2 {
    font-size: 2.2rem; }
  #jobIntro .introbox .imgslide {
    width: 100%; }
  #jobIntro .introbox .txtbox {
    margin-top: 40px;
    width: 100%; }
    #jobIntro .introbox .txtbox h3 {
      font-size: 1.8rem; }

  #jobSingle table {
    margin-top: 20px; }
    #jobSingle table .map {
      display: block;
      margin: 4px 0 0; }
  #jobSingle .linkbtn a {
    margin: 40px auto 0; }

  #jobYoutube .moviebox {
    width: 100%;
    margin: 40px auto 0; } }
