@charset "UTF-8";

body {
  width: 100%;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  color: #505050;
  line-height: 1.5;
}

a {
  text-decoration: none;
  color: #505050;
}

.cf:after {
  display: block;
  content: "";
  clear: both;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

.img-border {
  padding: 4px;
  border: 1px solid #ccc;
  background: #fff;
  box-sizing: border-box;
}

.img-right {
  float: right;
  margin: 0 0 10px 15px;
  width: 44%;
}

.img-left {
  float: left;
  margin: 0 15px 10px 0;
  width: 44%;
}

/*.fNavi-wrap ul li:nth-child(2) a{position:relative;}

.fNavi-wrap ul li:nth-child(2) a:before{content: '24時間受付中';color: #ff5757;font-size: 13px;display:block;position:absolute;left:50%;transform:translateX(-50%);white-space:nowrap;background: #ffef77;padding: 3px 7px 1px;border-radius: 5px;top: -13px;font-weight: bold;}

.fNavi-wrap ul li:nth-child(2) a:after{

  content:'';

  width: 0;

  height: 0;

  border-style: solid;

  border-right: 8px solid transparent;

  border-left: 8px solid transparent;

  border-top: 8px solid #ffef77;

  border-bottom: 0;

  position:absolute;

  left:50%;

  transform:translateX(-50%);

  top: 9px;

  }*/
.grecaptcha-badge {
  visibility: hidden;
}

.pagetop {
  position: fixed;
  right: 10px;
  bottom: 60vw;
  width: 14.93333vw;
  box-shadow: 0px 14px 18px 0px rgba(167, 165, 161, 0.23);
  border-radius: 14.93333vw;
  z-index: 1000;
}

.marker {
  background: linear-gradient(transparent 60%, #fff5d5 60%);
}

iframe[name*="vgdataMainFrm"] {
  top: 50% !important;
  transform: translate(0, -50%);
}

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



	01. header(multinfo)

	02. menu

	03. callbox

	04. menu

	05. footer

	06. reservebanner (low only)

	07. low-common-design(low only)



	08.multi-class



	10. 404 error



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

	01. header (multinfo)

========================================================================== */
/*header {
  display: flex;
  justify-content: space-between;
  padding: 0 3.2vw 3.6vw 4.933333vw;
}
header .h_logo {
  width: 52.13333vw;
  margin-top: 9.76667vw;
}
header .h_menu {
  margin-top: 6.7vw;
  width: 14.53333vw;
  position: relative;
  z-index: 2;
}
header h1 {
  position: absolute;
  font-size: 2.6vw;
  line-height: 1;
  margin-top: 2.2vw;
  left: 5.2vw;
  padding-right: 3.2vw;
  z-index: 1;
}
header + .translate {
  display: flex;
  column-gap: 5px;
  align-items: center;
  justify-content: flex-end;
  margin: 0 3.2vw 3.6vw 0;
}
header + .translate > img {
  width: 20px;
  aspect-ratio: 1/1;
}*/
/*

	kv

========================================================================== */
.kv {
  margin-bottom: 5%;
}

section.trial_low {
  padding: 0 4vw;
  margin-bottom: 7.2vw;
}

/*

	nav

========================================================================== */
/*.gnav {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(19, 186, 255, 0.9);
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: 0 4.933333% 3.2%;
  z-index: 9999;
}
.gnav .h_logo {
  width: 39.73333vw;
  margin: 7.86667vw 0 14%;
}
.gnav .h_menu {
  width: 17.2%;
  position: absolute;
  top: 0;
  right: 0;
}
.gnav ul {
  height: 70%;
  overflow-y: scroll;
  margin-bottom: 8%;
}
.gnav ul li {
  font-size: 15px;
  line-height: 1em;
  border-bottom: 1px dashed #FFFFFF;
}
.gnav ul li a {
  color: #FFFFFF;
  padding: 1.25em 1em 1em 1em;
  display: block;
}
.gnav .nav_btn {
  display: flex;
  justify-content: center;
}
.gnav .nav_btn div + div {
  margin-left: 4vw;
}
.gnav .nav_btn img {
  height: 8.4vw;
  width: auto;
}
.gnav .nav_btn div.line img {
  background: #62d759;
}
.gnav .nav_btn div.web img {
  background: #f2a899;
}*/
/*

	menu

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

	banner

========================================================================== */
.banner {
  padding: 4vw 3.33333% 16%;
}

.banner ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.banner li:nth-child(-n+2) {
  width: 100%;
  margin-bottom: 3.2%;
}

.banner li:nth-child(n+3) {
  width: 48.57142%;
}

.bnr_remote {
  margin: 0 auto;
  width: 97.73333vw;
}

/*

	search

========================================================================== */
/*.search {
  margin-top: 5%;
  margin-bottom: 15%;
}
.search .fig {
  width: 49.333vw;
  margin: 0 0 5vw 28.4%;
}
.search h2 {
  width: 82.57142%;
  margin: 0 auto 5.5%;
}
.search .clinicpref {
  width: fit-content;
  font-size: 4vw;
  padding: 0em 0.5em;
  margin: 0px auto 6vw;
  text-align: center;
  line-height: 1.8;
}
.search .clinicpref .acc-l {
  display: inline-block;
  background: url(../../images/top/quotation01.png) no-repeat top left;
  background-size: 0.7em auto;
  padding-left: 0.95em;
}
.search .clinicpref .acc-r {
  display: inline-block;
  background: url(../../images/top/quotation02.png) no-repeat top right 0.1em;
  background-size: 1.05em auto;
  padding-right: 1.25em;
}
.search .clinicpref .br01 {
  display: none;
}
.search .clinicpref .marker {
  display: inline-block;
  line-height: 1.3;
}
.search select {
  display: block;
  width: 70%;
  height: 32px;
  margin: 0 auto;
  border: none;
  border: 1px solid #cce2eb;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: #505050;
  font-size: 16px;
  box-sizing: border-box;
  padding: 0 0.5em;
  background: url(../images/common/select_arrow.png) no-repeat right center;
  background-size: 35px;
  cursor: pointer;
}
.search select::-ms-expand {
  display: none;
}*/
/*

	footer

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

     06. reservebanner (low only)

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

     07. low-common-design(low only)

 ========================================================================== */
.sp-contents {
  padding: 0 10px;
}

.mainPhoto {
  width: 100%;
  margin-bottom: 8px;
}

.mainPhoto img {
  width: 100%;
  height: auto;
}

.breadcrumb {
  width: 100%;
  box-sizing: border-box;
}

.page-catch {
  margin: 0 auto 30px;
  text-align: center;
  font-size: 14px;
  font-family: "Times New Roman", Times, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  border: 1px solid #b9a66f;
  padding: 30px 15px 25px;
  box-shadow: 0 10px 6px -6px rgba(211, 239, 249, 0.31);
}

/*

       08. multi-class

========================================================================== */
#sidr ul li {
  line-height: 1.2;
}

#sidr ul li a {
  display: block;
  padding: 18px 10px;
}

.gothic {
  font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.mincho {
  font-family: "Times New Roman", Times, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.ryumin {
  font-family: 'リュウミン M-KL', 'Ryumin Medium KL';
}

.yu-go {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

.thonburi {
  font-family: "Thonburi", sans-serif;
}

.center {
  text-align: center;
}

.alignR {
  text-align: right !important;
}

.alignL {
  text-align: left !important;
}

.bold,
.bold * {
  font-weight: bold;
}

.italic {
  font-style: italic;
}

.dispB {
  display: block;
}

.dispIB {
  display: inline-block;
}

.sp-none {
  display: none !important;
}

.txt60 {
  font-size: 60%;
}

.txt65 {
  font-size: 65%;
}

.txt70 {
  font-size: 70%;
}

.txt75 {
  font-size: 75%;
}

.txt80 {
  font-size: 80%;
}

.txt85 {
  font-size: 85%;
}

.txt90 {
  font-size: 90%;
}

.txt95 {
  font-size: 95%;
}

.txt110 {
  font-size: 110%;
}

.txt115 {
  font-size: 115%;
}

.txt120 {
  font-size: 120%;
}

.txt127 {
  font-size: 127%;
}

.txt130 {
  font-size: 130%;
}

.txt136 {
  font-size: 136%;
}

.txt140 {
  font-size: 140%;
}

.txt145 {
  font-size: 145%;
}

.txt150 {
  font-size: 150%;
}

.txt155 {
  font-size: 155%;
}

.txt160 {
  font-size: 160%;
}

.txt166 {
  font-size: 166%;
}

.txt170 {
  font-size: 170%;
}

.txt190 {
  font-size: 190%;
}

.txt200 {
  font-size: 200%;
}

.txt230 {
  font-size: 230%;
}

.txt240 {
  font-size: 240%;
}

.fs10 {
  font-size: 10px;
}

.fs11 {
  font-size: 11px;
}

.fs12 {
  font-size: 12px;
}

.fs13 {
  font-size: 13px;
}

.fs14 {
  font-size: 14px;
}

.fs15 {
  font-size: 15px;
}

.fs16 {
  font-size: 16px;
}

.fs17 {
  font-size: 17px;
}

.fs18 {
  font-size: 18px;
}

.fs19 {
  font-size: 19px;
}

.fs20 {
  font-size: 20px;
}

.fs21 {
  font-size: 21px;
}

.fs22 {
  font-size: 22px;
}

.fs24 {
  font-size: 24px;
}

.fs25 {
  font-size: 25px;
}

.fs26 {
  font-size: 26px;
}

.fs27 {
  font-size: 27px;
}

.fs28 {
  font-size: 28px;
}

.fs29 {
  font-size: 29px;
}

.fs30 {
  font-size: 30px;
}

.fs32 {
  font-size: 32px;
}

.fs33 {
  font-size: 33px;
}

.fs34 {
  font-size: 34px;
}

.fs35 {
  font-size: 35px;
}

.fs36 {
  font-size: 36px;
}

.fs37 {
  font-size: 37px;
}

.fs38 {
  font-size: 38px;
}

.fs39 {
  font-size: 39px;
}

.fs40 {
  font-size: 40px;
}

.fs41 {
  font-size: 41px;
}

.fs42 {
  font-size: 42px;
}

.fs43 {
  font-size: 43px;
}

.fs44 {
  font-size: 44px;
}

.fs46 {
  font-size: 46px;
}

.fs47 {
  font-size: 47px;
}

.fs48 {
  font-size: 48px;
}

.fs49 {
  font-size: 49px;
}

.fs53 {
  font-size: 53px;
}

.fs54 {
  font-size: 54px;
}

.fs57 {
  font-size: 57px;
}

.fs58 {
  font-size: 58px;
}

.fs60 {
  font-size: 60px;
}

.fs63 {
  font-size: 63px;
}

.fs64 {
  font-size: 64px;
}

.fs65 {
  font-size: 65px;
}

.fs66 {
  font-size: 66px;
}

.fs67 {
  font-size: 67px;
}

.fs76 {
  font-size: 76px;
}

.fs77 {
  font-size: 77px;
}

.fs78 {
  font-size: 78px;
}

.fs79 {
  font-size: 79px;
}

.fs81 {
  font-size: 81px;
}

.fs83 {
  font-size: 83px;
}

.fs90 {
  font-size: 90px;
}

.fs98 {
  font-size: 98px;
}

.fs99 {
  font-size: 99px;
}

.fs101 {
  font-size: 101px;
}

.fs106 {
  font-size: 106px;
}

.fs109 {
  font-size: 109px;
}

.fs115 {
  font-size: 115px;
}

.fs127 {
  font-size: 127px;
}

.underline {
  text-decoration: underline;
}

.dot {
  text-emphasis-style: dot;
  -webkit-text-emphasis-style: filled;
  -moz-text-emphasis-style: filled;
  -ms-text-emphasis-style: filled;
}

.re {
  color: #e32c03;
}

.re2 {
  color: #ff133a;
}

.re3 {
  color: #ff4116;
}

.re4 {
  color: #ff3a0f;
}

.pk {
  color: #ffaa97;
}

.pk2 {
  color: #ff9d88;
}

.pk3 {
  color: #ff886f;
}

.pk4 {
  color: #FD8F76;
}

.pk5 {
  color: #ff7657;
}

.pk6 {
  color: #ff866a;
}

.pk7 {
  color: #ff9279;
}

.pk8 {
  color: #ffa692;
}

.pk9 {
  color: #ff9780;
}

.or {
  color: #ff856b;
}

.or2 {
  color: #ff5d1d;
}

.or3 {
  color: #ff6000;
}

.or4 {
  color: #ff9d72;
}

.or5 {
  color: #ff8a34;
}

.or6 {
  color: #ff9920;
}

.bl {
  color: #13baff;
}

.bl2 {
  color: #00b4ff;
}

.bl3 {
  color: #06a2e2;
}

.gray {
  color: #6d6d6d;
}

.p10 {
  padding: 10px;
}

.pt10 {
  padding-top: 10px;
}

.pr10 {
  padding-right: 10px;
}

.pl10 {
  padding-left: 10px;
}

.pb10 {
  padding-bottom: 10px;
}

.mb5 {
  margin-bottom: 5px;
}

.mb10 {
  margin-bottom: 10px;
}

.mb15 {
  margin-bottom: 15px;
}

.mb20 {
  margin-bottom: 20px;
}

.mb30 {
  margin-bottom: 30px;
}

.mb40 {
  margin-bottom: 40px;
}

.mb50 {
  margin-bottom: 50px;
}

.mb60 {
  margin-bottom: 60px;
}

.mt5 {
  margin-top: 5px;
}

.mt10 {
  margin-top: 10px;
}

.mt20 {
  margin-top: 20px;
}

.mt30 {
  margin-top: 30px;
}

.mr5 {
  margin-right: 5px;
}

.mr10 {
  margin-right: 10px;
}

.mr15 {
  margin-right: 15px;
}

.mr20 {
  margin-right: 20px;
}

.mr30 {
  margin-right: 30px;
}

.ml5 {
  margin-left: 5px;
}

.ml10 {
  margin-left: 10px;
}

.ml15 {
  margin-left: 15px;
}

.ml20 {
  margin-left: 20px;
}

.ml30 {
  margin-left: 30px;
}

#point {
  background: url(../images/common/point_bg.png) repeat top left;
  background-size: 1.2vw;
  padding: 6.4vw 3.2vw;
  width: 96%;
  margin: 10vw auto 0;
  box-sizing: border-box;
}

#point .inner {
  background: #FFFFFF;
  border-radius: 8px;
  box-shadow: 0px 7px 24px 0px rgba(203, 222, 233, 0.14);
  padding: 8vw 4.8vw;
}

#point h2 {
  color: #13baff;
  font-size: 14px;
  border-bottom: 1px dashed #8c8c8c;
  font-weight: 600;
  padding: 0 0.5em 0.75em;
  margin-bottom: 1.5em;
}

#point ul {
  padding: 0 1em;
}

#point li + li {
  margin-top: 2.5em;
}

#point h3 {
  font-size: 14px;
  font-weight: 600;
  line-height: 1em;
  margin-bottom: 0.75em;
}

#point h3 span {
  color: #13baff;
  display: inline-block;
  margin-right: 0.75em;
}

#point p {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.625em;
}

#point li ul + h4 {
  margin-top: 0.75em;
}

#point li li {
  margin-top: 0;
}

#popup {
  display: none;
  position: fixed;
  z-index: 9999;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  padding: 4em 5vw 2em;
  background: #fff;
  box-shadow: 0px 0px 20px #ccc;
  box-sizing: border-box;
  max-width: 95vw;
  max-height: 90vh;
  overflow-y: auto;
  font-size: 3.4vw;
}

#popup .table_wrap {
  width: 80vw;
}

#popup table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}

#popup table th {
  text-align: center;
  background: #E2E2E2;
  font-size: 15px;
  padding: 6px 12px;
  border: 1px solid #ccc;
  vertical-align: middle;
}

#popup table td {
  background: #fff;
  padding: 6px 7px;
  border: 1px solid #ccc;
  vertical-align: middle;
  width: 50%;
}

#popup label {
  cursor: pointer;
}

#popup .close.btn {
  position: absolute;
  right: 10px;
  top: 10px;
  width: 3em;
  height: 3em;
  cursor: pointer;
}

#popup .close.btn::before,
#popup .close.btn::after {
  position: absolute;
  content: "";
  border-bottom: 2px solid #8c8c8c;
  top: 50%;
  left: 50%;
  width: 2.5em;
}

#popup .close.btn::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

#popup .close.btn::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.influencer {
  padding: 0 2%;
  margin: 10vw 0;
}

section.maker_notice {
  font-size: 3.6vw;
  line-height: 1.8;
  padding-bottom: 12vw;
}

section.maker_notice h2 {
  font-size: 140%;
  line-height: 1;
  margin-bottom: 0.5em;
}
