@media only screen and (max-width: 768px) {
    .home_page .key {
        --height: calc(100vh - 60px);
        --max-height: 500px;
        --min-height: 320px;
        width: calc(100% - 20px);
		background: url(../images/idx-main-img01sp.jpg) no-repeat top center;
		background-size: cover;
    }
    .home_page .key .key_text .item {
        padding: 10px;
        height: calc(100dvh - 60px);
        min-height: 320px;
        padding-bottom: 180px;
		align-items: flex-end;
    }
	.home_page .key .key_text .s1{
	background: url(../images/idx-main-img01sp.jpg) no-repeat top center;
		background-size: cover;
	}
	.home_page .key .key_text .s2{
		background: url(../images/idx-main-img02sp.jpg) no-repeat top center;
		background-size: cover;
	}
	.home_page .key .key_text .s3{
		background: url(../images/idx-main-img03sp.jpg) no-repeat top center;
		background-size: cover;
	}
    .home_page .key .catch {
        text-align: center;
    }
    .home_page .key .catch .title {
        font-size: min(6.93vw, 24px);
        line-height: 1.5em;
        text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
    }
    .home_page .key .catch .title br {
        display: none;
    }
    .home_page .key .catch>p {
        font-size: min(4.27vw, 16px);
        text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
    }
    .home_page .key .idx-list-main {
        position: absolute;
        left: 0px;
        bottom: 40px;
        display: flex;
        right: -23px;
        margin: 0 auto;
        justify-content: center;
    }
    .home_page .key .idx-list-main li {
        width: min(32vw, 160px);
        height: min(32vw, 160px);
        padding: 5px 15px;
        align-items: center;
        justify-content: center;
        display: flex;
        flex-direction: column;
    }
    .home_page .key .idx-list-main li .ttl {
        font-size: min(4.27vw, 20px);
    }
    .home_page .key .idx-list-main li .txt {
        font-size: min(3.33vw, 16px);
    }
    .home_page .key .idx-list-main li .txt br {
        display: none;
    }
}

@media only screen and (max-width: 640px) {
    .home_page .key {
        font-size: 1.5vmin;
    }
}

@media only screen and (min-width: 639px) and (max-width: 768px) {
    .home_page .key {
        font-size: 1.5vmin;
    }
    .home_page .key .idx-list-main li {
        padding: 5px 25px;
    }
}

@media only screen and (max-width: 768px) and (orientation: landscape) {
    .home_page .key {
        font-size: 1.5vmin;
    }
}

@media only screen and (max-width: 768px) {
    .home_page h3 {
        margin-bottom: 30px;
        font-size: calc(var(--ttl_size) - 2px);
    }
}

@media only screen and (max-width: 768px) {
    .iNews {
        padding: 60px 0;
    }
    .iNews .inner_big {
        max-width: 100%;
        padding: 0 20px;
    }
    .iNews-box {
        flex-direction: column;
        max-width: 500px;
        margin: 0 auto;
        padding: 20px;
    }
    .iNews-box .box-ttl-news {
        padding: 0;
        margin-bottom: 10px;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    .iNews-box .box-ttl-news .box-ttl {
        margin-bottom: 0;
        text-align: center;
    }
    .iNews-box .box-ttl-news .box-ttl .ttl {
        font-size: 18px;
        margin-bottom: 0;
    }
    .iNews-box .box-ttl-news .box-ttl .sub-ttl {
        margin-left: 0;
    }
    .iNews-box ul {
        width: 100%;
        max-width: 100%;
        margin-top: 0;
    }
    .iNews-box ul li:last-child a {
        background: transparent;
    }
    .iNews-box ul li a {
        background-size: 350% 5px;
        flex-direction: column;
        align-items: flex-start;
        padding-bottom: 10px;
    }
    .iNews-box ul li a .date {
        margin-right: 0;
        margin-bottom: 5px;
        font-size: 12px;
    }
    .iNews-box ul li a .ttl {
        font-size: 14px;
    }
    .iMedical {
        padding: 60px 0;
    }
    .iMedical .idx-box-ttl .ico img {
        width: 34px;
        height: auto;
    }
    .iMedical-list {
        flex-direction: column;
        padding: 0 20px;
    }
    .iMedical-list li {
        width: 100%;
        max-width: 500px;
        margin: 0 auto 20px !important;
        padding: 15px;
    }
    .iMedical-list li:last-child {
        margin-bottom: 0 !important;
    }
    .iMedical-list li .idx-box-ttl {
        padding-left: 0 !important;
        padding-bottom: 10px;
        margin-bottom: 10px;
    }
    .iMedical-list li .idx-box-ttl .ico {
        margin-right: 5px;
    }
    .iMedical-list li .idx-box-ttl .ico img {
        width: 40px;
        height: auto;
    }
    .iMedical-list li .idx-box-ttl .ttl h2 {
        margin-bottom: 0;
        font-size: 23px;
    }
    .iMedical-list li .idx-box-ttl .ttl .idx-ttl-en {
        font-size: 12px;
        margin-left: 0;
    }
    .iMedical-list li .txt>p {
        font-size: 14px;
    }
    .iGastro-box {
        max-width: calc(100% - min(10.67vw, 40px));
        margin-top: -60px;
        padding: 15px min(4vw, 15px);
    }
    .iGastro-fx {
        flex-direction: column;
    }
    .iGastro-fx .box-cnt:before {
        left: max(-4vw, -15px);
        top: 0;
        background: url(../images/idx-gastro-img01.png) no-repeat center;
        background-size: 100% auto;
        width: 66.9375em;
        height: 76.1875em;
    }
    .iGastro-fx .box-cnt .idx-box-ttl .ico {
        margin-right: 5px;
    }
    .iGastro-fx .box-cnt .idx-box-ttl .ico img {
        width: 40px;
        height: auto;
    }
    .iGastro-fx .box-cnt .idx-box-ttl .ttl h2 {
        font-size: 24px;
    }
    .iGastro-fx .box-cnt .idx-box-ttl .ttl .idx-ttl-en {
        font-size: 12px;
        margin-left: 0;
    }
    .iGastro-fx .box-cnt h3 {
        margin-left: 0;
        font-size: 18px;
        margin-bottom: 20px;
    }
    .iGastro-fx .box-img {
        margin-left: 0;
        margin-top: 20px;
    }
    .iGastro-fx .box-img .img {
        width: 100%;
        max-width: 500px;
        margin: 0 auto;
    }
    .iGastro-fx .box-img .img img {
        width: 100%;
        height: auto;
        border-radius: 20px;
        max-height: 350px;
        object-fit: cover;
        object-position: top;
    }
    .iGastro-list {
        margin-left: 0;
        flex-wrap: wrap;
        justify-content: center;
        margin-right: 0;
    }
    .iGastro-list li {
        flex-shrink: 0;
        width: min(37.87vw, 170px);
        height: min(37.87vw, 170px);
        max-width: 100%;
        margin: min(1.33vw, 5px) !important;
    }
    .iGastro-list li a {
        font-size: min(1.33vw, 6px);
        align-items: center;
        justify-content: center;
        padding-bottom: 30px;
    }
    .iGastro-list li a:before {
        font-size: 10px;
        bottom: 0.6em;
    }
    .iGastro-list li a .ico {
        font-size: min(1.87vw, 7px);
        margin-bottom: min(4vw, 15px);
    }
    .iGastro-list li a .ttl {
        min-height: auto;
        font-size: min(3.73vw, 16px);
    }
    .iGastro-frame {
        margin-left: 0;
        margin-top: -50px;
        max-width: 100%;
        border-radius: 15px;
    }
    .iGastro-frame:before {
        border-radius: 15px;
        width: calc(100% - 10px);
        height: calc(100% - 10px);
    }
    .iGastro-frame-box {
        padding: 15px;
    }
    .iGastro-frame-box h3 {
        font-size: 20px;
        margin-left: 0;
        margin-bottom: 10px;
    }
    .iGastro-frame-fx {
        flex-direction: column;
        margin-top: 20px;
    }
    .iGastro-frame-fx .box-cnt {
        width: 100%;
        margin: 0 auto 20px !important;
    }
    .iGastro-frame-fx .box-cnt:last-child {
        margin-bottom: 0 !important;
    }
    .iEndo {
        padding: 60px 20px;
    }
    .iEndo-fx {
        flex-direction: column;
        max-width: 500px;
        margin: 0 auto;
        z-index: 1;
    }
    .iEndo-fx .box-img {
        margin-left: 0;
        margin-top: 0;
    }
    .iEndo-fx .box-img .img img {
        width: 100%;
        height: auto;
        max-height: 350px;
        object-fit: cover;
        object-position: top;
        border-radius: 20px;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }
    .iEndo-fx .box-cnt {
        margin-left: 0;
        width: 100%;
    }
    .iEndo-fx .box-cnt .idx-box-ttl .ico {
        margin-right: 10px;
    }
    .iEndo-fx .box-cnt .idx-box-ttl .ico img {
        width: 40px;
        height: auto;
    }
    .iEndo-fx .box-cnt .idx-box-ttl .ttl h2 {
        font-size: 24px;
    }
    .iEndo-fx .box-cnt .idx-box-ttl .ttl .idx-ttl-en {
        margin-left: 0;
        font-size: 12px;
    }
    .iEndo-fx .box-cnt h3 {
        font-size: 20px;
    }
    .iEndo-fx .box-cnt .txt {
        margin-bottom: 20px;
    }
    .iEndo-fx .box-cnt .txt>p {
        font-size: 14px;
    }
    .iEndo-fx .box-cnt .idx-list-btn02 li {
        width: calc(50% - 5px);
        max-width: 100%;
        margin-right: 5px;
    }
    .iEndo-fx .box-cnt .idx-list-btn02 li:nth-child(2n) {
        margin-right: 0;
    }
    .iEndo-fx .box-cnt .idx-list-btn02 li a {
        font-size: 12px;
        min-width: 100%;
        padding-left: 10px;
        padding-right: 20px;
        justify-content: flex-start;
    }
    .iEndo-fx .box-cnt .idx-list-btn02 li a:before {
        right: 10px;
        width: 16px;
        height: 16px;
    }
    .iFeatures {
        padding: 20px 0 90px;
    }
    .iFeatures .inner_big {
        max-width: 100%;
        padding: 0 min(5.33vw, 20px);
    }
    .iFeatures .idx-box-ttl .ico img {
        width: 40px;
        height: auto;
    }
    .iFeatures-list {
        flex-wrap: wrap;
        max-width: 500px;
        margin: 0 auto 30px;
    }
    .iFeatures-list li {
        margin: 0 auto 20px;
        width: 100%;
        max-width: 100%;
        border-radius: 15px;
        padding: 15px;
        font-size: min(3.33vw, 12.5px);
    }
    .iFeatures-list li:last-child {
        margin-bottom: 0;
    }
    .iFeatures-list02 {
        flex-wrap: wrap;
        max-width: 500px;
        margin: 0 auto;
    }
    .iFeatures-list02 .box-cnt {
        width: 100%;
        max-width: 100%;
        margin: 0 auto 20px;
        font-size: min(3.2vw, 12px);
        padding: 15px;
    }
    .iFeatures-list02 .box-cnt:last-child {
        margin-bottom: 0 !important;
    }
    .iFeatures-list02 .box-cnt h3 {
        font-size: 2em;
    }
    .iFeatures-list02 .box-cnt .idx-btn02 a {
        min-width: 100%;
    }
    .iInternal-box {
        padding: 15px min(4vw, 15px);
        width: calc(100% - 20px);
        border-radius: 20px;
        background-size: cover;
        max-width: 550px;
        margin: -50px auto 0;
        margin-top: -50px;
    }
    .iInternal-fx {
        flex-direction: column;
    }
    .iInternal-fx .box-img {
        order: 1;
        right: 0;
        width: 100%;
        max-width: 500px;
        margin: 0 auto 20px;
    }
    .iInternal-fx .box-img .img img {
        width: 100%;
        height: 250px;
        border-radius: 15px;
        object-fit: cover;
		object-position: top;
    }
    .iInternal-fx .box-cnt {
        order: 2;
    }
    .iInternal-fx .box-cnt .idx-box-ttl .ico {
        margin-right: 10px;
    }
    .iInternal-fx .box-cnt .idx-box-ttl .ico img {
        width: 40px;
        height: auto;
    }
    .iInternal-fx .box-cnt .idx-box-ttl .ttl .idx-ttl-en {
        margin-left: 0;
    }
    .iInternal-fx .box-cnt .txt {
        font-size: 16px;
        line-height: 1.6em;
    }
    .iInternal-list {
        margin-right: 0;
        justify-content: center;
    }
    .iInternal-list li {
        width: min(40vw, 170px);
        height: min(40vw, 170px);
        max-width: 100%;
        margin: min(1.33vw, 5px) !important;
    }
    .iInternal-list li a {
        min-width: 100%;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    .iInternal-list li a:before {
        font-size: min(2.93vw, 11px);
        bottom: 0.5em;
    }
    .iInternal-list li a .ico {
        margin-bottom: 0;
        height: 60px;
    }
    .iInternal-list li a .ico img {
        width: auto;
        height: 60px;
    }
    .iInternal-list li a .ttl {
        font-size: min(4.27vw, 16px);
    }
    .iOther {
        padding-top: 60px;
        padding-bottom: 120px;
    }
    .iOther .inner_big {
        padding: 0 20px;
    }
    .iOther .idx-box-ttl .ico {
        margin-right: 5px;
    }
    .iOther .idx-box-ttl .ico img {
        width: min(9.07vw, 34px);
        height: auto;
    }
    .iOther .txt {
        font-size: min(4.27vw, 16px);
        line-height: 1.6em;
        margin-bottom: 20px;
    }
    .iOther-list {
        flex-wrap: wrap;
        max-width: 500px;
        margin: 0 auto;
    }
    .iOther-list li {
        width: 100%;
        max-width: 100%;
        font-size: 12.5px;
        margin: 0 auto 20px;
    }
    .iOther-list li:last-child {
        margin-bottom: 0;
    }
    .iOther-list li a {
        padding: 15px;
    }
    .iOther-list li a .img {
        width: 100%;
        margin: 0 auto 10px;
        max-width: 500px;
    }
    .iOther-list li a .img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        max-height: 200px;
    }
    .iFeatures02 {
        padding-bottom: 60px;
    }
    .iFeatures02-box {
        padding: 30px 0;
        max-width: calc(100% - 40px);
        margin: -70px auto 0;
        border-radius: 20px;
    }
    .iFeatures02-box:before {
        border-radius: 20px;
    }
    .iFeatures02-box .inner_big {
        padding: 0 15px;
        max-width: 100%;
    }
    .iFeatures02 .idx-box-ttl {
        margin-bottom: 20px;
    }
    .iFeatures02 .idx-box-ttl .ico {
        margin-right: 10px;
    }
    .iFeatures02 .idx-box-ttl .ico img {
        width: 34px;
        height: auto;
    }
    .iFeatures02-list {
        flex-wrap: wrap;
        max-width: 500px;
        margin: 0 auto 30px;
    }
    .iFeatures02-list li {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 20px;
        flex-direction: column;
        border-radius: 15px;
    }
    .iFeatures02-list li:last-child {
        margin-bottom: 0;
    }
    .iFeatures02-list li .img {
        order: 1 !important;
        width: 100%;
    }
    .iFeatures02-list li .img img {
        border-top-right-radius: 15px !important;
        border-top-left-radius: 15px !important;
        border-bottom-left-radius: 0 !important;
        border-bottom-right-radius: 0 !important;
        width: 100%;
        height: 100%;
        max-height: 250px;
        object-fit: cover;
    }
    .iFeatures02-list li .box-cnt {
        padding: 15px;
        order: 2 !important;
    }
    .iFeatures02-list li .box-cnt .stt {
        font-size: 12px;
    }
    .iFeatures02-list li .box-cnt h3 {
        font-size: 20px;
    }
    .iFeatures02-list li .box-cnt h3 br {
        display: none;
    }
    .iFeatures02-list li .box-cnt .txt>p {
        font-size: 14px;
    }
    .iGreeting {
        padding: 60px 0;
    }
    .iGreeting .inner_big {
        max-width: 100%;
        padding: 0 20px;
    }
    .iGreeting .idx-box-ttl {
        margin-bottom: 0;
    }
    .iGreeting .idx-box-ttl .ico img {
        width: 40px;
        height: auto;
    }
    .iGreeting-fx {
        flex-direction: column;
    }
    .iGreeting-fx .box-img {
        width: fit-content;
        order: 1;
        margin: 0 auto 20px;
        font-size: 8px;
    }
    .iGreeting-fx .box-img .box-name .sub-name {
        background: url(../images/idx-company-hr.svg) no-repeat bottom center;
        background-size: 8em 2px;
    }
    .iGreeting-fx .box-cnt {
        order: 2;
        margin-right: 0;
    }
    .iGreeting-fx .box-cnt .txt {
        margin-bottom: 30px;
    }
    .iGreeting-fx .box-cnt .txt>p {
        font-size: 16px;
    }
    .iGreeting-fx .box-cnt .idx-list-btn .idx-btn02 {
        width: calc(50% - 5px);
        max-width: 100%;
    }
    .iGreeting-fx .box-cnt .idx-list-btn .idx-btn02 a {
        min-width: 100%;
        padding-right: 30px;
        padding-left: 20px;
        line-height: 1.4em;
        text-align: center;
    }
    .idx_gallery {
        margin-top: 40px;
    }
    .idx_gallery .list .item {
        margin: 0 10px;
    }
    .idx_gallery .list .item img {
        border-radius: 15px;
        width: 250px;
        height: auto;
    }
    .idx-list-btn li {
        width: calc(50% - 5px) !important;
        margin-right: 5px !important;
        max-width: 100%;
    }
    .idx-list-btn li:nth-child(2n) {
        margin-right: 0;
    }
    .idx-list-btn li a {
        min-width: 100%;
        font-size: min(3.47vw, 13px);
        line-height: 1.4em;
        padding-left: 10px;
        padding-right: 20px;
    }
    .idx-list-btn li a:before {
        width: min(4.27vw, 16px);
        height: min(4.27vw, 16px);
    }
    .idx-btn-news a {
        font-size: 14px;
    }
    .idx-box-ttl .ttl h2 {
        font-size: min(6.93vw, 26px);
    }
    .idx-box-ttl .ttl .idx-ttl-en {
        font-size: min(3.73vw, 14px);
    }
}


/*# sourceMappingURL=index_sp.css.map */