.concept-page {
  background: #ffffff;
  color: #24211f;
}

.concept-hero {
  padding: calc(var(--header-height) + 34px) 0 72px;
}

.concept-hero__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: start;
}

.concept-hero__head h1,
.concept-block__copy h2 {
  margin: 0;
  font-family: "Baskervville", "Times New Roman", serif;
  font-weight: 400;
  line-height: 0.96;
}

.concept-hero__head h1 {
  font-size: clamp(4.6rem, 10vw, 7.2rem);
  letter-spacing: -0.03em;
}

.concept-hero__links {
  display: grid;
  justify-items: end;
  gap: 28px;
  padding-top: 18px;
}

.concept-hero__links a {
  color: #24211f;
  font-family: "Baskervville", "Times New Roman", serif;
  font-size: 0.98rem;
}

.concept-hero__visual-wrap {
  margin-top: 52px;
  border-top: 1px solid rgba(36, 33, 31, 0.4);
}

.concept-hero__visual {
  width: min(72vw, 960px);
  margin: 0;
}

.concept-hero__visual img {
  display: block;
  width: 100%;
  height: auto;
}

.concept-section {
  padding: 84px 0 0;
}

.concept-block {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(240px, 360px);
  gap: 54px;
  align-items: start;
}

.concept-block--left {
  grid-template-columns: minmax(240px, 360px) minmax(0, 1.1fr);
}

.concept-block__copy {
  max-width: 520px;
}

.concept-label {
  margin: 0 0 26px;
  color: #5d775a;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}

.concept-block__copy h2 {
  font-size: clamp(2.1rem, 4.2vw, 3rem);
  letter-spacing: -0.02em;
}

.concept-block__copy p {
  margin: 20px 0 0;
  color: rgba(36, 33, 31, 0.78);
  font-size: 0.95rem;
  line-height: 2;
}

.concept-block__media {
  margin: 0;
  justify-self: end;
  width: min(100%, 360px);
  background: rgba(255, 255, 255, 0.38);
}

.concept-block__media img {
  display: block;
  width: 100%;
  height: auto;
}

.concept-block--left .concept-block__media {
  justify-self: start;
}

.concept-block--left .concept-block__copy {
  justify-self: end;
}

.concept-block__media--soft {
  width: min(100%, 330px);
}

.concept-block__media--pale {
  width: min(100%, 340px);
  opacity: 0.94;
}

.concept-section--history {
  padding-bottom: 92px;
}

.concept-matrix {
  padding: 48px 0 0;
  margin-bottom: 44px;
  background: #284137;
}

.concept-matrix__head {
  display: grid;
  gap: 12px;
  padding-bottom: 24px;
}

.concept-matrix__eyebrow,
.concept-matrix__intro {
  margin: 0;
  color: #f1eee8;
}

.concept-matrix__eyebrow {
  font-family: "Baskervville", "Times New Roman", serif;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
}

.concept-matrix__intro {
  color: rgba(241, 238, 232, 0.74);
  font-size: 0.86rem;
  line-height: 1.8;
}

.concept-matrix__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: 1px solid rgba(241, 238, 232, 0.14);
}

.concept-matrix__card {
  display: grid;
  align-content: start;
  gap: 14px;
  min-height: 260px;
  padding: 32px 22px 28px;
  border-left: 1px solid rgba(241, 238, 232, 0.14);
}

.concept-matrix__card:first-child {
  border-left: 0;
}

.concept-matrix__card span,
.concept-matrix__card h3,
.concept-matrix__card p,
.concept-matrix__card a {
  color: #f1eee8;
}

.concept-matrix__card span,
.concept-matrix__card h3 {
  font-family: "Baskervville", "Times New Roman", serif;
  font-weight: 400;
}

.concept-matrix__card span {
  font-size: 0.82rem;
  opacity: 0.7;
}

.concept-matrix__card h3 {
  margin: 0;
  font-size: 1.12rem;
  letter-spacing: 0.04em;
}

.concept-matrix__card p {
  margin: 0;
  color: rgba(241, 238, 232, 0.72);
  font-size: 0.84rem;
  line-height: 1.85;
}

.concept-matrix__card a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 14px;
  align-self: end;
  justify-self: start;
  border: 1px solid rgba(241, 238, 232, 0.34);
  border-radius: 999px;
  color: rgba(241, 238, 232, 0.88);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
}

.concept-page .reveal,
.concept-page .reveal.delay-1,
.concept-page .reveal.delay-2,
.concept-page .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: none;
}

@media (max-width: 980px) {
  .concept-block,
  .concept-block--left,
  .concept-hero__head {
    grid-template-columns: 1fr;
  }

  .concept-hero__links {
    justify-items: start;
    gap: 12px;
    padding-top: 0;
  }

  .concept-hero__visual {
    width: 100%;
  }

  .concept-block__media,
  .concept-block--left .concept-block__media {
    justify-self: start;
  }

  .concept-matrix__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .concept-matrix__card:nth-child(3) {
    border-left: 0;
  }
}

@media (max-width: 640px) {
  .concept-hero {
    padding-top: calc(var(--header-height) + 24px);
  }

  .concept-section {
    padding-top: 64px;
  }

  .concept-section--history {
    padding-bottom: 72px;
  }

  .concept-matrix__grid {
    grid-template-columns: 1fr;
  }

  .concept-matrix__card {
    min-height: auto;
    border-left: 0;
    border-top: 1px solid rgba(241, 238, 232, 0.14);
  }

  .concept-matrix__card:first-child {
    border-top: 0;
  }
}
