body {
  background-color: #ffffff;
  -webkit-font-smoothing: antialiased;
}

.cmp-container {
  max-width: 68rem;
  margin: 0 auto;
  padding: 0 clamp(24px, 3.3333333333vw, 48px);
}
@media screen and (max-width: 768px) {
  .cmp-container {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}

.cmp-section-header {
  text-align: center;
  margin-bottom: clamp(48px, 5vw, 72px);
}
@media screen and (max-width: 768px) {
  .cmp-section-header {
    margin-bottom: clamp(28px, 9.3023255814vw, 71px);
  }
}
.cmp-section-header--light {
  color: #ffffff;
}

.cmp-label {
  display: inline-block;
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #6b7280;
  margin-bottom: clamp(12px, 1.1111111111vw, 16px);
}
.cmp-label--light {
  color: #9ca3af;
}
@media screen and (max-width: 768px) {
  .cmp-label {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(10px, 3.2558139535vw, 25px);
  }
}

.cmp-section-title {
  font-family: "Noto Serif JP", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(22px, 2.2222222222vw, 32px);
  font-weight: 400;
  line-height: 1.5;
  color: #333333;
}
.cmp-section-title--light {
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cmp-section-title {
    font-size: clamp(18px, 5.5813953488vw, 43px);
  }
}

.cmp-hero {
  position: relative;
  background-color: #000000;
  color: #ffffff;
  display: flex;
  align-items: center;
  min-height: 60vh;
  padding-top: clamp(100px, 9.7222222222vw, 140px);
  padding-bottom: clamp(80px, 8.3333333333vw, 120px);
}
@media screen and (max-width: 768px) {
  .cmp-hero {
    padding-top: clamp(96px, 27.9069767442vw, 214px);
    padding-bottom: clamp(64px, 18.6046511628vw, 143px);
    min-height: 50vh;
    min-height: 50svh;
  }
}
.cmp-hero::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.2), transparent);
}
.cmp-hero__inner {
  max-width: 68rem;
  margin: 0 auto;
  padding: 0 clamp(24px, 3.3333333333vw, 48px);
  width: 100%;
}
@media screen and (max-width: 768px) {
  .cmp-hero__inner {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}
.cmp-hero__eyebrow {
  display: block;
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: clamp(20px, 1.9444444444vw, 28px);
}
@media screen and (max-width: 768px) {
  .cmp-hero__eyebrow {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.cmp-hero__title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(32px, 3.8888888889vw, 56px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.02em;
  margin-bottom: clamp(24px, 2.2222222222vw, 32px);
}
@media screen and (max-width: 768px) {
  .cmp-hero__title {
    font-size: clamp(20px, 6.0465116279vw, 46px);
    line-height: 1.55;
    margin-bottom: clamp(18px, 5.5813953488vw, 43px);
  }
  .cmp-hero__title br {
    display: none;
  }
}
.cmp-hero__lead {
  font-size: clamp(13px, 1.1111111111vw, 16px);
  color: #9ca3af;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .cmp-hero__lead {
    font-size: clamp(11px, 3.023255814vw, 23px);
    line-height: 1.8;
  }
}

.cmp-profile {
  background-color: #ffffff;
}
.cmp-profile__inner {
  display: flex;
  flex-direction: column;
  gap: clamp(40px, 4.4444444444vw, 64px);
}
@media screen and (min-width: 769px) {
  .cmp-profile__inner {
    flex-direction: row;
    gap: clamp(40px, 5.5555555556vw, 80px);
    align-items: flex-start;
  }
}
@media screen and (max-width: 768px) {
  .cmp-profile__inner {
    gap: clamp(28px, 9.3023255814vw, 71px);
  }
}
.cmp-profile__lead-col {
  flex: 1;
}
@media screen and (min-width: 769px) {
  .cmp-profile__lead-col {
    flex: 0 0 38%;
  }
}
.cmp-profile__lead-text {
  font-size: clamp(13px, 1.0416666667vw, 15px);
  line-height: 2;
  color: #374151;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cmp-profile__lead-text {
    font-size: clamp(12px, 3.2558139535vw, 25px);
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.cmp-profile__founding {
  display: flex;
  align-items: baseline;
  gap: clamp(6px, 0.5555555556vw, 8px);
  margin-top: clamp(32px, 3.3333333333vw, 48px);
  padding-top: clamp(24px, 2.2222222222vw, 32px);
  border-top: 1px solid #e5e7eb;
}
@media screen and (max-width: 768px) {
  .cmp-profile__founding {
    margin-top: clamp(28px, 8.3720930233vw, 64px);
    padding-top: clamp(20px, 6.511627907vw, 50px);
  }
}
.cmp-profile__founding-year {
  font-size: clamp(40px, 4.4444444444vw, 64px);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #333333;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .cmp-profile__founding-year {
    font-size: clamp(36px, 11.1627906977vw, 86px);
  }
}
.cmp-profile__founding-label {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #6b7280;
}
@media screen and (max-width: 768px) {
  .cmp-profile__founding-label {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
}
.cmp-profile__table-col {
  flex: 1;
}

.cmp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(12px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 768px) {
  .cmp-table {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
}
.cmp-table__head, .cmp-table__data {
  padding: clamp(14px, 1.25vw, 18px) clamp(16px, 1.3888888889vw, 20px);
  border-bottom: 1px solid #e5e7eb;
  text-align: left;
  vertical-align: top;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .cmp-table__head, .cmp-table__data {
    padding: clamp(12px, 3.7209302326vw, 29px) clamp(12px, 3.7209302326vw, 29px);
  }
}
.cmp-table__head {
  white-space: nowrap;
  font-weight: 600;
  color: #1f2937;
  width: 30%;
  background-color: #f9fafb;
}
.cmp-table__data {
  color: #374151;
}

.cmp-mvv {
  background-color: #111111;
  color: #ffffff;
}
.cmp-mvv__grid {
  display: grid;
  gap: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (min-width: 769px) {
  .cmp-mvv__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .cmp-mvv__grid {
    gap: clamp(16px, 4.6511627907vw, 36px);
  }
}
.cmp-mvv__card {
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: clamp(28px, 2.7777777778vw, 40px);
  position: relative;
}
.cmp-mvv__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: clamp(32px, 3.3333333333vw, 48px);
  height: 2px;
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cmp-mvv__card {
    padding: clamp(24px, 7.4418604651vw, 57px);
  }
}
.cmp-mvv__card-en {
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cmp-mvv__card-en {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(14px, 4.1860465116vw, 32px);
  }
}
.cmp-mvv__card-title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(16px, 1.5277777778vw, 22px);
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cmp-mvv__card-title {
    font-size: clamp(15px, 4.1860465116vw, 32px);
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
    line-height: 1.65;
  }
  .cmp-mvv__card-title br {
    display: none;
  }
}
.cmp-mvv__card-text {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  color: #9ca3af;
  line-height: 1.9;
}
@media screen and (max-width: 768px) {
  .cmp-mvv__card-text {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
}

.cmp-history {
  background-color: #f9fafb;
}
.cmp-history__timeline {
  max-width: 44rem;
  margin: 0 auto;
  position: relative;
}
.cmp-history__timeline::before {
  content: "";
  position: absolute;
  left: clamp(74px, 7.2222222222vw, 104px);
  top: 0;
  bottom: 0;
  width: 1px;
  background-color: #e5e7eb;
}
@media screen and (max-width: 768px) {
  .cmp-history__timeline::before {
    left: clamp(58px, 18.6046511628vw, 143px);
  }
}
.cmp-history__item {
  display: flex;
  gap: clamp(20px, 2.2222222222vw, 32px);
  padding-bottom: clamp(32px, 3.3333333333vw, 48px);
  position: relative;
}
.cmp-history__item::after {
  content: "";
  position: absolute;
  left: clamp(69px, 6.875vw, 99px);
  top: clamp(6px, 0.5555555556vw, 8px);
  width: clamp(8px, 0.6944444444vw, 10px);
  height: clamp(8px, 0.6944444444vw, 10px);
  border-radius: 50%;
  background-color: #333333;
  border: 2px solid #ffffff;
  box-shadow: 0 0 0 1px #9ca3af;
}
@media screen and (max-width: 768px) {
  .cmp-history__item::after {
    left: clamp(53px, 17.4418604651vw, 134px);
    top: clamp(5px, 1.6279069767vw, 13px);
    width: clamp(8px, 2.3255813953vw, 18px);
    height: clamp(8px, 2.3255813953vw, 18px);
  }
}
@media screen and (max-width: 768px) {
  .cmp-history__item {
    gap: clamp(16px, 5.5813953488vw, 43px);
    padding-bottom: clamp(28px, 8.3720930233vw, 64px);
  }
}
.cmp-history__item:last-child {
  padding-bottom: 0;
}
.cmp-history__year {
  flex-shrink: 0;
  width: clamp(64px, 6.1111111111vw, 88px);
  font-size: clamp(20px, 1.9444444444vw, 28px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #333333;
  line-height: 1.2;
  padding-top: clamp(2px, 0.2777777778vw, 4px);
}
@media screen and (max-width: 768px) {
  .cmp-history__year {
    width: clamp(52px, 15.8139534884vw, 121px);
    font-size: clamp(16px, 5.1162790698vw, 39px);
  }
}
.cmp-history__content {
  padding-top: clamp(2px, 0.2777777778vw, 4px);
}
.cmp-history__month {
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-weight: 700;
  color: #6b7280;
  letter-spacing: 0.1em;
  margin-bottom: clamp(6px, 0.5555555556vw, 8px);
}
@media screen and (max-width: 768px) {
  .cmp-history__month {
    font-size: clamp(10px, 2.7906976744vw, 21px);
  }
}
.cmp-history__text {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #374151;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .cmp-history__text {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
}

.cmp-access {
  background-color: #ffffff;
}
.cmp-access__inner {
  display: flex;
  flex-direction: column;
  gap: clamp(32px, 3.3333333333vw, 48px);
}
@media screen and (min-width: 769px) {
  .cmp-access__inner {
    flex-direction: row;
    gap: clamp(40px, 4.4444444444vw, 64px);
    align-items: flex-start;
  }
}
@media screen and (max-width: 768px) {
  .cmp-access__inner {
    gap: clamp(28px, 8.3720930233vw, 64px);
  }
}
.cmp-access__map {
  flex: 1;
}
@media screen and (min-width: 769px) {
  .cmp-access__map {
    flex: 0 0 55%;
  }
}
.cmp-access__map-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background-color: #f3f4f6;
  border: 1px solid #e5e7eb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 0.8333333333vw, 12px);
  color: #9ca3af;
}
.cmp-access__map-placeholder svg {
  width: clamp(32px, 3.3333333333vw, 48px);
  height: clamp(32px, 3.3333333333vw, 48px);
}
@media screen and (max-width: 768px) {
  .cmp-access__map-placeholder svg {
    width: clamp(28px, 8.3720930233vw, 64px);
    height: clamp(28px, 8.3720930233vw, 64px);
  }
}
.cmp-access__map-placeholder span {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
@media screen and (max-width: 768px) {
  .cmp-access__map-placeholder span {
    font-size: clamp(10px, 2.7906976744vw, 21px);
  }
}
.cmp-access__info {
  flex: 1;
}
.cmp-access__name {
  font-size: clamp(15px, 1.3888888889vw, 20px);
  font-weight: 700;
  color: #333333;
  margin-bottom: clamp(20px, 1.9444444444vw, 28px);
  padding-bottom: clamp(16px, 1.3888888889vw, 20px);
  border-bottom: 2px solid #333333;
}
@media screen and (max-width: 768px) {
  .cmp-access__name {
    font-size: clamp(14px, 4.1860465116vw, 32px);
    margin-bottom: clamp(16px, 5.1162790698vw, 39px);
    padding-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
}
.cmp-access__dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(12px, 1.1111111111vw, 16px) clamp(16px, 1.6666666667vw, 24px);
  font-size: clamp(12px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 768px) {
  .cmp-access__dl {
    font-size: clamp(11px, 3.023255814vw, 23px);
    gap: clamp(10px, 3.2558139535vw, 25px) clamp(12px, 3.7209302326vw, 29px);
  }
}
.cmp-access__dl dt {
  font-weight: 600;
  color: #1f2937;
  white-space: nowrap;
  padding-top: clamp(2px, 0.2083333333vw, 3px);
}
.cmp-access__dl dd {
  color: #4b5563;
  line-height: 1.8;
}

.cmp-cta {
  background-color: #000000;
  text-align: center;
}
.cmp-cta__text {
  font-size: clamp(14px, 1.25vw, 18px);
  margin-bottom: clamp(28px, 2.7777777778vw, 40px);
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cmp-cta__text {
    font-size: clamp(13px, 3.7209302326vw, 29px);
    margin-bottom: clamp(24px, 7.4418604651vw, 57px);
  }
}
.cmp-cta__btn {
  display: inline-block;
  background-color: #ffffff;
  color: #000000;
  font-weight: 700;
  font-size: clamp(12px, 1.0416666667vw, 15px);
  letter-spacing: 0.1em;
  padding: clamp(14px, 1.25vw, 18px) clamp(40px, 3.8888888889vw, 56px);
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.cmp-cta__btn:hover {
  background-color: #e5e7eb;
}
@media screen and (max-width: 768px) {
  .cmp-cta__btn {
    display: block;
    width: 100%;
    text-align: center;
    font-size: clamp(12px, 3.2558139535vw, 25px);
    letter-spacing: 0.08em;
    padding: clamp(14px, 4.1860465116vw, 32px) clamp(20px, 6.511627907vw, 50px);
  }
}/*# sourceMappingURL=company-page.css.map */