@charset "UTF-8";
body {
  padding: 90px 0 0; }

/*max-width:1280px*/
@media (max-width: 1024px) {
  body {
    padding: 105px 0 0; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  body {
    padding: 80px 0 0 0; } }
/*max-width:480px*/
@media (max-width: 480px) {
  body {
    padding: 80px 0 0 0; } }
/*max-width:480px*/
/*****************/
header {
  transition: opacity .3s;
  position: fixed;
  z-index: 9999;
  top: 50px;
  left: 70px; }
  header .header_box {
    transition: .3s; }
    header .header_box.hide {
      opacity: 0;
      pointer-events: none; }
    header .header_box h1 {
      margin: 0 0 40px; }
      header .header_box h1 a {
        transition: .3s;
        position: relative;
        padding: 50px 0 0;
        background: url("../images/logo.svg") top left no-repeat;
        background-size: auto 40px;
        display: block;
        width: fit-content;
        font: 2.3rem/1em "Noto Sans", "sans-serif";
        font-weight: 600;
        letter-spacing: 0.08em;
        color: #4F4F4F; }
    header .header_box p {
      margin: -25px 0 60px;
      color: #2E5287;
      font: 4.3rem/1em "Poppins", "sans-serif";
      font-weight: 600;
      letter-spacing: 0.08em; }
    header .header_box .header_box_recruit a {
      transition: .3s;
      padding: 0 0 0 25px;
      font: 1.6rem/1em "Noto Sans", "sans-serif";
      font-weight: 500;
      letter-spacing: 0.08em;
      color: #2E5287;
      position: relative; }
      header .header_box .header_box_recruit a:before {
        display: block;
        position: absolute;
        content: "";
        width: 8px;
        height: 8px;
        background-color: #F29600;
        top: 8px;
        left: 2px; }
    header .header_box .btn {
      display: block;
      width: 140px;
      height: 40px;
      border-radius: 5px;
      position: relative;
      font: 1.6rem/38px "Noto Sans", "sans-serif";
      font-weight: 500;
      padding: 0 0 0 15px;
      letter-spacing: 0.08em;
      color: #2E5287;
      border: 1px solid #2E5287; }
      header .header_box .btn:before {
        position: absolute;
        content: "";
        top: 15px;
        right: 15px;
        width: 8px;
        height: 8px;
        border-top: 3px solid #F29600;
        border-right: 3px solid #F29600;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
    header .header_box li {
      margin: 0 0 23px; }
      header .header_box li .parent {
        transition: .3s;
        padding: 0 0 0 25px;
        font: 1.6rem/1em "Noto Sans", "sans-serif";
        font-weight: 500;
        letter-spacing: 0.08em;
        color: #2E5287;
        position: relative; }
        header .header_box li .parent:before {
          display: block;
          position: absolute;
          content: "";
          width: 8px;
          height: 8px;
          background-color: #F29600;
          top: 7px;
          left: 2px; }
      header .header_box li .sub {
        padding: 20px 0 20px;
        display: none; }
        header .header_box li .sub.active {
          display: block; }
        header .header_box li .sub a {
          color: #858585;
          display: block;
          width: object-fit;
          padding: 0 0 0 25px;
          font: 1.5rem/1em "Noto Sans", "sans-serif";
          font-weight: 400;
          letter-spacing: 0.08em;
          margin: 0 0 20px; }
          header .header_box li .sub a.current {
            color: #0091DB; }
          header .header_box li .sub a:last-of-type {
            margin: 0; }

@media (hover: hover) {
  header .header_box h1 {
    margin: 0 0 40px; }
    header .header_box h1 a:hover {
      color: #F29600; }
  header .header_box p {
    margin: -25px 0 60px;
    color: #2E5287;
    font: 4.3rem/1em "Poppins", "sans-serif";
    font-weight: 600;
    letter-spacing: 0.08em; }
  header .header_box .header_box_recruit a:hover {
    color: #F29600; }
  header .header_box .btn:hover {
    color: #F29600; }
  header .header_box li {
    margin: 0 0 23px; }
    header .header_box li .parent:hover {
      color: #F29600; }
    header .header_box li .sub a:hover {
      color: #F29600; } }
@media (max-width: 1280px) {
  header {
    position: fixed;
    z-index: 9999;
    top: 40px;
    left: 40px; }
    header .header_box {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: flex-start;
      align-items: center;
      width: 100%; }
      header .header_box.hide {
        opacity: 1;
        pointer-events: all; }
      header .header_box p {
        margin: 0 0 0 15px;
        color: #2E5287;
        font: 4rem/1em "Poppins", "sans-serif";
        font-weight: 600;
        letter-spacing: 0.08em; }
      header .header_box .btn {
        display: none; }
      header .header_box h1 {
        margin: 0; }
        header .header_box h1 a {
          padding: 0 0 0 90px;
          background: url("../images/logo.svg") center left no-repeat;
          background-size: auto 40px;
          font: 2.4rem/40px "Noto Sans", "sans-serif";
          font-weight: 500;
          height: 40px; }
      header .header_box ul {
        display: none; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  header {
    top: 0;
    left: 0;
    transition: .3s;
    width: 100%;
    background-color: #fff;
    height: 105px; }
    header .header_box {
      height: 100%;
      padding: 0 0 0 25px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  header {
    width: 100%;
    height: 80px;
    top: 0;
    left: 0; }
    header .header_box {
      height: 100%;
      padding: 0 0 0 25px;
      display: flex;
      flex-direction: column;
      flex-wrap: wrap;
      justify-content: center;
      align-items: flex-start; }
      header .header_box p {
        display: none; }
      header .header_box h1 a {
        padding: 0 0 0 90px;
        background: url("../images/logo.svg") center left no-repeat;
        background-size: auto 40px;
        font: 2.4rem/40px "Noto Sans", "sans-serif";
        font-weight: 500;
        height: 40px; }
      header .header_box ul {
        display: none; }
    header.active {
      background-color: #fff; } }
/*max-width:768px*/
@media (max-width: 480px) {
  header {
    height: 80px; }
    header .header_box {
      padding: 0 0 0 15px; }
      header .header_box h1 a {
        padding: 0 0 0 70px;
        background: url("../images/logo.svg") center left no-repeat;
        background-size: auto 32px;
        font: 2.2rem/32px "Noto Sans", "sans-serif";
        font-weight: 500;
        height: 32px; } }
/*max-width:480px*/
/*****************/
.gnav {
  width: 100%;
  height: 100vh;
  overflow-y: scroll;
  background-color: white;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  inset: 0;
  -ms-overflow-style: none;
  scrollbar-width: none;
  transition: .3s;
  z-index: -1;
  pointer-events: none;
  visibility: hidden;
  opacity: 0; }
  .gnav::-webkit-scrollbar {
    display: none; }
  .gnav.active {
    width: 100%;
    opacity: 1;
    z-index: 999;
    pointer-events: all;
    visibility: visible; }
  .gnav nav {
    padding: 200px 0 120px;
    max-width: 1024px;
    width: calc(100% - 100px);
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start; }
    .gnav nav a, .gnav nav span {
      display: block;
      width: fit-content;
      position: relative;
      color: #2E5287; }
    .gnav nav .normal {
      font: 1.5rem/1.5em "Noto Sans", "sans-serif";
      font-weight: 500;
      margin: 0 0 20px; }
    .gnav nav .dot {
      font: 1.4rem/1.5em "Noto Sans", "sans-serif";
      font-weight: 400;
      margin: 0 0 15px;
      padding: 0 0 0 17px; }
      .gnav nav .dot:before {
        position: absolute;
        content: "";
        display: block;
        border-radius: 50px;
        background-color: #0091DB;
        width: 10px;
        height: 10px;
        left: 0;
        top: 6px; }

@media (max-width: 1024px) {
  .gnav nav {
    padding: 150px 0 120px;
    max-width: 480px;
    width: calc(100% - 80px);
    margin: 0 auto;
    display: block; }
    .gnav nav a, .gnav nav span {
      display: block;
      width: 100%;
      position: relative;
      color: #2E5287; }
      .gnav nav a br, .gnav nav span br {
        display: none; }
    .gnav nav ul {
      border-bottom: 1px solid #ccc; }
      .gnav nav ul:last-of-type li {
        border-bottom: 1px solid #ccc; }
      .gnav nav ul li {
        border-bottom: 1px dashed #ccc; }
        .gnav nav ul li:last-of-type {
          border-bottom: none; }
    .gnav nav .normal {
      font: 1.8rem/1.5em "Noto Sans", "sans-serif";
      font-weight: 500;
      margin: 0;
      padding: 20px 0 20px; }
    .gnav nav .dot {
      font: 1.6rem/1.5em "Noto Sans", "sans-serif";
      font-weight: 400;
      margin: 0;
      padding: 20px 0 20px 45px; }
      .gnav nav .dot:before {
        width: 8px;
        height: 8px;
        left: 23px;
        top: 28px; } }
@media (max-width: 768px) {
  .gnav nav {
    padding: 75px 0 120px;
    max-width: 480px;
    width: calc(100% - 80px);
    margin: 0 auto;
    display: block; } }
@media (max-width: 480px) {
  .gnav nav {
    padding: 65px 0 120px;
    max-width: 480px;
    width: calc(100% - 60px);
    margin: 0 auto;
    display: block; }
    .gnav nav .dot {
      font: 1.4rem/1.5em "Noto Sans", "sans-serif";
      font-weight: 400;
      margin: 0;
      padding: 15px 0 15px 20px; }
      .gnav nav .dot:before {
        width: 8px;
        height: 8px;
        left: 3px;
        top: 21px; } }
/*****************/
aside > div {
  position: fixed; }
aside .toggle {
  z-index: 9999;
  top: 50px;
  right: 25px;
  display: block;
  width: 86px;
  height: 86px;
  background: #2E5287;
  border-radius: 50px; }
  aside .toggle span {
    transition: .3s;
    display: block;
    width: 37px;
    height: 4px;
    position: absolute;
    background-color: #fff; }
    aside .toggle span:nth-of-type(1) {
      top: 37%;
      left: 50%;
      transform: translate(-50%, -50%); }
    aside .toggle span:nth-of-type(2) {
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
    aside .toggle span:nth-of-type(3) {
      top: 63%;
      left: 50%;
      transform: translate(-50%, -50%); }
  aside .toggle.active span:nth-of-type(1) {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-45deg); }
  aside .toggle.active span:nth-of-type(2) {
    opacity: 0; }
  aside .toggle.active span:nth-of-type(3) {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg); }
aside .side_menu {
  z-index: 7777;
  top: 150px;
  right: 25px; }
  aside .side_menu a {
    transition: .3s;
    font: 1.4rem/1em "Noto Sans", "sans-serif";
    font-weight: 700;
    color: #fff;
    border-radius: 50px;
    display: block;
    width: 86px;
    height: 86px;
    text-align: center; }
    aside .side_menu a span {
      padding: 55px 0 0;
      display: block;
      width: 100%; }
    aside .side_menu a.side_contact {
      background: #0091DB;
      margin: 0 0 10px; }
      aside .side_menu a.side_contact span {
        background: url("../images/common/icon_mail.svg") center bottom 25px no-repeat; }
    aside .side_menu a.side_recruit {
      background: #F29600; }
      aside .side_menu a.side_recruit span {
        background: url("../images/common/icon_recruit.svg") center bottom 25px no-repeat; }

@media (hover: hover) {
  aside .toggle:hover {
    cursor: pointer; }
    aside .toggle:hover span:nth-of-type(2) {
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%) rotate(25deg); }
  aside .side_menu a:hover {
    transform: rotate(25deg); } }
@media (max-width: 1280px) {
  aside .toggle,
  aside .side_menu {
    right: 20px; } }
@media (max-width: 1024px) {
  aside .toggle {
    top: 15px;
    right: 25px;
    width: 70px;
    height: 70px;
    border-radius: 50px; }
    aside .toggle span {
      display: block;
      width: 35px;
      height: 4px;
      position: absolute;
      background-color: #fff; }
      aside .toggle span:nth-of-type(1) {
        top: 37%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        /* Safari用 */
        transform: translate(-50%, -50%); }
      aside .toggle span:nth-of-type(2) {
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        /* Safari用 */
        transform: translate(-50%, -50%); }
      aside .toggle span:nth-of-type(3) {
        top: 63%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        /* Safari用 */
        transform: translate(-50%, -50%); }
  aside .side_menu {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    top: auto;
    bottom: -70px;
    right: auto;
    left: 0;
    transition: .3s; }
    aside .side_menu.active {
      bottom: 0; }
    aside .side_menu a {
      font: 2rem/71px "Noto Sans", "sans-serif";
      font-weight: 700;
      border-radius: 0;
      width: calc((100% - 70px)/2);
      height: 70px; }
      aside .side_menu a span {
        display: block;
        width: fit-content;
        margin: 0 auto; }
      aside .side_menu a.side_contact {
        margin: 0; }
        aside .side_menu a.side_contact span {
          padding: 0 10px 0 45px;
          background: url("../images/common/icon_mail.svg") center left no-repeat; }
      aside .side_menu a.side_recruit span {
        padding: 0 10px 0 25px;
        background: url("../images/common/icon_recruit.svg") center left no-repeat; } }
@media (max-width: 1024px) and (hover: hover) {
  aside .side_menu a:hover {
    font: 2rem/50px "Noto Sans", "sans-serif";
    font-weight: 700;
    transform: rotate(0deg); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  aside .toggle {
    top: 10px;
    right: 15px;
    width: 60px;
    height: 60px; }
    aside .toggle span {
      width: 30px;
      height: 3px; }
  aside .side_menu a {
    font: 2rem/61px "Noto Sans", "sans-serif";
    font-weight: 700;
    width: calc((100% - 60px)/2);
    height: 60px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  aside .toggle {
    top: 13px;
    right: 15px;
    width: 55px;
    height: 55px; }
    aside .toggle span {
      width: 25px;
      height: 3px; }
  aside .side_menu a.side_contact span {
    padding: 0 0 0 43px; }
  aside .side_menu a.side_recruit span {
    padding: 0 0 0 25px; } }
/*max-width:480px*/
/*****************/
.page_top {
  position: fixed;
  z-index: 8888;
  width: 86px;
  height: 86px;
  border-radius: 50px;
  background-color: #636363;
  display: block;
  bottom: -115px;
  right: 25px;
  transition: .3s;
  transition: .3s; }
  .page_top.active {
    bottom: 25px; }
  .page_top:before {
    transition: .3s;
    position: absolute;
    content: "";
    top: 55%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
    width: 15px;
    height: 15px;
    border-top: 4px solid #fff;
    border-right: 4px solid #fff; }

@media (hover: hover) {
  .page_top:hover {
    cursor: pointer; }
    .page_top:hover:before {
      top: 45%;
      left: 50%;
      transform: translate(-50%, -50%) rotate(-45deg); } }
@media (max-width: 1024px) {
  .page_top {
    width: 70px;
    height: 70px;
    border-radius: 0;
    bottom: -70px;
    right: 0; }
    .page_top.active {
      bottom: 0; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .page_top {
    width: 60px;
    height: 60px; } }
/*max-width:768px*/
/*****************/
footer {
  padding: 130px 0 0;
  position: relative; }

@media (max-width: 768px) {
  footer {
    padding: 88px 0 0;
    position: relative; } }
/*max-width:768px*/
@media (max-width: 480px) {
  footer {
    padding: 60px 0 0;
    position: relative; } }
/*max-width:480px*/
/*****************/
.marquee {
  position: absolute;
  top: 1%;
  left: 50%;
  transform: translate(-50%, 0%);
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  box-sizing: border-box; }

.marquee__inner {
  display: inline-block;
  animation: marquee 80s linear infinite; }

.marquee__inner span {
  font: 15rem/1em "Poppins", "sans-serif";
  font-weight: 700;
  color: #0091DB;
  display: inline-block;
  padding-right: 2rem; }

@keyframes marquee {
  0% {
    transform: translateX(0); }
  100% {
    transform: translateX(-50%); } }
@media (max-width: 768px) {
  .marquee__inner {
    animation: marquee 53s linear infinite; }

  .marquee__inner span {
    font: 10rem/1em "Poppins", "sans-serif";
    font-weight: 700; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .marquee {
    top: 0.5%; }

  .marquee__inner {
    animation: marquee 37s linear infinite; }

  .marquee__inner span {
    font: 7rem/1em "Poppins", "sans-serif";
    font-weight: 700; } }
/*max-width:480px*/
/*****************/
.footer_contact {
  background-color: #0091DB;
  padding: 50px 0 90px; }
  .footer_contact h2 {
    font: 3.4rem/1em "Poppins", "sans-serif";
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.04em;
    margin: 0 0 30px;
    max-width: 1200px;
    margin: 0 auto 10px;
    width: calc(100% - 80px); }
    .footer_contact h2 span {
      margin: 8px 0 0;
      display: block;
      font: 1.8rem/1em "Noto Sans", "sans-serif";
      font-weight: 500;
      letter-spacing: 0.08em;
      color: #fff; }
  .footer_contact a {
    color: #fff;
    display: block;
    text-align: center; }
    .footer_contact a.tel {
      width: fit-content;
      margin: 0 auto 40px; }
      .footer_contact a.tel span {
        display: block;
        font: 5.6rem/1em "Poppins", "sans-serif";
        font-weight: 500;
        letter-spacing: 0.06em;
        padding: 0 0 0 33px;
        background: url("../images/common/icon_tel.svg") left center no-repeat;
        background-size: auto;
        margin: 0 0 15px; }
      .footer_contact a.tel small {
        font: 1.6rem/1em "Noto Sans", "sans-serif";
        font-weight: 500;
        display: block; }
    .footer_contact a.mail {
      transition: .3s;
      height: 80px;
      max-width: 480px;
      width: calc(100% - 30px);
      margin: 0 auto;
      border: 1px solid #fff;
      border-radius: 50px; }
      .footer_contact a.mail span {
        padding: 0 0 0 50px;
        display: block;
        margin: 0 auto;
        width: fit-content;
        font: 2rem/78px "Noto Sans", "sans-serif";
        font-weight: 500;
        background: url("../images/common/icon_mail.svg") left center no-repeat;
        background-size: 40px 30px; }
      .footer_contact a.mail br {
        display: none; }

@media (hover: hover) {
  .footer_contact a {
    color: #fff;
    display: block;
    text-align: center; }
    .footer_contact a.tel:hover {
      cursor: text; }
    .footer_contact a.mail:hover {
      background-color: orange; } }
@media (max-width: 768px) {
  .footer_contact h2 {
    font: 3.4rem/1em "Poppins", "sans-serif";
    font-weight: 500;
    width: calc(100% - 60px);
    margin: 0 auto 40px; }
  .footer_contact a.tel {
    margin: 0 auto 40px; }
    .footer_contact a.tel span {
      font: 5rem/1em "Poppins", "sans-serif";
      font-weight: 500;
      background: url("../images/common/icon_tel.svg") left center no-repeat;
      background-size: auto 44px;
      margin: 0 0 15px; }
  .footer_contact a.mail {
    height: auto;
    padding: 15px;
    max-width: 400px;
    width: calc(100% - 60px);
    border-radius: 15px;
    text-align: left; }
    .footer_contact a.mail br {
      display: block; }
    .footer_contact a.mail span {
      padding: 0 0 0 60px;
      font: 2.2rem/1.6em "Noto Sans", "sans-serif";
      font-weight: 500;
      background: url("../images/common/icon_mail.svg") left center no-repeat;
      background-size: 40px 30px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .footer_contact {
    padding: 60px 0 100px; }
    .footer_contact h2 {
      max-width: 330px;
      margin: 0 auto 50px; }
    .footer_contact a.tel {
      max-width: 330px;
      margin: 0 auto 40px; }
      .footer_contact a.tel span {
        font: 3.9rem/1em "Poppins", "sans-serif";
        font-weight: 500;
        background: url("../images/common/icon_tel.svg") left center no-repeat;
        background-size: auto 35px;
        padding: 2px 0 2px 25px;
        margin: 0 0 10px; }
      .footer_contact a.tel small {
        font: 1.5rem/1em "Noto Sans", "sans-serif";
        font-weight: 500;
        padding: 0 0 0 25px; }
    .footer_contact a.mail {
      max-width: 330px;
      width: calc(100% - 60px); } }
/*max-width:480px*/
/*****************/
.footer_recruit {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  margin: 0;
  padding: 0; }

.footer_recruit_guideline,
.footer_recruit_contact {
  width: calc(100% /2);
  padding: 30px 0 74px; }
  .footer_recruit_guideline > div,
  .footer_recruit_contact > div {
    max-width: 840px;
    margin: 0 auto; }
  .footer_recruit_guideline h2,
  .footer_recruit_contact h2 {
    font: 3.4rem/1em "Poppins", "sans-serif";
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.04em;
    max-width: 1200px;
    margin: 0 auto 20px;
    width: calc(100% - 80px); }
    .footer_recruit_guideline h2 span,
    .footer_recruit_contact h2 span {
      margin: 8px 0 0;
      display: block;
      font: 1.8rem/1em "Noto Sans", "sans-serif";
      font-weight: 500;
      letter-spacing: 0.08em;
      color: #fff; }
  .footer_recruit_guideline a,
  .footer_recruit_contact a {
    color: #fff;
    display: block;
    text-align: center; }
    .footer_recruit_guideline a.tel,
    .footer_recruit_contact a.tel {
      width: fit-content;
      margin: 0 auto 40px; }
      .footer_recruit_guideline a.tel span,
      .footer_recruit_contact a.tel span {
        display: block;
        font: 5.6rem/1em "Poppins", "sans-serif";
        font-weight: 500;
        letter-spacing: 0.06em;
        padding: 0 0 0 33px;
        background: url("../images/common/icon_tel.svg") left center no-repeat;
        background-size: auto;
        margin: 0 0 10px; }
      .footer_recruit_guideline a.tel small,
      .footer_recruit_contact a.tel small {
        font: 1.6rem/1em "Noto Sans", "sans-serif";
        font-weight: 500;
        display: block; }
    .footer_recruit_guideline a.guideline_btn, .footer_recruit_guideline a.mail,
    .footer_recruit_contact a.guideline_btn,
    .footer_recruit_contact a.mail {
      transition: .3s;
      height: 80px;
      max-width: 480px;
      width: calc(100% - 30px);
      margin: 0 auto;
      border: 1px solid #fff;
      border-radius: 50px; }
      .footer_recruit_guideline a.guideline_btn span, .footer_recruit_guideline a.mail span,
      .footer_recruit_contact a.guideline_btn span,
      .footer_recruit_contact a.mail span {
        padding: 0 0 0 50px;
        display: block;
        margin: 0 auto;
        width: fit-content;
        font: 2rem/78px "Noto Sans", "sans-serif";
        font-weight: 500; }
      .footer_recruit_guideline a.guideline_btn br, .footer_recruit_guideline a.mail br,
      .footer_recruit_contact a.guideline_btn br,
      .footer_recruit_contact a.mail br {
        display: none; }
    .footer_recruit_guideline a.guideline_btn span,
    .footer_recruit_contact a.guideline_btn span {
      background: url("../images/common/recruit.svg") left center no-repeat;
      background-size: 40px 30px; }
    .footer_recruit_guideline a.mail span,
    .footer_recruit_contact a.mail span {
      background: url("../images/common/icon_mail.svg") left center no-repeat;
      background-size: 40px 30px; }

.footer_recruit_guideline {
  background-color: #0091DB; }
  .footer_recruit_guideline h2 {
    margin-bottom: 55px; }

.footer_recruit_contact {
  background-color: #F6AB00; }

@media (hover: hover) {
  .footer_contact a {
    color: #fff;
    display: block;
    text-align: center; }
    .footer_contact a.tel:hover {
      cursor: text; }
    .footer_contact a.mail:hover {
      background-color: orange; } }
@media (max-width: 1024px) {
  .footer_recruit {
    display: block; }

  .footer_recruit_guideline,
  .footer_recruit_contact {
    width: 100%;
    padding: 40px 40px 50px; }
    .footer_recruit_guideline h2,
    .footer_recruit_contact h2 {
      font: 3.4rem/1em "Poppins", "sans-serif";
      font-weight: 500;
      width: 100%;
      margin: 0 auto 30px;
      text-align: center; } }
@media (max-width: 768px) {
  .footer_recruit_guideline,
  .footer_recruit_contact {
    padding: 40px 0 50px; }
    .footer_recruit_guideline a.tel,
    .footer_recruit_contact a.tel {
      margin: 0 auto 40px; }
      .footer_recruit_guideline a.tel span,
      .footer_recruit_contact a.tel span {
        font: 5rem/1em "Poppins", "sans-serif";
        font-weight: 500;
        background: url("../images/common/icon_tel.svg") left center no-repeat;
        background-size: auto 44px;
        margin: 0 0 15px; }
    .footer_recruit_guideline a.guideline_btn, .footer_recruit_guideline a.mail,
    .footer_recruit_contact a.guideline_btn,
    .footer_recruit_contact a.mail {
      height: auto;
      padding: 15px;
      max-width: 400px;
      width: calc(100% - 60px);
      text-align: left; }
      .footer_recruit_guideline a.guideline_btn br, .footer_recruit_guideline a.mail br,
      .footer_recruit_contact a.guideline_btn br,
      .footer_recruit_contact a.mail br {
        display: block; }
      .footer_recruit_guideline a.guideline_btn span, .footer_recruit_guideline a.mail span,
      .footer_recruit_contact a.guideline_btn span,
      .footer_recruit_contact a.mail span {
        padding: 0 0 0 60px;
        font: 2.2rem/1.6em "Noto Sans", "sans-serif";
        font-weight: 500; }
    .footer_recruit_guideline a.mail,
    .footer_recruit_contact a.mail {
      border-radius: 15px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .footer_recruit_guideline a.tel,
  .footer_recruit_contact a.tel {
    max-width: 330px;
    margin: 0 auto 40px; }
    .footer_recruit_guideline a.tel span,
    .footer_recruit_contact a.tel span {
      font: 3.9rem/1em "Poppins", "sans-serif";
      font-weight: 500;
      background: url("../images/common/icon_tel.svg") left center no-repeat;
      background-size: auto 35px;
      padding: 2px 0 2px 25px;
      margin: 0 0 10px; }
    .footer_recruit_guideline a.tel small,
    .footer_recruit_contact a.tel small {
      font: 1.5rem/1em "Noto Sans", "sans-serif";
      font-weight: 500;
      padding: 0 0 0 25px; }
  .footer_recruit_guideline a.guideline_btn, .footer_recruit_guideline a.mail,
  .footer_recruit_contact a.guideline_btn,
  .footer_recruit_contact a.mail {
    max-width: 330px; }
    .footer_recruit_guideline a.guideline_btn span, .footer_recruit_guideline a.mail span,
    .footer_recruit_contact a.guideline_btn span,
    .footer_recruit_contact a.mail span {
      padding: 0 0 0 50px; }
  .footer_recruit_guideline a.mail span,
  .footer_recruit_contact a.mail span {
    padding: 0 0 0 60px; } }
/*max-width:480px*/
/*****************/
.footer_box {
  margin: 0 auto;
  max-width: 1920px;
  width: calc(100% - 80px);
  padding: 100px 60px 65px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: flex-start; }

.f_txt {
  flex: 1;
  max-width: 600px; }
  .f_txt p {
    font: 2.4rem/1em "Noto Sans", "sans-serif";
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 100px 0 0 0;
    background: url("../images/logo.svg") top left no-repeat;
    background-size: 130px 70px;
    margin: 0 0 40px; }
  .f_txt adress {
    font: 1.5rem/2em "Noto Sans", "sans-serif";
    font-weight: 300;
    letter-spacing: 0.04em; }
  .f_txt a {
    display: inline-block;
    margin: 0 15px 0 0; }

.f_nav {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  max-width: 1020px;
  width: calc(100% - 330px); }
  .f_nav a, .f_nav span {
    display: block;
    width: fit-content;
    position: relative;
    color: #2E5287; }
  .f_nav .normal {
    font: 1.4rem/1.5em "Noto Sans", "sans-serif";
    font-weight: 500;
    margin: 0 0 20px; }
  .f_nav .dot {
    font: 1.3rem/1.5em "Noto Sans", "sans-serif";
    font-weight: 400;
    margin: 0 0 15px;
    padding: 0 0 0 17px; }
    .f_nav .dot:before {
      position: absolute;
      content: "";
      display: block;
      border-radius: 50px;
      background-color: #0091DB;
      width: 7px;
      height: 7px;
      left: 2px;
      top: 6px; }

@media (hover: hover) {
  .f_txt a:hover {
    cursor: pointer;
    color: #F29600; }

  .f_nav a:hover {
    cursor: pointer;
    color: #F29600; } }
/*min-width:1920px*/
@media (max-width: 1280px) {
  .footer_box {
    width: calc(100% - 130px);
    padding: 80px 0 80px;
    display: block; }

  .f_txt {
    max-width: 305px;
    margin: 0; }

  .f_nav {
    display: none; } }
/*max-width:1280px*/
@media (max-width: 480px) {
  .footer_box {
    width: calc(100% - 60px);
    padding: 50px 0 100px;
    display: block; }

  .f_txt {
    max-width: 330px;
    margin: 0 auto; }
    .f_txt p {
      font: 2.4rem/1em "Noto Sans", "sans-serif";
      font-weight: 600;
      padding: 55px 0 0 0;
      background: url("../images/logo.svg") top left no-repeat;
      background-size: 74px auto;
      margin: 0 0 15px; } }
/*max-width:480px*/
/***content共通**************/
.anchor {
  display: block;
  padding: 80px 0 0 0;
  margin: -80px 0 0; }

.main_content {
  max-width: 1920px;
  width: 100%;
  padding: 0 150px 0 380px;
  margin: 0 auto; }
  .main_content section {
    max-width: 1380px;
    width: 100%;
    margin: 0 auto; }

@media (max-width: 1280px) {
  .main_content {
    max-width: 1920px;
    width: 100%;
    padding: 30px 150px 0 80px;
    margin: 0 auto; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .main_content {
    width: calc(100% - 80px);
    padding: 30px 0 0 0; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .main_content {
    width: calc(100% - 60px); } }
/*max-width:768px*/
@media (max-width: 480px) {
  .main_content {
    width: calc(100% - 40px); } }
/*max-width:480px*/
.page_header h1 {
  color: #2E5287;
  font: 10rem/1em "Poppins", "sans-serif";
  font-weight: 500;
  margin: 0 0 100px; }
  .page_header h1 span {
    margin: 10px 0 0;
    display: block;
    font: 2.4rem/1em "Noto Sans", "sans-serif";
    font-weight: 700;
    letter-spacing: 0.08rm; }
  .page_header h1 small {
    color: #F29600;
    margin: 0;
    display: block;
    font: 2rem/1em "Poppins", "sans-serif";
    font-weight: 700;
    letter-spacing: 0.02rm; }
.page_header .mv {
  border-radius: 10px;
  background: url("../images/company/mv.jpg") center center no-repeat;
  background-size: contain;
  aspect-ratio: 1380/600;
  width: 100%;
  max-width: 1380px;
  height: auto;
  margin: 0 0 100px; }
.page_header p {
  font: 2rem/2em "Noto Sans", "sans-serif";
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #2E5287;
  margin-bottom: 100px;
  text-align: justify;
  text-justify: inter-ideograph; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .page_header h1 {
    font: 8rem/1em "Poppins", "sans-serif";
    font-weight: 500; }
    .page_header h1 span {
      font: 2.2rem/1em "Noto Sans", "sans-serif";
      font-weight: 700; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .page_header h1 {
    font: 6.2rem/1em "Poppins", "sans-serif";
    font-weight: 500; }
    .page_header h1 span {
      font: 2rem/1em "Noto Sans", "sans-serif";
      font-weight: 700; }
  .page_header .mv {
    margin: 0 0 50px; }
  .page_header p {
    font: 2rem/2em "Noto Sans", "sans-serif";
    font-weight: 500;
    letter-spacing: 0.04em; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .page_header h1 {
    font: 5.5rem/1em "Poppins", "sans-serif";
    font-weight: 500; }
    .page_header h1 span {
      font: 1.8rem/1em "Noto Sans", "sans-serif";
      font-weight: 700; }
  .page_header p {
    font: 1.8rem/2em "Noto Sans", "sans-serif";
    font-weight: 500;
    letter-spacing: 0.04em; } }
/*max-width:480px*/
