@charset 'UTF-8';

/* ========== common ========== */
@media (width <= 768px) { /*768px以下,SPのみ*/
  .pconly {
    display: none !important;
  }
}

@media (769px <= width) { /*769px以上,PCのみ*/
  .sponly {
    display: none !important;
  }
}

html {
  font-size: 62.5%; /*1.0rem=10px*/
}

body {
  color: #646464;
  font-family: "BIZ UDGothic", "Noto Sans JP", Meiryo, sans-serif;
  font-size: 2.0rem;
  font-style: normal;
  font-weight: 400;
  line-height: 1.75;
  margin: 0;
  padding: 0;
  width: 100%;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 2.5rem;
  }
}


/* ========== hero ========== */
#lp2026_hero h1 {
  border: 0;
  clip-path: inset(50%);
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  height: 1px;
  width: 1px;
}


/* ========== main common ========== */
:where(.cont-main) {
  display: grid;
  grid-template-columns: 1fr min(335px, 100%) 1fr;
  padding-inline: 20px;
  &>* {
    grid-column: 2;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    grid-template-columns: 1fr min(1000px, 100%) 1fr;
  }
}

:where(.cont-sub) {
  display: grid;
  grid-template-columns: 1fr min(335px, 100%) 1fr;
  padding-inline: 20px;
  &>* {
    grid-column: 2;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    grid-template-columns: 1fr min(1000px, 100%) 1fr;
  }
}

:where(.lp2026_h2) {
  font-size: 3.0rem;
  font-weight: 700;
  margin: auto;
  position: relative;
  text-align: center;
  width: fit-content;
  &::before {
    background: url(../img/lp/2026/img-hdeco_L.webp) no-repeat center;
    left: -66px;
  }
  &::after {
    background: url(../img/lp/2026/img-hdeco_R.webp) no-repeat center;
    right: -66px;
  }
  &::before,
  &::after {
    background-size: contain;
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    height: 36px;
    width: 37px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 4.0rem;
    &::before,
    &::after {
      height: 45px;
      width: 44px;
    }
  }
}

:where(.lp2026_h2.color2) {
  &::before {
    background: url(../img/lp/2026/img-hdeco_L2.webp) no-repeat center;
    left: -66px;
  }
  &::after {
    background: url(../img/lp/2026/img-hdeco_R2.webp) no-repeat center;
    right: -66px;
  }
  &::before,
  &::after {
    background-size: contain;
  }
}

:where(.lp2026_h3) {
  font-size: 3.0rem;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 3.5rem;
  }
}

.lp2026_note {
  font-size: 1.6rem;
  font-weight: 700;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.8rem;
  }
}

.bk-beige {
  background-color: #ffefe6;
}

.bk-yellow {
  background-color: #fffca6;
}

:where(.lp2026_link a) {
  background: #ff6fa2;
  border-radius: 25px;
  display: block;
  font-size: 2.5rem;
  line-height: 1.4;
  padding: 20px 25px;
  text-align: center;
  text-decoration: none;

  &[href^='/'] {
    padding-bottom: 55px;
    position: relative;
    &::after {
      background: url(../img/lp/2026/ico-arrow_link.webp) no-repeat center;
      background-size: contain;
      content: '';
      margin: auto;
      position: absolute;
      bottom: 20px;
      left: 0;
      right: 0;
      height: 30px;
      width: 30px;
    }
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 4.0rem;
    padding: 40px 50px;

    &[href^='/'] {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-inline: auto;
      padding-bottom: 50px;
      position: inherit;
      max-width: 700px;
      &::after {
        margin: 0 0 0 40px;
        position: inherit;
        height: 37px;
        width: 37px;
      }
    }
  }
}

.lp2026_link a {
  color: #fff;
}

.lp2026_link + .lp2026_note {
  margin-top: 18px;
  text-align: center;
}

em {
  color: #ff6fa2;
  font-style: normal;
}

:where(ul) {
  list-style: none;
  margin: 0;
  padding: 0;
}


/* ========== main entry ========== */
.lp2026_about-entry .cont-main {
  padding-block: 75px 30px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-block: 90px 110px;
  }
}

.lp2026_about-entry .lp2026_h2 {
  margin: 0 auto 122px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin: 0 auto 45px;
  }
}

.lp2026_about-entry .lp2026_h2 .label {
  margin: 14px auto 0;
  position: absolute;
  left: 0;
  right: 0;
  height: 100%;
  height: 90px;
  max-width: 90px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin: 0;
    left: auto;
    right: -180px;
    top: 50%;
    transform: translateY(-50%);
    height: 97px;
    max-width: 97px;
  }
}

.lp2026_about-entry :where(p:not([class])) {
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}

.img_step {
  margin-top: 30px;
  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 45px;
  }
}

.lp2026_about-entry .lp2026_note {
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-top: 29px;
  text-align: center;
  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.6rem;
    letter-spacing: 0;
    margin-top: 50px;
  }
}

.lp2026_about-entry .cont-sub.bk-beige {  /*「みん芸」とは？*/
  padding-block: 45px 40px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-block: 75px 70px;
  }
}

.lp2026_about-entry .lp2026_h3 {
  text-align: center;

  .h3_marker {
    background: linear-gradient(transparent 50%, #fffa80 50%);
  }

  .h3_small {
    font-size: 1.9rem;
  }
}

.about-mingei_column {
  margin-top: 40px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    display: flex;
    margin-top: 80px;
  }
}

@media (769px <= width) { /*769px以上,PCのみ*/
  .about-mingei_column .column_child-l {
    flex-basis: 500px;
    flex-shrink: 0;
  }

  .about-mingei_column .column_child-r {
    flex-basis: auto;
    font-size: 2.5rem;
    padding-left: 43px;
  }
}

.img_mingei {
  margin: 0;
}

.column_child-r {
  margin-top: 30px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 0;
    &>p {
      margin-top: 0;
    }
}

  &>p {
    text-align: justify;
  }
}

.lp2026_about-entry .cont-sub.bk-yellow {  /*「みん芸」の楽しみ方*/
  padding-block: 28px 32px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-block: 48px 35px;
  }
}

.lp2026_about-entry .lp2026_h3 .h3_balloon {
  background: #80b9f4;
  border-radius: 17px;
  color: #fff;
  display: block;
  padding: 30px 15px 35px;
  position: relative;

  &::after {
    background: url(../img/lp/2026/img-balloonparts.webp) no-repeat center;
    background-size: contain;
    content: '';
    position: absolute;
    bottom: -25px;
    right: 50px;
    height: 35px;
    width: 42px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding: 15px;
    &::after {
      left: 40%;
      bottom: -40px;
      right: auto;
      height: 55px;
      width: 45px;
    }
  }
}

.about-enjoy_column {
  margin-top: -30px;
  position: static;
  z-index: 1;

  @media (769px <= width) { /*769px以上,PCのみ*/
    display: flex;
    margin-top: 5px;
  }
}

.img_pamphlet {
  margin: 0;
  height: auto;
  max-width: 287px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    flex-shrink: 0;
    padding-left: 50px;
    max-width: 482px;
  }
}

.about-enjoy_column .column_child-r {
  margin-top: 5px;

  p {
    margin-top: 0;
  }

  .lp2026_link {
    margin-top: 30px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 50px;
    padding-left: 20px;

    .lp2026_link {
      margin-top: 50px;

      a {
        font-size: 2.8rem;
        line-height: 1.3;
        padding-block: 15px 20px;
      }
    }
  }
}


/* ========== main term ========== */
.lp2026_about-term .cont-main {
  padding-block: 42px 50px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-block: 100px 120px;
  }
}

.lp2026_about-term .lp2026_h2 {
  &::before {
    left: -50px;
  }
  &::after {
    right: -50px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    &::before {
      left: -66px;
    }
    &::after {
      right: -66px;
    }
  }
}

.block_term {
  background-color: #fff;
  border: 1px solid #999;
  margin-top: 67px;
  padding: 75px 15px 23px;
  position: relative;
  &::before {
    background: rgba(0, 0, 0, 0.3);
    content: '';
    inset: 0;
    position: absolute;
    transform: translate(8px, 8px);
    z-index: -1;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 55px;
    padding: 45px 50px 70px;
  }
}

.label_term {
  margin: -45px auto 0;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 96px;
  width: 96px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: -20px;
    left: 45px;
    right: auto;
    height: 122px;
    width: 122px;
  }
}

.cont_term {
  margin: 0;
}

.disc_term {
  font-size: 2.5rem;
  font-weight: 700;
  margin-top: 0;

  em.large {
    font-size: 4.7rem;
    line-height: 1.1;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 3.5rem;
    padding-left: 160px;
    em.large {
      font-size: 6.5rem;
    }
  }
}

.column_term1 {
  margin-top: 10px;

  .img_post:nth-of-type(2)  {
    margin-top: 20px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-top: 50px;

    .img_post {
      flex-basis: 417px;
    }

    .img_post:nth-of-type(2)  {
      margin-top: 0;
    }
  }
}

.term2 .disc_term em {
  color: #79b832;
}

.lp2026_about-term .lp2026_link {
  margin-top: 42px;
}

@media (769px <= width) { /*769px以上,PCのみ*/
  .term2 .img_post {
    margin: 50px auto 0;
    max-width: 417px;
  }

  .lp2026_about-term .lp2026_link {
    margin-top: 90px;
  }
}


/* ========== main event ========== */
.lp2026_about-event .cont-main {
  padding-block: 42px 50px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-block: 100px 70px;
  }
}

.lp2026_about-event .lp2026_h2 {
  &::before {
    left: -50px;
  }
  &::after {
    right: -50px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    &::before {
      left: -66px;
    }
    &::after {
      right: -66px;
    }
  }
}

.list_about-event {
  border-top: 1px solid #000;
  margin-top: 45px;
  padding-top: 20px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 2.3rem;
    margin-top: 75px;
    padding-top: 50px;
  }

  li {
    font-weight: 700;
    text-align: justify;
  }
}

.list_event-genre {
  margin-top: 55px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 70px;
  }
}

.child_genre {
  font-weight: 700;
  padding-left: 165px;
  position: relative;
  &:not(:first-child) {
    flex-basis: 265px;
    margin-top: 55px;
  }

  &::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 140px;
    width: 140px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-left: 0;
    padding-top: 235px;
    &:not(:first-child) {
      margin-top: 0px;
    }
    &:nth-of-type(n+4) {
      margin-top: 80px;
    }

    &::before {
      left: 50%;
      top: 0;
      transform: translate(-50%, 0);
      height: 220px;
      width: 220px;
    }
  }

  &.music {
    color: #fe0000;
    &::before {
      background: url(../img/lp/2026/img-event_music.webp) no-repeat center;
      background-size: contain;
    }
  }
  &.drama {
    color: #ff7a00;
    &::before {
      background: url(../img/lp/2026/img-event_drama.webp) no-repeat center;
      background-size: contain;
    }
  }
  &.entertainment {
    color: #754c24;
    &::before {
      background: url(../img/lp/2026/img-event_entertainment.webp) no-repeat center;
      background-size: contain;
    }
  }
  &.dance {
    color: #39b54a;
    &::before {
      background: url(../img/lp/2026/img-event_dance.webp) no-repeat center;
      background-size: contain;
    }
  }
  &.art {
    color: #fe7bab;
    &::before {
      background: url(../img/lp/2026/img-event_art.webp) no-repeat center;
      background-size: contain;
    }
  }
  &.others {
    color: #0570bb;
    &::before {
      background: url(../img/lp/2026/img-event_others.webp) no-repeat center;
      background-size: contain;
    }
  }

  dt {
    font-size: 2.5rem;
    text-align: center;
  }

  dd {
    font-size: 1.5rem;
    line-height: 1.6;
    margin: 13px 0 0;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/]
    dt {
      font-size: 4.0rem;
    }

    dd {
      font-size: 2.0rem;
      margin-top: 25px;
      text-align: center;
      max-width: 265px;
    }
  }
}

.lp2026_about-event .lp2026_note {
  font-size: 1.5rem;
  margin-top: 50px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.8rem;
    margin-top: 90px;
    text-align: center;
  }
}

.event_more-info {
  background: #fff;
  border-radius: 30px;
  margin-top: 25px;
  padding: 30px 20px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 80px;
    padding: 50px;
  }
}

.child_more-info {
  font-weight: 700;
  &:not(:first-child) {
    border-top: 1px solid #c8c8c8;
    margin-top: 25px;
    padding-top: 25px;
  }

  dt {
    font-size: 2.5rem;
    text-align: center;
  }

  dd {
    font-size: 1.6rem;
    line-height: 1.6;
    margin: 15px 0 0;
    text-align: justify;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    display: flex;
    justify-content: space-between;

    &:not(:first-child) {
      margin-top: 45px;
      padding-top: 45px;
    }

    dt {
      font-size: 2.8rem;
      text-align: left;
    }

    dd {
      font-size: 1.7rem;
      flex: 0 1 673px;
      margin: 0;
    }
  }
}

.lp2026_about-event .child_more-info .lp2026_note {
  font-size: 1.6rem;
  margin-top: 0;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.7rem;
    text-align: left;
  }
}

.more-info_contact {
  display: block;
  font-size: 1.5rem;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.7rem;
  }
}

.event_more-info+.lp2026_link {
  margin-top: 38px;
  
  &+.lp2026_note {
    margin-top: 18px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 100px;
  }
}


/* ========== main faq ========== */
.lp2026_faq .cont-main {
  padding-block: 50px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-block: 115px;
  }
}

.wrap_faq {
  margin-top: 40px;
  &:first-of-type {
    margin-top: 60px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 95px;
    &:first-of-type {
      margin-top: 55px;
    }
  }
}

.cate_faq {
  font-size: 2.0rem;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 2.5rem;
  }
}

.item_faq {
  border-bottom: 1px dotted #000;
  font-family: "Noto Sans JP", Meiryo, sans-serif;
  font-weight: 700;
  padding-bottom: 15px;

  &:first-of-type {
    border-top: 1px solid #000;
    margin-top: 20px;
    padding-top: 20px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    padding-bottom: 20px;
    &:first-of-type {
      margin-top: 25px;
    }
  }
}

.item_faq-question {
  font-size: 1.4rem;
  line-height: 1.4;
  padding-inline: 45px 55px;
  position: relative;
  &::before {
    content: 'Q';
    color: #ff6fa2;
    font-size: 2.4rem;
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.8rem;
    padding-inline: 60px 70px;
    &::before {
      font-size: 3.0rem;
      left: 15px;
    }
  }
}

.icon_faq {
  position: absolute;
  right: 19px;
  top: 1px;
  height: 16px;
  width: 16px;
  &::before,
  &::after {
    background: #ff6fa2;
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    height: 2px;
    width: 16px;
  }
  &::after {
    transform: translate(-50%, -50%) rotate(90deg);
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    right: 23px;
    height: 20px;
    width: 20px;

    &::before,
    &::after {
      width: 20px;
    }
  }
}

.is-open .icon_faq {
  &::after {
    transform: translate(-50%, -50%) rotate(0deg);
  }
}

.item_faq-answer {
  display: none;
  margin-left: 0;
}

.inner-answer {
  font-size: 1.4rem;
  font-weight: 400;
  padding-left: 45px;
  position: relative;
  &::before {
    content: 'A';
    color: #79b832;
    font-size: 2.4rem;
    font-weight: 700;
    position: absolute;
    left: 10px;
    top: -7px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.8rem;
    padding-left: 60px;
    &::before {
      font-size: 3.0rem;
      left: 17px;
    }
  }
}

.lp2026_faq .lp2026_link {
  margin-top: 55px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    margin-top: 100px;
  }
}


/* ========== footer ========== */
.menu_footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-inline: 20px;

  li {
    font-size: 1.6rem;
    font-weight: 700;
    padding-inline: 20px;

    a {
      display: inline-flex;
      align-items: center;
      text-decoration: none;
      &::before {
        background: url(../img/lp/2026/ico-arrow_bottom.webp) no-repeat center;
        background-size: contain;
        content: '';
        display: inline-block;
        margin-right: 5px;
        height: 16px;
        width: 13px;
      }
    }
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    li {
      font-size: 2.0rem;
    }
  }
}

.sns_footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-evenly;
  margin-top: 30px;
  padding-inline: 20px;

  li:not([class]) {
    flex-basis: 100%;
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 10px;
    text-align: center;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    justify-content: center;
    margin-top: 45px;

    li {
      margin-inline: 20px;
    }

    li:not([class]) {
      flex-basis: auto;
      font-size: 1.6rem;
      margin-bottom: 0;
    }
  }
}

.link_sns {
  a {
    display: block;
    height: 44px;
    width: 44px;
  }

  @media (769px <= width) { /*769px以上,PCのみ*/
    a {
      height: 61px;
      width: 61px;
    }
  }

  &.ico_instagram a {
    background: url(../img/lp/2026/ico-sns_instagram.webp) no-repeat center;
    background-size: contain;
  }
  &.ico_facebook a {
    background: url(../img/lp/2026/ico-sns_facebook.webp) no-repeat center;
    background-size: contain;
  }
  &.ico_x a {
    background: url(../img/lp/2026/ico-sns_x.webp) no-repeat center;
    background-size: contain;
  }
  &.ico_youtube a {
    background: url(../img/lp/2026/ico-sns_youtube.webp) no-repeat center;
    background-size: contain;
  }
  &.ico_line a {
    background: url(../img/lp/2026/ico-sns_line.webp) no-repeat center;
    background-size: contain;
  }
}

.copylight_footer {
  background: #ff6fa2;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  margin-top: 33px;
  padding-block: 10px 18px;

  @media (769px <= width) { /*769px以上,PCのみ*/
    font-size: 1.3rem;
    margin-top: 35px;
    padding-block: 15px 20px;
  }
}