@charset "UTF-8";
/* Safariバージョン10.1~12.0対策 */
* {
  min-height: 0vw;
  min-height: 0;
}

.top-main-visual {
  position: relative;
  overflow: hidden;
  height: 75rem;
}
@keyframes zoomUp {
  0% {
    transform: scale(1.3) translateX(8%) translateY(11%);
  }
  100% {
    transform: scale(1) translateX(0%) translateY(0%);
  }
}
.top-main-visual::after {
  position: absolute;
  z-index: 100;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #333;
  content: "";
  opacity: 0.31;
}
.top-main-visual__container {
  position: relative;
  height: 134.4%;
  background-image: url("../../images/top/bg_top-main-visual.jpg");
  background-image: image-set(url("../../images/top/bg_top-main-visual.jpg") 1x, url("../../images/top/bg_top-main-visual@2x.jpg") 2x);
  background-size: cover;
  transform: scale(1.3) translateX(8%) translateY(11%);
  animation: zoomUp 20s ease-out forwards;
}
@media (max-width: 1280px) {
  .top-main-visual__container {
    background-position: top left 29%;
  }
}
.top-main-visual__content {
  position: absolute;
  z-index: 105;
  right: 13.6rem;
  bottom: 15.4rem;
  display: none;
}
@media (max-width: 767px) {
  .top-main-visual__content {
    right: 1rem;
  }
}
.top-main-visual__content p {
  border: 1px solid rgba(0, 0, 0, 0);
  font-family: "Noto Serif JP", serif;
  font-size: 6.5rem;
  line-height: 1.2;
  color: #fff;
  letter-spacing: 0.15em;
}
@media (max-width: 767px) {
  .top-main-visual {
    aspect-ratio: 640/467;
    width: 100%;
    height: auto;
  }
  .top-main-visual__container {
    height: 100%;
  }
}

.top-emergency {
  background-color: #fceeea;
  padding-block: 6.4rem 6.8rem;
}
@media (max-width: 767px) {
  .top-emergency__container.container {
    width: 474px;
  }
}
.top-emergency__title h2 {
  position: relative;
  padding-left: 2.4rem;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 4rem;
  color: #e50000;
}
.top-emergency__title h2 span {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 0.7rem;
  height: 100%;
}
.top-emergency__title h2 span::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1.3rem;
  content: "";
}
.top-emergency__title h2 span {
  background-color: #e50000;
}
.top-emergency__title h2 span::before {
  background-color: #f28080;
}
.top-emergency__content {
  display: flex;
  padding-top: 3rem;
  justify-content: flex-start;
  gap: 1.9rem;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .top-emergency__content {
    max-width: 100%;
    gap: 0;
    justify-content: space-around;
  }
}
.top-emergency__item {
  position: relative;
  display: flex;
  flex-direction: column;
  width: calc((100% - 3.8rem) / 3);
  height: clamp(125px, 108.3333333333px + 2.1701388889vw, 150px);
  margin-bottom: 1.1rem;
  border: 0.075rem solid #e50000;
  background: #fff;
  text-align: center;
  justify-content: center;
  align-items: center;
}
@media (max-width: 1280px) {
  .top-emergency__item {
    width: calc((100% - 8rem - 3.8rem) / 3);
  }
}
@media (max-width: 1280px) and (max-width: 767px) {
  .top-emergency__item {
    width: 230px;
    height: 125px;
  }
}
.top-emergency__item img {
  width: 11rem;
  aspect-ratio: 110/110;
}
@media (max-width: 767px) {
  .top-emergency__item img {
    width: 77px;
  }
}
.top-emergency__item p {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.2;
  color: #e50000;
  letter-spacing: -0.01em;
  transform: translateY(-1rem);
}
.top-emergency__item::after {
  position: absolute;
  top: 0;
  right: 1.5rem;
  bottom: 0;
  display: block;
  width: 0;
  height: 0;
  margin: auto;
  border-top: 8px solid #e50000;
  border-right: 8px solid transparent;
  border-left: 8px solid transparent;
  content: "";
  transform: rotate(-90deg);
}

.top-safety {
  padding-block: 7.3rem 10rem;
}
@media (max-width: 767px) {
  .top-safety__container.container {
    width: 474px;
    margin-inline: auto;
  }
}
.top-safety__title h2 {
  position: relative;
  padding-left: 2.4rem;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 4rem;
  color: #003881;
}
.top-safety__title h2 span {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 0.7rem;
  height: 100%;
}
.top-safety__title h2 span::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1.3rem;
  content: "";
}
.top-safety__title h2 span {
  background-color: #003881;
}
.top-safety__title h2 span::before {
  background-color: #5682bc;
}
.top-safety__content {
  display: flex;
  padding-top: 3rem;
  justify-content: flex-start;
  gap: 1.9rem;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .top-safety__content {
    gap: 0;
    justify-content: space-around;
  }
}
.top-safety__item {
  position: relative;
  display: flex;
  flex-direction: column;
  width: calc((100% - 3.8rem) / 3);
  height: clamp(150px, 130px + 2.6041666667vw, 180px);
  margin-bottom: 1.1rem;
  border: 0.075rem solid #003881;
  background: #fff;
  text-align: center;
  justify-content: flex-start;
  align-items: center;
}
@media (max-width: 1280px) {
  .top-safety__item {
    width: calc((100% - 8rem - 3.8rem) / 3);
  }
}
@media (max-width: 1280px) and (max-width: 767px) {
  .top-safety__item {
    width: 230px;
    height: 125px;
  }
}
.top-safety__item img {
  width: 11rem;
  aspect-ratio: 110/110;
}
@media (max-width: 767px) {
  .top-safety__item img {
    width: 77px;
  }
}
.top-safety__item p {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.2;
  color: #003881;
  letter-spacing: -0.01em;
}
.top-safety__item::after {
  position: absolute;
  top: 0;
  right: 1.5rem;
  bottom: 0;
  display: block;
  width: 0;
  height: 0;
  margin: auto;
  border-top: 8px solid #003881;
  border-right: 8px solid transparent;
  border-left: 8px solid transparent;
  content: "";
  transform: rotate(-90deg);
}

.top-personnel {
  padding-block: 7.3rem 10rem;
}
.top-personnel__container.container {
  display: grid;
  grid-template: "title--01 title--02" 4rem "content--01 content--02" clamp(125px, 108.3333333333px + 2.1701388889vw, 150px)/calc((100% - 3.8rem) / 3) calc((100% - 3.8rem) / 3);
}
@media (max-width: 1280px) {
  .top-personnel__container.container {
    grid-template: "title--01 title--02" 4rem "content--01 content--02" clamp(125px, 108.3333333333px + 2.1701388889vw, 150px)/calc((100% - 8rem - 3.8rem) / 3) calc((100% - 8rem - 3.8rem) / 3);
  }
}
@media (max-width: 1280px) and (max-width: 767px) {
  .top-personnel__container.container {
    width: 474px;
    margin-inline: auto;
    grid-template: "title--01" 4rem "content--01" 140px "title--02" 4rem "content--02" 140px/100%;
  }
}
.top-personnel__title {
  width: calc((100% - 3.8rem) / 3);
}
.top-personnel__title h2 {
  position: relative;
  padding-left: 2.4rem;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 4rem;
  color: #003881;
  white-space: nowrap;
}
.top-personnel__title h2 span {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 0.7rem;
  height: 100%;
}
.top-personnel__title h2 span::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1.3rem;
  content: "";
}
.top-personnel__title h2 span {
  background-color: #003881;
}
.top-personnel__title h2 span::before {
  background-color: #5682bc;
}
.top-personnel__title--01 {
  grid-area: title--01;
}
.top-personnel__title--02 {
  margin-left: 1.9rem;
  grid-area: title--02;
}
@media (max-width: 767px) {
  .top-personnel__title--02 {
    margin-top: 3rem;
    margin-left: 0;
  }
}
.top-personnel__content {
  padding-top: 3rem;
}
@media (max-width: 767px) {
  .top-personnel__content {
    display: flex;
    justify-content: center;
  }
}
.top-personnel__item {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: clamp(125px, 108.3333333333px + 2.1701388889vw, 150px);
  margin-bottom: 1.1rem;
  border: 0.075rem solid #003881;
  background: #fff;
  text-align: center;
  justify-content: flex-start;
  align-items: center;
}
@media (max-width: 767px) {
  .top-personnel__item {
    width: 230px;
    height: 125px;
  }
}
.top-personnel__item img {
  width: 11rem;
  aspect-ratio: 110/110;
}
@media (max-width: 767px) {
  .top-personnel__item img {
    width: 77px;
  }
}
.top-personnel__item p {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.2;
  color: #003881;
  letter-spacing: -0.01em;
}
.top-personnel__item::after {
  position: absolute;
  top: 0;
  right: 1.5rem;
  bottom: 0;
  display: block;
  width: 0;
  height: 0;
  margin: auto;
  border-top: 8px solid #003881;
  border-right: 8px solid transparent;
  border-left: 8px solid transparent;
  content: "";
  transform: rotate(-90deg);
}
.top-personnel__content--01 {
  grid-area: content--01;
}
.top-personnel__content--02 {
  margin-left: 1.9rem;
  grid-area: content--02;
}
@media (max-width: 767px) {
  .top-personnel__content--02 {
    margin-top: 3rem;
    margin-left: 0;
  }
}

.top-wp-contents {
  padding-block: 7.3rem 10rem;
}
@media (max-width: 767px) {
  .top-wp-contents {
    flex-direction: column;
  }
}
.top-wp-contents__container.container {
  display: flex;
  width: 108.4rem;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2rem;
}
@media (max-width: 767px) {
  .top-wp-contents__container.container {
    width: 53.2rem;
  }
}
.top-wp-contents__gas-price {
  width: 53.2rem;
}
@media (max-width: 767px) {
  .top-wp-contents__gas-price {
    width: 100%;
    max-width: 100%;
  }
}
.top-wp-contents__gas-price_title {
  width: 53.2rem;
  height: 16rem;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.2;
  color: #FFF;
  background-color: #003881;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5rem;
}
@media (max-width: 767px) {
  .top-wp-contents__gas-price_title {
    width: 100%;
    height: 30.0751879699vw;
    min-height: 0;
    max-height: 16rem;
  }
}
.top-wp-contents__gas-price_title img {
  display: block;
  margin-bottom: 1rem;
}
@media (max-width: 767px) {
  .top-wp-contents__gas-price_title img {
    width: clamp(60px, 40.9160305344px + 5.0890585242vw, 80px);
  }
}
.top-wp-contents__gas-price_content__list {
  min-height: 37rem;
  margin-bottom: 2.8rem;
}
.top-wp-contents__gas-price_content__link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 2.2rem;
  font-size: 1.6rem;
  background: #E4EFFA 0% 0% no-repeat padding-box;
  height: 7rem;
  padding-inline: 1.5rem;
  position: relative;
  margin-bottom: 0.5rem;
}
.top-wp-contents__gas-price_content__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 3rem;
  transform: translateY(-50%);
  width: 8px;
  height: 14px;
  background: #003881 0% 0% no-repeat padding-box;
  /* 右向き三角形を作成 */
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.top-wp-contents__gas-price_content__link .title {
  background: #FFF 0% 0% no-repeat padding-box;
  min-width: 18.9rem;
  border-radius: 30px;
  padding-block: 1.4rem;
  padding-inline: 2.4rem;
  text-align: center;
}
.top-wp-contents__gas-price_content__link .date {
  flex-grow: 1;
}
.top-wp-contents__gas-price_link a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 6rem;
  border: 1px solid #003881;
  position: relative;
  padding-inline: 1.5rem 3rem;
  text-align: center;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.2;
  color: #003881;
  letter-spacing: -0.01em;
  align-items: center;
  justify-content: center;
}
.top-wp-contents__gas-price_link a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 3rem;
  transform: translateY(-50%);
  width: 8px;
  height: 14px;
  background: #003881 0% 0% no-repeat padding-box;
  /* 右向き三角形を作成 */
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.top-wp-contents__news {
  width: 53.2rem;
}
@media (max-width: 767px) {
  .top-wp-contents__news {
    width: 100%;
    max-width: 100%;
  }
}
.top-wp-contents__news_title {
  width: 53.2rem;
  height: 16rem;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.2;
  color: #FFF;
  background-color: #003881;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5rem;
}
@media (max-width: 767px) {
  .top-wp-contents__news_title {
    width: 100%;
    height: 30.0751879699vw;
    min-height: 0;
    max-height: 16rem;
  }
}
.top-wp-contents__news_title img {
  display: block;
  margin-bottom: 1rem;
}
@media (max-width: 767px) {
  .top-wp-contents__news_title img {
    width: clamp(56px, 35.0076335878px + 5.5979643766vw, 78px);
  }
}
.top-wp-contents__news_content__list {
  min-height: 37rem;
  margin-bottom: 2.8rem;
}
.top-wp-contents__news_content__link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 2.2rem;
  font-size: 1.6rem;
  background: #E4EFFA 0% 0% no-repeat padding-box;
  height: 7rem;
  padding-inline: 1.5rem;
  position: relative;
  margin-bottom: 0.5rem;
}
.top-wp-contents__news_content__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 3rem;
  transform: translateY(-50%);
  width: 8px;
  height: 14px;
  background: #003881 0% 0% no-repeat padding-box;
  /* 右向き三角形を作成 */
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.top-wp-contents__news_content__link .title {
  background: #FFF 0% 0% no-repeat padding-box;
  min-width: 18.9rem;
  border-radius: 30px;
  padding-block: 1.4rem;
  padding-inline: 2.4rem;
  text-align: center;
}
.top-wp-contents__news_content__link .date {
  flex-grow: 1;
}
.top-wp-contents__news_link a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 6rem;
  border: 1px solid #003881;
  position: relative;
  padding-inline: 1.5rem 3rem;
  text-align: center;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.2;
  color: #003881;
  letter-spacing: -0.01em;
  align-items: center;
  justify-content: center;
}
.top-wp-contents__news_link a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 3rem;
  transform: translateY(-50%);
  width: 8px;
  height: 14px;
  background: #003881 0% 0% no-repeat padding-box;
  /* 右向き三角形を作成 */
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.top-banner__container.container {
  display: flex;
  width: 108.4rem;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2rem;
}
@media (max-width: 767px) {
  .top-banner__container.container {
    width: 53.2rem;
  }
}
.top-banner__container.container a {
  display: block;
  width: 53.2rem;
  max-width: 49%;
  aspect-ratio: 532/140;
}
@media (max-width: 767px) {
  .top-banner__container.container a {
    width: 100%;
    max-width: 100%;
  }
}

.top-link {
  padding-top: 10.1rem;
}
.top-link__container {
  display: flex;
  width: 1920px;
  max-width: 100%;
  margin-inline: auto;
}
@media (max-width: 767px) {
  .top-link__container {
    flex-direction: column;
    align-items: center;
  }
}
.top-link a {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 767px) {
  .top-link a {
    width: 100%;
    max-width: 384px;
  }
}
.top-link a p {
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.2;
  color: #fff;
}
.top-link__recruit {
  width: 50%;
  height: 30rem;
  background-image: url("../../images/top/bg_top-link-recruit.png");
  background-image: image-set(url("../../images/top/bg_top-link-recruit.png") 1x, url("../../images/top/bg_top-link-recruit@2x.png") 2x);
  background-size: cover;
}
.top-link__company {
  width: 50%;
  height: 30rem;
  background-image: url("../../images/top/bg_top-link-company.png");
  background-image: image-set(url("../../images/top/bg_top-link-company.png") 1x, url("../../images/top/bg_top-link-company@2x.png") 2x);
  background-size: cover;
}