@charset "UTF-8";
body {
  padding: 130px 0 0;
  background-color: #E7EBFE; }

/*min-width:1920px*/
@media (max-width: 1280px) {
  body {
    padding: 120px 0 0; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  body {
    padding: 100px 0 0; } }
/*max-width:1024px*/
/*max-width:768px*/
@media (max-width: 480px) {
  body {
    padding: 70px 0 0; } }
/*max-width:480px*/
/******************************************/
.circle_scroll {
  position: fixed;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  /* Safari用 */
  transform: translate(-50%, -50%);
  aspect-ratio: 1/1;
  width: 100%;
  max-width: 1100px;
  height: 100%;
  background-image: url("../images/common/circle.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center 380px;
  background-attachment: fixed;
  opacity: 0.5;
  z-index: -1; }
  .circle_scroll.active {
    opacity: 0.5; }

/*max-width:768px*/
@media (max-width: 480px) {
  .circle_scroll {
    background-position: center 285px; } }
/*max-width:480px*/
/******************************************/
.recruit_top h2 br {
  display: none; }

@media (max-width: 480px) {
  .recruit_top h2 br {
    display: block; }
  .recruit_top p br.three {
    display: none !important; } }
/*max-width:480px*/
/******************************************/
h2 {
  color: #00275C;
  font: 9rem/1em "Albert Sans", sans-serif;
  font-weight: 400; }
  h2 span {
    font-weight: 100; }
  h2 small {
    text-align: left;
    margin: 0 0 20px;
    display: block;
    width: fit-content;
    font: 1.8rem/1em "Noto Sans", sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
    padding: 0 20px 0 50px;
    background: url("../images/recruit/ttl_icon.svg") center left 25px no-repeat;
    border-left: 1px solid #00275C;
    border-right: 1px solid #00275C; }

/*max-width:1024px*/
@media (max-width: 768px) {
  h2 {
    font: 6.0rem/1em "Albert Sans", sans-serif;
    width: 100%; }
    h2 small {
      font: 1.6rem/1em "Noto Sans", sans-serif;
      font-weight: 700; } }
/*max-width:768px*/
@media (max-width: 480px) {
  h2 {
    font: 4.8rem/1em "Albert Sans", sans-serif;
    width: 100%; }
    h2 small {
      font: 1.4rem/1em "Noto Sans", sans-serif;
      font-weight: 700;
      padding: 0 15px 0 45px;
      background: url("../images/recruit/ttl_icon.svg") center left 20px no-repeat;
      background-size: 13px; } }
/*max-width:480px*/
/******************************************/
.company_dat {
  max-width: 1270px;
  width: calc(100% - 100px);
  margin: 0 auto 160px; }
  .company_dat h2 {
    width: calc(100% - 30px);
    margin: 0 auto 40px; }

.parent {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  max-width: 1271px;
  margin: 0 auto;
  width: 100%; }
  .parent div {
    width: calc(100%/2);
    max-width: 100%;
    height: auto; }
    .parent div p {
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap; }
    .parent div.div1 {
      background: url("../images/company/dat-01.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 2540/823;
      width: 100%;
      max-width: 100%;
      height: auto; }
    .parent div.div2 {
      background: url("../images/company/dat-02.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 1283/703; }
    .parent div.div3 {
      background: url("../images/company/dat-03.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 1283/703; }
    .parent div.div4 {
      background: url("../images/company/dat-04.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 1283/703; }
    .parent div.div5 {
      background: url("../images/company/dat-05.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 1283/703; }

@media (max-width: 1024px) {
  .company_dat {
    max-width: 1270px;
    width: calc(100% - 80px);
    margin: 0 auto 160px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .company_dat {
    max-width: 1270px;
    width: calc(100% - 60px);
    margin: 0 auto 100px; }

  .parent {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    max-width: 100%;
    margin: 0 auto;
    margin: 0 auto;
    width: 100%; }
    .parent div {
      width: 100%;
      max-width: 100%;
      height: auto; }
      .parent div p {
        overflow: hidden;
        text-indent: 100%;
        white-space: nowrap; }
      .parent div.div1 {
        background: url("../images/company/dat_tb-01.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 589/393;
        width: 100%;
        max-width: 100%;
        height: auto; }
      .parent div.div2 {
        background: url("../images/company/dat_tb-02.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 589/324; }
      .parent div.div3 {
        background: url("../images/company/dat_tb-03.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 589/324; }
      .parent div.div4 {
        background: url("../images/company/dat_tb-04.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 589/324; }
      .parent div.div5 {
        background: url("../images/company/dat_tb-05.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 589/324; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .company_dat {
    max-width: 355px;
    width: calc(100% - 30px);
    margin: 0 auto 60px; }

  .parent {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    max-width: 100%;
    margin: 0 auto;
    margin: 0 auto;
    width: 100%; }
    .parent div {
      width: 100%;
      max-width: 100%;
      height: auto; }
      .parent div p {
        overflow: hidden;
        text-indent: 100%;
        white-space: nowrap; }
      .parent div.div1 {
        background: url("../images/company/dat_sp-01.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 344/229;
        width: 100%;
        max-width: 100%;
        height: auto; }
      .parent div.div2 {
        background: url("../images/company/dat_sp-02.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 344/190; }
      .parent div.div3 {
        background: url("../images/company/dat_sp-03.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 344/189; }
      .parent div.div4 {
        background: url("../images/company/dat_sp-04.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 344/189; }
      .parent div.div5 {
        background: url("../images/company/dat_sp-05.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 344/189; } }
/*max-width:480px*/
/******************************************/
.company_product {
  max-width: 1920px;
  width: calc(100% - 40px);
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 20px;
  padding: 100px 0; }
  .company_product h2 {
    margin: 0 auto 60px; }

.product_box {
  max-width: 1240px;
  width: calc(100% - 60px);
  margin: 0 auto; }
  .product_box h3 {
    font: 2rem/1em "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.1em;
    padding: 0 0 0 20px;
    border-left: 4px solid #6E80DA;
    margin: 0 0 20px; }

.parent_product_01,
.parent_product_02 {
  width: 100%;
  grid-template-rows: 1fr;
  grid-column-gap: 10px;
  grid-row-gap: 0px;
  margin: 0 0 40px;
  width: 100%; }
  .parent_product_01 div,
  .parent_product_02 div {
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center; }
    .parent_product_01 div img,
    .parent_product_02 div img {
      max-width: 100%;
      /* ← これが1倍表示の決め手！ */
      height: auto; }

.parent_product_01 {
  display: grid;
  grid-template-columns: repeat(3, 1fr); }
  .parent_product_01 .div1 {
    grid-area: 1 / 1 / 2 / 3; }
  .parent_product_01 .div2 {
    grid-area: 1 / 3 / 2 / 4; }

.parent_product_02 {
  display: grid;
  grid-template-columns: repeat(3, 1fr); }
  .parent_product_02 .div1 {
    grid-area: 1 / 1 / 2 / 2; }
  .parent_product_02 .div2 {
    grid-area: 1 / 2 / 2 / 3; }
  .parent_product_02 .div3 {
    grid-area: 1 / 3 / 2 / 4; }

.parent_product_03 {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between; }
  .parent_product_03 div {
    width: calc((100% - 40px)/5);
    background-color: #fff;
    aspect-ratio: 1/1;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px; }
    .parent_product_03 div img {
      height: 100%;
      max-height: fit-content;
      width: auto; }

/*min-width:1920px*/
/*max-width:1280px*/
/*max-width:1024px*/
@media (max-width: 768px) {
  .product_box {
    max-width: 1240px;
    width: calc(100% - 40px);
    margin: 0 auto; }
    .product_box h3 {
      font: 1.8rem/1em "Noto Sans", sans-serif;
      font-weight: 500; }

  .company_product {
    padding: 70px 0; }

  .parent_product_03 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start; }
    .parent_product_03 div {
      width: calc((100% - 20px)/3);
      aspect-ratio: 1/1;
      margin: 0 10px 10px 0; }
      .parent_product_03 div:nth-of-type(3n) {
        margin-right: 0; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .company_product {
    max-width: 1920px;
    width: calc(100% - 20px);
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 20px;
    padding: 50px 0; }
    .company_product h2 {
      margin: 0 auto 40px;
      max-width: 320px; }

  .product_box {
    max-width: 320px;
    width: calc(100% - 40px); }
    .product_box h3 {
      font: 1.6rem/1em "Noto Sans", sans-serif;
      font-weight: 500;
      margin-bottom: 10px; }

  .parent_product_01,
  .parent_product_02 {
    margin: 0 0 40px; } }
/*max-width:480px*/
/******************************************/
.company_area {
  max-width: 1240px;
  margin: 0 auto;
  padding: 150px 0; }
  .company_area h2 {
    max-width: 1240px;
    width: calc(100% - 100px);
    margin: 0 auto 60px;
    font-weight: 200; }
  .company_area .area_map {
    width: 100%;
    max-width: 900px;
    margin: 0 auto; }
    .company_area .area_map img {
      image-rendering: -webkit-optimize-contrast;
      backface-visibility: hidden; }
      .company_area .area_map img.sp {
        display: none; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .company_area {
    padding: 150px 0; }
    .company_area h2 {
      width: calc(100% - 80px);
      margin: 0 auto 60px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .company_area {
    padding: 100px 0; }
    .company_area h2 {
      width: calc(100% - 60px);
      margin: 0 auto 60px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .company_area {
    padding: 60px 0 60px; }
    .company_area h2 {
      width: calc(100% - 30px);
      margin: 0 auto 60px;
      max-width: 315px; }
    .company_area .area_map img.pc {
      display: none; }
    .company_area .area_map img.sp {
      display: block; } }
/*max-width:480px*/
/******************************************/
.company_employee {
  max-width: 1240px;
  width: calc(100% - 100px);
  margin: 0 auto;
  padding: 0 0 150px; }
  .company_employee h2 {
    font-weight: 200;
    margin: 0 auto 40px; }
  .company_employee p {
    font: 2rem/2.4em "Noto Sans", sans-serif;
    font-weight: 400;
    letter-spacing: 0.08em;
    margin: 0 0 60px; }
  .company_employee .flex {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between; }
  .company_employee .item {
    border: 1px solid #C2C7E1;
    width: calc((100% - 20px )/2);
    background-color: rgba(255, 255, 255, 0.3);
    border-radius: 20px;
    padding: 40px 30px; }
  .company_employee h3 {
    font: 2.3rem/1em "Noto Sans", sans-serif;
    font-weight: 400;
    letter-spacing: 0.15em;
    text-align: center;
    max-width: 400px;
    width: 100%;
    padding: 0 0 20px;
    margin: 0 auto 35px;
    position: relative;
    border-bottom: #C0C9D5 1px solid; }
    .company_employee h3:before {
      position: absolute;
      content: "";
      width: 0;
      height: 0;
      border-style: solid;
      border-right: 7px solid transparent;
      border-left: 7px solid transparent;
      border-top: 12px solid #c0c9d5;
      border-bottom: 0;
      top: auto;
      bottom: -12px;
      left: 50%;
      transform: translate(-50%, 0%); }
  .company_employee ul {
    width: fit-content;
    margin: 0 auto; }
  .company_employee li {
    font: 1.8rem/2em "Noto Sans", sans-serif;
    font-weight: 400;
    letter-spacing: 0.05em;
    position: relative;
    padding: 0 0 0 20px; }
    .company_employee li:before {
      position: absolute;
      content: "";
      display: block;
      background-color: #6E80DA;
      width: 8px;
      height: 8px;
      border-radius: 50%;
      left: 0;
      top: 14px; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .company_employee {
    width: calc(100% - 80px); }
    .company_employee .flex {
      display: block; }
    .company_employee .item {
      width: 100%;
      max-width: 640px;
      margin: 0 auto 20px;
      padding: 40px 30px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .company_employee {
    width: calc(100% - 60px);
    padding: 0 0 100px; }
    .company_employee h2 {
      margin: 0 auto 40px; }
    .company_employee p {
      font: 1.8rem/2.4em "Noto Sans", sans-serif;
      font-weight: 400;
      margin: 0 0 60px; }
    .company_employee h3 {
      font: 2rem/1em "Noto Sans", sans-serif;
      font-weight: 400; }
    .company_employee li {
      font: 1.6rem/2em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }
      .company_employee li:before {
        border-radius: 50%;
        left: 0;
        top: 12px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .company_employee {
    width: calc(100% - 30px);
    padding: 0 0 60px; }
    .company_employee h2 {
      max-width: 320px;
      margin: 0 auto 20px; }
    .company_employee p {
      max-width: 320px;
      font: 1.6rem/2em "Noto Sans", sans-serif;
      font-weight: 400;
      margin: 0 auto 30px; }
    .company_employee h3 {
      font: 1.7rem/1em "Noto Sans", sans-serif;
      font-weight: 400;
      margin: 0 auto 20px;
      padding: 0 0 15px; }
    .company_employee li {
      font: 1.5rem/2em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em;
      padding: 0 0 0 15px; }
      .company_employee li:before {
        border-radius: 50%;
        left: 0;
        top: 12px;
        width: 7px;
        height: 7px; }
    .company_employee .item {
      max-width: 340px;
      padding: 25px 20px 25px;
      margin: 0 auto 10px; } }
/*max-width:480px*/
/******************************************/
.company_workplace {
  max-width: 1920px;
  width: calc(100% - 40px);
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 20px;
  padding: 120px 0 100px; }
  .company_workplace h2 {
    margin: 0 auto 40px; }

.workplace_box {
  max-width: 1240px;
  width: calc(100% - 60px);
  margin: 0 auto; }
  .workplace_box ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start; }
  .workplace_box li {
    width: calc((100% - 60px)/4);
    margin: 0 20px 20px 0; }
    .workplace_box li:nth-of-type(4n) {
      margin-right: 0; }
    .workplace_box li img {
      width: 100%; }
    .workplace_box li p {
      margin: 5px 0 0;
      font: 1.6rem/2em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .workplace_box {
    max-width: 1240px;
    margin: 0 auto; }
    .workplace_box li {
      width: calc((100% - 20px)/3);
      margin: 0 10px 20px 0; }
      .workplace_box li:nth-of-type(4n) {
        margin-right: 10px; }
      .workplace_box li:nth-of-type(3n) {
        margin-right: 0; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .company_workplace {
    max-width: 1920px;
    width: calc(100% - 40px);
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 20px;
    padding: 100px 0 100px; }
    .company_workplace h2 {
      margin: 0 auto 40px; }

  .workplace_box {
    width: calc(100% - 40px);
    margin: 0 auto; }
    .workplace_box ul {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
      align-items: flex-start; }
    .workplace_box li {
      width: calc((100% - 10px)/2);
      margin: 0 0 20px 0; }
      .workplace_box li:nth-of-type(4n) {
        margin-right: 0; }
      .workplace_box li img {
        width: 100%; }
      .workplace_box li p {
        margin: 5px 0 0;
        font: 1.5rem/2em "Noto Sans", sans-serif;
        font-weight: 400;
        letter-spacing: 0.05em; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .company_workplace {
    max-width: 1920px;
    width: calc(100% - 20px);
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 20px;
    padding: 60px 0 50px; }
    .company_workplace h2 {
      margin: 0 auto 40px; }

  .workplace_box {
    max-width: 320px;
    width: calc(100% - 30px); }
    .workplace_box li {
      width: calc((100% - 10px)/2);
      margin: 0 0 20px 0; }
      .workplace_box li:nth-of-type(4n) {
        margin-right: 0; }
      .workplace_box li img {
        width: 100%; }
      .workplace_box li p {
        margin: 5px 0 0;
        font: 1.2rem/1.5em "Noto Sans", sans-serif;
        font-weight: 400;
        letter-spacing: 0.05em; } }
/*max-width:480px*/
