@charset "UTF-8";
@font-face {
  font-family: "ZenKurenaido-Regular";
  src: url(../fonts/ZenKurenaido/ZenKurenaido-Regular.woff2) format("woff2");
  font-display: swap;
}
/*16*1.75/2*/
/*===========*/
/* 共通ページ */
/*===========*/
body {
  background: url(/images/common/bg01.jpg) center top no-repeat;
  background-size: contain;
}
@media (min-width: 1634px) {
  body {
    background: url(/images/common/bg01.jpg) center top no-repeat;
    background-size: cover;
  }
}
@media (max-width: 767px) {
  body {
    background: url(/images/common/bg01.jpg) center top no-repeat;
    background-size: 150%;
  }
}
body article {
  padding-top: 88px;
}
@media (max-width: 767px) {
  body article {
    padding-top: 146px;
  }
}
body article.page.nopd {
  padding-top: 1px;
  margin-top: -32px;
}
@media (max-width: 767px) {
  body article.page.nopd {
    padding-top: 68px;
    margin-top: 0;
  }
}
body article section .sec {
  padding: 32px 0;
}
body article section .sec:first-of-type {
  padding-top: 0;
}
body article section .sec:last-of-type {
  padding-bottom: 0;
}

.cts {
  position: relative;
  z-index: 2;
  max-width: 570px;
  margin: auto;
}
@media (max-width: 767px) {
  .cts {
    padding: 0 24px;
  }
}

.btn-area {
  max-width: 570px;
  margin: 80px auto auto auto;
  text-align: center;
  display: flex;
  justify-content: space-between;
}
.btn-area.pc-noflex {
  display: block;
}
@media (max-width: 767px) {
  .btn-area.sp-noflex {
    display: block;
  }
}
.btn-area:has(> *:only-child) {
  justify-content: center;
}
@media (max-width: 767px) {
  .btn-area {
    margin-top: 40px;
    padding: 0 12px;
  }
}
.btn-area.col2 > * {
  font-size: 18px;
  width: 48%;
}
@media (max-width: 767px) {
  .btn-area.col2 > * {
    width: 100%;
  }
  .btn-area.col2 > *:first-child {
    margin-bottom: 16px;
  }
}

.style-btn01 {
  transform: none;
  min-width: 150px;
  font-size: 23px;
  padding: 21px 82px 22px 32px;
  width: auto;
}
.style-btn01::before {
  right: -1px;
  width: 65px;
  height: 65px;
}
@media (max-width: 767px) {
  .style-btn01 {
    font-size: 16px;
    padding: 20px 60px 20px 16px;
  }
  .style-btn01::before {
    right: -1px;
    width: 55px;
    height: 55px;
  }
}
.style-btn01.mini {
  font-size: 18px;
  padding: 16px 60px 17px 20px;
}
.style-btn01.mini::before {
  right: -1px;
  width: 50px;
  height: 50px;
}
.style-btn01.mini:hover::before {
  right: -8px;
}
.style-btn01.reverse {
  padding: 21px 32px 22px 82px;
}
@media (max-width: 767px) {
  .style-btn01.reverse {
    padding: 20px 16px 20px 60px;
  }
}
.style-btn01.reverse.mini {
  padding: 16px 20px 17px 60px;
}
.style-btn01.reverse.mini::before {
  left: -1px;
}
.style-btn01.reverse.mini:hover::before {
  right: auto;
  left: -8px;
}
.style-btn01:hover::before {
  right: -12px;
}
.style-btn01:hover.reverse::before {
  left: -12px;
}

.input-style input[type=radio] {
  display: none;
}
.input-style input[type=radio] + label::before {
  content: "";
  position: absolute;
  bottom: 50%;
  left: 26px;
  transform: translateY(50%);
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 500px;
  border: 1px solid #4e3612;
  background-color: #FFF;
}
.input-style input[type=radio] + label::after {
  content: "";
  position: absolute;
  bottom: 50%;
  left: 30px;
  transform: translateY(50%);
  display: none;
  width: 14px;
  height: 14px;
  border-radius: 500px;
  background-color: #4e3612;
}
.input-style input[type=radio]:checked + label {
  background-color: #44c688;
  color: #FFF;
}
.input-style input[type=radio]:checked + label::after {
  display: block;
}
.input-style input[type=checkbox] {
  display: none;
}
.input-style input[type=checkbox] + label::before {
  content: "";
  position: absolute;
  bottom: 50%;
  left: 26px;
  transform: translateY(50%);
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 4px;
  border: 1px solid #4e3612;
  background-color: #FFF;
}
@media (max-width: 767px) {
  .input-style input[type=checkbox] + label::before {
    left: 20px;
  }
}
.input-style input[type=checkbox] + label::after {
  content: "";
  position: absolute;
  bottom: calc(50% + 7px);
  left: 24px;
  transform: translateY(50%) rotate(135deg);
  display: none;
  width: 20px;
  height: 14px;
  border-top: 3px solid #4e3612;
  border-right: 3px solid #4e3612;
}
@media (max-width: 767px) {
  .input-style input[type=checkbox] + label::after {
    left: 18px;
  }
}
.input-style input[type=checkbox]:checked + label {
  background-color: #44c688;
  color: #FFF;
}
.input-style input[type=checkbox]:checked + label::after {
  display: block;
}
.input-style label {
  display: block;
  margin-bottom: 24px;
  color: #4e3612;
  border: 1px solid #4e3612;
  padding: 16px 32px 16px 64px;
  border-radius: 8px;
  box-shadow: 0 8px 0 rgba(0, 0, 0, 0.2);
  background-color: #dcfae6;
  cursor: pointer;
  font-weight: bold;
  position: relative;
}
@media (max-width: 767px) {
  .input-style label {
    padding: 16px 4px 16px 56px;
  }
}

.main-ct {
  background: #FFF;
  position: relative;
}
.main-ct::before {
  position: absolute;
  top: -10vh;
  left: 0;
  content: "";
  background-color: #FFF;
  display: block;
  width: 100%;
  height: 10vh;
  border-radius: 500px 500px 0 0;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.2);
}
@media (min-height: 1000px) {
  .main-ct::before {
    height: 100px;
  }
}
@media (max-width: 767px) {
  .main-ct::before {
    height: 66px;
    top: -65px;
  }
}
.main-ct::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  background: #FFF;
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  z-index: 1;
}

.flow {
  border-top: 1px solid #4e3612;
  position: relative;
  height: 36px;
  margin-bottom: 80px;
}
.flow::before {
  content: "Start";
  color: #4e3612;
  position: absolute;
  bottom: 0;
  left: 0;
}
.flow::after {
  content: "Finish";
  color: #4e3612;
  position: absolute;
  bottom: 0;
  right: 0;
}
.flow span {
  display: block;
  width: 0%;
  height: 9px;
  background-color: #4e3612;
}

.btn-bg {
  background: url(/images/index/footer_bg01_pc.jpg) center 0 no-repeat;
  background-size: cover;
  border-radius: 10vh 10vh 0 0;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.2);
  position: relative;
  min-height: 240px;
  margin-bottom: -124px;
  margin-top: 104px;
  z-index: 2;
}
@media (min-height: 1000px) {
  .btn-bg {
    border-radius: 100px 100px 0 0;
  }
}
@media (max-width: 767px) {
  .btn-bg {
    background: url(/images/index/footer_bg01_sp.jpg) center 0 no-repeat;
    background-size: cover;
    border-radius: 66px 66px 0 0;
    min-height: 190px;
    margin-top: 88px;
  }
}
.btn-bg .btn-area {
  text-align: center;
  position: relative;
  top: -34px;
  margin-top: 0;
  /*@media (max-height: 700px) {
  	transform: scale(.7);
  }*/
}
@media (max-width: 767px) {
  .btn-bg .btn-area {
    position: absolute;
    width: 100%;
    right: 50%;
    transform: translateX(50%);
    top: -32px;
  }
}

.result-cmt {
  font-weight: bold;
}
@media (min-width: 768px) {
  .result-cmt {
    font-size: 18px;
    margin-bottom: 80px;
    line-height: 2.1;
  }
}
@media (max-width: 767px) {
  .result-cmt {
    font-size: 16px;
    line-height: 2;
  }
}
.result-cmt + .color-box > .heading04 + p {
  line-height: 2;
}
@media (max-width: 767px) {
  .result-cmt + .color-box > .heading04 + p {
    line-height: 1.8;
  }
}
.result-cmt + .sec > .heading04 + p, .result-cmt + .sec > .heading02 + p {
  line-height: 2;
}
@media (max-width: 767px) {
  .result-cmt + .sec > .heading04 + p, .result-cmt + .sec > .heading02 + p {
    line-height: 1.8;
  }
}
.result-cmt + .sec > .color-box > .heading04 + p, .result-cmt + .sec > .color-box > .heading02 + p {
  line-height: 2;
}
@media (max-width: 767px) {
  .result-cmt + .sec > .color-box > .heading04 + p, .result-cmt + .sec > .color-box > .heading02 + p {
    line-height: 1.8;
  }
}

/*ココロの健康度チェック*/
.cts-wide {
  max-width: 960px;
  position: relative;
  margin: auto;
  z-index: 2;
  padding: 0 24px;
}

.grid-table {
  background-color: #FFF;
  display: grid;
  grid-auto-rows: auto;
  grid-template-columns: 23% 20% 19% 19% 19%;
  border: 1px solid #4e3612;
  border-radius: 8px;
  box-shadow: 0 4px 0 #c9c4c0;
  overflow: hidden;
}
@media (max-width: 767px) {
  .grid-table {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-template-rows: auto auto auto auto;
  }
}
.grid-table .ttl {
  background-color: #FDFBDA;
  font-weight: bold;
}
@media (max-width: 767px) {
  .grid-table .ttl {
    background-color: #4f3514;
    color: #FFF;
    grid-column: 1/5;
    padding: 6px 13px !important;
  }
}
.grid-table .ttl-color {
  background-color: #FDFBDA;
  font-weight: bold;
}
.grid-table .gt-col {
  border-right: 1px solid #4e3612;
  border-bottom: 1px solid #4e3612;
}
.grid-table .gt-col.end-r {
  border-right: none;
}
.grid-table .gt-col.end-b {
  border-bottom: none;
}
.grid-table .gt-col.tx, .grid-table .gt-col label {
  display: block;
  padding: 8px 16px;
}
@media (max-width: 767px) {
  .grid-table .gt-col.tx, .grid-table .gt-col label {
    padding: 6px 2px;
  }
}
.grid-table .gt-col.sp {
  background-color: #fff6ed;
  line-height: 1.2;
  font-size: 14px;
}
.grid-table .gt-col.bd-bd {
  border-bottom: 1px dashed #4e3612;
  line-height: 1;
}
.grid-table .gt-col label {
  text-align: center;
  /*input {
  	position: absolute;
  	transform: translateY(50%) translateX(50%);
  	bottom: calc(50% - 0.5px);
  	right: 50%;
  }*/
}
.grid-table .gt-col.level1, .grid-table .gt-col.level2, .grid-table .gt-col.level3, .grid-table .gt-col.level4, .grid-table .gt-col.level5, .grid-table .gt-col.level6 {
  position: relative;
}
.grid-table .gt-col.level1 label span, .grid-table .gt-col.level2 label span, .grid-table .gt-col.level3 label span, .grid-table .gt-col.level4 label span, .grid-table .gt-col.level5 label span, .grid-table .gt-col.level6 label span {
  display: none;
  position: absolute;
  vertical-align: middle;
  width: 12px;
  height: 12px;
  margin-right: 8px;
  transform: translateY(50%) translateX(50%);
  bottom: calc(50% - 0.5px);
  right: calc(50% + 10px);
}
.grid-table .gt-col.level1 label input[type=radio]:checked + span, .grid-table .gt-col.level2 label input[type=radio]:checked + span, .grid-table .gt-col.level3 label input[type=radio]:checked + span, .grid-table .gt-col.level4 label input[type=radio]:checked + span, .grid-table .gt-col.level5 label input[type=radio]:checked + span, .grid-table .gt-col.level6 label input[type=radio]:checked + span {
  display: block;
}
.grid-table .gt-col.level1 label span {
  background-color: #0070C0;
}
.grid-table .gt-col.level2 label span {
  background-color: #00B050;
}
.grid-table .gt-col.level3 label span {
  background-color: #92D050;
}
.grid-table .gt-col.level4 label span {
  background-color: #FFC000;
}
.grid-table .gt-col.level5 label span {
  background-color: #FF0000;
}
.grid-table .gt-col.level6 label span {
  background-color: #782170;
}

.level-result {
  background-color: #FDFBDA;
  border-radius: 16px;
}
@media (max-width: 767px) {
  .level-result {
    border-radius: 0;
  }
}
.level-result ul {
  display: flex;
  padding: 32px 0;
  justify-content: center;
}
@media (max-width: 767px) {
  .level-result ul {
    flex-wrap: wrap;
    padding: 32px 0 16px;
  }
}
.level-result ul li {
  text-align: center;
  color: #4e3612;
  font-weight: bold;
  width: 90px;
  margin: 0 8px;
}
@media (max-width: 767px) {
  .level-result ul li {
    margin: 0 4px 16px;
  }
}
.level-result ul li span {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  padding: 2px;
}
@media (max-width: 767px) {
  .level-result ul li span {
    font-size: 12px;
  }
}
.level-result ul li.level1 span {
  background-color: #0070C0;
  color: #FFF;
}
.level-result ul li.level2 span {
  background-color: #00B050;
  color: #FFF;
}
.level-result ul li.level3 span {
  background-color: #92D050;
}
.level-result ul li.level4 span {
  background-color: #FFC000;
}
.level-result ul li.level5 span {
  background-color: #FF0000;
  color: #FFF;
}
.level-result ul li.level6 span {
  background-color: #782170;
  color: #FFF;
}
.level-result ul li div {
  background-color: #FFF;
  border: 1px solid #4e3612;
  font-size: 27px;
  position: relative;
}
@media (max-width: 767px) {
  .level-result ul li div {
    font-size: 22px;
  }
}
.level-result ul li div::after {
  content: "個";
  position: absolute;
  right: 4px;
  bottom: 4px;
  font-size: 14px;
  font-weight: bold;
}
@media (max-width: 767px) {
  .level-result ul li div::after {
    right: 2px;
    bottom: 2px;
    font-size: 12px;
  }
}

.check-result dt {
  background-color: #44C688;
  color: #FFF;
  border-radius: 4px;
  padding: 16px 50px 16px 2.3em;
  cursor: pointer;
  font-size: 18px;
  position: relative;
  margin-bottom: 16px;
  text-indent: -1.3em;
}
@media (max-width: 767px) {
  .check-result dt {
    padding: 12px 50px 12px 2.3em;
    font-size: 16px;
  }
}
.check-result dt::after {
  content: "";
  display: block;
  border-top: 2px solid #FFF;
  border-right: 2px solid #FFF;
  width: 12px;
  height: 12px;
  position: absolute;
  bottom: 37%;
  right: 22px;
  transform: rotate(135deg) translateY(50%);
  transform-origin: center;
}
.check-result dt:hover {
  background-color: #56d48d;
}
.check-result dt span {
  font-weight: bold;
}
.check-result dt.open::after {
  transform: rotate(-45deg) translateY(50%);
  bottom: 45%;
  right: 30px;
}
.check-result dd {
  margin-bottom: 32px;
  display: none;
}
.check-result dd span {
  font-weight: bold;
}

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