@charset "utf-8";
/* recruit-job
----------------------------------------------------------------------------------------------------*/
.p-job {
  padding-top: 14.5rem;
  margin-bottom: 25.3rem;
}
.p-job__intro {
  margin-bottom: 13rem;
}
.p-job__intro-title {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 10rem;
  margin-bottom: 4rem;
  border: solid 1px #164186;
  background-color: #e4eff2;
}
.p-job__intro-title h3 {
  font-weight: 700;
  /*font-size: 4.2rem;*/
  font-size: 3.6rem;
  color: #164186;
}
.p-job__intro p {
  line-height: 1.7;
  text-align: justify;
  font-weight: 600;
  /*font-size: 3.0rem;*/
  font-size: 2.4rem;
}
.p-job__intro-title h3 span {
  margin-left: 1rem;
}
/* MOBILE */
@media screen and (max-width: 767px) {
  .p-job__intro {
    margin-bottom: 4rem;
  }
  .p-job__intro-title {
    margin-bottom: 3.8rem;
  }
  .p-job__intro-title h3 {
    text-align: center;
    line-height: 1.6;
    font-size: 2.4rem;
  }
  .p-job__intro p {
    line-height: 1.7;
    font-size: 1.8rem;
  }
  .p-job__intro-title h3 span {
    margin-left: 0;
  }
}
/* 海務チーム オペレーションセクション */
.shift-system {
  margin-bottom: 14rem;
  overflow-x: auto;
}
.shift-system-wrap {
  min-width: 151rem;
}
.shift-system-box {
  overflow: hidden;
  border-radius: 2rem;
  border: solid 1px #c3cee0;
}
.shift-system__title {
  padding: 5rem 11.4rem;
  background-color: #ff6d00;
  font-weight: 700;
}
.shift-system__title h4 {
  font-weight: 700;
  font-size: 3.6rem;
  color: #fff;
  white-space: nowrap;
}
.shift-system__title h4 span {
  margin-left: 3rem;
  font-weight: 600;
  font-size: 2.8rem;
  color: #FFF;
}
/* 1行（ラベル＋タイムライン） */
.shift-row {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10.6rem;
  margin-bottom: 5rem;
}
.shift-row:last-of-type {
  margin-bottom: 0;
}
.shift-row--double {
  align-items: center;
}
.shift-label {
  width: calc(260 / 1260 * 100%);
}
.timeline {
  /* width: calc( 890 / 1260 * 100% ); */
}
.shift-name {
  font-weight: 700;
  font-size: 5.2rem;
  color: #164186;
}
.shift-name span {
  font-size: 2.8rem;
}
.shift-name--sm {
  font-weight: 700;
  font-size: 3.4rem;
  color: #164186;
}
.shift-freq {
  font-weight: 700;
  font-size: 2.0rem;
  color: #164186;
}
.shift-body {
  padding: 4.5rem 11.4rem 6.5rem;
}
/* タイムライン本体 */
.timeline {
  position: relative;
  flex: 1;
  /* height: 5rem; */
  /* ラベル＋バー＋ドットの高さ */
  padding-top: 3rem;
  /* 上部ラベル分の余白 */
}
/* グレーのベースバー */
.tl-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1.2rem;
  background: #c3cee0;
  border-radius: 0.4rem;
}
/* オレンジのアクティブ区間 */
.tl-segment--active {
  position: absolute;
  top: 0;
  height: 100%;
  background: #ff6d00;
  border-radius: 0.4rem;
}
/* ドット */
.tl-dot {
  position: absolute;
  bottom: -1rem;
  /* バー中央に合わせる */
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  transform: translateX(-50%);
}
.tl-dot--active {
  background: #ff6d00;
}
.tl-dot--inactive {
  background: #c3cee0;
}
/* 時刻ラベル（バーの上） */
.tl-label {
  position: absolute;
  bottom: calc(100% - 1rem);
  /* バーの上に配置 */
  transform: translateX(-50%);
  font-size: 3.6rem;
  font-weight: 700;
  color: #164186;
  white-space: nowrap;
}
.tl-label--breaktime {
  position: absolute;
  bottom: calc(100% - 1rem);
  /* バーの上に配置 */
  transform: translateX(-50%);
  font-size: 3.6rem;
  font-weight: 700;
  color: #5070a4;
  white-space: nowrap;
}
.tl-label--breaktext {
  font-size: 2.4rem;
  font-weight: 700;
  color: #5070a4;
}
/* 日勤の2段タイムライン */
.shift-double {
  padding-top: 2rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 10rem;
}
/* MOBILE */
@media screen and (max-width: 767px) {
  .shift-system {
    margin-bottom: 7.7rem;
  }
  .shift-system-wrap {
    min-width: 90.6rem;
  }
  .shift-system-box {
    border-radius: 1.2rem;
  }
  .shift-system__title {
    padding: 2.8rem 6.8rem;
  }
  .shift-system__title h4 {
    font-size: 2.16rem;
    color: #FFF;
  }
  .shift-system__title h4 span {
    margin-left: 2rem;
    font-size: 1.68rem;
  }
  .shift-row {
    gap: 6rem;
  }
  .shift-label {
    width: calc(160 / 760 * 100%);
  }
  .shift-name {
    font-size: 3.12rem;
  }
  .shift-name span {
    font-size: 1.68rem;
  }
  .shift-name--sm {
    font-size: 1.68rem;
  }
  .shift-freq {
    font-size: 1.2rem;
  }
  .shift-body {
    padding: 6rem 6.8rem 4rem;
  }
  .tl-bar {
    height: 7.2px;
    border-radius: 0.4rem;
  }
  .tl-dot {
    position: absolute;
    bottom: -0.6rem;
    width: 1.8rem;
    height: 1.8rem;
  }
  .tl-label {
    font-size: 2.16rem;
  }
  .tl-label--breaktime {
    font-size: 2.16rem;
  }
  .tl-label--breaktext {
    font-size: 1.41rem;
  }
  .shift-double {
    gap: 7rem;
  }
}
/* オペレーションセクションの1日〈A勤務の場合〉 */
.operation-title {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 16.4rem;
  margin-bottom: 12rem;
  border-radius: 2rem;
  background-color: #5070a4;
  text-align: center;
  font-weight: 700;
}
.operation-title h4 {
  font-weight: 700;
  font-size: 4.2rem;
  color: #fff;
}
.operation-wrap {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4rem;
}
.operation-wrap--time {
  position: relative;
  /* height: 120rem; */
  width: calc(245 / 375 * 100%);
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.operation-track {
  padding-top: 4rem;
  display: flex;
}
.operation-track--left, .operation-track--right, .operation-track--sub {
  position: relative;
}
.operation-track--left, .operation-track--right {
  padding: 5rem;
}
/* 縦線セグメント */
.operation-track__segment {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  background: #164186;
}
/* ドット */
.operation-track__dot {
  position: absolute;
  left: 50%;
  z-index: 1;
  width: 1.2rem;
  height: 1.2rem;
  transform: translate(-50%, -50%);
  background: #164186;
  border-radius: 50%;
}
/* 時刻ラベル（線の左右ではなく上下に配置） */
.operation-track__time {
  position: absolute;
  left: 50%;
  transform: translate(-50%, -100%);
  line-height: 1;
  font-size: clamp(1.2rem, 4vw, 5.2rem);
  font-weight: 700;
  color: #164186;
  white-space: nowrap;
}
.operation-track__label {
  position: relative;
  left: -30px;
  line-height: 1.2;
  white-space: nowrap;
  font-size: clamp(1.8rem, 4vw, 3.8rem);
  font-weight: 700;
  color: #5070a4;
}
.operation-track__label .sub-text {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 9rem;
  width: 20.5rem;
  padding: 0.3rem;
  margin-top: 1rem;
  background-color: #000;
  border-radius: 1rem;
  text-align: center;
  font-size: 2.8rem;
  font-weight: 600;
  color: #FFF;
}
/* ── 右コンテンツ ── */
.operation-contents {
  position: relative;
  width: calc(1300 / 1510 * 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 15rem;
}
.operation-work__text {
  line-height: 1.5;
  text-align: justify;
  font-weight: 600;
  font-size: clamp(1.4rem, 3vw, 2.8rem);
}
.operation-work__text span.attention {
  font-size: 1.4rem;
}
.operation-work__text.operation-work__text--sm {
  font-weight: 600;
  /*font-size: 1.8rem;*/
  font-size: clamp(1.2rem, 3vw, 1.8rem);
}
.operation-morning {
  display: flex;
  flex-direction: column;
  gap: 3.6rem;
}
.operation-work {
  display: flex;
  justify-content: space-between;
  gap: 3rem;
}
.operation-work__track {
  position: relative;
  z-index: 1;
  width: calc(215 / 1300 * 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align: right;
}
.--am .operation-work__track, .--noon .operation-work__track, .--pm .operation-work__track {
  display: flex;
  justify-content: center;
}
.operation-work__body {
  width: calc(1050 / 1300 * 100%);
}
.operation-work__body--row {
  width: calc(1050 / 1300 * 100%);
  display: flex;
  flex-direction: row;
  gap: 2.4rem;
  align-items: flex-start;
}
.operation-work__texts {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
.operation-work__img {
  position: relative;
}
.--am .operation-work__texts, .--pm .operation-work__texts {
  width: calc(582 / 1048 * 100%);
}
.--arrive .operation-work__img, .--am .operation-work__img, .--pm .operation-work__img {
  width: calc(425 / 1048 * 100%);
}
.operation-work__img-description {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 5rem;
  bottom: 0;
  background-color: rgb(255, 255, 255, 85%);
  line-height: 1.5;
  font-weight: 600;
  font-size: 2.8rem;
  color: #000;
}
.operation-work--a_end {
  height: 8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 1.5rem;
  background-color: #164186;
  margin-bottom: 2.4rem;
  font-weight: 700;
  font-size: 3.8rem;
  color: #FFF;
}
.operation-work--b_start {
  height: 8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 1.5rem;
  background-color: #823200;
  font-weight: 700;
  font-size: 3.8rem;
  color: #FFF;
}
/* MOBILE */
@media screen and (max-width: 767px) {
  .p-job {
    margin-bottom: 13rem;
  }
  .operation-title {
    height: 11.2rem;
    margin-bottom: 5.2rem;
    border-radius: 1rem;
  }
  .operation-title h4 {
    font-size: 2rem;
  }
  .operation-wrap {
    margin-bottom: 5.2rem;
  }
  .operation-wrap--time {
    width: calc(72 / 330 * 100%);
  }
  .operation-track {
    padding-top: 4rem;
  }
  .operation-track {
    position: relative;
    display: flex;
    padding-top: 2rem;
    width: calc(240 / 1510 * 100%);
  }
  .operation-track--left, .operation-track--right {
    padding: 2rem;
  }
  .operation-track__segment {
    width: 0.1rem;
  }
  .operation-track__dot {
    width: 0.6rem;
    height: 0.6rem;
  }
  .operation-track__label {
    left: 0;
  }
  .operation-track__label .sub-text {
    height: 4.8rem;
    width: 12rem;
    padding: 1rem;
    font-size: 1.2rem;
    margin: 1rem auto 0;
  }
  .operation-contents {
    width: calc(244 / 330 * 100%);
    gap: 9.5rem;
  }
  .operation-work__text {
    line-height: 1.7;
  }
  .operation-morning {
    display: flex;
    flex-direction: column;
    gap: 5rem;
  }
  .operation-work {
    flex-direction: column;
    gap: 1.5rem;
  }
  .operation-work__track {
    width: 100%;
    text-align: left;
  }
  .--am .operation-work__track, .--noon .operation-work__track, .--pm .operation-work__track {
    display: flex;
    justify-content: flex-start;
  }
  .--noon .operation-work__track {
    justify-content: center;
    text-align: center;
  }
  .-noon .operation-track__label {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .operation-work__body {
    width: 100%
  }
  .operation-work__body--row {
    width: 100%;
    flex-direction: column;
    gap: 3rem;
  }
  .operation-work__texts {
    gap: 3rem;
  }
  .--am .operation-work__texts, .--pm .operation-work__texts {
    width: 100%;
  }
  .--arrive .operation-work__img, .--am .operation-work__img, .--pm .operation-work__img {
    width: 100%;
  }
  .operation-work__img-description {
    height: 2.1rem;
    font-size: 1.2rem;
  }
  .--evening {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .operation-work--a_end {
    margin-bottom: 1.4rem;
    font-size: 2.0rem;
  }
  .operation-work--b_start {
    font-size: 2rem;
  }
}