@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@300;400;500;700;800&display=swap");
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 全体 */
:root {
  --maxWD-840px: 840px;
  --maxWD-inner: 840px; /* innerの最大幅 */
  --maxWD-inner-sm: 792px; /* inner(小)の最大幅 */

  --c-text: #1e1e1e; /* テキスト */
  --c-primary: #006cc2;
  --c-second: #f8e973;
  --c-link: #0452b0;
  --c-bk-main: #0098db; /* 背景 */
  --c-bk-skyblue: #eefbff;
  --c-marker-blue: #ccf2ff;

  --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: #fefefe;
  font-size: 1rem;
  font-weight: 300;
  font-family:
    "M PLUS 1p", "游ゴシック 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;
}

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

.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 span,
#LP_camp_box h4 span,
#LP_camp_box h5 span {
  color: var(--c-primary);
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 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;
}

.sec_firstview h2 {
  width: 100%;
  margin-bottom: 0 !important;
}
div.sec_firstview h2 img {
  width: min(100%, 980px) !important;
  height: auto !important;
}

@media screen and (max-width: 768px) {
}
@media screen and (max-width: 575px) {
}

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

#LP_camp_box h3 {
  display: inline-block;
  margin-inline: auto;
  font-size: 2rem;
  font-weight: 700;
  padding-bottom: 8px;
  border-bottom: solid 3px;
  border-image: linear-gradient(
    140deg,
    rgba(88, 217, 227, 1) 0%,
    rgba(2, 78, 175, 1) 100%
  );
  border-image-slice: 1;
  margin-bottom: 1em;
}

.intro_h4_inner {
  padding-top: 12px;
  margin-inline: auto !important;
  font-style: italic;
}
.intro_h4_inner h4 p {
  line-height: 1.8;
}
.intro_h4_inner h4 p span {
  width: fit-content;
  width: -moz-fit-content;
  padding: 2px 12px;
  background: #53d0e0;
  background: linear-gradient(
    140deg,
    rgba(83, 208, 224, 1) 0%,
    rgba(27, 118, 190, 1) 100%
  );
  color: #fff !important;
}
.intro_h4_inner h4 p em {
  color: var(--c-second) !important;
}

.sec_intro .d-sm-flex {
  width: min(90%, var(--maxWD-840px)) !important;
  margin-inline: auto;
  column-gap: 1rem;
}
.sec_intro .d-sm-flex div p {
  margin-top: 1rem;
  margin-bottom: 0 !important;
}

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

@media only screen and (max-width: 575px) {
  /* タブレット・スマホ用 */
  #LP_camp_box h3 {
    font-size: 1.25rem;
    font-weight: 700;
    padding-bottom: 8px;
    margin-bottom: 1em;
  }
  .intro_h4_inner h4 p {
    width: 94%;
    margin-inline: auto !important;
    line-height: 1.8;
    text-align: left;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* CTA部分 */
.sec_cta {
  width: 100%;
  background-color: var(--c-bk-main);
}
.sec_cta p {
  margin-bottom: 0;
}

.sec_cta01 {
}
.sec_cta02 {
}

.sec_cta01 h4 {
  margin-bottom: 1rem;
}
.sec_cta02 h5 {
  font-size: 1.5rem;
  color: #fff;
  margin-bottom: 2rem;
  line-height: 1.6;
}

.sec_cta .d-sm-flex {
  width: min(92%, var(--maxWD-inner));
  margin: 0 auto;
  color: #fff;
  align-items: center;
  column-gap: 2rem;
}
.sec_cta .d-sm-flex div {
  width: 50%;
}
.sec_cta01 .d-sm-flex {
  margin-top: 1rem;
}

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

@media only screen and (max-width: 769px) {
  .sec_cta .d-sm-flex {
    column-gap: 1.5rem;
  }
}

@media only screen and (max-width: 575px) {
  /* タブレット・スマホ用 */
  .sec_cta .d-sm-flex {
    width: 86%;
    text-align: center;
  }
  .sec_cta .d-sm-flex > div:first-of-type {
    width: 100%;
    padding-right: 0;
  }
  .sec_cta .d-sm-flex > div:last-of-type {
    width: 100%;
    margin-top: 1rem;
    border-left: none;
    padding-left: 0;
  }
  .sec_cta02 h5 {
    font-size: 1.25rem;
    margin-bottom: 1rem;
    line-height: 1.5;
    text-align: left;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* div「特徴」 */
.sec_feature {
  /* 共通 */
  width: 100%;
}
.sec_feature01,
.sec_feature04 {
  background-color: var(--c-bk-skyblue);
}
.sec_feature02 {
  background-color: #efefef;
}

.sec_feature_inner {
  width: min(96%, var(--maxWD-840px));
  margin-inline: auto;
  column-gap: 2rem;
  border-radius: 0.75em;
}
.sec_feature02 .sec_feature_inner,
.sec_feature04 .sec_feature_inner {
  background-color: #fff;
  padding: 1em 2em;
}
.sec_feature03 .sec_feature_inner {
  position: relative;
  border: 1px solid #000;
  padding: 1em 2em;
  margin-inline: auto;
}
.overlap-text {
  position: absolute;
  top: 0;
  left: 50%;
  font-size: 1em;
  padding: 0 2em;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  background-color: white;
}

/* Feature Flex */
.sec_feature .Feature_flex {
  width: min(96%, var(--maxWD-840px));
  margin-inline: auto;
  padding-bottom: 3rem;
}
.sec_feature .Feature_flex {
  column-gap: 1rem;
}
.sec_feature .Feature_flex div {
  width: calc(100% / 3);
  display: inline-block;
  color: #fff;
  background: #5adbe4;
  background: linear-gradient(
    140deg,
    rgba(90, 219, 228, 1) 0%,
    rgba(11, 91, 180, 1) 100%
  );
  border-radius: 1em;
  padding: 2em;
}
.sec_feature .Feature_flex div p {
  margin-bottom: 0;
  line-height: 1.5;
}
.sec_feature .Feature_flex div p em {
  font-weight: 600;
  font-style: normal;
}

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  .overlap-text {
    padding: 0 0.5em;
  }
}

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

.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-840px));
  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-840px));
  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-840px));
  margin-inline: auto;
}
.sec_feature .Feature_img_inner p {
  margin-bottom: 0 !important;
}

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;
}

@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-840px));
  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;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* TABLE */

table.table_score {
  background-color: #f8f8f8;
}
table.table_score th {
  color: #fff !important;
  padding: 0.25em 1em;
  text-align: center;
}
table.table_score th.scoreA {
  background-color: #dcdddd;
}
table.table_score td.scoreA {
  border-bottom: 8px solid #dcdddd;
}
table.table_score th.scoreB {
  background-color: #bae3f9;
}
table.table_score td.scoreB {
  border-bottom: 8px solid #bae3f9;
}
table.table_score th.scoreC {
  background-color: #a0ceef;
}
table.table_score td.scoreC {
  border-bottom: 8px solid #a0ceef;
}
table.table_score th.scoreD {
  background-color: #5eb7e8;
}
table.table_score td.scoreD {
  border-bottom: 8px solid #5eb7e8;
}
table.table_score tr:first-of-type th {
  border-right: 1px solid #fff;
}
table.table_score tr td {
  padding: 0.25em 1em;
}
table.table_score tr td {
  border-right: solid 1px #e5e5e5;
}
table.table_score tr td:last-of-type {
  border-right: none;
}

/* --- */

.table_cancer_wrapper {
  margin-inline: auto !important;
}
table.table_cancer {
  margin-left: auto;
  margin-right: auto;
  width: fit-content;
  width: -moz-fit-content;
}
table.table_cancer tr td {
  padding: 0.25em 1em;
  border: 1px solid #aaaaaa;
}

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  table.table_score {
    overflow-x: auto;
    display: block;
  }

  table.table_score th,
  table.table_score td {
    white-space: nowrap;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ボタン */
#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;
}
.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);
}

#LP_camp_box a.btn-col_main {
  background: #ffd32c;
  background: linear-gradient(
    140deg,
    rgba(255, 211, 44, 1) 0%,
    rgba(255, 103, 29, 1) 100%
  );
  color: #fff;
}
#LP_camp_box a.btn-col_rev {
  background: #fff;
  border: 1px solid var(--c-link);
  color: var(--c-link);
}
#LP_camp_box a.btn-col_mono {
  background-color: #fff;
  color: var(--c-primary);
  border: 2px solid;
  border-color: var(--c-primary);
}

#LP_camp_box a.btn_w400 {
  max-width: 400px;
}

@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;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 総合問い合わせ */

@media only screen and (max-width: 599px) {
  /* スマホ用 */
  div.Vets_SupportDesk_wrapper {
    padding: 16px !important;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ムービー用Div指定(全体) */
.sec_movie {
  width: 100%;
  background-color: var(--c-bk-skyblue);
}
/* ムービー用Div指定(単体) */
.sec_movie .LP_movie_box {
  margin-inline: auto;
  text-align: center;
}
.sec_movie .LP_movie_box p {
  margin-bottom: 0;
}

/* ムービー用Div指定(共通) */
.LP_movie_box .movie-wrap {
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}
.LP_movie_box .inner {
  padding-top: 56.25%;
  position: relative;
  height: 0;
  overflow: hidden;
}
.LP_movie_box iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ムービーの幅指定(単体) */
@media (min-width: 960px) {
  /* PC用 */
  .sec_movie .movie-wrap {
    width: 560px;
  }
  .sec_movie iframe {
    width: 560px !important;
    height: 315px !important;
  }
}

@media only screen and (max-width: 959px) {
  /* スマホ用 */
  .sec_movie .movie-wrap {
    width: 90%;
  }
}
