@import url(./module/default.css);

:root {
  --gap: 2em;
}

h1,
h2 {
  width: 100%;
}

main h2 {
  font-size: 1.33em;
  margin: 2em 0 1.33em 0;
  padding: 0;
}

main h2 span {
  display: inline-block;
  font-size: 0.66em;
  margin-left: 1em;
}

@media screen and (max-width: 768px) {
  main h2 span {
    display: block;
    margin-top: 0;
    margin-left: 0;
  }
}

section {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap);
}

megei-staff {
  width: calc((100% - var(--gap) * 4) / 5);
  margin: 0;
  padding: 0;
}

@media screen and (max-width: 1280px) {
  megei-staff {
    width: calc((100% - var(--gap) * 3) / 4);
  }
}

@media screen and (max-width: 1024px) {
  megei-staff {
    width: calc((100% - var(--gap) * 2) / 3);
  }
}

@media screen and (max-width: 768px) {
  megei-staff {
    width: calc((100% - var(--gap) * 1) / 2);
  }
}

megei-staff>* {
  display: block;
  margin: 1em 0;
}

megei-staff-portrait {
  display: block;
  margin-top: 0;
}

megei-staff:not(:has(megei-staff-portrait))::before {
  display: block;
  content: "";
  width: 100%;
  aspect-ratio: 1/1;
  background-color: #eee;
}

megei-staff-name {
  font-weight: 800;
  line-height: 1.1em;
  margin: 0;
}

megei-staff-name:lang(en) {
  display: block;
  font-size: 1em;
  margin-top: 1em;
}

megei-staff-name:lang(ja) {
  display: block;
  font-size: 1.5em;
  line-height: 1.33em;
  margin: 0.33em 0 0.75em 0;
}

@media screen and (max-width: 512px) {
  megei-staff-name:lang(ja) {
    font-size: 1.1em;
  }
}

megei-staff-practices {
  font-size: 0.8em;
  font-weight: 500;
  line-height: 1.33em;
}

megei-staff-practices div {
  font-weight: 400;
  margin: 0 0 0.5em 0;
}

megei-staff-portrait>img {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
}

megei-practice[inline] a.loading-practice {
  background-color: #eee;
  color: #eee;
  word-break: break-all;
}

megei-practice[inline]>a {
  display: inline;
}