/*==================================================
sp pc
==================================================*/
@media all and (max-width: 768px) {
  .pc-only {
    display: none !important;
  }
}

@media all and (min-width: 769px) {
  .sp-only {
    display: none !important;
  }
}
@media all and (max-width: 768px) {
  .sp-only {
    display: block;
  }
}

/*--------------------------------------
campaign
----------------------------------------*/
.campaign-sec {
  padding-bottom: 4rem;
}
@media all and (max-width: 768px) {
  .campaign-sec {
    padding-block: 4rem;
  }
}
@media all and (max-width: 768px) {
  .campaign-sec .p-sec__ttl {
    font-size: 2rem;
  }
}

.campaign-brands {
  display: grid;
  gap: 3.5rem;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 6rem;
}
@media all and (max-width: 1280px) {
  .campaign-brands {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media all and (max-width: 768px) {
  .campaign-brands {
    gap: 4rem;
    grid-template-columns: 1fr;
    margin-top: 4rem;
  }
}

.campaign-brand {
  background-color: #fff;
  border-radius: 0.8rem;
  box-shadow: 0 0 1.6rem rgba(142, 126, 102, 0.3);
  padding: 3rem;
}
.campaign-brand__logo {
  text-align: center;
}
.campaign-brand__logo-img {
  max-width: 20rem;
  width: 100%;
}
.campaign-brand__logo-name {
  display: block;
  letter-spacing: 0.1em;
  line-height: 1.6;
  margin-top: 0.5em;
}
.campaign-brand__btns {
  display: grid;
  gap: 1em;
  justify-items: center;
  margin-top: 1.5em;
  text-align: center;
}
.campaign-brand__btns .m-btn {
  max-width: 26rem;
  width: 100%;
}

.campaign-search {
  align-items: start;
  display: grid;
  gap: 2rem;
  grid-template-columns: 10rem 68rem;
  justify-content: center;
  margin-top: 4rem;
}
@media all and (max-width: 1080px) {
  .campaign-search {
    display: block;
  }
}
.campaign-search__ttl {
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.1em;
  margin-top: 0.9rem;
}
@media all and (max-width: 1080px) {
  .campaign-search__ttl {
    margin-block: 0 1.5rem;
  }
}
.campaign-search .m-search {
  margin: 0;
  width: 100%;
}
.campaign-search .m-search__select {
  width: 22rem;
}
@media all and (max-width: 768px) {
  .campaign-search .m-search__select {
    display: block;
    height: 5rem;
    width: 28rem;
  }
  .campaign-search .m-search__select select {
    border-color: var(--body-color);
    border-radius: 0.8rem;
    padding-left: 1em;
  }
}
@media all and (max-width: 768px) {
  .campaign-search .m-search__keyword {
    position: relative;
    z-index: 0;
  }
  .campaign-search .m-search__keyword input {
    padding-right: 4.8rem;
  }
}
@media all and (max-width: 768px) {
  .campaign-search .m-search__keyword-submit {
    display: block;
    height: 100%;
    padding: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 4.8rem;
    z-index: 1;
  }
}

.campaign-search-info {
  margin-top: 4rem;
}
.campaign-search-info__ico {
  margin: -0.2rem 0.3rem 0 0.2rem;
  vertical-align: middle;
}

.campaign-search-box {
  margin-top: 4rem;
}
@media all and (min-width: 769px) {
  .campaign-search-box .p-box {
    padding: 3.2rem 6rem 4rem;
  }
}

.campaign-number {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem 0.8rem;
  justify-content: center;
  line-height: 1;
  margin-block: 4.5rem;
}
@media all and (max-width: 768px) {
  .campaign-number {
    margin-block: 3.5rem;
  }
}
.campaign-number__ttl {
  font-size: 2.4rem;
  font-weight: var(--font-weight-base);
  letter-spacing: 0.1em;
}
@media all and (max-width: 768px) {
  .campaign-number__ttl {
    font-size: 2rem;
  }
}
.campaign-number__body {
  font-size: 4rem;
  font-weight: var(--font-weight-base);
  letter-spacing: 0.1em;
}
@media all and (max-width: 768px) {
  .campaign-number__body {
    font-size: 3.2rem;
  }
}

.campaign-dl {
  display: grid;
  gap: 1.7rem;
  margin-top: 3rem;
}
@media all and (max-width: 768px) {
  .campaign-dl {
    gap: 2rem;
  }
}
.campaign-dl__item {
  border-bottom: 0.1rem solid var(--border-color);
  display: grid;
  font-size: 1.8rem;
  gap: 2rem;
  grid-template-columns: 26rem 1fr;
  letter-spacing: 0.05em;
  line-height: 1.33;
  padding: 0 2rem 1.8rem;
}
@media all and (max-width: 768px) {
  .campaign-dl__item {
    font-size: 1.6rem;
    gap: 1.2rem;
    grid-template-columns: 1fr;
    padding-inline: 0;
  }
}
@media all and (max-width: 768px) {
  .campaign-dl__dd {
    line-height: 1.94;
    padding-inline: 1.5rem;
  }
}