@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
@media all and (min-width: 897px) and (max-width: 1000px) {
  .treatments .linkUl {
    margin-right: 0;
  }
  .treatments .linkUl li {
    width: 130px;
    height: 130px;
  }
  .treatments .linkUl li img {
    margin-bottom: 5px;
  }
  .treatments .listUl, .innerCenBox {
    margin-right: 0;
  }
}
@media all and (max-width: 896px) {
  .mainVisual {
    background-color: #fff;
  }
  .mainVisual .textBox {
    margin-top: 21px;
    padding: 0 20px;
    position: initial;
    transform: none;
  }
  .mainVisual .textBox p {
    padding-left: 12px;
    margin-bottom: 0px;
    font-size: 1.2rem;
  }
  .mainVisual .textBox h2 {
    margin-bottom: 20px;
    font-size: 2.3rem;
    line-height: 1.46;
    letter-spacing: 0.15em;
  }
  .mainVisual .txtBox a {
    right: 10px;
    bottom: auto;
    width: 139px;
    height: 138px;
    top: 270px;
  }
  .mainVisual .textBox p::before {
    width: 6px;
    height: 50px;
    top: 4px;
  }
  .mainVisual .txtBox a::after {
    width: 120px;
    height: 120px;
  }
  .mainVisual .txtBox img {
      margin: -18px 0px 0px 0px;
	  width: 45px
  }
  .mainVisual .txtBox span {
    font-size: 1.5rem;
  }
  .mainVisual .txtBox a::before {
    bottom: 21px;
    background-size: 23px;
  }
  .mainVisual::after {
    display: none;
  }
  .mainVisual .slideUl {
    position: relative;
  }
  .mainVisual .slideUl::after {
    position: absolute;
    width: 100%;
    height: 73px;
    left: 0;
    bottom: 0;
    background: url("../images/index/sp_main_bg.png") no-repeat right bottom / 100% 100%;
    right: 0;
    content: '';
    transform: none;
  }
  .no-webp .mainVisual .slideUl::after {
    background: url("../images/index/main_bg.png") no-repeat center bottom / 100% 100%;
  }
  .mainVisual .wave {
    height: 193px;
    bottom: 305px;
    left: 0;
  }
  .phoBox::after {
    width: 100%;
    height: 125px;
    bottom: 0;
    margin-left: -1px;
    background-image: url("../images/index/webp/sp_pho_bg02.webp");
    background-size: 100% 100%;
  }
    .no-webp .phoBox::after {
    background-image: url("../images/index/sp_pho_bg02.png");
  }
  .phoBox02::after {
    margin-left: -1px;
    bottom: -1px;
    background-image: url("../images/index/sp_pho_bg03.png");
  }
  .no-webp .phoBox03::after {
    background-image: url("../images/index/sp_pho_bg03.png");
  }
  .topBox {
    padding: 62px 0 55px;
    margin-top: 0;
  }
  .newsBox .title {
    margin: 0 02px;
    width: auto;
    text-align: left;
  }
  .newsBox {
    padding: 28px 0 31px;
    display: block;
  }
  .newsBox .moreBtn {
    margin-top: 0;
    position: absolute;
    top: 31px;
    right: 4px;
  }
  .moreBtn a {
    padding-right: 13px;
    font-size: 1.3rem;
    letter-spacing: 0.05em;
  }
  .moreBtn a::after {
    top: 3px;
  }
  .newsBox .newsDl dt {
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
  .information {
    padding-bottom: 37px;
  }
  .recommend {
    padding: 81px 0 44px;
  }
  .recommend .headLine01 {
    margin-bottom: 47px;
  }
  .phoBox {
    margin-bottom: 37px;
  }
  .phoBox02 {
    margin-bottom: 0;
  }
  .about .photoBox {
    width: 82%;
    margin: 0 0 0 auto;
  }
  .about .headLine01 {
    margin-bottom: 44px;
    margin-top: -76px;
  }
  .about .imgBox .textBox .comTxt {
    margin-bottom: 39px;
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "palt";
  }
  .about .imgBox .textBox .comText {
    margin-bottom: 40px;
  }
  .about .comBtn a {
    padding: 17px 10px 18px;
    max-width: 300px;
    margin: 0 auto;
  }
  .about {
    padding-bottom: 49px;
  }
  .features {
    padding: 56px 0 62px;
  }
  .features .listUl {
    margin-top: -3px;
    display: block;
  }
  .features .listUl li {
    margin: 41px 0 0;
    width: auto;
  }
  .features .listUl .img {
    margin-bottom: 22px;
  }
  .features .listUl .ttl {
    padding-bottom: 24px;
  }
  .features .listUl p {
    line-height: 1.85;
  }
  .features::after {
    width: 188px;
    height: 270px;
    top: 0;
    background: url("../images/index/webp/sp_features_bg.webp") no-repeat right top / 188px;
  }
  .no-webp .features::after {
    background: url("../images/index/sp_features_bg.png") no-repeat right top / 188px;
  }
  .innerBox h2 span::after {
    bottom: -9px;
  }
  .innerBox .comBtn a {
    padding: 17px 10px 17px;
  }
  .innerBox {
    padding: 0 20px;
    background: linear-gradient(180deg, #fff 0%, #FFF calc(100% - 50px), #F7F7F7 calc(100% - 51px), #F7F7F7 100%);
  }
  .innerBox02 {
    background: linear-gradient(0deg, #fff 0%, #FFF calc(100% - 50px), #F7F7F7 calc(100% - 51px), #F7F7F7 100%);
  }
  .innerBox03 {
    background: #fff;
  }
  .innerBox .box {
    padding: 0 0 38px;
    background: #69B0D0 !important;
    background-image: none;
  }
  .innerBox03 .box {
    padding-bottom: 41px;
  }
  .innerBox .spPhoto {
    margin-bottom: 28px;
    overflow: hidden;
  }
  .innerBox h2 {
    text-align: center;
    letter-spacing: 0.05em;
  }
  .innerBox .txtUl {
    margin: 0 -10px 36px -3px;
  }
  .innerBox .txtUl li {
    letter-spacing: 0;
  }
  .innerBox02 h2 {
    margin-bottom: 23px;
  }
  .innerBox03 h2 {
    margin-bottom: 23px;
  }
  .innerBox03 p {
    margin-bottom: 35px;
    max-width: inherit;
  }
  .innerBox03 .img {
    max-width: inherit;
  }
  .treatments {
    padding: 55px 0 10px;
  }
  .treatments .comText {
    margin-bottom: 48px;
  }
  .treatments .linkUl {
    margin: -10px -15px 52px;
    justify-content: center;
  }
  .treatments .linkUl li {
    margin: 10px 4.5px 0;
    width: 112px;
    height: 112px;
  }
  .treatments .linkUl li:nth-child(3n) {
    margin-right: 0;
  }
  .treatments .linkUl li a {
    padding-top: 20px;
    border: none;
    line-height: 1.2;
    align-content: flex-start;
  }
  .treatments .linkUl li img {
    margin-bottom: 8px;
    width: 40px;
  }
  .treatments .listUl {
    margin: 0 2px 70px -2px;
  }
  .treatments .listUl li {
    margin-bottom: 25px;
  }
  .innerCenBox {
    margin: 0 0 70px;
  }
  .innerCenBox .box {
    padding: 50px 42px 65px;
  }
  .innerCenBox h2 {
    padding: 4px 2px 6px;
    display: block;
    max-width: 85%;
    color: #fff;
    font-size: 2rem;
    font-weight: normal;
    letter-spacing: 0.1em;
    text-align: center;
    background-color: #03004D;
    border-radius: 45px;
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
  }
  .innerCenBox .txtBox p {
    margin-bottom: 35px;
    padding-bottom: 32px;
    border-bottom: 1px solid #EFEFEF;
  }
  .innerCenBox .txtBox ul {
    margin: 0 -30px 0 -22px;
  }
  .innerCenBox .txtBox li {
    margin-top: 15px;
    align-items: flex-start;
  }
  .innerCenBox .txtBox li span {
    width: 140px;
    flex-basis: 140px;
    flex-shrink: 0;
    padding: 4px 10px 5px 10px;
    margin: 5px 20px 0 0;
    box-sizing: border-box;
  }
  .innerCenBox .comBtn {
    position: absolute;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%);
    width: 100%;
    max-width: 300px;
  }
  .innerCenBox .comBtn a {
    padding: 18px 10px 17px;
    font-size: 1.6rem;
  }
  .innerCenBox .txtBox p .txtLine::after {
    height: 4px;
  }
  .introduction {
    padding: 54px 0 50px;
  }
  .introduction .comBtn {
    margin: 0 38px;
  }
  .doctor {
    padding: 207px 0 62px;
  }
  .doctor .photo {
    width: 250px;
    right: 0;
    top: -208px;
  }
  .doctor .headLine01 {
    margin-bottom: 41px;
  }
  .doctor .ttl {
    margin-bottom: 30px;
  }
  .doctor .txt {
    margin-bottom: 30px;
  }
  .doctor .txt small {
    margin-right: 5px;
    min-width: 165px;
  }
  .doctor .txt span {
    min-width: 165px;
    flex-shrink: 0;
  }
  .doctor .comBtn {
    margin: 0 18px;
  }
  .group {
    padding-bottom: 50px;
    padding-top: 60px;
  }
  .group .headLine01 {
    margin-bottom: 50px;
  }
  .group .linkUl {
    margin-top: -26px;
  }
  .group .linkUl li {
    margin: 26px 36px 0 0;
    width: calc(100%/2 - 18px);
    text-align: center;
  }
  .group .linkUl li:nth-child(2n) {
    margin-right: 0;
  }
  .group .linkUl .img {
    margin-bottom: 11px;
  }
  .group .linkUl .img img {
    border-radius: 19px;
  }
  .group .linkUl li .topTxt {
    white-space: inherit;
    margin-bottom: -2px;
    letter-spacing: 0;
  }
  .group .linkUl li .txt {
    background: url("../images/index/webp/group_icon.webp") no-repeat center bottom / 10px;
    font-size: 1.6rem;
    padding-bottom: 20px;
    letter-spacing: 0;
    margin: 0 -10px;
  }
  .no-webp .group .linkUl li .txt {
    background: url("../images/index/group_icon.png") no-repeat center bottom / 10px;
  }
  .about .imgBox .textBox {
    max-width: inherit;
  }
	
	.sunrockers img {
    width: 90%;
    height: auto;
}
	.pb_txt{
	margin: auto;
	margin-bottom: 0px;
	margin-top: 8vw;
	width: 100%;
}
}
@media all and (max-width: 374px) {
  .innerBox h2 {
    font-size: 2.5rem;
  }
  .innerBox .txtUl li {
    padding-left: 25px;
    font-size: 1.5rem;
    background-size: 18px;
  }
  .innerBox .content {
    padding: 0 15px;
  }
  .treatments .linkUl li {
    width: 94px;
    height: 94px;
  }
  .treatments .linkUl li a {
    padding-top: 5px;
    font-size: 1.1rem;
    align-content: center;
  }
  .treatments .linkUl li img {
    width: 30px;
  }
  .innerCenBox h2 {
    font-size: 1.8rem;
  }
  .innerCenBox .box {
    padding: 50px 15px 65px;
  }
  .innerCenBox .txtBox ul {
    margin: 0 -5px;
  }
  .innerCenBox .txtBox li span {
    width: 115px;
    flex-basis: 115px;
    font-size: 1.1rem;
  }
  .doctor .ttl {
    font-size: 2rem;
  }
  .doctor .txt small {
    min-width: 140px;
    font-size: 1.2rem;
    letter-spacing: 0;
  }
  .doctor .txt span {
    min-width: 130px;
    font-size: 3.2rem;
    letter-spacing: 0;
  }
  .group .linkUl li .txt {
    font-size: 1.4rem;
  }
  .mainVisual .txtBox a {
    width: 120px;
    height: 120px;
    top: 220px;
  }
  .mainVisual .txtBox a::after {
    width: 110px;
    height: 110px;
  }
  .mainVisual .txtBox span {
    font-size: 1.3rem;
  }
  .mainVisual .txtBox a::before {
    bottom: 14px;
  }
  .mainVisual .textBox h2 {
    font-size: 2rem;
  }
  .newsBox .newsDl dd {
    padding: 0 0 5px 7.8em;
  }
  .about .imgBox .textBox .comTxt {
    font-size: 2rem;
  }
	
	.sunrockers img {
    width: 90%;
    height: auto;
}
	
}