@charset "UTF-8";
.p-top {
  display: block;
  position: relative;
}

.p-headline {
  width: 100%;
  height: 6rem;
  display: block;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 960px) {
  .p-headline {
    height: 5.3rem;
  }
}
.p-headline__container {
  width: calc(100% - 8rem);
  display: block;
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 961px) {
  .p-headline__container {
    display: grid;
    grid-template-columns: 1fr 12rem;
    gap: 0.5rem;
  }
}
@media screen and (max-width: 960px) {
  .p-headline__container {
    width: 100%;
  }
}
.p-headline__inner {
  display: block;
  position: relative;
}
.p-headline__list {
  display: block;
  position: relative;
}
.p-headline__list-item {
  display: block;
  position: relative;
}
.p-headline__list-item:nth-child(n+2) {
  display: none;
}
.p-headline__footer {
  display: block;
  position: relative;
}
.p-headline__more {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  color: var(--color-gold);
}
.p-headline__more-text {
  display: block;
  position: relative;
  padding-top: 0.15em;
  padding-right: 1.8rem;
  font-size: 2rem;
  font-family: "Modern Antiqua", "Noto Serif JP", "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ 明朝", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
}
@supports ((-webkit-text-decoration-color: transparent) or (text-decoration-color: transparent)) {
  @media (hover: hover) and (pointer: fine) {
    .p-headline__more-text {
      -webkit-text-decoration: 1px underline;
      text-decoration: 1px underline;
      -webkit-text-decoration-color: transparent;
      text-decoration-color: transparent;
      transition: -webkit-text-decoration-color 0.3s var(--ease_out);
      transition: text-decoration-color 0.3s var(--ease_out);
      transition: text-decoration-color 0.3s var(--ease_out), -webkit-text-decoration-color 0.3s var(--ease_out);
    }
    .p-headline__more:hover .p-headline__more-text {
      -webkit-text-decoration-color: currentColor;
      text-decoration-color: currentColor;
    }
  }
}
@supports not ((-webkit-text-decoration-color: transparent) or (text-decoration-color: transparent)) {
  @media (hover: hover) and (pointer: fine) {
    .p-headline__more:hover .p-headline__more-text {
      text-decoration: underline;
    }
  }
}
.p-headline__more-text::after {
  content: "";
  width: 1rem;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../img/ar_g.png") no-repeat center/contain;
}

.p-headline_article {
  display: block;
  position: relative;
  padding: 0 1.8rem;
}
@media screen and (max-width: 960px) {
  .p-headline_article {
    padding: 0 1.4rem;
  }
}
.p-headline_article__content {
  min-height: 6rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-headline_article__content {
    min-height: 5.3rem;
  }
}
.p-headline_article__date {
  min-width: 10rem;
  display: block;
  position: relative;
  top: 0.16em;
  margin-right: 1rem;
  font-size: 1.4rem;
  letter-spacing: 0.15rem;
  font-family: "Modern Antiqua", "Noto Serif JP", "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ 明朝", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  color: var(--color-gold);
}
@media screen and (max-width: 960px) {
  .p-headline_article__date {
    min-width: 5rem;
    top: 0.1em;
    font-size: 1rem;
    letter-spacing: 0.05rem;
  }
}
.p-headline_article__title {
  flex: 1 1 0;
  line-height: 1.5;
  display: block;
  position: relative;
  font-size: 1.6rem;
  letter-spacing: 0.1rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media screen and (max-width: 960px) {
  .p-headline_article__title {
    font-size: 1.1rem;
  }
}
@supports ((-webkit-text-decoration-color: transparent) or (text-decoration-color: transparent)) {
  @media (hover: hover) and (pointer: fine) {
    .p-headline_article__title {
      -webkit-text-decoration: 1px underline;
      text-decoration: 1px underline;
      -webkit-text-decoration-color: transparent;
      text-decoration-color: transparent;
      transition: -webkit-text-decoration-color 0.3s var(--ease_out);
      transition: text-decoration-color 0.3s var(--ease_out);
      transition: text-decoration-color 0.3s var(--ease_out), -webkit-text-decoration-color 0.3s var(--ease_out);
    }
    .p-headline_article:hover .p-headline_article__title {
      -webkit-text-decoration-color: currentColor;
      text-decoration-color: currentColor;
    }
  }
}
@supports not ((-webkit-text-decoration-color: transparent) or (text-decoration-color: transparent)) {
  @media (hover: hover) and (pointer: fine) {
    .p-headline_article:hover .p-headline_article__title {
      text-decoration: underline;
    }
  }
}

.p-hero {
  --heroH: calc(var(--svh) - 6rem);
  display: block;
  position: relative;
  overflow: hidden;
}
.p-hero__container {
  width: 100%;
  display: block;
  position: relative;
}
.p-hero__inner {
  width: 100%;
  display: block;
  position: relative;
  overflow: hidden;
  z-index: 0;
}
.p-hero__nav {
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  gap: 0.5rem;
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 5;
}
.p-hero__nav-item {
  width: 5rem;
  display: block;
  position: relative;
}
.p-hero__btn {
  display: block;
  position: relative;
}
.is-current .p-hero__btn {
  pointer-events: none;
}
.p-hero__btn-img {
  display: block;
  position: relative;
  z-index: 0;
}
.p-hero__btn-img::before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  border: 1px solid var(--color-gold);
}
@media (hover: hover) and (pointer: fine) {
  .p-hero__btn-img::before {
    transition: border-color 0.3s var(--ease_out);
  }
  .p-hero__btn:hover .p-hero__btn-img::before {
    border-color: var(--color-white);
  }
}
.is-current .p-hero__btn-img::before {
  opacity: 1;
  border-color: var(--color-gold);
}
.p-hero__btn-img::after {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: var(--color-black);
  opacity: 0.3;
}
.is-current .p-hero__btn-img::after {
  opacity: 0;
}
@media (hover: hover) and (pointer: fine) {
  .p-hero__btn-img::after {
    transition: opacity 0.3s var(--ease_out);
  }
  .p-hero__btn:hover .p-hero__btn-img::after {
    opacity: 0.1;
  }
}
.p-hero__kv {
  display: block;
  position: relative;
  z-index: 0;
}
.p-hero__kv-item {
  width: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 0;
  transition: 0s opacity 1s;
}
.p-hero__kv-item.is-current {
  position: relative;
  opacity: 1;
  transition: 0s opacity;
  z-index: 1;
}
.p-hero__content {
  width: 100%;
  display: block;
  position: relative;
  opacity: 0;
}
@media screen and (min-width: 961px) {
  .p-hero__content {
    max-width: min(var(--svh) * 2.2, 1400px);
    position: absolute;
    bottom: 8.2%;
    left: 50%;
    transform: translate(-50%, 0);
  }
}
@media screen and (max-width: 960px) {
  .p-hero__content {
    margin-top: -6.2rem;
  }
}
@media screen and (min-width: 961px) {
  .--kv2 .p-hero__content {
    bottom: 4.2%;
  }
}
@media screen and (max-width: 960px) {
  .--kv2 .p-hero__content {
    margin-top: -6.2rem;
  }
}
.is-current .p-hero__content {
  opacity: 1;
}
.is-load .p-hero__content {
  transition: opacity 0.8s var(--ease_out);
}
.is-load .is-current .p-hero__content {
  transition: opacity 0.8s var(--ease_inout) 0.5s;
}
.p-hero__logo {
  width: 27.5%;
  display: block;
  position: relative;
  margin: 0 auto 1%;
}
@media screen and (max-width: 960px) {
  .p-hero__logo {
    width: 28.5rem;
    margin-bottom: 2.3rem;
  }
}
@media screen and (max-width: 960px) {
  .--kv2 .p-hero__logo {
    width: 28.5rem;
    margin-bottom: 2.3rem;
  }
}
.p-hero__onair {
  display: block;
  position: relative;
  margin: 0 auto;
}
.--kv1 .p-hero__onair {
  width: 64%;
}
@media screen and (max-width: 960px) {
  .--kv1 .p-hero__onair {
    width: 34.2rem;
  }
}
.--kv2 .p-hero__onair {
  width: 66%;
}
@media screen and (max-width: 960px) {
  .--kv2 .p-hero__onair {
    width: 34.2rem;
  }
}

.p-hero_kv {
  width: 100%;
  height: var(--heroH);
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  background: var(--color-black);
  position: relative;
  -webkit-mask: url("../img/mask_area1.png") no-repeat 50% 100%/110% 1500%;
  mask: url("../img/mask_area1.png") no-repeat 50% 100%/110% 1500%;
}
@media screen and (max-width: 960px) {
  .p-hero_kv {
    height: 46.4rem;
    -webkit-mask-size: 150% 1500%;
    mask-size: 150% 1500%;
  }
}
.is-current .p-hero_kv {
  animation: mask 1s steps(14, end);
}
.p-hero_kv__bg {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(1.15);
  filter: blur(1rem);
  opacity: 0.5;
}
.p-hero_kv__bg img {
  width: 100% !important;
  height: 100% !important;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
  object-fit: cover;
}
.--kv2 .p-hero_kv__bg img {
  -o-object-position: 60% 10%;
  object-position: 60% 10%;
}
.p-hero_kv__container {
  width: 100%;
  height: var(--heroH);
  display: block;
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-hero_kv__container {
    height: 46.4rem;
  }
}
.--kv2 .p-hero_kv__container {
  max-height: calc((100vw - var(--sideW)) * 0.8);
}
@media screen and (max-width: 960px) {
  .--kv2 .p-hero_kv__container {
    max-height: 80vw;
  }
}
.p-hero_kv__visual {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
}
.p-hero_kv__visual-img {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(1.15);
  transition: transform 0s linear 1s;
}
.is-load .is-current .p-hero_kv__visual-img {
  transform: scale(1);
  transition: transform 30s linear;
}
.p-hero_kv__visual-img img {
  width: 100% !important;
  height: 100% !important;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
  object-fit: cover;
}
.--kv2 .p-hero_kv__visual-img img {
  -o-object-position: 60% 10%;
  object-position: 60% 10%;
}