@charset "utf-8";

/* ------------------------------
 メインビジュアル（PC）
------------------------------ */
.mainimgBlock {
    position: relative;
    width: 100%;
    padding-top: 60px;
    padding-left: 55px;
    background-color: var(--brown-color);
    background: 
        linear-gradient(transparent 47% , #fff 0),
        linear-gradient(45deg, var(--brown-color) , #33161e);
}
.mainImg {
    position: relative;
    background-color: #fff;
    border-top: solid 3px var(--yellow-color);
}
.mainimgBlock .swiper,
.mainimgBlock .swiper-slide,
.mainimgBlock .swiper-img {
	height: 100%;
}
.mainimgBlock .swiper-slide-active .swiper-img,
.mainimgBlock .swiper-slide-duplicate-active .swiper-img,
.mainimgBlock .swiper-slide-prev .swiper-img {
	animation: zoomUp 10s linear 0s normal both;
}
@keyframes zoomUp {
	0% {
		transform: scale(1);
	}
	100% {
		transform: scale(1.15);
	}
}
.mainimgBlock .swiper-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/* -- 動画・スライド -- */
.mainimgBlock .mainimgSwiper {
    position: relative;
    width: 100%;
    height: 100%;
}
/* 画像上ロゴ */
.mainimgBlock .mainimgLogoBox {
    width: 234px;
    position: absolute;
    top: calc(60px + 45px);
    right: 40px;
    z-index: 999;
}
/* メインテキスト */
.mainText {
    width: 738px;
    display: inline-block;
    padding-top: 70px;
    padding-right: 72px;
    background-color: #fff;
    position: absolute;
    bottom: -15px;
    left: -60px;
    z-index: 1;
}
/* お問い合わせ */
.mainimgBlock .contact {
    line-height: 1.5;
    color: #fff;
    font-weight: bold;
    display: flex;
    background-color: var(--yellow-color);
}
.mainimgBlock .contact a {
    width: 100%;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    color: #fff;
}
.mainimgBlock .contact .title {
    font-size: 1.8rem;
    line-height: 1.25;
    text-align: center;
    color: var(--yellow-color);
    display: inline-block;
    padding: 5px 10px;
    margin-bottom: 12px;
    background-color: #fff;
}
@media screen and (min-width: 768px) {
    /* お問い合わせ */
    .mainimgBlock .contact {
        text-align: center;
        width: 234px;
        aspect-ratio: 1 / 1;
        position: absolute;
        right: 72px;
        bottom: -130px;
        z-index: 10;
        border-radius: 100%;
    }
    .mainimgBlock .contact a {
        border-radius: 100%;
    }
}
/* ------------------------------
 メインビジュアル（SP）
------------------------------ */
@media screen and (max-width: 767px) {
    .mainimgBlock {
        width: 100%;
        max-width: 100%;
        max-height: 100%;
        overflow: visible;
        padding-top: 5%;
        padding-left: 5%;
    }
    .mainImg {
        aspect-ratio: 71 / 92;
        border-top-width: 2px;
        margin-bottom: 45px;
    }
    /* 画像上ロゴ */
    .mainimgBlock .mainimgLogoBox {
        width: 111px;
        top: calc(5% + 2%);
        right: 5%;
    }
   /* メインテキスト */
    .mainText {
        width: 91.2%;
        padding-top: 5%;
        padding-right: 6.1%;
        left: -5.5%;
        bottom: -15px;
    }
    /* お問い合わせ */
    .mainimgBlock .contact a {
        padding: 18px;
        flex-flow: wrap;
        justify-content: flex-start;
        gap: 10px;
    }
    .mainimgBlock .contact .title {
        font-size: 1.6rem;
        margin-bottom: 0;
        padding: 10px;
    }
}

/* ------------------------------
 ご利用案内（PC）
------------------------------ */
.guideBlock {
    padding: 160px 0 170px;
}
.guideList {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
}
.guideList li {
    position: relative;
}
.guideList .title {
    font-size: 2.4rem;
    font-weight: bold;
    padding: 17px  55px 17px 17px;
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: #fff;
}
.guideList .title::after {
    content: "";
    width: 33px;
    height: 33px;
    position: absolute;
    right: 17px;
    top: 0;
    bottom: -1px;
    margin: auto;
    border-radius: 100%;
    background: var(--yellow-color) url(../img/arrow_w.svg) no-repeat center / 6px auto;
}
@media print, screen and (min-width: 768px) {
    .guideList li {
        width: calc((100% - 2px) / 2);
    }
}
/* ------------------------------
 ご利用案内（SP）
------------------------------ */
@media screen and (max-width: 767px) {
    .guideBlock {
        padding: 45px 0 55px;
    }
    .guideList .title {
        font-size: 1.8rem;
        padding: 10px 35px 10px 0;
    }
    .guideList .title::after {
        width: 24px;
        height: 24px;
        right: 10px;
        background-size: 5px auto;
    }
}
/* ------------------------------
 ブログ（PC）
------------------------------ */
.blogBlock {
    color: #fff;
    position: relative;
    padding: 90px 0 100px;
    background-color: var(--brown-color);
}
.blogBlock a {
	color: #fff;
}
/* -- h2 -- */
.blogBlock h2 {
    font-family: var(--font-en);
    font-size: 6.8rem;
    font-weight: 600;
    line-height: 1.4;
    color: #fff;
    letter-spacing: 0;
    margin-bottom: 35px;
    background-image: linear-gradient(90deg, var(--yellow-color));
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 90px 4px;
    padding-bottom: 10px;
}
/* 一覧へリンク */
.blogBlock .link {
    font-weight: bold;
    line-height: 26px;
    position: relative;
    padding-right: 30px;
}
.blogBlock .link::after {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 26px;
    height: 26px;
    border-radius: 100%;
    background: var(--yellow-color) url(../img/icon_list.svg) no-repeat center center / 10px auto;
}
/* -- タグ絞り込み -- */
.blogBlock input {
    display: none;
}
.tagBtnBox {
    display: flex;
    flex-flow: row wrap;
    gap: 1px;
}
label.tagBtn {
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.2;
    color: var(--yellow-color);
    display: flex;
    justify-content: center;
    align-items: center;
    width: 118px;
    height: 34px;
    background-color: #fff;
    transition: 0.3s ease-in-out;
    cursor: pointer;
}
label.tagBtn:hover,
#blog1:checked ~ .tagBtnBox label.tagBtn[for="blog1"],
#blog2:checked ~ .tagBtnBox label.tagBtn[for="blog2"],
#blog3:checked ~ .tagBtnBox label.tagBtn[for="blog3"],
#blog4:checked ~ .tagBtnBox label.tagBtn[for="blog4"],
#blog5:checked ~ .tagBtnBox label.tagBtn[for="blog5"],
#blog6:checked ~ .tagBtnBox label.tagBtn[for="blog6"] {
    color: #fff;
    background-color: var(--yellow-color);
}
.tagArea {
    opacity: 0;
    visibility: hidden;
    display: none;
    transition: 0.3s ease-in-out;
}
#blog1:checked ~ .tagArea.blog1,
#blog2:checked ~ .tagArea.blog2,
#blog3:checked ~ .tagArea.blog3,
#blog4:checked ~ .tagArea.blog4,
#blog5:checked ~ .tagArea.blog5,
#blog6:checked ~ .tagArea.blog6 {
    opacity: 1;
    visibility: visible;
    display: block;
}
/* -- 記事一覧 -- */
.blogBlock .blogSwiper {
    position: relative;
    overflow: hidden;
    padding-bottom: 55px;
}
.blogBlock .blogList {
	display: flex;
}
.blogBlock .blogText {
	font-size: 1.8rem;
}
/* Swiper */
.blogBlock .swiper-button-prev,
.blogBlock .swiper-button-next {
    position: absolute;
    top: calc(100% - 45px);
    z-index: 20;
}
.blogBlock .swiper-button-prev {
    left: 0;
}
.blogBlock .swiper-button-next {
    right: auto;
    left: 45px;
}
@media print, screen and (min-width: 768px) {
    .blogBlock h2 {
       width: 1140px;
       margin-left: auto;
       margin-right: auto;
    }
    /* 一覧へリンク */
    .blogBlock .link {
        font-size: 1.8rem;
        position: absolute;
        right: calc(50% - 570px);
        bottom: 110px;
        z-index: 10;
    }
    /* -- タグ絞り込み -- */
    .blogBlock .tagBtnBox {
        width: 846px;
        justify-content: flex-end;
        position: absolute;
        top: 145px;
        right: calc(50% - 570px);
    }
    /* -- 記事一覧 -- */
    .blogBlock .blogSwiper {
        width: 100%;
        margin-left: calc(50% - 570px);
    }
    .blogSwiper:not(.swiper-initialized) .swiper-wrapper {
        gap: 0 45px;
    }
    .blogBlock .blogList li {
       width: 350px;
    }
}
/* ------------------------------
 ブログ（SP）
------------------------------ */
@media screen and (max-width: 767px) {
    .blogBlock  {
        padding: 60px 5% 50px;
    }
    /* -- h2 -- */
    .blogBlock h2 {
        font-size: 4.8rem;
        margin-bottom: 30px;
        background-size: 66px 3px;
        padding-bottom: 0;
    }
    /* 一覧へリンク */
    .blogBlock .link {
        text-align: right;
        margin-top: -30px;
        margin-bottom: 30px;
    }
    
    /* -- タグ絞り込み -- */
    .tagBtnBox {
        margin-bottom: 15px;
    }
    .blogBlock .tagBtnBox > * {
        width: calc((100% - 2px) / 3);
        flex: 1 1 auto;
    }
    label.tagBtn {
        font-size: 1.4rem;
        width: 100%;
        min-height: 36px;
    }
    /* -- 記事一覧 -- */
	.blogBlock .blogSwiper {
		position: relative;
		padding-bottom: 45px;
	}
    /* Swiper */
    .blogBlock .swiper-button-prev,
    .blogBlock .swiper-button-next {
        top: calc(100% - 30px);
    }
    .blogBlock .swiper-button-next {
        right: auto;
        left: 35px;
    }
    .blogBlock .swiper-pagination, 
    .blogBlock .swiper-horizontal > .swiper-pagination-bullets, 
    .blogBlock .swiper-pagination-bullets.swiper-pagination-horizontal, 
    .blogBlock .swiper-pagination-custom, 
    .blogBlock .swiper-pagination-fraction {
        justify-content: flex-end;
    }
}
/* ------------------------------
 練習医育成（PC）
------------------------------ */
.trainingBlock {
    padding-top: 120px;
    padding-bottom: 120px;
}
/* h2 */
.trainingBlock h2 {
    font-family: var(--font-min);
    font-size: 2.8rem;
    font-weight: 500;
    letter-spacing: 0.05em;
}
/* 左ブロック */
.trainingBlock .textBox {
    text-align: center;
    background-color: var(--base-color);
}
.trainingBlock .textBox a {
    display: flex;
    flex-flow: column;
    justify-content: center;
    height: 100%;
    padding: 30px;
}
.trainingBlock .textBox h2 {
    padding-bottom: 15px;
    margin-bottom: 25px;
    background-image: linear-gradient(to right, var(--brown-color) 100%, transparent 0);
    background-size: 70px 4px;
    background-repeat: no-repeat;
    background-position: center bottom;
}
.trainingBlock .textBox .imgBox {
    width: 115px;
    margin: 0 auto 20px;
}
/* 詳細 */
.trainingBlock .detailBox {
    color: #fff;
}
.trainingBlock .detailBox a {
    color: #fff;
    padding: 40px;
}
.trainingBlock .detailBox h2 {
    color: #fff;
    text-align: left;
    margin-bottom: 15px;
}
/* 黄色背景（cvs） */
.trainingBlock .detailBox.cvs {
    background-color: var(--yellow-color);
}
/* 緑色背景（診療情報） */
.trainingBlock .detailBox.info {
    background-color: var(--green-color);
}
@media print, screen and (min-width: 768px) {
    .trainingBlock .inBlock {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr 1fr;
        gap: 1px;
        min-height: 440px;
    }
    .trainingBlock .textBox {
        grid-row: 1 / 3;
    }
    .trainingBlock .detailBox.cvs {
        grid-row: 1 / 2;
    }
    .trainingBlock .detailBox.info {
        grid-row: 2 / 3;
    }
    /* 詳細 */
    .trainingBlock .detailBox {
        display: flex;
        align-items: center;
    }
    .trainingBlock .detailBox a {
        display: grid;
        grid-template-columns: 100px 1fr; /* 左画像 / 右テキスト */
        grid-template-rows: auto auto;    /* h2 と p を別行 */
        column-gap: 20px;
        align-items: center;
        align-content: center;
        height: 100%;
    }
    .trainingBlock .detailBox .imgBox {
        grid-row: 1 / 3;
        width: 100px;
    }
    .trainingBlock .detailBox h2 {
        grid-row: 1 / 2;
    }
    .trainingBlock .detailBox p {
        grid-row: 2 / 3;
    }
}
/* ------------------------------
 練習医育成（SP）
------------------------------ */
@media screen and (max-width: 767px) {
    .trainingBlock .detailBox a {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 10px;
        padding: 30px 20px;
    }
    .trainingBlock .detailBox .imgBox {
        width: 65px;
    }
    .trainingBlock .detailBox h2 {
        width: calc(100% - (65px + 10px));
        margin-bottom: 0;
        font-size: 2.4rem;
    }
}
/* ------------------------------
 バナー（PC）
------------------------------ */
.bannerBlock {
    padding: 95px 0;
    background-color: var(--base-color);
}
.bannerBlock .inBlock {
    position: relative;
}
/* Swiper */
.bannerBlock .swiper-buttons {
    margin-top: 15px;
}

@media print, screen and (min-width: 768px) {
    .bannerBlock .textBox {
        width: 22.632%;
        min-height: 600px;
        padding-bottom: 60px;
    }
    .bannerBlock .bannerSwiper {
        overflow: hidden;
    }
    .bannerSwiper:not(.swiper-initialized) .swiper-wrapper {
        gap: 0 36px;
    }
    .bannerSwiper .swiper-slide {
		width: 258px;
    }
    /* Swiper */
    .bannerBlock .swiper-pagination,
    .bannerBlock .swiper-horizontal > .swiper-pagination-bullets, 
    .bannerBlock .swiper-pagination-bullets.swiper-pagination-horizontal, 
    .bannerBlock .swiper-pagination-custom, 
    .bannerBlock .swiper-pagination-fraction {
        bottom: 25px;
    }
}
/* ------------------------------
 バナー（SP）
------------------------------ */
@media screen and (max-width: 767px) {
    .bannerBlock {
        position: relative;
        padding-top: 50px;
        padding-bottom: 40px;
    }
    .bannerBlock .inBlock {
        width: auto;
        margin-left: 15%;
        margin-right: 15%;
    }
    /* Swiper */
    .bannerBlock .swiper-pagination,
    .bannerBlock .swiper-horizontal > .swiper-pagination-bullets, 
    .bannerBlock .swiper-pagination-bullets.swiper-pagination-horizontal, 
    .bannerBlock .swiper-pagination-custom, 
    .bannerBlock .swiper-pagination-fraction {
        justify-content: flex-end;
        left: auto;
        right: -15%;
    }
    .bannerBlock .swiper-buttons {
        margin-left: -15%;
    }
    
}
/* ------------------------------
 Swiper 部品
------------------------------ */
/* PREV NEXT */
.swiper-buttons {
    display: flex;
    justify-content: flex-start;
    gap: 5px;
    z-index: 20;
}
.swiper-pagination .swiper-pagination-bullet {
    background-color: rgba(153, 150, 138, .5);
    opacity: 1;
}
.swiper-pagination .swiper-pagination-bullet-active {
    background-color: var(--yellow-color);
}
.swiper-button-prev,
.swiper-button-next {
    position: static;
    width: 44px;
    height: 44px;
    margin: 0;
    transition: 0.3s ease-in-out;

    /* Safari描画バグ対策 */
    transform: translateZ(0);
    backface-visibility: hidden;
}
.swiper-button-prev::after,
.swiper-button-next::after {
    content: "";
    display: block;
    width: 40px;
    height: 40px;
    border-radius: 100%;
    background: var(--yellow-color) url(../img/arrow_w.svg) no-repeat center / 7px auto;

    /* Safari描画バグ対策 */
    transform: translateZ(0);
}
.swiper-button-prev::after {
    transform: rotate(180deg);
}
/* Pagination */
.swiper-pagination,
.swiper-horizontal > .swiper-pagination-bullets, 
.swiper-pagination-bullets.swiper-pagination-horizontal, 
.swiper-pagination-custom, 
.swiper-pagination-fraction {
    width: 1140px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0;
}
.swiper-button-prev:hover,
.swiper-button-next:hover {
    opacity: .7;
}
@media screen and (max-width: 767px) {
    /* PREV NEXT */
    .swiper-button-prev,
    .swiper-button-next {
        width: 30px;
        height: 30px;
    }
    .swiper-button-prev::after,
    .swiper-button-next::after {
        width: 30px;
        height: 30px;
        background-size: 6px auto;
    }
    /* Pagination */
    .swiper-pagination,
    .swiper-horizontal > .swiper-pagination-bullets, 
    .swiper-pagination-bullets.swiper-pagination-horizontal, 
    .swiper-pagination-custom, 
    .swiper-pagination-fraction {
        width: 100%;
        gap: 6px;
    }
    .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
    .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
        width: 6px;
        height: 6px;
    }
}