@charset "UTF-8";
/* CSS Document */

/* 見出し共通 */
.md-type3 {
  font-size: 120%;
  color: #6e4c40;
  font-weight: 600;
}
@media (max-width : 500px) {
  .md-type3 {
    font-size: 110%;
  }
}
.dd-line {
  border-bottom: dotted 1.5px;
  padding-bottom: 8px;
  margin-bottom: 8px;
}
@media (max-width : 500px) {
  .dd-line {
    padding-bottom: 4px;
    margin-bottom: 4px;
  }
}
.beta span {
  color: #fff;
  padding: 3px 15px 5px;
}
.betamds span {
  color: #fff;
  padding: 3px 15px 5px;
}
@media (max-width : 500px) {
  .betamds span {
    padding: 1px 12px 2px;
  }
}
.txbg {
  padding: 36px 40px 40px;
  background-color: #f5f4f3;
}
@media (max-width : 500px) {
  .txbg {
    padding: 20px;
  }
  .betamds + .txbg {
    padding: 30px 20px 20px;
  }
}
.whitebg {
  padding: 30px;
  background-color: #fff;
}
@media (max-width : 500px) {
  .whitebg {
    padding: 20px;
  }
}
.table-img-wrap {
  display: table;
  margin-left: auto;
  margin-right: auto;
}
.fs120 { font-size: 120%;}
.fs130 { font-size: 130%;}
@media (max-width : 500px) {
  .fs120 { font-size: 110%;}
  .fs130 { font-size: 120%;}
}

h2.medical {
  color: #7c0404;
  text-align: center;
  font-size: 166%;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  line-height: 1.4em;
}
@media (max-width : 500px) {
  h2.medical {
    font-size: 131%;
  }
}
h2.medical span.circle {
  position: relative;
}
h2.medical span.circle::before {
	content: "";
	display: inline-block;
	width: 98px;
	height: 98px;
  border-radius: 50%;
  background-color: #f1e3e3;
	position: absolute;
	top: -25px;
	left: -50px;
  z-index: -1;
}
@media (max-width : 500px) {
  h2.medical span.circle::before {
    width: 60px;
	  height: 60px;
    top: -15px;
	  left: -25px;
  }
}
h2.medical span.notice {
  font-size: 60%;
}

.explanation-wrap {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  margin-top: 50px;
}
@media (max-width : 500px) {
  .explanation-wrap {
    display: block;
    margin-top: 15px;
  }
}
/*
.explanation-wrap .icns {
  display: flex;
  justify-content: center;
}
.explanation-wrap.m01 .icns {
  width: 20%;
}
.explanation-wrap.m02 .icns {
  width: 18%;
}
@media (max-width : 500px) {
  .explanation-wrap.m01 .icns,
  .explanation-wrap.m02 .icns {
    width: 30%;
    margin-left: auto;
    margin-right: auto;
  } 
}
.explanation-wrap.m01 .lead {
  width: 74%;
}
.explanation-wrap.m02 .lead {
  width: 76%;
}
@media (max-width : 500px) {
  .explanation-wrap.m01 .lead,
  .explanation-wrap.m02 .lead {
    width: 100%;
    padding-top: 15px;
    text-align: justify;
  }
}
*/
.explanation-wrap .imgs {
  width: 35%;
}
.explanation-wrap .imgs.shadow img {
  box-shadow: 15px 15px 0px 0px #ece8e7;
}
@media (max-width : 500px) {
  .explanation-wrap .imgs {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  .explanation-wrap .imgs.shadow img {
    box-shadow: 10px 10px 0px 0px #ece8e7;
  }
}
.explanation-wrap .lead {
  width: 60%;
}
@media (max-width : 500px) {
  .explanation-wrap .lead {
    width: 100%;
    padding-top: 20px;
     text-align: justify;
  }
}
.explanation-wrap .order1 {
  order: 1;
}
.explanation-wrap .order2 {
  order: 2;
}
@media (max-width : 500px) {
  .explanation-wrap .order1 {
    margin-top: 20px;
  }
  .explanation-wrap .order2 {
    padding-top: 0px;
  }
}

.main-symptoms {
  width: 100%;
  /*background-color: #f9f8f7;*/
  background-color: rgba(64,33,15,0.05);
  padding: 60px 40px 70px 40px;
  margin-top: 70px !important;
}
@media (max-width : 500px) {
  .main-symptoms {
    margin-top: 50px !important;
    padding: 30px 0 35px 0;
  }
}
.main-symptoms h2 {
  color: #40210f;
  text-align: center;
  font-size: 166%;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  line-height: 1.2em;
}
@media (max-width : 500px) {
  .main-symptoms h2 {
    font-size: 130%;
    width: 80%;
    text-align: left;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 10px;
    border-bottom: #40210f solid 2px;
  }
}
.main-symptoms h2 span {
  position: relative;
  display: inline-table;
}
.main-symptoms h2 span::before,
.main-symptoms h2 span::after {
  content: "";
  display: inline-block;
  position: absolute;
  background-color: #40210f;
  width: 110px;
  height: 3px;
  top: 50%;
}
@media (max-width : 500px) {
  .main-symptoms h2 span::before,
  .main-symptoms h2 span::after {
    content: none;
  }
  .main-symptoms h2 {
    position: relative;
  }
  .main-symptoms span {
    display: table;
    margin-left: auto;
    margin-right: auto;
  }
  .main-symptoms h2.mm01 span {
    padding-left: 96px;
  }
  .main-symptoms h2.mm01::before {
    content: "";
    display: inline-block;
    width: 44px;
    height: 52px;
    background-image: url("../medical/images/icn01.png");
    background-size: contain;
    position: absolute;
    top: 1px;
    left: 40px;
}
  .main-symptoms h2.mm02 span{
    padding-left: 63px;
  }
  .main-symptoms h2.mm02::before {
    content: "";
    display: inline-block;
    width: 38px;
    height: 52px;
    background-image: url("../medical/images/icn02.png");
    background-size: contain;
    position: absolute;
    top: 2px;
    left: 16px;
}
}
.main-symptoms h2 span::before {
  left: -130px;
}
.main-symptoms h2 span::after {
  right: -130px;
}
.main-symptoms p {
  color: #7c0404;
  text-align: center;
  padding-top: 10px;  
}
ul.symptoms {
  max-width: 1000px;
  display: flex;
  flex-wrap: wrap;
  margin-left: auto;
  margin-right: auto;
  margin-top: 30px;
}
.regular-vaccinations ul.symptoms {
  max-width: 1200px;
  margin-top: 0px;
}
@media (max-width : 500px) {
  ul.symptoms {
    margin-top: 16px;
    padding-left: 20px;
    padding-right: 20px;
    justify-content: space-between;
  }
  .regular-vaccinations ul.symptoms {
    padding-left: 0px;
    padding-right: 0px;
  }
}
ul.symptoms li {
  width: 32%;
  margin-top: 10px;
  margin-right: 2%;
  background-color: rgba(255,255,255,1.00);
  padding: 12px 15px 12px 30px;
  line-height: 1.4em;
}
ul.symptoms li:nth-child(3n) {
  margin-right: 0;
}
.regular-vaccinations ul.symptoms li {
  background-color: #f9f8f7;
}
@media (max-width : 900px) {
  ul.symptoms {
    justify-content: space-between;
  }
  ul.symptoms li {
    width: 49.2%;
    margin-right: 0;
  }
}
@media (max-width : 500px) {
  ul.symptoms li {
    width: 49%;
    margin-top: 6px;
    margin-right: 0;
    padding: 10px 15px 10px 30px;
  }
  .regular-vaccinations ul.symptoms li {
    width: 100%;
  }
}
ul.symptoms li span {
  position: relative;
  padding-left: 10px;
  width: 100%;
}
ul.symptoms li span::before {
  content: "";
  display: inline-block;
  position: absolute;
  background-color: #7c0404;
  width: 7px;
  height: 7px;
  left: -4px;
  top: 12px;
}
@media (max-width : 500px) {
  ul.symptoms li span {
    padding-left: 0px;
  }
  ul.symptoms li span::before {
    left: -14px;
    top: 9px;
  }
}

.examples h2 {
  margin-top: 90px;
}
@media (max-width : 500px) {
  .examples h2 {
    margin-top: 40px;
  }
}
.examples .examples-box {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 50px 50px 50px;
  border: #939393 solid 1px;
  box-shadow: 15px 15px 0px 0px #ece8e7;
  margin-top: 110px;
  border-radius: 15px;
}
.examples .examples-box:nth-of-type(1) {
  margin-top: 80px;
}
@media (max-width : 500px) {
  .examples .examples-box {
    padding: 0 20px 30px 20px;
    box-shadow: 10px 10px 0px 0px #ece8e7;
    margin-top: 60px;
    border-radius: 10px;
  }
  .examples .examples-box:nth-of-type(1) {
    margin-top: 40px;
  }
}
.examples .examples-box h3 {
  color: #fff;
  background-color: #6e4c40;
  display: table;
  margin-left: auto;
  margin-right: auto;
  font-size: 145%;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  padding: 8px 56px 10px 56px;
  position: relative;
  z-index: 1;
  top: -22px;
  box-shadow: 7px 7px 0px 0px #d2c8c4;
}
@media (max-width : 500px) {
  .examples .examples-box h3 {
    font-size: 125%;
    padding: 5px 36px 7px 36px;
  }
}
.examples .examples-box .flex-inner {
  display: flex;
  justify-content: space-between;
}
@media (max-width : 500px) {
  .examples .examples-box .flex-inner {
    display: block;
  }
}
.examples .examples-box .flex-inner .leadbox {
  width: 67%;
  order: 1;
  text-align: justify;
}
.examples .examples-box .flex-inner .leadbox p:nth-of-type(n+2) {
  padding-top: 25px;
}
@media (max-width : 500px) {
  .examples .examples-box .flex-inner .leadbox {
    width: 100%;
    padding-top: 13px;
  }
}
.examples .examples-box .flex-inner .imgs {
  width: 26%;
  order: 2;
}
@media (max-width : 500px) {
  .examples .examples-box .flex-inner .imgs {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}
.examples .examples-box table.costs {
  margin-top: 30px;
}
h4.mtype04 + table.costs {
  margin-top: 0px !important;
}

.btns {
  display: flex;
}
.btns li:nth-of-type(n+2) {
  margin-left: 15px;
}
@media (max-width : 500px) {
  .btns {
    display: block;
  }
  .btns li:nth-of-type(n+2) {
    margin-left: 0;
    margin-top: 10px;
  }
}

.btn {
  display: table;
  position: relative;
}
.btn.mla {
  margin-left: auto;
}
@media (max-width : 500px) {
  .btn {
    margin-left: auto;
    margin-right: auto;
  }
  .btns > .btn {
    margin-left: inherit;
  }
  .btn.mla {
    margin-right: 0;
  }
}
.btn a {
  display: block;
  /*color: #7c0404;*/
  border: #000 solid 1px;
  padding: 8px 25px 10px 45px;
  border-radius: 50vh;
  line-height: 1.3em;
  position: relative;
  font-size: 90%;
  background-color: #fff;
  
}
@media (max-width : 500px) {
  .btn a {
    padding: 8px 25px 10px 48px;
  }
}
.btn a:hover {
  background-color: rgba(123,4,4,0.2)
}

.examples .examples-box h4.mtype01 {
  text-align: center;
  padding-top: 60px;
  padding-bottom: 60px;
  color: #40210f;
  font-size: 160%;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
}
@media (max-width : 500px) {
  .examples .examples-box h4.mtype01 {
    padding-top: 30px;
    padding-bottom: 30px;
    font-size: 130%;
    font-weight: 600;
  }
}
.examples .examples-box h4.mtype02 {
  text-align: center;
  padding-bottom: 10px;
  color: #7c0404;
  font-size: 150%;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  border-bottom: #939393 solid 1px;
  margin-bottom: 8px;
}
@media (max-width : 500px) {
  .examples .examples-box h4.mtype02 {
    font-size: 130%;
  }
}
.examples .examples-box h4.mtype03 {
  padding-bottom: 10px;
  color: #40210f;
  font-size: 130%;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  position: relative;
}
@media (max-width : 500px) {
  .examples .examples-box h4.mtype03 {
    margin-top: 25px;
    padding-bottom: 4px;
    font-size: 115%;
  }
}
.examples .examples-box h4.mtype03:nth-of-type(2) {
  border-top: #939393 solid 1px;
  margin-top: 80px;
  padding-top: 80px;
}
@media (max-width : 500px) {
  .examples .examples-box h4.mtype03:nth-of-type(2) {
    margin-top: 40px;
    padding-top: 30px;
  }
}
.examples .examples-box h4.mtype04 {
  color: #40210f;
  font-size: 100%;
  font-weight: 600;
  position: relative;
  padding-bottom: 4px;
  margin-top: 25px;
}
.examples .examples-box h5 {
  margin-top: 25px;
  margin-bottom: 4px;
}
.examples .examples-box h5 span {
  color: #fff;
  background-color: #6e4c40;
  font-weight: 500;
  padding: 3px 15px 5px 15px;
}
.examples .examples-box .flex-inner .hbox {
  width: 48%;
}
@media (max-width : 500px) {
  .examples .examples-box .flex-inner .hbox {
    width: 100%;
  }
  .examples .examples-box .flex-inner .hbox:nth-of-type(n+2) {
    padding-top: 60px;
  }
}
ul.ultype01 {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
}
ul.ultype01 li {
  position: relative;
  padding-left: 22px;
  width: 33%;
  margin-top: 5px;
}
@media (max-width : 500px) {
  ul.ultype01 {
    display: block;
  }
  ul.ultype01 li {
    width: 100%;
    padding-left: 18px;
  }
}
ul.ultype01 li::before {
  content: "";
  display: inline-block;
  position: absolute;
  background-color: #40210f;
  width: 18px;
  height: 18px;
  border-radius: 50vh;
  left: 0px;
  top: 8px;
}
@media (max-width : 500px) {
  ul.ultype01 li::before {
    width: 14px;
    height: 14px;
    top: 7px
  }
}


/* 予防接種 
------------------------ */
#vaccination section:nth-of-type(n+2) {
  margin-top: 120px;
}
@media (max-width : 500px) {
  #vaccination section:nth-of-type(n+2) {
    margin-top: 40px;
  }
}
#vaccination ul.pagelink {
  max-width: 1030px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-left: auto;
  margin-right: auto;
  margin-top: 30px;
}
@media (max-width : 500px) {
  #vaccination ul.pagelink {
    display: block;
    padding-left: 20px;
    padding-right: 20px;
  }
}
#vaccination ul.pagelink li {
  text-align: center;
}
#vaccination ul.pagelink li:nth-of-type(1) {
  width: 37%;
}
#vaccination ul.pagelink li:nth-of-type(2) {
  width: 15%;
}
#vaccination ul.pagelink li:nth-of-type(3) {
  width: 18%;
}
#vaccination ul.pagelink li:nth-of-type(4) {
  width: 21%;
}
@media (max-width : 900px) {
  #vaccination ul.pagelink li {
    width: 49% !important;
    text-align: left;
    margin-top: 6px;
  }
}
@media (max-width : 500px) {
  #vaccination ul.pagelink li {
    width: 100% !important;
    text-align: left;
  }
  #vaccination ul.pagelink li span {
    width: 100% !important;
  }
  #vaccination ul.pagelink li:nth-of-type(n+2) {
    margin-top: 6px;
    text-align: left !important
  }
}
#vaccination ul.pagelink li a {
  display: block;
  background-color: rgba(255,255,255,1.00);
  padding: 12px 35px 12px 15px;
}
#vaccination ul.pagelink li a:hover {
  background-color: rgba(124,4,4,0.1);
}
@media (max-width : 500px) {
  #vaccination h2.mm03 span {
    padding-left: 80px;
    position: relative;
  }
  #vaccination h2.mm03::before {
    content: "";
    display: inline-block;
    width: 70px;
    height: 70px;
    background-image: url("../images/icn04.svg");
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 1px;
    left: 16px;
  }
}
/*
table.t-type1 {
	width: 100%;
  border-collapse: collapse;
	border-left: #000 solid 1px;
}
@media (max-width : 500px) {
  
}
table.t-type1 th,
table.t-type1 td {
	padding: 11px 14px;
	border-bottom: #000 solid 1px;
	border-top: #000 solid 1px;
	border-right: #000 solid 1px;
	vertical-align: middle;
  line-height: 1.5em;
}
table.t-type1 th {
  background-color: #f5ebeb;
  text-align: left;
}
table.t-type1 .dan {
  padding-top: 18px;
}
table.t-type1 .flex-wrap {
  display: flex;
}
table.t-type1 .flex-wrap .box:nth-of-type(2) {
  padding-left: 80px;
}
*/
dl.table-type {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  border-bottom: #000 solid 1px;
}
@media (max-width : 500px) {
  dl.table-type {
    display: block;
  }
}
dl.table-type dt,
dl.table-type dd {
  padding: 8px 14px;
}
dl.table-type dt {
  width: 18%;
  background-color: #f5ebeb;
	border-top: #000 solid 1px;
	border-right: #000 solid 1px;
  border-left: #000 solid 1px;
}
dl.table-type dd {
  width: 82%;
  border-top: #000 solid 1px;
  border-right: #000 solid 1px;
}
@media (max-width : 500px) {
  dl.table-type dt,
  dl.table-type dd {
    width: 100%;
    padding: 8px 10px;
  }
  dl.table-type dd {
    border-left: #000 solid 1px;
  }
}
dl.table-type dd h3 {
  color:#ff5a27;
  font-weight: 600;
}
dl.table-type dd h4 {
  font-weight: 600;
  border-bottom: dotted 1.5px;
}
dl.table-type dd .dan {
  padding-top: 18px;
}
dl.table-type dd .flex-wrap {
  display: flex;
}
dl.table-type dd .flex-wrap .box:nth-of-type(2) {
  padding-left: 80px;
}
@media (max-width : 500px) {
  dl.table-type dd .flex-wrap {
   justify-content: space-between; 
  }
  dl.table-type dd .flex-wrap .box {
    width: 46%;
  }
  dl.table-type dd .flex-wrap .box:nth-of-type(2) {
    padding-left: 0px;
  }
}

/* 鼻から胃カメラ検査
------------------------ */
#hanaikamera .low-common {
  padding-bottom: 120px;
}
@media (max-width : 500px) {
  #hanaikamera .low-common {
    padding-bottom: 60px;
  }
}
#hanaikamera .btn-box {
  padding-top: 30px;
}
@media (max-width : 500px) {
  #hanaikamera .btn-box {
    display: table;
    margin-left: auto;
    margin-right: auto;
  }
  #hanaikamera .btn-box p {
    line-height: 1.3em;
    text-align: center;
    padding-top: 6px;
  }
}

#hanaikamera .cont-wrap {
  display: flex;
  justify-content: space-between;
  padding: 60px 20px;
  border-top: dotted 1.5px;
}
@media (max-width : 500px) {
  #hanaikamera .cont-wrap {
    display: block;
    padding: 30px 0;
  }
}
@media (min-width : 500px) {
#hanaikamera .cont-wrap .mdwrap {
  width: 220px;
  height: 220px;
  border-radius: 50vh;
  background-color: #f2e5e5;
  display: flex;
  justify-content: center;
  align-items: center;
}
}
#hanaikamera .cont-wrap .mdwrap h2 {
  color: #7c0404;
  font-size: 160%;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  line-height: 1.1em;
}
@media (max-width : 500px) {
  #hanaikamera .cont-wrap .mdwrap h2 {
    margin-bottom: 20px;
  }
}
#hanaikamera .cont-wrap .mdwrap h2 span.j {
  font-size: 70%;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
}
@media (min-width : 500px) {
  #hanaikamera .cont-wrap .mdwrap h2 span.j {
    display: block;
  }
}
@media (max-width : 500px) {
  #hanaikamera .cont-wrap .mdwrap h2 span.line {
    background: linear-gradient(transparent 50%, #f5ebeb 50%);
	  padding-left: 40px;
	  padding-right: 40px;
	  padding-bottom: 5px;
  }
}

#hanaikamera .cont-wrap .cont {
  width: 70%;
}
@media (max-width : 500px) {
  #hanaikamera .cont-wrap .cont {
    width: 100%;
  }
}

#hanaikamera .features {
  display: flex;
  flex-wrap: wrap;
}
@media (max-width : 500px) {
  #hanaikamera .features {
    display: block;
  }
}
#hanaikamera .features dt {
  max-width: 280px;
  width: 40%;
  position: relative;
}
#hanaikamera .features dd {
  width: 60%;
  padding-left: 10px;
}
@media (max-width : 500px) {
  #hanaikamera .features dt {
    width: 100%;
  }
  #hanaikamera .features dt:nth-of-type(n+2) {
    padding-top: 10px;
  }
  #hanaikamera .features dd {
    width: 100%;
    padding-left: 0px;
  }
}
#hanaikamera .features dt span {
  display: table;
  padding-left: 14px;
  padding-right: 10px;
  background-color: #fff;
  color: #7c0404;
  font-weight: 500;
  position: relative;
  z-index: 1;
}
#hanaikamera .features dt span::before {
  content: "";
  display: inline-block;
  position: absolute;
  background-color: #7c0404;
  width: 7px;
  height: 7px;
  top: 16px;
  left: 0;
}
@media (max-width : 500px) {
  #hanaikamera .features dt span::before {
    top: 11px;
  }
}
@media (min-width : 500px) {
#hanaikamera .features dt::after {
  border-bottom: 3px dotted #000;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 280px;
}
}
#hanaikamera .imgbox {
  display: flex;
  justify-content: space-between;
}
#hanaikamera .imgbox.box1 {
  width: 63%;
}
#hanaikamera .imgbox.box1 .box {
  width: 46%;
}
#hanaikamera .imgbox.box2 {
  width: 80%;
}
#hanaikamera .imgbox.box2 .box {
  width: 48%;
}
@media (max-width : 500px) {
  #hanaikamera .imgbox.box1{
    width: 100%;
  }
  #hanaikamera .imgbox.box1 .box {
    width: 49%;
  }
  #hanaikamera .imgbox.box2 {
    display: block;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  #hanaikamera .imgbox.box2 .box {
    width: 100%;
  }
  #hanaikamera .imgbox.box2 .box:nth-of-type(2) {
    margin-top: 15px;
  }
}
#hanaikamera .imgbox .box p {
  font-size: 80%;
  text-align: center;
  line-height: 1.5em;
}
@media (max-width : 500px) {
  #hanaikamera .imgbox.box1 .box p {
    font-size: 65%;
  }
}

h4.tvcm,
h3.tvcm {
	text-align: center;
  font-size: 110%;
  font-weight: 500;
  margin-top: 30px;
}
.youtube {
	aspect-ratio: 16 / 9;
}
#hanaikamera .cont .youtube {
	width: 100%;
  margin-top: 0px;
}
#gastroenterologist .youtube {
  width: 70%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 0px;
}
@media (max-width : 500px) {
  h4.tvcm {
    margin-top: 15px;
  }
  #gastroenterologist .youtube {
    width: 100%;
    margin-top: 0px;
  }
}
.youtube iframe {
	width: 100%;
	height: 100%;
}

/* 胃カメラ症例
------------------------ */
.cases-photo {
  width: 94%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap);
  --gap: 22px; /* 要素間の余白 */
}
.cases-photo .box {
  flex: 0 0 calc((100% - (3 * var(--gap))) / 4);
}
@media (max-width : 500px) {
  .cases-photo {
   width: 100%;
    --gap: 10px;
  }
  .cases-photo .box {
   flex: 0 0 calc((100% - (1 * var(--gap))) / 2);
  }
  .cases-photo .box p {
    line-height: 1.4em;
    padding-top: 4px;
  }
}
ul.cases {
  display: flex;
  flex-wrap: wrap;
  background-color: #f5f4f3;
  padding: 20px 40px;
}
ul.cases li {
  margin-right: 30px;
}
@media (max-width : 500px) {
  ul.cases {
    padding: 15px 20px;
    font-size: 90%;
  }
  ul.cases li {
    margin-right: 25px;
  }
}

/* 各種検査一覧
------------------------ */
ul.tests-list {
  display: flex;
  flex-wrap: wrap;
}
@media (max-width : 500px) {
  ul.tests-list {
   display: block; 
  }
}
ul.tests-list li {
  width: 32%;
  margin-right: 2%;
  margin-top: 8px;
}
@media (max-width : 900px) {
  ul.tests-list {
    justify-content: space-between;
  }
  ul.tests-list li {
    width: 49%;
    margin-right: 0;
  }
}
@media (max-width : 500px) {
  ul.tests-list li {
    width: 100%;
    margin-right: 0;
    margin-top: 0;
  }
  ul.tests-list li:nth-of-type(n+2) {
    margin-top: 8px;
  }
}
ul.tests-list li:nth-of-type(3n) {
  margin-right: 0;
}
ul.tests-list li a {
  display: block;
  background-color: rgba(255,255,255,1.00);
  padding: 12px 35px 12px 15px;
}
ul.tests-list li a:hover {
  background-color: rgba(124,4,4,0.1);
}
@media (max-width : 500px) {
  ul.tests-list li a {
    padding: 8px 35px 8px 15px;
  }
}

.flex-ul {
  display: flex;
  flex-wrap: wrap;
}
.flex-ul li {
  width: 33%;
}


.mgt10 {margin-top: 10px;}
.mgt20 {margin-top: 20px;}
.mgt30 {margin-top: 30px;}
.mgt40 {margin-top: 40px;}
.mgt50 {margin-top: 50px;}
.mgt60 {margin-top: 60px;}
.mgt70 {margin-top: 70px;}
.mgt80 {margin-top: 80px;}
.mgt90 {margin-top: 90px;}
.mgt100 {margin-top: 100px;}
@media (max-width : 500px) {
  .mgt10, .spmgt5 {margin-top: 5px;}
  .mgt20, .spmgt10 {margin-top: 10px;}
  .mgt30 {margin-top: 15px;}
  .mgt40 {margin-top: 20px;}
  .mgt50 {margin-top: 25px;}
  .mgt60 {margin-top: 30px;}
  .mgt70 {margin-top: 35px;}
  .mgt80 {margin-top: 40px;}
  .mgt90 {margin-top: 45px;}
  .mgt100 {margin-top: 50px;}
}

.mgb-15 {margin-bottom: -15px;}

.pdt10 {padding-top: 10px;}
.pdt20 {padding-top: 20px;}
.pdt30 {padding-top: 30px;}
.pdt40 {padding-top: 40px;}
@media (max-width : 500px) {
  .pdt10 {padding-top: 5px;}
  .pdt20 {padding-top: 10px;}
  .pdt30 {padding-top: 15px;}
  .pdt40 {padding-top: 20px;}
}

.pdb10 {padding-bottom: 10px;}
.pdb20 {padding-bottom: 20px;}
.pdb30 {padding-bottom: 30px;}
@media (max-width : 500px) {
  .pdb10 {padding-bottom: 5px;}
  .pdb20 {padding-bottom: 10px;}
  .pdb30 {padding-bottom: 15px;}
}

.bg-wrap {
  width: 100%;
  background-color: rgba(64,33,15,0.05);
  padding: 40px 0px 40px 0px;
}
@media (max-width : 900px) {
  .bg-wrap {
    padding: 30px 0px 30px 0px;
  }
}
@media (max-width : 500px) {
  .bg-wrap {
    padding: 20px 10px;
  }
}

/* ページ内リンク ##
----------------------------------------------------- */
a.anchor-thispage {
    display: block;
    padding-top: 60px;
    margin-top: -60px;
}
a.anchor-thispage2 {
    display: block;
    padding-top: 10px;
    margin-top: -10px;
}
@media(max-width: 500px) {
	a.anchor-thispage,
  a.anchor-thispage2 {
		display: table;
    padding-top: 0px;
    margin-top: -0px;
	}
}