/*======================
 * 共通
 =======================*/
/*===== ページタイトル =====*/
.page-title {
  h1 {
    color: #60b43a;
  }
}
/*===== サイドメニュー =====*/
.side-menu a.current {
  background-color: #60b43a;
  background-image: radial-gradient(
      circle at 100% 150%,
      #60b43a 24%,
      #67c13e 24%,
      #67c13e 28%,
      #60b43a 28%,
      #60b43a 36%,
      #67c13e 36%,
      #67c13e 40%,
      transparent 40%,
      transparent
    ),
    radial-gradient(
      circle at 0 150%,
      #60b43a 24%,
      #67c13e 24%,
      #67c13e 28%,
      #60b43a 28%,
      #60b43a 36%,
      #67c13e 36%,
      #67c13e 40%,
      transparent 40%,
      transparent
    ),
    radial-gradient(
      circle at 50% 100%,
      #67c13e 10%,
      #60b43a 10%,
      #60b43a 23%,
      #67c13e 23%,
      #67c13e 30%,
      #60b43a 30%,
      #60b43a 43%,
      #67c13e 43%,
      #67c13e 50%,
      #60b43a 50%,
      #60b43a 63%,
      #67c13e 63%,
      #67c13e 71%,
      transparent 71%,
      transparent
    ),
    radial-gradient(
      circle at 100% 50%,
      #67c13e 5%,
      #60b43a 5%,
      #60b43a 15%,
      #67c13e 15%,
      #67c13e 20%,
      #60b43a 20%,
      #60b43a 29%,
      #67c13e 29%,
      #67c13e 34%,
      #60b43a 34%,
      #60b43a 44%,
      #67c13e 44%,
      #67c13e 49%,
      transparent 49%,
      transparent
    ),
    radial-gradient(
      circle at 0 50%,
      #67c13e 5%,
      #60b43a 5%,
      #60b43a 15%,
      #67c13e 15%,
      #67c13e 20%,
      #60b43a 20%,
      #60b43a 29%,
      #67c13e 29%,
      #67c13e 34%,
      #60b43a 34%,
      #60b43a 44%,
      #67c13e 44%,
      #67c13e 49%,
      transparent 49%,
      transparent
    );
  background-size: 100px 50px;
}
/*===== ページクセクションタイトル =====*/
.section-title::before {
  background-color: #60b43a;
}

/*===== リンクボタン =====*/
.two-col-wrap .text-area .link-button {
  position: absolute;
  bottom: 0;
  right: 0;
}
.two-col-wrap .text-area .link-button a {
  display: flex;
  border-radius: 10px;
  background-color: #5eb336;
  width: fit-content;
  padding: 17px 25px;
  box-shadow: 2px 1px 3px 2px rgba(0, 0, 0, 0.4);
  transition: transform 0.5s ease-out;
}
.two-col-wrap .text-area .link-button a:hover {
  animation: jump 1s ease-out infinite;
}
.two-col-wrap .text-area .link-button a span {
  color: #fff;
  margin-right: 10px;
  font-size: 20px;
}
.two-col-wrap .text-area .link-button a img {
  width: 22px;
}

@media screen and (max-width: 1024px) {
  .two-col-wrap .text-area .link-button {
    position: unset;
    margin-top: 20px;
  }
  .two-col-wrap .text-area .link-button a {
    padding: 12px 20px;
    margin: 0 auto;
  }
  .two-col-wrap .text-area .link-button a span {
    font-size: 16px;
  }
  .two-col-wrap .text-area .link-button a img {
    width: 17px;
  }
}

/*======================
 * スマホで聴く
 =======================*/
.sp-listen {
  /*=== 背景シルエット ===*/
  main {
    position: relative;

    .bg {
      position: absolute;
      z-index: 1;
    }
    .bg01 {
      width: 20%;
      top: 40%;
      right: 0;
    }

    @media screen and (max-width: 480px) {
      .bg01 {
        width: 200px;
      }
    }
  }
  /*=== セクション ===*/
  section {
    margin-bottom: 80px;
    @media screen and (max-width: 480px) {
      margin-bottom: 40px;
    }
  }
  /*===== スマホで聴くセクション  =====*/
  .listen-section {
    position: relative;

    .two-col-wrap .img-area {
      width: 340px;
      border: 2px solid #5eb336;
    }
    .two-col-wrap .text-area h4 {
      font-size: 24px;
      font-weight: bold;
      line-height: 32px;
      letter-spacing: 1.5px;
      margin-bottom: 20px;
    }

    @media screen and (max-width: 1024px) {
      .two-col-wrap .text-area h4 {
        font-size: 18px;
        line-height: 26px;
      }
    }
  }

  /*===== アプリでダウンロードセクション  =====*/
  .app-section {
    margin-bottom: 0;

    .process h4 {
      font-size: 20px;
      line-height: 28px;
      margin-bottom: 30px;
    }
    .process h4 span {
      border-radius: 50%;
      background-color: #5eb336;
      color: #fff;
      padding: 10px 13px;
      font-size: 20px;
      margin-right: 20px;
    }

    @media screen and (max-width: 480px) {
      .process h4 {
        font-size: 18px;
        line-height: 26px;
      }
      .process h4 span {
        padding: 5px 7px;
        font-size: 14px;
        margin-right: 10px;
      }
    }

    /*=== 手順１ ===*/
    .process01 {
      margin-bottom: 60px;
    }
    .process01 .app-qr {
      display: flex;
      flex-wrap: wrap;
      gap: 100px;
      margin-bottom: 20px;
    }
    .process01 .app-qr .img-area {
      border-radius: 10px;
      border: 2px solid #5eb336;
      overflow: hidden;
    }
    .process01 .app-qr img {
      width: 100%;
      display: block;
    }
    .process01 .app-qr .img-area.app-icon {
      width: 180px;
    }
    .process01 .app-qr .qr {
      display: flex;
      gap: 40px;
    }
    .process01 .app-qr .qr .img-area {
      width: 140px;
      margin: 0 auto;
      margin-bottom: 20px;
    }
    .process01 .app-qr .qr .ios,
    .process01 .app-qr .qr .android {
      text-align: center;
    }

    @media screen and (max-width: 1024px) {
      .process01 {
        margin-bottom: 40px;
      }
    }
    @media screen and (max-width: 480px) {
      .process01 .app-qr {
        gap: 20px;
      }
      .process01 .app-qr .img-area.app-icon {
        width: 100%;
      }
    }

    /*=== 手順２ ===*/
    .process02 .info .img-area {
      border-radius: 26px;
      width: 145px;
    }
    .process02 .info .text-area p {
      font-size: 20px;
      line-height: 28px;
      margin-bottom: 30px;
    }
    .process02 .info .text-area .info-list {
      border-radius: 10px;
      border: 2px solid #5eb336;
      padding: 20px;
    }
    .process02 .info .text-area ul {
      display: flex;
      flex-wrap: wrap;
      gap: 30px;
      column-gap: 50px;
      max-width: 570px;
      margin: 0 auto;
      padding-left: 15px;
    }
    .process02 .info .text-area ul li {
      position: relative;
    }
    .process02 .info .text-area ul li::before {
      content: '';
      position: absolute;
      left: -21px;
      top: 0.5px;
      width: 15px;
      height: 15px;
      background-color: #5eb336;
      border-radius: 50%;
    }

    @media screen and (max-width: 1024px) {
      .process02 .info .img-area {
        width: 145px !important;
      }
    }
    @media screen and (max-width: 480px) {
      .process02 .info .img-area {
        width: 100% !important;
        border-radius: 55px;
      }
      .process02 .info .text-area p {
        font-size: 18px;
        line-height: 26px;
        margin-bottom: 20px;
      }
      .process02 .info .text-area ul {
        gap: 20px;
        column-gap: 40px;
      }
    }
  }
}

/*======================
 * パソコンで聴く
 =======================*/
.pc-listen {
  /*=== 背景シルエット ===*/
  main {
    position: relative;
    .bg {
      position: absolute;
      z-index: 1;
    }
    .bg01 {
      width: 20%;
      top: 30%;
      right: 0;
    }

    @media screen and (max-width: 480px) {
      .bg01 {
        width: 200px;
      }
    }
  }
  /*=== セクション ===*/
  section {
    margin-bottom: 80px;
    @media screen and (max-width: 480px) {
      margin-bottom: 40px;
    }
  }
  /*===== スマホで聴くセクション  =====*/
  .listen-section {
    position: relative;

    .two-col-wrap .img-area {
      width: 340px;
      border: 2px solid #5eb336;
    }
    .two-col-wrap .text-area h4 {
      font-size: 24px;
      font-weight: bold;
      line-height: 32px;
      letter-spacing: 1.5px;
      margin-bottom: 20px;
    }

    @media screen and (max-width: 1024px) {
      .two-col-wrap .text-area h4 {
        font-size: 18px;
        line-height: 26px;
      }
    }
  }

  /*===== 動作確認環境セクション  =====*/
  .player-section {
    margin-bottom: 0;

    .info {
      border-radius: 10px;
      border: 2px solid #5eb336;
      padding: 20px 40px;
      margin-bottom: 30px;
    }
    .env-table table {
      width: 100%;
      border-collapse: separate;
      border-spacing: 0;
      border-radius: 10px;
      border: 2px solid #5eb337;
      overflow: hidden;
    }
    .env-table th,
    td {
      padding: 10px;
      vertical-align: middle;
      border-right: 1px solid #5eb337;
      border-bottom: 1px solid #5eb337;
      text-align: center;
    }
    .env-table th {
      width: 50%;
      padding: 15px;
      font-weight: bold;
      background: radial-gradient(rgb(161 207 140) 3px, transparent 4px),
        radial-gradient(rgb(161 207 140) 3px, transparent 4px), linear-gradient(#c8ecb6 4px, transparent 0),
        linear-gradient(
          45deg,
          transparent 44px,
          transparent 45px,
          #c6c5c5 45px,
          #c6c5c5 46px,
          transparent 47px,
          transparent 65px
        ),
        linear-gradient(
          -45deg,
          transparent 44px,
          transparent 45px,
          #c6c5c5 45px,
          #c6c5c5 46px,
          transparent 47px,
          transparent 65px
        ),
        #c8ecb6;
      background-size: 65px 65px, 65px 65px, 100% 6px, 65px 65px, 65px 65px;
      background-position: 32px 32px, 0 0, 0 0, 0 0, 0 0;
    }
    .env-table td {
      background-color: #fff;
      line-height: 20px;
    }
    .env-table .br-none {
      border-right: none;
    }
    .env-table .bb-none {
      border-bottom: none;
    }

    @media screen and (max-width: 480px) {
      .info {
        padding: 20px;
        margin-bottom: 20px;
      }
    }
  }
}

/*======================
 * ラジオで聴く
 =======================*/
.radio-listen {
  /*=== 背景シルエット ===*/
  main {
    position: relative;
    .bg {
      position: absolute;
      z-index: 1;
    }
    .bg01 {
      width: 20%;
      top: 30%;
      right: 0;
    }
    .bg02 {
      width: 13%;
      bottom: 10%;
      left: 0;
    }

    @media screen and (max-width: 480px) {
      .bg01 {
        width: 200px;
      }
      .bg02 {
        width: 15%;
      }
    }
  }

  /*===== ラジオで聴くセクション  =====*/
  .listen-section {
    /*=== 三角見出し ===*/
    h5 {
      position: relative;
      padding-left: 25px;
      font-size: 20px;
      font-weight: bold;
      margin-left: 10px;
      margin-bottom: 20px;
    }
    h5::before {
      content: '';
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 0;
      height: 0;
      border-top: 10px solid transparent;
      border-bottom: 10px solid transparent;
      border-left: 15px solid #5eb336;
    }

    /*=== 導入 ===*/
    .intro {
      margin-bottom: 50px;
    }
    .intro h4 {
      font-size: 24px;
      line-height: 30px;
      font-weight: bold;
      margin-bottom: 40px;
    }
    @media screen and (max-width: 480px) {
      .intro h4 {
        font-size: 18px;
        line-height: 26px;
        margin-bottom: 20px;
      }
    }

    /*=== 受信対策 ===*/
    .action {
      margin-bottom: 70px;

      /* 見出し吹き出し */
      .heading-block {
        margin-bottom: 40px;
      }
      .heading-block .label {
        display: inline-block;
        background-color: #5eb336;
        color: #fff;
        padding: 12px 20px;
        border-radius: 10px;
        font-weight: bold;
        position: relative;
        font-size: 16px;
      }
      .heading-block .label::after {
        content: '';
        position: absolute;
        bottom: -10px;
        left: 50%;
        transform: translateX(-50%);
        border-width: 10px 10px 0 10px;
        border-style: solid;
        border-color: #5eb336 transparent transparent transparent;
      }
      .heading-block .main-title {
        font-size: 24px;
        line-height: 32px;
        margin-top: 20px;
        font-weight: bold;
      }
      /* 内容 */
      .content {
        margin-bottom: 0;
      }
      .content .two-col-wrap {
        align-items: center;
        gap: 20px;
      }
      .content .two-col-wrap .img-area {
        border: 2px solid #000;
        width: 150px;
      }

      .content .sub-info {
        display: flex;
        flex-wrap: wrap;
        gap: 30px;
      }
      .content .sub-info h6 {
        position: relative;
        padding-left: 25px;
        font-size: 20px;
        font-weight: bold;
        margin-left: 10px;
        margin-bottom: 20px;
      }
      .content .sub-info h6::before {
        content: '★';
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        color: #5eb336;
        font-size: 16px;
      }
      .content .sub-info p {
        line-height: 20px;
        font-size: 14px;
      }
      .content .sub-info .info-item {
        width: 48%;
      }
      .content .green-window {
        border: 2px solid #5eb336;
        border-radius: 10px;
        padding: 40px 20px;
      }
      @media screen and (max-width: 1024px) {
        .content .sub-info .info-item {
          width: 100%;
        }
      }
      @media screen and (max-width: 480px) {
        margin-bottom: 40px;

        .heading-block {
          margin-bottom: 20px;
        }
        .heading-block .label {
          display: block;
          width: fit-content;
          margin: 0 auto;
        }
        .heading-block .main-title {
          font-size: 18px;
          line-height: 26px;
          text-align: center;
        }
        .content .sub-info {
          gap: 20px;
        }
        .content .sub-info h6 {
          padding-left: 25px;
          font-size: 18px;
          margin-bottom: 15px;
        }
        .content .sub-info p {
          line-height: 20px;
          font-size: 14px;
        }
        .content .green-window {
          padding: 20px;
        }
      }
    }

    /* 受信対策4 */
    .action04 .tv-antena-img {
      height: 125px;
      background-color: #fff;
      display: flex;
    }
    /* 受信対策5 */
    .action05 .content .two-col-wrap .img-area.antena-img {
      min-width: 270px;
    }
    @media screen and (max-width: 1024px) {
      .action04 .tv-antena-img {
        height: auto;
      }
    }

    /*=== 販売 ===*/
    .selling {
      margin-top: 70px;
      border: 2px solid #5eb336;
      border-radius: 10px;
      padding: 20px;
      text-align: center;
    }
    .selling h6 {
      font-size: 20px;
      margin-bottom: 15px;
    }
    .selling .detail {
      width: fit-content;
      text-align: left;
      margin: 0 auto;
    }
    @media screen and (max-width: 480px) {
      .selling h6 {
        font-size: 18px;
        line-height: 26px;
        margin-bottom: 15px;
      }
    }
  }
}
