main, main .inner, .campaign-fv, .campaign-fv img {
  width: 100%;
}

.content_wrap {
  background: radial-gradient(rgb(254, 249, 249) 22.8%, transparent 22.8%), radial-gradient(rgb(254, 249, 249) 22.8%, transparent 22.8%);
  background-position: 0px 0px, 24px 24px;
  background-size: 48px 48px;
  background-color: #ffffff;
}
.content_wrap .page_wrap {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .content_wrap .page_wrap {
    margin-top: 30px;
  }
}

h1.tit.campaign-tit br {
  display: none;
}
@media screen and (max-width: 768px) {
  h1.tit.campaign-tit {
    position: relative;
    display: inline-block;
    padding-left: 42px;
    width: 100%;
    text-align: center;
    font-size: 17px;
    word-break: auto-phrase;
  }
  h1.tit.campaign-tit i {
    position: absolute;
    display: inline-block;
    left: 6px;
    top: 14px;
    width: 34px;
  }
  h1.tit.campaign-tit br {
    display: block;
  }
}
h1.tit.campaign-tit span {
  color: #F2FF3F;
  -webkit-text-stroke: 8px #E8442B;
  font-weight: 900;
  font-size: 45px;
  display: inline-block;
  margin: 0 4px;
  paint-order: stroke fill;
}
@media screen and (max-width: 768px) {
  h1.tit.campaign-tit span {
    -webkit-text-stroke: 4px #E8442B;
    font-weight: 900;
    font-size: 22px;
  }
}

.campaign-fv {
  position: relative;
}
.campaign-fv .due-date {
  position: absolute;
  color: #ffffff;
  font: bold 28px/28px sans-serif;
  top: 46%;
  left: 22.7%;
  transform: translate(-50%, -50%);
  text-align: center;
}
@media screen and (max-width: 768px) {
  .campaign-fv .due-date {
    font: bold 17px/17px sans-serif;
    top: 47%;
    left: 14%;
  }
}
.campaign-fv .due-date span {
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .campaign-fv .due-date span {
    font-size: 15px;
  }
}
.campaign-fv.pc {
  display: block;
}
@media screen and (max-width: 768px) {
  .campaign-fv.pc {
    display: none;
  }
}
.campaign-fv.sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .campaign-fv.sp {
    display: block;
  }
}

.campaign-block {
  background: #ffffff;
  border-radius: 14px;
  border: 1px solid #F16B6F;
  margin-bottom: 64px;
}
.campaign-block .company-name {
  position: relative;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .campaign-block .company-name {
    margin-bottom: 16px;
  }
}
.campaign-block .company-name a {
  display: block;
  color: #F16B6F;
  text-align: center;
  font-size: 38px;
  font-style: normal;
  font-weight: bolder;
  line-height: 38px;
  padding: 16px 0;
  -webkit-text-stroke-width: 8px;
  -webkit-text-stroke-color: #FFF;
  background: rgba(241, 107, 111, 0.62);
  paint-order: stroke fill;
  max-width: 80%;
  margin: 40px auto 0;
}
@media screen and (max-width: 768px) {
  .campaign-block .company-name a {
    font-size: 24px;
    line-height: 28px;
    font-weight: 600;
    -webkit-text-stroke-width: 6px;
    margin: 16px auto 0;
    max-width: 90%;
  }
}
.campaign-block .content {
  display: flex;
  gap: 8px;
  padding: 0 64px 64px;
}
@media screen and (max-width: 768px) {
  .campaign-block .content {
    flex-direction: column;
    padding: 0 24px 32px;
  }
  .campaign-block .content p, .campaign-block .content li {
    font-size: 14px;
    line-height: normal;
  }
  .campaign-block .content p:has(strong) {
    margin-bottom: 0;
  }
}
.campaign-block .content .left {
  flex-basis: 30%;
  display: flex;
  flex-direction: column;
  gap: 48px;
}
@media screen and (max-width: 768px) {
  .campaign-block .content .left {
    flex-basis: auto;
    gap: 32px;
  }
}
.campaign-block .content .left *:first-child {
  margin-top: 96px;
}
@media screen and (max-width: 768px) {
  .campaign-block .content .left *:first-child {
    margin-top: 0;
  }
}
.campaign-block .content .left .img-wrap {
  display: block;
  width: 100%;
}
.campaign-block .content .left .img-wrap img {
  margin: 0;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.campaign-block .content .left .target-item {
  border-radius: 25px;
  background: #FFE8E2;
  padding: 32px;
}
@media screen and (max-width: 768px) {
  .campaign-block .content .left .target-item {
    padding: 15px 32px 32px;
  }
}
.campaign-block .content .left .target-item h3 {
  color: #FFF;
  -webkit-text-stroke-width: 4px;
  -webkit-text-stroke-color: #E8442B;
  font-size: 30px;
  font-style: normal;
  font-weight: bold;
  margin: 0;
  display: block;
  text-align: center;
  padding: 0 0 16px;
  paint-order: stroke fill;
  line-height: 30px;
}
@media screen and (max-width: 768px) {
  .campaign-block .content .left .target-item h3 {
    font-size: 22px;
    -webkit-text-stroke-width: 2px;
  }
}
.campaign-block .content .left .target-item ul {
  list-style-type: disc;
  margin-left: 16px;
}
.campaign-block .content .left .target-item ul li {
  margin-top: 0;
}
.campaign-block .content .right {
  flex-basis: 70%;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
@media screen and (max-width: 768px) {
  .campaign-block .content .right {
    flex-basis: auto;
  }
  .campaign-block .content .right .select .btn span, .campaign-block .content .right .page_column .btn span {
    width: auto;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  .campaign-block .content .right ul {
    margin-left: 16px;
  }
}
@media screen and (max-width: 768px) {
  .campaign-block .content .right ul li {
    padding-left: 0;
  }
  .campaign-block .content .right ul li::before {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .campaign-block .content .right .content-body {
    padding-bottom: 0;
  }
}
.campaign-block .content .right .content-body h3 {
  margin-top: 32px;
  margin-bottom: 16px;
  color: #F16B6F;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 32px;
  font-style: normal;
  font-weight: bold;
  line-height: normal;
}
.campaign-block .content .right .content-body h3::before, .campaign-block .content .right .content-body h3::after {
  content: "";
  display: none;
}
@media screen and (max-width: 768px) {
  .campaign-block .content .right .content-body h3 {
    font-size: 19px;
  }
}
.campaign-block .content .right .content-body p {
  font-weight: normal;
}
.campaign-block .content .right .content-body p strong {
  font-weight: bold;
  color: unset;
  font-size: medium;
}
.campaign-block .content .right .content-body ul {
  list-style-type: disc;
  margin-left: 24px;
}
.campaign-block .content .right .content-body ul li {
  margin-top: 0;
}
.campaign-block .select .btn {
  max-width: 80%;
}
@media screen and (max-width: 768px) {
  .campaign-block .select .btn {
    margin: 0 auto;
  }
}/*# sourceMappingURL=campaign.css.map */