picture {
  display: block;
  width: 100%;
}

.br_pc{
  display: block;
}

.br_sp{
  display: none;
}

.header-logo {
  width: 13.2rem;
  min-width: 5.2rem;
  height: 5.2rem;
}

.g-nav-wrap {
  position: relative;
  z-index: 1;
  width: 69vw;
  height: 100%;
  margin: 0 auto;
}

.concept h2 .c-head__block{
  /* font-size: 2.2rem; */
  opacity: 1;
}

.concept .c-lead.--lv1 {
  font-size: 2.8rem;
  letter-spacing: 0.5em;
  line-height: 1.7105263158;
}

.concept .c-inner {
  padding-top: 6rem;
  padding-bottom: 0rem;
}

.menu {
  padding-bottom: 0rem;
  padding-top: 17rem;
}

@media screen and (max-width: 767px) {
  .menu {
    /* padding-bottom: 30rem; */
    padding-top: 17rem;
  }
}

.video_sec .menu-list.--layout-1 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2vw 2vw;
}

video{
  width: 100%;
}

.c-divider-shape.--type2::before {
  background-color: #2c54b3;
}

.c-divider-shape.--type2 .c-divider-shape__bottom::before {
  background-color: #2c54b3;
}

.news-list,.special-sauce-box{
  margin-bottom:7%;
}

.special-sauce-box{
  margin-top: 5%;
}

.menu .c-head-wrap{
    margin-bottom: 6%;
}

.menu.video_sec h3 .c-head__block{
    font-size: 2rem;
}
.media-item-data {
    margin-top: 0rem;
}

#form p,.contact .c-head-wrap{
    color: #fff;
}

#form p{
    line-height: 1.6;
    margin-bottom: 20px;
}

.footer-nav-list {
    gap: 4rem;
}

.footer-logo__link {
    width: 24rem;
}

@media screen and (max-width: 767px) {
  .br_pc{
    display: none;
  }

  .br_sp{
    display: block;
  }

  .video_sec .menu-list.--layout-1 {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 2vw 2vw;
  }

  .header-logo {
    width: 8.2rem;
    min-width: 5.2rem;
    height: 5.2rem;
  }

  .concept .c-lead.--lv1,.concept .c-txt-wrap {
    text-align: left;
  }

  .concept .c-lead.--lv1 {
    font-size: 2rem;
    letter-spacing: 0.5em;
    line-height: 1.7105263158;
  }
}



/* テーブルパーツ */
.regulation {
  overflow: hidden;
}

.regulation,
.regulation ul,
.regulation p {
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: left;
  font-size: 1.4rem;
  line-height: 1.786;
}

.regulation ul li:last-child {
  margin-bottom: 7rem;
}

.regulation table {
  margin-top: 0.75rem;
  text-align: center;
  font-weight: bold;
  background-color: #fff;
  table-layout: fixed;
  box-sizing: border-box;
  border-collapse: collapse;
  width: 100%;
}

.regulation table,
.regulation th,
.regulation td {
  border: 2px solid #000;
  text-align: center;
  vertical-align: middle;
}

.regulation th,
.regulation td {
  padding: 5px;
}

.regulation td ul {
  letter-spacing: 0em;
}

.regulation td ul li:last-child {
  margin-bottom: 0;
}


.regulation ul li::before {
  content: "◆";
}


@media screen and (max-width: 767px) {
  .regulation {
    overflow: scroll;
  }

  .regulation,
  .regulation ul,
  .regulation p {
    line-height: 2;
    font-size: 1.2rem;
    letter-spacing: 0.2em;
  }

  .regulation table {
    width: 120%;
  }

  .regulation ul li:last-child {
    margin-bottom: 5rem;
  }
}


/* 余白パーツ */
.mt100 {
  margin-top: 100px;
}

@media screen and (max-width: 767px) {
  .mt100 {
    margin-top: 20vw;
  }
}

.mt50 {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .mt100 {
    margin-top: 10vw;
  }
}


.special-sauce-box {
  padding-top: 0;
  padding-bottom: 0;
}

.special-sauce-box a {
  display: block;
  padding-top: 2rem;
  padding-bottom: 1.25rem;
  transition: 0.3s;
}

.special-sauce-box a:hover {
  opacity: 0.7;
}

.text-link {
  text-decoration: underline;
  transition: 0.3s;
}

.text-link:hover {
  opacity: 0.7;
}



/* 緊急対応 */
.c-divider-shape.--type2 .c-divider-shape__bottom::before,
.c-divider-shape.--type2 .c-divider-shape__bottom::after {
  background-color: transparent;
}

.panf-text {
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .panf-text {
    font-size: 4vw;
  }
}

.menu-media-item__fig video {
  aspect-ratio: 16 / 9;
  width: 100%;
  object-fit: cover;
  display: block;
}