@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 全体 */
:root {
  --maxWD-820px: 820px;
  --maxWD-inner: 820px; /* innerの最大幅 */
  --maxWD-inner-sm: 792px; /* inner(小)の最大幅 */

  --c-text: #010d04; /* テキスト */
  --c-primary: #025434;
  --c-second: #f8e973;
  --c-link: #032e1c;
  --c-bk-main: #0098db; /* 背景 */
  --c-bk-white: #f4f4f4;

  --padding-PC-top-big: 104px; /* 共通の上パッディング設定(大) */
  --padding-SP-top-big: 72px;
  --padding-PC-bottom-big: 104px; /* 共通の下パッディング設定(大) */
  --padding-SP-bottom-big: 72px;

  --padding-PC-top: 72px; /* 共通の上パッディング設定 */
  --padding-SP-top: 40px;
  --padding-PC-bottom: 72px; /* 共通の下パッディング設定 */
  --padding-SP-bottom: 40px;

  --padding-PC-top-sml: 54px; /* 共通の上パッディング設定(小) */
  --padding-SP-top-sml: 24px;
  --padding-PC-bottom-sml: 54px; /* 共通の下パッディング設定(小) */
  --padding-SP-bottom-sml: 24px;

  --padding-inn-PC-top: 48px; /* 共通のinner上パッディング設定 */
  --padding-inn-SP-top: 24px;
  --padding-inn-PC-bottom: 48px; /* 共通のinner下パッディング設定 */
  --padding-inn-SP-bottom: 24px;

  --padding-inn-PC-top-sml: 24px; /* 共通のinner内の上パッディング設定(小) */
  --padding-inn-SP-top-sml: 16px;
  --padding-inn-PC-bottom-sml: 24px; /* 共通のinner内の下パッディング設定(小) */
  --padding-inn-SP-bottom-sml: 16px;

  --margin-PC-div-top: 24px; /* inner内divの上マージン設定 */
  --margin-SP-div-top: 32px;
  --margin-PC-div-bottom: 24px; /* inner内divの下マージン設定 */
  --margin-SP-div-bottom: 32px;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* パッディング用（共通） */
.padding-t-sec {
  /* 共通の上パッディング設定 */
  padding-top: var(--padding-PC-top);
}
.padding-b-sec {
  padding-bottom: var(--padding-PC-bottom);
}

.padding-t-big {
  /* 共通の上パッディング設定(大) */
  padding-top: var(--padding-PC-top-big);
}
.padding-b-big {
  padding-bottom: var(--padding-PC-bottom-big);
}

.padding-t-sml {
  /* 共通の上パッディング設定(小) */
  padding-top: var(--padding-PC-top-sml);
}
.padding-b-sml {
  padding-bottom: var(--padding-PC-bottom-sml);
}

.padding-inn-t-sec {
  /* 共通のinner上パッディング設定 */
  padding-top: var(--padding-inn-PC-top);
}
.padding-inn-b-sec {
  padding-bottom: var(--padding-inn-PC-bottom);
}

.padding-inn-t-sec-sml {
  /* 共通のinner内の上パッディング設定(小) */
  padding-top: var(--padding-inn-PC-top-sml);
}
.padding-inn-b-sec-sml {
  padding-bottom: var(--padding-inn-PC-bottom-sml);
}

.margin-div-t {
  padding-top: var(--margin-PC-div-top);
}
.margin-div-b {
  padding-bottom: var(--margin-PC-div-bottom);
}

@media only screen and (max-width: 768px) {
  /* タブレット・スマホ用 */
  .padding-t-sec {
    padding-top: var(--padding-SP-top);
  }
  .padding-b-sec {
    padding-bottom: var(--padding-SP-bottom);
  }

  .padding-t-big {
    padding-top: var(--padding-SP-top-big);
  }
  .padding-b-big {
    padding-bottom: var(--padding-SP-bottom-big);
  }

  .padding-t-sml {
    padding-top: var(--padding-SP-top-sml);
  }
  .padding-b-sml {
    padding-bottom: var(--padding-SP-bottom-sml);
  }

  .padding-inn-t-sec {
    padding-top: var(--padding-inn-SP-top);
  }
  .padding-inn-b-sec {
    padding-bottom: var(--padding-inn-SP-bottom);
  }

  .padding-inn-t-sec-sml {
    padding-top: var(--padding-inn-SP-top-sml);
  }
  .padding-inn-b-sec-sml {
    padding-bottom: var(--padding-inn-SP-bottom-sml);
  }

  .margin-div-t {
    padding-top: var(--margin-SP-div-top);
  }
  .margin-div-b {
    padding-bottom: var(--margin-SP-div-bottom);
  }
}

#LP_camp_box {
  overflow: hidden;
  color: var(--c-text);
  line-height: 1.7;
  background-color: var(--c-bk-white);
  font-size: 1rem;
  font-weight: 300;
  font-family:
    "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体",
    YuGothic, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ",
    Meiryo, "ＭＳ Ｐゴシック", "Lucida Grande", "Lucida Sans Unicode", Arial,
    Verdana, sans-serif;
  font-optical-sizing: auto;
  text-rendering: optimizeLegibility;
  font-kerning: normal;
  font-variant-ligatures: common-ligatures contextual;
  font-feature-settings: "kern", "liga", "clig", "calt";
}
.material-symbols-outlined {
  /* Googleアイコンフォント関連 */
  display: inline-flex;
  vertical-align: middle;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* テキスト(全体) */

#LP_camp_box p {
  margin-bottom: 0;
}

.txt-center {
  text-align: center !important;
}
.txt-p-left {
  text-align: left !important;
}
.txt-p-right {
  text-align: right !important;
}
.txt-s-small {
  font-size: 0.9375rem;
}
.txt-xs-small {
  font-size: 0.8125rem;
}
.txt-c-wh {
  color: #fff !important;
}

/* 改行の設定 */
br.is-pc {
  display: block;
}
br.is-sp {
  display: none;
}
@media screen and (max-width: 768px) {
  br.is-pc {
    display: none;
  }
  br.is-sp {
    display: block;
  }
}

#LP_camp_box h3 {
  font-size: 2rem;
}
#LP_camp_box h3.hed-h3 {
  position: relative;
  padding: 0 0 0.5em;
}
#LP_camp_box h3.hed-h3::before {
  content: attr(data-en);
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1rem;
  letter-spacing: 0.05em;
  font-weight: 400;
  margin-bottom: 8px;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* Flex */

.grid-inn-gap {
  column-gap: 4rem;
}
@media screen and (max-width: 368px) {
  .grid-inn-gap {
    column-gap: 2rem;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* リスト */

#LP_camp_box ul {
  list-style: none;
  text-align: left;
  margin: 0;
  padding: 0;
}
#LP_camp_box ul li {
  position: relative;
  list-style: none;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ヘッダー */
#LP_camp_box .sec_firstview {
  width: 100%;
  text-align: center;
}

.hd__wrapper {
  position: relative;
  z-index: 1;
  height: 649px;
  background-color: #003b22;
}

.hd__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 980px;
  height: 649px;
}
.hd__img figure picture img {
  width: min(100%, 980px);
  height: auto;
}

.hd__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 332px;
  margin-left: 6rem;
  transform: translateY(-50%);
}
h2.hd__ttl {
  width: 332px;
  margin-inline: auto;
}
.hd__copy {
  color: #fff;
  width: 100%;
  margin: 2rem auto 0;
}
.hd__inner .txt-c-wh {
  margin-top: 1.5rem;
}

.hd__inner .btn_wrapper {
  margin-top: 2rem;
}
.img-hd-sp__inner {
  display: none;
}

@media screen and (max-width: 740px) {
}
@media screen and (max-width: 570px) {
  .img-hd-sp__inner {
    display: block;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* イントロ */
#LP_camp_box .sec_intro {
  width: 100%;
}

.sec_intro h3 {
  display: inline-block;
  margin-inline: auto;
  font-family: "Noto Serif JP", serif;
  color: var(--c-primary);
  font-weight: 500;
  margin-bottom: 3rem;
}

.sec_intro .d-sm-flex {
  width: min(96%, var(--maxWD-820px)) !important;
  margin-inline: auto;
  column-gap: 2rem;
}
.drhiguchi-pic__inner {
  width: 40%;
}
.drhiguchi-txt__inner {
  width: 60%;
}

img.img_intro_thumb {
  width: min(100%, 321px) !important;
  height: auto !important;
}

.drhiguchi-txt__inner h5 {
  display: inline-block;
  font-size: 1.625rem;
  color: var(--c-primary);
  background-color: #e5e5e5;
  font-weight: 400;
  padding: 6px 4rem;
}
p.drhiguchi-txt__name {
  font-family: "Noto Serif JP", serif;
  font-size: 2.5rem;
  color: var(--c-primary);
}
p.drhiguchi-txt__sub {
  color: var(--c-primary);
  font-size: 1.125rem;
}

.drhiguchi-txt__inner div:last-of-type {
  margin-top: 2rem;
  background-color: #fff;
  padding: 1rem;
}
.drhiguchi-txt__inner h6 {
  color: #fff;
  background: #60bd75;
  background: linear-gradient(
    270deg,
    rgba(96, 189, 117, 1) 0%,
    rgba(55, 135, 103, 1) 66%
  );
  padding: 6px 0;
}

@media only screen and (max-width: 575px) {
  /* タブレット・スマホ用 */
  #LP_camp_box h3 {
    font-size: 1.75rem;
    font-weight: 700;
    padding-bottom: 8px;
    margin-bottom: 1em;
  }
  .drhiguchi-pic__inner {
    width: 96%;
  }
  .drhiguchi-txt__inner {
    width: 96%;
    margin-inline: auto;
    margin-top: 2rem;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* CTA部分 */
.sec_cta {
  width: 100%;
  background-color: #01411d;
  background-image: url("https://vetswan.s3.amazonaws.com/upload/feature_data/20304/lp_img/bg_ft20304_05.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}

img.img_campbnr {
  max-width: 840px;
  height: auto !important;
  border: 1px solid #d5d5d5;
}

@media only screen and (max-width: 769px) {
}

@media only screen and (max-width: 575px) {
  .sec_cta {
    background-image: none;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* div「特徴」 */
.sec_feature {
  /* 共通 */
  width: 100%;
}
.sec_feature_inner {
  width: min(96%, var(--maxWD-820px));
  margin-inline: auto;
}

.sec_feature01 {
  background-color: #012718;
  background-image: url("https://vetswan.s3.amazonaws.com/upload/feature_data/20304/lp_img/bg_ft20304_02.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}
.sec_feature02 {
  background-color: #012718;
  background-image: url("https://vetswan.s3.amazonaws.com/upload/feature_data/20304/lp_img/bg_ft20304_03.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}
.sec_feature04 {
  background-color: #000100;
  background-image: url("https://vetswan.s3.amazonaws.com/upload/feature_data/20304/lp_img/bg_ft20304_04.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}
.sec_feature05 {
  background: #dcdcdc;
}

.sec_feature01 h3 {
  font-family: "Noto Serif JP", serif;
  color: #fff;
  margin-bottom: 2rem;
}
.sec_feature01 h4 {
  font-family: "Noto Serif JP", serif;
  color: #fff;
}
.sec_feature01 p.txt-s-small {
  margin-top: 2rem;
}

.sec_feature02 h3 {
  font-family: "Noto Serif JP", serif;
  margin-bottom: 2rem;
}

.sec_feature03 h4 {
  display: inline-block;
  font-family: "Noto Serif JP", serif;
  color: var(--c-primary);
  border: 1px solid var(--c-primary);
  padding: 6px 16px;
  margin-bottom: 2rem;
}

.sec_feature04 h3 {
  font-family: "Noto Serif JP", serif;
  color: #ccaa56;
}
.sec_feature04 p.txt-c-wh {
  margin-top: 2rem;
}

.sec_feature05 h3 {
  font-family: "Noto Serif JP", serif;
  margin-bottom: 2rem;
}

.ft01__inner {
  background-color: #03160d;
  border: 1px solid #909995;
  color: #fff;
  padding: 3rem;
  margin-top: 3rem;
}
.ft01__inner h4 {
  margin-bottom: 1rem;
}
.ft01__inner p {
  margin-bottom: 2rem !important;
}

.ft03__inner {
  background-color: #fff;
  border: 1px solid #bfbfbf;
  padding: 3rem;
  text-align: center;
}
.ft03__inner ul {
  /* リスト */
  display: block;
  width: 80%;
  max-width: 400px;
  margin: 2rem auto !important;
  line-height: 2;
  font-size: 1.125rem;
  text-align: left;
}
.ft03__inner ul li {
  position: relative;
  list-style: none;
  background-image: url("https://vetswan.s3.amazonaws.com/upload/feature_data/20304/lp_img/icon_ft20304_check.png");
  background-position: left 0.3em;
  background-repeat: no-repeat;
  padding: 0 0 6px 34px;
  color: var(--c-primary);
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
}
.ft03-img__inner {
  margin: 2rem auto;
}
.ft03__inner img {
  width: min(100%, 764px) !important;
  height: auto !important;
}

.ft04__inner {
  background-color: #fff;
  border: 1px solid #c7b57d;
  padding: 3rem;
  text-align: center;
}
.ft04__inner > p {
  text-align: left;
}
.ft04__inner p.txt-p-right {
  display: block;
  color: #fff !important;
  margin-right: 0 !important;
  margin-left: auto !important;
}
.ft04__inner p.txt-p-right span {
  background-color: #75c786;
  padding: 4px 2px;
}

.ft05__inner {
  background-color: #fff;
  padding: 3rem;
  text-align: center;
}
.ft05__inner p {
  line-height: 2;
  text-align: left;
}

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  .sec_feature01 p.txt-c-wh {
    text-align: left;
  }
  .ft04__inner p.txt-p-right {
    margin-top: 1rem;
  }
}

/* ============= */

.sec_feature01 h5 {
  display: inline;
  background: linear-gradient(transparent 70%, var(--c-marker-blue) 70%);
  width: -moz-fit-content;
  width: fit-content;
}
.sec_feature02 h5 {
  display: inline;
  background: linear-gradient(transparent 70%, var(--c-marker-blue) 70%);
  width: -moz-fit-content;
  width: fit-content;
}
.sec_feature03 h5 {
  color: var(--c-primary);
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.25rem;
}

.sec_feature03 .d-sm-flex p em {
  font-style: normal;
  font-weight: 600;
  font-size: 1.125em;
}
.sec_feature03 p {
  margin-bottom: 0 !important;
}
.sec_feature02 .d-sm-flex,
.sec_feature04 .d-sm-flex,
.sec_feature05 .d-sm-flex {
  column-gap: 3rem;
}

/* 検体準備 */
.sec_feature06 .kentai_inner {
  border: 2px solid #f75454;
  border-radius: 0.75em;
  padding: 2em;
  column-gap: 3rem;
}
.sec_feature06 .kentai_inner h5 {
  color: #f75454;
}
.kentaiatten_inner {
  color: #f75454;
  font-weight: 600;
  font-size: 1.5rem;
  margin-left: auto;
  margin-right: auto;
}
.kentaionegai_inner {
  border: 1px solid #f75454;
  color: #f75454;
  border-radius: 0.75em;
  padding: 1em;
  background-color: #fff9f8;
}
.kentaionegai_inner strong {
  font-weight: 600;
}

.sec_feature_inner_lv01 {
  background-color: #fff;
  border-radius: 0.75em;
  padding: 1.5em 2em;
}
.sec_feature_inner_lv01 p:first-of-type {
  margin-top: 1rem;
}

.sec_feature_inner_lv02 {
  width: min(96%, var(--maxWD-820px));
  margin-inline: auto;
  padding-top: 1em;
}
.sec_feature02 p.txt-p-left:first-of-type {
  margin-top: 1rem;
}

.sec_feature_inner_lv03 {
  background-color: #f2f2f2;
  width: min(96%, var(--maxWD-820px));
  border-radius: 0.75em;
  margin-inline: auto;
  padding: 1.5em 2em;
}

.sec_feature p.txt-s-small {
  color: var(--c-primary);
}

.sec_feature .Feature_img_inner {
  width: min(96%, var(--maxWD-820px));
  margin-inline: auto;
}
.sec_feature .Feature_img_inner p {
  margin-bottom: 0 !important;
}

.sec_report_inner {
  width: min(96%, var(--maxWD-820px));
  margin-inline: auto;
}
.sec_report_inner .btn_wrapper {
  margin-top: 2rem;
}

img.img_icon_feature {
  max-width: 100px;
}
img.img_kainushisama {
  max-width: 150px;
}
img.img_stepmark {
  max-width: 110px;
}
img.img_icon_atten {
  max-width: 42px;
}
img.img_medicalreport {
  max-width: 720px;
  border: #ddd 1px solid;
}

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  .sec_feature .Feature_flex div {
    width: 96%;
    margin-bottom: 1rem;
  }
  .sec_feature .Feature_flex div:last-of-type {
    margin-bottom: 0;
  }
  .kentaiatten_inner {
    font-size: 1.125rem;
  }
  .sec_feature02 .sec_feature_inner .d-sm-flex div:first-of-type {
    margin-bottom: 2rem;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* div「利用方法」 */
.sec_howto {
  width: 100%;
  background-color: #caf1ff;
}
.sec_howto h3 {
  border-bottom: none !important;
}

.howto_inner {
  width: min(96%, var(--maxWD-820px));
  margin-inline: auto;
}

.howto_inner .d-sm-flex {
  column-gap: 2rem;
}
.howto_inner .d-sm-flex div:first-of-type {
  width: 20%;
}
.howto_inner .d-sm-flex div:last-of-type {
  width: 80%;
}
@media only screen and (max-width: 599px) {
  /* スマホ用 */
  .howto_inner .d-sm-flex div:first-of-type {
    width: 100%;
    margin-bottom: 1rem;
  }
  .howto_inner .d-sm-flex div:last-of-type {
    width: 100%;
  }
  img.img_stepmark {
    max-width: 80px;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* List */

.sec_feature04 ul li {
  background-image: url(https://vetswan.s3.amazonaws.com/upload/feature_data/20156/check_ft20156.png);
  background-position: left 0.3em;
  background-repeat: no-repeat;
  font-size: 1.25rem;
  font-weight: 300;
  padding: 5px 0 10px 30px;
}

.sec_howto ul {
  background-color: #fff;
  border-radius: 0.75em;
}
.sec_howto ul li {
  padding: 2em;
  border-top: solid 2px #d9d9d9;
}
.sec_howto ul li:first-of-type {
  border-top: none;
}
.sec_howto ul li.d-flex {
  column-gap: 2em;
}
.sec_howto ul li h6 {
  font-size: 1.125rem;
  color: var(--c-bk-main);
}

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  .sec_feature04 ul li {
    font-size: 1rem;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ボタン */
#LP_camp_box div.btn_wrapper {
  width: 100%;
  position: relative;
  cursor: pointer;
  display: inline-block;
}

div.txt_tooltip {
  /* hoverでツールチップ表示 */
  display: none;
  position: absolute;
  padding: 10px;
  font-size: 0.875rem;
  line-height: 1.6;
  color: #fff;
  border-radius: 5px;
  background: #000;
  max-width: 300px;
  width: 80%;
}
div.txt_tooltip:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  border: 8px solid transparent;
  border-top: 8px solid #000;
  margin-left: -8px;
}
#LP_camp_box div.btn_wrapper:hover div.txt_tooltip {
  display: inline-block;
  top: -60%;
  left: 12%;
}

#LP_camp_box a.btn {
  width: 100%;
  max-width: 448px;
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 1.125rem;
  font-weight: 500;
  padding: 0.9em 2em;
  text-decoration: none;
  outline: none;
  border-radius: 64px;
  background-color: #fff;
  color: var(--c-link);
}
.btn-icon-r {
  position: absolute;
  top: 50%;
  right: 10px;
  height: 1em;
  line-height: 1em;
  font-size: 1.4em !important;
  transform: translateY(-50%); /* 上下中央に */
}

#LP_camp_box div.btn_wrapper:hover a span.txt_link_rote {
  /* hoverで回転 */
  transition: transform 1s;
  transform: rotateX(360deg);
}

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  #LP_camp_box a.btn {
    font-size: 1em;
    max-width: 100%;
    letter-spacing: 0;
  }
}
@media only screen and (max-width: 387px) {
  /* スマホ(小)用 */
  #LP_camp_box a.btn {
    font-size: 0.8125em;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* FAQ */
section.faq_wrapper {
  background-color: #f2f2f2;
}
section.faq_wrapper h3 {
  font-family: "Noto Serif JP", serif;
}

section.faq_wrapper dl {
  max-width: var(--maxWD-820px);
  margin-inline: auto;
  text-align: left;
}
section.faq_wrapper dd.faq_dd {
  display: none;
}

section.faq_wrapper dt.faq_dt {
  background-color: #fff;
  padding: 1em 45px 1em 20px;
  margin: 2rem 0 0;
  transition: background 0.3s ease;
  cursor: pointer;
  position: relative;
  font-weight: 500;
}

section.faq_wrapper dt.faq_dt::before,
section.faq_wrapper dt.faq_dt::after {
  position: absolute;
  content: "";
  top: 1px;
  right: 20px;
  bottom: 0;
  width: 12px;
  height: 2px;
  margin: auto;
  background: #151e2f;
}
section.faq_wrapper dt.faq_dt::after {
  transform: rotate(-90deg);
  transition: transform 0.3s;
}
section.faq_wrapper dt.faq_dt.active::after {
  transform: rotate(0deg);
}
section.faq_wrapper dt.faq_dt.active {
  background-color: #ececec;
}

section.faq_wrapper dd.faq_dd {
  background-color: #fff;
  padding: 12px 20px 10px;
}

section.faq_wrapper dt.faq_dt span,
section.faq_wrapper dd.faq_dd span {
  display: inline-block;
  padding-left: 45px;
  position: relative;
}

section.faq_wrapper dt.faq_dt span::before {
  position: absolute;
  content: "Q";
  top: 50%;
  left: 10px;
  font-size: 20px;
  transform: translateY(-50%) translateX(-50%);
  display: inline-block;
  width: 40px;
  height: 40px;
  color: #fff;
  background-color: #d0d0d0;
  text-align: center;
  line-height: 40px;
}

section.faq_wrapper dd.faq_dd span::before {
  position: absolute;
  content: "A";
  top: 10px;
  left: 10px;
  font-size: 20px;
  transform: translateY(-50%) translateX(-50%);
  display: inline-block;
  width: 40px;
  height: 40px;
  color: #fff;
  background-color: #22be88;
  text-align: center;
  line-height: 40px;
}

/* hover */
section.faq_wrapper dt.faq_dt:hover {
  background-color: #f2f2f2;
}
