@charset "UTF-8";
.breadcrumb {
  position: absolute;
  top: 78px;
  left: 0;
  z-index: var(--z-base);
  width: 100%;
  padding: 0 calc(12 * var(--px)) 10px;
  overflow-x: auto;
}
.breadcrumb-list {
  display: flex;
  gap: calc(8 * var(--px));
  width: -moz-fit-content;
  width: fit-content;
  color: var(--color-blue);
}
.breadcrumb-list-item {
  display: flex;
  flex-shrink: 0;
  gap: calc(8 * var(--px));
  align-items: center;
  font-size: calc(0.625 * var(--rem));
  font-weight: 500;
  line-height: 1.3;
  pointer-events: auto;
}
.breadcrumb-list-item:not(:first-child)::before {
  content: '／';
}
.breadcrumb-list-item:last-child {
  padding-right: calc(12 * var(--px));
}
.breadcrumb-list-link-text {
  display: inline-block;
}
.breadcrumb-list-arrow {
  width: calc(9 * var(--px));
  height: calc(12 * var(--px));
}

@media screen and (min-width: 960px) {
  .breadcrumb {
    top: calc(106 * var(--px));
    padding: 0 calc(34 * var(--px));
  }
  .breadcrumb-list {
    background-color: transparent;
  }
  .breadcrumb-list-item {
    font-size: calc(0.8125 * var(--rem));
  }
  .breadcrumb-list-link-text {
    padding-bottom: 1px;
  }
}
.lMain {
  padding-bottom: calc(56 * var(--px));
}

.fv-inner {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: calc(1.5 * var(--rem));
  gap: calc(1.5 * var(--rem));
  padding: calc(var(--header-height) + 58 * var(--px)) calc(20 * var(--px)) 0;
}
.fv-content {
  display: flex;
  flex-direction: column;
  gap: calc(1.5 * var(--rem));
}
.fv-headline-tag {
  display: flex;
  align-items: center;
  margin-left: calc(-11 * var(--px));
  color: var(--color-blue);
  opacity: var(--init-opacity);
}
.fv-headline-tag-en {
  font-family: var(--font-oswald);
  font-size: calc(0.9375 * var(--rem));
  font-weight: 400;
  line-height: 1.24;
  text-transform: uppercase;
  letter-spacing: 0.09em;
}
.fv-headline-tag-ja {
  font-size: calc(0.875 * var(--rem));
  font-weight: 500;
  line-height: 1;
}
.fv-headline-main {
  margin-top: calc(24 * var(--px));
}
.fv-headline-main-text {
  display: flex;
  flex-direction: column;
  font-family: var(--font-shippori-antique);
  font-size: calc(2.25 * var(--rem));
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: 0.04em;
  opacity: var(--init-opacity);
}
.fv-note {
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
  opacity: var(--init-opacity);
}
.fv-image {
  width: 100%;
  height: 87.5vw;
  overflow: hidden;
  border-radius: calc(4 * var(--px));
  opacity: var(--init-opacity);
}
.fv-image-inner {
  width: 100%;
  height: 100%;
}

.philosophy {
  margin-top: calc(2.75 * var(--rem));
}
.philosophy-inner {
  padding: 0 calc(20 * var(--px));
}
.philosophy-list {
  display: flex;
  flex-direction: column;
  gap: calc(3 * var(--rem));
  padding-bottom: calc(48 * var(--px));
  border-bottom: solid 1px #92b6cc;
}
.philosophy-list-item {
  padding-top: calc(2 * var(--rem));
  border-top: solid 1px #92b6cc;
}
.philosophy-list-item-category {
  width: -moz-fit-content;
  width: fit-content;
  padding: calc(0.125 * var(--rem)) calc(8 * var(--px)) calc(0.25 * var(--rem));
  font-size: calc(1 * var(--rem));
  font-weight: 600;
  line-height: 1.4;
  color: var(--color-white);
  letter-spacing: 0.08em;
  background-color: var(--color-blue);
}
.philosophy-list-item-body {
  display: flex;
  flex-direction: column;
  gap: calc(2 * var(--rem));
  margin-top: calc(0.5 * var(--rem));
}
.philosophy-list-item-copy {
  display: flex;
  flex-direction: column;
  font-family: var(--font-shippori-antique);
  font-size: calc(2.3125 * var(--rem));
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.04em;
}
.philosophy-list-item-copy-flex {
  display: flex;
  flex-wrap: wrap;
  gap: calc(4 * var(--px));
  align-items: center;
}
.philosophy-list-item-copy-strong {
  font-size: calc(2.9375 * var(--rem));
  color: var(--color-blue);
}
.philosophy-list-item-copy .letter-spacing-007 {
  letter-spacing: 0.07em;
}
.philosophy-list-item-copy .letter-spacing-mainus-002 {
  margin-right: calc(-4 * var(--px));
  letter-spacing: -0.02em;
}
.philosophy-list-item-about {
  padding: calc(1.5 * var(--rem)) calc(20 * var(--px)) calc(2 * var(--rem));
  background-color: var(--color-white);
  border-radius: calc(8 * var(--px));
}
.philosophy-list-item-about-text {
  display: inline;
  padding-bottom: calc(3 * var(--px));
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.06em;
  background-image: linear-gradient(90deg, currentcolor, currentcolor);
  background-repeat: no-repeat;
  background-position: 100% 100%;
  background-size: 100% 1px;
}

.other {
  margin-top: calc(3.5 * var(--rem));
}
.other-inner {
  padding: 0 calc(20 * var(--px));
}
.other-head {
  display: flex;
  flex-direction: column;
  gap: calc(0.5 * var(--rem));
  align-items: center;
}
.other-head-title {
  font-family: var(--font-shippori-antique);
  font-size: calc(2 * var(--rem));
  font-weight: 400;
  line-height: 1.4;
  text-align: center;
  letter-spacing: 0.04em;
}
.other-head-icon {
  width: calc(27 * var(--px));
  height: calc(27 * var(--px));
}
.other-body {
  margin-top: calc(48 * var(--px));
}
.other-page {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: calc(8 * var(--px));
  gap: calc(8 * var(--px));
}
.other-page-link {
  position: relative;
  padding: calc(1.5 * var(--rem)) calc(20 * var(--px));
  background: linear-gradient(58deg, #137bee -8.51%, #0f36c4 104.67%);
  border-radius: calc(8 * var(--px));
}
.other-page-link::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
  background-color: #0f36c4;
  border-radius: calc(8 * var(--px));
  opacity: 0;
}
.other-page-link-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.other-page-link-head-title {
  display: flex;
  flex-direction: column;
}
.other-page-link-head-title-text {
  width: -moz-fit-content;
  width: fit-content;
  padding: calc(0.625 * var(--rem)) calc(8 * var(--px));
  font-size: calc(1.25 * var(--rem));
  font-weight: 500;
  line-height: 1;
  color: var(--color-blue);
  letter-spacing: 0.08em;
  background-color: var(--color-white);
}
.other-page-link-head-title-text:not(:first-child) {
  margin-top: calc(-2 * var(--px));
}
.other-page-link-head-icon {
  position: relative;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(63 * var(--px));
  height: calc(23 * var(--px));
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 50vh;
}
.other-page-link-head-icon-arrow {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  transform: rotate(-45deg);
}
.other-page-link-head-icon-arrow img {
  width: calc(12 * var(--px));
  height: calc(12 * var(--px));
}
.other-page-link-body {
  position: relative;
  z-index: 1;
  margin-top: calc(1 * var(--rem));
}
.other-page-link-text {
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1.8;
  color: var(--color-white);
  letter-spacing: 0.06em;
}
.other-page-link:nth-child(2) .other-page-link-head {
  height: calc(5.3125 * var(--rem));
}

@media screen and (min-width: 960px) {
  .lMain {
    padding-bottom: calc(131 * var(--px));
  }
  .fv-inner {
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    grid-gap: 0;
    gap: 0;
    grid-row-gap: calc(3.25 * var(--rem));
    row-gap: calc(3.25 * var(--rem));
    padding: calc(var(--header-height) + 113 * var(--px)) 0 0;
  }
  .fv-content {
    flex-direction: row;
    grid-column: 3/39;
    gap: 0;
    align-items: flex-end;
    justify-content: space-between;
  }
  .fv-headline-tag-en {
    margin-right: calc(-5 * var(--px));
    font-size: calc(1 * var(--rem));
  }
  .fv-headline-tag-ja {
    font-size: calc(1.125 * var(--rem));
  }
  .fv-headline-main-text {
    font-size: calc(3.25 * var(--rem));
  }
  .fv-note {
    width: 37.63vw;
  }
  .fv-image {
    grid-column: 3/39;
    height: 27.23vw;
  }
  .philosophy {
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    margin-top: calc(125 * var(--px));
  }
  .philosophy-inner {
    grid-column: 4/38;
    padding: 0;
  }
  .philosophy-list {
    gap: calc(80 * var(--px));
    padding-bottom: calc(80 * var(--px));
  }
  .philosophy-list-item {
    padding: calc(64 * var(--px)) calc(16 * var(--px)) 0;
  }
  .philosophy-list-item-category {
    padding: calc(0.625 * var(--rem)) calc(10 * var(--px));
    font-size: calc(1.125 * var(--rem));
    line-height: 1.1;
    letter-spacing: 0.04em;
  }
  .philosophy-list-item-body {
    flex-direction: row;
    gap: calc(48 * var(--px));
    align-items: center;
    justify-content: space-between;
    margin-top: 0;
  }
  .philosophy-list-item-copy {
    position: relative;
    z-index: 1;
    font-size: calc(3.5625 * var(--rem));
  }
  .philosophy-list-item-copy.gap-12 {
    gap: calc(0.75 * var(--rem));
  }
  .philosophy-list-item-copy.gap-10 {
    gap: calc(0.625 * var(--rem));
  }
  .philosophy-list-item-copy.font-size-47 {
    font-size: calc(2.9375 * var(--rem));
  }
  .philosophy-list-item-copy.font-size-52 {
    font-size: calc(3.25 * var(--rem));
  }
  .philosophy-list-item-copy-flex {
    gap: 0;
  }
  .philosophy-list-item-copy-strong {
    padding: 0 calc(9 * var(--px));
    font-size: calc(4.375 * var(--rem));
  }
  .philosophy-list-item-copy-strong.font-size-58 {
    padding: 0 calc(7 * var(--px));
  }
  .philosophy-list-item-copy-strong.font-size-64 {
    padding: 0 calc(8 * var(--px));
  }
  .philosophy-list-item-copy .letter-spacing-007 {
    letter-spacing: 0.04em;
  }
  .philosophy-list-item-copy .letter-spacing-mainus-002 {
    margin-right: 0;
    letter-spacing: 0.04em;
  }
  .philosophy-list-item-copy .font-size-64 {
    font-size: calc(4 * var(--rem));
  }
  .philosophy-list-item-copy .font-size-52 {
    font-size: calc(3.25 * var(--rem));
  }
  .philosophy-list-item-copy .font-size-58 {
    font-size: calc(3.625 * var(--rem));
  }
  .philosophy-list-item-about {
    position: relative;
    width: 36.02vw;
    padding: calc(1.5 * var(--rem)) calc(35 * var(--px)) calc(2 * var(--rem));
  }
  .philosophy-list-item-about::before {
    position: absolute;
    top: calc(50% - 0.5px);
    left: -4.39vw;
    width: 4.47vw;
    height: 1px;
    content: '';
    background-color: var(--color-white);
  }
  .philosophy-list-item-about::after {
    position: absolute;
    top: calc(50% - 7 * var(--px) / 2);
    left: -4.76vw;
    width: calc(7 * var(--px));
    height: calc(7 * var(--px));
    content: '';
    background-color: var(--color-white);
  }
  .philosophy-list-item-about-text {
    line-height: 2.4;
  }
  .other {
    margin-top: calc(7.5 * var(--rem));
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
  }
  .other-inner {
    grid-column: 4/38;
    padding: 0;
  }
  .other-head {
    flex-direction: row;
    flex-wrap: wrap;
    gap: calc(8 * var(--px));
    justify-content: center;
  }
  .other-head-title {
    font-size: calc(2.25 * var(--rem));
  }
  .other-head-icon {
    width: calc(35 * var(--px));
    height: calc(35 * var(--px));
  }
  .other-body {
    margin-top: calc(80 * var(--px));
  }
  .other-page {
    grid-template-columns: 1fr 1fr;
  }
  .other-page-link {
    padding: calc(1.5 * var(--rem)) calc(40 * var(--px));
  }
  .other-page-link-head-title-text {
    font-size: calc(1.625 * var(--rem));
  }
  .other-page-link-head-title-text:not(:first-child) {
    margin-top: calc(-1 * var(--px));
  }
  .other-page-link-text {
    padding-right: 5.71vw;
    line-height: 1.7;
    letter-spacing: 0.04em;
  }
  .other-page-link:nth-child(2) .other-page-link-head {
    height: calc(5.75 * var(--rem));
  }
}
@media screen and (min-width: 1280px) {
  .philosophy-list-item-about::before {
    left: -8.86vw;
    width: 8.93vw;
  }
  .philosophy-list-item-about::after {
    left: -9.22vw;
    width: calc(7 * var(--px));
  }
}
@media (any-hover: hover) {
  .other-page-link::before {
    transition: opacity 0.4s var(--ease-out-quart);
  }
  .other-page-link:hover::before {
    opacity: 1;
  }
}
