.laprimp-img {
  text-align: center;
  margin: 0 auto;
}

.laprimp-img img {
  width: auto;
}
@media only screen and (max-width: 768px) {
  .laprimp-img img {
    max-width: 100px;
    padding-bottom: 50px;
  }
}
@media print, screen and (min-width: 769px) {
  .laprimp-img img {
    max-width: 200px;
    padding-bottom: 100px;
  }
}

.policy-img img {
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .policy-img img {
    padding: 20px 0;
  }
}
@media print, screen and (min-width: 769px) {
  .policy-img img {
    padding: 30px 0;
  }
}

.p-policy {
  background: var(--color-gray);
  font-weight: 300;
}
@media only screen and (max-width: 768px) {
  .p-policy {
    margin-bottom: 16vw;
    padding: 13.3333333333vw 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-policy {
    margin-bottom: min(117px, 9.140625vw);
    padding-block: min(94px, 7.34375vw) min(234px, 18.28125vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-sec + .p-sec {
    margin-top: 11.7333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec + .p-sec {
    margin-top: min(88px, 6.875vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-item + .p-sec-item {
    margin-top: 5.8666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-item + .p-sec-item {
    margin-top: min(44px, 3.4375vw);
  }
}

.p-sec-title {
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .p-sec-title {
    font-size: 3.6vw;
    line-height: 1.62;
    margin-bottom: 1em;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-title {
    font-size: min(25px, 1.953125vw);
    line-height: 1.76;
    margin-bottom: 1.3em;
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-lead {
    font-size: 3.0666666667vw;
    line-height: 1.91;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-lead {
    font-size: min(21px, 1.640625vw);
    line-height: 2.09;
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-heading {
    font-size: 3.0666666667vw;
    line-height: 1.91;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-heading {
    font-size: min(21px, 1.640625vw);
    line-height: 2.09;
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-text {
    font-size: 3.0666666667vw;
    line-height: 1.91;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-text {
    font-size: min(18px, 1.40625vw);
    line-height: 2.444;
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-text-2 {
    margin-bottom: 1em;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-text-2 {
    margin-bottom: 2em;
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-sub {
    padding: 1em 0;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-sub {
    padding: 2em 0;
  }
}

.p-sec-sub-title {
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .p-sec-sub-title {
    font-size: 3.6vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-sub-title {
    font-size: min(25px, 1.953125vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-sec-sub-text {
    font-size: 3.0666666667vw;
    line-height: 1.91;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec-sub-text {
    font-size: min(18px, 1.40625vw);
    line-height: 2.444;
  }
}

.policy-sec-img {
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .policy-sec-img {
    margin: 1em 0;
  }
}
@media print, screen and (min-width: 769px) {
  .policy-sec-img {
    margin: 2em 0;
  }
}

@media only screen and (max-width: 768px) {
  .pc-disp {
    display: none;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-disp {
    display: block;
  }
}

@media only screen and (max-width: 768px) {
  .sp-disp {
    display: block;
  }
}
@media print, screen and (min-width: 769px) {
  .sp-disp {
    display: none;
  }
}

.policy-sec-img img {
  width: 100%;
  padding: 0;
}

@media only screen and (max-width: 768px) {
  .p-system-items {
    border: 2px solid var(--color-pink);
    border-radius: 4vw;
    margin-block: 5.3333333333vw;
    padding: 8vw 6.9333333333vw 9.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-system-items {
    background: #ffffff;
    padding: 3rem;
    display: flex;
    justify-content: space-around;
    margin-block: min(30px, 2.34375vw) min(25px, 1.953125vw);
  }
}

.p-system-item {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-system-item {
    display: grid;
    grid-template: "num heading" auto "num detail" auto/11.7333333333vw 1fr;
    row-gap: 3.6vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-system-item {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: min(322px, 25.15625vw);
    padding: min(50px, 3.90625vw) min(12px, 0.9375vw) 0;
    width: min(204px, 15.9375vw);
  }
}
.p-system-item::after {
  background: url("../img/bg-pazzle.svg") no-repeat left top/cover;
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: 50%;
  translate: -50% -50%;
}
@media print, screen and (min-width: 769px) {
  .p-system-item::after {
    height: min(322px, 25.15625vw);
    width: min(204px, 15.9375vw);
  }
}
@media print, screen and (min-width: 769px) {
  .p-system-item:nth-child(2) {
    width: min(325px, 25.390625vw);
  }
}
.p-system-item:nth-child(2)::after {
  rotate: 90deg;
}
@media print, screen and (min-width: 769px) {
  .p-system-item:nth-child(2) .p-system-detail {
    width: min(140px, 10.9375vw);
  }
}
@media only screen and (max-width: 768px) {
  .p-system-item:not(:last-child) {
    border-bottom: 1px dashed var(--color-pink);
    margin-bottom: 4.6666666667vw;
    padding-bottom: 5.3333333333vw;
  }
}

.p-system-num {
  color: var(--color-pink);
  font-family: "Noto Serif JP", serif;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  .p-system-num {
    font-size: 6.9333333333vw;
    grid-area: num;
    line-height: 1.442;
  }
}
@media print, screen and (min-width: 769px) {
  .p-system-num {
    font-size: min(33px, 2.578125vw);
    line-height: 1.42;
    margin-bottom: min(5px, 0.390625vw);
  }
}

.p-system-heading {
  letter-spacing: 0.06em;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  .p-system-heading {
    font-size: 4vw;
    grid-area: heading;
    line-height: 1.466;
    padding-top: 2.4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-system-heading {
    font-size: min(19px, 1.484375vw);
    line-height: 1.42;
    margin-bottom: min(26px, 2.03125vw);
  }
}

.p-system-detail {
  letter-spacing: 0.06em;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  .p-system-detail {
    font-size: 3.0666666667vw;
    grid-area: detail;
    line-height: 1.652;
  }
}
@media print, screen and (min-width: 769px) {
  .p-system-detail {
    font-size: min(12px, 0.9375vw);
    line-height: 1.83;
    text-align: center;
  }
}
@media only screen and (max-width: 768px) {
  .p-system-detail br {
    display: none;
  }
}/*# sourceMappingURL=index.css.map */