* {
  margin: calc(100vw * 0 / 1440);
  padding: calc(100vw * 0 / 1440);
  box-sizing: border-box;
}

body {
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Kaku Gothic ProN",
    "Hiragino Sans", "Noto Sans JP", Meiryo, Arial, sans-serif;
  background-color: rgba(255, 255, 255, 1);
  line-height: 1.6;
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

.service-title,
.news-title,
.company-title {
  font-size: calc(100vw * 40 / 1440);
  color: rgba(0, 125, 201, 1);
  margin: calc(100vw * 0 / 1440);
  font-weight: bold;
  letter-spacing: 0.2em;
  position: relative;
  z-index: 2;
}

.service-watermark,
.news-watermark,
.company-watermark {
  position: absolute;
  left: calc(100vw * 0 / 1440);
  top: calc(100vw * -72 / 1440);
  z-index: 1;
  font-size: calc(100vw * 110 / 1440);
  font-weight: bold;
  letter-spacing: 0.2em;
  color: rgba(0, 125, 201, 0.1);
  pointer-events: none;
  user-select: none;
}

.title-content {
  padding: calc(100vw * 60 / 1440) calc(100vw * 0 / 1440);
}

.title-content h1 {
  color: rgba(0, 125, 201, 0.1);
  font-size: calc(100vw * 85 / 1440);
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fv-container {
  position: relative;
  min-height: calc(100vw * 502 / 1440);
  background-image: url(./image/fv-background.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  border-radius: calc(100vw * 0 / 1440) calc(100vw * 50 / 1440) calc(100vw * 50 / 1440) calc(100vw * 0 / 1440);
  overflow: hidden;
  margin: calc(100vw * 0 / 1440) calc(100vw * 102 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.fv-content {
  position: absolute;
  top: calc(100vw * 0 / 1440);
  right: calc(100vw * 0 / 1440);
  bottom: calc(100vw * 0 / 1440);
  left: calc(100vw * 0 / 1440);
  background-color: rgba(0, 0, 0, 0.4);
  padding: calc(100vw * 98 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 170 / 1440);
  color: rgba(255, 255, 255, 1);
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  border-radius: calc(100vw * 0 / 1440) calc(100vw * 50 / 1440) calc(100vw * 50 / 1440) calc(100vw * 0 / 1440);
}

.fv-text {
  font-weight: bold;
  font-size: calc(100vw * 20 / 1440);
  line-height: calc(100vw * 45 / 1440);
}

.service-container,
.article-container {
  display: flex;
  justify-content: center;
  padding: calc(100vw * 81 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  margin: calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 70 / 1440) calc(100vw * 0 / 1440);
}

.service-wrapper,
.article-wrapper {
  width: min(calc(100vw * 1366 / 1440), 100%);
  margin: calc(100vw * 0 / 1440) auto;
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440);
}

.service-content,
.article-content {
  width: 100%;
  position: relative;
}

.service-carousel,
.article-carousel {
  margin: calc(100vw * 29 / 1440) calc(100vw * -60 / 1440) calc(100vw * 0 / 1440) calc(100vw * -60 / 1440);
  display: flex;
  align-items: center;
  gap: calc(100vw * 20 / 1440);
}

.service-cards-wrapper,
.article-cards-wrapper {
  flex: 1;
  overflow: hidden;
  min-width: calc(100vw * 0 / 1440);
}

.service-cards,
.article-cards {
  display: flex;
  gap: calc(100vw * 41 / 1440);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.service-card,
.article-card {
  flex: 0 0 calc((100% - (calc(100vw * 82 / 1440))) / 3);
  overflow: hidden;
  box-shadow: calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 30 / 1440) rgba(0, 0, 0, 0.1);
  border-radius: calc(100vw * 10 / 1440);
  display: flex;
  flex-direction: column;
  background-color: rgba(255, 255, 255, 1);
  margin: calc(100vw * 2 / 1440);
  min-width: calc(100vw * 0 / 1440);
}

.service-image,
.article-image {
  height: calc(100vw * 288 / 1440);
  overflow: hidden;
  border-radius: calc(100vw * 10 / 1440) calc(100vw * 10 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.service-image img,
.article-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.service-card-title,
.article-card-title {
  padding: calc(100vw * 20 / 1440);
  font-size: calc(100vw * 24 / 1440);
  color: rgba(0, 0, 0, 1);
  background-color: #f4faff;
  min-height: calc(100vw * 120 / 1440);
  padding-bottom: calc(100vw * 0 / 1440);
}

.service-text,
.article-text {
  margin: calc(100vw * 11 / 1440) auto calc(100vw * 35 / 1440);
  font-size: calc(100vw * 16 / 1440);
  line-height: calc(100vw * 30 / 1440);
  color: rgba(0, 0, 0, 1);
  padding: calc(100vw * 10 / 1440);
}

.carousel-nav {
  position: relative;
  width: calc(100vw * 40 / 1440);
  height: calc(100vw * 40 / 1440);
  border-radius: 50%;
  border: calc(100vw * 1 / 1440) solid rgba(29, 58, 120, 1);
  background-color: rgba(255, 255, 255, 1);
  cursor: pointer;
  transition: all 0.3s ease;
}

@media (min-width: 769px) {
  .carousel-nav {
    display: none;
  }
}

.carousel-nav::before,
.carousel-nav::after {
  content: "";
  position: absolute;
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 10 / 1440);
  background-color: rgba(29, 58, 120, 1);
  transition: background-color 0.3s ease;
  border-radius: calc(100vw * 2 / 1440);
}

.carousel-nav-prev::before {
  top: calc(100vw * 11 / 1440);
  left: calc(100vw * 17 / 1440);
  transform: rotate(45deg);
}

.carousel-nav-prev::after {
  bottom: calc(100vw * 11 / 1440);
  left: calc(100vw * 17 / 1440);
  transform: rotate(-45deg);
}

.carousel-nav-next::before {
  top: calc(100vw * 11 / 1440);
  right: calc(100vw * 17 / 1440);
  transform: rotate(-45deg);
}

.carousel-nav-next::after {
  bottom: calc(100vw * 11 / 1440);
  right: calc(100vw * 17 / 1440);
  transform: rotate(45deg);
}

.service-actions,
.article-actions {
  margin: calc(100vw * 40 / 1440) calc(100vw * -24 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  display: flex;
  justify-content: flex-end;
}

.service-actions .more-button,
.article-actions .more-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: calc(100vw * 70 / 1440);
  min-width: calc(100vw * 315 / 1440);
  border-radius: calc(100vw * 10 / 1440);
  border: none;
  background: linear-gradient(90deg, #1d3a78 0%, #395797 100%);
  color: rgba(255, 255, 255, 1);
  font-size: calc(100vw * 20 / 1440);
  font-weight: bold;
  cursor: pointer;
  line-height: calc(100vw * 30 / 1440);
  transition: opacity 0.3s ease;
}

.service-actions .more-button::after,
.article-actions .more-button::after {
  content: "";
  position: absolute;
  bottom: calc(100vw * 27 / 1440);
  right: calc(100vw * 35 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 10 / 1440);
  background: rgba(255, 255, 255, 1);
  transform: rotate(45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.service-actions .more-button::before,
.article-actions .more-button::before {
  content: "";
  position: absolute;
  top: calc(100vw * 27 / 1440);
  right: calc(100vw * 35 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 10 / 1440);
  background: rgba(255, 255, 255, 1);
  transform: rotate(-45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.news-container {
  padding: calc(100vw * 80 / 1440) calc(100vw * 0 / 1440) calc(100vw * 70 / 1440);
  background: rgba(57, 87, 151, 0.03);
}

.news-wrapper {
  width: min(calc(100vw * 1366 / 1440), 100%);
  margin: calc(100vw * 0 / 1440) auto;
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440);
  display: flex;
  gap: calc(100vw * 89 / 1440);
  align-items: flex-start;
}

.news-content-left {
  position: relative;
}

.news-content-left .more-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: calc(100vw * 22 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  min-width: calc(100vw * 199 / 1440);
  height: calc(100vw * 70 / 1440);
  border-radius: calc(100vw * 10 / 1440);
  border: none;
  background-color: rgba(41, 82, 145, 1);
  color: rgba(255, 255, 255, 1);
  font-size: calc(100vw * 20 / 1440);
  font-weight: bold;
  cursor: pointer;
}

.news-content-left .more-button::after {
  content: "";
  position: absolute;
  bottom: calc(100vw * 28 / 1440);
  right: calc(100vw * 30 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 8 / 1440);
  background-color: rgba(255, 255, 255, 1);
  transform: rotate(45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.news-content-left .more-button::before {
  content: "";
  position: absolute;
  top: calc(100vw * 29 / 1440);
  right: calc(100vw * 30 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 8 / 1440);
  background-color: rgba(255, 255, 255, 1);
  transform: rotate(-45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.news-content-right {
  flex: 1;
  min-width: calc(100vw * 0 / 1440);
}

.news-list {
  width: 100%;
}

.news-item {
  display: grid;
  grid-template-columns: calc(100vw * 120 / 1440) calc(100vw * 180 / 1440) 1fr;
  grid-template-areas:
    "genre date date"
    "title title title";
  column-gap: calc(100vw * 18 / 1440);
  row-gap: calc(100vw * 10 / 1440);
  padding: calc(100vw * 40 / 1440) calc(100vw * 0 / 1440);
  border-bottom: calc(100vw * 1 / 1440) solid rgba(185, 185, 185, 1);
}

.news-genre {
  grid-area: genre;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: calc(100vw * 40 / 1440);
  border-radius: calc(100vw * 5 / 1440);
  font-size: calc(100vw * 16 / 1440);
}

.news-date {
  grid-area: date;
  margin: calc(100vw * 0 / 1440);
  font-size: calc(100vw * 14 / 1440);
  text-align: left;
  display: flex;
  align-items: center;
}

.news-link {
  grid-area: title;
  font-size: calc(100vw * 16 / 1440);
  min-width: calc(100vw * 0 / 1440);
  word-break: break-word;
}

.news-link:hover {
  text-decoration: underline;
}

.news-item:nth-child(1) .news-genre {
  background: rgba(243, 237, 193, 1);
}

.news-item:nth-child(2) .news-genre {
  background: rgba(251, 234, 232, 1);
}

.news-item:nth-child(3) .news-genre {
  background: rgba(218, 237, 242, 1);
}

.recruit-container {
  position: relative;
  min-height: calc(100vw * 560 / 1440);
  background-image: url(./image/recruit-background.png);
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
  border-radius: calc(100vw * 20 / 1440);
  overflow: hidden;
  margin: calc(100vw * 0 / 1440) calc(100vw * 73 / 1440);
}

.recruit-content {
  position: absolute;
  top: calc(100vw * 0 / 1440);
  right: calc(100vw * 0 / 1440);
  bottom: calc(100vw * 0 / 1440);
  left: calc(100vw * 0 / 1440);
  background-color: rgba(0, 0, 0, 0.25);
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  border-radius: calc(100vw * 20 / 1440);
}

.recruit-text-area {
  padding: calc(100vw * 48 / 1440) calc(100vw * 60 / 1440) calc(100vw * 60 / 1440);
}

.recruit-title {
  font-size: calc(100vw * 40 / 1440);
  color: rgba(255, 255, 255, 1);
  margin: calc(100vw * 0 / 1440);
  font-weight: bold;
  letter-spacing: 0.2em;
  position: relative;
  z-index: 2;
}

.recruit-watermark {
  position: absolute;
  left: calc(100vw * 60 / 1440);
  top: calc(100vw * -12 / 1440);
  z-index: 1;
  font-size: calc(100vw * 110 / 1440);
  font-weight: bold;
  letter-spacing: 0.2em;
  color: rgba(255, 255, 255, 0.5);
  pointer-events: none;
  user-select: none;
}

.recruit-head {
  font-size: calc(100vw * 40 / 1440);
  font-weight: bold;
  color: rgba(255, 255, 255, 1);
  margin: calc(100vw * 40 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.recruit-description {
  font-size: calc(100vw * 20 / 1440);
  font-weight: bold;
  color: rgba(255, 255, 255, 1);
  margin: calc(100vw * 30 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.recruit-actions {
  display: flex;
  justify-content: flex-start;
}

.recruit-actions .more-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: calc(100vw * 30 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  min-width: calc(100vw * 290 / 1440);
  height: calc(100vw * 70 / 1440);
  border-radius: calc(100vw * 10 / 1440);
  border: calc(100vw * 1 / 1440) solid rgba(29, 58, 120, 1);
  background-color: rgba(255, 255, 255, 1);
  color: rgba(29, 58, 120, 1);
  font-size: calc(100vw * 20 / 1440);
  cursor: pointer;
}

.recruit-actions .more-button::after {
  content: "";
  position: absolute;
  bottom: calc(100vw * 28 / 1440);
  right: calc(100vw * 30 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 8 / 1440);
  background-color: rgba(29, 58, 120, 1);
  transform: rotate(45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.recruit-actions .more-button::before {
  content: "";
  position: absolute;
  top: calc(100vw * 29 / 1440);
  right: calc(100vw * 30 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 8 / 1440);
  background-color: rgba(29, 58, 120, 1);
  transform: rotate(-45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.company-container {
  background-color: rgba(255, 255, 255, 1);
  padding: calc(100vw * 140 / 1440) calc(100vw * 0 / 1440) calc(100vw * 82 / 1440);
  position: relative;
  overflow: hidden;
}

.company-container::after {
  content: "";
  position: absolute;
  bottom: calc(100vw * 0 / 1440);
  left: calc(100vw * 0 / 1440);
  width: 100%;
  height: calc(100vw * 121 / 1440);
  background-color: rgba(29, 58, 120, 1);
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  pointer-events: none;
  display: none;
}

.company-wrapper {
  width: min(calc(100vw * 1026 / 1440), 100%);
  margin: calc(100vw * 0 / 1440) auto;
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440);
}

.company-content {
  position: relative;
}

.company-info-list {
  border-radius: calc(100vw * 12 / 1440);
  padding: calc(100vw * 40 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.company-info-item {
  display: flex;
  gap: calc(100vw * 106 / 1440);
  padding: calc(100vw * 20 / 1440) calc(100vw * 0 / 1440);
  border-bottom: calc(100vw * 1 / 1440) solid rgba(185, 185, 185, 1);
}

.company-info-item:last-child {
  border-bottom: none;
  align-items: flex-start;
  margin-bottom: calc(100vw * 85 / 1440);
}

.company-info-label {
  font-size: calc(100vw * 20 / 1440);
  flex: 0 0 calc(100vw * 260 / 1440);
}

.company-info-value {
  font-size: calc(100vw * 16 / 1440);
  margin: calc(100vw * 0 / 1440);
  flex: 1;
}

.company-map {
  width: 100%;
  height: calc(100vw * 420 / 1440);
  overflow: hidden;
  border-radius: calc(100vw * 12 / 1440);
}

.company-map iframe {
  width: 100%;
  height: 100%;
  min-height: calc(100vw * 420 / 1440);
}

.stats-container {
  padding: calc(100vw * 97 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.stats-wrapper {
  width: min(calc(100vw * 1366 / 1440), 100%);
  margin: calc(100vw * 0 / 1440) auto;
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440);
}

.stats-content {
  display: flex;
  position: relative;
  background-color: rgba(255, 255, 255, 1);
  border: calc(100vw * 20 / 1440) solid rgba(29, 58, 120, 0.4);
  border-radius: calc(100vw * 30 / 1440);
  padding: calc(100vw * 0 / 1440) calc(100vw * 40 / 1440);
}

.stats-item {
  flex: 1;
  text-align: center;
  margin: calc(100vw * 107 / 1440) calc(100vw * 0 / 1440);
}

.stats-item:first-child::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 10%;
  bottom: 10%;
  width: calc(100vw * 1 / 1440);
  background-color: rgba(185, 185, 185, 1);
}

.stats-label,
.stats-period {
  font-size: calc(100vw * 20 / 1440);
}

.stats-value {
  font-size: calc(100vw * 64 / 1440);
  font-weight: bold;
  color: rgba(247, 181, 0, 1);
  margin: calc(100vw * 18 / 1440) calc(100vw * 0 / 1440);
}

.stats-unit {
  font-size: calc(100vw * 32 / 1440);
  font-weight: bold;
  color: rgba(0, 0, 0, 1);
}

.service-bottom-container {
  background-color: rgba(249, 250, 251, 1);
  padding: calc(100vw * 80 / 1440) calc(100vw * 0 / 1440);
}

.service-bottom-wrapper {
  width: min(calc(100vw * 1366 / 1440), 100%);
  margin: calc(100vw * 0 / 1440) auto;
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440);
}

.service-bottom-content {
  width: 100%;
}

.contact-container {
  background-color: rgba(29, 58, 120, 1);
  padding: calc(100vw * 100 / 1440) calc(100vw * 0 / 1440);
  color: rgba(255, 255, 255, 1);
}

.contact-wrapper {
  width: min(calc(100vw * 1366 / 1440), 100%);
  margin: calc(100vw * 0 / 1440) auto;
  padding: calc(100vw * 0 / 1440) calc(100vw * 24 / 1440);
  display: flex;
  align-items: center;
}

.contact-content {
  width: 100%;
}

.contact-text-area {
  display: flex;
  align-items: center;
  gap: calc(100vw * 0 / 1440);
}

.contact-title {
  font-size: calc(100vw * 40 / 1440);
  font-weight: bold;
  line-height: calc(100vw * 30 / 1440);
}

.contact-actions {
  margin-left: auto;
}

.contact-description {
  font-size: calc(100vw * 20 / 1440);
  font-weight: bold;
  line-height: calc(100vw * 35 / 1440);
  margin: calc(100vw * 20 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
}

.contact-actions .more-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 25 / 1440);
  min-width: calc(100vw * 315 / 1440);
  height: calc(100vw * 70 / 1440);
  border-radius: calc(100vw * 10 / 1440);
  border: calc(100vw * 1 / 1440) solid rgba(29, 58, 120, 1);
  background-color: rgba(255, 255, 255, 1);
  color: rgba(29, 58, 120, 1);
  font-size: calc(100vw * 20 / 1440);
  cursor: pointer;
}

.contact-actions .more-button::after {
  content: "";
  position: absolute;
  bottom: calc(100vw * 28 / 1440);
  right: calc(100vw * 30 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 8 / 1440);
  background-color: rgba(29, 58, 120, 1);
  transform: rotate(45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.contact-actions .more-button::before {
  content: "";
  position: absolute;
  top: calc(100vw * 29 / 1440);
  right: calc(100vw * 30 / 1440);
  width: calc(100vw * 2 / 1440);
  height: calc(100vw * 8 / 1440);
  background-color: rgba(29, 58, 120, 1);
  transform: rotate(-45deg);
  border-radius: calc(100vw * 2 / 1440);
}

.contact-button-area .more-button:hover {
  opacity: 0.9;
}

header {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}

.title-ch-container {
  background-image: url(./image/fv-background-ch.png);
  background-position: center;
  background-size: cover;
}

.title-ch-wrapper {
  padding-top: calc(100vw * 219 / 1440);
  padding-bottom: calc(100vw * 79 / 1440);
}

.title-heading {
  padding-left: calc(100vw * 3 / 1440);
  padding-right: calc(100vw * 3 / 1440);
}

.title-heading h1 {
  font-size: calc(100vw * 85 / 1440);
  font-weight: 900;
  color: #ffffff;
  line-height: calc(100vw * 102 / 1440);
}

.title-text {
  padding-top: calc(100vw * 79 / 1440);
  padding-left: calc(100vw * 170 / 1440);
}

.title-text p {
  font-size: calc(100vw * 20 / 1440);
  font-weight: 900;
  color: #ffffff;
  line-height: calc(100vw * 45 / 1440);
}

@media (min-width: 769px) {
	.title-heading h1 {
		text-align:center;
	}
  .title-heading-sp {
    display: none;
  }
}

@media (max-width: 768px) {
  * {
    margin: calc(100vw * 0 / 375);
    padding: calc(100vw * 0 / 375);
  }

  .title-heading-pc {
    display: none;
  }

  .title-ch-container {
    background-image: url(./image/fv-background-ch.png);
    background-position: center;
    background-size: cover;
  }

  .title-ch-wrapper {
    padding-top: calc(100vw * 120 / 375);
    padding-bottom: calc(100vw * 60 / 375);
  }

  .title-heading {
    padding-left: calc(100vw * 10 / 375);
    padding-right: calc(100vw * 10 / 375);
  }

  .title-heading h1 {
    font-size: calc(100vw * 50 / 375);
    line-height: calc(100vw * 85 / 375);
  }

  .title-text {
    padding-top: calc(100vw * 20 / 375);
    padding-left: calc(100vw * 10 / 375);
    padding-right: calc(100vw * 10 / 375);
  }

  .title-text p {
    font-size: calc(100vw * 18 / 375);
    line-height: calc(100vw * 35 / 375);
  }

  .title-text p br {
    display: none;
  }
}

@media (max-width: 768px) {
  .service-title,
  .news-title,
  .company-title {
    font-size: calc(100vw * 28 / 375);
    letter-spacing: 0.18em;
  }

  .service-watermark,
  .news-watermark,
  .company-watermark {
    top: calc(100vw * -44 / 375);
    font-size: calc(100vw * 64 / 375);
    letter-spacing: 0.18em;
    left: calc(100vw * 0 / 375);
  }

  .service-container,
  .article-container {
    padding: calc(100vw * 50 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    margin: calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 50 / 375) calc(100vw * 0 / 375);
  }

  .service-wrapper,
  .article-wrapper {
    width: 100%;
    padding: calc(100vw * 0 / 375) calc(100vw * 18 / 375);
  }

  .service-content,
  .article-content {
    width: 100%;
  }

  .service-carousel,
  .article-carousel {
    margin: calc(100vw * 18 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    gap: calc(100vw * 12 / 375);
    align-items: center;
  }

  .carousel-nav {
    width: calc(100vw * 34 / 375);
    height: calc(100vw * 34 / 375);
    flex: 0 0 auto;
  }

  .carousel-nav::before,
  .carousel-nav::after {
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 9 / 375);
    border-radius: calc(100vw * 2 / 375);
  }

  .carousel-nav-prev::before {
    top: calc(100vw * 9 / 375);
    left: calc(100vw * 14 / 375);
  }

  .carousel-nav-prev::after {
    bottom: calc(100vw * 9 / 375);
    left: calc(100vw * 14 / 375);
  }

  .carousel-nav-next::before {
    top: calc(100vw * 9 / 375);
    right: calc(100vw * 14 / 375);
  }

  .carousel-nav-next::after {
    bottom: calc(100vw * 9 / 375);
    right: calc(100vw * 14 / 375);
  }

  .service-cards-wrapper,
  .article-cards-wrapper {
    overflow: hidden;
  }

  .service-cards,
  .article-cards {
    gap: calc(100vw * 14 / 375);
  }

  .service-card,
  .article-card {
    flex: 0 0 100%;
    border-radius: calc(100vw * 10 / 375);
    margin: calc(100vw * 2 / 375);
    box-shadow: calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 30 / 375) rgba(0, 0, 0, 0.1);
  }

  .service-image,
  .article-image {
    height: calc(100vw * 200 / 375);
    border-radius: calc(100vw * 10 / 375) calc(100vw * 10 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
  }

  .service-card-title,
  .article-card-title {
    padding: calc(100vw * 20 / 375);
    font-size: calc(100vw * 20 / 375);
    min-height: calc(100vw * 120 / 375);
    padding-bottom: calc(100vw * 0 / 375);
  }

  .service-text,
  .article-text {
    margin: calc(100vw * 10 / 375) auto calc(100vw * 22 / 375);
    font-size: calc(100vw * 14 / 375);
    line-height: calc(100vw * 26 / 375);
    text-align: left;
    width: calc(100vw * 315 / 375);
    max-width: 100%;
    padding: calc(100vw * 10 / 375);
  }

  .service-actions,
  .article-actions {
    margin: calc(100vw * 18 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    padding: calc(100vw * 0 / 375);
    justify-content: center;
  }

  .service-actions .more-button,
  .article-actions .more-button {
    width: 100%;
    min-width: calc(100vw * 0 / 375);
    height: calc(100vw * 56 / 375);
    border-radius: calc(100vw * 10 / 375);
    font-size: calc(100vw * 16 / 375);
    line-height: calc(100vw * 30 / 375);
  }

  .service-actions .more-button::after,
  .article-actions .more-button::after {
    bottom: calc(100vw * 22 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 9 / 375);
    border-radius: calc(100vw * 2 / 375);
  }

  .service-actions .more-button::before,
  .article-actions .more-button::before {
    top: calc(100vw * 22 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 9 / 375);
    border-radius: calc(100vw * 2 / 375);
  }

  .news-container {
    padding: calc(100vw * 56 / 375) calc(100vw * 0 / 375) calc(100vw * 50 / 375);
  }

  .news-wrapper {
    width: 100%;
    padding: calc(100vw * 0 / 375) calc(100vw * 18 / 375);
    flex-direction: column;
    gap: calc(100vw * 22 / 375);
  }

  .news-content-left {
    width: 100%;
  }

  .news-content-left .more-button {
    width: 100%;
    min-width: calc(100vw * 0 / 375);
    height: calc(100vw * 56 / 375);
    border-radius: calc(100vw * 10 / 375);
    font-size: calc(100vw * 16 / 375);
    margin: calc(100vw * 14 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
  }

  .news-content-left .more-button::after {
    bottom: calc(100vw * 20 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
    border-radius: calc(100vw * 2 / 375);
  }

  .news-content-left .more-button::before {
    top: calc(100vw * 23 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
    border-radius: calc(100vw * 2 / 375);
  }

  .news-content-right {
    width: 100%;
  }

  .news-item {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "genre date"
      "title title";
    column-gap: calc(100vw * 12 / 375);
    row-gap: calc(100vw * 10 / 375);
    padding: calc(100vw * 18 / 375) calc(100vw * 0 / 375);
    border-bottom: calc(100vw * 1 / 375) solid rgba(185, 185, 185, 1);
  }

  .news-genre {
    height: calc(100vw * 34 / 375);
    border-radius: calc(100vw * 6 / 375);
    font-size: calc(100vw * 13 / 375);
  }

  .news-date {
    font-size: calc(100vw * 12 / 375);
    justify-content: flex-end;
  }

  .news-link {
    font-size: calc(100vw * 14 / 375);
    line-height: calc(100vw * 24 / 375);
  }

  .recruit-container {
    min-height: calc(100vw * 520 / 375);
    margin: calc(100vw * 0 / 375) calc(100vw * 18 / 375);
    border-radius: calc(100vw * 16 / 375);
  }

  .recruit-content {
    border-radius: calc(100vw * 16 / 375);
    align-items: flex-start;
  }

  .recruit-text-area {
    padding: calc(100vw * 28 / 375) calc(100vw * 18 / 375) calc(100vw * 26 / 375);
  }

  .recruit-title {
    font-size: calc(100vw * 28 / 375);
    letter-spacing: 0.18em;
  }

  .recruit-watermark {
    left: calc(100vw * 18 / 375);
    top: calc(100vw * -4 / 375);
    font-size: calc(100vw * 64 / 375);
    letter-spacing: 0.18em;
  }

  .recruit-head {
    font-size: calc(100vw * 22 / 375);
    line-height: calc(100vw * 34 / 375);
    margin: calc(100vw * 18 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
  }

  .recruit-description {
    font-size: calc(100vw * 14 / 375);
    line-height: calc(100vw * 26 / 375);
    margin: calc(100vw * 14 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    font-weight: 700;
  }

  .recruit-actions .more-button {
    width: 100%;
    min-width: calc(100vw * 0 / 375);
    height: calc(100vw * 56 / 375);
    border-radius: calc(100vw * 10 / 375);
    font-size: calc(100vw * 16 / 375);
    margin: calc(100vw * 18 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
  }

  .recruit-actions .more-button::after {
    bottom: calc(100vw * 22 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }

  .recruit-actions .more-button::before {
    top: calc(100vw * 23 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }

  .company-container {
    padding: calc(100vw * 70 / 375) calc(100vw * 0 / 375) calc(100vw * 60 / 375);
  }

  .company-container::after {
    height: calc(100vw * 90 / 375);
  }

  .company-wrapper {
    width: 100%;
    padding: calc(100vw * 0 / 375) calc(100vw * 18 / 375);
  }

  .company-info-list {
    padding: calc(100vw * 18 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    border-radius: calc(100vw * 12 / 375);
  }

  .company-info-item {
    flex-direction: column;
    gap: calc(100vw * 8 / 375);
    padding: calc(100vw * 16 / 375) calc(100vw * 0 / 375);
    border-bottom: calc(100vw * 1 / 375) solid rgba(185, 185, 185, 1);
  }

  .company-info-label {
    font-size: calc(100vw * 15 / 375);
    flex: none;
  }

  .company-info-value {
    font-size: calc(100vw * 14 / 375);
    line-height: calc(100vw * 24 / 375);
    width: 100%;
  }

  .company-info-item:last-child {
    margin-bottom: calc(100vw * 40 / 375);
  }

  .company-map {
    height: calc(100vw * 260 / 375);
    border-radius: calc(100vw * 12 / 375);
  }

  .company-map iframe {
    min-height: calc(100vw * 260 / 375);
  }

  .stats-container {
    padding: calc(100vw * 50 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
  }

  .stats-wrapper {
    width: 100%;
    padding: calc(100vw * 0 / 375) calc(100vw * 18 / 375);
  }

  .stats-content {
    flex-direction: column;
    border: calc(100vw * 10 / 375) solid rgba(29, 58, 120, 0.4);
    border-radius: calc(100vw * 18 / 375);
    padding: calc(100vw * 10 / 375) calc(100vw * 14 / 375);
  }

  .stats-item {
    margin: calc(100vw * 26 / 375) calc(100vw * 0 / 375);
  }

  .stats-item:first-child::after {
    left: 10%;
    right: 10%;
    top: auto;
    bottom: calc(100vw * 0 / 375);
    width: auto;
    height: calc(100vw * 1 / 375);
  }

  .stats-label,
  .stats-period {
    font-size: calc(100vw * 14 / 375);
  }

  .stats-value {
    font-size: calc(100vw * 48 / 375);
    margin: calc(100vw * 10 / 375) calc(100vw * 0 / 375);
  }

  .stats-unit {
    font-size: calc(100vw * 22 / 375);
  }

  .contact-container {
    padding: calc(100vw * 60 / 375) calc(100vw * 0 / 375);
  }

  .contact-wrapper {
    width: 100%;
    padding: calc(100vw * 0 / 375) calc(100vw * 18 / 375);
  }

  .contact-text-area {
    flex-direction: column;
    align-items: flex-start;
    gap: calc(100vw * 16 / 375);
  }

  .contact-title {
    font-size: calc(100vw * 28 / 375);
    line-height: calc(100vw * 34 / 375);
  }

  .contact-description {
    font-size: calc(100vw * 12 / 375);
    line-height: calc(100vw * 24 / 375);
    margin: calc(100vw * 0 / 375);
    font-weight: 700;
  }

  .contact-actions {
    margin-left: calc(100vw * 0 / 375);
    width: 100%;
  }

  .contact-actions .more-button {
    width: 100%;
    min-width: calc(100vw * 0 / 375);
    height: calc(100vw * 56 / 375);
    border-radius: calc(100vw * 10 / 375);
    font-size: calc(100vw * 16 / 375);
    margin: calc(100vw * 0 / 375);
  }

  .contact-actions .more-button::after {
    bottom: calc(100vw * 22 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }

  .contact-actions .more-button::before {
    top: calc(100vw * 23 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }
}

.title-container {
  display: none;
}

.company-article-wave {
  position: relative;
  width: 100%;
  height: calc(100vw * 150 / 1440);
  overflow: hidden;
  background-color: #ffffff;
  background-image:
    radial-gradient(calc(100vw * 1200 / 1440) calc(100vw * 600 / 1440) at 20% 0%, rgba(0, 125, 201, 0.10), rgba(255, 255, 255, 0) 62%),
    radial-gradient(calc(100vw * 900 / 1440) calc(100vw * 520 / 1440) at 85% 10%, rgba(0, 125, 201, 0.08), rgba(255, 255, 255, 0) 60%),
    linear-gradient(to bottom, rgba(255, 255, 255, 1), rgba(255, 255, 255, 1));
  margin-top: calc(100vw * -65 / 1440);
  margin-bottom: calc(100vw * -25 / 1440);
  pointer-events: none;
}

.company-article-wave__svg {
  position: absolute;
  left: 50%;
  bottom: calc(100vw * -1 / 1440);
  transform: translateX(-50%);
  width: 120%;
  height: 100%;
  display: block;
}

@media (max-width: 768px) {
  .company-article-wave {
    height: calc(100vw * 110 / 375);
    margin-top: calc(100vw * -52 / 375);
    margin-bottom: calc(100vw * -22 / 375);
  }

  .company-article-wave__svg {
    width: 160%;
    bottom: calc(100vw * -1 / 375);
  }
}

.company-container,
.article-container {
  background-color: #fff;
  background-image:
    radial-gradient(calc(100vw * 1200 / 1440) calc(100vw * 600 / 1440) at 20% 0%, rgba(0, 125, 201, 0.08), rgba(255, 255, 255, 0) 62%),
    radial-gradient(calc(100vw * 900 / 1440) calc(100vw * 520 / 1440) at 85% 10%, rgba(0, 125, 201, 0.06), rgba(255, 255, 255, 0) 60%),
    linear-gradient(to bottom, rgba(255, 255, 255, 1), rgba(255, 255, 255, 1));
  background-repeat: no-repeat;
}

.company-container,
.article-container {
  position: relative;
  z-index: 2;
  background: transparent;
}

.company-article-wave {
  position: relative;
  width: 100%;
  height: calc(100vw * 420 / 1440);
  min-height: calc(100vw * 420 / 1440);
  overflow: hidden;
  pointer-events: none;
  background-color: #fff;
  background-image:
    linear-gradient(
      to bottom,
      rgba(255, 255, 255, 1) 0%,
      rgba(0, 125, 201, 0.06) 40%,
      rgba(255, 255, 255, 1) 100%
    );
  background-repeat: no-repeat;
  margin-top: calc(100vw * -260 / 1440);
  margin-bottom: calc(100vw * -220 / 1440);
  z-index: 1;
}

.company-article-wave__svg {
  position: absolute;
  left: 50%;
  bottom: calc(100vw * -4 / 1440);
  transform: translateX(-50%);
  width: 170%;
  height: 100%;
  display: block;
}

.company-container {
  padding: calc(100vw * 140 / 1440) calc(100vw * 0 / 1440) calc(100vw * 10 / 1440);
  background: #fff;
}

.article-container {
  padding: calc(100vw * 10 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  margin: calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 70 / 1440) calc(100vw * 0 / 1440);
  background: #fff;
}

@media (max-width: 768px) {
  .company-article-wave {
    height: calc(100vw * 320 / 375);
    min-height: calc(100vw * 320 / 375);
    margin-top: calc(100vw * -210 / 375);
    margin-bottom: calc(100vw * -180 / 375);
  }

  .company-article-wave__svg {
    width: 240%;
    bottom: calc(100vw * -4 / 375);
  }

  .company-container {
    padding: calc(100vw * 70 / 375) calc(100vw * 0 / 375) calc(100vw * 6 / 375);
    background: #fff;
  }

  .article-container {
    padding: calc(100vw * 6 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    background: #fff;
    margin: calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 50 / 375) calc(100vw * 0 / 375);
  }
}

.company-container {
  position: relative;
  background: #fff;
  padding: calc(100vw * 140 / 1440) calc(100vw * 0 / 1440) calc(100vw * 82 / 1440);
  z-index: 2;
}

.article-container {
  position: relative;
  background: #fff;
  padding: calc(100vw * 81 / 1440) calc(100vw * 0 / 1440) calc(100vw * 0 / 1440);
  margin: calc(100vw * 0 / 1440) calc(100vw * 0 / 1440) calc(100vw * 70 / 1440) calc(100vw * 0 / 1440);
  z-index: 2;
}

.company-article-wave {
  position: relative;
  height: calc(100vw * 170 / 1440);
  overflow: hidden;
  pointer-events: none;
  margin-top: calc(100vw * -85 / 1440);
  margin-bottom: calc(100vw * -85 / 1440);
  background: transparent;
  z-index: 1;
}

.company-article-wave::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to bottom,
      rgba(255, 255, 255, 1) 0%,
      rgba(0, 125, 201, 0.05) 50%,
      rgba(255, 255, 255, 1) 100%
    );
  z-index: 0;
}

.company-article-wave__svg {
  position: absolute;
  inset: 0;
  width: 140%;
  height: 100%;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  z-index: 1;
}

@media (max-width: 768px) {
  .company-container {
    padding: calc(100vw * 70 / 375) calc(100vw * 0 / 375) calc(100vw * 60 / 375);
	padding-bottom:0;
  }

  .article-container {
    padding: calc(100vw * 50 / 375) calc(100vw * 0 / 375) calc(100vw * 0 / 375);
    margin: calc(100vw * 0 / 375) calc(100vw * 0 / 375) calc(100vw * 50 / 375) calc(100vw * 0 / 375);
  }

  .company-article-wave {
    height: calc(100vw * 150 / 375);
    margin-top: calc(100vw * -78 / 375);
    margin-bottom: calc(100vw * -78 / 375);
  }

  .company-article-wave__svg {
    width: 190%;
  }
}

@media (min-width: 769px){
  .service-carousel,
  .article-carousel{
    margin: calc(100vw * 29 / 1440) calc(100vw * -24 / 1440) 0;
    padding: 0 calc(100vw * 24 / 1440);
  }

  .service-cards-wrapper,
  .article-cards-wrapper{
    overflow: hidden;
padding: calc(100vw * 5 / 375);
        padding-bottom: calc(100vw * 10 / 375);
  }

  .service-cards,
  .article-cards{
    padding: calc(100vw * 5 / 1440);
  }

  .service-card,
  .article-card{
    margin: 0;
  }
}

@media (max-width: 768px){

  .service-carousel,
  .article-carousel{
    position: relative;
    margin: calc(100vw * 18 / 375) calc(100vw * -18 / 375) 0;
    padding: 0 calc(100vw * 36 / 375);
    gap: 0;
    align-items: stretch;
    overflow: visible;
  }

  .service-cards-wrapper,
  .article-cards-wrapper{
    width: 100%;
    overflow: hidden;
    min-width: 0;
  }
	.article-cards-wrapper{
	padding: calc(100vw * 10/ 375);
	}

  .service-cards,
  .article-cards{
    gap: calc(100vw * 12 / 375);
    padding: calc(100vw * 5 / 375);
    will-change: transform;
  }

  .service-card,
  .article-card{
    margin: 0;
    flex: 0 0 calc(100% - (calc(100vw * 18 / 375)));
    border-radius: calc(100vw * 12 / 375);
  }

  .carousel-nav{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    width: calc(100vw * 36 / 375);
    height: calc(100vw * 36 / 375);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.95);
  }

  .carousel-nav-prev{
    left: calc(100vw * 10 / 375);
  }

  .carousel-nav-next{
    right: calc(100vw * 10 / 375);
  }
}
@media (max-width: 768px){
  .service-actions .more-button,
  .article-actions .more-button{
    position: relative;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    line-height: 1;
  }

  .service-actions .more-button::after,
  .article-actions .more-button::after{
    content: "";
    position: absolute;
    bottom: calc(100vw * 20 / 375);
    right: calc(100vw * 18 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 9 / 375);
    border-radius: calc(100vw * 2 / 375);
    pointer-events: none;
  }
}

@media (max-width: 768px) {
  .carousel-nav-next::before,
  .carousel-nav-next::after{
    right: calc(100vw * 14 / 375);
    bottom: auto;
  }

  .carousel-nav-next::before{
    top: calc(100vw * 10.5 / 375);
  }

  .carousel-nav-next::after{
    top: calc(100vw * 15.5 / 375);
  }
}
@media (max-width: 768px) {
  .carousel-nav-prev::before,
  .carousel-nav-prev::after{
    left: calc(100vw * 14 / 375);
    bottom: auto;
  }

  .carousel-nav-prev::before{
    top: calc(100vw * 10.5 / 375);
  }

  .carousel-nav-prev::after{
    top: calc(100vw * 15.5 / 375);
  }
}
@media (max-width: 768px) {
  .contact-actions .more-button::before,
  .contact-actions .more-button::after{
    right: calc(100vw * 18 / 375);
    bottom: auto;
  }

  .contact-actions .more-button::before{
    top: calc(100vw * 20 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }

  .contact-actions .more-button::after{
    top: calc(100vw * 25 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }
}

@media (max-width: 768px) {
  .recruit-actions .more-button::before,
  .recruit-actions .more-button::after{
    right: calc(100vw * 18 / 375);
    bottom: auto;
  }

  .recruit-actions .more-button::before{
    top: calc(100vw * 21 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }

  .recruit-actions .more-button::after{
    top: calc(100vw * 26 / 375);
    width: calc(100vw * 2 / 375);
    height: calc(100vw * 8 / 375);
  }
}