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


	.top-houshin-l{
		width:100%;
		max-width:1100px;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
	}
	.top-houshin p{
		text-align: left!important;
			width:98%;
	margin-left: auto!important;
		margin-right: auto!important;
		}
	
@media screen and (min-width: 769px) {
.spsize{
font-size:12px;
}
.top-houshin{
		width:28%;
		display: inline-block;
		border:1px solid #333;
		border-radius:6px;
		padding: 1%;
		margin-bottom: 2%;
		background:#fff;
	}
.top-houshin h3{
	color:#f63299;
	font-weight:bold;
	font-size:22px;
	}
.mg-lr-2{
		margin-left: 1%;
		margin-right: 1%;
	}
	.mg-r-1{
		margin-right: 0.5%;
	}
	.mg-l-1{
		margin-left: 0.5%;
	}
	.pccenter{
text-align: center;
	}
}
@media screen and (max-width: 768px) {
.spsize{
font-size:10px!important;
}
.top-houshin{
		width:90%;
		border:1px solid #333;
		border-radius:6px;
		padding: 2%;
		margin-bottom: 3%;
		background:#fff;
	margin-left: auto!important;
		margin-right: auto!important;
	}
.top-houshin h3{
	color:#f63299;
	font-size:15px!important;
	text-align: left;
	}
	.pccenter{
text-align: center;
	}
}








@media screen and (min-width: 769px) {
.shinjuku_pic{
font-size:12px;
padding-bottom:15px;
width:35%;
float:right;
line-height: 1.5em;
}
.shinjuku_pic img{
width:100%;
height:auto!important;
}
.shinjuku_txt{
width:60%;
float:left;		
}
}
@media screen and (max-width: 768px) {
.shinjuku_pic{
font-size:12px;
padding-bottom:15px;
width:37%;
float:right;
line-height: 1.5em;
}
.shinjuku_pic img{
width:100%;
height:auto!important;
}
.shinjuku_txt{
width:59%;
float:left;		
}	
}
.to-access{
display:block;
text-align: right;
margin-top: 3%;
color:#f63299;
text-decoration: underline;
}
.to-access:hover{
text-decoration: none;
}







/*トップ レビュー*/
.reviews-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
	margin-top: 3%;
}
.review {
    width: 32%;
    margin-bottom: 20px;
    border: 1px solid #ddd;
    padding: 20px;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 8px;
    text-align: left;
}
.rating {
    margin-bottom: 10px;
	text-align: center!important;
}
.star {
    color: #FFD700;
    font-size: 20px;
}
.review-text {
    font-size: 14px;
    color: #333;
    margin-bottom: 10px;
    max-height: 250px;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}
.review-author {
    font-size: 12px;
    color: #777;
	text-align: right!important;
}
.read-more-btn {
    background-color: #ffaa01;
    color: white;
    border: none;
    padding: 4px 8px;
    cursor: pointer;
    font-size: 12px;
    border-radius: 5px;
}
.read-more-btn:hover {
    opacity:0.7;
}
@media (max-width: 768px) {
    .review {
        width: 100%;
    }
}
@media (max-width: 480px) {
    .review {
        width: 100%;
    }
}
@media screen and (max-width: 768px) {
  .reviews-container {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding: 0;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .reviews-container::-webkit-scrollbar {
    display: none;
  }

  .review {
    flex: 0 0 100%;
    width: 100%;
    max-width: 100%;
    scroll-snap-align: start;
  }
}
.reviews-wrap {
  position: relative;
}
@media screen and (min-width: 769px) {
.slide-arrow.prev,
.slide-arrow.next{
display:none;	 
}
}
@media screen and (max-width: 768px) {
  .reviews-container {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
  }
  .review {
    flex: 0 0 100%;
    width: 100%;
    scroll-snap-align: start;
  }
  .reviews-container::-webkit-scrollbar {
    display: none;
  }
.slide-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: none;
    background: rgba(0,0,0,0.5);
    color: #fff;
    font-size: 24px;
    line-height: 15px;
	padding-bottom:3px;
    text-align: center;
    cursor: pointer;
  }
  .slide-arrow.prev { left: 4px; }
  .slide-arrow.next { right: 4px; }
}
.to-google{
text-align:right;
display:block;
color:#ffaa01;
text-decoration: underline;
}
.to-google:hover{
text-decoration:none;
}






.feature-table {
  width: 94%;
  max-width: 800px;
  border-collapse: collapse;
  margin-left: auto;
  margin-right: auto;
  border-top: 1px solid #ddd;
  border-left: 1px solid #ddd;
  border-right: 1px solid #ddd;
}
.feature-table th {
  width: 160px;
  font-weight: 600;
  text-align: left;
  background-color: #f7f7f7;
}
.feature-table td {
  color: #333;
}
@media screen and (min-width: 769px) {
.feature-table th,
.feature-table td {
  padding: 12px 16px;
  border-bottom: 1px solid #ddd;
  vertical-align: top;
}	
}
@media screen and (max-width: 768px) {
.feature-table th,
.feature-table td {
  padding: 2%;
  border-bottom: 1px solid #ddd;
  vertical-align: top;
}
  .feature-table th,
  .feature-table td {
    display: block;
    width: 96%;
  }
  .feature-table th {
    border-bottom: none;
    padding-bottom: 4px;
  }
  .feature-table td {
    padding-top: 0;
  }
}








	.inner_02{
		width:94%;
		max-width:800px;
		margin-left: auto;
		margin-right: auto;
	}
	.inner{
		width:94%;
		max-width:1020px;
		margin-left: auto;
		margin-right: auto;
	}
	.case-p{
		border:1px solid #333;
		border-radius:8px;
		padding: 2%;
	}
.case-detail {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 12px 24px;
}
.case-detail dt {
  font-weight: 600;
}
.case-detail dd {
  margin_: 0;
margin-left: 1em;
	text-indent: -1em;
}
@media screen and (max-width: 768px) {
  .case-detail {
    grid-template-columns: 1fr;
    gap: 8px 0;
  }
}

@media screen and (min-width: 769px) {
.case-h3{
		text-align: center;
		font-size:24px;
		margin-top: 5%;
		margin-bottom: 2%;
	}	
}
@media screen and (max-width: 768px) {
.case-h3{
		text-align: center;
		font-size:18px;
		margin-top: 3%;
		margin-bottom: 2%;
	}	
}









	.info-style{
		font-size:medium;
		font-family:游明朝,yumincho,;
		margin:0px;
		padding:0px 20px 0px 0px;
		border:0px;
		vertical-align:baseline;
		color:rgb(32,12,23);
	}
	.info-style_02{
	margin:0px;
		padding:0px;
		border:0px;
		font-size:16px;
		vertical-align:baseline;	
	}
	.info-style_03{
	border:0px;
	font-size:15px;
	vertical-align:baseline;
	color:rgb(32,12,23);
	font-family:游明朝,YuMincho,;
	}
	.info-style_04{
		font-size:medium;
		margin:0px;
		padding:0px 20px 0px 0px;
		border:0px;
		vertical-align:baseline;
	}
@media screen and (min-width: 769px) {
.to-df-box{
			text-align: center;
		}
	.to-df{
		margin-top: 3%;
		width:48%;
		max-width:500px;
		border_:1px solid #288e3a;
		display: inline-block;
		vertical-align: top;
	}
	.to-df img{
		width:100%;
	}
	.mg-r-1-1{
	margin-right: 1%;
	border:1px solid #288e3a;
	}
	.mg-l-1-1{
	margin-left: 1%;
	text-align: left;
	line-height: 1.4em;
	color:#333;
	}
}
@media screen and (max-width: 768px) {
.to-df-box{
			text-align: center;
		}
	.to-df{
		margin-top: 3%;
		width:90%;
		max-width:500px;
		display:block;
		vertical-align: top;
		margin-left: auto;
		margin-right: auto;
	}
	.to-df img{
		width:100%;
	}
.mg-r-1-1{
	border:1px solid #288e3a;
	}
	.mg-l-1{
	text-align: left;
	line-height: 1.4em;
	color:#333;
	}
}
		
/*症例*/		
.astyle{
		text-decoration: underline;
	}
	.astyle:hover{
		text-decoration: none;
	}
	@media screen and (min-width: 741px) {
		.li_01{
			width:29%;
		}
		.li_02{
			width:21%;
		}
		.li_03{
			width:28%;
		}
		.li_04{
			width:22%;
		}
	.ttl_case{
		font-size:19px;
	}
	.list-size li ul li a{
border-bottom:1px dotted #999;
	}
	.list-size li ul li a:hover{
border-bottom:none;
	}
	.list-size li ul li{
padding-left:10px;
	}
	}
	@media screen and (max-width: 740px) {
	.ttl_case{
		font-size:16px;
	}	
	}
	.list-size li ul li a{
	font-size:13px!important;
	}
		
		
#case .pageNav {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding-bottom: 0px;
  width: 1000px;
  margin: 0 auto; }
 #case .pageNav li i {
    display: inline-block;
    transform: rotate(180deg);
    margin-right: 5px;
    font-size: 1rem; }
 #case .pageNav li + li:before {
    content: "";
    margin_: 0 10px; }
		
@media screen and (max-width: 740px) {		
#case .pageNav {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    padding-bottom: 0px;
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
    margin: 0 auto;
    border-bottom: #d0d0d0 dotted 1px; }
#case .pageNav li {
      padding: 8px;
      width: 100%;
      border-top: #d0d0d0 dotted 1px;
      box-sizing: border-box; }
#case .pageNav li + li:before {
      content: none;
      margin: 0 10px; }
	}







	@media screen and (min-width: 741px) {
	.risk ul li ul li{
		font-size:14px!important;
		margin-left: 1em;
		text-indent: -1em;
	}
		.risk ul li ul{
		padding-left:10px;
	}
	}
	@media screen and (max-width: 740px) {
	.risk ul li ul li{
		margin-left: 1em;
		text-indent: -0.5em;
	}
	.risk ul li ul{
		padding-left:5px;
	}
	}
	.risk .listyle{
		margin-top: 20px;
	    margin-bottom: 20px;
	}
#top-reason{
  scroll-margin-top: 60px;
}








@media screen and (min-width: 769px) {
.access_sec h3.center {
  text-align: center;
  font-size: 2.3rem;
  line-height: 1.5;
  padding-bottom: 70px
}
.access_sec .accessBox {
  padding: 0 50px;
  display: flex;
  justify-content: flex-start
}
.access_sec .accessBox figure {
  width: 50%;
  background: #ccc;
  flex-shrink: 0;
  position: relative
}
.access_sec .accessBox figure iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%
}
.access_sec .accessBox .text {
  padding: 50px 0 50px 50px
}
.access_sec .accessBox .text h4 {
  color: #200c17;
  font-size: 2.1rem
}
.access_sec .accessBox .text p + h4 {
  padding-top: 40px
}
.access_sec .inner {
  width: 800px
}
}
@media screen and (max-width: 768px) {
.access_sec h3.center {
    text-align: center;
    font-size: 1.6rem;
    line-height: 1.5;
    padding: 0 20px 20px
  }
.access_sec .accessBox {
    padding: 0;
    flex-wrap: wrap
  }
.access_sec .accessBox figure {
    width: 94%;
margin-left: auto;
	margin-right: auto;
  }
.access_sec .accessBox .text {
    width: 100%;
    box-sizing: border-box;
    padding: 20px 20px 0
  }
.access_sec .accessBox .text h4 {
    color: #200c17;
    font-size: 1.5rem;
    font-feature-settings: "palt"
  }
.access_sec .accessBox .text p + h4 {
    padding-top: 10px
  }
.access_sec .inner {
    width: 100%;
    font-size: 1rem
  }	
}
