@media only screen and (max-width: 768px) {
  .c-mv {
    background-image: url("../img/img-main_sp.jpg");
  }
}
@media print, screen and (min-width: 769px) {
  .c-mv {
    background-image: url("../img/img-main.jpg");
  }
}

@media only screen and (max-width: 768px) {
  .p-summary {
    margin-bottom: 15.2vw;
    padding-inline: 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary {
    align-items: center;
    display: flex;
    gap: min(78px, 5.5714285714vw);
    margin: 0 auto min(102px, 7.2857142857vw);
    width: min(990px, 70.7142857143vw);
  }
}

.p-summary-catch {
  line-height: 1.625;
}
@media only screen and (max-width: 768px) {
  .p-summary-catch {
    font-size: 6.1333333333vw;
    margin-bottom: 4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-catch {
    font-size: min(32px, 2.2857142857vw);
    margin-bottom: min(15px, 1.0714285714vw);
  }
}
.p-summary-catch span {
  background: linear-gradient(to right, var(--bc05), #6464d9);
  color: #fff;
  display: inline-block;
}
@media only screen and (max-width: 768px) {
  .p-summary-catch span {
    margin-right: 2.6666666667vw;
    padding-inline: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-catch span {
    margin-right: min(10px, 0.7142857143vw);
    padding-inline: min(10px, 0.7142857143vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-summary-lead {
    font-size: 3.7333333333vw;
    margin-bottom: 5.8666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-lead {
    font-size: min(18px, 1.2857142857vw);
    margin-bottom: min(30px, 2.1428571429vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-summary-text {
    font-size: 3.7333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-text {
    font-size: min(15px, 1.0714285714vw);
  }
}
.p-summary-text + .p-summary-text {
  margin-top: 1.6em;
}

@media only screen and (max-width: 768px) {
  .p-summary-image {
    margin-top: 6.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-image {
    flex-shrink: 0;
    width: min(496px, 35.4285714286vw);
  }
}
.p-summary-image img {
  height: auto;
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .p-factory {
    padding: 5.3333333333vw 5.3333333333vw 13.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory {
    padding: min(40px, 2.8571428571vw) min(40px, 2.8571428571vw) min(100px, 7.1428571429vw);
  }
}

.p-factory-mv {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-factory-mv {
    margin-bottom: 10vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-mv {
    margin-bottom: min(75px, 5.3571428571vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-factory-mv-image {
    height: 53.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-mv-image {
    height: min(320px, 22.8571428571vw);
  }
}
.p-factory-mv-image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-factory-mv-title {
  color: #fff;
  left: 50%;
  position: absolute;
  text-align: center;
  top: 50%;
  translate: -50% -50%;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .p-factory-mv-title {
    font-size: 6.1333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-mv-title {
    font-size: min(32px, 2.2857142857vw);
  }
}

.p-factory-mv-button {
  position: absolute;
}
@media only screen and (max-width: 768px) {
  .p-factory-mv-button {
    bottom: -12.9333333333vw;
    right: 2.4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-mv-button {
    bottom: max(-80px, -5.7142857143vw);
    display: flex;
    justify-content: flex-end;
    left: 50%;
    translate: -50%;
    width: min(990px, 70.7142857143vw);
  }
}

@media print, screen and (min-width: 769px) {
  .p-factory-main {
    margin-inline: auto;
    width: min(990px, 70.7142857143vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-factory-catch {
    font-size: 4.2666666667vw;
    margin-bottom: 6.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-catch {
    font-size: min(28px, 2vw);
    margin-bottom: min(30px, 2.1428571429vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-factory-lead {
    font-size: 3.7333333333vw;
    line-height: 1.785;
    margin-bottom: 6.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-lead {
    font-size: min(15px, 1.0714285714vw);
    margin-bottom: min(70px, 5vw);
    width: min(680px, 48.5714285714vw);
  }
}

@media print, screen and (min-width: 769px) {
  .p-factory-item {
    align-items: center;
    display: flex;
    gap: min(40px, 2.8571428571vw);
  }
}
@media only screen and (max-width: 768px) {
  .p-factory-item + .p-factory-item {
    margin-top: 7.2vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-item + .p-factory-item {
    margin-top: min(60px, 4.2857142857vw);
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-item:nth-child(even) {
    flex-direction: row-reverse;
  }
}

@media only screen and (max-width: 768px) {
  .p-factory-item-image {
    margin-bottom: 4.8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-item-image {
    flex-shrink: 0;
    width: min(495px, 35.3571428571vw);
  }
}
.p-factory-item-image img {
  height: auto;
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .p-factory-item-title {
    font-size: 4.2666666667vw;
    margin-bottom: 4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-item-title {
    font-size: min(20px, 1.4285714286vw);
    margin-bottom: min(13px, 0.9285714286vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-factory-item-text {
    font-size: 3.7333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory-item-text {
    font-size: min(15px, 1.0714285714vw);
  }
}

.p-franchise {
  background: var(--bc03);
}