.blocks.gray {
  background-color: #292929;
  padding: 10rem 2rem;
  color: #fff;
}
@media (720px <= width) {
  .blocks.gray {
    padding: 10rem 6rem;
  }
}
@media (1024px <= width) {
  .blocks.gray {
    padding: 16rem max(50% - 85rem, 11rem) 20rem;
  }
}

#index {
  margin: 0;
}

.index.column3sp {
  grid-template-columns: auto;
}
.index.column3sp a:nth-child(even) {
  border-left: none;
  border-top: 1px solid #ccc;
}
@media (720px <= width) {
  .index.column3sp {
    grid-template-columns: repeat(3, 1fr);
  }
  .index.column3sp a:nth-child(even) {
    border-top: none;
  }
}
.index a {
  color: #fff;
}
@media (width < 720px) {
  .index a:nth-child(odd) {
    border-right: none;
  }
}

.category__copy {
  margin-top: 2rem;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 150%;
  text-align: center;
}
@media (1024px <= width) {
  .category__copy {
    margin-top: 5rem;
    font-size: 6.8rem;
    line-height: 140%;
  }
}
.category__text {
  margin-top: 2rem;
  font-size: 2rem;
  font-weight: 700;
  line-height: 160%;
}
@media (720px <= width) {
  .category__text {
    margin-top: 4rem;
    font-size: 3.2rem;
    line-height: 160%;
    text-align: center;
  }
}
.category__about {
  margin-top: 6rem;
  padding: 4rem 2rem;
  position: relative;
}
@media (720px <= width) {
  .category__about {
    padding: 4rem 6rem;
  }
}
@media (1024px <= width) {
  .category__about {
    margin-top: 10rem;
    padding: 10rem;
    max-width: 140rem;
    margin-left: auto;
    margin-right: auto;
  }
}
.category__about::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  border: 2px solid var(--color);
}
.category__about__lbl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 160%;
  text-align: center;
}
@media (720px <= width) {
  .category__about__lbl {
    font-size: 3.6rem;
    line-height: 1.3333;
  }
}
.category__about__text {
  margin-top: 2rem;
  font-size: 1.6rem;
  line-height: 175%;
}
@media (720px <= width) {
  .category__about__text {
    margin-top: 5rem;
    font-size: 2rem;
    line-height: 1.8;
  }
}

.lesmillsvirtual {
  padding: 10rem 0 0;
  background: url(../images/virtualstudio/lesmillsvirtual_bg_sp.webp) center top/contain no-repeat;
}
@media (720px <= width) {
  .lesmillsvirtual {
    background-image: url(../images/virtualstudio/lesmillsvirtual_bg.webp);
    background-image: -webkit-image-set(url(../images/virtualstudio/lesmillsvirtual_bg.webp) 1x, url(../images/virtualstudio/lesmillsvirtual_bg@2x.webp) 2x);
    background-image: image-set(url(../images/virtualstudio/lesmillsvirtual_bg.webp) 1x, url(../images/virtualstudio/lesmillsvirtual_bg@2x.webp) 2x);
  }
}
.lesmillsvirtual__title {
  width: 29.4rem;
  margin-left: auto;
  margin-right: auto;
}
@media (720px <= width) {
  .lesmillsvirtual__title {
    width: 58.8rem;
  }
}
.lesmillsvirtual__copy {
  color: #fff200;
}
.lesmillsvirtual__about::before {
  --color: #fffa96;
  filter: drop-shadow(0px 0px 8px #fff200);
}
.lesmillsvirtual__about__lbl {
  color: #fff200;
}
.program {
  padding: 10rem 2rem;
  background: var(--colorbg) var(--bgimg) center top/contain no-repeat;
  color: #fff;
}
@media (720px <= width) {
  .program {
    padding: 20rem 6rem;
  }
}
@media (1024px <= width) {
  .program {
    padding: 20rem max(50% - 85rem, 11rem);
  }
}
.program__title {
  color: var(--colormain);
  padding-bottom: 4rem;
}
.program__lists {
  position: relative;
}
.program__lists::before {
  content: "";
  width: 100%;
  height: 2px;
  background: var(--colorborder);
  position: absolute;
  bottom: 0;
  left: 0;
  box-shadow: 0px 0px 8px var(--colormain);
}
.program .item {
  position: relative;
  padding-top: 4rem;
  padding-bottom: 4rem;
}
@media (720px <= width) {
  .program .item {
    padding: 8rem 0 10rem;
  }
}
@media (1024px <= width) {
  .program .item {
    padding: 8rem 0 10rem;
    display: grid;
    grid-template-columns: 38.2352941176% 55.8823529412%;
    gap: 5.8823529412%;
  }
}
.program .item::before {
  content: "";
  width: 100%;
  height: 2px;
  background: var(--colorborder);
  position: absolute;
  top: 0;
  left: 0;
  box-shadow: 0px 0px 8px var(--colormain);
}
.program .item__tag {
  color: #fff;
  background: var(--colormain);
  position: absolute;
  left: 0;
  top: 0;
  width: 7rem;
  height: 7rem;
  font-size: 1.4rem;
  font-weight: 700;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  transform-origin: top center;
}
@media (720px <= width) {
  .program .item__tag {
    width: 12rem;
    height: 12rem;
  }
}
.program .item__tag span {
  display: inline-block;
  transform: rotate(315deg);
  position: absolute;
  top: 1rem;
  left: 1rem;
}
@media (720px <= width) {
  .program .item__tag span {
    font-size: 2rem;
    top: 2rem;
    left: 2rem;
  }
}
.program .item__img {
  text-align: center;
}
.program .item__name {
  padding: 4rem 0 3rem;
  font-weight: 700;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
@media (1024px <= width) {
  .program .item__name {
    padding: 0 0 5rem;
  }
}
.program .item__name .sub {
  font-size: 1.8rem;
  line-height: 1;
}
@media (720px <= width) {
  .program .item__name .sub {
    font-size: 2.4rem;
  }
}
.program .item__name .main {
  font-size: 2.8rem;
  line-height: 1;
  margin-top: 1.5rem;
}
@media (720px <= width) {
  .program .item__name .main {
    font-size: 4rem;
    margin-top: 2.5rem;
  }
}
.program .item__text {
  padding-top: 3rem;
  font-size: 1.6rem;
  line-height: 175%;
}
@media (720px <= width) {
  .program .item__text {
    padding-top: 5rem;
    font-size: 2rem;
    line-height: 1.8;
  }
}
.program .item__effect {
  background: var(--colorgra);
  padding: 1.5rem 1rem;
  text-align: center;
  margin-top: 3rem;
}
@media (720px <= width) {
  .program .item__effect {
    margin-top: 5rem;
    padding: 2rem;
    display: grid;
    grid-template-columns: 14.2857142857% 83.5164835165%;
    gap: 2.1978021978%;
    align-items: center;
  }
}
.program .item__effect .lbl {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}
@media (720px <= width) {
  .program .item__effect .lbl {
    font-size: 2rem;
  }
}
.program .item__effect .content {
  margin-top: 1.3rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 0.3rem;
}
@media (720px <= width) {
  .program .item__effect .content {
    margin-top: 0;
    gap: 0 0.5rem;
  }
}
.program .item__effect .content span {
  background-color: rgba(255, 255, 255, 0.2);
  display: inline-grid;
  align-items: center;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 140%;
}
@media (720px <= width) {
  .program .item__effect .content span {
    font-size: 2rem;
    padding: 1rem;
  }
}

.hf24box {
  padding: 10rem 2rem;
  background: #f5f5f5 url(../images/virtualstudio/hf24box_bg_sp.webp) center top/contain no-repeat;
}
@media (720px <= width) {
  .hf24box {
    padding: 20rem 6rem;
    background-image: url(../images/virtualstudio/hf24box_bg.webp);
    background-image: -webkit-image-set(url(../images/virtualstudio/hf24box_bg.webp) 1x, url(../images/virtualstudio/hf24box_bg@2x.webp) 2x);
    background-image: image-set(url(../images/virtualstudio/hf24box_bg.webp) 1x, url(../images/virtualstudio/hf24box_bg@2x.webp) 2x);
  }
}
.hf24box__title {
  width: 32.8rem;
  margin-left: auto;
  margin-right: auto;
}
@media (720px <= width) {
  .hf24box__title {
    width: 65.7rem;
  }
}
.hf24box__copy {
  color: #36993e;
}
.hf24box__about::before {
  --color: #36993e;
}
.hf24box__about__lbl {
  color: #36993e;
}
.hf24box__program {
  margin-top: 10rem;
  color: #333;
  display: grid;
  gap: 4rem;
}
@media (1024px <= width) {
  .hf24box__program {
    display: grid;
    grid-template-columns: 44.2708333333% auto;
    gap: 0 6rem;
    justify-content: end;
  }
}
@media (720px <= width) {
  .hf24box__program__box {
    width: -moz-fit-content;
    width: fit-content;
  }
}
.hf24box__program__title {
  color: #36993e;
}
.hf24box__program__lead {
  margin-top: 4rem;
}
@media (720px <= width) {
  .hf24box__program__lead {
    margin-top: 8rem;
  }
}
.hf24box__program__lead .sub {
  font-size: 2rem;
  font-weight: 700;
  line-height: 160%;
}
@media (720px <= width) {
  .hf24box__program__lead .sub {
    font-size: 2.8rem;
    line-height: 4.4rem;
  }
}
.hf24box__program__lead .main {
  margin-top: 1.5rem;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 150%;
}
@media (720px <= width) {
  .hf24box__program__lead .main {
    margin-top: 2rem;
    font-size: 4.6rem;
    line-height: 6.8rem;
  }
}
.hf24box__program__text {
  margin-top: 3rem;
  font-size: 1.6rem;
  line-height: 175%;
}
.hf24box__program__img img {
  width: 100%;
}