@charset "utf-8";

@media screen and (max-width: 640px) {
  img {
    width: 100%;
  }

  .pc-view,
  .pc-inline-view {
    display: none;
  }

  .sp-view {
    display: block;
  }

  .contents {
    width: 100%;
    overflow: hidden;
  }

  .cont-inner {
    padding: 0 5.333vw;
  }

  .l-header{
    position: static;
  }

  .section-headline {
    font-size: 10.667vw;
    margin: 0 0 5.333vw;
    padding: 0 0 5.333vw;
  }

  .section-headline:after {
    width: 34.667vw;
    height: 0.533vw;
  }

  .section-headline__ja {
    font-size: 4vw;
    margin: 4vw 0 0;
  }

  /*header*/
  .header-logo {
    width: 36vw;
    left: 3.2vw;
  }

  .sp-header__inner {
    height: 12vw;
    display: flex;
    justify-content: flex-end;
    align-items: center;
  }

  .header-menu__list {
    display: flex;
  }

  .header-menu__list--item {
    width: 9.2vw;
    margin: 0 2.667vw 0 0;
  }

  .header-menu__list--item:last-child {
    margin: 0;
  }

  /*l-main*/
  .l-main {
    padding: 0;
  }

  /*hero*/
  .hero {
    padding: 2.667vw 0 6.667vw;
  }

  /*contact*/
  .section-contact {
    padding: 4vw 0 5.333vw;
  }

  .contact-headline {
    font-size: 5.333vw;
  }

  .contact-headline__text:before,
  .contact-headline__text:after {
    height: 6.4vw;
  }

  .contact-headline__text {
    padding: 0 2.667vw;
  }


  .contact-btn {
    margin: 0 0 4vw;
  }

  .contact-btn a {
    width: 83.2vw;
    height: 10.667vw;
    font-size: 5.333vw;
    border-radius: 1.333vw;
  }

  .contact-btn a:after {
    display: none;
  }


  .contact-tel__text {
    font-size: 4.533vw;
  }

  .contact-tel__number--link {
    font-size: 10.667vw;
  }

  .contact-tel__time {
    font-size: 4.533vw;
  }

  /*reason*/
  .section-reason {
    padding: 6.667vw 0;
  }

  .reason-inner {
    flex-direction: column;
  }

  .reason-desc {
    width: 100%;
  }

  .reason-headline {
    display: block;
    font-size: 6.667vw;
    text-align: center;
    border: none;
    margin: 0 0 4vw;
  }

  .reason-headline__subtitle {
    font-size: 5.333vw;
    line-height: 1.25;
    margin: 0 0 5.333vw;
    padding: 0 0 0 4vw;
  }

  .reason-img {
    width: 61.067vw;
    margin: 0 auto 8vw;
  }

  .reason-text {
    font-size: 3.733vw;
  }

  /*surgery-case*/
  .section-surgery-case {
    padding: 9.333vw 0 8vw;
  }

  .surgery-case__list {
    padding: 5.333vw 3.733vw 3.2vw;
    background-position: right -10.667vw top;
  }

  .surgery-case__list:not(:last-child) {
    margin: 0 0 8vw;
  }

  .text_notes{
    margin: 10px 0 0 0;
    padding-left: 1em;
    text-indent: -1em;
  }

  .surgery-title {
    flex-direction: column;
    margin: 0 0 2.667vw;
  }

  .surgery-title__text{
    text-align: center;
  }

  .surgery-title__text {
    font-size: 6.667vw;
    margin: 0 0 4vw;
  }

  .surgery-price {
    padding: 2.667vw 0;
    width: 100%;
    border-top: 1px solid #534946;
  }

  .surgery-price__data {
    flex-direction: column;
  }

  .surgery-price__data--title {
    font-size: 4vw;
  }

  .surgery-price__data--value {
    font-size: 8vw;
    text-align: center;
  }

  .surgery-price__data--value__note {
    font-size: 3.2vw;
  }

  .surgery-case__content--list {
    margin: 0 0 5.333vw;
  }

  .text-details{
    font-size: 5.2vw;
  }

  .surgery-case__content--list__item {
    font-size: 3.467vw;
    height: 6.4vw;
    padding: 0 2.667vw;
    margin: 0 1.333vw 2.667vw;
  }

  .surgery-case__sample {
    padding: 8vw 3.2vw 2.667vw;
    margin: 0;
    box-shadow: 0 0.8vw 1.333vw 0 rgba(0, 0, 0, 0.3);
  }

  .surgery-case__sample--title {
    width: 20.8vw;
    height: 8.8vw;
    font-size: 4vw;
    top: -4.267vw;
  }

  .surgery-case__sample--box {
    flex-direction: column;
    padding: 0 4.8vw;
  }

  .surgery-case__sample--list {
    justify-content: space-between;
    margin: 0 0 2.667vw;
  }

  .surgery-case__sample--list:first-child {
    margin: 0 0 5.333vw;
  }

  .surgery-case__sample--list__item {
    width: 32.533vw;
  }

  .surgery-case__risk {
    padding: 2.667vw;
    box-shadow: 0 0.8vw 1.6vw 0 rgba(0, 0, 0, 0.3);
  }

  .surgery-case__risk--list {
    flex-direction: column;
    align-items: center;
  }

  .surgery-case__risk--list__title {
    font-size: 3.733vw;
    margin: 0 0 2.667vw;
  }

  .surgery-case__risk--list__data {
    font-size: 3.2vw;
  }

  /*problem*/
  .section-problem {
    padding: 8vw 0 0;
    background-size: 292.333vw;
    background-position: left -68.667vw top;
  }

  .section-problem:after {
    width: 74.133vw;
    height: 28.8vw;
    background-size: contain;
    bottom: -26.667vw;
  }

  .problem-headline {
    font-size: 6.667vw;
    margin: 0 0 5.333vw;
  }

  .problem-list {
    padding: 0 0 0 5.333vw;
    margin: 0 0 8vw;
  }

  .problem-list__item {
    font-size: 4.533vw;
    background-size: 5.333vw;
    padding: 0 0 0 6vw;
  }

  .problem-text {
    font-size: 6.667vw;
  }

  /*type of trouble*/
  .section-trouble {
    padding: 29.867vw 0 6.133vw;
  }

  .trouble-list__item {
    height: 17.067vw;
    width: 18.133vw;
    border-right: 1px solid #d4d4d4;
  }

  .trouble-list__item:first-child {
    border-left: 1px solid #d4d4d4;
  }

  .trouble-list__item--link {
    font-size: 4vw;
    align-items: flex-start;
    padding-top: 4vw;
  }

  .trouble-list__item--link:after {
    width: 4.8vw;
    height: 3.2vw;
    background: url(../images/icon_sp_tot_arrow.png) no-repeat center / cover;
    transform: none;
    bottom: 2.667vw;
  }

  .trouble-list__item--link:hover:after {
    bottom: 0;
  }

  /*treatment*/
  .section-treatment {
    padding: 8vw 0;
  }

  .treatment-intro {
    margin: 0 0 5.333vw;
  }

  .treatment-intro .cont-inner {
    align-items: flex-start;
  }

  .treatment-intro:after {
    height: calc(100% + 4vw);
    right: 0;
  }

  .treatment-desc {
    width: 52.8vw;
    margin: 0 2.667vw 0 0;
  }

  .treatment-intro__headline {
    font-size: 6.667vw;
    margin: 0 0 2.667vw;
  }

  .treatment-headline__text {
    width: 100%;
    font-size: 3.2vw;
    line-height: 1.65;
  }

  .treatment-img {
    width: 35.2vw;
    position: absolute;
    top: 0;
    right: 5.333vw;
  }

  .treatment-img:after {
    top: 2.667vw;
    right: -2.667vw;
  }

  .treatment-title {
    font-size: 5.333vw;
    padding: 0 0 2.667vw;
    margin: 0 0 10.667vw;
  }

  .treatment-title:after {
    width: 26.133vw;
    height: 0.533vw;
  }

  .treatment-list {
    border-width: 0.533vw;
    margin: 0 0 8vw;
  }

  .treatment-list__title {
    height: 10.933vw;
    font-size: 5.333vw;
  }

  .treatment-list__inner {
    padding: 2.667vw 2.667vw 3.467vw;
  }

  .treatment-list__contents-name {
    font-size: 4.533vw;
    margin: 0 0 2.667vw;
  }

  .treatment-list__contents-name__text:before,
  .treatment-list__contents-name__text:after {
    width: 6.667vw;
  }

  .treatment-list__contents-name__text:before {
    left: -8vw;
  }

  .treatment-list__contents-name__text:after {
    right: -8vw;
  }

  .treatment-detail {
    flex-direction: column;
    margin: 0 0 5.333vw;
  }

  .treatment-detail-point__list {
    width: 100%;
    margin: 0 0 2.667vw;
  }

  .treatment-detail-point__list--item:first-child {
    width: auto;
  }

  .treatment-detail-point__list--item:first-child,
  .treatment-detail-point__list--item {
    width: calc(100% / 3);
  }

  .treatment-detail-sample__list {
    justify-content: center;
    flex-wrap: wrap;
  }

  .treatment-detail-sample__list--item {
    width: calc(100% / 2);
    display: flex;
    align-items: center;
    flex-direction: column;
    margin: 0 0 5.333vw;
  }

  .treatment-detail-sample__list--item:first-child {
    width: 100%;
  }

  .treatment-detail-sample__list--item:not(:first-child) {
    margin: 0;
  }


  .treatment-detail-point__img {
    width: 29.867vw;
    margin: 0 0 2.667vw;
    position: relative;
  }

  .treatment-detail-point__text {
    font-size: 3.2vw;
    min-height: auto;
  }

  .treatment-detail-point__img:before {
    content: "1";
    width: 6.667vw;
    height: 6.667vw;
    background: #818181;
    position: absolute;
    top: -2.667vw;
    left: -2.667vw;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
  }

  .treatment-detail-sample__list--item:nth-child(2) .treatment-detail-point__img:before {
    content: "2";
  }

  .treatment-detail-sample__list--item:nth-child(3) .treatment-detail-point__img:before {
    content: "3";
  }

  .treatment-list__text {
    font-size: 3.2vw;
    margin: 0 0 5.333vw;
  }

  .treatment-recommend {
    padding: 4vw 2.667vw;
  }

  .treatment-recommend__title {
    font-size: 4vw;
    margin: 0 0 2.667vw;
  }

  .treatment-recommend__data {
    font-size: 3.2vw;
  }

  .section-treatment:nth-child(even) .treatment-intro__headline:after {
    width: 100%;
  }

  .section-treatment:nth-child(even) .treatment-desc {
    width: 53.4vw;
  }

  .section-treatment:nth-child(even) .treatment-intro:after {
    left: 0;
  }

  /*price*/
  .section-price {
    padding: 8vw 0;
  }

  .section-price {
    padding: 8vw 0;
  }

  .price-list {
    margin: 0 auto 5.333vw;
  }

  .price-list__title a {
    height: 10.667vw;
    font-size: 4.267vw;
  }

  .price-list__title--switch {
    width: 6.133vw;
    height: 6.133vw;
    border-radius: 1.333vw;
    right: 3.733vw;
  }

  .price-list__title--switch:before {
    width: 3.2vw;
  }

  .price-list__title--switch:after {
    height: 3.2vw;
  }

  .price-menu {
    padding: 5.333vw 6.667vw;
  }

  .price-menu__list {
    padding: 2vw 0 1.333vw 0;
    display: block;
  }

  .price-menu__other--line{
    padding: 0;
  }

  .price-menu_title{
    font-size: 20px;
  }

  .price-menu_title2{
    margin-top: 4%;
  }

  .price-menu__other1{
    text-indent: -1em;
    padding-left: 1em;
    font-size: 3.0vw;
  }

  .price-menu__list--title {
    font-size: 3.5vw;
    text-align: center;
  }

  .price-menu__list--data {
    font-size: 4.7vw;
    width: 100%;
  }

  .price-unit {
    font-size: 3.733vw;
  }

  .price-unit2 {
    font-size: 2vw;
  }

  .price-menu__other {
    font-size: 3.733vw;
    margin: 2vw 0 1.333vw;
  }

  /*director*/
  .section-director {
    padding: 8vw 0;
    background: url(../images/bg_sp_director.png) no-repeat center top / cover;
  }

  .director-box {
    flex-direction: column-reverse;
  }

  .director-box:nth-of-type(1) {
    margin: 0 0 5.333vw;
  }

  .director-box:nth-of-type(2) {
    margin: 0 0 5.333vw;
  }

  .director-picture {
    width: 74.133vw;
    margin: 0 auto 4.8vw;
  }

  .director-picture__name {
    font-size: 4vw;
  }

  .director-greeting {
    width: 100%;
  }

  .director-greeting__title {
    font-size: 6.667vw;
    margin: 0 0 5.333vw;
  }

  .director-greeting__text {
    font-size: 3.733vw;
    line-height: 1.5;
  }

  .director-box:nth-of-type(2) {
    flex-direction: column;
  }

  .director-box:nth-of-type(3) {
    flex-direction: column;
  }

  .director-data {
    width: 100%;
  }

  .director-data:first-child {
    margin: 0 0 5.333vw;
  }

  .img_CLINIC{
    margin: 0 0 5.333vw;
  }

  .director-data__title {
    font-size: 4.267vw;
    margin: 0 0 4vw;
    height: 13.333vw;
  }

  .director-data__title--en {
    font-size: 3.2vw;
    margin: 0 0 0 9.333vw;
  }

  .director-data__list--item {
    font-size: 3.733vw;
  }

  /*clinic*/
  .section-clinic {
    padding: 8vw 0 5.333vw;
  }

  .section-clinic .cont-inner {
    padding: 0 0 5.333vw;
  }

  .clinic-box {
    flex-direction: column;
  }

  .clinic-picture {
    margin: 2.667vw auto 5.333vw;
    width: 69.333vw;
  }

  .clinic-picture2 {
    margin: 2.667vw auto 5.333vw;
  }

  .sp_flexbox {
    display: flex;
    justify-content: center;
    width: 90%;
    margin: 0 auto;
  }

  .clinic-data__title {
    font-size: 4.8vw;
    text-align: center;
    margin: 0 0 2.667vw;
  }

  .clinic-data__list {
    font-size: 4vw;
  }

  .clinic-map {
    height: 48.8vw;
  }

  /*page-top*/
  .page-top__btn a {
    width: 40px;
    height: 40px;
    bottom: 20px;
    right: 6px;
  }

  .page-top__btn a:before {
    width: 14px;
    height: 14px;
    border-width: 2px;
    top: 18px;
    left: 14px;
  }

  .on.snsMenu{
    bottom: -2px;
    padding: 0 0;
    width: 100%;
    height: auto;
    display: block;
    box-sizing: border-box;
    position: fixed;
    left: 0;
    z-index: 100;
    transition: 0.6s ease;
  }

  .snsMenu ul{
    box-sizing: border-box;
    position: relative;
    background-color: #FFFFFF;
    width: 100%;
    height: auto;
    float: left;
    display: block;
  }

  .snsMenu ul li{
    width: 25%;
    height: auto;
    float: left;
    display: inline-block;
    box-sizing: border-box;
    position: relative;
    text-align: center;
  }

  .snsMenu ul li.p01 a{
    background-color: #00b900;
  }

  .snsMenu ul li a{
    width: 100%;
    height: 70px;
    float: left;
    display: inline-block;
    box-sizing: border-box;
    position: relative;
    text-align: center;
    font-size: 13px;
    line-height: 20px;
    padding: 15px 0;
    color: #FFF;
    text-decoration: none;
    letter-spacing: 0.15em;
    transition: 0.2s ease;
    overflow: hidden;
  }

  .snsMenu ul li a i{
    font-size: 22px;
  }

  .fab{
    font-family: "Font Awesome 5 Brands";
  }

  .fa-line:before {
    content: ''; 
    box-sizing: border-box;
    content: url(../images/icon_sp_line.png);
    display: inline-block;
    vertical-align: middle;
    transform: scale(0.4);
    position: absolute;
    top: -9px;
    left: 16px;
  }

  .snsMenu ul li.p02 a{
    background-color: #f47ebb;
  }

  .fa-envelope:before{
    content: ''; 
    box-sizing: border-box;
    content: url(../images/icon_sp_mail.png);
    display: inline-block;
    vertical-align: middle;
    transform: scale(0.4);
    position: absolute;
    top: -9px;
    left: 16px;
  }

  .snsMenu ul li.p03 a {
      background-color: #94a5ac;
  }   

  .p04 {
      border: 1px solid #ddd;
      background: #f7f7f7;
      background-size: 30px auto;
  }

  .fa-phone:before {
      content: ''; 
      box-sizing: border-box;
      content: url(../images/icon_sp_phone.png);
      display: inline-block;
      vertical-align: middle;
      transform: scale(0.4);
      position: absolute;
      top: -9px;
      left: 16px;

  }

  .text_Instagram{
    color: #7b8488;
  }

  .fa-insta:before {
      content: ''; 
      box-sizing: border-box;
      content: url(../images/instagram.png);
      display: inline-block;
      vertical-align: middle;
      transform: scale(0.4);
      position: absolute;
      top: -9px;
      left: 16px;

  }

  /*footer*/
  .l-footer {
    height: 12.533vw;
    margin-bottom: 70px;
  }

  .footer-copy {
    font-size: 2.667vw;
    text-align: center;
    line-height: 1.5;
  }
}