@charset "utf-8";
@import 'https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;700&display=swap';

/* ------------------------------------
 * contents共通
 * --------------------------------- */

html {
  overflow-x: clip;
}

body {
  overflow-x: clip;
}

.contents-block {
  font-family: "Noto Sans JP", sans-serif;
}

:root {
  --contents-black-01: #262626;
  --contents-black-02: #000;
  --contents-white-01: #FFF;
  --contents-blue-01: #1E2766;
  --contents-blue-02: #294197;
  --contents-skyblue-01: #F0F7FF;
  --contents-red-01: #E4007F;
  --root-font-size: 16;
  --rem: 1rem / var(--root-font-size);
}

/* ------------------------------------
 * Body
 * --------------------------------- */

/* heading */
.primary>* {
  font-size: calc(28 * var(--rem));
  font-weight: 700;
  line-height: calc(36 / 28);
  color: var(--contents-black-01);
  text-align: center;
  letter-spacing: normal;
}

.secondary>* {
  font-size: calc(27 * var(--rem));
  font-weight: 700;
  line-height: calc(32 / 27);
  color: var(--contents-blue-01);
  text-align: center;
  letter-spacing: normal;
}

.tertiary>* {
  font-size: calc(18 * var(--rem));
  font-weight: 700;
  line-height: calc(25.2 / 18);
  text-align: center;
  letter-spacing: calc(0.9 * var(--rem));
}

.contents-block {
  width: 100%;
  max-width: 1230px;
  padding-inline: 15px;
  margin-inline: auto;
}

.contents-breadcrumb .uc-mod-nav-breadcrumb-01 {
  width: 1200px;
}

/* TOP */

/* .lead-text a {
  display: block;
  padding: 11px 20px 20px;
  background-color: var(--contents-blue-01);
}

.lead-text>*,
.lead-text a {
  font-size: calc(16 * var(--rem));
  font-weight: 700;
  line-height: calc(25 / 16);
  color: var(--contents-white-01);
  text-align: center;
  letter-spacing: normal;
}

.lead-text {
  position: relative;
}

.lead-text a::after {
  position: absolute;
  right: 50%;
  bottom: 2px;
  display: inline-block;
  width: 20px;
  height: 20px;
  content: "";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-arrow_03.png");
  background-repeat: no-repeat;
  background-size: 100%;
  transform: translateX(50%);
} */

.kv-image {
  margin-bottom: 0;
}

.content-heading {
  padding-bottom: 14px;
  margin-bottom: 20px;
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/image-line_01.png");
  background-repeat: no-repeat;
  background-position: bottom;
  background-size: 142px 4px;
}

.content-text {
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(26 / 16);
  color: var(--contents-black-01);
  text-align: center;
  letter-spacing: normal;
}

.content-image {
  width: 100%;
  max-width: 163px;
  margin-bottom: 0;
}


.select-wrap {
  display: grid;
  gap: 10px;
}

.card-voice-block {
  display: flex;
  gap: 25px;
  align-items: center;
  justify-content: center;
}

.card-voice-text {
  position: relative;
  width: 100%;
  max-width: 240px;
}

.card-voice-text a {
  display: block;
  padding: 15px;
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(22 / 16);
  color: var(--contents-blue-01);
  letter-spacing: normal;
  background: var(--contents-white-01);
  border: 1px solid var(--contents-blue-02);
  border-radius: 10px;
}

.card-voice-text a::after {
  position: absolute;
  z-index: 1;
  width: 25px;
  height: 22px;
  content: "";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-voice-bubble_01.png");
  background-repeat: no-repeat;
  background-position: left;
  background-size: 100%;
  transform: translateY(50%);
}

.card-voice-text a:hover {
  text-decoration: none;
  opacity: 0.7;
}

.select-wrap>.CMP-CM05-block:nth-child(odd) .card-voice-text a::after {
  top: 36%;
  left: -20px;
}

.select-wrap>.CMP-CM05-block:nth-child(even) .card-voice-text a::after {
  top: 50%;
  right: -20px;
  rotate: 180deg;
}

.card-voice-text b {
  margin-top: auto;
  font-weight: 400;
}

.card-voice-text-custom {
  display: block;
  width: fit-content;
  margin-top: auto;
  margin-left: auto;
}

.card-voice-text-custom::after {
  display: inline-block;
  width: 17px;
  height: 17px;
  margin-bottom: -2px;
  margin-left: 8px;
  content: "";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-arrow_01.png");
  background-repeat: no-repeat;
  background-size: 100%;
}

.card-voice-image {
  width: 80px;
  margin-bottom: 0;
}

/* TOP・下層共通パーツ */
.choice-wrap {
  width: 100vw;
  padding: 22px 15px 27.6px;
  margin: 0 calc(50% - 50vw);
  background-color: var(--contents-skyblue-01);
}

.heading-decoration_01 {
  display: flex;
  justify-content: center;
}

.heading-decoration_01>* {
  display: flex;
  flex-direction: column;
}

.heading-decoration_01>* span:nth-child(1) {
  position: relative;
  margin-bottom: 15px;
  font-size: calc(18 * var(--rem));
  line-height: calc(28 / 18);
  color: var(--contents-blue-02);
  letter-spacing: normal;
}

.heading-decoration_01>* span:nth-child(1)::before,
.heading-decoration_01>* span:nth-child(1)::after {
  position: absolute;
  bottom: 3px;
  width: 1px;
  height: 23px;
  content: "";
  background-color: var(--contents-blue-02);
  background-size: 100%;
}

.heading-decoration_01>* span:nth-child(1)::before {
  margin-left: -10px;
  background-position: left;
  transform: rotate(-45deg);
}

.heading-decoration_01>* span:nth-child(1)::after {
  margin-left: 10px;
  background-position: right;
  transform: rotate(45deg);
}

.heading-decoration_01>* span:nth-child(2) {
  font-size: calc(24 * var(--rem));
  line-height: calc(28 / 24);
  color: var(--contents-blue-01);
  letter-spacing: normal;
}

.card-block {
  display: grid;
  gap: 15px;
  max-width: 1160px;
  margin-inline: auto;
}

.card a {
  display: flex;
  flex-direction: row-reverse;
  gap: 12px;
  align-items: center;
  justify-content: flex-end;
  padding: 15px 15.5px 15px 13.5px;
  background-color: var(--contents-white-01);
  border: 1px solid var(--contents-blue-02);
}

.card a:hover {
  text-decoration: none;
  opacity: 0.7;
}

.card-text_01 {
  font-size: calc(18 * var(--rem));
  font-weight: 700;
  line-height: calc(20 / 18);
  color: var(--contents-blue-01);
  text-align: left;
  letter-spacing: normal;
}

.card.card-custom_01,
.card.card-custom_02 {
  position: relative;
  width: 100%;
  max-width: 345px;
  margin-inline: auto;
}

.card.card-custom_01 a,
.card.card-custom_02 a {
  padding-right: 28px;
}

.card.card-custom_01 a::after,
.card.card-custom_02 a::after {
  position: absolute;
  right: 10px;
  bottom: 50%;
  display: inline-block;
  width: 17px;
  height: 17px;
  content: "";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-arrow_01.png");
  background-repeat: no-repeat;
  background-size: 100%;
  transform: translateY(50%);
}

.card.card-custom_01 .uc-put-media,
.card.card-custom_02 .uc-put-media {
  width: 80px;
}

.card.card-custom_01 a .uc-put-text,
.card.card-custom_02 a .uc-put-text {
  font-size: calc(14 * var(--rem));
  font-weight: 700;
  line-height: calc(20 / 14);
  color: var(--contents-blue-01);
  text-align: left;
  letter-spacing: normal;
}

.card.card-custom_01 a .uc-put-text p:has(.card-text_02) {
  margin-bottom: 8px;
}

.card.card-custom_02 a .uc-put-text p:has(.card-text_01) {
  margin-bottom: 8px;
}

.card.card-custom_01 a .card-text_01,
.card.card-custom_01 a .card-text_02,
.card.card-custom_02 a .card-text_01,
.card.card-custom_02 a .card-text_02 {
  display: block;
  width: 100%;
}

.card.card-custom_01 a .card-text_01,
.card.card-custom_02 a .card-text_01 {
  max-width: 220px;
}

.card.card-custom_01 a .card-text_02,
.card.card-custom_02 a .card-text_02 {
  max-width: 200px;
}

.card-block-custom_01 {
  align-items: center;
}

.annotation-block_01 {
  padding: 20px 5px 30px;
}

.annotation-text_01 {
  font-size: calc(14 * var(--rem));
  font-weight: 400;
  line-height: calc(22 / 14);
  color: var(--contents-black-02);
  text-align: left;
  letter-spacing: normal;
}


/* 下層ページ */
.contents-sub-block {
  padding-bottom: 25px;
}

.primary-sub>* {
  font-size: calc(22 * var(--rem));
  line-height: calc(40 / 22);
  color: var(--contents-blue-01);
  text-align: left;
}

.intro-wrap {
  padding: 23px 10px 21px;
}

.type-shindan-intro {
  background-color: #FFFCE4;
}

.size-shindan-intro {
  background-color: #F0F7FF;
}

.pants-shindan-intro {
  background-color: #FFEFF2;
}

.charm-san-intro {
  background-color: #F1FDE2;
}

.intro-heading>* {
  font-size: calc(22 * var(--rem));
  line-height: calc(30 / 22);
  color: var(--contents-blue-01);
}

.type-shindan-intro .intro-image {
  width: 100%;
  max-width: 104px;
  margin-block: 10px 6.7px;
  transform: translateX(17px);
}

.size-shindan-intro .intro-image {
  width: 100%;
  max-width: 86px;
  margin-block: 19px 0;
}

.pants-shindan-intro .intro-image {
  width: 100%;
  max-width: 75px;
  margin-block: 5px 8px;
}

.charm-san-intro .intro-image {
  width: 100%;
  max-width: 140px;
  margin-block: 12px 3px;
  transform: translateX(3px);
}

.image-wrap {
  display: flex;
  flex-direction: column;
}

.image-block {
  display: flex;
  flex-direction: column;
  padding-bottom: 34px;
  background-color: var(--contents-white-01);
  border-radius: 15px;
}

.image-text {
  padding: 15px;
  font-size: calc(18 * var(--rem));
  font-weight: 700;
  line-height: calc(20 / 18);
  color: var(--contents-white-01);
  text-align: center;
  letter-spacing: normal;
  background-color: var(--contents-blue-02);
  border-radius: 8px 8px 0 0;
}

.image-sub-text {
  padding-inline: 10px;
  margin-block: 17px 20px;
  margin-bottom: 20px;
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(24 / 16);
  color: var(--contents-blue-01);
  text-align: center;
}

.image-sub-text b {
  font-weight: 400;
}

/* .CMP-CM11-image-and-text:has(>.image-capture) {
  margin-top: auto;
} */

.image-capture.uc-mod-media-01 {
  margin-bottom: 0;
}

.image-capture img {
  width: 100%;
  max-width: 200px;
}

.CMP-CM11-image-and-text:has(>.image-capture-custom-01) {
  margin-top: 0;
}

.CMP-CM05-block:has(>.image-block-next) {
  position: relative;
  padding-bottom: 58px;
}

.CMP-CM05-block:has(>.image-block-next)::before {
  position: absolute;
  bottom: -6px;
  left: calc(50% - 20px);
  width: 38.5px;
  height: 33.5px;
  content: "";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-arrow_02.png");
  background-repeat: no-repeat;
  background-position: left;
  background-size: 100%;
  transform: translateX(-50%);
  rotate: 90deg;
}

.contents-button_01 a {
  /* position: relative; */
  display: grid;
  width: 100%;
  max-width: 344px;
  padding: 18px 36px;
  margin-inline: auto;
  font-size: calc(18 * var(--rem));
  font-weight: 700;
  line-height: calc(28 / 18);
  color: var(--contents-white-01);
  text-align: center;
  letter-spacing: normal;
  background-color: var(--contents-red-01);
  border-radius: 32px;
}

.blank-button_01 a {
  position: relative;
}

.blank-button_01 a::after {
  position: absolute;
  top: 50%;
  right: 28px;
  width: 13.5px;
  height: 14px;
  font-size: 0;
  content: "別ウインドウで開きます";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-blank_01.png");
  background-repeat: no-repeat;
  background-position: left;
  background-size: 100%;
  transform: translateY(-50%);
}

/* .contents-button_01 a::after {
  position: absolute;
  top: 50%;
  right: 20px;
  width: 24px;
  height: 24px;
  content: "";
  background-image: url("/content/dam/sites/jp_lifree_com/ja/contents/icon-arrow_04.png");
  background-repeat: no-repeat;
  background-position: left;
  background-size: 100%;
  transform: translateY(-50%);
} */

.user-voice-image.uc-mod-media-01 {
  margin-bottom: 0;
}

.user-voice-image img {
  width: 100%;
  max-width: 125px;
}

.user-voice-text {
  padding: 25px 22.5px 27px;
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(28 / 16);
  color: var(--contents-black-01);
  letter-spacing: normal;
  background-color: var(--contents-skyblue-01);
  border-radius: 10px;
}

.useful-content-section {
  padding: 28px 15px 21.5px;
}

.useful-content-heading>* {
  font-size: calc(22 * var(--rem));
  line-height: calc(32 / 22);
}

.useful-content-text {
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(28 / 16);
  color: var(--contents-black-01);
  text-align: center;
  letter-spacing: normal;
}

.useful-content-image.uc-mod-media-01 {
  margin-bottom: 0;
}

.useful-content-image img {
  width: 100%;
  max-width: 130px;
}

.no-js .only-pc,
.no-js .only-sp {
  display: none;
}

.only-pc,
.only-sp {
  display: none;
}

.is-sp .only-sp {
  display: block;
}

.is-nonsp .only-pc {
  display: block;
}

.size-shindan-intro-text {
  padding: 16px;
  margin: 0 calc(50% - 50vw);
  font-size: calc(18 * var(--rem));
  font-weight: 700;
  line-height: calc(18 / 18);
  color: var(--contents-white-01);
  text-align: center;
  letter-spacing: normal;
  background-color: var(--contents-red-01);
}

.size-shindan-heading>* {
  font-size: calc(22 * var(--rem));
  line-height: calc(32 / 22);
}

.size-shindan-block {
  display: flex;
  flex-direction: row;
  column-gap: 10px;
}

.size-shindan-block>.CMP-CM05-block {
  display: flex;
  flex-grow: 1;
  flex-direction: column;
}

.CMP-CM10-text:has(>.size-shindan-button) {
  margin-top: auto;
}

.size-shindan-image.uc-mod-media-01 {
  margin-bottom: 10px;
}

.size-shindan-image .uc-caption {
  display: grid;
  justify-content: center;
  margin: 5px 0 0 5.5px;
  font-size: calc(14 * var(--rem));
  font-weight: 400;
  line-height: calc(22 / 14);
  color: var(--contents-black-01);
  text-align: left;
  letter-spacing: normal;
}

.size-shindan-button a {
  display: block;
  width: 100%;
  max-width: 160px;
  padding: 8px 25px;
  margin-inline: auto;
  font-size: calc(14 * var(--rem));
  font-weight: 400;
  line-height: calc(25 / 14);
  color: var(--contents-white-01);
  text-align: center;
  letter-spacing: normal;
  background-color: var(--contents-blue-02);
  border-radius: 5px;
}

.size-shindan-button.blank-button_01 a::after {
  right: 11px;
  width: 10.5px;
  height: 11px;
}

.size-shindan-not-text {
  width: fit-content;
  padding: 5px 20px;
  margin-inline: auto;
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(26 / 16);
  color: var(--contents-white-01);
  text-align: center;
  letter-spacing: normal;
  background-color: var(--contents-blue-02);
}

.specialist-section {
  padding: 16px 6px 6px;
  background: #f5f5f5;
}

.specialist-heading {
  margin-bottom: 17px;
}

.specialist-heading>* {
  font-size: calc(19 * var(--rem));
  line-height: calc(30 / 19);
}

.specialist-block {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 15px 20px;
  align-items: center;
  padding: 20px;
  background-color: var(--contents-white-01);
}

.CMP-CM05-block:has(>.specialist-block_01) {
  grid-row: 1 / 2;
  grid-column: 1 / 2;
}

.CMP-CM05-block:has(>.specialist-block_02) {
  grid-row: 1 / 2;
  grid-column: 2 / 3;
}

.CMP-CM05-block:has(>.specialist-block_03) {
  grid-row: 2 / 3;
  grid-column: 1 / 3;
}

.specialist-image.uc-mod-media-01 {
  margin-bottom: 0;
}

.specialist-text_01 {
  font-size: calc(18 * var(--rem));
  font-weight: 700;
  line-height: calc(28 / 18);
  color: #060606;
  text-align: left;
  letter-spacing: normal;
}

.specialist-text_02 {
  font-size: calc(14 * var(--rem));
  font-weight: 400;
  line-height: calc(24 / 14);
  color: var(--contents-black-01);
  text-align: left;
  letter-spacing: normal;
}

.specialist-text_03 {
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(28 / 16);
  color: var(--contents-black-01);
  text-align: left;
  letter-spacing: normal;
}

/* PC */


@media screen and (min-width: 769px) {
  .primary>* {
    font-size: calc(32 * var(--rem));
    line-height: calc(32 / 32);
  }

  .secondary>* {
    font-size: calc(30 * var(--rem));
    line-height: calc(30 / 30);
  }

  .contents-block {
    padding-bottom: 53px;
  }

  .kv-image {
    margin-top: 17px;
  }

  /* .lead-text a {
    padding-block: 26px 25px;
  }

  .lead-text>*,
  .lead-text a {
    font-size: calc(20 * var(--rem));
    line-height: calc(25 / 20);
  }

  .lead-text a::after {
    right: 36px;
    bottom: 50%;
    transform: translate(50%, 50%);
  } */

  .content-heading {
    padding-bottom: 30px;
    background-size: 162px 4px;
  }

  .content-image {
    max-width: 208px;
  }

  .choice-wrap {
    width: 100%;
    padding: 30px 40px 36px;
    margin-inline: auto;
    border-radius: 10px;
  }

  .choice-wrap-custom_01 {
    padding: 40px 49px 38.5px 55px;
  }

  .card-block {
    flex-direction: row;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .card-block>* {
    max-width: 570px;
    height: 100%;
  }

  .card-block-custom_01 {
    grid-template-columns: unset;
    justify-content: center;
  }

  .card-block-custom_01>* {
    width: unset;
    max-width: 360px;
  }

  .card a {
    gap: 22px;
    width: 100%;
  }

  .CMP-CM11-image-and-text:has(.card-custom_01),
  .CMP-CM11-image-and-text:has(.card-custom_02) {
    display: flex;
  }

  .card.card-custom_01,
  .card.card-custom_02 {
    display: flex;
    flex-grow: 1;
    margin-inline: unset;
  }

  .card.card-custom_01 {
    max-width: 550px;
  }

  .card.card-custom_02 {
    max-width: 360px;
  }

  .card.card-custom_01 .uc-put-media,
  .card.card-custom_02 .uc-put-media {
    width: 100px;
  }

  .card.card-custom_01 a .uc-put-text {
    font-size: calc(16 * var(--rem));
    line-height: calc(30 / 16);
  }

  .card-text_01 {
    font-size: calc(20 * var(--rem));
    line-height: calc(30 / 20);
  }


  .card.card-custom_01 a::after,
  .card.card-custom_02 a::after {
    width: 18px;
    height: 18px;
  }

  .card.card-custom_01 a::after {
    right: 21px;
  }

  .card.card-custom_02 a::after {
    right: 15px;
  }

  .card.card-custom_01 a .uc-put-text p:has(.card-text_02),
  .card.card-custom_02 a .uc-put-text p:has(.card-text_01) {
    margin-bottom: 3px;
  }

  .card.card-custom_01 a .card-text_01,
  .card.card-custom_01 a .card-text_02 {
    max-width: 360px;
  }

  .card.card-custom_01 a {
    padding-right: 40px;
  }

  .card.card-custom_02 a {
    gap: 15px;
    padding-right: 33px;
  }

  .card.card-custom_02 a .card-text_01,
  .card.card-custom_02 a .card-text_02 {
    max-width: 180px;
  }

  .card.card-custom_02 a .uc-put-text {
    font-size: calc(16 * var(--rem));
    line-height: calc(24 / 16);
  }

  .card.card-custom_02 a .card-text_01 {
    margin-bottom: 11px;
    font-size: calc(22 * var(--rem));
    line-height: calc(22 / 22);
  }

  .card.card-custom_02 .uc-put-object {
    width: 100px;
  }

  .select-wrap {
    grid-template-columns: repeat(2, 1fr);
    align-items: unset;
  }

  .CMP-CM05-block:has(>.card-voice-block) {
    justify-content: center;
  }

  .CMP-CM05-block:has(>.card-voice-block),
  .card-voice-block,
  .card-voice-block .CMP-CM43-text-mulit-link:has(.card-voice-text),
  .card-voice-block .card-voice-text,
  .card-voice-block .CMP-CM43-text-mulit-link .uc-mod-mulit-link,
  .card-voice-block .CMP-CM43-text-mulit-link .uc-mod-mulit-link a {
    display: flex;
  }

  .card-voice-block {
    align-items: stretch;
  }

  .card-voice-block .CMP-CM43-text-mulit-link .uc-mod-mulit-link a {
    flex-direction: column;
  }

  .card-voice-text {
    width: fit-content;
    max-width: unset;
  }

  .card-voice-text a {
    width: 100%;
    max-width: 400px;
    font-size: calc(17 * var(--rem));
    line-height: calc(24 / 17);
  }

  .card-voice-text a br {
    display: none;
  }

  .card-voice-image {
    width: 100px;
  }

  .CMP-CM11-image-and-text:has(>.card-voice-image) {
    margin-block: auto;
  }

  .annotation-block_01 {
    padding-top: 30px;
  }

  /* 下層ページ */

  .contents-sub-block {
    padding-bottom: 115px;
  }

  .contents-sub-wrap {
    margin-top: 30px;
  }

  .primary-sub>* {
    font-size: calc(30 * var(--rem));
    line-height: calc(40 / 30);
  }

  .intro-wrap {
    padding-bottom: 49px;
  }

  .intro-heading-block {
    display: flex;
    justify-content: center;
  }

  .type-shindan-intro .intro-heading-block {
    column-gap: 30.5px;
    margin-bottom: 18px;
    margin-left: 137px;
  }

  .size-shindan-intro {
    padding-top: 19px;
  }

  .size-shindan-intro .intro-heading-block {
    column-gap: 47px;
    margin-bottom: 9px;
    margin-left: 134px;
  }

  .pants-shindan-intro .intro-heading-block {
    column-gap: 26px;
    margin-bottom: 15px;
    margin-left: 100px;
  }

  .charm-san-intro .intro-heading-block {
    column-gap: 28px;
    margin-bottom: 16px;
    margin-left: 168px;
  }

  .intro-heading>* {
    line-height: calc(40 / 30);
  }

  .type-shindan-intro .intro-image {
    max-width: 105px;
    margin-block: 10px 0;
    transform: unset;
  }

  .pants-shindan-intro .intro-image {
    max-width: 75px;
    margin-block: 7px 0;
    transform: unset;
  }

  .charm-san-intro .intro-image {
    max-width: 140px;
    margin-block: 12px 0;
    transform: unset;
  }

  .image-wrap {
    flex-direction: row;
    justify-content: space-around;
    max-width: 1080px;
    margin-inline: auto;
  }

  .image-wrap>.CMP-CM05-block {
    padding-bottom: 53px;
    background-color: var(--contents-white-01);
    border-radius: 15px;
  }

  .image-wrap-2col {
    column-gap: 80px;
  }

  .image-wrap-3col {
    column-gap: 60px;
  }

  .image-wrap.image-wrap-2col,
  .image-wrap.image-wrap-3col {
    display: grid;
    grid-template-rows: auto auto auto;
  }

  .image-wrap.image-wrap-2col {
    display: grid;
    grid-template-rows: auto auto auto;
    grid-template-columns: repeat(2, 1fr);
  }


  .image-wrap.image-wrap-3col {
    grid-template-columns: repeat(3, 1fr);
  }

  .image-wrap.image-wrap-2col>.CMP-CM05-block {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: 1 / span 3;
  }

  .CMP-CM05-block>.image-block {
    display: contents;
  }

  .CMP-CM05-block:has(>.image-block-next) {
    padding-bottom: 0;
  }

  .CMP-CM05-block:has(>.image-block-next)::before {
    right: -40px;
    bottom: 50%;
    left: auto;
    transform: translate(50%, 50%);
    rotate: unset;
  }

  .image-wrap-3col .CMP-CM05-block:has(>.image-block-next)::before {
    right: -30px;
  }

  .image-text {
    padding-block: 19px;
  }

  .image-sub-text {
    margin-block: 29px 34px;
  }

  .image-capture img {
    max-width: 240px;
  }

  .heading-decoration_01>* span:nth-child(2) {
    font-size: calc(30 * var(--rem));
    line-height: calc(30 / 30);
  }

  .user-voice-section {
    width: 100%;
    max-width: 1033px;
    margin-inline: auto;
  }

  .user-voice-block {
    display: flex;
    flex-direction: row;
    column-gap: 13px;
    align-items: center;
  }

  .user-voice-image .uc-object img {
    width: 120px;
    max-width: unset;
  }

  .CMP-CM10-text:has(>.user-voice-text) {
    width: 100%;
    max-width: 900px;
  }

  .user-voice-text {
    padding: 30px 50px;
  }

  .useful-content-section {
    padding: 40px 40px 38px;
  }

  /* .useful-content-intro-block {
    display: flex;
    flex-direction: row;
    column-gap: 81px;
    justify-content: center;
    margin-left: 227px;
  }

  .useful-content-image {
    margin-top: -45px;
  } */

  .useful-content-image img {
    max-width: 149px;
  }

  .specialist-section {
    padding: 19px 8px 8px;
  }

  .specialist-heading>* {
    font-size: calc(22 * var(--rem));
    line-height: calc(28 / 22);
  }

  .specialist-block {
    grid-template-columns: 100px 1fr;
    padding: 30px 40px;
  }

  .CMP-CM05-block:has(>.specialist-block_01) {
    grid-row: 1 / 3;
    grid-column: 1 / 2;
  }

  .CMP-CM05-block:has(>.specialist-block_02) {
    grid-row: 1 / 2;
    grid-column: 2 / 3;
  }

  .CMP-CM05-block:has(>.specialist-block_03) {
    grid-row: 2 / 3;
    grid-column: 2 / 3;
  }

  .specialist-block_02 {
    display: flex;
    flex-direction: row;
    column-gap: 15px;
    align-items: flex-end;
  }

}

/* PC以上（タブレット除く） */
@media screen and (min-width: 1100px) {
  .content-block {
    display: flex;
    column-gap: 25px;
    justify-content: center;
    margin-left: 275px;
  }

  .CMP-CM11-image-and-text:has(.content-image) {
    margin-top: -37px;
  }

  .useful-content-intro-block {
    display: flex;
    flex-direction: row;
    column-gap: 81px;
    justify-content: center;
    margin-left: 227px;
  }

  .useful-content-image {
    margin-top: -45px;
  }

  .card-block-custom_01 {
    grid-template-columns: repeat(3, 1fr);
    justify-content: start;
  }

}



/* 汎用 */

.text-decoration_01[class] {
  font-weight: 700;
  color: var(--contents-red-01);
}

.text-decoration_mb-10 {
  display: inline-block;
  margin-bottom: 10px;
}

.break-text b::after {
  white-space: pre;
  content: "\A";
}

._contents-black-01,
._contents-black-01>*,
._contents-black-01[class] {
  color: var(--contents-black-01);
}

._contents-black-02,
._contents-black-02>*,
._contents-black-02[class] {
  color: var(--contents-black-02);
}

._contents-blue-01,
._contents-blue-01>*,
._contents-blue-01[class] {
  color: var(--contents-blue-01);
}

._contents-blue-02,
._contents-blue-02>*,
._contents-blue-02[class] {
  color: var(--contents-blue-02);
}

._contents-red-01,
._contents-red-01>*,
._contents-red-01[class] {
  color: var(--contents-red-01);
}

._contents-skyblue-01,
._contents-skyblue-01>*,
._contents-skyblue-01[class] {
  color: var(--contents-skyblue-01);
}

._contents-white-01,
._contents-white-01>*,
._contents-white-01[class] {
  color: var(--contents-white-01);
}

._mb-07 {
  margin-bottom: 7px;
}

._mb-16 {
  margin-bottom: 16px;
}

._text-center,
._text-center>* {
  text-align: center;
}

._text-left,
._text-left>* {
  text-align: left;
}

._text-right,
._text-right>* {
  text-align: right;
}

._element-none {
  display: none;
}

@media screen and (min-width: 769px) {
  ._mt-45-pc {
    margin-top: 45px;
  }

  ._mb-07-pc {
    margin-bottom: 7px;
  }

  ._mb-14-pc {
    margin-bottom: 14px;
  }

  ._mb-20-pc {
    margin-bottom: 20px;
  }

  ._mb-25-pc {
    margin-bottom: 25px;
  }

  ._mb-30-pc {
    margin-bottom: 30px;
  }

  ._mb-37-pc {
    margin-bottom: 37px;
  }

  ._mb-45-pc {
    margin-bottom: 45px;
  }

  ._mb-60-pc {
    margin-bottom: 60px;
  }

  ._mb-75-pc {
    margin-bottom: 75px;
  }

  ._text-center-pc,
  ._text-center-pc>* {
    text-align: center;
  }

  ._text-left-pc,
  ._text-left-pc>* {
    text-align: left;
  }

  ._text-right-pc,
  ._text-right-pc>* {
    text-align: right;
  }

  .break-text b::after {
    content: "";
  }

  ._element-none-pc {
    display: none;
  }

}

@media screen and (max-width: 768px) {
  ._mb-07-sp {
    margin-bottom: 7px;
  }

  ._mb-08-sp {
    margin-bottom: 8px;
  }

  ._mb-10-sp {
    margin-bottom: 10px;
  }

  ._mb-16-sp {
    margin-bottom: 16px;
  }

  ._mb-18-sp {
    margin-bottom: 18px;
  }

  ._mb-20-sp {
    margin-bottom: 20px;
  }

  ._mb-22-sp {
    margin-bottom: 22px;
  }

  ._mb-30-sp {
    margin-bottom: 30px;
  }

  ._text-center-sp,
  ._text-center-sp>* {
    text-align: center;
  }

  ._text-left-sp,
  ._text-left-sp>* {
    text-align: left;
  }

  ._text-right-sp,
  ._text-right-sp>* {
    text-align: right;
  }

  ._element-none-sp {
    display: none;
  }
}

/* ブロックスキップ */

.accessibility-jump-main a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 0;
  font-size: 0;
  color: #1E2766;
  text-align: center;
  text-decoration: underline;
  background: none;
  transition:
    height 0.35s ease-in-out,
    background 0.35s linear 0.35s,
    font-size 0.35s linear 0.35s;
  transition:
    height 0.35s ease-in-out,
    background 0.35s linear 0.35s,
    font-size 0.35s linear 0.35s,
    z-index linear 0.35s;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -ms-flex-align: center;
}

.accessibility-jump-main a:focus {
  z-index: 100;
  height: 50px;
  font-size: calc(16 * var(--rem));
  font-weight: 400;
  line-height: calc(26 / 16);
  color: #1E2766;
  text-align: center;
  letter-spacing: normal;
  outline: none;
  background-color: #F0F7FF;
  transition: height 0.35s ease-in-out;
}

.accessibility-jump-main a span {
  align-content: baseline;

  /* margin-bottom: 10px; */
  line-height: 1;
}

.accessibility-jump-main.is-hidden a {
  height: 0;
  font-size: 0;
  background: none;
}