.l-main {
  padding-bottom: 0;
}

.p-mv {
  background: url("../img/bg-mv.svg") no-repeat center min(17px, 1.328125vw);
  background-size: min(371px, 28.984375vw) auto;
}
@media only screen and (max-width: 768px) {
  .p-mv {
    background-position: center center;
    background-size: 80vw auto;
    margin-bottom: 13.3333333333vw;
  }
}
.p-mv.start .p-mv-inner .p-mv-title,
.p-mv.start .p-mv-inner .p-mv-badge01,
.p-mv.start .p-mv-inner .p-mv-badge02,
.p-mv.start .p-mv-inner .p-mv-image,
.p-mv.start .p-mv-inner .p-mv-buttons {
  opacity: 1;
  transform: translateY(0);
}

.p-mv-inner {
  max-width: 980px;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-mv-inner {
    padding-top: 19.7333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-inner {
    height: min(478px, 37.34375vw);
    margin-inline: auto;
    padding-top: min(24px, 1.875vw);
  }
}

.p-mv-title {
  opacity: 0;
  text-align: center;
  transform: translateY(20px);
  transition: 0.4s ease-in-out;
}
@media only screen and (max-width: 768px) {
  .p-mv-title {
    margin-bottom: -5.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-title {
    margin-bottom: max(-30px, -2.34375vw);
  }
}
.p-mv-title img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-mv-title img {
    width: 74.9333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-title img {
    width: min(430px, 33.59375vw);
  }
}

.p-mv-badge01 {
  opacity: 0;
  position: absolute;
  top: 0;
  transform: translateY(-20px);
  transition: 0.4s ease-in-out 0.3s;
}
@media only screen and (max-width: 768px) {
  .p-mv-badge01 {
    left: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-badge01 {
    left: min(27px, 2.109375vw);
  }
}
.p-mv-badge01 img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-mv-badge01 img {
    width: 12vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-badge01 img {
    width: min(98px, 7.65625vw);
  }
}

.p-mv-badge02 {
  opacity: 0;
  position: absolute;
  transform: translateY(-20px);
  transition: 0.4s ease-in-out 0.7s;
}
@media only screen and (max-width: 768px) {
  .p-mv-badge02 {
    right: 4vw;
    top: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-badge02 {
    right: min(25px, 1.953125vw);
    top: min(18px, 1.40625vw);
  }
}
.p-mv-badge02 img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-mv-badge02 img {
    width: 36vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-badge02 img {
    width: min(206px, 16.09375vw);
  }
}

.p-mv-image {
  opacity: 0;
  text-align: center;
  transform: translateY(20px);
  transition: 0.4s ease-in-out 1.1s;
}
@media only screen and (max-width: 768px) {
  .p-mv-image {
    margin-bottom: 5.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-image {
    margin-bottom: min(19px, 1.484375vw);
  }
}
.p-mv-image img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-mv-image img {
    width: 93.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-image img {
    width: min(623px, 48.671875vw);
  }
}

.p-mv-buttons {
  opacity: 0;
  transform: translateY(20px);
  transition: 0.4s ease-in-out 1.5s;
}
@media only screen and (max-width: 768px) {
  .p-mv-buttons {
    margin-inline: auto;
    width: 80vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-buttons {
    display: flex;
    justify-content: center;
    gap: min(38px, 2.96875vw);
  }
}
@media print, screen and (min-width: 769px) {
  .p-mv-buttons li {
    width: min(330px, 25.78125vw);
  }
}
@media only screen and (max-width: 768px) {
  .p-mv-buttons li + li {
    margin-top: 5.3333333333vw;
  }
}

@media only screen and (max-width: 768px) {
  .p-contents {
    padding-inline: 6.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-contents {
    background: url("../img/bg-main.png") no-repeat calc(50% - min(106px, 8.28125vw)) min(72px, 5.625vw)/min(1873px, 146.328125vw) auto;
    padding-top: min(82px, 6.40625vw);
  }
}

.p-summary {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-summary {
    margin: 0 -6.6666666667vw 16vw;
    padding: 5.3333333333vw 6.6666666667vw 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary {
    margin-bottom: min(113px, 8.828125vw);
    padding-block: min(30px, 2.34375vw) min(130px, 10.15625vw);
  }
}
.p-summary::before {
  background: #f7f7f7;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  width: 100%;
}

.p-summary-inner {
  position: relative;
  z-index: 2;
}

.p-summary-title {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .p-summary-title {
    gap: 5.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-title {
    gap: min(36px, 2.8125vw);
  }
}

.p-summary-pict img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-summary-pict img {
    width: 16vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-pict img {
    width: min(94px, 7.34375vw);
  }
}

.p-summary-heading {
  font-weight: bold;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
  .p-summary-heading {
    font-size: 5.8666666667vw;
    line-height: 1.7;
    margin-bottom: 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-heading {
    font-size: min(2.5rem, 3.125vw);
    line-height: 1.75;
    margin-bottom: min(20px, 1.5625vw);
  }
}

.p-summary-text {
  background: #fff url("../img/bg-summary.png") no-repeat min(65px, 5.078125vw) min(15px, 1.171875vw)/min(840px, 65.625vw) auto;
}
@media only screen and (max-width: 768px) {
  .p-summary-text {
    background-position: center center;
    background-size: 100% auto;
    margin-inline: -6.6666666667vw;
    padding-block: 2.6666666667vw 5.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-text {
    border-radius: min(30px, 2.34375vw);
    padding-block: min(14px, 1.09375vw) min(32px, 2.5vw);
  }
}
.p-summary-text p {
  font-weight: bold;
  letter-spacing: 0.1em;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .p-summary-text p {
    font-size: 4.2666666667vw;
    line-height: 2.2;
  }
}
@media print, screen and (min-width: 769px) {
  .p-summary-text p {
    font-size: min(1.4375rem, 1.796875vw);
    line-height: 2.782;
  }
}

@media only screen and (max-width: 768px) {
  .p-renewal {
    border-bottom: 1.3333333333vw solid #f7f7f7;
    margin: 0 -6.6666666667vw 0;
    padding-bottom: 13.0666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal {
    border-bottom: min(10px, 0.78125vw) solid #f7f7f7;
    padding-bottom: min(98px, 7.65625vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-renewal-inner {
    padding: 4vw 6.6666666667vw 5.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-inner {
    padding-inline: min(30px, 2.34375vw);
  }
}

.p-renewal-heading {
  color: var(--bc03);
  letter-spacing: 0.15em;
  position: relative;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .p-renewal-heading {
    font-size: 5.3333333333vw;
    line-height: 1.43;
    margin-bottom: 5.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-heading {
    font-size: min(2.25rem, 2.8125vw);
    line-height: 1.405;
    margin-bottom: min(19px, 1.484375vw);
  }
}
@media only screen and (max-width: 768px) {
  .p-renewal-heading small {
    font-size: 4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-heading small {
    font-size: min(1.6875rem, 2.109375vw);
  }
}
.p-renewal-heading span {
  position: relative;
  z-index: 2;
}
.p-renewal-heading::before {
  background: var(--bc03);
  content: "";
  display: block;
  left: 0;
  opacity: 0.2;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .p-renewal-heading::before {
    height: 6.4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-heading::before {
    height: min(26px, 2.03125vw);
  }
}

.p-renewal-logo {
  display: flex;
}
@media only screen and (max-width: 768px) {
  .p-renewal-logo {
    align-items: center;
    background: url("../../img/pict-arrow_sp.svg") no-repeat center 20vw/10.6666666667vw auto;
    flex-direction: column;
    gap: 20vw;
    margin-bottom: 10.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-logo {
    align-items: flex-end;
    background: url("../../img/pict-arrow.svg") no-repeat calc(50% - min(40px, 3.125vw)) min(50px, 3.90625vw)/min(80px, 6.25vw) auto;
    justify-content: space-between;
    margin-bottom: min(52px, 4.0625vw);
    padding-top: min(40px, 3.125vw);
    padding-inline: min(35px, 2.734375vw);
  }
}

.p-renewal-logo-sagiwall img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-renewal-logo-sagiwall img {
    width: 53.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-logo-sagiwall img {
    width: min(253px, 19.765625vw);
  }
}

.p-renewal-logo-miyaburu img {
  height: auto;
}
@media only screen and (max-width: 768px) {
  .p-renewal-logo-miyaburu img {
    width: 61.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-renewal-logo-miyaburu img {
    width: min(282px, 22.03125vw);
  }
}

.p-renewal-text {
  font-weight: 400;
  text-align: justify;
}

@media only screen and (max-width: 768px) {
  .c-recommend {
    margin-bottom: 26.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .c-recommend {
    margin-bottom: min(164px, 12.8125vw);
  }
}

.p-news {
  background: #f4f4f4;
}
@media only screen and (max-width: 768px) {
  .p-news {
    margin-inline: -6.6666666667vw;
    padding: 6.6666666667vw 6.6666666667vw 18.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news {
    padding-block: min(47px, 3.671875vw) min(63px, 4.921875vw);
  }
}

.p-news-title {
  border-bottom: 1px solid #000;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
  .p-news-title {
    font-size: 4.8vw;
    line-height: 1.4;
    margin-bottom: 5.3333333333vw;
    padding-bottom: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-title {
    font-size: min(1.25rem, 1.5625vw);
    line-height: 1.5;
    margin-bottom: min(23px, 1.796875vw);
    padding-bottom: min(13px, 1.015625vw);
  }
}

@media print, screen and (min-width: 769px) {
  .p-news-items {
    padding-right: min(27px, 2.109375vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-news-item {
    position: relative;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-item {
    display: flex;
    gap: min(25px, 1.953125vw);
  }
}
@media only screen and (max-width: 768px) {
  .p-news-item + .p-news-item {
    margin-top: 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-item + .p-news-item {
    margin-top: min(22px, 1.71875vw);
  }
}

.p-news-category {
  display: grid;
  flex-shrink: 0;
  font-weight: 400;
  place-content: center;
}
@media only screen and (max-width: 768px) {
  .p-news-category {
    border-radius: 0.9333333333vw;
    font-size: 3.4666666667vw;
    height: 6.4vw;
    left: 0;
    line-height: 1.2;
    position: absolute;
    top: 0;
    width: 34.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-category {
    font-size: min(1rem, 1.25vw);
    border-radius: min(5px, 0.390625vw);
    height: min(28px, 2.1875vw);
    line-height: 1.75;
    width: min(168px, 13.125vw);
  }
}
.p-news-category.-cat01 {
  background: #ff6f6f;
}
.p-news-category.-cat02 {
  background: #d0e9f7;
}
.p-news-category.-cat03 {
  background: #fccbcb;
}

@media print, screen and (min-width: 769px) {
  .p-news-detail a {
    display: flex;
    position: relative;
  }
}
.p-news-detail a::after {
  background: #000;
  bottom: max(-8px, -0.625vw);
  content: "";
  display: block;
  height: min(2px, 0.15625vw);
  left: 0;
  position: absolute;
  scale: 0 1;
  transition: scale 0.3s ease-in-out;
  transform-origin: right;
  width: 100%;
}
@media (any-hover: hover) {
  .p-news-detail a:hover::after {
    scale: 1 1;
    transform-origin: left;
  }
}

.p-news-date {
  flex-shrink: 0;
  font-weight: 400;
}
@media only screen and (max-width: 768px) {
  .p-news-date {
    font-size: 3.4666666667vw;
    line-height: 1.846;
    padding-left: 40vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-date {
    font-size: min(1rem, 1.25vw);
    line-height: 1.75;
    width: min(140px, 10.9375vw);
  }
}

.p-news-heading {
  font-weight: 400;
}
@media only screen and (max-width: 768px) {
  .p-news-heading {
    font-size: 3.4666666667vw;
    line-height: 1.846;
    margin-top: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-heading {
    font-size: min(1rem, 1.25vw);
    line-height: 1.75;
  }
}

@media only screen and (max-width: 768px) {
  .p-news-button {
    margin: 5.3333333333vw auto 0;
    width: 66.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-news-button {
    margin: min(40px, 3.125vw) auto 0;
    width: min(329px, 25.703125vw);
  }
}
.p-news-button .c-btn02 {
  background: #fffef4;
}

.external-link-icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-left: 4px;
  opacity: 0.7;
  vertical-align: middle;
}

.p-banner {
  text-align: center;
  line-height: 1.4;
  background: #f4f4f4;
}
@media only screen and (max-width: 768px) {
  .p-banner {
    margin-bottom: 16vw;
    font-size: 3.7333333333vw;
    margin-inline: -6.6666666667vw;
    padding: 6.6666666667vw 6.6666666667vw 18.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-banner {
    font-size: min(1.4375rem, 1.796875vw);
    margin-bottom: min(120px, 9.375vw);
    padding-block: min(47px, 3.671875vw) min(63px, 4.921875vw);
  }
}
.p-banner h1 {
  font-weight: bold;
  margin-block: 1em;
}
.p-banner h1 span {
  font-weight: normal;
  display: block;
}
@media only screen and (max-width: 768px) {
  .p-banner h1 {
    font-size: 3.7333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-banner h1 {
    font-size: min(1.4375rem, 1.796875vw);
  }
}
.p-banner a {
  display: inline-block;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
@media (any-hover: hover) {
  .p-banner a:hover {
    opacity: 0.7;
  }
}

/*# sourceMappingURL=index.css.map */
