
.site-main {
  padding-top: 3rem;
}

.section-title .title {
  font-size: clamp(48px, 8.889vw, 128px);
}

.block-title .title {
  display: inline-block;
  color: #87a2b2;
  font-size: clamp(28px, 4.444vw,64px);
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.6;
  padding: 1.625rem 0 0 0;
}

.block-title .subtitle {
  font-size: clamp(20px,2.5vw,36px);
  font-weight: 600;
  line-height: 1.6;
}

@media screen and (min-width: 992px) {
  .site-main {
    padding-top: 6.5rem;
  }

  .section-title {
    transform: scale(0.9);
  }

  .block-title .title {
    padding: 5.625rem 0 0 0;
  }
}

.philosophy-purpose {
  background-image: url(../assets/images/philosophy-purpose-bg.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.purpose-infinity {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  aspect-ratio: 16/6;
  background-image: url(../assets/images/infinity-half.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin: 2rem 0;
}

.purpose-infinity .chips-group {
  display: grid;
  width: 100%;
  max-width: 75rem;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  gap: 0.5rem;
  padding-bottom: 3rem;
}
.purpose-infinity .chips-group .chip {
  position: relative;
  display: inline-block;
  color: var(--bs-white);
  background-color: var(--color-dark-blue);
  border-radius: 2.5rem;
  font-weight: 500;
  line-height: 1.4;
  flex: none;
  box-shadow: 0px 4px 20px rgba(27, 73, 101, 0.25);
  white-space: nowrap;
}
.purpose-infinity .chips-group .chip.lt {
  align-self: flex-start;
  justify-self: flex-start;
}
.purpose-infinity .chips-group .chip.lb {
  align-self: flex-end;
  justify-self: flex-start;
}
.purpose-infinity .chips-group .chip.rt {
  align-self: flex-start;
  justify-self: flex-end;
}
.purpose-infinity .chips-group .chip.rb {
  align-self: flex-end;
  justify-self: flex-end;
}
.purpose-infinity .chips-group .chip.cm {
  align-self: center;
  justify-self: center;
}
.purpose-infinity .chips-group .chip.cb {
  align-self: flex-end;
  justify-self: center;
}

.purpose-infinity .chips-group .chip.xlarge {
  font-size: clamp(14px,1.944vw,28px);
  padding: 0.75rem 1.5rem;
}
.purpose-infinity .chips-group .chip.large {
  font-size: clamp(14px,1.389vw,20px);
  padding: 0.75rem 1.5rem;
}
.purpose-infinity .chips-group .chip.mid {
  font-size: clamp(14px,1.111vw,16px);
  padding: 0.75rem 1.5rem;
}
.purpose-infinity .chips-group .chip.small {
  font-size: 14px;
  padding: 0.75rem 1.5rem;
}
.purpose-infinity .chips-group .chip.xsmall {
  font-size: 12px;
  padding: 0.625rem 1rem;
}

.purpose-message .message-title {
  color: var(--color-light-blue);
  font-size: clamp(24px,2.222vw,32px);
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
  padding: 0 1rem;
  margin: 1.875rem 0;
}

.purpose-message .message-text {
  font-size: clamp(16px,1.25vw,18px);
  font-weight: 400;
  line-height: 2;
  text-align: center;  
}

@media screen and (min-width: 992px) {
  .purpose-infinity .chips-group {
    gap: 1rem;
    padding-bottom: 6rem;
  }

  .purpose-infinity .chips-group .chip.xlarge {
    padding: 1.25rem 2.5rem;
  }
  .purpose-infinity .chips-group .chip.large {
    padding: 1.125rem 2rem;
  }
  .purpose-infinity .chips-group .chip.mid {
    padding: 0.75rem 1.5rem;
  }
  .purpose-infinity .chips-group .chip.small {
    padding: 0.75rem 1.5rem;
  }
  .purpose-infinity .chips-group .chip.xsmall {
    padding: 0.625rem 1rem;
  }
}

.philosophy-mission {
  background-image: url(../assets/images/philosophy-mission-bg.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.philosophy-mission .section-body {
  padding: 2rem 0.5rem 0 0.5rem;
}

.philosophy-mission .post-title {
  font-size: clamp(24px,2.222vw,32px);
  font-weight: 600;
  line-height: 2.4;
}

.philosophy-mission .post-text {
  font-size: clamp(16px,1.25vw,18px);
  font-weight: 400;
  line-height: 1.81;
  padding-top: 2rem;
  text-align: justify;
}

@media screen and (min-width: 992px) {
  .philosophy-mission .section-body {
    max-width: 50%;
    padding: 3rem 1rem;
  }

  .philosophy-mission .post-text {
    padding-top: 3rem;
  }
}

.philosophy-vision .section-body {
  position: relative;
  margin-top: 1rem;
}

.philosophy-vision .section-image {
  object-fit: contain;
  width: 90%;
}

.philosophy-vision .section-content {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  border-radius: 2rem;
  display: flex;
  flex-flow: column;
  align-items: end;
  color: var(--bs-white);
  background: linear-gradient(90deg, rgba(66, 179, 211, 0) 10%, #81d6e7 63%);
  padding: 2rem 2rem;
}

.philosophy-vision .block-title {
  display: inline-block;
}

.philosophy-vision .section-content .block-title {
  display: none;
  text-align: right;
}

.philosophy-vision .section-content .block-title .title {
  color: var(--bs-white);
}

.philosophy-vision .section-content .post-title {
  font-size: clamp(20px,1.944vw,28px);
  font-weight: 500;
  line-height: 1.4;
  text-align: right;
  padding: 3rem 0 4rem 0;
}

.philosophy-vision .section-content .post-text {
  font-size: clamp(14px,1.25vw,18px);
  font-weight: 400;
  line-height: 2;
  text-align: right;
}

@media screen and (min-width: 992px) {
  .philosophy-vision .section-body {
    margin-top: 5rem;
  }

  .philosophy-vision .block-title {
    display: none;
  }

  .philosophy-vision .section-content {
    right: 3rem;
    max-width: 60%;
    border-radius: 5.125rem;
    padding: 3rem 5rem 5rem 5rem;
  }

  .philosophy-vision .section-content .block-title {
    display: inline-block;
    text-align: right;
  }

  .philosophy-vision .section-image {
    max-width: 60%;
  }

  .philosophy-vision .section-body {
    margin-top: 3rem;
  }
}

.philosophy-value {
  width: 100vw;
  overflow-x: hidden;
  background-image: url(../assets/images/philosophy-value-bg.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 100%;
}

.philosophy-value .section-body {
  display: flex;
  flex-flow: column;
  gap: 3rem;
  padding: 2rem 0 4rem 0;
}

.philosophy-value .block {
  position: relative;
  overflow-x: visible;
  display: block;
  min-height: 260px;
}

.philosophy-value .block .block-bg {
  position: absolute;
  display: block;
  height: 260px;
  width: 100vw;  
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: auto 260px;
  z-index: 0;
}

.philosophy-value .block.right .block-bg {
  right: 0;
  background-image: url(../assets/images/philosophy-value-r.svg);
  background-position: 100% 0;
}

.philosophy-value .block.left .block-bg {
  left: 0;
  background-image: url(../assets/images/philosophy-value-l.svg);
  background-position: 0 0;
}

.philosophy-value .block .block-body {
  position: relative;
  display: flex;
  flex-flow: row;
  justify-content: center;
  gap: 3rem;
  z-index: 10;
  padding: 7rem 1.5rem 0 1.5rem;
}

.philosophy-value .block.left .block-body {
  flex-flow: row-reverse;
}

.philosophy-value .block .block-icon {
  position: absolute;
  top: 3rem;
  display: block;
  width: 80px;
  height: auto;
  transform: translateY(-50%);
}

.philosophy-value .block.right .block-icon {
  left: 0;
}

.philosophy-value .block.left .block-icon {
  right: 0;
}

.philosophy-value .block .block-content {
  position: relative;
  display: inline-block;
  background: rgba(255, 255, 255, 0.63);
  border-radius: 8px;
  width: 85%;
  max-width: 52rem;
  box-shadow: 0px 2px 30px rgba(192, 192, 192, 0.2);
  padding: 0.25rem 1.25rem 1.25rem 1.25rem;
}

.philosophy-value .block .block-content .title {
  position: absolute;
  top: -2rem;
  left: 0.25rem;
  font-size: clamp(48px,8.333vw,120px);
  font-weight: 800;
}

.philosophy-value .block .block-content .subtitle {
  font-size: clamp(16px,1.944vw,28px);
  font-weight: 700;
  margin: 1.75rem 0;
}

.philosophy-value .block .block-content .text {
  font-size: clamp(16px,1.25vw,18px);
  font-weight: 400;
  text-align: justify;
}

@media screen and (min-width: 992px) {
  .philosophy-value .section-body {
    gap: 5rem;
  }
  
  .philosophy-value .block .block-body {
    
    padding: 6rem 2rem 0 2rem;
  }

  .philosophy-value .block .block-icon {
    top: 8.126rem;
    width: 150px;
  }

  .philosophy-value .block .block-content {
    padding: 0.75rem 4rem 2rem 8rem;
  }

  .philosophy-value .block .block-content .title {
    top: -4rem;
    left: 1rem;
  }
}