@charset "utf-8";


.medical-h2 {
    background-color: #175899;
    text-align: center;
    color: #fff;
    font-size: 3.6rem;
    font-weight: normal;
    letter-spacing: .05em;
    line-height: 1.6em;
    padding: .5em 3%;
    margin-bottom: 60px;
}

.medical-h3 {
    color: #C2A95C;
    text-shadow: 0 2px 1px rgba(0, 0, 0, 0.10);
    font-size: 2.4rem;
    line-height: normal;
}

.under-subtitle-h3-blue {
    display: inline-block;
    position: relative;
    margin: calc(3.5em / 3) 0 calc(3.5em / 4) calc(3.5em / 2);
    color: #175899;
    font-size: 2.4rem;
    line-height: 1.2;
    z-index: 10;
}

.under-subtitle-h3-blue::before {
    position: absolute;
    top: 50%;
    left: calc(-3.5em / 2);
    transform: translateY(-50%);
    z-index: -1;
    width: 2.5em;
    height: 2.5em;
    border-radius: 50%;
    background: #e4edf5;
    content: '';
}

.under-subtitle-h3-white {
    display: inline-block;
    position: relative;
    margin: calc(3.5em / 3) 0 calc(3.5em / 4) calc(3.5em / 2);
    color: #175899;
    font-size: 2.4rem;
    line-height: 1.2;
    z-index: 10;
}

.under-subtitle-h3-white::before {
    position: absolute;
    top: 50%;
    left: calc(-3.5em / 2);
    transform: translateY(-50%);
    z-index: -1;
    width: 2.5em;
    height: 2.5em;
    border-radius: 50%;
    background: #FFFEFE;
    content: '';
}

.under-title-h4 {
    color: #091B2C;
    font-size: 2.0rem;
    font-weight: 500;
    line-height: normal;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-color: #C2A95C;
    text-decoration-thickness: auto;
    text-underline-offset: 25%;
    text-underline-position: from-font;
}

.under-lead {
    text-align: center;
    margin: 75px auto;
    color: #091B2C;
    font-size: 1.6rem;
    line-height: normal;
}

/* ===== ブレイクポイント：タブレット ===== */
@media screen and (min-width: 768px) and (max-width: 1024px) {
    .medical-h2 {
        font-size: 2.8rem;
        letter-spacing: .05em;
        line-height: 1.6em;
        padding: .5em 3%;
        margin-bottom: 40px;
    }

    .medical-h3 {
        font-size: 2.0rem;
    }

    .under-lead {
        text-align: start;
        padding: 0 6%;
    }
}

/* ===== ブレイクポイント：スマホ ===== */
@media (max-width: 768px) {
    .medical-h2 {
        font-size: 2.4rem;
        letter-spacing: .05em;
        line-height: 1.6em;
        padding: .5em 3%;
        margin-bottom: 40px;
    }

    .medical-h3 {
        font-size: 2.0rem;
    }

    .under-subtitle-h3-blue {
        font-size: 2.0rem;
        text-align: start;
    }

    .under-subtitle-h3-blue::before {
        width: 2.0em;
        height: 2.0em;
        left: calc(-2.5em / 2);
    }

    .under-subtitle-h3-white {
        font-size: 2.0rem;
        text-align: start;
    }

    .under-subtitle-h3-white::before {
        width: 2.0em;
        height: 2.0em;
        left: calc(-2.5em / 2);
    }

    .under-title-h4 {
        color: #091B2C;
        font-size: 2.0rem;
        font-weight: 500;
        line-height: normal;
        text-decoration-line: underline;
        text-decoration-style: solid;
        text-decoration-skip-ink: auto;
        text-decoration-color: #C2A95C;
        text-decoration-thickness: auto;
        text-underline-offset: 25%;
        text-underline-position: from-font;
    }

    .under-lead {
        text-align: start;
        margin: 40px auto;
        padding: 0 4%;
        line-height: 26px;
    }
}


/* ===== 下層ヘッダー ===== */
.under_head {
    height: 70vh;
}

.under_head h1 {
    color: #fff;
    font-size: 1.2rem;
	padding:0 0.5%;
}

.under_head {
    position: relative;
    z-index: 0;
    width: 100%;
    height: 50vw;
    max-height: 480px;
    background-image: url(../images/under-head.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

.under_head::before {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0) 20%, rgba(0, 0, 0, 1) 80%);
    opacity: 0.05;
}

.under_ttl {
    position: absolute;
    z-index: 1;
    margin: auto;
    left: 0;
    right: 0;
    top: 30%;
    transform: translateY(40%);
    color: #fff;
    width: 100%;
}


.under_ttlp {
    color: #FFFEFE;
    text-align: center;
    text-shadow: 0 4px 4px rgba(0, 0, 0, 0.40);
    font-size: 5.8rem;
    font-style: normal;
    line-height: normal;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-color: #A18838;
    text-decoration-thickness: 6%;
    /* 3.84px */
    text-underline-offset: 25%;
    /* 16px */
    text-underline-position: from-font;
}
.fv-logo a {
    position: relative;
    z-index: 10; /* 他の要素の上に表示 */
	display: inline-block;
}

.fv-logo img {
    display: block;
    height: auto;
    width: auto;
    padding-left: 0.7%;
}
/* ===== ブレイクポイント：タブレット ===== */
@media screen and (min-width: 768px) and (max-width: 1024px) {
    .under_head {
        height: 50vw;
        max-height: 280px;
    }

    .under_ttlp {
        font-size: 3.6rem;
    }

    .fv-logo img {
        width: auto;
        height: 60px;
    }
}

/* ===== ブレイクポイント：スマホ ===== */
@media (max-width: 768px) {
    .under_ttlp {
        font-size: 2.4rem;
    }

    .under_head h1 {
        color: #fff;
        font-size: 1.0rem;
    }
    .fv-logo img {
        display: block;
        height: 32px;
        width: auto;
        padding-left: 0.7%;
    }

}

/* ===== パンくずリスト ===== */

#breadcrumbs {
    padding: 20px 9.2%;
    background: #E4EDF5;
}

.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    color: #000;
    text-align: center;
    font-size: 1.6rem;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    padding: 20px 6.2%;
    background-color: #E4EDF5;
}

.breadcrumb ol {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
    padding: 0;
    margin: 0;
}

.breadcrumb li {
    display: flex;
    align-items: center;
}

.breadcrumb li+li::before {
    content: ">";
    color: #999;
    margin: 0 8px;
}

.breadcrumb a {
    text-decoration: none;
    color: #b19768;
    transition: color 0.2s;
}

.breadcrumb a:hover {
    text-decoration: underline;
    color: #8e6c2d;
}

/* 現在のページのリンク */
.breadcrumb .active {
    color: #000;
    /* 黒色 */
    font-weight: bold;
    /* 強調したい場合は太字 */
}


@media only screen and (max-width: 768px) {
    .breadcrumb {
		font-size: 0.9rem;
    }
}


/* ===== パンくずリスト ===== */