@charset "utf-8";

/*-----------------------------------------------------
font
-------------------------------------------------------*/
#Main .access h2,
#Main .access p.link {
  font-family: "DINNextLTPro-Condensed", sans-serif;
  letter-spacing: 0.1em;
}

#Main .contact h2 {
  font-family: "TsukuGoPr5-R";
  letter-spacing: 0.2em;
}
#Main .contact p.btn a {
  font-family: "TsukuGoPr5-D";
  letter-spacing: 0.2em;
}

/*-----------------------------------------------------
Main
-------------------------------------------------------*/
#Main {
  padding-bottom: 40px;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main {
    padding-bottom: 10px;
  }
}

#Main h1 {
  margin: 0 0 70px 0;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main h1 {
    margin: 0 0 35px;
  }
}

/*-------------------------------------
contact
---------------------------------------*/
#Main .contact {
  width: 30%;
  overflow: hidden;
  float: left;
  display: inline;
  margin: 0 5% 95px 0;
}
#Main .contact:nth-of-type(3) {
  margin-right: 0;
}

@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .contact {
    width: 100%;
    float: none;
    display: block;
    margin: 0 0 30px 0;
  }
  #Main .contact:nth-of-type(3) {
    margin: 0 0 60px 0;
  }
}

/* h2
---------------------*/
#Main .contact h2 {
  margin: 0 0 30px 0;
  padding: 0 0 0 32px;
  font-size: 139%;
  line-height: 1.2;
  letter-spacing: 0.15em;
  background-position: 0 47%;
  background-repeat: no-repeat;
  background-size: 20px 20px;
}
#Main .contact.works h2 {
  background-image: url("../images/icon_works.png");
}
#Main .contact.recruit h2 {
  background-image: url("../images/icon_recruit.png");
}
#Main .contact.etc h2 {
  background-image: url("../images/icon_etc.png");
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .contact h2 {
    margin: 0 0 15px 0;
    padding: 0 0 0 22px;
    font-size: 108%;
    background-size: 15px 15px;
  }
}

/* text
---------------------*/
#Main .contact p.text {
  margin: 0 2px 35px 2px;
  font-size: 124%;
  line-height: 1.8;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .contact p.text {
    margin: 0 0 17px 0;
    font-size: 93%;
    line-height: 1.6;
  }
}

/* btn
---------------------*/
#Main .contact p.btn {
  width: 100%;
  height: 80px;
  display: table;
}
#Main .contact p.btn a {
  display: table-cell;
  padding: 0 10.7%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-align: center;
  vertical-align: middle;
  font-size: 139%;
  text-decoration: none;
  color: #272727;
  border: 2px solid #272727;
  background-image: url("../../common/images/icon_arrow_right_black_min.png");
  background-position: 94.4% 50%;
  background-repeat: no-repeat;
  -webkit-background-size: 10px auto;
  background-size: 10px auto;

  -webkit-transition: opacity 170ms cubic-bezier(0.25, 0.25, 0.75, 0.75),
    background 170ms cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 170ms cubic-bezier(0.25, 0.25, 0.75, 0.75),
    /* linear */ background 170ms cubic-bezier(0.19, 1, 0.22, 1)
      /* easeOutExpo */;
}
#Main .contact p.btn a:hover {
  background-position: 95.4% 50%;
  opacity: 0.5;
}

@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .contact p.btn {
    height: 60px;
  }
  #Main .contact p.btn a {
    font-size: 100%;
    border: 1px solid #272727;
    -webkit-background-size: 5px auto;
    background-size: 5px auto;
  }
}

/*-------------------------------------
contact
---------------------------------------*/
#Main .access {
  width: 100%;
  overflow: hidden;
  margin: 0 0 60px 0;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .access {
    margin: 0 0 30px 0;
  }
}

/* btn
---------------------*/
#Main .access h2 {
  margin: 0 0 10px 0;
  line-height: 1;
  font-size: 185%;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .access h2 {
    line-height: 1;
    font-size: 116%;
  }
}

/* text
---------------------*/
#Main .access p.text {
  margin: 0 0 18px 0;
  font-size: 124%;
  line-height: 1.8;
}
#Main .access p.text a {
  color: #131313;
  text-decoration: none;
  pointer-events: none;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .access p.text {
    margin: 0 0 10px 0;
    font-size: 93%;
    line-height: 1.6;
  }
  #Main .access p.text a {
    pointer-events: auto;
  }
}

/* link
---------------------*/
#Main .access p.link {
  float: right;
  display: inline;
  margin: -49px 0 10px 0;
  font-size: 139%;
}
#Main .access p.link a span.blank {
  margin: 0 0 -2px 5px;
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .access p.link {
    float: none;
    display: block;
    margin: 0 0 15px 0;
    font-size: 100%;
    line-height: 1.6;
  }
}

/* map
---------------------*/
#Main .access div.map {
  width: 100%;
  height: 480px;
  padding-left: calc(5vw);
}
@media screen and (max-width: 640px) {
  /* == device-width < 640 == */
  #Main .access div.map {
    height: 180px;
  }
}
