@charset "utf-8";

:root {
  --color-main: #333333;
  --color-gray: #eaeaef;
  --color-green: #00a8a9;
  --color-yellow: #e3c814;
  --color-orange: #ff9900;
  --color-blue: #3399cc;
  --color-pink: #ed7d7d;
  --font-sans: "Noto Sans JP", sans-serif;
  --font-zen: "Zen Kaku Gothic New", serif;
}


/* ----- common ----- */

#Voice_Content .Question_section {
  margin-top: clamp(20px, 8vw, 100px);
  /* padding: 55px 80px 55px 55px;
  background: #FFF;
  border-radius: 40px 0 0 40px;
  position: relative; */
  
}

/* @media only screen and (min-width: 560px) and (max-width: 959px) {
  #Voice_Content .Question_section {
    margin-top: 40px;
    padding: 35px;
    border-radius: 40px 0 0 40px;
  }
}

@media only screen and (max-width: 559px) {
  #Voice_Content .Question_section {
    margin-top: 40px;
    padding: 30px 20px 30px 20px;
    border-radius: 30px 0 0 30px;
  }
} */

div.container {
  max-width: 1240px;
  margin: 0 auto;
  /* padding: min(6rem, 60px) 20px; */
  padding: 0 20px;
  position: relative;
  
}

section.right div.container {
  padding-right: 0;
  
}

section.left div.container {
  padding-left: 0;
}

section.right div.container_s {
  width: 100%;
  padding: clamp(20px, 6vw, 60px) clamp(20px, 6vw, 60px);
  background-color: #fff;
  border-radius: min(2.4rem, 24px) 0 0 min(2.4rem, 24px);
  position: relative;
}

section.right div.container_s::after {
  content: "";
  display: block;
  position: absolute;
  width: calc((100vw - 1260px) / 2);
  height: 100%;
  background-color: #fff;
  top: 0;
  right: 0;
  transform: translateX(100%);
}

section.left div.container_s {
  width: 100%;
  padding: clamp(20px, 6vw, 60px) clamp(20px, 6vw, 60px);
  background-color: #fff;
  border-radius: 0 min(2.4rem, 24px) min(2.4rem, 24px) 0;
  position: relative;
}

section.left div.container_s::after {
  content: "";
  display: block;
  position: absolute;
  width: calc((100vw - 1240px) / 2);
  height: 100%;
  background-color: #fff;
  top: 0;
  right: auto;
  left: 0;
  transform: translateX(-100%);
  overflow: hidden;
}



.Question_section .Section_heading{
  margin-bottom: clamp(40px, 8.3vw, 80px);
}

.Question_section .Section_heading h2 {
  width: fit-content;
  margin: 0 auto;
  font-size: clamp(18px, 2.5vw, 24px);
  line-height: 1.5;
  font-weight: 900;
  /* padding: 0 min(8rem, 80px); */
  position: relative;
  text-align: center;
  color: #666
}
@media only screen and (max-width: 559px) {
.Question_section .Section_heading h2 {
    width: 100%;
  }
}

.Question_section .Section_heading h2 small {
  display: block;
  font-size: clamp(10px, 1.25vw, 12px);
  color: var(--color-green);
}

.Question_section .Section_heading h2 strong {
  display: block;
  font-size: clamp(40px, 6.25vw, 60px);
  line-height: 1;
  color: var(--color-green);
  margin-bottom:0.2em;
  font-family: var(--font-zen);
}
.Question_section .Section_heading h2 span {
  font-size: clamp(10px, 1.25vw, 12px);
  font-weight: 500;
}

.Question_section .Section_heading h2::before,
.Question_section .Section_heading h2::after {
  content: "";
    /* display: inline-block; */
    position: absolute;
    left: 0;
    width: 2px;
    height: 115%;
    background-color: var(--kblue);
    transform: rotate(30deg);
    transform-origin: 0% 0%;
}

.Question_section .Section_heading h2::after {
    /* display: inline-block; */
    position: absolute;
    left: auto;
    right: -90px;
    top:0;
    /* transform-origin: 100% 0%; */
}
/* @media only screen and (min-width: 560px) and (max-width: 959px) {
  .Question_section .Section_heading h2::after {
      right: -80px;
    }
} */
@media only screen and (max-width: 559px) {
.Question_section .Section_heading h2::before,
  .Question_section .Section_heading h2::after {
    content: "";
    /* display: inline-block; */
    position: absolute;
    left: 0;
    bottom: -1em;
    width: 2px;
    height: 115%;
    background-color: var(--kblue);
    transform: rotate(30deg);
    transform-origin: 0% 100%;
  }

  .Question_section .Section_heading h2::after {
    /* display: inline-block; */
    position: absolute;
    left: auto;
    right: 0;
    top: 1em;
    transform-origin: 100% 0%;
  }
}

/* p.common_txt {
  font-size: min(1.6rem, 16px);
  line-height: 2;
} */

.no_mt {
  margin-top: 0 !important;
}

.target {
  transform: translateY(80px);
  opacity: 0;
  transition: all .8s;
}

.target.appear {
  transform: none;
  opacity: 1;
}

@media (max-width: 799px) {
  p.common_txt {
    font-size: 1.4rem;
    line-height: 1.8;
  }
}

/* ----- main ----- */

/* main {
  padding-top: min(7.5rem, 75px);
  overflow: hidden;
  background-color: var(--color-gray);
} */

/* @media (max-width: 799px) {
  main {
  }
} */

/* ----- mv ----- */

#Voice_Content {
  width:100%;
  padding-top:0;
  padding-bottom: clamp(100 * 0.5px, 100 / 960 * 100vw, 100px);
}

#Voice_Content .Mv {
  position: relative;
  width: 100%;
  height: 580px;
  /* height: 46vw; */
  margin-top: 3em;
  background-color: #e4e5e7;
  /* background-image: url(../images/img_mv.png);
  background-size: contain;
  background-position: right bottom;
  background-repeat: no-repeat; */
  /* clip-path: polygon(100% 0, 100% 99%, 0 100%, 0 25%); */
}
@media only screen and (min-width: 560px) and (max-width: 959px) {
  #Voice_Content .Mv {
      height: 60vw;
      height: 60vw;
    }
}
@media only screen and (max-width: 559px) {
  #Voice_Content .Mv {
    height: 75vw;
  }
}
#Voice_Content .Mv .inner{
  position: relative;
  width: 100%;
  height: 100%;
  padding-top: clamp(20px, 5.2vw, 30px);
  padding-top: 0;
  background-image: url(../images/img_mv.png);
  background-size: cover;
  background-size: 1610px 580px;
  background-position: center bottom;
  background-repeat: no-repeat;
  z-index: 1;
}
@media only screen and (min-width: 560px) and (max-width: 959px) {
  #Voice_Content .Mv .inner {
      padding-top:0;
      background-size: cover;
      background-repeat: no-repeat;
      z-index: 1;
    }
}
@media only screen and (max-width: 559px) {
    #Voice_Content .Mv .inner {
        padding-top: 0;
        background-size: cover;
        background-repeat: no-repeat;
        z-index: 1;
        margin-top:6vw;
        padding-top: 0;
      }
}

#Voice_Content .Mv::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 40%;
  height: 100%;
  background: #c9e581;
  clip-path: polygon(0 0, 100% 0, 50% 100%, 0% 100%);
  z-index: 1;
}
#Voice_Content .Mv .inner::after {
  content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 18vw;
    background: #eaeaef;
    clip-path: polygon(0 0, 0 100%, 100% 0);
    z-index: 2;
}
@media only screen and (max-width: 559px) {
#Voice_Content .Mv .inner::after {
    height: 32vw;
    z-index: 2;
}
}

#Voice_Content .Mv h2.mv_h2 {
  font-size: clamp(30px, 5.2vw, 50px);
  font-weight: 700;
  line-height: 1;
  position: relative;
  z-index: 10;
}

#Voice_Content .Mv h2.mv_h2 span {
  display: block;
  margin-top: 0.8em;
  font-size: clamp(16px, 2.5vw, 24px);
  font-weight: 700;
}




/* ----- question ----- */

#Voice_Content div.voice_wrap {
  margin-top: min(8rem, 80px);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: start;
  gap: min(4rem, 40px);
}
@media only screen and (max-width: 959px) {
  #Voice_Content div.voice_wrap {
      margin-top: 5em;
      display: block;
    }
}
@media only screen and (max-width: 959px) {
  #Voice_Content div.voice_wrap .right {
    margin-top: 2em;
  }
}

#Voice_Content .Mv {
  position: relative;
}

#Voice_Content ol.voice_list {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2.5vw, 24px);
}

#Voice_Content ol.voice_list li {
  display: flex;
  align-items: center;
  gap: min(1rem, 10px);
  font-size: clamp(18px, 4.285vw, 24px);
  line-height: 1.4;
  font-weight: 900;
}

#Voice_Content ol.voice_list li::before {
  content: "";
  display: block;
  width: min(5rem, 50px);
  height: min(5.5rem, 55px);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
#Voice_Content ol.voice_list li span{
  width: calc(100% - 55px);
}

#Voice_Content ol.voice_list li.first {
  font-size: clamp(24px, 5.3vw, 30px);
  font-weight: 900;
  color: var(--color-orange);
}

#Voice_Content ol.voice_list li.first:before {
  background-image: url(../images/icon_01_orange.png);
}

#Voice_Content ol.voice_list li.small {
  font-size: clamp(16px, 3.2vw, 18px);
  font-weight: 400;
  line-height: 1.2;
}

#Voice_Content ol.voice_list li.fourth.small:before {
  background-image: url(../images/icon_04_green_small.png);
  height: 20px;
}

#Voice_Content ol.voice_list li.fifth.small:before {
  background-image: url(../images/icon_05_green_small.png);
  height: 20px;
}

#Voice_Content ol.voice_list li.sixth.small:before {
  background-image: url(../images/icon_06_green_small.png);
  height: 20px;
}

#Voice_Content ol.voice_list li.seventh.small:before {
  background-image: url(../images/icon_07_green_small.png);
  height: 20px;
}

#Voice_Content ol.voice_list li.yellow {
  color: var(--color-yellow);
}

#Voice_Content ol.voice_list li.yellow:before {
  background-image: url(../images/icon_02_yellow.png);
}

#Voice_Content ol.voice_list li.pink {
  color: var(--color-pink);
}

#Voice_Content ol.voice_list li.pink:before {
  background-image: url(../images/icon_03_pink.png);
}

#Voice_Content ol.voice_list li.second.green::before {
  background-image: url(../images/icon_02_green.png);
}

#Voice_Content ol.voice_list li.third.green::before {
  background-image: url(../images/icon_03_green.png);
}

#Voice_Content ol.voice_list li.fourth.green::before {
  background-image: url(../images/icon_04_green.png);
}

#Voice_Content ol.voice_list li.fifth.green::before {
  background-image: url(../images/icon_05_green.png);
}

#Voice_Content div.comment_wrap {
  /* margin-top: clamp(40px, 8.3vw, 80px); */
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: start;
  gap: min(1.6rem, 16px);
}

#Voice_Content div.comment_wrap.column03 {
  grid-template-columns: repeat(3, 1fr);
}
@media only screen and (max-width: 559px) {
  #Voice_Content div.comment_wrap.column03 {
      grid-template-columns: repeat(2, 2fr);
    }
}

#Voice_Content div.comment_wrap.column04 {
  grid-template-columns: repeat(4, 1fr);
}
@media only screen and (max-width: 959px) {
  #Voice_Content div.comment_wrap.column04 {
    grid-template-columns: repeat(2, 2fr);
  }
}

#Voice_Content div.comment_wrap.column05 {
  grid-template-columns: repeat(5, 1fr);
}
@media only screen and (max-width: 959px) {
#Voice_Content div.comment_wrap.column05 {
    grid-template-columns: repeat(2, 2fr);
  }
}

#Voice_Content div.comment_wrap div.comment_item {
  display: flex;
  flex-direction: column;
  gap: min(.8rem, 8px);
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text {
  padding: clamp(10px, 2vw, 20px);
  border-radius: min(1rem, 10px);
  border: 1px solid var(--color-orange);
  background-color: #fff;
  font-size: clamp(10px, 1.25vw, 12px);
  color: #666666;
  line-height: 1.5;
}

#Voice_Content div.comment_wrap.blue div.comment_item p.comment_text {
  border-color: var(--color-blue);
}

#Voice_Content div.comment_wrap.green div.comment_item p.comment_text {
  border-color: var(--color-green);
}

#Voice_Content div.comment_wrap.gray div.comment_item p.comment_text {
  border-color: #666666;
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text .orange {
  color: var(--color-orange);
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text .blue {
  color: var(--color-blue);
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text .green {
  color: var(--color-green);
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text strong {
  display: inline;
  font-size: clamp(20px, 5.3vw, 30px);
  font-weight: 700;
  line-height: 1.3;
}
#Voice_Content .question06 div.comment_wrap div.comment_item p.comment_text strong {
  display: inline;
  font-size: clamp(16px, 3.2vw, 18px);
  font-weight: 700;
  line-height: 1.3;
}
#Voice_Content div.comment_wrap div.comment_item p.comment_text strong.text_smaller{
  display: inline;
  font-weight: 700;
  font-size: clamp(18px, 5vw, 26px);
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text strong.text_larger {
  display: inline;
  font-weight: 700;
  font-size: clamp(18px, 6vw, 36px);
}

#Voice_Content div.comment_wrap div.comment_item p.comment_text span {
  display: inline;
  font-weight: 500;
  font-size: clamp(16px, 3.2vw, 18px);
}

#Voice_Content p.comment_note {
  margin-top: clamp(40px, 8.3vw, 80px);
  font-size: min(1.3rem, 13px);
  color: #666666;
  line-height: 2.0;
}


#Voice_Content p.comment_note span {
  display: block;
  width: min(25rem, 250px);
  height: min(3rem, 30px);
  border-radius: 99px;
  font-size: clamp(16px, 3.2vw, 18px);
  font-weight: 500;
  background-color: var(--color-orange);
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 min(1rem, 10px);
  margin-bottom: min(2rem, 20px);
}

#Voice_Content p.comment_note span::after {
  content: "";
  width: min(.8rem, 8px);
  height: min(.8rem, 8px);
  background-image: url(../images/icon_arrow_down_white.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

/* ----- question01 ----- */

#Voice_Content .question01 div.voice_wrap div.img_area {
  margin-right: min(8rem, 80px);
}
@media only screen and (min-width: 560px) and (max-width: 959px) {
  #Voice_Content .question01 div.voice_wrap div.img_area {
    max-width:450px;
    margin: 0 auto 4em auto;
    }
}

@media only screen and (max-width: 559px) {
  #Voice_Content .question01 div.voice_wrap div.img_area {
      margin: 0 auto 4em auto;
    }
}

/* ----- question02 ----- */

#Voice_Content div.Q2_illust {
  position: absolute;
  top: 370px;
  bottom: 0;
  right: 20px;
  margin: 0 auto;
  /* transform: translate(100%, 40%); */
  /* width: min(40rem, 400px); */
  width: clamp(22px, 30vw, 380px);
  height: fit-content;
}
@media only screen and (max-width: 559px) {
  #Voice_Content div.Q2_illust {
      position: relative;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      margin: 0 auto;
      margin-top: 2em;
      transform: translate(0%, 0%);
      /* width: min(40rem, 400px); */
      width: 90%;
      height: fit-content;
    }
}

/* ----- question03 ----- */

#Voice_Content .question03 ol.voice_list {
  /* margin: min(8rem, 80px) auto 0; */
  /* margin-top: clamp(40px, 8.3vw, 80px); */
  width: fit-content;
}

#Voice_Content .question03 h3.Q3_h3 {
  /* font-size: clamp(10px, 1.25vw, 12px); */
  color: #666666;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(2rem, 20px);
  /* padding-bottom: 16px; */
  position: relative;
  margin-bottom:2em;
}

#Voice_Content .question03 h3.Q3_h3::before {
  content: "";
  background-image: url(../images/illust_Q3_01.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: clamp(50px, 18vw, 100px);
  height:clamp(50px, 18vw, 100px);
}

#Voice_Content .question03 h3.Q3_h3.blue::before {
  background-image: url(../images/illust_Q3_02.png);
}

#Voice_Content .question03 h3.Q3_h3::after {
  content: "";
  display: block;
  position: absolute;
  background-image: url(../images/img_Q3_underline_orange.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  bottom: -15px;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: min(2.4rem, 24px);
}

#Voice_Content .question03 h3.Q3_h3.blue::after {
  background-image: url(../images/img_Q3_underline_blue.png);
}

#Voice_Content .question03 h3.Q3_h3 strong {
  font-size: clamp(24px, 5.3vw, 30px);
  font-weight: 700;
  color: var(--color-orange);
}

#Voice_Content .question03 h3.Q3_h3 strong.blue {
  color: var(--color-blue);
}

#Voice_Content .question03 div.comment_wrap {
  margin-top: min(2rem, 20px);
}

/* ----- question04 ----- */

#Voice_Content .question04 h3.Q4_h3 {
  width: fit-content;
  margin: 0 auto;
  padding: 0 min(1rem, 10px);
  font-size: clamp(16px, 3.57vw, 20px);
  font-weight: 600;
  line-height: 1.5;
  padding-bottom: min(1rem, 10px);
  border-bottom: min(.2rem, 2px) solid var(--color-main);
}
#Voice_Content .question04 h3.Q4_h3 small{
  font-size: clamp(10px, 1.25vw, 12px);
}

#Voice_Content .question04 ol.voice_list {
  margin-top: min(4rem, 40px);
}

#Voice_Content .question04 div.comment_wrap {
  margin-top: clamp(40px, 8.3vw, 80px);
  width: 50%;
  margin-left: auto;
}
@media only screen and (max-width: 959px) {
  #Voice_Content .question04 div.comment_wrap {
    width: 100%;
    margin-left: auto;
    padding-bottom:22vw;
  }
}

#Voice_Content .question04 div.Q4_illust {
  position: absolute;
  bottom: 0;
  left: 0;
  width: min(55rem, 550px);
}
@media only screen and (max-width: 959px) {
  #Voice_Content .question04 div.Q4_illust {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 80%;
  }
}

/* ----- question06 ----- */
#Voice_Content .question06 ol.voice_list {
  width: fit-content;
}
#Voice_Content .question06 .comment_wrap {
  margin-top: clamp(40px, 8.3vw, 80px);
}

/* ----- question07 ----- */
#Voice_Content .question07 .comment_wrap {
  margin-top: clamp(40px, 8.3vw, 80px);
}
#Voice_Content .question07 div.Q7_illust {
  position: absolute;
  width: clamp(200px, 40vw, 500px);
  top: 0;
  right: 0;
  transform: translateY(130%);
}
@media only screen and (max-width: 959px) {
#Voice_Content .question07 div.Q7_illust {
    position: relative;
    width: 80%;
    top: auto;
    right: 0;
    bottom: 0;
    margin: 2em 0 0 auto;
    transform: none;
  }
}

/* ----- question09 ----- */

#Voice_Content .question09 ul.Q9_ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(13px, 3.3vw, 16px) clamp(20px, 3.3vw, 32px);
}
@media only screen and (max-width: 559px) {
  #Voice_Content .question09 ul.Q9_ul {
    grid-template-columns: repeat(1, 1fr);
  }
}

#Voice_Content .question09 ul.Q9_ul li.Q9_li {
  width: 100%;
  height: 75px;
  padding: 0 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(16px, 2.29vw, 22px);
  line-height: 1.3;
  text-align: center;
  font-weight: 600;

  background-color: #fff5e5;
  background-image: url(../images/bg_Q9.png);
  background-repeat: no-repeat;
  background-size: 800px 26px;
  background-position: right bottom;
  border: 1px solid #666;
  border-bottom: none;
}
@media only screen and (max-width: 559px) {
  #Voice_Content .question09 ul.Q9_ul li.Q9_li {
    height: 50px;
  }
}
#Voice_Content .question09 ul.Q9_ul li.Q9_li strong {
  color: var(--color-orange);
  font-weight: 600;
}

#Voice_Content .question09 div.img_area {
  margin: min(4rem, 40px) auto 0;
  width: 60%;
}
@media only screen and (min-width: 560px) and (max-width: 959px) {
  #Voice_Content .question09 div.img_area {
      width: 80%;
      padding-bottom:5em;
    }
}
@media only screen and (max-width: 559px) {
  #Voice_Content .question09 div.img_area {
      width: 100%;
      padding-bottom: 3em;
    }
}

#Voice_Content .question09 div.Q9_illust {
  position: absolute;
  width: 80%;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}


.other_wrap {
  margin-top: 2.5em;
}
.other_toggle {
  display: none;
}

.other_item {
  width: 100%;
  position: relative;
  border-bottom: 1px solid #676767;
}

.other_title,
.other_content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}

.other_title {
  width: auto;
  padding: 3px 60px;
  font-size: 15px;
  list-style: 1;
  display: inline-block;
  color: #FFF;
  font-weight: bold;
  background: var(--color-orange);
  border-radius: 999px;
}


.other_title::after,
.other_title::before {
  content: "";
  position: absolute;
  left: 20px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 2px;
  height: 18px;
  background-color: #FFF;
  transition: all 0.3s;
}

/* @media only screen and (max-width: 559px) {

  .other_title::after,
  .other_title::before {
    left: 4.26vw;
    top: 30%;
    top: 4.26vw;
    width: 2px;
    height: 8.53vw;
  }
} */

.other_title::after {
  transform: rotate(90deg);
}

.other_content {
  max-height: 0;
  overflow: hidden;
}

.other_content p {
  margin: 1em 0 0 0;
  padding: 0;
  font-size: 0.9em;
  line-height: 1.7;
}

/* @media only screen and (min-width: 560px) and (max-width: 959px) {
  .other_content p {
    padding-right: 32px;
  }
} */

/* @media only screen and (max-width: 559px) {
  .other_content p {
    padding: 0 0 4.26vw 15vw;
    font-size: 4.26vw;
    line-height: 8.53vw;
  }
} */

.other_toggle:checked+.other_title+.other_content {
  max-height: 500px;
  transition: all 1.5s;
}

.other_toggle:checked+.other_title::before {
  transform: rotate(90deg) !important;
}