.p-professionals {
  padding: 20px 0 100px; }
  @media screen and (max-width: 767px) {
    .p-professionals {
      padding: 10vw 4vw; } }
  .p-professionals-ttl {
    position: relative;
    text-align: center;
    font-size: 3.0rem;
    line-height: 1.5;
    font-weight: 500;
    padding-top: 85px;
    margin-bottom: 50px; }
    @media screen and (max-width: 1320px) and (min-width: 768px) {
      .p-professionals-ttl {
        font-size: min(3vw, 3.0rem);
        padding-top: 6.4vw; } }
    @media screen and (max-width: 767px) {
      .p-professionals-ttl {
        font-size: 4.9vw;
        text-align: left;
        padding-top: 8.4vw;
        margin-bottom: 8vw; } }
    .p-professionals-ttl::before {
      content: '';
      position: absolute;
      top: 0;
      left: 50%;
      width: 1095px;
      height: 155px;
      background: url(/recruit/assets/images/job/img_ttl_professionals.png) 0 0 no-repeat;
      transform: translateX(-50%);
      z-index: -1; }
      @media screen and (max-width: 1320px) and (min-width: 768px) {
        .p-professionals-ttl::before {
          width: 90vw;
          height: 12vw;
          background-size: auto 100%; } }
      @media screen and (max-width: 767px) {
        .p-professionals-ttl::before {
          left: -2vw;
          width: 93vw;
          height: 12vw;
          background-size: 100% auto;
          transform: none; } }
  .p-professionals-block {
    width: 800px;
    box-shadow: 0 -1px 5px rgba(0, 0, 0, 0.1);
    padding: 50px 0;
    margin: 0 auto; }
    @media screen and (max-width: 840px) and (min-width: 768px) {
      .p-professionals-block {
        width: auto;
        margin: 0 20px; } }
    @media screen and (max-width: 767px) {
      .p-professionals-block {
        width: auto;
        padding: 6.6vw 0; } }
    .p-professionals-block-ttl {
      text-align: center;
      font-size: 2.0rem;
      font-weight: 700;
      line-height: 1.5;
      color: #66c7bd; }
      @media screen and (max-width: 767px) {
        .p-professionals-block-ttl {
          font-size: 4.9vw; } }
  .p-professionals-lists {
    width: 540px;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 20px auto 0; }
    @media screen and (max-width: 767px) {
      .p-professionals-lists {
        width: auto; } }
  .p-professionals-list {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    flex-flow: column;
    width: 280px;
    height: 280px;
    border: 2px solid #66c7bd;
    border-radius: 100%;
    margin: 0 -10px; }
    @media screen and (max-width: 767px) {
      .p-professionals-list {
        width: 44vw;
        height: 44vw;
        margin: 0 -1.5vw; } }
    .p-professionals-list:first-child {
      margin: 0 130px -50px; }
      @media screen and (max-width: 767px) {
        .p-professionals-list:first-child {
          margin: 0 10vw -8vw; } }
    .p-professionals-list-img {
      display: block;
      flex-shrink: 0;
      width: 62px;
      height: auto;
      margin: 0 auto; }
      @media screen and (max-width: 767px) {
        .p-professionals-list-img {
          width: 9.8vw; } }
    .p-professionals-list-ttl {
      text-align: center;
      font-size: 2.0rem;
      letter-spacing: 0.08em;
      font-weight: 700;
      margin: 0.8em 0 0.4em; }
      @media screen and (max-width: 767px) {
        .p-professionals-list-ttl {
          font-size: 3.4vw;
          line-height: 1.0; } }
      .p-professionals-list-ttl--none {
        letter-spacing: 0; }
    .p-professionals-list-txt {
      text-align: center;
      line-height: 1.5;
      font-size: 1.6rem; }
      @media screen and (max-width: 767px) {
        .p-professionals-list-txt {
          font-size: 2.9vw; } }

.p-message {
  background: #ebefef;
  padding: 80px 0 100px; }
  @media screen and (max-width: 767px) {
    .p-message {
      padding: 10vw 0; } }
  .p-message-block {
    /*
    @include flex(between,start);
    flex-flow: row-reverse;
    */
    overflow: hidden;
    text-align: center;
    background: #fff;
    margin-top: 40px; }
    @media screen and (max-width: 767px) {
      .p-message-block {
        display: block;
        overflow: visible;
        margin-top: 40vw; } }
    .p-message-block-img {
      float: right;
      margin: 0 0 0 35px; }
      @media screen and (max-width: 1320px) and (min-width: 768px) {
        .p-message-block-img {
          width: 34vw; } }
      .p-message-block-img--02 {
        float: left;
        margin: 0 35px 0 0; }
      @media screen and (max-width: 767px) {
        .p-message-block-img {
          float: none;
          width: 60vw;
          margin: -33vw 0 0 0; } }
  .p-message-txt {
    padding: 30px 50px; }
    @media screen and (max-width: 767px) {
      .p-message-txt {
        padding: 7vw 4vw 6vw; } }
    .p-message-txt-ttl {
      font-weight: 700;
      font-size: 1.8rem;
      margin-bottom: 1em; }
    .p-message-txt-letter {
      font-size: 1.4rem; }
      @media screen and (max-width: 767px) {
        .p-message-txt-letter {
          font-size: 4.2vw;
          line-height: 1.625; } }
      .p-message-txt-letter + .p-message-txt-letter {
        margin-top: 0.5em; }
  .p-message-profile {
    margin-top: 90px; }
    @media screen and (max-width: 767px) {
      .p-message-profile {
        margin-top: 5.3vw; } }
    .p-message-profile-ttl {
      text-align: center;
      font-weight: 700;
      font-size: 2.0rem;
      color: #66c7bd;
      margin-bottom: 1em; }
      @media screen and (max-width: 767px) {
        .p-message-profile-ttl {
          font-size: 4.2vw; } }
    .p-message-profile-block {
      width: 800px;
      background: #fff;
      margin: 40px auto 0;
      padding: 25px 110px 20px; }
      @media screen and (max-width: 767px) {
        .p-message-profile-block {
          width: auto;
          margin-top: 9.3vw;
          padding: 6vw 4vw; } }
    .p-message-profile-name {
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
      justify-content: space-between;
      -webkit-align-items: center;
      -ms-flex-align: center;
      align-items: center; }
      @media screen and (max-width: 767px) {
        .p-message-profile-name {
          display: block; } }
    .p-message-profile-txt {
      font-weight: 500; }
      @media screen and (max-width: 767px) {
        .p-message-profile-txt {
          font-size: 3.9vw; }
          .p-message-profile-txt + .p-message-profile-txt {
            border-top: 2px solid #ebefef;
            margin-top: 3vw;
            padding-top: 3vw; } }

.p-number {
  padding: 80px 0 0; }
  @media screen and (max-width: 767px) {
    .p-number {
      padding: 10vw 0 0; } }
  .p-number-data {
    margin-top: 40px; }
