@charset "UTF-8";
/* ================================
  　フォントの設定方法
    step1:サイトで使うフォントをすべて洗い出し、Google Fontsにアクセスして"Get font"
    step2:"Get font"したhtmlのコードをheadに貼る
    step3:"Get font"したcssのコードを_variables.scss(このファイル)に貼り、変数名を付ける
    step4:デフォルト以外のフォントを使いたい場面では定義した変数名を呼び出す
   ================================ */
.base__bg {
  position: fixed;
  inset: 0;
  z-index: -1;
}

/* ================================
   Main Layout
   ================================ */
.main-layout {
  position: relative;
  overflow-x: clip;
}

/* ================================
   Main Visual / fv
   ================================ */
.main-hero {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
}

/* ================================
   Main Body Layout
   ================================ */
.main-body {
  position: relative;
}
@media screen and (min-width: 768px) {
  .main-body {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

/* ================================
   Sidebar
   ================================ */
/* ================================
   Main Content Column
   ================================ */
.main-content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width: 0;
}

/* 紙面型では中央寄せしない */
.main-content .container {
  max-width: none;
  margin: 0;
}

/* =====================================
   Section上書き

===================================== */
.section--greeting {
  padding-bottom: 93px;
}
@media screen and (min-width: 768px) {
  .section--greeting {
    padding-bottom: 153px;
  }
}
@media screen and (min-width: 768px) {
  .section--greeting .inner {
    max-width: 1080px;
  }
}

.greeting__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}
@media screen and (min-width: 768px) {
  .greeting__container {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 460px));
    grid-template-areas: "a b" "c b";
    -webkit-column-gap: 40px;
       -moz-column-gap: 40px;
            column-gap: 40px;
    row-gap: 53px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media screen and (min-width: 768px) {
  .greeting-message {
    grid-area: a;
  }
}
.greeting-message .message__head {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.6px;
}
@media screen and (min-width: 768px) {
  .greeting-message .message__head {
    margin-bottom: 40px;
    font-size: 28px;
    letter-spacing: 2.24px;
  }
}
.greeting-message p {
  margin-bottom: 14px;
  font-size: 14px;
  line-height: 1.7;
}
.greeting-message p:last-child {
  margin-bottom: 0;
  text-align: right;
}

.greeting__img {
  margin-inline: auto;
  width: 100%;
  max-width: 335px;
  aspect-ratio: 335/446;
  border-radius: 20px;
  background: lightgray -7.619px 21.44px/104.548% 95.251% no-repeat;
}
.greeting__img img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .greeting__img {
    grid-area: b;
    max-width: none;
  }
}

.greeting-career {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
.greeting-career .career__table1,
.greeting-career .career__table2 {
  width: 100%;
  border-collapse: separate;
}
.greeting-career .career__table1 thead,
.greeting-career .career__table2 thead {
  font-size: 16px;
  text-align: left;
  line-height: 1.5;
}
.greeting-career .career__table1 thead th,
.greeting-career .career__table2 thead th {
  padding-bottom: 5px;
  border-bottom: 1px solid #393939;
  padding: 7px 7px;
}
.greeting-career .career__table1 tbody,
.greeting-career .career__table2 tbody {
  font-size: 14px;
  line-height: 1.7;
}
.greeting-career .career__table1 tbody th,
.greeting-career .career__table1 tbody td,
.greeting-career .career__table2 tbody th,
.greeting-career .career__table2 tbody td {
  text-align: left;
  padding: 7px 7px;
}
.greeting-career .career__table1 tbody th,
.greeting-career .career__table2 tbody th {
  width: 50px;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .greeting-career {
    grid-area: c;
  }
}

.section--staff-divider .swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}
.section--staff-divider .swiper-slide-staff-divider {
  width: 200px;
  aspect-ratio: 2000/1331;
  border-radius: 20px;
  overflow: hidden;
  opacity: 0.7;
}
@media screen and (min-width: 768px) {
  .section--staff-divider .swiper-slide-staff-divider {
    width: 305px;
    aspect-ratio: 2000/1331;
  }
}

.section--staff {
  padding-bottom: 100px;
}
@media screen and (min-width: 768px) {
  .section--staff {
    padding-bottom: 160px;
  }
}
@media screen and (min-width: 768px) {
  .section--staff .inner {
    max-width: 1080px;
  }
}

.cards-staff__wrapper {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) {
  .cards-staff__wrapper {
    margin-bottom: 60px;
  }
}
.cards-staff__wrapper .cards-staff__title {
  font-size: 16px;
  line-height: 1.5;
  border-bottom: 1px solid #393939;
  padding-bottom: 5px;
  margin-bottom: 40px;
}

.cards-staff {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .cards-staff {
    display: grid;
    grid-template-columns: repeat(2, auto);
    gap: 80px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (min-width: 1120px) {
  .cards-staff {
    display: grid;
    grid-template-columns: repeat(3, auto);
    gap: 80px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.card-staff {
  width: 100%;
  max-width: 335px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 15px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .card-staff {
    max-width: 280px;
  }
}
.card-staff .card-staff__main-link {
  display: block;
  width: 100%;
  text-decoration: none;
  color: inherit;
}
.card-staff .card-staff__main-link:hover .card__img, .card-staff .card-staff__main-link:focus-visible .card__img {
  -webkit-box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
          box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}
.card-staff .card-staff__main-link:hover .card__head span, .card-staff .card-staff__main-link:focus-visible .card__head span {
  color: #1391e6;
}
.card-staff .card__img {
  width: 100%;
aspect-ratio: 1 / 1;
  background: rgba(255, 255, 255, 0.35);
  border: 2px solid rgba(0, 0, 0, 0.06);
  overflow: hidden;
  border-radius: 20px;
  -webkit-transition: border-color 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-transform 0.25s ease;
  transition: border-color 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-transform 0.25s ease;
  transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
  transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-transform 0.25s ease;
}
.card-staff .card__img img {
  width: 100%;
  height: auto;
  display: block;
}
@media screen and (max-width: 767px) {
  .card-staff .card__img {
    width: 60%;
    margin: 0 auto;
  }
}
.card-staff .card__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 12px;
  margin-top: 15px;
  margin-bottom: 12px;
}
.card-staff .card__head span {
  font-size: 18px;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 1.44px;
  -webkit-transition: color 0.25s ease;
  transition: color 0.25s ease;
}
.card-staff .card__info {
  font-size: 14px;
  line-height: 1.5;
  text-align: left;
}
.card-staff .card__info th,
.card-staff .card__info td {
  padding: 17px 20px;
  vertical-align: top;
}
.card-staff .card__info th {
  background: #dff1fd;
  width: 140px;
}
.card-staff .card__info td:empty {
  display: none;
}
.card-staff .card__info th:has(+ td:empty) {
  display: none;
}
.card-staff .card__blog-link {
  display: inline-block;
  margin-top: 12px;
  font-size: 14px;
  font-weight: 700;
  color: #1391e6;
  text-decoration: underline;
  text-underline-offset: 3px;
  -webkit-transition: color 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease;
  transition: color 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease;
  transition: color 0.25s ease, transform 0.25s ease, opacity 0.25s ease;
  transition: color 0.25s ease, transform 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease;
}
.card-staff .card__blog-link:hover, .card-staff .card__blog-link:focus-visible {
  color: rgb(15.1084337349, 115.3012048193, 182.8915662651);
  -webkit-transform: translateX(3px);
          transform: translateX(3px);
  opacity: 0.85;
}

/* ================================
   footer
   ================================ */
/* =====================================
    トップに戻るボタン

===================================== */