@charset "UTF-8";
/* SCSSの読み込み */
/* font-weight */
:root {
  /* カラー */
  --color-text: #333;
  --color-orange: #fb7f1b;
  --color-orange-shadow: #db6403;
  --color-green: #29be5c;
  --color-green-shadow: #0c9d3e;
  --color-yellow: #f6da00;
  --color-yellow-line: #fff9c3;
  --color-bg: #f8f8ea;
  /* font-family */
  --font-family-noto: "Noto Sans JP", sans-serif;
  --font-family-maru: "Zen Maru Gothic", serif;
  /* font-weight */
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;
}

@media screen and (min-width: 768px) {
  :root {
    /* フォントサイズ */
    --font-size-xxxl: 5rem;
    --font-size-xxl: 4.2rem;
    --font-size-xl: 3.6rem;
    --font-size-gl: 2.4rem;
    --font-size-base: 1.8rem;
    --font-size-sm: 1.6rem;
    /* line-height */
    --line-height-xxxl: 1.52;
    --margin-height-xxxl: -0.26em;
    --line-height-xl: 1.55556;
    --margin-height-xl: -0.2778em;
    --line-height-gl: 1.33334;
    --margin-height-gl: -0.1667em;
    --line-height-base: 1.77778;
    --margin-height-base: -0.38889em;
    /* letter-speacing */
    --letter-spacing-base: 0.06em;
  }
}
@media screen and (max-width: 767px) {
  :root {
    /* フォントサイズ */
    --font-size-xxl: 3.6rem;
    --font-size-xl: 3rem;
    --font-size-gl: 2.4rem;
    --font-size-base: 1.5rem;
    --font-size-xm: 1.2rem;
    /* line-height */
    --line-height-xl: 2;
    --margin-height-xl: -0.5em;
    --line-height-base: 1.75;
    --margin-height-base: -0.375em;
    --line-height-sm: 1.5;
    --margin-height-sm: -0.25em;
    /* letter-speacing */
    --letter-spacing-base: 0.04em;
  }
}
/*===============================================
  共通スタイル
===============================================*/
/* タイトル
-----------------------------*/
.com-title {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-family: var(--font-family-maru);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  letter-spacing: 0;
  line-height: 1;
  margin-bottom: 50px;
}
.com-title > span {
  display: block;
  position: relative;
  z-index: 0;
}
.com-title .main {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-xl);
  letter-spacing: var(--letter-spacing-base);
  padding: 12px 30px;
}
.com-title .g {
  color: #29be5c;
  font-weight: 900;
}

/* 前に戻るボタン
-----------------------------*/
.back__btns {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 55px;
}

.back__btn {
  display: block;
  font-size: 1.111112em;
  line-height: 1.5;
  font-weight: var(--font-weight-bold);
  color: var(--color-orange);
  padding: 0 5px 7px;
  transition: all 0.12s;
  border-bottom: solid 2px var(--color-orange);
}
.back__btn:hover {
  color: var(--color-text);
}

/*===============================================
  質問内容
===============================================*/
.questionnaire__title {
  align-items: stretch;
  border-radius: 10px;
  overflow: hidden;
}
.questionnaire__title .icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 80px;
  font-size: var(--font-size-xxxl);
  color: #fff;
  padding-bottom: 0.15em;
  background: var(--color-green);
}
.questionnaire__title .main {
  width: calc(100% - 80px);
  padding-right: 110px;
  background: var(--color-yellow-line);
}
.questionnaire__choices {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  padding: 0 20px;
  margin-top: -40px;
}
.questionnaire__choice-item {
  width: 300px;
  margin-top: 40px;
  margin-right: 70px;
}
.questionnaire__choice-item:nth-of-type(3n), .questionnaire__choice-item:last-of-type {
  margin-right: 0;
}
.questionnaire__choice-item--xl {
  width: 100%;
  margin-right: 0;
}
.questionnaire__choice-button {
  min-height: 80px;
  font-size: 1.333334em;
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  padding: 15px 60px;
}
.questionnaire__choice-button--xl {
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 0 0 0 3px var(--color-orange) inset;
  border-radius: 100vh;
  overflow: hidden;
  transition: all 0.3s;
  padding: 15px 30px 15px 110px;
  position: relative;
  z-index: 0;
}
.questionnaire__choice-button--xl::before {
  content: "";
  width: 80px;
  height: 100%;
  background: url(../img/common/arrow.png) no-repeat left 57.8125% center/16px;
  background-color: var(--color-orange);
  position: absolute;
  top: 0;
  left: 0;
}
.questionnaire__choice-button--xl:hover {
  background: rgba(219, 100, 3, 0.24);
}

/* ===============================================
  診断結果
=============================================== */
.result__title {
  flex-direction: column;
}
.result__title .sub {
  font-size: 2.8rem;
  color: var(--color-green);
  letter-spacing: var(--letter-spacing-base);
  margin-bottom: 40px;
}
.result__title .sub::before {
  content: "";
  width: calc(100% + 160px);
  height: 60px;
  background: url(../chart/img/waa-l.png) no-repeat left bottom/contain, url(../chart/img/waa-r.png) no-repeat right bottom/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -11px;
  z-index: -2;
}
.result__title .main {
  width: 100%;
  background: #fee2d2;
  border-radius: 10px;
}
.result__body {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0 20px;
}
.result__image {
  width: 460px;
}
.result__image img {
  aspect-ratio: 23/16;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 30px;
}
.result__text {
  width: 540px;
  margin: 13px 0;
}
.result__contact {
  padding-top: 60px;
}
.result__contact-title {
  text-align: center;
  font-size: 1.555556em;
  line-height: 1.5;
  font-family: var(--font-family-maru);
  font-weight: var(--font-weight-bold);
  color: #fff;
  letter-spacing: var(--letter-spacing-base);
  background: #fdac31;
  padding: 19px 30px;
  border-radius: 10px 10px 0 0;
}
.result__contact-list {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--color-yellow-line);
  padding: 44px 40px;
  border-radius: 0 0 10px 10px;
}
.result__contact-list:has(.result__contact-tel) {
  padding-top: 56px;
}
.result__contact-item {
  width: 310px;
  margin-right: 35px;
  position: relative;
  z-index: 0;
}
.result__contact-item:nth-of-type(3n), .result__contact-item:last-of-type {
  margin-right: 0;
}
.result__contact-txt {
  width: 100%;
  text-align: center;
  font-weight: var(--font-weight-bold);
  color: var(--color-green);
  line-height: 1;
  padding-bottom: 10px;
  border-bottom: solid 2px var(--color-green);
  position: absolute;
  left: 0;
  bottom: 100%;
}
.result__contact-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 80px;
  font-weight: var(--font-weight-bold);
  line-height: 1;
  border-radius: 20px;
  transition: all 0.3s;
}
.result__contact-btn::before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  margin-right: 15px;
}
.result__contact-btn > span {
  display: block;
}
.result__contact-btn:hover {
  text-decoration: none;
  opacity: 0.64;
}
.result__contact-btn--line {
  color: var(--color-text);
  background: var(--color-yellow);
}
.result__contact-btn--line::before {
  background: url(../img/common/icon_LINE.svg) no-repeat center/contain;
}
.result__contact-btn--mail {
  color: #fff;
  background: var(--color-orange);
}
.result__contact-btn--mail::before {
  background: url(../img/common/icon_mail.png) no-repeat center/contain;
}
.result__contact-tel {
  height: 100px;
  background: #fff;
}
.result__contact-tel .com-tel-num {
  font-size: 3.2rem;
}
.result__contact-tel .com-tel-num::before {
  width: 23px;
  height: 23px;
}
.result__contact-tel .com-tel-num a {
  margin-top: -7px;
  margin-bottom: -2px;
}
.result__contact-tel .com-replace {
  margin-top: 12px;
}
.result__contact-tel .com-replace img {
  height: 13px;
}
.result__links {
  display: grid;
  grid-auto-flow: column;
  gap: 40px;
  padding-top: 40px;
}
.result__link-btn {
  height: 80px;
  border-radius: 20px;
}
.result__link-btn::before {
  left: 40px;
}