.p-download {
  background: #EEF5FF;
  padding: 12rem 0;
}

.p-list {
  margin: 6rem 0;
  gap: 3rem;
}

.p-pickup .m-card {
  width: 57rem;
  padding: 4rem;
}
.p-pickup .m-card-image {
  width: 49rem;
  height: 30.2rem;
}
.p-pickup .p-list {
  margin: 3rem 0 6rem;
  gap: 6rem;
}

.p-pickup-ttl {
  font-size: 4.8rem;
  line-height: 1.25;
  letter-spacing: 0.08em;
  font-weight: 400;
  position: relative;
}
.p-pickup-ttl::before {
  position: absolute;
  content: "";
  top: 50%;
  right: 0;
  width: calc(100% - 15rem);
  height: 1px;
  background: #005ED2;
}

.p-tab-inner {
  max-width: 96rem;
  margin: 0 auto;
}

.p-tab-nav {
  display: flex;
  border-radius: 0.5rem;
  max-width: 96rem;
  margin: 0 auto;
}

.p-tab-button {
  flex: 1;
}
.p-tab-button a {
  display: block;
  text-align: center;
  padding: 2rem;
  cursor: pointer;
  background: #DFDFDF;
  color: #7B7B7B;
  position: relative;
  font-size: 2.4rem;
  line-height: 2;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.p-tab-button a:hover {
  background: #ccc;
}

.p-tab-button:first-child a {
  border-radius: 0.5rem 0 0 0.5rem;
}

.p-tab-button:last-child a {
  border-radius: 0 0.5rem 0.5rem 0;
}

.p-tab-button.is-active a {
  background: #005ED2;
  color: #fff;
}

.p-tab-button.is-active a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: -1.7rem;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 1.7rem 1.7rem 0 1.7rem;
  border-color: #005ED2 transparent transparent;
}

.p-tab-content-wrap {
  margin-top: 3rem;
}

@media screen and (max-width: 767px) {
  .p-download {
    background: #EEF5FF;
    padding: 21.3333333333vw 0 16vw;
  }
  .p-list {
    margin: 8vw 0 16vw;
    flex-direction: column;
    gap: 5.3333333333vw;
  }
  .p-pickup .p-list {
    margin: 8vw 0 16vw;
    gap: 5.3333333333vw;
  }
  .p-card {
    width: 100%;
    margin: 0;
  }
  .p-pickup-ttl {
    font-size: 10.1333333333vw;
    line-height: 1.1842105263;
    letter-spacing: 0.06em;
    font-weight: 400;
  }
  .p-pickup-ttl::before {
    width: calc(100% - 32vw);
  }
  .p-tab-inner {
    max-width: 100%;
    margin: 0 auto;
  }
  .p-tab-nav {
    max-width: 100%;
  }
  .p-tab-button a {
    padding: 5.3333333333vw;
    font-size: 4.8vw;
    line-height: 1.3333333333;
    letter-spacing: 0.06em;
    font-weight: 700;
  }
  .p-tab-button:first-child a {
    border-radius: 1.3333333333vw 0 0 1.3333333333vw;
  }
  .p-tab-button:last-child a {
    border-radius: 0 1.3333333333vw 1.3333333333vw 0;
  }
  .p-tab-button.is-active a::after {
    bottom: -2.4vw;
    border-width: 2.6666666667vw 2.6666666667vw 0 2.6666666667vw;
  }
  .p-tab-content-wrap {
    margin-top: 8vw;
  }
  .p-download .m-card {
    width: 100%;
    padding: 4vw 4vw 4vw;
    border: solid 0.8vw transparent;
    margin: 0;
  }
  .p-download .m-card-image {
    width: 100%;
    height: auto;
  }
}
.p-download-detail {
  padding: 13rem 0 7rem;
  width: 120rem;
  margin: 0 auto;
}

.p-download-detail-ttl {
  font-size: 4.6rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #005ED2;
  margin-bottom: 2.5rem;
}

.p-download-detail-meta {
  margin-top: 2rem;
  font-size: 1.5rem;
  line-height: 1.5333333333;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #7B7B7B;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 3rem;
}

.p-download-detail-content {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-top: 2.5rem;
  gap: 8rem;
}

.p-download-detail-main {
  width: 66rem;
}

.p-download-detail-sub {
  width: 46rem;
}

.p-download-detail-slider {
  margin-bottom: 3rem;
}

.p-download-detail-slider-inner {
  max-width: 70rem;
  margin: 0 auto;
  position: relative;
}
.p-download-detail-slider-inner .slick-prev {
  position: absolute;
  content: "";
  background: url(../../images/download/icn_prev.svg) no-repeat left top;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 3.7rem;
  height: 7.2rem;
  background-size: contain;
  z-index: 1;
}
.p-download-detail-slider-inner .slick-next {
  position: absolute;
  content: "";
  background: url(../../images/download/icn_next.svg) no-repeat left top;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 3.7rem;
  height: 7.2rem;
  background-size: contain;
  z-index: 1;
}

.p-download-detail-slider-item img {
  width: 100%;
  height: auto;
  display: block;
}

.p-download-detail-description {
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 400;
  margin-bottom: 8rem;
}

.p-download-detail-item {
  background-color: #EEF5FF;
  padding: 3rem 4rem;
  margin-bottom: 8rem;
}

.p-download-detail-item-ttl {
  font-size: 2rem;
  line-height: 2.4;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #005ED2;
  margin-bottom: 0.5rem;
}

.p-download-detail-item-list {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0.5rem 2rem;
}
.p-download-detail-item-list li {
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 400;
  position: relative;
  padding-left: 1.5rem;
  width: 28rem;
}
.p-download-detail-item-list li::before {
  position: absolute;
  content: "";
  top: 1rem;
  left: 0;
  background-color: #005ED2;
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
}

.p-download-detail-support {
  margin-bottom: 8rem;
}

.p-download-detail-support-ttl {
  font-size: 3.5rem;
  line-height: 1.5142857143;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #005ED2;
  position: relative;
  margin-bottom: 4rem;
}
.p-download-detail-support-ttl::before {
  position: absolute;
  bottom: -1.2rem;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #DFDFDF;
}
.p-download-detail-support-ttl::after {
  position: absolute;
  bottom: -1.2rem;
  left: 0;
  content: "";
  width: 22rem;
  height: 1px;
  background-color: #005ED2;
}

.p-download-detail-support-list {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 0 3rem;
  gap: 1.2rem;
}
.p-download-detail-support-list img {
  width: 100%;
  height: 5.1rem;
}

.p-download-detail-support-list-txt {
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 700;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 1rem 2rem;
}

@media screen and (max-width: 767px) {
  .p-download-detail {
    padding: 21.3333333333vw 5.3333333333vw 21.3333333333vw;
    width: 100%;
  }
  .p-download-detail-ttl {
    font-size: 8vw;
    line-height: 1.6;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 5.3333333333vw;
  }
  .p-download-detail-meta {
    margin-top: 5.3333333333vw;
    font-size: 4vw;
    line-height: 1.6;
    letter-spacing: 0.06em;
    font-weight: 700;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 5.3333333333vw;
  }
  .p-download-detail-content {
    flex-direction: column;
    margin-top: 5.3333333333vw;
    gap: 0;
  }
  .p-download-detail-main {
    width: 100%;
  }
  .p-download-detail-sub {
    width: 100%;
  }
  .p-download-detail-slider {
    margin-bottom: 5.3333333333vw;
  }
  .p-download-detail-slider-inner {
    max-width: 100%;
  }
  .p-download-detail-slider-inner .slick-prev {
    background: url(../../images/download/icn_prev.svg) no-repeat left top;
    width: 6.4vw;
    height: 12.2666666667vw;
    background-size: contain;
  }
  .p-download-detail-slider-inner .slick-next {
    background: url(../../images/download/icn_next.svg) no-repeat left top;
    width: 6.4vw;
    height: 12.2666666667vw;
    background-size: contain;
    z-index: 1;
  }
  .p-download-detail-description {
    font-size: 4.2666666667vw;
    line-height: 1.8125;
    letter-spacing: 0.06em;
    font-weight: 400;
    margin-bottom: 10.6666666667vw;
  }
  .p-download-detail-item {
    padding: 8vw 5.3333333333vw;
    margin-bottom: 10.6666666667vw;
  }
  .p-download-detail-item-ttl {
    font-size: 6.4vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 4vw;
  }
  .p-download-detail-item-list {
    gap: 1.3333333333vw;
  }
  .p-download-detail-item-list li {
    font-size: 4.2666666667vw;
    line-height: 1.8125;
    letter-spacing: 0.06em;
    font-weight: 400;
    padding-left: 4vw;
    width: 100%;
  }
  .p-download-detail-item-list li::before {
    top: 2.9333333333vw;
    width: 2.1333333333vw;
    height: 2.1333333333vw;
  }
  .p-download-detail-support {
    margin-bottom: 10.6666666667vw;
  }
  .p-download-detail-support-ttl {
    font-size: 6.4vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 10.6666666667vw;
  }
  .p-download-detail-support-ttl::before {
    bottom: -3.2vw;
  }
  .p-download-detail-support-ttl::after {
    bottom: -3.2vw;
    width: 26.6666666667vw;
  }
  .p-download-detail-support-list {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 0 5.3333333333vw;
    gap: 2.6666666667vw;
  }
  .p-download-detail-support-list img {
    width: 100%;
    height: 13.6vw;
  }
  .p-download-detail-support-list-txt {
    flex-direction: column;
    font-size: 4.2666666667vw;
    line-height: 1.8125;
    letter-spacing: 0.06em;
    font-weight: 700;
    gap: 1.3333333333vw 5.3333333333vw;
  }
}
.p-download-detail-cms h2 {
  font-size: 3.5rem;
  line-height: 1.5142857143;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #005ED2;
  position: relative;
  margin-bottom: 4rem;
}
.p-download-detail-cms h2::before {
  position: absolute;
  bottom: -1.2rem;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #DFDFDF;
}
.p-download-detail-cms h2::after {
  position: absolute;
  bottom: -1.2rem;
  left: 0;
  content: "";
  width: 22rem;
  height: 1px;
  background-color: #005ED2;
}
.p-download-detail-cms p {
  font-size: 1.6rem;
  line-height: 1.8125;
  letter-spacing: 0.06em;
  font-weight: 400;
  margin-bottom: 5rem;
}
.p-download-detail-cms p + p {
  margin-top: -2rem;
}
.p-download-detail-cms h3 {
  font-size: 2.8rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  margin-bottom: 2rem;
}
.p-download-detail-cms h4 {
  font-size: 2.4rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  margin-bottom: 2rem;
}
.p-download-detail-cms img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto 4rem;
  display: block;
}

@media screen and (max-width: 767px) {
  .p-download-detail-cms h2 {
    font-size: 6.4vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 10.6666666667vw;
  }
  .p-download-detail-cms h2::before {
    bottom: -3.2vw;
  }
  .p-download-detail-cms h2::after {
    bottom: -3.2vw;
    width: 26.6666666667vw;
  }
  .p-download-detail-cms p {
    font-size: 4.2666666667vw;
    line-height: 1.8125;
    letter-spacing: 0.06em;
    font-weight: 400;
    margin-bottom: 8vw;
  }
  .p-download-detail-cms p + p {
    margin-top: -2.6666666667vw;
  }
  .p-download-detail-cms h3 {
    font-size: 6.4vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 5.3333333333vw;
  }
  .p-download-detail-cms h4 {
    font-size: 5.3333333333vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 5.3333333333vw;
  }
  .p-download-detail-cms img {
    margin: 0 auto 8vw;
  }
}
