@charset "UTF-8";
/* ==========================================================
  フォント
========================================================== */
/* ===================================================================
CSS information
 file name  :top.css
 style info :トップのスタイル
=================================================================== */
body {
  position: relative;
}
body:before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-repeat: no-repeat;
  background-position: center top;
}
@media screen and (min-width: 751px) {
  body:before {
    background-image: url("../img/shared/bg_contents_pc.jpg");
  }
}
@media screen and (min-width: 1921px) {
  body:before {
    background-size: cover;
  }
}
@media screen and (max-width: 767px) {
  body:before {
    background-image: url("../img/shared/bg_contents_sp.png");
  }
}

#visual {
  position: relative;
  background-repeat: no-repeat;
}
@media screen and (min-width: 751px) {
  #visual {
    background-image: url("../img/shared/bg_illustration_pc.png");
    background-position: left calc(50% + 30px) top 160px;
    padding: 180px 0 80px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1020px) {
  #visual {
    background-position: left calc(50% + 2vw) top 17vw;
    background-size: 104vw;
    padding: 18vw 0 8vw;
  }
}
@media screen and (min-width: 1921px) {
  #visual {
    background-position: left calc(50% + 2vw) top 7vw;
    background-size: 62vw;
    padding: 8vw 0 4vw;
  }
}
@media screen and (max-width: 767px) {
  #visual {
    background-image: url("../img/shared/bg_illustration_sp.png");
    background-position: center top 4vw;
    background-size: 86vw;
    padding: 8vw 0 10vw;
  }
}
@media screen and (min-width: 751px) {
  #visual .logo {
    position: absolute;
    top: 30px;
    left: calc(50% - 460px);
    width: 300px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1020px) {
  #visual .logo {
    left: calc(50% - 50vw);
    width: 30vw;
  }
}
@media screen and (min-width: 1921px) {
  #visual .logo {
    top: 2vw;
    left: calc(50% - 26vw);
    width: 15vw;
  }
}
@media screen and (max-width: 767px) {
  #visual .logo {
    width: 50%;
    margin: 0 auto 4vw;
  }
}
@media screen and (min-width: 751px) {
  #visual .main {
    width: min(90%, 840px);
    margin: 0 auto 20px;
  }
}
@media screen and (min-width: 1921px) {
  #visual .main {
    width: 50%;
    margin: 0 auto 1vw;
  }
}
@media screen and (max-width: 767px) {
  #visual .main {
    width: 90%;
    margin: 0 auto 4vw;
  }
}
@media screen and (min-width: 751px) {
  #visual .date {
    width: 503px;
    margin: 0 auto 20px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1020px) {
  #visual .date {
    width: 50%;
    margin: 0 auto 1vw;
  }
}
@media screen and (min-width: 1921px) {
  #visual .date {
    width: 28%;
    margin: 0 auto 1vw;
  }
}
@media screen and (max-width: 767px) {
  #visual .date {
    width: 78%;
    margin: 0 auto 4vw;
  }
}
@media screen and (min-width: 751px) {
  :lang(en) #visual .date {
    width: 623px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1020px) {
  :lang(en) #visual .date {
    width: 62%;
  }
}
@media screen and (min-width: 1921px) {
  :lang(en) #visual .date {
    width: 34%;
  }
}
@media screen and (max-width: 767px) {
  :lang(en) #visual .date {
    width: 92%;
  }
}
@media screen and (min-width: 751px) {
  #visual .read {
    margin: 0 20px;
  }
}
@media screen and (min-width: 1921px) {
  #visual .read {
    margin: 0 2vw;
  }
}
@media screen and (max-width: 767px) {
  #visual .read {
    margin: 0 2vw;
  }
}
#visual .read p {
  color: #fff;
  text-shadow: 0 0 0.5em #000eb5;
  margin-bottom: 0.6em;
}
@media screen and (min-width: 751px) {
  #visual .read p {
    font-size: 20px;
  }
}
@media screen and (min-width: 1921px) {
  #visual .read p {
    font-size: 1.4vw;
  }
}
@media screen and (max-width: 767px) {
  #visual .read p {
    font-size: 4vw;
  }
}
#visual .read .anoTxt {
  margin-bottom: 2.5em;
}
#visual .read .anoTxt li {
  color: #fff;
  text-shadow: 0 0 0.5em #000eb5;
}
@media screen and (min-width: 751px) {
  #visual .read .anoTxt li {
    font-size: 15px;
  }
}
@media screen and (min-width: 1921px) {
  #visual .read .anoTxt li {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  #visual .read .anoTxt li {
    font-size: 3.2vw;
  }
}
#visual .read .btnRed {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 auto 2em;
}
@media screen and (min-width: 751px) {
  #visual .read .btnRed {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 0 2%;
    width: min(96%, 920px);
  }
}
@media screen and (min-width: 1921px) {
  #visual .read .btnRed {
    width: 54%;
  }
}
@media screen and (max-width: 767px) {
  #visual .read .btnRed {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    gap: 6vw 0;
    width: 90%;
  }
}
@media screen and (min-width: 751px) {
  #visual .read .btnRed li {
    width: 48.9%;
  }
}
#visual .read .btnRed li:hover {
  -webkit-filter: brightness(110%);
          filter: brightness(110%);
}
#visual .read .btnGuideLine {
  display: inline-block;
  color: #fff;
  font-weight: 700;
  padding: 1.2em;
  border-radius: 100px;
  border: 3px solid #fff;
  background: #000;
}
@media screen and (min-width: 751px) {
  #visual .read .btnGuideLine {
    font-size: 18px;
    min-width: 360px;
  }
}
@media screen and (min-width: 1921px) {
  #visual .read .btnGuideLine {
    font-size: 1vw;
    width: 22%;
  }
}
@media screen and (max-width: 767px) {
  #visual .read .btnGuideLine {
    width: 80%;
  }
}
#visual .read .btnGuideLine:hover {
  opacity: 0.8;
}

@media screen and (min-width: 751px) {
  #content .questionnaire {
    background: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.9) 12px, rgba(0, 0, 0, 0.85) 12px, rgba(0, 0, 0, 0.85) 18px);
    padding: 60px 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1020px) {
  #content .questionnaire {
    padding: 4vw 2vw 6vw;
  }
}
@media screen and (min-width: 1921px) {
  #content .questionnaire {
    background: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.9) 1vw, rgba(0, 0, 0, 0.85) 1vw, rgba(0, 0, 0, 0.85) 2vw);
    padding: 2vw 0;
  }
}
@media screen and (max-width: 767px) {
  #content .questionnaire {
    background: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.9) 2vw, rgba(0, 0, 0, 0.85) 2vw, rgba(0, 0, 0, 0.85) 4vw);
    padding: 10vw 0;
  }
}
#content .questionnaire .reportBnr {
  position: relative;
  padding-bottom: 3em;
  margin: 0 auto 3em;
}
@media screen and (min-width: 751px) {
  #content .questionnaire .reportBnr {
    width: 750px;
  }
}
@media screen and (min-width: 1921px) {
  #content .questionnaire .reportBnr {
    width: 42%;
  }
}
#content .questionnaire .reportBnr:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  background: -webkit-gradient(linear, left top, right top, from(#7cff85), to(#eaff00));
  background: linear-gradient(90deg, #7cff85 0%, #eaff00 100%);
  width: 100%;
  height: 0.3em;
}
#content .questionnaire .reportBnr dd {
  width: 100%;
}
#content .questionnaire dl {
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  #content .questionnaire dl {
    width: 90%;
  }
}
#content .questionnaire dl dt {
  font-weight: 700;
  line-height: 1.4;
  background: -webkit-gradient(linear, left top, right top, from(#7cff85), to(#eaff00));
  background: linear-gradient(90deg, #7cff85 0%, #eaff00 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 0.5em;
}
@media screen and (min-width: 751px) {
  #content .questionnaire dl dt {
    font-size: 36px;
  }
}
@media screen and (min-width: 1921px) {
  #content .questionnaire dl dt {
    font-size: 2.2vw;
  }
}
@media screen and (max-width: 767px) {
  #content .questionnaire dl dt {
    font-size: 6.6vw;
  }
}
#content .questionnaire dl dd {
  background: linear-gradient(60deg, #7cff85, #eaff00);
  border-radius: 20px;
  padding: 4px;
  margin-inline: auto;
}
@media screen and (min-width: 751px) {
  #content .questionnaire dl dd {
    width: 750px;
  }
}
@media screen and (min-width: 1921px) {
  #content .questionnaire dl dd {
    width: 42%;
  }
}
#content .questionnaire dl dd img {
  border-radius: 16px;
  overflow: hidden;
}
#content .questionnaire dl dd:hover {
  background: linear-gradient(60deg, #ffc000, #ff3f3a);
}
#content .questionnaire .anoTxt {
  margin-top: 1em;
}
#content .questionnaire .anoTxt li {
  color: #fff;
}
@media screen and (min-width: 751px) {
  #content .questionnaire .anoTxt li {
    font-size: 15px;
  }
}
@media screen and (min-width: 1921px) {
  #content .questionnaire .anoTxt li {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  #content .questionnaire .anoTxt li {
    font-size: 3.2vw;
  }
}