:root {
    --color-black: #000;
    --color-white: #fff
}

html {
    font-size: 10px
}

body {
    font-family: "Noto Serif JP", serif;
    font-size: 14px;
    letter-spacing: .1em;
    font-weight: 600;
    line-height: 1.6
}

body.is-scroll-lock {
    overflow: hidden
}

body.modal-open {
    overflow: hidden
}

.js-fadeIn {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .6s ease, transform .6s ease
}

.is-visible {
    opacity: 1;
    transform: translateY(0)
}

*:where(:not(html, iframe, canvas, img, svg, video, audio):not(svg *, symbol *)) {
    all: unset;
    display: revert
}

*,
*::before,
*::after {
    box-sizing: border-box
}

html {
    -moz-text-size-adjust: none;
    -webkit-text-size-adjust: none;
    text-size-adjust: none
}

a,
button {
    cursor: revert
}

ol,
ul,
menu,
summary {
    list-style: none
}

img {
    max-inline-size: 100%;
    max-block-size: 100%
}

table {
    border-collapse: collapse
}

input,
textarea {
    -webkit-user-select: auto
}

textarea {
    white-space: revert
}

meter {
    -webkit-appearance: revert;
    appearance: revert
}

:where(pre) {
    all: revert;
    box-sizing: border-box
}

::placeholder {
    color: unset
}

:where([hidden]) {
    display: none
}

:where([contenteditable]:not([contenteditable=false])) {
    -moz-user-modify: read-write;
    -webkit-user-modify: read-write;
    overflow-wrap: break-word;
    -webkit-line-break: after-white-space;
    -webkit-user-select: auto
}

:where([draggable=true]) {
    -webkit-user-drag: element
}

:where(dialog:modal) {
    all: revert;
    box-sizing: border-box
}

::-webkit-details-marker {
    display: none
}

.footer {
    background: #1f244f;
    padding: 16px 0;
    color: #fff
}

.footer .u-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0 100px
}

@media screen and (max-width: 768px) {
    .footer .u-inner {
        gap: 0
    }
}

.footer small {
    font-size: 10px
}

.footer span {
    background: url(/assets/image/footer_top.webp);
    background-size: cover;
    width: 40px;
    aspect-ratio: 1/1;
    display: inline-block;
    cursor: pointer
}

@media screen and (max-width: 768px) {
    .footer span {
        width: 32px
    }
}

.footer__copy {
    max-width: calc(100% - 60px)
}

.c-cta {
    background: #37839e;
    padding: 0 0 24px;
}

/* CTAエリアの追加ブロック */
.c-cta .c-headingType001 {
    padding: 16px 5%;
    margin-bottom: 16px;
    background-color: #1f244f;
    gap: 16px;
    justify-content: flex-start;
}

.c-cta .c-headingType001 .c-headingType001__body {
    width: auto;
}


/* CTAエリアの追加ブロック */

.c-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between
}

@media screen and (max-width: 768px) {
    .c-cta__inner {
        flex-wrap: wrap;
        gap: 16px 0
    }
}

.c-cta__text {
    font-size: 14px;
    color: #fff;
    width: calc(100% - 400px)
}

@media screen and (max-width: 768px) {
    .c-cta__text {
        width: 100%
    }
}

.c-cta__text span {
    color: #ddd47f
}

.c-cta__text span.c-cta__suggestion {
    color: #fff;
}

@media screen and (max-width: 768px) {
    .c-cta__text span.c-cta__suggestion {
        display: block;
    }
}

.c-cta__text span.c-cta__suggestion.--small {
    font-size: 12px;
    color: #1f244f;
}

.c-cta__button {
    display: inline-block;
    background: #fff;
    color: #37839e;
    padding: 8px 24px;
    cursor: pointer;
    font-weight: 800
}

@media screen and (max-width: 768px) {
    .c-cta__button {
        width: 100%;
        text-align: center;
        padding: 16px 24px
    }
}

.c-headingType001 {
    display: flex;
    align-items: center;
    gap: 0 24px;
    margin-bottom: 32px
}

@media screen and (max-width: 768px) {
    .c-headingType001 {
        gap: 0 12px
    }
}

.c-headingType001__icon {
    display: inline-block;
    width: 62px;
    aspect-ratio: 85/96;
    background: url(/assets/image/logo_main.svg);
    background-size: cover
}

@media screen and (max-width: 768px) {
    .c-headingType001__icon {
        width: 32px
    }
}

.c-headingType001__body {
    width: calc(100% - 88px)
}

@media screen and (max-width: 768px) {
    .c-headingType001__body {
        width: calc(100% - 56px)
    }
}

.c-headingType001__bodyEn {
    font-size: 18px;
    font-weight: 800;
    color: #ddd47f;
    letter-spacing: .2em
}

.c-headingType001__bodyEn span {
    font-weight: 200
}

@media screen and (max-width: 768px) {
    .c-headingType001__bodyEn {
        font-size: 12px
    }
}

.c-headingType001__bodyJa {
    font-weight: 800;
    font-size: 20px;
    color: #fff;
    letter-spacing: .2em
}

@media screen and (max-width: 768px) {
    .c-headingType001__bodyJa {
        font-size: 16px
    }
}

@media screen and (max-width: 768px) {
    .c-headingType001__bodyJaSmall {
        font-size: 12px;
    }
}

.c-headingType001--main .c-headingType001__bodyJa {
    color: #1f244f
}

.c-headingType001--center {
    gap: 16px 0;
    flex-wrap: wrap;
    justify-content: center
}

.c-headingType001--center .c-headingType001__icon {
    width: 48px
}

@media screen and (max-width: 768px) {
    .c-headingType001--center .c-headingType001__icon {
        width: 32px
    }
}

.c-headingType001--center .c-headingType001__body {
    width: 100%;
    text-align: center
}

.c-modal {
    position: fixed;
    z-index: 99999;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100dvh;
    display: none
}

.c-modal__overlay {
    cursor: pointer;
    background: rgba(0, 0, 0, .6);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1
}

.c-modal__box {
    background: #fff;
    padding: 40px 40px;
    border-radius: 16px;
    width: 60%;
    min-width: 620px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2
}

@media screen and (max-width: 768px) {
    .c-modal__box {
        width: 90%;
        min-width: 0;
        padding: 20px 20px
    }
}

.c-modal__list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 0
}

.c-modal__listItem {
    width: 100%
}

.c-modal__clinic>a {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    background: #1f244f;
    border-radius: 8px;
    padding: 20px 20px;
    color: #fff;
    gap: 8px 0
}

.c-modal__clinicName {
    font-size: 16px;
    font-weight: 800
}

.c-modal__clinicTel {
    font-size: 12px
}

.c-modal__clinicTel span {
    text-decoration: underline;
    font-size: 16px
}

.c-modal__note {
    margin-top: 20px;
    font-size: 10px
}

.u-displayMobile {
    display: none !important
}

@media screen and (max-width: 768px) {
    .u-displayMobile {
        display: inherit !important
    }
}

.u-displayDesktop {
    display: none !important
}

@media screen and (min-width: 769px) {
    .u-displayDesktop {
        display: inherit !important
    }
}

.u-inner {
    width: 90%;
    margin: 0 auto
}

.loading {
    background: #1f244f;
    width: 100vw;
    height: 100svh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99999
}

.loading .u-inner {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center
}

.loading__title {
    font-size: 0;
    width: 80%;
    max-width: 560px;
    aspect-ratio: 569/407
}

.loading__title img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.kv {
    background: #1f244f;
    width: 100%;
    height: 100svh
}

.kv .u-inner {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center
}

.kv__title {
    font-size: 0;
    width: 80%;
    max-width: 560px;
    aspect-ratio: 569/407
}

.kv__title img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.kv-wrapper {
    background: #1f244f;
    width: 100vw;
    height: 100svh
}

.kv-wrapper .u-inner {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center
}

.kv-wrapper__layer {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0
}

.kv-wrapper__layer:nth-of-type(1) {
    z-index: 1
}

.kv-wrapper__layer:nth-of-type(2) {
    z-index: 2
}

.kv-wrapper__layer__inner {
    background: #fff;
    opacity: .8;
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    padding: 5%
}

.kv-wrapper__layer__inner p {
    text-align: center;
    line-height: 2;
    color: #1f244f;
    font-weight: 700
}

.intro {
    background: #000;
    position: relative
}

.intro::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    background-image: url(/assets/image/intro_back.webp);
    background-size: cover;
    position: absolute;
    z-index: 1;
    opacity: .4;
    background-position: 0% 30%
}

.intro__primary {
    position: relative;
    z-index: 2;
    color: #fff;
    padding: 120px 0
}

@media screen and (max-width: 768px) {
    .intro__primary {
        padding: 56px 0
    }
}

.intro__primaryTitle {
    font-size: 24px;
    font-weight: 800;
    text-align: center;
    margin-bottom: 32px;
    letter-spacing: .2em
}

@media screen and (max-width: 768px) {
    .intro__primaryTitle {
        font-size: 18px
    }
}

.intro__primaryText {
    font-size: 18px;
    text-align: left;
    margin: 0 auto;
    width: fit-content;
}

@media screen and (max-width: 768px) {
    .intro__primaryText {
        font-size: 14px;
        line-height: 2.2;
    }
}

.intro__secondary {
    position: relative;
    z-index: 2;
    color: #fff;
    background: #ddd47f;
    padding: 32px 0
}

@media screen and (max-width: 768px) {
    .intro__secondary {
        padding: 24px 0
    }
}

.intro__secondaryText {
    font-size: 18px;
    text-align: center;
    color: #1f244f;
    text-align: center;
    font-weight: 800
}

.intro__secondary::before {
    content: "";
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 32px 149px 0 149px;
    border-color: #ddd47f rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0);
    position: absolute;
    left: 50%;
    bottom: -32px;
    transform: translateX(-50%)
}

@media screen and (max-width: 768px) {
    .intro__secondary::before {
        border-width: 20px 100px 0 100px;
        bottom: -20px
    }
}

.about {
    background: #1f244f;
    padding: 80px 0
}

.about__lead {
    color: #fff;
    line-height: 2
}

.about__image {
    margin: 32px auto 0;
    width: 100%;
    aspect-ratio: 951/694;
    max-width: 1000px
}

.about__image img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.feature {
    padding: 80px 0
}

/* featureブロックのタイトルスタイルのみ調整 */

/* @media screen and (max-width: 768px) { */
.feature .c-headingType001 .c-headingType001__body {
    width: fit-content;
    text-align: left;
    text-indent: -4em;
    padding-left: 4em;
}

/* } */


/* featureブロックのタイトルスタイルのみ調整 */

.feature__body {
    margin-top: 32px;
}

.feature__bodyText {
    font-size: 16px;
    font-weight: 800;
    color: #1f244f;
    line-height: 2;
    text-align: center;
}

@media screen and (max-width: 768px) {
    .feature__bodyText {
        font-size: 14px;
    }
}


.feature__image {
    width: 80%;
    max-width: 720px;
    margin: 0 auto
}

@media screen and (max-width: 768px) {
    .feature__image {
        width: 100%
    }
}

.works {
    background: #1f244f
}

.works__inner {
    display: flex;
    align-items: stretch
}

.works__body {
    width: 50%;
    padding: 80px 5%;
    position: relative;
    z-index: 2
}

@media screen and (max-width: 768px) {
    .works__body {
        width: 100%
    }
}

.works__body::before {
    content: "";
    display: inline-block;
    position: absolute;
    width: 10%;
    height: 100%;
    top: 0;
    right: -10%;
    background-image: linear-gradient(90deg, #1F244F, transparent)
}

@media screen and (max-width: 768px) {
    .works__body::before {
        display: none
    }
}

@media screen and (max-width: 768px) {
    .works__body::after {
        content: "";
        background: url(/assets/image/works_object.webp);
        background-size: cover;
        z-index: -1;
        opacity: .4;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0
    }
}

.works__image {
    width: 50%;
    font-size: 0
}

@media screen and (max-width: 768px) {
    .works__image {
        display: none
    }
}

.works__image img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.works__title {
    display: flex;
    align-items: center;
    gap: 0 16px
}

.works__titleMain {
    font-size: 18px;
    font-weight: 800;
    color: #ddd47f
}

.works__titleNote {
    font-size: 12px;
    color: #fff
}

.works__text {
    font-size: 18px;
    color: #fff;
    font-weight: 800;
    margin-top: 32px;
    line-height: 2;
    letter-spacing: 0;
}

.works__textTitle{
    display: block;
    font-size: 20px;
    border-bottom: 1px solid #fff;   
}

.works__note {
    margin-top: 16px;
    font-size: 10px;
    color: #fff
}

.voc {
    background: #f5f5f5;
    padding: 80px 0
}

.voc__lead {
    font-size: 14px;
    font-weight: 800;
    color: #1f244f;
    line-height: 2;
    margin-bottom: 32px;
}

.voc__list {
    display: flex;
    flex-wrap: wrap;
    gap: 32px 0
}

@media screen and (max-width: 768px) {
    .voc__list {
        gap: 24px 0
    }
}

.voc__listItem {
    width: 100%
}

.voc .card {
    background: #fff;
    padding: 20px 20px
}

.voc .card__head {
    display: flex;
    gap: 0 16px;
    align-items: center
}

@media screen and (max-width: 768px) {
    .voc .card__head {
        flex-wrap: wrap
    }
}

.voc .card__headImage {
    width: 180px;
    aspect-ratio: 180/103
}

@media screen and (max-width: 768px) {
    .voc .card__headImage {
        width: 100%;
        margin-bottom: 8px
    }
}

.voc .card__headImage img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.voc .card__headBody {
    width: calc(100% - 196px)
}

@media screen and (max-width: 768px) {
    .voc .card__headBody {
        width: 100%
    }
}

.voc .card__headBody h3 {
    color: #1f244f;
    font-size: 16px;
    font-weight: 800
}

.voc .card__headBody ul {
    display: flex;
    gap: 8px 8px;
    margin-top: 8px
}

.voc .card__headBody ul li {
    background: #1f244f;
    color: #fff;
    padding: 2px 4px;
    font-size: 12px;
    border-radius: 2px;
    font-weight: 800
}

.voc .card__body {
    margin-top: 16px
}

.voc .card__body .reason {
    position: relative;
    padding-left: 48px;
    margin-top: 16px
}

@media screen and (max-width: 768px) {
    .voc .card__body .reason {
        padding-left: 0;
        display: flex;
        flex-wrap: wrap;
        gap: 8px 0
    }
}

.voc .card__body .reason>span:nth-of-type(1) {
    position: absolute;
    top: 0;
    left: 0;
    background: #1f244f;
    color: #fff;
    padding: 2px 4px;
    font-size: 12px;
    border-radius: 2px;
    font-weight: 800
}

@media screen and (max-width: 768px) {
    .voc .card__body .reason>span:nth-of-type(1) {
        position: relative
    }
}

.voc .card__body .result {
    position: relative;
    padding-left: 48px;
    margin-top: 16px
}

@media screen and (max-width: 768px) {
    .voc .card__body .result {
        padding-left: 0;
        display: flex;
        flex-wrap: wrap;
        gap: 8px 0
    }
}

.voc .card__body .result>span:nth-of-type(1) {
    position: absolute;
    top: 0;
    left: 0;
    background: #1f244f;
    color: #fff;
    padding: 2px 4px;
    font-size: 12px;
    border-radius: 2px;
    font-weight: 800
}

@media screen and (max-width: 768px) {
    .voc .card__body .result>span:nth-of-type(1) {
        position: relative
    }
}

.voc .card__body .result--col2 {
    display: flex;
    flex-wrap: wrap;
    padding-left: 0
}

.voc .card__body .result--col2 .col2 {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 0 16px;
    margin-top: 32px
}

@media screen and (max-width: 768px) {
    .voc .card__body .result--col2 .col2 {
        flex-wrap: wrap;
        margin-top: 4px
    }
}

.voc .card__body .result--col2 .col2 .image {
    display: inline-block;
    width: 180px;
    aspect-ratio: 180/103;
    font-size: 0
}

@media screen and (max-width: 768px) {
    .voc .card__body .result--col2 .col2 .image {
        width: 100%
    }
}

.voc .card__body .result--col2 .col2 .image img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.voc .card__body .result--col2 .col2 span:nth-of-type(3) {
    width: calc(100% - 196px)
}

@media screen and (max-width: 768px) {
    .voc .card__body .result--col2 .col2 span:nth-of-type(3) {
        width: 100%
    }
}

.voc .card__body .result--col2 .u-displayDesktop {
    font-size: 10px;
    margin-top: 8px
}

.voc .card__body .result--col2 .u-displayMobile {
    font-size: 10px;
    margin-top: 8px;
    margin-bottom: 8px
}

.voc .card__body .comment {
    padding: 16px 16px;
    display: flex;
    gap: 0 16px;
    align-items: center;
    background: #f5f5f5;
    margin-top: 16px
}

@media screen and (max-width: 768px) {
    .voc .card__body .comment {
        flex-wrap: wrap;
        gap: 8px 0
    }
}

.voc .card__body .comment span {
    display: inline-block
}

.voc .card__body .comment span:nth-of-type(1) {
    display: inline-block;
    background: #fff;
    color: #1f244f;
    padding: 2px 4px;
    font-size: 12px;
    font-weight: 800
}

.voc .card__body .comment span:nth-of-type(2) {
    display: inline-block;
    width: calc(100% - 108px);
    font-size: 12px
}

@media screen and (max-width: 768px) {
    .voc .card__body .comment span:nth-of-type(2) {
        width: 100%
    }
}

.youtube {
    padding: 40px 0
}

.youtube .u-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 20px
}

.youtube__iframe {
    width: calc((100% - 40px)/3);
    aspect-ratio: 16/9;
    font-size: 0
}

@media screen and (max-width: 768px) {
    .youtube__iframe {
        width: 100%
    }
}

.youtube__iframe iframe {
    width: 100%;
    height: 100%
}

.fee {
    background: #1f244f;
    padding: 80px 0;
    color: #fff
}

.fee .c-headingType001__bodyJa {
    font-size: 20px;
    font-weight: 500;
}
@media screen and (max-width: 768px) {
    .fee .c-headingType001__bodyJa {
        font-size: 13px;
        font-weight: 500;
    }
}

.fee__mainTitle {
    font-size: 24px;
    letter-spacing: .2em
}

@media screen and (max-width: 768px) {
    .fee__mainTitle {
        font-size: 15px;
        display: flex;
        align-items: baseline;
        justify-content: space-between;
    }
}

.fee__mainNum {
    font-size: 20px;
    letter-spacing: .2em;
    margin-top: 8px
}

@media screen and (max-width: 768px) {
    .fee__mainNum {
        margin-top: 0;
        letter-spacing: 0;
    }
}

.fee__mainNum small {
    font-size: 14px;
}

.fee__mainNote {
    display: flex;
    flex-wrap: wrap;
    margin-top: 16px;
    gap: 8px 0
}

.fee__mainNote li {
    width: 100%;
    padding-left: 16px;
    position: relative;
    font-size: 12px
}

.fee__mainNote li span {
    position: absolute;
    left: 0;
    top: 0
}

.service {
    background: #f5f5f5;
    padding: 80px 0
}


/* serviceセクションのc-headingType001__bodyJaSmall調整 */

@media screen and (max-width: 768px) {
    .service .c-headingType001__body {
        width: 100%;
    }
}

.service__title {
    margin-top: 52px;
    color: #1f244f;
    display: flex;
    flex-direction: column;
    gap: 0 16px;
    font-size: 20px;
    font-weight: 800;
    letter-spacing: .2em
}

@media screen and (max-width: 768px) {
    .service__title {
        margin-top: 24px;
        flex-direction: row;
        flex-wrap: wrap;
    }
}

.service__titleSmall {
    font-size: 12px;
    letter-spacing: 0.05em;
}

.service__text {
    color: #1f244f;
    line-height: 2;
    margin-top: 16px
}

.service--01 .service__text{
    letter-spacing: 0;
}

.service__image {
    width: 100%;
    aspect-ratio: 106/55;
    max-width: 1000px;
    margin: 32px auto 0
}

.service__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.profile {
    background: #000;
    color: #fff;
    position: relative
}

.profile::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    background-image: url(/assets/image/intro_back.webp);
    background-size: cover;
    position: absolute;
    z-index: 1;
    opacity: .4
}

.profile__col {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 0 32px;
    padding: 80px 0
}

@media screen and (max-width: 768px) {
    .profile__col {
        flex-wrap: wrap;
        gap: 0 12px
    }
}

.profile__colImage {
    width: calc(35% - 16px)
}

@media screen and (max-width: 768px) {
    .profile__colImage {
        width: calc(40% - 8px)
    }
}

.profile__colBody {
    width: calc(65% - 16px)
}

@media screen and (max-width: 768px) {
    .profile__colBody {
        width: 100%
    }
}

.profile__title {
    font-size: 20px;
    font-weight: 800
}

@media screen and (max-width: 768px) {
    .profile__title {
        width: calc(60% - 8px);
        font-size: 18px
    }
}

.profile__text {
    line-height: 2;
    margin-top: 32px
}

.faq {
    padding: 80px 0;
    color: #1f244f
}

.faq__list {
    max-width: 400px;
    margin: 56px auto 0;
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.faq__listItem {
    text-indent: -1.9em;
    padding-left: 1.9em;
}


.clinic {
    padding: 80px 0;
    color: #1f244f
}

.clinic .u-inner {
    max-width: 400px
}

.clinic__list {
    display: flex;
    flex-wrap: wrap;
    gap: 32px 0;
    margin-top: 56px
}

@media screen and (max-width: 768px) {
    .clinic__list {
        gap: 48px 0
    }
}

.clinic__listItem {
    width: 100%
}

.clinicInfo__title {
    font-size: 20px;
    font-weight: 800
}

@media screen and (max-width: 768px) {
    .clinicInfo__title {
        font-size: 18px
    }
}

.clinicInfo__adress {
    margin-top: 8px
}

.clinicInfo__adress a {
    text-decoration: underline
}

.clinicInfo__time {
    margin-top: 8px;
    font-weight: 800
}

.clinicInfo__timeItem {
    position: relative;
    padding-left: 100px
}

@media screen and (max-width: 768px) {
    .clinicInfo__timeItem {
        padding-left: 76px
    }
}

.clinicInfo__timeItem span {
    position: absolute;
    top: 0;
    left: 0
}

.clinicInfo__note {
    margin-top: 8px;
    font-size: 12px;
    padding-left: 12px;
    position: relative
}

.clinicInfo__note .ast {
    position: absolute;
    top: 0;
    left: 0
}


/* 20251117 新規追加 */
.service__podc {
    padding: 80px 0;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    background-image: url(/assets/image/service_podc_bg_pc_1366-464.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #fff;
}
@media screen and (max-width: 768px) {
    .service__podc {
        background-image: url(/assets/image/service_podc_bg.jpg);
        
    }
}

.service__podcTitle {
    margin: 0 auto 20px;
    max-width: 500px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px 16px;
}

.service__podcTitleText--row1 {
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    align-self: flex-start;
}

.service__podcTitleText--row3 {
    font-weight: 700;
    font-size: 12px;
    line-height: 1;
    align-self: flex-end;
    letter-spacing: 0;
}

.service__podc .service__text {
    color: #fff;
    margin: 0;
    padding-top: 1em;
    padding-bottom: 1em;
}

.service__podc .service__text+.service__text {
    border-top: 1px solid #fff;
}


.service__medicalMenuTitle{
    margin-bottom: 30px;
    display: flex;
    justify-content: center;
}

.service__title.--priorityService{
    margin-top: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.service__title.--priorityService::after{
    content: '';
    display: block;
    background-image: url(/assets/image/service_priority_border.png);    
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 25px;
    
}

.service--podc{
    padding-top: 0;
}

.c-headingType001.--premiumConsultation{
    justify-content: center;
    text-align: center;
}

/* c-headingType002追加「診断を支える３つの視点セクション」 */
.c-headingType002{
    margin-bottom: 40px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.c-headingType002En{
    margin-bottom: 12px;
    font-size: 18px;
    font-weight: 700;
    color: #B9AE45;
    line-height: 1;
    text-align: center;
}
@media screen and (max-width: 768px) {
    .c-headingType002En{
        margin-bottom: 12px;
        font-size: 16px;
    }
}

.c-headingType002Small{
    margin-bottom: 18px;
    font-size: 14px;
    font-weight: 700;
    color: #B9AE45;
    line-height: 1;
    text-align: center;
    letter-spacing: .1em;
}

@media screen and (max-width: 768px) {
    .c-headingType002Small{
        margin-bottom: 12px;
        font-size: 12px;
    }
}
.c-headingType002Ja{
    font-size: 28px;
    font-weight: 500;
    color: #1f244f;
    line-height: 1;
    text-align: center;
}

@media screen and (max-width: 768px) {
    .c-headingType002Ja{
        font-size: 20px;
    }
}
    