@charset "UTF-8";
@import url(normalize.css);
/* ----------------------------
  PC用CSS
---------------------------- */
@import url(normalize.css);
@import url(normalize.css);
@import url(normalize.css);
@import url(normalize.css);
@import url(normalize.css);
@import url(normalize.css);
.pc {
  display: block; }

.sp {
  display: none; }

.sp_br {
  display: none; }

/*-------------
 mv
-------------*/
.komogomo-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

/* ----------------------------
  PC用CSS
---------------------------- */
/* DEBUG facility-introduction */
.pc {
  display: block; }

.sp {
  display: none; }

.sp_br {
  display: none; }

/*-------------
 mv
-------------*/
.fi-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

/*-------------
 fi-menu
-------------*/
.fi-menu {
  margin: 80px auto; }
  .fi-menu .fi-menu-list {
    width: 1000px;
    display: flex;
    justify-content: center;
    gap: 18px;
    list-style: none;
    padding: 0;
    margin: 0 auto; }
    .fi-menu .fi-menu-list .menu-item a {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-width: 220px;
      padding: 10px 10px;
      color: #fff;
      font-size: 2.2rem;
      font-weight: 400;
      letter-spacing: -0.06em;
      text-decoration: none;
      transition: transform .2s ease, filter .2s ease; }
      .fi-menu .fi-menu-list .menu-item a .arrow {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 26px;
        height: 26px;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.25);
        font-size: 1.8rem;
        line-height: 1;
        padding-bottom: 3px; }
      @media (hover: hover) and (pointer: fine) {
        .fi-menu .fi-menu-list .menu-item a:hover {
          transform: translateY(-2px);
          filter: brightness(1.05); } }
    .fi-menu .fi-menu-list .menu-item.home a {
      background: #dd6b74; }
    .fi-menu .fi-menu-list .menu-item.group a {
      background: #64abcb; }
    .fi-menu .fi-menu-list .menu-item.day a {
      background: #e6ae5b; }
    .fi-menu .fi-menu-list .menu-item.short a {
      background: #87a976; }

/*-------------
 fi-con-01
-------------*/
.fi-con-01 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 0px;
  padding-bottom: 100px;
  position: relative; }
  .fi-con-01 .page-content .fi-con-title {
    width: 1000px;
    margin: 0 auto;
    padding: 8px 0;
    border: 3px solid #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .fi-con-01 .page-content .fi-con-title p {
      margin: 0;
      color: #f09e67;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .fi-con-01 .page-content .tokuyou .tokuyou-title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #dd6b74;
    text-align: center;
    box-sizing: border-box; }
    .fi-con-01 .page-content .tokuyou .tokuyou-title p {
      margin: 0;
      color: #fff;
      font-size: 2.2rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .fi-con-01 .page-content .tokuyou .tokuyou-subtitle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 30px auto 0;
    color: #dd6b74; }
    .fi-con-01 .page-content .tokuyou .tokuyou-subtitle span {
      font-size: 2.0rem;
      font-weight: bold;
      white-space: nowrap;
      letter-spacing: 0.05em; }
    .fi-con-01 .page-content .tokuyou .tokuyou-subtitle::before, .fi-con-01 .page-content .tokuyou .tokuyou-subtitle::after {
      content: "";
      flex: 1;
      height: 1px;
      background-color: currentColor;
      max-width: 200px; }
  .fi-con-01 .page-content .tokuyou .tokuyou-text {
    margin: 30px auto; }
    .fi-con-01 .page-content .tokuyou .tokuyou-text p {
      font-weight: normal;
      line-height: 1.8; }
  .fi-con-01 .page-content .tokuyou .tokuyou-table {
    width: 1000px;
    margin: 0 auto;
    border-collapse: collapse; }
    .fi-con-01 .page-content .tokuyou .tokuyou-table th, .fi-con-01 .page-content .tokuyou .tokuyou-table td {
      padding: 20px;
      border: 1px solid #fff;
      vertical-align: top; }
    .fi-con-01 .page-content .tokuyou .tokuyou-table th {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      background-color: #dd6b74;
      color: #fff;
      width: 220px;
      white-space: nowrap; }
    .fi-con-01 .page-content .tokuyou .tokuyou-table td {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      color: #333;
      background-color: #fff3f4; }
  .fi-con-01 .page-content .group .group-title {
    width: 1000px;
    margin: 60px auto 0;
    padding: 6px 0;
    background-color: #64abcb;
    text-align: center;
    box-sizing: border-box; }
    .fi-con-01 .page-content .group .group-title p {
      margin: 0;
      color: #fff;
      font-size: 2.2rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .fi-con-01 .page-content .group .group-subtitle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 30px auto 0;
    color: #64abcb; }
    .fi-con-01 .page-content .group .group-subtitle span {
      font-size: 2.0rem;
      font-weight: bold;
      white-space: nowrap;
      letter-spacing: 0.05em; }
    .fi-con-01 .page-content .group .group-subtitle::before, .fi-con-01 .page-content .group .group-subtitle::after {
      content: "";
      flex: 1;
      height: 1px;
      background-color: currentColor;
      max-width: 200px; }
  .fi-con-01 .page-content .group .group-text {
    margin: 30px auto; }
    .fi-con-01 .page-content .group .group-text p {
      font-weight: normal;
      line-height: 1.8; }
  .fi-con-01 .page-content .group .group-table {
    width: 1000px;
    margin: 0 auto;
    border-collapse: collapse; }
    .fi-con-01 .page-content .group .group-table th, .fi-con-01 .page-content .group .group-table td {
      padding: 20px;
      border: 1px solid #fff;
      vertical-align: top; }
    .fi-con-01 .page-content .group .group-table th {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      background-color: #64abcb;
      color: #fff;
      width: 220px;
      white-space: nowrap; }
    .fi-con-01 .page-content .group .group-table td {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      color: #333;
      background-color: #ebf9ff; }

/*-------------
 fi-con-02
-------------*/
.fi-con-02 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 0px;
  padding-bottom: 100px;
  position: relative; }
  .fi-con-02 .page-content .fi-con-title {
    width: 1000px;
    margin: 0 auto;
    padding: 8px 0;
    border: 3px solid #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .fi-con-02 .page-content .fi-con-title p {
      margin: 0;
      color: #f09e67;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .fi-con-02 .page-content .day .day-title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #e6ae5b;
    text-align: center;
    box-sizing: border-box; }
    .fi-con-02 .page-content .day .day-title p {
      margin: 0;
      color: #fff;
      font-size: 2.2rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .fi-con-02 .page-content .day .day-subtitle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 30px auto 0;
    color: #e6ae5b; }
    .fi-con-02 .page-content .day .day-subtitle span {
      font-size: 2.0rem;
      font-weight: bold;
      white-space: nowrap;
      letter-spacing: 0.05em; }
    .fi-con-02 .page-content .day .day-subtitle::before, .fi-con-02 .page-content .day .day-subtitle::after {
      content: "";
      flex: 1;
      height: 1px;
      background-color: currentColor;
      max-width: 200px; }
  .fi-con-02 .page-content .day .day-text {
    margin: 30px auto; }
    .fi-con-02 .page-content .day .day-text p {
      font-weight: normal;
      line-height: 1.8; }
  .fi-con-02 .page-content .day .day-table {
    width: 1000px;
    margin: 0 auto;
    border-collapse: collapse; }
    .fi-con-02 .page-content .day .day-table th, .fi-con-02 .page-content .day .day-table td {
      padding: 20px;
      border: 1px solid #fff;
      vertical-align: top; }
    .fi-con-02 .page-content .day .day-table th {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      background-color: #e6ae5b;
      color: #fff;
      width: 220px;
      white-space: nowrap; }
    .fi-con-02 .page-content .day .day-table td {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      color: #333;
      background-color: #fdf9f1; }
  .fi-con-02 .page-content .short .short-title {
    width: 1000px;
    margin: 60px auto 0;
    padding: 6px 0;
    background-color: #87a976;
    text-align: center;
    box-sizing: border-box; }
    .fi-con-02 .page-content .short .short-title p {
      margin: 0;
      color: #fff;
      font-size: 2.2rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .fi-con-02 .page-content .short .short-subtitle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 30px auto 0;
    color: #87a976; }
    .fi-con-02 .page-content .short .short-subtitle span {
      font-size: 2.0rem;
      font-weight: bold;
      white-space: nowrap;
      letter-spacing: 0.05em; }
    .fi-con-02 .page-content .short .short-subtitle::before, .fi-con-02 .page-content .short .short-subtitle::after {
      content: "";
      flex: 1;
      height: 1px;
      background-color: currentColor;
      max-width: 200px; }
  .fi-con-02 .page-content .short .short-text {
    margin: 30px auto; }
    .fi-con-02 .page-content .short .short-text p {
      font-weight: normal;
      line-height: 1.8; }
  .fi-con-02 .page-content .short .short-table {
    width: 1000px;
    margin: 0 auto;
    border-collapse: collapse; }
    .fi-con-02 .page-content .short .short-table th, .fi-con-02 .page-content .short .short-table td {
      padding: 20px;
      border: 1px solid #fff;
      vertical-align: top; }
    .fi-con-02 .page-content .short .short-table th {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      background-color: #87a976;
      color: #fff;
      width: 220px;
      white-space: nowrap; }
    .fi-con-02 .page-content .short .short-table td {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      color: #333;
      background-color: #f7fff3; }

/* ----------------------------
  SP用CSS（768px以下）
---------------------------- */
@media screen and (max-width: 768px) {
  .pc {
    display: none; }

  .sp {
    display: block; }

  /*-------------
   mv
  -------------*/
  .fi-mv {
    background-image: url(../img/bairinen_sp_fv_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center top;
    padding-top: 80px;
    padding-bottom: 40px;
    position: relative; }

  /*-------------
   fi-menu
  -------------*/
  .fi-menu {
    margin: 40px auto; }
    .fi-menu .fi-menu-list {
      width: 100%;
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      justify-content: center;
      gap: 16px;
      list-style: none;
      padding: 0;
      margin: 0 auto; }
      .fi-menu .fi-menu-list .menu-item a {
        display: flex;
        align-items: left;
        justify-content: center;
        gap: 12px;
        min-width: 0;
        width: 100%;
        padding: 10px 6px;
        color: #fff;
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: -0.1em;
        font-weight: bold;
        text-decoration: none;
        transition: transform .2s ease, filter .2s ease; }
        .fi-menu .fi-menu-list .menu-item a .arrow {
          display: inline-flex;
          align-items: center;
          justify-content: center;
          width: 26px;
          height: 26px;
          border-radius: 50%;
          background: rgba(255, 255, 255, 0.25);
          font-size: 1.8rem;
          line-height: 1;
          padding-bottom: 3px; } }
      @media screen and (max-width: 768px) and (hover: hover) and (pointer: fine) {
        .fi-menu .fi-menu-list .menu-item a:hover {
          transform: translateY(-2px);
          filter: brightness(1.05); } }
@media screen and (max-width: 768px) {
      .fi-menu .fi-menu-list .menu-item.home a {
        background: #dd6b74; }
      .fi-menu .fi-menu-list .menu-item.group a {
        background: #64abcb; }
      .fi-menu .fi-menu-list .menu-item.day a {
        background: #e6ae5b; }
      .fi-menu .fi-menu-list .menu-item.short a {
        background: #87a976; }

  /*-------------
   fi-con-01
  -------------*/
  .fi-con-01 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 0px;
    padding-bottom: 80px;
    position: relative; }
    .fi-con-01 .page-content .fi-con-title {
      width: 100%;
      margin: 0 auto;
      padding: 8px 0;
      border: 3px solid #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .fi-con-01 .page-content .fi-con-title p {
        margin: 0;
        color: #f09e67;
        font-size: 2.0rem;
        font-weight: bold; }
    .fi-con-01 .page-content .tokuyou .tokuyou-title {
      width: 100%;
      margin: 20px auto 0;
      padding: 6px 0;
      background-color: #dd6b74;
      text-align: center;
      box-sizing: border-box; }
      .fi-con-01 .page-content .tokuyou .tokuyou-title p {
        margin: 0;
        color: #fff;
        font-size: 1.6rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .fi-con-01 .page-content .tokuyou .tokuyou-subtitle {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      margin: 20px auto 0;
      color: #dd6b74; }
      .fi-con-01 .page-content .tokuyou .tokuyou-subtitle span {
        font-size: 1.6rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .fi-con-01 .page-content .tokuyou .tokuyou-subtitle::before, .fi-con-01 .page-content .tokuyou .tokuyou-subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor; }
    .fi-con-01 .page-content .tokuyou .tokuyou-text {
      margin: 20px auto 40px auto;
      width: 98%; }
      .fi-con-01 .page-content .tokuyou .tokuyou-text p {
        font-weight: bold;
        line-height: 1.6; }
    .fi-con-01 .page-content .tokuyou .tokuyou-table {
      width: 100%;
      margin: 0 auto;
      border-collapse: collapse; }
      .fi-con-01 .page-content .tokuyou .tokuyou-table th, .fi-con-01 .page-content .tokuyou .tokuyou-table td {
        padding: 14px;
        border: 1px solid #fff;
        vertical-align: top; }
      .fi-con-01 .page-content .tokuyou .tokuyou-table th {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        background-color: #dd6b74;
        color: #fff;
        width: auto;
        white-space: nowrap; }
      .fi-con-01 .page-content .tokuyou .tokuyou-table td {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        color: #333;
        background-color: #fff3f4; }
    .fi-con-01 .page-content .group .group-title {
      width: 100%;
      margin: 60px auto 0;
      padding: 6px 0;
      background-color: #64abcb;
      text-align: center;
      box-sizing: border-box; }
      .fi-con-01 .page-content .group .group-title p {
        margin: 0;
        color: #fff;
        font-size: 1.6rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .fi-con-01 .page-content .group .group-subtitle {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      margin: 20px auto 0;
      color: #64abcb; }
      .fi-con-01 .page-content .group .group-subtitle span {
        font-size: 1.6rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .fi-con-01 .page-content .group .group-subtitle::before, .fi-con-01 .page-content .group .group-subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor;
        max-width: 200px; }
    .fi-con-01 .page-content .group .group-text {
      margin: 20px auto 40px auto;
      width: 98%; }
      .fi-con-01 .page-content .group .group-text p {
        font-weight: bold;
        line-height: 1.6; }
    .fi-con-01 .page-content .group .group-table {
      width: 100%;
      margin: 0 auto;
      border-collapse: collapse; }
      .fi-con-01 .page-content .group .group-table th, .fi-con-01 .page-content .group .group-table td {
        padding: 14px;
        border: 1px solid #fff;
        vertical-align: top; }
      .fi-con-01 .page-content .group .group-table th {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        background-color: #64abcb;
        color: #fff;
        width: auto;
        white-space: nowrap; }
      .fi-con-01 .page-content .group .group-table td {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        color: #333;
        background-color: #ebf9ff; }

  /*-------------
   fi-con-02
  -------------*/
  .fi-con-02 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 0px;
    padding-bottom: 100px;
    position: relative; }
    .fi-con-02 .page-content .fi-con-title {
      width: 100%;
      margin: 0 auto;
      padding: 8px 0;
      border: 3px solid #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .fi-con-02 .page-content .fi-con-title p {
        margin: 0;
        color: #f09e67;
        font-size: 2.0rem;
        font-weight: bold; }
    .fi-con-02 .page-content .day .day-title {
      width: 100%;
      margin: 20px auto 0;
      padding: 6px 0;
      background-color: #e6ae5b;
      text-align: center;
      box-sizing: border-box; }
      .fi-con-02 .page-content .day .day-title p {
        margin: 0;
        color: #fff;
        font-size: 1.6rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .fi-con-02 .page-content .day .day-subtitle {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      margin: 20px auto 0;
      color: #e6ae5b; }
      .fi-con-02 .page-content .day .day-subtitle span {
        font-size: 1.6rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .fi-con-02 .page-content .day .day-subtitle::before, .fi-con-02 .page-content .day .day-subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor;
        max-width: 200px; }
    .fi-con-02 .page-content .day .day-text {
      margin: 20px auto 40px auto;
      width: 98%; }
      .fi-con-02 .page-content .day .day-text p {
        font-weight: bold;
        line-height: 1.6; }
    .fi-con-02 .page-content .day .day-table {
      width: 100%;
      margin: 0 auto;
      border-collapse: collapse; }
      .fi-con-02 .page-content .day .day-table th, .fi-con-02 .page-content .day .day-table td {
        padding: 14px;
        border: 1px solid #fff;
        vertical-align: top; }
      .fi-con-02 .page-content .day .day-table th {
        font-size: 1.4em;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        background-color: #e6ae5b;
        color: #fff;
        width: auto;
        white-space: nowrap; }
      .fi-con-02 .page-content .day .day-table td {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        color: #333;
        background-color: #fdf9f1; }
    .fi-con-02 .page-content .short .short-title {
      width: 100%;
      margin: 60px auto 0;
      padding: 6px 0;
      background-color: #87a976;
      text-align: center;
      box-sizing: border-box; }
      .fi-con-02 .page-content .short .short-title p {
        margin: 0;
        color: #fff;
        font-size: 1.6rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .fi-con-02 .page-content .short .short-subtitle {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      margin: 20px auto 0;
      color: #87a976; }
      .fi-con-02 .page-content .short .short-subtitle span {
        font-size: 1.6rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .fi-con-02 .page-content .short .short-subtitle::before, .fi-con-02 .page-content .short .short-subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor;
        max-width: 200px; }
    .fi-con-02 .page-content .short .short-text {
      margin: 20px auto 40px auto;
      width: 98%; }
      .fi-con-02 .page-content .short .short-text p {
        font-weight: bold;
        line-height: 1.6; }
    .fi-con-02 .page-content .short .short-table {
      width: 100%;
      margin: 0 auto;
      border-collapse: collapse; }
      .fi-con-02 .page-content .short .short-table th, .fi-con-02 .page-content .short .short-table td {
        padding: 14px;
        border: 1px solid #fff;
        vertical-align: top; }
      .fi-con-02 .page-content .short .short-table th {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        background-color: #87a976;
        color: #fff;
        width: auto;
        white-space: nowrap; }
      .fi-con-02 .page-content .short .short-table td {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        color: #333;
        background-color: #f7fff3; } }
/* ----------------------------
  PC用CSS
---------------------------- */
.pc {
  display: block; }

.sp {
  display: none; }

.sp_br {
  display: none; }

/*-------------
 mv
-------------*/
.corporation-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

/*-------------
 corporation-con-01
-------------*/
.corporation-con-01 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 40px;
  position: relative; }
  .corporation-con-01 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .corporation-con-01 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .corporation-con-01 .page-content .philosophy-list {
    width: 800px;
    margin: 60px auto 0 auto; }
    .corporation-con-01 .page-content .philosophy-list img {
      display: block; }
    .corporation-con-01 .page-content .philosophy-list .philosophy-list-items {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 40px; }
    .corporation-con-01 .page-content .philosophy-list .philosophy-list-item {
      display: flex;
      align-items: flex-start;
      gap: 30px; }
    .corporation-con-01 .page-content .philosophy-list .philosophy-list-badge {
      width: 100px;
      flex: 0 0 100px; }
      .corporation-con-01 .page-content .philosophy-list .philosophy-list-badge img {
        width: 100%;
        height: auto; }
    .corporation-con-01 .page-content .philosophy-list .philosophy-list-text {
      flex: 1;
      padding-top: 6px; }
      .corporation-con-01 .page-content .philosophy-list .philosophy-list-text p {
        margin: 0;
        text-align: left;
        font-size: 1.6rem;
        line-height: 2.0;
        color: #333; }

/*-------------
 corporation-con-02
-------------*/
.corporation-con-02 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 60px;
  position: relative; }
  .corporation-con-02 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .corporation-con-02 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .corporation-con-02 .page-content .message-item {
    /* ----------------
       reverse（真ん中だけ）
    ---------------- */ }
    .corporation-con-02 .page-content .message-item .subtitle {
      width: 1000px;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 24px;
      margin: 40px auto 0;
      color: #f09e67; }
      .corporation-con-02 .page-content .message-item .subtitle span {
        font-size: 2.0rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .corporation-con-02 .page-content .message-item .subtitle::before, .corporation-con-02 .page-content .message-item .subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor; }
    .corporation-con-02 .page-content .message-item .message-body {
      width: 1000px;
      display: grid;
      grid-template-columns: 360px 1fr;
      gap: 30px;
      align-items: start;
      margin: 30px auto 0 auto; }
      .corporation-con-02 .page-content .message-item .message-body .message-photo {
        width: 360px;
        max-width: 100%; }
        .corporation-con-02 .page-content .message-item .message-body .message-photo img {
          width: 100%;
          height: auto;
          display: block; }
      .corporation-con-02 .page-content .message-item .message-body .message-text {
        font-size: 1.6rem;
        line-height: 1.6;
        color: #333; }
        .corporation-con-02 .page-content .message-item .message-body .message-text p {
          text-align: left;
          margin: 0 0 14px;
          letter-spacing: -0.03em;
          line-height: 1.8; }
        .corporation-con-02 .page-content .message-item .message-body .message-text .message-title {
          margin: 0 0 10px;
          font-size: 2.2rem;
          font-weight: bold; }
        .corporation-con-02 .page-content .message-item .message-body .message-text .message-sign {
          margin-top: 20px;
          text-align: right;
          font-weight: bold;
          font-weight: normal; }
          .corporation-con-02 .page-content .message-item .message-body .message-text .message-sign strong {
            font-size: 1.8rem; }
    .corporation-con-02 .page-content .message-item.is-reverse .message-body {
      grid-template-columns: 1fr 360px; }
    .corporation-con-02 .page-content .message-item.is-reverse .message-photo {
      order: 2; }
    .corporation-con-02 .page-content .message-item.is-reverse .message-text {
      order: 1; }
      .corporation-con-02 .page-content .message-item.is-reverse .message-text .message-sign {
        text-align: left; }

/*-------------
 corporation-con-03
-------------*/
.corporation-con-03 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 60px;
  position: relative; }
  .corporation-con-03 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .corporation-con-03 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .corporation-con-03 .page-content .con-03-text {
    margin: 30px auto 0 auto;
    color: #333;
    font-size: 2.0rem;
    font-weight: bold;
    letter-spacing: 0.1em; }
  .corporation-con-03 .page-content .con-03-img {
    max-width: 1000px;
    margin: 30px auto 0 auto;
    display: flex;
    gap: 0; }
  .corporation-con-03 .page-content .con-03-img img {
    width: 25%;
    height: auto;
    display: block; }
  .corporation-con-03 .page-content .message-item .subtitle {
    width: 1000px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 40px auto 0;
    color: #f09e67; }
    .corporation-con-03 .page-content .message-item .subtitle span {
      font-size: 2.0rem;
      font-weight: bold;
      white-space: nowrap;
      letter-spacing: 0.05em; }
    .corporation-con-03 .page-content .message-item .subtitle::before, .corporation-con-03 .page-content .message-item .subtitle::after {
      content: "";
      flex: 1;
      height: 1px;
      background-color: currentColor; }
  .corporation-con-03 .page-content .message-item .message-body {
    width: 1000px;
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 30px;
    align-items: start;
    margin: 30px auto 0 auto; }
    .corporation-con-03 .page-content .message-item .message-body .message-photo {
      width: 360px;
      max-width: 100%; }
      .corporation-con-03 .page-content .message-item .message-body .message-photo img {
        width: 100%;
        height: auto;
        display: block; }
    .corporation-con-03 .page-content .message-item .message-body .message-text {
      font-size: 1.6rem;
      line-height: 1.6;
      color: #333; }
      .corporation-con-03 .page-content .message-item .message-body .message-text p {
        text-align: left;
        margin: 0 0 14px;
        letter-spacing: -0.03em;
        line-height: 1.8; }
      .corporation-con-03 .page-content .message-item .message-body .message-text .message-sign {
        margin-top: 20px;
        text-align: right;
        font-weight: bold;
        font-weight: normal; }
        .corporation-con-03 .page-content .message-item .message-body .message-text .message-sign strong {
          font-size: 1.8rem; }

/*-------------
 corporation-con-04
-------------*/
.corporation-con-04 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 60px;
  position: relative; }
  .corporation-con-04 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .corporation-con-04 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .corporation-con-04 .page-content .table {
    width: 900px;
    margin: 40px auto 0 auto;
    border-collapse: collapse; }
    .corporation-con-04 .page-content .table th, .corporation-con-04 .page-content .table td {
      padding: 20px;
      border: 1px solid #fff;
      vertical-align: top; }
    .corporation-con-04 .page-content .table th {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      background-color: #dd6b74;
      color: #fff;
      width: 220px;
      white-space: nowrap; }
    .corporation-con-04 .page-content .table td {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      color: #333;
      background-color: #fff3f4; }

/*-------------
 corporation-con-05
-------------*/
.corporation-con-05 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 60px;
  position: relative; }
  .corporation-con-05 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .corporation-con-05 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .corporation-con-05 .page-content .table {
    width: 900px;
    margin: 40px auto 0 auto;
    border-collapse: collapse; }
    .corporation-con-05 .page-content .table th, .corporation-con-05 .page-content .table td {
      padding: 20px;
      border: 1px solid #fff;
      vertical-align: top; }
    .corporation-con-05 .page-content .table th {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      background-color: #dd6b74;
      color: #fff;
      width: 220px;
      white-space: nowrap; }
    .corporation-con-05 .page-content .table td {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: palt;
      vertical-align: middle;
      color: #333;
      background-color: #fff3f4; }

/* ----------------------------
  SP用CSS（768px以下）
---------------------------- */
@media screen and (max-width: 768px) {
  .pc {
    display: none; }

  .sp {
    display: block; }

  /*-------------
   mv
  -------------*/
  .corporation-mv {
    background-image: url(../img/bairinen_sp_fv_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center top;
    padding-top: 80px;
    padding-bottom: 40px;
    position: relative; }

  /*-------------
   corporation-con-01
  -------------*/
  .corporation-con-01 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 40px;
    position: relative; }
    .corporation-con-01 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .corporation-con-01 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .corporation-con-01 .page-content .philosophy-list {
      width: 100%;
      margin: 60px auto 0 auto; }
      .corporation-con-01 .page-content .philosophy-list img {
        display: block; }
      .corporation-con-01 .page-content .philosophy-list .philosophy-list-items {
        list-style: none;
        padding: 0;
        margin: 0;
        display: grid;
        gap: 40px; }
      .corporation-con-01 .page-content .philosophy-list .philosophy-list-item {
        display: flex;
        align-items: flex-start;
        gap: 30px; }
      .corporation-con-01 .page-content .philosophy-list .philosophy-list-badge {
        width: 80px;
        flex: 0 0 80px; }
        .corporation-con-01 .page-content .philosophy-list .philosophy-list-badge img {
          width: 100%;
          height: auto; }
      .corporation-con-01 .page-content .philosophy-list .philosophy-list-text {
        flex: 1;
        padding-top: 6px; }
        .corporation-con-01 .page-content .philosophy-list .philosophy-list-text p {
          margin: 0;
          text-align: left;
          font-size: 1.4rem;
          line-height: 1.8;
          color: #333; }

  /*-------------
   corporation-con-02
  -------------*/
  .corporation-con-02 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 20px;
    position: relative; }
    .corporation-con-02 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .corporation-con-02 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .corporation-con-02 .page-content .message-item {
      /* ----------------
         reverse（真ん中だけ）
         でも縦統一したいので「無効化」する
      ---------------- */ }
      .corporation-con-02 .page-content .message-item .subtitle {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 24px;
        margin: 30px auto 0;
        color: #f09e67; }
        .corporation-con-02 .page-content .message-item .subtitle span {
          font-size: 1.6rem;
          font-weight: bold;
          white-space: nowrap;
          letter-spacing: 0.05em; }
        .corporation-con-02 .page-content .message-item .subtitle::before, .corporation-con-02 .page-content .message-item .subtitle::after {
          content: "";
          flex: 1;
          height: 1px;
          background-color: currentColor; }
      .corporation-con-02 .page-content .message-item .message-body {
        width: 100%;
        display: flex;
        flex-direction: column;
        gap: 20px;
        align-items: start;
        margin: 30px auto 0 auto; }
        .corporation-con-02 .page-content .message-item .message-body .message-photo {
          width: 86%;
          max-width: 100%;
          margin: 0 auto; }
          .corporation-con-02 .page-content .message-item .message-body .message-photo img {
            width: 100%;
            height: auto;
            display: block; }
        .corporation-con-02 .page-content .message-item .message-body .message-text {
          width: 96%;
          font-size: 1.4rem;
          line-height: 1.6;
          color: #333;
          margin: 0 auto; }
          .corporation-con-02 .page-content .message-item .message-body .message-text p {
            text-align: left;
            margin: 0 0 14px;
            letter-spacing: -0.03em;
            line-height: 1.6; }
          .corporation-con-02 .page-content .message-item .message-body .message-text .message-title {
            margin: 0 0 10px;
            font-size: 1.6rem;
            font-weight: bold; }
          .corporation-con-02 .page-content .message-item .message-body .message-text .message-sign {
            margin-top: 20px;
            text-align: right;
            font-weight: normal; }
            .corporation-con-02 .page-content .message-item .message-body .message-text .message-sign strong {
              font-size: 1.6rem; }
      .corporation-con-02 .page-content .message-item.is-reverse .message-body {
        display: flex;
        flex-direction: column; }
      .corporation-con-02 .page-content .message-item.is-reverse .message-photo {
        order: 1; }
      .corporation-con-02 .page-content .message-item.is-reverse .message-text {
        order: 2; }
        .corporation-con-02 .page-content .message-item.is-reverse .message-text .message-sign {
          text-align: right; }

  /*-------------
   corporation-con-03
  -------------*/
  .corporation-con-03 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 20px;
    position: relative; }
    .corporation-con-03 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .corporation-con-03 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .corporation-con-03 .page-content .con-03-text {
      margin: 30px auto 0 auto;
      color: #333;
      font-size: 1.4rem;
      font-weight: bold; }
    .corporation-con-03 .page-content .con-03-img {
      width: 80%;
      margin: 20px auto 0 auto;
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 10px; }
    .corporation-con-03 .page-content .con-03-img img {
      width: 100%;
      height: auto;
      display: block; }
    .corporation-con-03 .page-content .message-item .subtitle {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 24px;
      margin: 30px auto 0;
      color: #f09e67; }
      .corporation-con-03 .page-content .message-item .subtitle span {
        font-size: 1.6rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .corporation-con-03 .page-content .message-item .subtitle::before, .corporation-con-03 .page-content .message-item .subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor; }
    .corporation-con-03 .page-content .message-item .message-body {
      width: 100%;
      display: flex;
      flex-direction: column;
      gap: 20px;
      align-items: start;
      margin: 30px auto 0 auto; }
      .corporation-con-03 .page-content .message-item .message-body .message-photo {
        width: 86%;
        max-width: 100%;
        margin: 0 auto; }
        .corporation-con-03 .page-content .message-item .message-body .message-photo img {
          width: 100%;
          height: auto;
          display: block; }
      .corporation-con-03 .page-content .message-item .message-body .message-text {
        width: 96%;
        font-size: 1.4rem;
        line-height: 1.6;
        color: #333;
        margin: 0 auto; }
        .corporation-con-03 .page-content .message-item .message-body .message-text p {
          text-align: left;
          margin: 0 0 14px;
          letter-spacing: -0.03em;
          line-height: 1.6; }
        .corporation-con-03 .page-content .message-item .message-body .message-text .message-title {
          margin: 0 0 10px;
          font-size: 1.6rem;
          font-weight: bold; }
        .corporation-con-03 .page-content .message-item .message-body .message-text .message-sign {
          margin-top: 20px;
          text-align: right;
          font-weight: normal; }
          .corporation-con-03 .page-content .message-item .message-body .message-text .message-sign strong {
            font-size: 1.6rem; }

  /*-------------
   corporation-con-04
  -------------*/
  .corporation-con-04 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 20px;
    position: relative; }
    .corporation-con-04 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .corporation-con-04 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .corporation-con-04 .page-content .table {
      width: 100%;
      margin: 40px auto 0 auto;
      border-collapse: collapse; }
      .corporation-con-04 .page-content .table th, .corporation-con-04 .page-content .table td {
        padding: 14px;
        border: 1px solid #fff;
        vertical-align: top; }
      .corporation-con-04 .page-content .table th {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        background-color: #dd6b74;
        color: #fff;
        width: auto;
        white-space: nowrap; }
      .corporation-con-04 .page-content .table td {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        color: #333;
        background-color: #fff3f4; }

  /*-------------
   corporation-con-05
  -------------*/
  .corporation-con-05 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 60px;
    position: relative; }
    .corporation-con-05 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .corporation-con-05 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .corporation-con-05 .page-content .table {
      width: 100%;
      margin: 40px auto 0 auto;
      border-collapse: collapse; }
      .corporation-con-05 .page-content .table th, .corporation-con-05 .page-content .table td {
        padding: 14px;
        border: 1px solid #fff;
        vertical-align: top; }
      .corporation-con-05 .page-content .table th {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        background-color: #dd6b74;
        color: #fff;
        width: auto;
        white-space: nowrap; }
      .corporation-con-05 .page-content .table td {
        font-size: 1.4rem;
        text-align: left;
        letter-spacing: palt;
        vertical-align: middle;
        color: #333;
        background-color: #fff3f4; } }
/* ----------------------------
  PC用CSS
---------------------------- */
.pc {
  display: block; }

.sp {
  display: none; }

.sp_br {
  display: none; }

/*-------------
 mv
-------------*/
.fs-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

/* ----------------------------
  PC用CSS
---------------------------- */
.pc {
  display: block; }

.sp {
  display: none; }

.sp_br {
  display: none; }

/*-------------
 mv
-------------*/
.apply-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

/* ----------------------------
  PC用CSS
---------------------------- */
.pc {
  display: block; }

.sp {
  display: none; }

/*-------------
 mv
-------------*/
.recruit-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

/*-------------
 recruit-con-01
-------------*/
.recruit-con-01 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 40px;
  position: relative; }
  .recruit-con-01 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .recruit-con-01 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .recruit-con-01 .page-content .message-item .subtitle {
    width: 1000px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 40px auto 0;
    color: #f09e67; }
    .recruit-con-01 .page-content .message-item .subtitle span {
      font-size: 2.0rem;
      font-weight: bold;
      white-space: nowrap;
      letter-spacing: 0.05em; }
    .recruit-con-01 .page-content .message-item .subtitle::before, .recruit-con-01 .page-content .message-item .subtitle::after {
      content: "";
      flex: 1;
      height: 1px;
      background-color: currentColor; }
  .recruit-con-01 .page-content .message-item .message-title {
    margin: 0 0 10px;
    font-size: 1.8rem;
    font-weight: bold;
    margin: 30px auto 0 auto; }
  .recruit-con-01 .page-content .message-item .message-body {
    width: 1000px;
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 30px;
    align-items: start;
    margin: 30px auto 0 auto; }
    .recruit-con-01 .page-content .message-item .message-body .message-photo {
      width: 360px;
      max-width: 100%; }
      .recruit-con-01 .page-content .message-item .message-body .message-photo img {
        width: 100%;
        height: auto;
        display: block; }
    .recruit-con-01 .page-content .message-item .message-body .message-text {
      font-size: 1.6rem;
      line-height: 1.6;
      color: #333; }
      .recruit-con-01 .page-content .message-item .message-body .message-text p {
        text-align: left;
        margin: 0 0 14px;
        letter-spacing: -0.03em;
        line-height: 1.8; }

/*-------------
 recruit-con-02
-------------*/
.recruit-con-02 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 40px;
  position: relative; }
  .recruit-con-02 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .recruit-con-02 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .recruit-con-02 .page-content .message-title {
    margin: 0 0 10px;
    font-size: 1.8rem;
    font-weight: bold;
    margin: 30px auto 0 auto; }
  .recruit-con-02 .page-content .point {
    width: 1000px;
    margin: 30px auto 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px; }
    .recruit-con-02 .page-content .point img {
      width: 100%;
      max-width: calc((1000px - 40px) / 3);
      height: auto;
      display: block; }
  .recruit-con-02 .page-content .point-img {
    margin: 60px auto 0 auto; }
  .recruit-con-02 .page-content .img-list {
    max-width: 1000px;
    margin: 60px auto 30px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px; }
    .recruit-con-02 .page-content .img-list img {
      width: 100%;
      height: auto;
      display: block; }

/*-------------
 recruit-con-03
-------------*/
.recruit-con-03 {
  background-color: #fff;
  background-repeat: no-repeat;
  padding-top: 60px;
  padding-bottom: 100px;
  position: relative; }
  .recruit-con-03 .page-content .title {
    width: 1000px;
    margin: 40px auto 0;
    padding: 6px 0;
    background-color: #f09e67;
    text-align: center;
    box-sizing: border-box; }
    .recruit-con-03 .page-content .title p {
      margin: 0;
      color: #fff;
      font-size: 2.4rem;
      font-weight: bold;
      letter-spacing: 0.1em; }
  .recruit-con-03 .page-content .message-title {
    margin: 0 0 10px;
    font-size: 1.8rem;
    font-weight: bold;
    margin: 30px auto 0 auto; }
  .recruit-con-03 .page-content .step {
    width: 1000px;
    margin: 30px auto 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px; }
    .recruit-con-03 .page-content .step img {
      width: 100%;
      max-width: calc((1000px - 40px) / 3);
      height: auto;
      display: block; }
  .recruit-con-03 .page-content .step-img {
    margin: 60px auto 0 auto; }

/*-------------
 recruit-con-04
-------------*/
.recruit-con-04 {
  background-color: #fff3f4;
  background-repeat: no-repeat;
  padding-top: 40px;
  padding-bottom: 40px;
  position: relative; }
  .recruit-con-04 .page-content .recruit-img {
    margin: 0 auto; }
    .recruit-con-04 .page-content .recruit-img img {
      width: auto; }
  .recruit-con-04 .page-content .recruit-btn {
    margin: -120px auto 0 auto; }

/* ----------------------------
  SP用CSS（768px以下）
---------------------------- */
@media screen and (max-width: 768px) {
  .pc {
    display: none !important; }

  .sp {
    display: block !important; }

  /*-------------
   mv
  -------------*/
  .recruit-mv {
    background-image: url(../img/bairinen_sp_fv_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center top;
    padding-top: 80px;
    padding-bottom: 40px;
    position: relative; }

  /*-------------
   recruit-con-01
  -------------*/
  .recruit-con-01 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 40px;
    position: relative; }
    .recruit-con-01 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .recruit-con-01 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .recruit-con-01 .page-content .message-item .subtitle {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 24px;
      margin: 30px auto 0;
      color: #f09e67; }
      .recruit-con-01 .page-content .message-item .subtitle span {
        font-size: 1.6rem;
        font-weight: bold;
        white-space: nowrap;
        letter-spacing: 0.05em; }
      .recruit-con-01 .page-content .message-item .subtitle::before, .recruit-con-01 .page-content .message-item .subtitle::after {
        content: "";
        flex: 1;
        height: 1px;
        background-color: currentColor; }
    .recruit-con-01 .page-content .message-item .message-title {
      margin: 20px 0 10px;
      font-size: 1.6rem;
      font-weight: bold; }
    .recruit-con-01 .page-content .message-item .message-body {
      width: 100%;
      display: flex;
      flex-direction: column;
      gap: 20px;
      align-items: start;
      margin: 30px auto 0 auto; }
      .recruit-con-01 .page-content .message-item .message-body .message-photo {
        width: 86%;
        max-width: 100%;
        margin: 0 auto; }
        .recruit-con-01 .page-content .message-item .message-body .message-photo img {
          width: 100%;
          height: auto;
          display: block; }
      .recruit-con-01 .page-content .message-item .message-body .message-text {
        width: 96%;
        font-size: 1.4rem;
        line-height: 1.6;
        color: #333;
        margin: 0 auto; }
        .recruit-con-01 .page-content .message-item .message-body .message-text p {
          text-align: left;
          margin: 0 0 14px;
          letter-spacing: -0.03em;
          line-height: 1.6; }

  /*-------------
   recruit-con-02
  -------------*/
  .recruit-con-02 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 40px;
    padding-bottom: 40px;
    position: relative; }
    .recruit-con-02 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .recruit-con-02 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .recruit-con-02 .page-content .message-title {
      margin: 20px 0 10px;
      font-size: 1.6rem;
      font-weight: bold; }
    .recruit-con-02 .page-content .point {
      width: 84%;
      flex-direction: column;
      gap: 20px; }
      .recruit-con-02 .page-content .point img {
        width: 100%;
        max-width: 100%; }
    .recruit-con-02 .page-content .point-img {
      width: 100%;
      margin: 40px auto 0 auto; }
      .recruit-con-02 .page-content .point-img img {
        width: 100%; }
    .recruit-con-02 .page-content .img-list {
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
      margin: 30px auto 0 auto; }

  /*-------------
   recruit-con-03
  -------------*/
  .recruit-con-03 {
    background-color: #fff;
    background-repeat: no-repeat;
    padding-top: 60px;
    padding-bottom: 40px;
    position: relative; }
    .recruit-con-03 .page-content .title {
      width: 100%;
      margin: 0 auto;
      padding: 6px 0;
      background-color: #f09e67;
      text-align: center;
      box-sizing: border-box; }
      .recruit-con-03 .page-content .title p {
        margin: 0;
        color: #fff;
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.1em; }
    .recruit-con-03 .page-content .step {
      width: 84%;
      flex-direction: column;
      gap: 20px; }
      .recruit-con-03 .page-content .step img {
        width: 100%;
        max-width: 100%; }
    .recruit-con-03 .page-content .step-img {
      width: 100%;
      margin: 40px auto 0 auto; }
      .recruit-con-03 .page-content .step-img img {
        width: 100%; }

  /*-------------
   recruit-con-04
  -------------*/
  .recruit-con-04 {
    background-color: #fff3f4;
    background-repeat: no-repeat;
    padding-top: 30px;
    padding-bottom: 30px;
    position: relative; }
    .recruit-con-04 .page-content .recruit-img {
      margin: 0 auto; }
      .recruit-con-04 .page-content .recruit-img img {
        width: 100%; }
    .recruit-con-04 .page-content .recruit-btn {
      margin: -20px auto 0 auto; }
      .recruit-con-04 .page-content .recruit-btn img {
        width: 80%; } }
/* ----------------------------
  PC用CSS
---------------------------- */
.pc {
  display: block; }

.sp {
  display: none; }

.sp_br {
  display: none; }

/*-------------
 mv
-------------*/
.contact-mv {
  background-image: url(../img/bairinen_pc_top_fv_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-top: 120px;
  padding-bottom: 40px;
  position: relative; }

.contact-form .page-content .contact-form-wrap {
  width: 1000px;
  margin: 60px auto; }
  .contact-form .page-content .contact-form-wrap .form-row {
    display: flex;
    align-items: center;
    margin-bottom: 40px;
    background: none; }
    .contact-form .page-content .contact-form-wrap .form-row.textarea-row {
      align-items: flex-start; }
      .contact-form .page-content .contact-form-wrap .form-row.textarea-row .form-field textarea {
        min-height: 160px;
        border-bottom: 1px solid #ccc !important; }
    .contact-form .page-content .contact-form-wrap .form-row.submit_btn {
      width: 100%;
      margin: 0 auto;
      display: flex;
      justify-content: center; }
      .contact-form .page-content .contact-form-wrap .form-row.submit_btn p {
        margin: 0 auto;
        display: flex;
        justify-content: center; }
      .contact-form .page-content .contact-form-wrap .form-row.submit_btn input[type="submit"] {
        width: 300px;
        display: inline-block;
        background-color: #f09e67;
        color: #fff;
        font-weight: bold;
        font-size: 1.8rem;
        padding: 12px 60px;
        border: none;
        border-radius: 4px;
        cursor: pointer;
        transition: background 0.3s; }
        .contact-form .page-content .contact-form-wrap .form-row.submit_btn input[type="submit"]:hover {
          opacity: 0.9; }
      .contact-form .page-content .contact-form-wrap .form-row.submit_btn .wpcf7-spinner {
        display: none !important; }
    .contact-form .page-content .contact-form-wrap .form-row .form-label p {
      width: 300px;
      font-weight: bold;
      font-size: 1.8rem;
      color: #333;
      text-align: left; }
    .contact-form .page-content .contact-form-wrap .form-row .form-label .wpcf7-required {
      display: inline-block;
      background-color: #da3832;
      color: #fff;
      font-size: 1.4rem;
      padding: 2px 4px;
      margin-left: 8px;
      border-radius: 4px; }
    .contact-form .page-content .contact-form-wrap .form-row .form-field {
      flex: 1; }
      .contact-form .page-content .contact-form-wrap .form-row .form-field input,
      .contact-form .page-content .contact-form-wrap .form-row .form-field textarea,
      .contact-form .page-content .contact-form-wrap .form-row .form-field select {
        width: 580px;
        padding: 10px;
        border: 1px solid #ccc;
        border-radius: 4px;
        font-size: 1.6rem;
        box-shadow: none; }
      .contact-form .page-content .contact-form-wrap .form-row .form-field textarea {
        min-height: 160px; }
.contact-form .wpcf7-response-output {
  margin: 2em 0.5em 1em;
  padding: 0.2em 1em;
  border: 2px solid #f09e67;
  font-size: 2.2rem; }

/* ----------------------------
  SP用CSS（768px以下）
---------------------------- */
@media screen and (max-width: 768px) {
  .pc {
    display: none !important; }

  .sp {
    display: block !important; }

  /*-------------
   mv
  -------------*/
  .contact-mv {
    background-image: url(../img/bairinen_sp_fv_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center top;
    padding-top: 80px;
    padding-bottom: 40px;
    position: relative; }

  .contact-form .page-content .contact-form-wrap {
    width: 98%;
    margin: 60px auto; }
    .contact-form .page-content .contact-form-wrap .form-row {
      flex-direction: column;
      align-items: flex-start; }
      .contact-form .page-content .contact-form-wrap .form-row .form-label {
        width: 100%;
        margin-bottom: 10px; }
        .contact-form .page-content .contact-form-wrap .form-row .form-label p {
          width: auto;
          font-size: 1.6rem; }
        .contact-form .page-content .contact-form-wrap .form-row .form-label .wpcf7-required {
          font-size: 1.2rem; }
      .contact-form .page-content .contact-form-wrap .form-row .form-field {
        width: 100%;
        margin: 0 auto; }
        .contact-form .page-content .contact-form-wrap .form-row .form-field input,
        .contact-form .page-content .contact-form-wrap .form-row .form-field textarea,
        .contact-form .page-content .contact-form-wrap .form-row .form-field select {
          width: 100%;
          padding: 10px;
          font-size: 1.8rem; }
      .contact-form .page-content .contact-form-wrap .form-row.submit_btn {
        align-items: center;
        justify-content: center; }
        .contact-form .page-content .contact-form-wrap .form-row.submit_btn input[type="submit"] {
          width: 100%;
          font-size: 1.6rem;
          padding: 10px 20px; }
  .contact-form .page-content .wpcf7-response-output {
    margin: 2em 0.5em 1em;
    padding: 0.2em 1em;
    border: 2px solid #f09e67;
    font-size: 2.0rem; } }

/*# sourceMappingURL=pages.css.map */
