@charset "UTF-8";
/* Scss Document */
:root {
    --min-size: 100px;
    --clamp-vw: 18vw;
}
@media (max-width: 1024px) {
    :root {
        --min-size: 60px;
        --clamp-vw: 10vw;
    }
}
.padding100 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 100px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.padding110 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 110px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.padding120 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 120px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.padding130 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 130px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.padding140 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 140px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.padding150 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 150px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.padding160 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 160px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.padding170 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 170px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.padding180 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 180px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.padding190 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 190px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.padding200 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 200px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.padding210 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 210px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.padding220 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 220px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.padding230 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 230px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.padding240 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 240px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.padding250 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 250px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.padding260 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 260px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.padding270 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 270px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.padding280 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 280px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.padding290 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 290px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.padding300 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 300px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.margin100 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 100px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.margin110 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 110px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.margin120 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 120px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.margin130 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 130px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.margin140 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 140px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.margin150 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 150px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.margin160 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 160px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.margin170 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 170px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.margin180 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 180px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.margin190 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 190px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.margin200 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 200px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.margin210 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 210px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.margin220 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 220px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.margin230 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 230px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.margin240 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 240px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.margin250 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 250px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.margin260 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 260px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.margin270 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 270px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.margin280 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 280px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.margin290 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 290px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.margin300 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 300px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.pt-100 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.pt-110 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.pt-120 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.pt-130 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.pt-140 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.pt-150 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.pt-160 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.pt-170 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.pt-180 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.pt-190 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.pt-200 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.pt-210 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.pt-220 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.pt-230 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.pt-240 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.pt-250 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.pt-260 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.pt-270 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.pt-280 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.pt-290 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.pt-300 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.pb-100 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.pb-110 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.pb-120 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.pb-130 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.pb-140 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.pb-150 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.pb-160 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.pb-170 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.pb-180 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.pb-190 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.pb-200 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.pb-210 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.pb-220 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.pb-230 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.pb-240 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.pb-250 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.pb-260 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.pb-270 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.pb-280 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.pb-290 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.pb-300 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.mt-100 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.mt-110 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.mt-120 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.mt-130 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.mt-140 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.mt-150 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.mt-160 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.mt-170 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.mt-180 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.mt-190 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.mt-200 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.mt-210 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.mt-220 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.mt-230 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.mt-240 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.mt-250 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.mt-260 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.mt-270 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.mt-280 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.mt-290 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.mt-300 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.mb-100 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.mb-110 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.mb-120 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.mb-130 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.mb-140 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.mb-150 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.mb-160 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.mb-170 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.mb-180 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.mb-190 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.mb-200 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.mb-210 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.mb-220 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.mb-230 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.mb-240 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.mb-250 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.mb-260 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.mb-270 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.mb-280 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.mb-290 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.mb-300 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
a, a:hover, a:focus, a:active, a:visited, a:focus-visible {
    text-decoration: none;
}
.green_53B95F {
    color: #53B95F !important;
}
/************************/
.header {
    background: #fff;
    padding: 30px 0 30px;
    position: relative;
    z-index: 800;
}
.h_flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    margin: 0 auto;
    max-width: 1848px;
    width: 94%;
}
#logo {
    flex-shrink: 0;
    width: 312px;
}
#logo a {
    display: block;
}
#logo img {
    display: block;
    width: 100%;
    height: auto;
}
.h_nav {
    margin-left: auto;
}
.h_nav ul {
    align-items: center;
    display: flex;
    justify-content: flex-end;
    margin: 0;
}
.h_nav li {
    color: #5e625c;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 1.4;
    position: relative;
    white-space: nowrap;
    border-right: 1px solid #DDD;
    padding: 0 30px;
}
.h_nav li:last-child {
    border-right: 0;
}
.h_nav a, .h_nav span {
    transition: 0.3s ease-in-out;
    align-items: center;
    color: inherit;
    display: inline-flex;
}
.h_nav a:hover, .h_nav li:hover > a, .h_nav li:hover > span, .h_nav li:focus-within > a, .h_nav li:focus-within > span {
    color: #81b26b;
    text-decoration: none;
}
.h_nav li > span {
    cursor: default;
    padding-right: 18px;
    position: relative;
}
.h_nav li > span::after {
    border-left: 1px solid #81b26b;
    border-bottom: 1px solid #81b26b;
    content: "";
    height: 8px;
    position: absolute;
    right: 0;
    top: 6px;
    transform: rotate(-45deg);
    width: 8px;
}
.nav_hov {
    left: 50%;
    min-width: 232px;
    opacity: 0;
    padding-top: 18px;
    pointer-events: none;
    position: absolute;
    top: 100%;
    transform: translate(-50%, 12px) scale(1, 0);
    visibility: hidden;
    z-index: 20;
    transition: 0.3s ease;
    transform-origin: top left;
}
.h_nav li:hover .nav_hov, .h_nav li:focus-within .nav_hov {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, 0) scale(1, 1);
    visibility: visible;
}
.hav_hov_bg {
    background: rgba(255, 255, 255, 0.98);
    border-radius: 24px;
    box-shadow: 0 18px 36px rgba(100, 130, 88, 0.16);
    padding: 20px 24px;
}
.hav_hov_bg p {
    font-size: 15px;
}
.hav_hov_bg p + p {
    margin-top: 12px;
}
.fv_relative {
    background: #fff;
    padding: 6px 0 0;
    position: relative;
}
.fv_relative .flexslider, .fv_relative .flex-viewport {
    border-radius: 30px;
    overflow: hidden;
}
.fv_relative .slides img {
    aspect-ratio: 1594/820;
    display: block;
    height: auto;
    object-fit: cover;
    width: 100%;
}
.fv_title_absolute {
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 1220px;
    pointer-events: none;
    position: absolute;
    bottom: 16%;
    z-index: 2;
}
.fv_title68 {
    color: #fff;
    font-size: clamp(38px, 6vw, 68px);
    font-weight: 400;
    letter-spacing: 0.08em;
    line-height: 1.6em;
    letter-spacing: 2px;
}
.fv_absolute_deco1, .fv_absolute_deco2 {
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.fv_absolute_deco1 img, .fv_absolute_deco2 img {
    display: block;
    height: auto;
    width: 100%;
}
.fv_absolute_deco1 {
    left: -96px;
    top: 176px;
    width: 340px;
}
.fv_absolute_deco2 {
    right: -38px;
    top: 470px;
    width: 259px;
}
/***************/
.plr35 {
    padding-left: 35px;
    padding-right: 35px;
}
.bg_FBFBF3 {
    background: #fbfbf3;
    border-radius: 30px;
}
.eng_15 {
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 3px;
    line-height: 1.4;
}
.green_53B95F {
    color: #53b95f;
}
.gray_3f3f3f {
    color: #3f3f3f;
}
.uppercase {
    text-transform: uppercase;
}
/***************/
.title_34 {
    color: #444;
    font-size: clamp(28px, 2.9vw, 34px);
    font-weight: 500;
    letter-spacing: 1.7px;
    font-family: "Zen Maru Gothic", sans-serif;
}
.title_mt15 {
    margin-top: 15px;
}
.text_17 {
    color: #5c5c5c;
    font-size: 17px;
    letter-spacing: 0.08em;
}
.text_18 {
    font-size: 18px;
}
.text_20 {
    font-size: 20px;
}
.text_21 {
    font-size: 21px;
}
.text_34 {
    font-size: 34px;
}
.sec01_flex {
    align-items: flex-start;
    display: flex;
    gap: 90px;
    justify-content: space-between;
}
.sec01_left {
    width: max-content;
    flex-shrink: 0;
    padding-top: 8px;
}
.sec01_right {
    flex-grow: 2;
    max-width: 750px;
    min-height: 200px;
}
.sec01_more_absolute {
    position: absolute;
    top: 140px;
    left: 0;
}
.news {
    margin: 0;
}
.news li {
    border-bottom: 1px solid #ece9df;
}
.news a {
    transition: 0.3s ease-in-out;
    align-items: center;
    color: #444;
    display: flex;
    gap: 34px;
    padding: 35px 40px 35px 0;
    position: relative;
}
.news a::after {
    background: url("../images/arrow_g.webp") center center/contain no-repeat;
    content: "";
    height: 10px;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
}
.news a:hover {
    color: #53b95f;
}
.news a:hover::after {
    right: -4px;
}
.n_cell1 {
    width: 120px;
    font-size: 15px;
    letter-spacing: 0.08em;
    line-height: 1.6;
    color: #868686;
    flex-shrink: 0;
}
.n_cell2 {
    flex-grow: 2;
    max-width: 590px;
    color: #444;
    flex: 1;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.7;
    padding-right: 18px;
}
/***************/
.sec02_flex {
    align-items: center;
    display: flex;
    gap: 88px;
    justify-content: space-between;
    position: relative;
    z-index: 2;
}
.sec02_left {
    flex-grow: 2;
    max-width: 550px;
    min-width: 0;
    width: 50%;
}
.sec02_right {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.sec02_right img {
    border-radius: 118px 24px 24px 24px;
    display: block;
    height: auto;
    max-width: 100%;
    width: 601px;
}
.sec02_absolute_deco {
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 280px;
    max-width: 320px;
    z-index: 0;
}
.sec02_absolute_deco img {
    display: block;
    height: auto;
    width: 100%;
}
.title_dot_on {
    padding-top: 20px;
    position: relative;
}
.title_dot_on::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 8px;
    left: 50%;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 8px;
}
.title_32 {
    color: #444;
    font-size: clamp(22px, 2.6vw, 32px);
    font-weight: 500;
    letter-spacing: 1.35px;
    line-height: 1.8em;
    font-family: "Zen Maru Gothic", sans-serif;
}
.title_mt30 {
    margin-top: 30px;
}
.title_27 {
    color: #444;
    font-size: clamp(22px, 1.406vw, 27px);
    font-weight: 500;
    letter-spacing: 1.35px;
    line-height: 1.9;
    font-family: "Zen Maru Gothic", sans-serif;
}
/*******************/
.sec03_flex {
    align-items: center;
    border-bottom: 1px solid #e8e5e3;
    display: flex;
    gap: 74px;
    justify-content: space-between;
    padding: 58px 0;
}
.sec03_flex:first-child {
    padding-top: 48px;
}
.sec03_flex:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}
.sec03_flex:nth-child(even) .sec03_img {
    order: 2;
}
.sec03_img {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.sec03_img img {
    border-radius: 24px 88px 24px 24px;
    display: block;
    height: auto;
    max-width: 100%;
}
.sec03_flex:nth-child(even) .sec03_img img {
    border-radius: 88px 24px 24px 24px;
}
.sec03_content {
    flex-grow: 2;
    max-width: 550px;
    width: 50%;
}
.sec03_content .title_27 {
    margin-top: 10px;
}
.sec03_content p {
    letter-spacing: 1.28px;
}
.sec03_fit_bg {
    background: #a8d276;
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 15px;
    font-weight: 400;
    line-height: 1;
    padding: 7px 18px 8px;
}
.sec03_mark {
    color: #2cad79;
    font-weight: 500;
}
/************************/
.sec04_flex {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    max-width: 1180px;
}
.sec04_card {
    width: calc((100% - 80px) / 3);
}
.sec04_card > a {
    transition: 0.3s ease-in-out;
    background: #fff;
    border-radius: 65px 65px 9px 9px;
    color: #444;
    display: block;
    overflow: hidden;
    padding: 10px;
}
.sec04_card > a:hover {
    box-shadow: 0 16px 32px rgba(118, 199, 97, 0.14);
    transform: translateY(-4px);
}
.sec04_img img {
    display: block;
    height: auto;
    width: 100%;
}
.sec04_card_relative {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 70px;
    padding: 30px 54px 30px 30px;
    position: relative;
}
.sec04_title {
    color: #444;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 2.2px;
    line-height: 1.5;
    text-align: center;
    width: 100%;
    padding-left: 30px;
}
.sec04_absolute_arrow {
    align-items: center;
    display: inline-flex;
    height: 15px;
    justify-content: center;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    width: 15px;
}
.sec04_absolute_arrow img {
    display: block;
    height: 15px;
    width: 15px;
}
.more_btn a {
    transition: 0.3s ease-in-out;
    align-items: center;
    background: #76c761;
    border-radius: 42px;
    color: #fff;
    display: inline-flex;
    font-size: 18px;
    font-weight: 500;
    gap: 10px;
    height: 47px;
    justify-content: center;
    padding: 12px 33px;
    width: 243px;
}
.more_btn a:hover {
    background: #69b856;
}
.arrow {
    align-items: center;
    display: inline-flex;
    height: 13px;
    justify-content: center;
    width: 13px;
}
.arrow img {
    display: block;
    height: auto;
    width: 100%;
}
/***************************/
.title_20 {
    color: #444;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 2.2px;
    line-height: 1.5;
}
.sec05_grid {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.sec05_card {
    background: #fff;
    border-radius: 34px;
    box-shadow: 0 0 21px 0 rgba(228, 232, 224, 0.76);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 389px;
    padding: 45px 20px 45px;
}
.sec05_card .check_list {
    max-width: max-content;
    margin-left: auto;
    margin-right: auto;
}
.sec05_card .check_list li {
    display: flex;
}
.sec05_card .check_list li .check {
    flex-shrink: 0;
    background: url("../images/check.webp") 50% 50%/100% 100% no-repeat;
    width: 18px;
    height: 18px;
    margin-top: 7px;
}
.sec05_card > div {
    width: 100%;
}
.sec05_icon {
    align-items: center;
    display: flex;
    height: 94px;
    justify-content: center;
    margin-bottom: 18px;
}
.sec05_icon img {
    display: block;
    height: auto;
    max-height: 94px;
    max-width: 88px;
    width: auto;
}
.sec05_title {
    align-items: center;
    display: flex;
    justify-content: center;
    margin: 0 auto;
    min-height: 60px;
    text-align: center;
}
.check_list {
    margin-top: 18px;
}
.check_list li {
    align-items: flex-start;
    color: #5c5c5c;
    display: flex;
    font-size: 16px;
    font-weight: 500;
    gap: 10px;
    letter-spacing: 0.05em;
    line-height: 1.7;
}
.check_list li + li {
    margin-top: 9px;
}
.check_list .check {
    width: 18px;
    flex-shrink: 0;
    position: relative;
    top: -2px;
}
.sec05_card .more_btn {
    margin-top: 24px;
}
.sec05_card .more_btn a {
    font-size: 15px;
    gap: 8px;
    height: 47px;
    padding: 8px 20px;
    width: 100%;
    max-width: 243px;
}
.sec05_card .arrow {
    height: 10px;
    width: 10px;
}
.sec05_card:nth-child(odd) .more_btn a {
    background-color: #76C761;
}
.sec05_card:nth-child(even) .more_btn a {
    background-color: #B8D96A;
}
.sec05_absolute_deco {
    pointer-events: none;
    position: absolute;
    right: -72px;
    top: 66px;
    width: 315px;
    z-index: 0;
}
.sec05_absolute_deco img {
    display: block;
    height: auto;
    width: 100%;
}
.title_36 {
    color: #444;
    font-size: clamp(20px, 1.875vw, 36px);
    font-weight: 700;
    letter-spacing: 1.8px;
    line-height: 1.5;
    font-family: "Zen Maru Gothic", sans-serif;
}
.before_dot {
    align-items: center;
    display: flex;
    gap: 16px;
}
.before_dot::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    flex: 0 0 8px;
    height: 8px;
    width: 8px;
}
/***************************/
.sec06_flex {
    align-items: flex-start;
    display: flex;
    gap: 50px;
    justify-content: space-between;
}
.sec06_left {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.sec06_left img {
    display: block;
    height: auto;
    max-width: 100%;
    width: 100%;
}
.sec06_right {
    flex-grow: 2;
    max-width: 560px;
}
.sec06_right > p {
    color: #444;
    font-size: 17px;
    letter-spacing: 0.85px;
    line-height: 2em;
}
.sec06_right .name_small {
    font-size: 15px;
    line-height: 1.5;
    letter-spacing: 1.6px;
}
.sec06_name_flex {
    align-items: flex-end;
    display: flex;
    gap: 25px;
}
.sec06_name_ja {
    color: #444;
    font-size: 24px;
    font-weight: 500;
    letter-spacing: 3.4px;
    line-height: 1.2;
}
.sec06_name_eng {
    color: #7f7f7f;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 1.5px;
    line-height: 1.6;
    padding-top: 10px;
}
.sec06_more_btn {
    display: flex;
    justify-content: flex-end;
}
.sec06_more_btn a {
    transition: 0.3s ease-in-out;
    align-items: center;
    color: #444;
    display: inline-flex;
    font-size: 18px;
    font-weight: 500;
    gap: 16px;
    line-height: 1.4;
    text-decoration: none;
}
.sec06_more_btn a:hover {
    color: #444;
    text-decoration: none;
}
.sec06_more_btn .arrow {
    background: #76c761;
    border-radius: 50%;
    flex: 0 0 38px;
    height: 38px;
    width: 38px;
}
.sec06_more_btn .arrow img {
    width: 10px;
}
.sec06_more_btn a:hover .arrow {
    background: #69b856;
}
.sec06_absolute_deco {
    left: 0;
    pointer-events: none;
    position: absolute;
    bottom: 70px;
    z-index: 0;
}
.sec06_absolute_deco img {
    display: block;
    height: auto;
    width: 100%;
}
.sec06_scroll {
    display: flex;
    white-space: nowrap;
    width: max-content;
    animation: loopAnimation 40s linear infinite;
}
.sec06_scroll > div {
    margin-right: 40px;
}
.sec06_scroll img {
    border-radius: 30px;
    display: block;
    height: auto;
    width: 350px;
}
@keyframes loopAnimation {
    to {
        transform: translateX(-50%);
    }
}
/*****************/
.sec07_flex {
    display: flex;
    gap: 40px 50px;
    justify-content: space-between;
    position: relative;
    max-width: 1220px;
    margin-left: auto;
    margin-right: auto;
}
.sec07_left, .sec07_map {
    position: relative;
    z-index: 1;
}
.sec07_left {
    flex-grow: 2;
    max-width: 560px;
    min-width: 0;
    width: 50%;
}
.sec07_logo img {
    max-width: 100%;
    height: auto;
}
.sec07_tel {
    color: #76c761;
    font-size: 21px;
    line-height: 1.1;
    margin-top: 24px;
}
.sec07_tel a {
    align-items: flex-end;
    color: inherit;
    display: inline-flex;
    font-weight: 400;
    gap: 10px;
    text-decoration: none;
}
.sec07_tel a:hover {
    color: inherit;
    text-decoration: none;
}
.tel_large {
    font-size: 34px;
    letter-spacing: 1.6px;
    line-height: 1;
}
.sec07_access_flex {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px 12px;
    margin-top: 20px;
}
.sec07_access_left {
    align-items: center;
    color: #444;
    display: flex;
    font-size: 16px;
    gap: 10px;
    line-height: 1.7;
    white-space: nowrap;
}
.sec07_access_left i {
    display: block;
    flex: 0 0 12px;
    height: 16px;
    position: relative;
    width: 12px;
}
.sec07_access_left i::before {
    background: #444;
    border-radius: 50% 50% 50% 0;
    content: "";
    height: 12px;
    left: 0;
    position: absolute;
    top: 2px;
    transform: rotate(-45deg);
    width: 12px;
}
.sec07_access_left i::after {
    background: #fff;
    border-radius: 50%;
    content: "";
    height: 4px;
    left: 4px;
    position: absolute;
    top: 6px;
    width: 4px;
}
.sec07_access_map a {
    border: 1px solid #8fce79;
    border-radius: 18px;
    color: #76c761;
    display: inline-flex;
    font-size: 13px;
    line-height: 1;
    padding: 3px 16px 5px;
    text-decoration: none;
}
.sec07_access_map a:hover {
    color: #76c761;
    text-decoration: none;
}
.sec07_table {
    margin-top: 34px;
}
.sec07_table table {
    width: 100%;
}
.sec07_table thead th {
    border-bottom: 1px solid #e6e7dd;
    color: #505050;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.5;
    padding: 0 0 14px;
    text-align: center;
}
.sec07_table thead th:first-child {
    text-align: left;
    width: 170px;
}
.sec07_table tbody th, .sec07_table tbody td {
    border-bottom: 1px solid #e6e7dd;
    padding: 13px 0;
    text-align: center;
    letter-spacing: 0.85px;
}
.sec07_table tbody th {
    color: #545454;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.5;
    text-align: left;
    white-space: nowrap;
}
.sec07_table tbody .small_15 {
    font-size: 15px;
}
.sec07_table td {
    width: 38px;
}
.sec07_circle {
    background: #76c761;
    border-radius: 50%;
    display: inline-block;
    height: 12px;
    width: 12px;
}
.sec07_dash {
    color: #a8d88a;
    display: inline-block;
    font-size: 20px;
    font-weight: 500;
    line-height: 1;
    transform: translateY(-1px);
}
.indent_list {
    margin-top: 24px;
}
.indent_list li {
    font-size: 15px;
    line-height: 1.87;
    padding-left: 1.1em;
    text-indent: -1.1em;
}
.indent_list li + li {
    margin-top: 8px;
}
.sec07_map {
    border-radius: 30px;
    max-width: 560px;
    overflow: hidden;
    width: 50%;
}
.sec07_map iframe {
    height: 100%;
    width: 100%;
}
.sec07_absolute_deco {
    position: absolute;
    right: 0;
    top: 100px;
}
/*************************/
.footer {
    background: url("../images/footer_bg.webp") no-repeat center center/cover;
    color: #fff;
    overflow: hidden;
    padding: 100px 0;
    position: relative;
}
.f_flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 36px 64px;
    position: relative;
    z-index: 1;
}
.f_left {
    flex-shrink: 0;
    max-width: max-content;
    padding-top: 2px;
}
.f_left p {
    color: rgba(255, 255, 255, 0.94);
    font-size: 14px;
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0.08em;
    white-space: pre-line;
}
.f_logo {
    max-width: 432px;
    width: 100%;
}
.f_logo a {
    display: block;
}
.f_logo img {
    display: block;
    height: auto;
    width: 100%;
}
.f_nav {
    display: flex;
    flex-grow: 2;
    flex-wrap: wrap;
    gap: 20px 42px;
    justify-content: flex-end;
    max-width: 880px;
    min-width: 0;
    padding-top: 4px;
    width: 100%;
}
.f_nav ul {
    max-width: max-content;
}
.f_nav li > a, .f_nav li > span {
    color: #fff;
    display: inline-flex;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 1.5;
    padding-left: 16px;
    position: relative;
    text-decoration: none;
}
.f_nav li > a::before, .f_nav li > span::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 6px;
    left: 0;
    position: absolute;
    top: 8px;
    width: 6px;
}
.f_nav a:hover {
    color: #d9f1d2;
    text-decoration: none;
}
.f_sub {
    margin-top: 16px;
    padding-left: 16px;
}
.f_sub p {
    color: rgba(255, 255, 255, 0.92);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.9;
}
.f_sub p + p {
    margin-top: 4px;
}
.f_sub a {
    color: inherit;
    display: inline-flex;
}
.copyright {
    color: rgba(255, 255, 255, 0.84);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 1.6;
    margin-top: 20px;
    text-align: right;
    width: 100%;
}
/********************************************************

	当院について

********************************************************/
.fv_in_relative {
    background: #fff;
    padding: 6px 0 0;
    position: relative;
}
.main_size img {
    border-radius: 30px;
    display: block;
    height: auto;
    width: 100%;
}
.fv_in_title_absolute {
    left: 50%;
    max-width: 1380px;
    width: 90%;
    pointer-events: none;
    position: absolute;
    bottom: 15%;
    transform: translateX(-50%);
    z-index: 2;
}
.title_in_ja, .title_in_eng {
    color: #fff;
    text-shadow: 0 4px 18px rgba(70, 70, 70, 0.16);
}
.title_in_ja {
    font-size: clamp(30px, 4.5vw, 48px);
    font-weight: 500;
    letter-spacing: 2.4px;
    line-height: 1.5;
}
.title_in_eng {
    font-size: 17px;
    font-weight: 500;
    letter-spacing: 0.85px;
    line-height: 1.4;
    margin-top: 5px;
}
/************/
.title_30 {
    font-size: clamp(24px, 2.3vw, 30px);
    font-family: "Zen Maru Gothic", sans-serif;
}
.green_61B542 {
    color: #61b542;
}
/************************/
.ab01_absolute_deco1, .ab03_absolute_deco1, .ab03_absolute_deco2 {
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.ab01_absolute_deco1 img, .ab03_absolute_deco1 img, .ab03_absolute_deco2 img {
    display: block;
    height: auto;
    width: 100%;
}
.ab01_absolute_deco1 {
    right: 0;
    top: 100px;
    width: 300px;
}
.ab03_absolute_deco1 {
    right: 0;
    top: 124px;
    width: 270px;
}
.ab03_absolute_deco2 {
    left: 0;
    bottom: 450px;
    width: 320px;
}
/************************/
.title_22 {
    font-size: clamp(20px, 1.7vw, 22px);
}
.title_23 {
    font-size: clamp(20px, 1.198vw, 23px);
}
.title_25 {
    font-size: clamp(20px, 1.302vw, 25px);
}
.green_4C9830 {
    color: #4c9830;
}
.ab02_flex_wrap {
    margin-top: 60px;
}
.ab02_flex {
    align-items: flex-start;
    border-bottom: 1px solid #e5e2d8;
    display: flex;
    gap: 50px;
    justify-content: space-between;
    padding: 60px 0;
}
.ab02_flex:first-child {
    padding-top: 0;
}
.ab02_flex:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}
.ab02_img {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.ab02_img img {
    border-radius: 10px 70px 10px 10px;
    display: block;
    height: auto;
    max-width: 100%;
    width: 100%;
}
.ab02_content {
    flex-grow: 2;
    max-width: 585px;
}
.ab02_num_flex {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
}
.ab02_num_cell1 {
    background-color: #A8D276;
    width: 50px;
    border-radius: 50px;
    color: #FFF;
    font-size: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 25px;
    flex-shrink: 0;
    font-weight: 200;
}
.title_af_bb60 {
    margin-top: 16px;
    padding-bottom: 22px;
    position: relative;
}
.title_af_bb60::after {
    background: #c3d97a;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    bottom: 0;
    width: 60px;
}
/************************/
.before_dot_title {
    align-items: flex-start;
    display: flex;
    gap: 12px;
}
.before_dot_title::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    flex-shrink: 0;
    height: 8px;
    margin-top: 12px;
    width: 8px;
}
.before_dot_title.dot_big_style:before {
    margin-top: 18px;
}
.ab03_grid {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
    gap: 60px;
    justify-content: space-between;
}
.ab03_grid > div {
    width: calc((100% - 60px) / 2);
}
.ab03_grid img {
    display: block;
    height: auto;
    width: 100%;
}
.ab03_grid .title_20 {
    letter-spacing: 1px;
}
/************************/
.title_28 {
    font-size: clamp(24px, 1.458vw, 28px);
}
.title_24 {
    font-size: clamp(20px, 1.25vw, 24px);
}
.green_43A856 {
    color: #43a856;
}
.ab03_flex_wrap {
    display: flex;
    flex-direction: column;
    gap: 60px;
}
.ab03_flex_wrap .ab03_flex:nth-child(even) .ab03_left {
    order: 2;
}
.ab03_flex {
    align-items: center;
    display: flex;
    gap: 24px 60px;
    justify-content: space-between;
}
.ab03_flex .before_dot_title::before {
    margin-top: 15px;
}
.ab03_left {
    flex-shrink: 0;
    max-width: max-content;
    width: calc((100% - 60px) / 2);
}
.ab03_left img {
    display: block;
    height: auto;
    width: 100%;
}
.ab03_right {
    flex-grow: 2;
    max-width: 555px;
}
/********************************************************

	医師紹介

********************************************************/
.title_44 {
    font-size: clamp(30px, 2.292vw, 44px);
}
.title_21 {
    font-size: clamp(20px, 1.094vw, 21px);
}
.padding55_55 {
    padding: 55px;
    position: relative;
    z-index: 1;
}
.doc01_flex {
    align-items: center;
    display: flex;
    gap: 40px 87px;
    justify-content: space-between;
    position: relative;
    z-index: 1;
}
.doc01_left {
    flex-shrink: 0;
    max-width: max-content;
    width: calc((100% - 87px) / 2);
}
.doc01_img {
    margin-left: 27px;
    max-width: 526px;
    width: calc(100% - 27px);
}
.doc01_name_absolute {
    background: url("../images/doctor_name_bg.webp") left bottom/101px 76px no-repeat;
    bottom: 20px;
    height: 162px;
    left: 0;
    max-width: none;
    padding: 0;
    position: absolute;
    width: 128px;
    z-index: 2;
    background-color: #7FC86C;
    border-radius: 10px;
}
.doc01_name_post {
    color: #fff;
    font-weight: 500;
    line-height: 1.6;
    left: 19px;
    position: absolute;
    top: 25px;
    writing-mode: vertical-rl;
}
.doc01_name_wrap {
    left: 69px;
    position: absolute;
    top: 24px;
}
.doc01_name_ja {
    color: #fff;
    letter-spacing: 2.2px;
    line-height: 1.2;
    margin-top: 0;
    writing-mode: vertical-rl;
}
.doc01_name_ja_sub {
    margin-top: 4px;
}
.doc01_name_kana {
    color: #fff;
    font-size: 13px;
    left: 114px;
    letter-spacing: 1.17px;
    line-height: 1;
    position: absolute;
    top: 26px;
    transform: rotate(90deg);
    transform-origin: left top;
    white-space: nowrap;
}
.doc01_right {
    flex-grow: 2;
    letter-spacing: 0.08em;
    line-height: 2.12;
    max-width: 587px;
}
.doc01_his_flex {
    align-items: flex-start;
    display: flex;
    gap: 40px 60px;
    justify-content: space-between;
}
.doc01_his_left {
    width: calc((100% - 60px) / 2);
}
.doc01_his_table, .doc01_his_list {
    margin-top: 28px;
}
.doc01_his_table {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.doc01_his_table li {
    align-items: flex-start;
    display: flex;
    gap: 20px;
}
.doc01_his_cell1 {
    flex-shrink: 0;
    max-width: 110px;
    width: 24%;
    letter-spacing: 0.75px;
}
.doc01_his_cell2 {
    flex-grow: 2;
    letter-spacing: 0.75px;
}
.doc01_his_list {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.doc01_his_list li {
    letter-spacing: 0.75px;
    position: relative;
}
.doc01_absolute_deco1 {
    display: flex;
    justify-content: flex-start;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 130px;
    width: 38%;
    z-index: 0;
}
.doc01_absolute_deco1 img {
    display: block;
    height: auto;
    max-width: 100%;
}
/************************/
.doc02_flex {
    display: flex;
    flex-direction: column;
    gap: 76px;
}
.doc02_box {
    align-items: flex-start;
    display: flex;
    gap: 30px 64px;
    justify-content: space-between;
    background-color: #FFF;
    padding: 80px 120px;
    border-radius: 20px;
}
.doc02_name_wrap {
    flex-shrink: 0;
    width: 260px;
    padding-top: 4px;
    white-space: nowrap;
}
.doc02_name_flex {
    align-items: flex-start;
    display: flex;
    gap: 14px;
}
.doc02_post {
    line-height: 1.6;
    font-size: 17px;
}
.doc02_name {
    letter-spacing: 0.14em;
    line-height: 1.25;
    font-size: clamp(22px, 2vw, 24px);
}
.doc02_name_eng {
    letter-spacing: 0.75px;
    line-height: 1.6;
    color: #3F3F3F;
    font-size: 15px;
}
.doc02_right {
    flex-grow: 2;
    max-width: 540px;
}
.doc02_right > div {
    border-bottom: 1px solid #CCD9DE;
    padding-bottom: 35px;
}
.doc02_right > div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}
/********************************************************

	内科・循環器内科

********************************************************/
/********************************************************

	内科・循環器内科

********************************************************/
.internal01_text_wrap {
    letter-spacing: 1.6px;
    line-height: 2.45;
}
.internal01_text {
    text-wrap: pretty;
}
.internal02_text {
    letter-spacing: 1.7px;
    line-height: 2;
}
.internal02_flex {
    display: flex;
    gap: 81px;
    justify-content: space-between;
}
.internal02_box {
    background: #fff;
    border-radius: 65px 65px 16px 16px;
    padding: 13px 13px 30px;
    width: calc((100% - 81px) / 2);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.internal02_img img {
    border-radius: 53px 53px 0 0;
    display: block;
    height: auto;
    width: 100%;
}
.internal02_title {
    letter-spacing: 2.7px;
    line-height: 1.5;
    text-align: center;
}
.internal02_list li {
    letter-spacing: 1.6px;
    line-height: 1.9;
    padding-left: 35px;
    position: relative;
}
.internal02_list li + li {
    margin-top: 5px;
}
.internal02_list li::before {
    background: url("../images/check.webp") center center/contain no-repeat;
    content: "";
    height: 18px;
    left: 0;
    position: absolute;
    top: 7px;
    width: 18px;
}
.internal02_more {
    letter-spacing: 1.5px;
    text-align: right;
    padding-right: 20px;
}
.center_content {
    max-width: max-content;
    margin-left: auto;
    margin-right: auto;
}
.internal02_note {
    background: #fdf4f2;
    border-radius: 10px;
    line-height: 2;
    padding: 20px clamp(20px, 7%, 50px);
    position: relative;
}
.internal02_note::before {
    color: #b91c1c;
    content: "※";
    margin-right: 2px;
}
.internal03_title_wrap, .internal04_title_wrap {
    border-bottom: 2px dashed #9ccc8b;
    padding-bottom: 16px;
}
.internal03_title_flex, .internal04_title_flex {
    align-items: center;
    display: flex;
    gap: 15px;
    padding-left: 13px;
}
.internal03_icon, .internal04_icon {
    flex-shrink: 0;
    width: 37px;
}
.internal03_icon img, .internal04_icon img {
    display: block;
    height: auto;
    width: 100%;
}
.internal03_title_text, .internal04_title_text {
    letter-spacing: 4px;
    line-height: 1.45;
}
.internal03_text, .internal04_text {
    letter-spacing: 1.6px;
    line-height: 2;
}
.internal04_list li {
    letter-spacing: 1.6px;
    line-height: 2;
    padding-left: 23px;
    position: relative;
}
.internal04_list li::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 10px;
    left: 0;
    position: absolute;
    top: 11px;
    width: 10px;
}
.internal05_text {
    letter-spacing: 1.7px;
    line-height: 2;
}
.internal05_flex {
    display: flex;
    gap: 42px;
    justify-content: space-between;
}
.internal05_box {
    align-items: center;
    background: #89cd77;
    border-radius: 40px 10px 10px 10px;
    display: flex;
    height: 95px;
    justify-content: center;
    padding: 15px 20px;
    width: calc((100% - 84px) / 3);
}
.internal05_box_text {
    color: #fff;
    letter-spacing: 2.1px;
    line-height: 1.5;
}
.internal05_absolute_deco1, .internal06_absolute_deco1 {
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.internal05_absolute_deco1 img, .internal06_absolute_deco1 img {
    display: block;
    height: auto;
    width: 100%;
}
.internal05_absolute_deco1 {
    right: 0;
    top: 38px;
    width: 335px;
}
.internal06_text_wrap {
    letter-spacing: 1.6px;
    line-height: 2.45;
}
.internal06_absolute_deco1 {
    left: 0;
    top: -24px;
    width: 313px;
}
/********************************************************

	禁煙外来

********************************************************/
.smoking01_text_wrap, .smoking03_text_wrap, .smoking04_text_wrap, .smoking05_text {
    letter-spacing: 1.6px;
    line-height: 2.45;
}
.smoking01_absolute_deco1, .smoking04_absolute_deco1, .smoking05_absolute_deco1 {
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.smoking01_absolute_deco1 img, .smoking04_absolute_deco1 img, .smoking05_absolute_deco1 img {
    max-width: 100%;
    height: auto;
}
.smoking01_absolute_deco1 {
    right: 0;
    top: 100px;
    width: 40%;
    text-align: right;
}
.smoking02_flex {
    align-items: center;
    display: flex;
    gap: 77px;
    justify-content: space-between;
}
.smoking02_left {
    flex-grow: 2;
    max-width: 620px;
    width: 56%;
}
.smoking02_right {
    flex-shrink: 0;
    max-width: max-content;
    width: 45%;
}
.smoking02_right img {
    border-radius: 70px 10px 10px 10px;
    display: block;
    height: auto;
    max-width: 100%;
    width: 100%;
}
.smoking02_text_wrap {
    letter-spacing: 1.6px;
    line-height: 2;
}
.smoking03_title, .smoking05_title {
    letter-spacing: 1.5px;
    line-height: 1.5;
}
.smoking03_text {
    letter-spacing: 1.6px;
    line-height: 2;
}
.w1070_auto {
    max-width: 1070px;
    margin-left: auto;
    margin-right: auto;
}
.smoking03_condition_box {
    background: #fff;
    border-radius: 20px;
    padding: 45px 30px 46px;
}
.smoking03_condition_list {
    margin-left: auto;
    margin-right: auto;
    max-width: max-content;
}
.smoking03_condition_list li {
    line-height: 2;
    padding-left: 28px;
    position: relative;
}
.smoking03_condition_list li + li {
    margin-top: 2px;
}
.smoking03_condition_list li::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 6px;
    left: 0;
    position: absolute;
    top: 14px;
    width: 6px;
}
.smoking03_note, .smoking05_note {
    letter-spacing: 0.75px;
    line-height: 2;
    text-align: right;
}
.smoking03_schedule {
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
}
.smoking03_schedule_head {
    background: #7fc86c;
    padding: 5px 20px;
}
.smoking03_schedule_scroll {
    padding: 54px 40px 34px;
}
.smoking03_schedule_inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 870px;
}
.smoking03_step_wrap {
    display: flex;
    justify-content: space-between;
    position: relative;
}
.smoking03_step_wrap::before {
    background: #C1D8BB;
    content: "";
    height: 2px;
    left: 10%;
    position: absolute;
    right: 10%;
    top: 52px;
}
.smoking03_step {
    position: relative;
    text-align: center;
    width: 20%;
    z-index: 1;
}
.smoking03_circle {
    align-items: center;
    background: #fcfcf4;
    border: 1px solid #e2e8d5;
    border-radius: 50%;
    display: flex;
    height: 105px;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    max-width: 105px;
    letter-spacing: 0.18px;
    line-height: 1.4;
    width: 100%;
    font-size: 18px;
    font-weight: bold;
}
.smoking03_circle_last {
    background: #7fc86c;
    border-color: #7fc86c;
}
.smoking03_step_text {
    letter-spacing: 1.6px;
    line-height: 1.4;
    text-align: center;
}
.smoking03_flex {
    display: flex;
    gap: 42px;
    justify-content: space-between;
}
.smoking03_card {
    background: #fff;
    border-radius: 20px;
    padding: 43px 48px 40px;
    width: calc((100% - 42px) / 2);
}
.smoking03_card_title, .smoking04_card_title {
    border-bottom: 2px dashed #9ccb8b;
    line-height: 1.5;
    padding-bottom: 18px;
}
.smoking03_card_title {
    letter-spacing: 1.6px;
    padding-left: 13px;
}
.smoking03_card_text, .smoking04_card_text {
    letter-spacing: 1.2px;
    line-height: 2;
}
.smoking03_card_list li {
    letter-spacing: 1.2px;
    line-height: 2;
    padding-left: 23px;
    position: relative;
}
.smoking03_card_list li + li {
    margin-top: 2px;
}
.smoking03_card_list li::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 6px;
    left: 0;
    position: absolute;
    top: 12px;
    width: 6px;
}
.smoking04_flex {
    display: flex;
    gap: 54px;
    justify-content: space-between;
    position: relative;
    z-index: 1;
}
.smoking04_card {
    background: #fbfbf3;
    border-radius: 20px;
    padding: 33px 48px 40px;
    width: calc((100% - 54px) / 2);
}
.smoking04_card_title {
    letter-spacing: 2.4px;
}
.smoking04_card_flex {
    align-items: flex-start;
    display: flex;
    gap: 20px;
}
.smoking04_icon {
    flex-shrink: 0;
    max-width: max-content;
    width: 19.7183098592%;
    max-width: 98px;
}
.smoking04_icon img {
    display: block;
    height: auto;
    width: 100%;
}
.smoking04_card_text {
    flex-grow: 2;
    max-width: 379px;
}
.smoking04_absolute_deco1 {
    right: 0;
    text-align: right;
    top: 120px;
    width: 35%;
}
.smoking05_table_wrap {
    position: relative;
    z-index: 1;
}
.smoking05_table {
    border: 1px solid #e6e6d5;
    border-radius: 20px;
    overflow: hidden;
}
.smoking05_table table {
    border-collapse: collapse;
    width: 100%;
}
.smoking05_table thead th {
    background: #f7feef;
    border-bottom: 1px solid #d2ded2;
    line-height: 1.5;
    padding: 17px 50px;
    text-align: left;
    width: 50%;
}
.smoking05_table tbody td {
    border-bottom: 1px solid #d2ded2;
    line-height: 1.5;
    padding: 17px 50px;
    width: 50%;
}
.smoking05_table tbody tr:last-child td {
    border-bottom: 0;
}
.smoking05_absolute_deco1 {
    left: 0;
    top: 100px;
    width: 35%;
}
.faq_wrap {
    margin-left: auto;
    margin-right: auto;
    width: calc(100% - 146px);
    max-width: 1072px;
}
.faq_row, .faq_q_only {
    border-bottom: 1px solid #c9c9c2;
}
.faq_q, .faq_a_inner {
    align-items: center;
    gap: 39px;
    min-height: 90px;
}
.faq_q {
    display: flex;
}
.faq_row .faq_q {
    cursor: pointer;
}
.faq_a {
    display: none;
}
.faq_a.faq_a_open {
    display: block;
}
.faq_a_inner {
    display: flex;
}
.faq_icon {
    align-items: center;
    border-radius: 50%;
    display: flex;
    flex-shrink: 0;
    height: 44px;
    justify-content: center;
    line-height: 1;
    width: 44px;
}
.faq_icon_q {
    background: #fff;
    box-shadow: 0 0 10px rgba(225, 231, 218, 0.76);
    color: #76c761;
}
.faq_icon_a {
    background: #76c761;
    color: #fff;
}
.faq_q_text, .faq_a_text {
    flex-grow: 2;
    letter-spacing: 1.7px;
    line-height: 2;
    min-width: 0;
}
.faq_toggle {
    flex-shrink: 0;
    height: 16px;
    position: relative;
    width: 16px;
}
.faq_toggle::before, .faq_toggle::after {
    background: #76c761;
    border-radius: 20px;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    top: 7px;
    width: 16px;
}
.faq_toggle::after {
    transform: rotate(90deg);
}
.faq_toggle_open::after {
    display: none;
}
/********************************************************

	予防接種

********************************************************/
.vaccination01_text_wrap {
    letter-spacing: 1.6px;
    line-height: 2;
    position: relative;
    z-index: 1;
}
.vaccination01_absolute_deco1, .vaccination01_absolute_deco2 {
    position: absolute;
    z-index: 0;
}
.vaccination01_absolute_deco1 img, .vaccination01_absolute_deco2 img {
    max-width: 100%;
    height: auto;
}
.vaccination01_absolute_deco1 {
    bottom: 450px;
    height: 280px;
    left: 0;
    width: 35%;
}
.vaccination01_absolute_deco2 {
    height: 280px;
    right: 0;
    top: 420px;
    width: 35%;
    text-align: right;
}
.vaccination01_table_title {
    border-bottom: 2px dashed #9ccc8b;
    letter-spacing: 3.6px;
    line-height: 1.5;
    padding: 0 20px 18px;
}
.vaccination01_table_scroll {
    background: #fff;
    border: 1.5px solid #a8d5a8;
    border-radius: 13px;
    overflow: hidden;
    position: relative;
    z-index: 1;
}
.vaccination01_table_main {
    border-collapse: collapse;
    table-layout: fixed;
    width: 100%;
}
.vaccination01_head, .vaccination01_name_cell, .vaccination01_category_cell, .vaccination01_fee_cell {
    border-right: 1px solid #d2ded2;
    border-bottom: 1px solid #d2ded2;
}
.vaccination01_head {
    background: #f7feef;
    line-height: 1.5;
    padding: 14px 54px;
    text-align: left;
}
.vaccination01_head_name {
    width: 48.4%;
}
.vaccination01_head_category {
    text-align: center;
    width: 16.1%;
}
.vaccination01_head_fee {
    border-right: 0;
    width: 35.5%;
}
.vaccination01_name_cell {
    line-height: 1.5;
    padding: 12px 54px;
    vertical-align: middle;
}
.vaccination01_category_cell {
    padding: 20px 12px;
    text-align: center;
    vertical-align: middle;
}
.vaccination01_fee_cell {
    border-right: 0;
    padding: 20px 54px;
    vertical-align: middle;
}
.vaccination01_category_inner, .vaccination01_fee_inner {
    margin-left: auto;
    margin-right: auto;
}
.vaccination01_badge {
    border-radius: 6px;
    display: inline-flex;
    justify-content: center;
    letter-spacing: 1.6px;
    line-height: 1;
    padding: 8px 20px;
}
.vaccination01_badge_green {
    background: #f7fff6;
    border: 1px solid #d1eacf;
    color: #28993d;
}
.vaccination01_badge_orange {
    background: #fffaf0;
    border: 1px solid #feebc8;
    color: #9c4221;
}
.vaccination01_fee_inner {
    max-width: max-content;
}
.vaccination01_fee_main {
    font-weight: 700;
    letter-spacing: 1.6px;
    line-height: 1.5;
}
.vaccination01_fee_small {
    font-weight: 400;
}
.vaccination01_fee_sub {
    letter-spacing: 1.5px;
    line-height: 2;
}
.vaccination02_bg {
    background: #fbfbf3;
    border-radius: 10px 10px 0 0;
}
.vaccination02_wrap {
    display: flex;
    flex-direction: column;
    gap: 55px;
    margin-left: auto;
    margin-right: auto;
    max-width: 1121px;
}
.vaccination02_card {
    background: #fff;
    border-radius: 20px;
    padding: 40px 80px;
}
.vaccination02_card_title {
    border-bottom: 2px dashed #9ccc8b;
    letter-spacing: 3.6px;
    line-height: 1.5;
    padding: 0 20px 18px;
}
.vaccination02_card_text_wrap {
    padding: 0 20px;
}
.vaccination02_card_text {
    letter-spacing: 1.6px;
    line-height: 2;
}
/********************************************************

	睡眠時無呼吸症候群

********************************************************/
.sleep01_text_wrap, .sleep02_text_wrap, .sleep03_text, .sleep04_text, .sleep05_text_wrap, .sleep05_item_text, .sleep06_text_wrap {
    letter-spacing: 1.6px;
    line-height: 2.45;
}
.title_bb {
    border-bottom: 1px solid #D9D9D9;
    padding-bottom: 10px;
}
.sleep02_flex {
    align-items: center;
    display: flex;
    gap: 90px;
    justify-content: space-between;
}
.sleep02_flex_reverse .sleep02_img {
    order: 1;
}
.sleep02_flex_reverse .sleep02_content {
    order: 2;
}
.sleep02_content {
    flex-grow: 2;
    max-width: 595px;
    width: 50%;
}
.sleep02_img {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.sleep02_img img {
    border-radius: 48px 8px 8px 8px;
    display: block;
    height: auto;
    width: 100%;
}
.sleep02_sub_title, .sleep03_title {
    border-bottom: 2px dashed #9ccc8b;
    letter-spacing: 2.4px;
    line-height: 1.5;
    padding-bottom: 18px;
}
.sleep03_box {
    background: #fbfbf3;
    border-radius: 20px;
    padding: 50px 60px 55px;
}
.sleep03_text {
    line-height: 2;
}
.sleep03_text_wrap {
    line-height: 2;
}
.sleep03_text_wrap_osa {
    padding-left: 20px;
}
.sleep03_box_osa {
    padding: 50px 78px 40px;
}
.sleep03_box_csa {
    padding: 50px 78px 48px;
}
.sleep03_osa_flex {
    align-items: flex-start;
    display: flex;
    gap: 112px;
    justify-content: space-between;
    margin-top: 70px;
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}
.sleep03_osa_item {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: calc((100% - 112px) / 2);
}
.sleep03_badge {
    align-items: center;
    background: #fff;
    border: 1px solid #a0d592;
    border-radius: 26px;
    color: #42902d;
    display: inline-flex;
    font-size: 18px;
    font-weight: 700;
    justify-content: center;
    letter-spacing: 1.8px;
    line-height: 1.4;
    min-height: 39px;
    padding: 6px 34px;
    text-align: center;
}
.sleep03_badge_fill {
    background: #7fc86c;
    border-color: #7fc86c;
    color: #fff;
    min-width: 190px;
}
.sleep03_normal_img, .sleep03_abnormal_img {
    position: relative;
    width: 100%;
}
.sleep03_normal_img img, .sleep03_abnormal_img img {
    display: block;
    height: auto;
    margin-left: auto;
    margin-right: auto;
}
.sleep03_normal_img {
    margin-top: 36px;
    max-width: 220px;
}
.sleep03_abnormal_img {
    margin-top: 34px;
    max-width: 339px;
}
.sleep03_normal_label {
    color: #3f3f3f;
    font-size: 17px;
    left: 18px;
    letter-spacing: 1.36px;
    line-height: 2;
    position: absolute;
    top: 38px;
}
.sleep03_air_flex {
    align-items: center;
    display: flex;
    gap: 11px;
    margin-top: 35px;
}
.sleep03_air_arrow {
    width: 42px;
}
.sleep03_air_arrow img {
    display: block;
    height: auto;
    width: 100%;
}
.sleep03_air_text {
    color: #3f3f3f;
    font-size: 16px;
    letter-spacing: 1.6px;
    line-height: 1.4;
}
.sleep04_box {
    background: #fff;
    border-radius: 20px;
    padding: 50px 70px;
}
.sleep04_flex {
    display: flex;
    gap: 34px 60px;
    justify-content: space-between;
}
.sleep04_list {
    width: calc((100% - 60px) / 2);
}
.sleep04_list li {
    line-height: 1.9;
    padding-left: 39px;
    position: relative;
}
.sleep04_list li + li {
    margin-top: 25px;
}
.sleep04_list li::before {
    content: "";
    background: url("../images/check.webp") 50% 0/100% 100% no-repeat;
    height: 18px;
    left: 0;
    position: absolute;
    top: 6px;
    width: 18px;
}
.sleep05_wrap {
    position: relative;
    z-index: 1;
}
.sleep05_flex {
    align-items: center;
    border-bottom: 1px solid #e7e2cf;
    display: flex;
    gap: 100px;
    justify-content: space-between;
    padding: 50px 0;
}
.sleep05_flex:first-child {
    padding-top: 0;
}
.sleep05_flex:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}
.sleep05_img {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.sleep05_img img {
    border-radius: 48px 8px 8px 8px;
    display: block;
    height: auto;
    width: 100%;
}
.sleep05_content {
    flex-grow: 2;
    max-width: 565px;
    width: 50%;
}
.sleep06_flex {
    align-items: center;
    display: flex;
    gap: 70px;
    justify-content: space-between;
    position: relative;
    z-index: 1;
}
.sleep06_left {
    flex-grow: 2;
    max-width: 543px;
    width: 50%;
}
.sleep06_right {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.sleep06_right img {
    border-radius: 48px 8px 8px 8px;
    display: block;
    height: auto;
    width: 100%;
}
.sleep06_absolute_deco1, .sleep07_absolute_deco1, .sleep07_absolute_deco2 {
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.sleep06_absolute_deco1 img, .sleep07_absolute_deco1 img, .sleep07_absolute_deco2 img {
    height: auto;
    max-width: 100%;
}
.sleep06_absolute_deco1 {
    right: 0;
    top: 70px;
    width: 40%;
    text-align: right;
}
.sleep07_inner, .faq_wrap {
    margin-left: auto;
    margin-right: auto;
    max-width: 1072px;
}
.sleep07_head {
    display: flex;
}
.sleep07_head_item {
    align-items: center;
    clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%, 18px 50%);
    display: flex;
    flex: 1 1 20%;
    justify-content: center;
    margin-left: -18px;
    min-height: 69px;
    padding: 8px 24px;
    position: relative;
}
.sleep07_head_item p {
    letter-spacing: 3px;
    line-height: 1.5;
}
.sleep07_head_item:nth-child(1) {
    background: #69b555;
}
.sleep07_head_item:nth-child(2) {
    background: #78c365;
}
.sleep07_head_item:nth-child(3) {
    background: #83cb70;
}
.sleep07_head_item:nth-child(4) {
    background: #8ed47a;
}
.sleep07_head_item:nth-child(5) {
    background: #9ade85;
}
.sleep07_head_item_first {
    border-radius: 23px 0 0 0;
    clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%);
    margin-left: 0;
}
.sleep07_flow {
    overflow: hidden;
}
.sleep07_row {
    align-items: center;
    background: #fefef6;
    display: flex;
    min-height: 111px;
}
.sleep07_row_alt {
    background: #f9f9ef;
}
.sleep07_no {
    align-items: center;
    display: flex;
    flex: 0 0 180px;
    justify-content: center;
    position: relative;
    width: 98px;
}
.sleep07_no span {
    align-items: center;
    background: #76c761;
    border: 1px solid #76c761;
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    font-weight: 700;
    height: 45px;
    justify-content: center;
    line-height: 1;
    width: 45px;
}
.sleep07_no::after {
    border-left: 1px dashed #76c761;
    top: 100%;
    content: "";
    left: 50%;
    height: calc(100% + 50px);
    position: absolute;
    transform: translateX(-50%);
}
.sleep07_no_fill span {
    color: #76c761;
    background: #fefef6;
}
.sleep07_row_last .sleep07_no::after {
    display: none;
}
.sleep07_content {
    flex-grow: 2;
    padding: 20px 180px 20px 0;
}
.sleep07_title {
    letter-spacing: 2px;
    line-height: 1.5;
}
.sleep07_sub {
    letter-spacing: 1.5px;
    line-height: 1.5;
}
.sleep07_absolute_deco1 {
    left: -118px;
    top: 10px;
    width: 409px;
}
.sleep07_absolute_deco2 {
    bottom: -18px;
    right: -92px;
    width: 328px;
}
/********************************************************

	呼吸器内科・アレルギー科

********************************************************/
.respiratory01_flex {
    align-items: center;
    display: flex;
    gap: 60px 80px;
    justify-content: space-between;
}
.respiratory01_left {
    flex-grow: 2;
    max-width: 562px;
    width: 50%;
}
.respiratory01_right {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.respiratory01_right img {
    border-radius: 10px;
    display: block;
    height: auto;
    width: 100%;
}
.respiratory01_text_wrap, .respiratory03_text_wrap, .respiratory04_text_wrap, .respiratory05_text_wrap, .respiratory05_lead, .respiratory05_conclusion, .respiratory06_text_wrap, .respiratory06_box_text, .respiratory07_content {
    letter-spacing: 1.6px;
    line-height: 2;
}
.respiratory01_absolute_deco1, .respiratory04_absolute_deco1, .respiratory06_absolute_deco1, .respiratory07_absolute_deco1 {
    display: flex;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.respiratory01_absolute_deco1 img, .respiratory04_absolute_deco1 img, .respiratory06_absolute_deco1 img, .respiratory07_absolute_deco1 img {
    display: block;
    height: auto;
    max-width: 100%;
}
.respiratory01_absolute_deco1 {
    justify-content: flex-end;
    right: 0;
    bottom: 0;
    width: 18%;
}
/************************/
.respiratory02_grid {
    display: grid;
    gap: 12px 15px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.respiratory02_grid li {
    background: #f6faef;
    border-radius: 8px;
    line-height: 1.5;
    min-height: 46px;
    padding: 15px 18px 15px 42px;
    position: relative;
}
.respiratory02_grid li::before {
    background: url("../images/check.webp") 50% 0/100% 100% no-repeat;
    content: "";
    height: 18px;
    left: 15px;
    position: absolute;
    top: 20px;
    width: 18px;
}
.respiratory02_note {
    line-height: 1.5;
    margin-left: auto;
    max-width: max-content;
}
/************************/
.respiratory03_head {
    border-bottom: 2px dashed #9ccc8b;
    padding-bottom: 16px;
}
.respiratory03_title {
    letter-spacing: 1.5px;
}
.respiratory03_title::before {
    margin-top: 16px;
}
.title_26 {
    font-size: clamp(20px, 2.2vw, 26px);
}
.respiratory03_flex {
    align-items: center;
    display: flex;
    gap: 50px 60px;
    justify-content: space-between;
}
.respiratory03_flex_reverse .respiratory03_img {
    order: 1;
}
.respiratory03_flex_reverse .respiratory03_text_wrap {
    order: 2;
}
.respiratory03_text_wrap {
    flex-grow: 2;
    max-width: 650px;
    width: 54%;
}
.respiratory03_img {
    flex-shrink: 0;
    max-width: max-content;
    width: 46%;
}
.respiratory03_img img {
    border-radius: 10px;
    display: block;
    height: auto;
    width: 100%;
}
/************************/
.respiratory04_grid {
    display: grid;
    gap: 18px 11px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.respiratory04_card {
    align-items: center;
    background: #87cb70;
    border-radius: 6px;
    color: #fff;
    display: flex;
    justify-content: center;
    line-height: 1.4;
    min-height: 80px;
    padding: 10px 18px;
}
.respiratory04_more {
    align-self: center;
    justify-self: end;
    line-height: 1.5;
}
.respiratory04_absolute_deco1 {
    justify-content: flex-start;
    left: 0;
    bottom: 0;
    width: 16%;
}
/************************/
.respiratory05_wrap {
    display: flex;
    flex-direction: column;
    gap: 60px;
}
.respiratory05_box {
    background: #fff;
    border-radius: 10px;
    padding: 80px 120px;
}
.respiratory05_box_title {
    border-bottom: 2px dashed #9ccc8b;
    letter-spacing: 2.5px;
    line-height: 1.5;
    padding: 0 14px 22px;
}
.respiratory05_section_head {
    padding-left: 26px;
    position: relative;
}
.respiratory05_section_head::before {
    background: #6eb953;
    border-radius: 2.4px;
    content: "";
    height: 28px;
    left: 0;
    position: absolute;
    top: 1px;
    width: 5px;
}
.respiratory05_section_title {
    letter-spacing: 2.3px;
    line-height: 1.5;
}
.respiratory05_bullet_list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.respiratory05_bullet_list li {
    letter-spacing: 1.6px;
    line-height: 2;
    padding-left: 23px;
    position: relative;
}
.respiratory05_bullet_list li::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 8px;
    left: 0;
    position: absolute;
    top: 12px;
    width: 8px;
}
.respiratory05_compare {
    display: flex;
    justify-content: space-between;
}
.respiratory05_list_2col {
    display: flex;
    justify-content: space-between;
}
.respiratory05_trigger_flex {
    display: flex;
    justify-content: space-between;
}
.respiratory05_treatment_flex {
    display: flex;
    justify-content: space-between;
}
.respiratory05_intro_flex {
    display: flex;
    justify-content: space-between;
}
.respiratory06_flex {
    display: flex;
    justify-content: space-between;
}
.respiratory07_flex {
    display: flex;
    justify-content: space-between;
}
.respiratory05_compare {
    gap: 64px 60px;
}
.respiratory05_compare_box {
    border-radius: 9px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 42px 20px 34px;
    position: relative;
    width: 50%;
}
.respiratory05_compare_box_normal {
    border: 1.5px solid #cee0c9;
}
.respiratory05_compare_box_alert {
    border: 1.5px solid #fac2c2;
}
.respiratory05_compare_badge {
    align-items: center;
    border-radius: 23px;
    color: #fff;
    display: inline-flex;
    font-size: 16px;
    font-weight: 700;
    height: 35px;
    justify-content: center;
    left: 50%;
    letter-spacing: 1.6px;
    line-height: 1.4;
    min-width: 158px;
    padding: 0 18px;
    position: absolute;
    top: -17px;
    transform: translateX(-50%);
}
.respiratory05_compare_badge_normal {
    background: #87c376;
}
.respiratory05_compare_badge_alert {
    background: #e57379;
}
.respiratory05_compare_lung {
    align-items: flex-end;
    display: flex;
    height: 155px;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}
.respiratory05_compare_lung img {
    display: block;
    height: auto;
    max-width: 100%;
}
.respiratory05_compare_panel {
    align-items: center;
    display: flex;
    justify-content: center;
    margin-top: 10px;
    padding: 20px 12px;
}
.respiratory05_compare_panel img {
    display: block;
    height: auto;
    margin-left: auto;
    margin-right: auto;
}
.respiratory05_compare_panel_normal {
    background: #f5faee;
    position: relative;
}
.respiratory05_compare_panel_normal:before {
    border-bottom: 23px solid #f5faee;
    border-left: 23px solid transparent;
    border-right: 23px solid transparent;
    content: "";
    left: 50%;
    position: absolute;
    top: -23px;
    transform: translateX(-50%);
}
.respiratory05_compare_panel_alert {
    background: #fff1f1;
}
.respiratory05_compare_icon {
    margin: -10px auto 0;
    max-width: 96px;
}
.respiratory05_compare_icon img {
    display: block;
    height: auto;
    width: 100%;
}
.respiratory05_caption, .respiratory05_small_note {
    letter-spacing: 1.5px;
    line-height: 1.6;
}
.respiratory05_small_note {
    margin-left: auto;
    max-width: max-content;
}
.respiratory05_list_2col {
    gap: 40px 60px;
}
.respiratory05_trigger_flex {
    gap: 40px 60px;
}
.respiratory05_trigger_icons {
    flex-shrink: 0;
    max-width: max-content;
}
.respiratory05_trigger_row {
    display: flex;
    gap: 15px;
}
.respiratory05_trigger_row_sub {
    justify-content: center;
    margin-top: 20px;
}
.respiratory05_trigger_icon {
    width: 114px;
}
.respiratory05_trigger_icon img {
    display: block;
    height: auto;
    width: 100%;
}
.respiratory05_trigger_list {
    flex-grow: 2;
    max-width: 440px;
}
.respiratory05_treatment_flex {
    gap: 40px 60px;
}
.respiratory05_treatment_list {
    flex-grow: 2;
    max-width: 625px;
}
.respiratory05_treatment_img {
    flex-shrink: 0;
    max-width: max-content;
    width: 30%;
}
.respiratory05_treatment_img img {
    display: block;
    height: auto;
    width: 100%;
}
.respiratory05_copd_panel {
    margin-top: 30px;
    min-height: 214px;
    padding: 27px 25px 22px;
    position: relative;
    width: 100%;
}
.respiratory05_copd_panel_normal {
    background: #f5faee;
}
.respiratory05_copd_panel_normal::before {
    border-bottom: 23px solid #f5faee;
    border-left: 23px solid transparent;
    border-right: 23px solid transparent;
    content: "";
    left: 50%;
    position: absolute;
    top: -23px;
    transform: translateX(-50%);
}
.respiratory05_copd_panel_alert {
    background: #fff1f1;
}
.respiratory05_copd_panel_alert::before {
    border-bottom: 23px solid #fff1f1;
    border-left: 23px solid transparent;
    border-right: 23px solid transparent;
    content: "";
    left: 50%;
    position: absolute;
    top: -23px;
    transform: translateX(-50%);
}
.respiratory05_copd_item {
    line-height: 1.6;
    min-height: 80px;
}
.respiratory05_small_text {
    letter-spacing: 0.3px;
    line-height: 1.6em;
    font-size: 15px;
    margin-top: 5px;
}
.respiratory05_copd_item_title {
    font-weight: 700;
    line-height: 1.5;
}
.respiratory05_copd_item_title_alert {
    color: #e57379;
}
.respiratory05_intro_flex {
    gap: 40px 60px;
}
.respiratory05_intro_text {
    flex-grow: 2;
    max-width: 545px;
    width: 60%;
}
.respiratory05_intro_img {
    flex-shrink: 0;
    width: 40%;
}
.respiratory05_intro_img img {
    display: block;
    height: auto;
    max-width: 100%;
    margin: 0 auto;
}
/************************/
.respiratory06_flex {
    gap: 50px 60px;
    align-items: center;
}
.respiratory06_left {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.respiratory06_left img {
    border-radius: 10px;
    display: block;
    height: auto;
    width: 100%;
}
.respiratory06_right {
    flex-grow: 2;
    max-width: 600px;
    width: 50%;
}
.respiratory06_box {
    background: #fbfbf3;
    border-radius: 20px;
    padding: 60px;
}
.respiratory06_box_head {
    border-bottom: 2px dashed #9ccc8b;
    padding-bottom: 16px;
}
.respiratory06_box_title {
    letter-spacing: 2.5px;
    line-height: 1.5;
    padding-left: 6px;
}
.respiratory06_absolute_deco1 {
    justify-content: flex-end;
    right: 0;
    top: 12px;
    width: 18%;
}
/************************/
.respiratory07_flex {
    gap: 34px;
}
.respiratory07_card {
    background: #fbfbf3;
    border-radius: 40px;
    padding: 28px 40px 24px;
    width: calc((100% - 34px) / 2);
}
.respiratory07_card_head {
    border-bottom: 2px dashed #9ccc8b;
    padding-bottom: 14px;
}
.respiratory07_card_title {
    letter-spacing: 1.6px;
    line-height: 1.5;
}
.respiratory07_card_flex {
    display: flex;
    gap: 24px;
}
.respiratory07_icon {
    flex-shrink: 0;
    max-width: max-content;
    width: 34.2465753425%;
    max-width: 150px;
}
.respiratory07_icon img {
    display: block;
    height: auto;
    width: 100%;
}
.respiratory07_content {
    flex-grow: 2;
    font-size: 15px;
}
.respiratory07_link {
    display: flex;
    justify-content: flex-end;
}
.respiratory07_link a {
    align-items: center;
    color: inherit;
    display: inline-flex;
    font-size: 15px;
    gap: 10px;
    line-height: 1.5;
}
.respiratory07_arrow {
    align-items: center;
    background: #76c761;
    border-radius: 50%;
    display: inline-flex;
    height: 18px;
    justify-content: center;
    width: 18px;
}
.respiratory07_arrow img {
    display: block;
    height: auto;
    width: 5px;
}
.respiratory07_absolute_deco1 {
    justify-content: flex-start;
    left: 0;
    top: -18px;
    width: 18%;
}
/********************************************************

	アクセス

********************************************************/
.ac01_time_width {
    max-width: 1050px;
    margin-left: auto;
    margin-right: auto;
}
.access01_map {
    border-radius: 30px;
    height: 460px;
    overflow: hidden;
    position: relative;
    z-index: 1;
}
.access01_map img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}
.access01_absolute_deco1, .access02_absolute_deco1 {
    display: flex;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}
.access01_absolute_deco1 img, .access02_absolute_deco1 img {
    display: block;
    height: auto;
    max-width: 100%;
}
.access01_absolute_deco1 {
    justify-content: flex-end;
    right: -86px;
    top: 24px;
    width: 30%;
}
.access02_section {
    padding: 90px 0 140px;
}
.access02_flex {
    align-items: center;
    display: flex;
    gap: 123px;
    justify-content: space-between;
}
.access02_photo {
    flex-shrink: 0;
    max-width: max-content;
    width: 50%;
}
.access02_photo img {
    border-radius: 32px;
    display: block;
    height: auto;
    max-width: 100%;
    width: 641px;
}
.access02_content {
    flex-grow: 2;
    max-width: 486px;
}
.access02_org_name {
    letter-spacing: 1px;
    line-height: 1.45;
}
.access02_clinic_name {
    letter-spacing: 1.6px;
    line-height: 1.4;
    margin-top: 2px;
}
.access02_address {
    align-items: flex-start;
    display: flex;
    gap: 7px;
    letter-spacing: 1.6px;
    line-height: 1.6;
}
.access02_pin {
    background: url("../images/pin.webp") center center/contain no-repeat;
    flex-shrink: 0;
    height: 17px;
    margin-top: 4px;
    width: 17px;
}
.access02_tel {
    align-items: flex-end;
    display: flex;
    gap: 7px;
    line-height: 1;
}
.access02_tel_num {
    letter-spacing: 1px;
}
.access02_info_list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.access02_info_row {
    align-items: center;
    display: flex;
    gap: 21px;
    letter-spacing: 0.9px;
    line-height: 1.5;
}
.access02_info_icon {
    border: 1px solid #6eb953;
    border-radius: 50%;
    display: inline-flex;
    flex-shrink: 0;
    height: 41px;
    position: relative;
    width: 41px;
}
.access02_info_icon_fax::before {
    border: 2px solid #6eb953;
    border-radius: 2px;
    content: "";
    height: 10px;
    left: 12px;
    position: absolute;
    top: 16px;
    width: 14px;
}
.access02_info_icon_fax::after {
    background: #6eb953;
    box-shadow: 0 4px 0 #6eb953, 0 8px 0 #6eb953;
    content: "";
    height: 2px;
    left: 14px;
    position: absolute;
    top: 12px;
    width: 10px;
}
.access02_info_icon_car::before {
    border: 2px solid #6eb953;
    border-radius: 4px 8px 3px 3px;
    content: "";
    height: 8px;
    left: 8px;
    position: absolute;
    top: 15px;
    width: 21px;
}
.access02_info_icon_car::after {
    background: #6eb953;
    border-radius: 50%;
    box-shadow: 12px 0 0 #6eb953;
    content: "";
    height: 5px;
    left: 11px;
    position: absolute;
    top: 25px;
    width: 5px;
}
.access02_card_flex {
    display: flex;
    gap: 86px;
    justify-content: space-between;
}
.access02_card {
    background: #fbfbf3;
    border-radius: 10px;
    padding: 41px 55px 59px;
    width: calc((100% - 86px) / 2);
}
.access02_card_title {
    border-bottom: 2px dashed #9ccc8b;
    letter-spacing: 2.6px;
    line-height: 1.5;
    padding-bottom: 16px;
}
.access02_card_item {
    line-height: 1.8;
}
.access02_item_title {
    letter-spacing: 0.9px;
    line-height: 1.5;
    padding-left: 18px;
    position: relative;
}
.access02_item_title::before {
    background: #6eb953;
    border-radius: 2.4px;
    content: "";
    height: 22px;
    left: 0;
    position: absolute;
    top: 2px;
    width: 5px;
}
.access02_absolute_deco1 {
    justify-content: flex-start;
    left: -68px;
    top: 150px;
    width: 30%;
}
/********************************************************

	お知らせ一覧

********************************************************/
.news01_list li {
    border-bottom: 1px solid #e3e3e3;
}
.news01_link {
    transition: 0.3s ease-in-out;
    align-items: center;
    display: flex;
    min-height: 104px;
    padding: 20px 51px 20px 15px;
    position: relative;
}
.news01_date {
    color: #868686;
    flex-shrink: 0;
    letter-spacing: 0.75px;
    line-height: 1.6;
    margin-right: 75px;
    width: 105px;
}
.news01_title {
    flex-grow: 2;
    font-weight: 500;
    letter-spacing: 1.5px;
    line-height: 1.7;
    min-width: 0;
}
.news01_arrow {
    transition: 0.3s ease-in-out;
    align-items: center;
    display: inline-flex;
    flex-shrink: 0;
    height: 13px;
    justify-content: center;
    margin-left: 30px;
    width: 15px;
}
.news01_arrow::before {
    background: url("../images/arrow_g.webp") 50% 50%/6px 10px no-repeat;
    content: "";
    height: 13px;
    width: 15px;
}
.news01_link:hover .news01_arrow {
    transform: translateX(4px);
}
.pagenation ul {
    align-items: center;
    display: flex;
}
.pagenation li {
    align-items: center;
    display: flex;
    height: 30px;
    justify-content: center;
    position: relative;
    width: 48px;
}
.pagenation li.active {
    color: #fff;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    position: relative;
    z-index: 1;
}
.pagenation li.active::before {
    background: #76c761;
    border-radius: 50%;
    content: "";
    height: 27px;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 27px;
    z-index: -1;
}
.pagenation li a {
    transition: 0.3s ease-in-out;
    align-items: center;
    color: #76c761;
    display: flex;
    font-size: 13px;
    font-weight: 500;
    height: 100%;
    justify-content: center;
    line-height: 1;
    width: 100%;
}
.pagenation li.prev a::before {
    transform: rotate(180deg);
}
/* PC用
------------------------------------------------------------*/
@media only screen and (max-width: 1024px) {
    .h_nav {
        display: none;
    }
    /************************/
    .sec04_card {
        width: calc((100% - 80px) / 2);
    }
    /***************************/
    .sec05_grid {
        gap: 20px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    /********************************************************

  	当院について

  ********************************************************/
    .fv_in_title_absolute {
        width: calc(100% - 120px);
    }
    .title_in_ja {
        font-size: clamp(20px, 4.297vw, 44px);
        letter-spacing: 2px;
    }
    .title_in_eng {
        font-size: 18px;
        letter-spacing: 4px;
        margin-top: 12px;
    }
    /************************/
    .ab02_flex {
        gap: 40px;
    }
    .ab02_img {
        width: calc((100% - 40px) / 2);
    }
    .ab02_content {
        max-width: 520px;
        width: calc((100% - 40px) / 2);
    }
    /************************/
    .ab03_grid {
        gap: 40px;
    }
    .ab03_grid > div {
        width: calc((100% - 40px) / 2);
    }
    /************************/
    .ab03_flex_wrap {
        gap: 50px;
    }
    .ab03_flex {
        gap: 24px 40px;
    }
    .ab03_left {
        width: calc((100% - 40px) / 2);
    }
    .ab03_right {
        max-width: 500px;
    }
    /********************************************************

  	医師紹介

  ********************************************************/
    .doc01_flex {
        gap: 32px 48px;
    }
    .doc01_left {
        width: calc((100% - 48px) / 2);
    }
    .doc01_img {
        margin-left: 22px;
        width: calc(100% - 22px);
    }
    .doc01_name_absolute {
        bottom: 18px;
        height: 146px;
        width: 116px;
    }
    .doc01_name_post {
        left: 17px;
        top: 22px;
    }
    .doc01_name_wrap {
        left: 60px;
        top: 22px;
    }
    .doc01_name_kana {
        font-size: 12px;
        left: 104px;
        top: 24px;
    }
    .doc01_right {
        max-width: 520px;
    }
    .doc01_his_flex {
        gap: 36px 40px;
    }
    .doc01_his_left {
        width: calc((100% - 40px) / 2);
    }
    .doc01_his_cell1 {
        max-width: 96px;
        width: 26%;
    }
    .doc01_absolute_deco1 {
        left: -14%;
        top: 46px;
        width: 44%;
    }
    /************************/
    .doc02_box {
        gap: 24px 40px;
    }
    .doc02_name_wrap {
        max-width: 180px;
        width: 20%;
    }
    .doc02_right {
        max-width: 680px;
    }
    /********************************************************

  	内科・循環器内科

  ********************************************************/
    .internal02_flex {
        gap: 40px;
    }
    .internal02_box {
        width: calc((100% - 40px) / 2);
    }
    .internal03_title_text, .internal04_title_text {
        letter-spacing: 3px;
    }
    .internal05_flex {
        gap: 20px;
    }
    .internal05_box {
        width: calc((100% - 40px) / 3);
    }
    .internal05_absolute_deco1 {
        right: -126px;
        top: 52px;
        width: 260px;
    }
    .internal06_absolute_deco1 {
        left: -120px;
        top: -20px;
        width: 230px;
    }
    /********************************************************

  	禁煙外来

  ********************************************************/
    .smoking02_flex {
        gap: 40px;
    }
    .smoking03_schedule_scroll {
        padding: 46px 30px 30px;
    }
    .smoking03_flex {
        gap: 24px;
    }
    .smoking03_card {
        padding: 36px 30px;
        width: calc((100% - 24px) / 2);
    }
    .smoking04_flex {
        gap: 24px;
    }
    .smoking04_card {
        padding: 30px;
        width: calc((100% - 24px) / 2);
    }
    /********************************************************

  	予防接種

  ********************************************************/
    .vaccination01_absolute_deco1 {
        bottom: 120px;
        height: 240px;
        left: -130px;
        width: 260px;
    }
    .vaccination01_absolute_deco2 {
        height: 240px;
        right: -130px;
        top: 500px;
        width: 260px;
    }
    .vaccination01_name_cell {
        padding-left: 30px;
        padding-right: 30px;
    }
    .vaccination01_fee_cell {
        padding-left: 30px;
        padding-right: 30px;
    }
    .vaccination02_card {
        padding: 32px 40px;
    }
    /********************************************************

  	睡眠時無呼吸症候群

  ********************************************************/
    .sleep02_flex {
        gap: 40px;
    }
    .sleep03_box {
        padding: 40px;
    }
    .sleep03_box_osa, .sleep03_box_csa {
        padding-left: 40px;
        padding-right: 40px;
    }
    .sleep03_osa_flex {
        gap: 50px;
    }
    .sleep03_osa_item {
        width: calc((100% - 50px) / 2);
    }
    .sleep04_box {
        padding: 40px;
    }
    .sleep05_flex {
        gap: 40px;
    }
    .sleep06_flex {
        gap: 40px;
    }
    .sleep06_absolute_deco1 {
        right: -120px;
        top: 40px;
        width: 300px;
    }
    .sleep07_absolute_deco1 {
        left: -126px;
        top: 30px;
        width: 280px;
    }
    .sleep07_absolute_deco2 {
        bottom: 20px;
        right: -110px;
        width: 250px;
    }
    /********************************************************

  	呼吸器内科・アレルギー科

  ********************************************************/
    .respiratory01_flex, .respiratory03_flex, .respiratory06_flex {
        gap: 40px;
    }
    .respiratory02_grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .respiratory04_grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .respiratory04_more {
        grid-column: 2;
    }
    .respiratory05_box {
        padding: 60px 40px;
    }
    .respiratory05_compare, .respiratory05_intro_flex, .respiratory05_treatment_flex {
        gap: 40px;
    }
    .respiratory05_compare_box {
        width: calc((100% - 40px) / 2);
    }
    .respiratory05_list_2col, .respiratory05_trigger_flex {
        gap: 40px;
    }
    .respiratory05_trigger_list {
        max-width: 360px;
    }
    .respiratory06_box {
        padding-left: 32px;
        padding-right: 32px;
    }
    .respiratory07_card {
        padding-left: 24px;
        padding-right: 24px;
    }
    .respiratory07_card_flex {
        gap: 20px;
    }
    .respiratory01_absolute_deco1 {
        width: 24%;
    }
    .respiratory04_absolute_deco1 {
        width: 22%;
    }
    .respiratory06_absolute_deco1 {
        right: -104px;
        top: 0;
        width: 24%;
    }
    .respiratory07_absolute_deco1 {
        left: -112px;
        top: -10px;
        width: 24%;
    }
    /********************************************************

  	アクセス

  ********************************************************/
    .access01_map {
        height: 400px;
    }
    .access01_absolute_deco1 {
        right: -108px;
        top: 44px;
        width: 40%;
    }
    .access02_section {
        padding: 80px 0 120px;
    }
    .access02_flex {
        gap: 50px;
    }
    .access02_card_flex {
        gap: 30px;
    }
    .access02_card {
        padding: 36px 32px 44px;
        width: calc((100% - 30px) / 2);
    }
    .access02_absolute_deco1 {
        left: -118px;
        top: 200px;
        width: 40%;
    }
    /********************************************************

  	お知らせ一覧

  ********************************************************/
    .news01_link {
        padding-right: 40px;
    }
    .news01_date {
        margin-right: 50px;
        width: 95px;
    }
}
@media only screen and (max-width: 768px) {
    .header {
        padding: 20px 0;
    }
    .h_flex {
        display: block;
    }
    #logo {
        max-width: 312px;
        width: 100%;
    }
    .h_nav {
        margin-top: 18px;
    }
    .h_nav ul {
        flex-wrap: wrap;
        gap: 12px 22px;
        justify-content: center;
        padding: 0;
        width: 100%;
    }
    .h_nav li {
        font-size: 17px;
    }
    .nav_hov {
        left: 0;
        min-width: 220px;
        padding-top: 12px;
        transform: translate(0, 12px);
    }
    .h_nav li:hover .nav_hov, .h_nav li:focus-within .nav_hov {
        transform: translate(0, 0);
    }
    .hav_hov_bg {
        border-radius: 18px;
        padding: 16px 18px;
    }
    .hav_hov_bg p {
        font-size: 17px;
    }
    .fv_relative {
        padding: 8px 0 0;
    }
    .fv_relative .flexslider, .fv_relative .flex-viewport {
        border-radius: 24px;
    }
    .fv_relative .slides img {
        height: 500px;
    }
    .fv_title_absolute {
        bottom: 42px;
    }
    .fv_absolute_deco1 {
        left: -120px;
        top: 154px;
        width: 250px;
    }
    .fv_absolute_deco2 {
        bottom: 18px;
        right: -84px;
        top: auto;
        width: 190px;
    }
    /******/
    .plr35 {
        padding-left: 20px;
        padding-right: 20px;
    }
    .bg_FBFBF3 {
        border-radius: 24px;
    }
    .eng_15 {
        font-size: 17px;
        letter-spacing: 2.4px;
    }
    .sec01_flex {
        display: block;
    }
    .sec01_left {
        padding-top: 0;
    }
    .sec01_right {
        margin-top: 28px;
    }
    .sec01_more_absolute {
        position: static;
        margin-top: 60px;
    }
    .sec01_more_absolute a {
        margin-left: auto;
    }
    .news a {
        align-items: flex-start;
        display: block;
        padding: 20px 24px 20px 0;
    }
    .n_cell1, .n_cell2 {
        font-size: 17px;
    }
    .n_cell1 {
        display: block;
        margin-bottom: 6px;
    }
    .n_cell2 {
        display: block;
        padding-right: 0;
    }
    .sec02_flex {
        flex-direction: column;
        gap: 34px;
    }
    .sec02_left, .sec02_right {
        flex: none;
        max-width: none;
        width: 100%;
    }
    .sec02_right img {
        border-radius: 72px 20px 20px 20px;
    }
    .sec02_absolute_deco {
        left: -122px;
        top: 228px;
        width: 230px;
    }
    .title_27 {
        letter-spacing: 1px;
        line-height: 1.7;
    }
    .sec03_flex_wrap.mt-10 {
        margin-top: 30px;
    }
    .sec03_flex {
        display: block;
        padding: 34px 0;
    }
    .sec03_flex:first-child {
        padding-top: 34px;
    }
    .sec03_img {
        margin: 0 0 24px;
        width: 100%;
    }
    .sec03_img img {
        border-radius: 24px 52px 24px 24px;
    }
    .sec03_flex:nth-child(even) .sec03_img img {
        border-radius: 52px 24px 24px 24px;
    }
    .sec03_content {
        max-width: 100%;
        width: 100%;
    }
    .sec03_content .title_27 {
        margin-top: 16px;
    }
    .sec03_content > p:last-child {
        font-size: 17px;
        line-height: 2;
    }
    .sec03_fit_bg {
        font-size: 17px;
        padding: 8px 18px 9px;
    }
    .sec04_flex {
        display: block;
        max-width: none;
    }
    .sec04_card {
        margin: 0 auto;
        max-width: 100%;
        width: 100%;
    }
    .sec04_card + .sec04_card {
        margin-top: 24px;
    }
    .sec04_card_relative {
        min-height: 86px;
        padding: 24px 48px 24px 24px;
    }
    .sec04_title {
        font-size: 22px;
        line-height: 1.5;
    }
    .sec04_absolute_arrow {
        right: 22px;
    }
    .more_btn a {
        font-size: 17px;
        width: 220px;
    }
    .title_20 {
        letter-spacing: 1.2px;
        line-height: 1.6;
    }
    .sec05_grid {
        display: block;
        max-width: 100%;
    }
    .sec05_card {
        margin: 0 auto;
        max-width: 100%;
        min-height: 0;
        padding: 30px 18px 30px;
        width: 100%;
    }
    .sec05_card + .sec05_card {
        margin-top: 20px;
    }
    .sec05_icon {
        height: 88px;
        margin-bottom: 16px;
    }
    .sec05_title {
        min-height: 0;
        font-size: 22px;
    }
    .check_list li {
        font-size: 17px;
    }
    .sec05_card .more_btn {
        margin-top: 22px;
    }
    .sec05_card .more_btn a {
        font-size: 17px;
        height: 40px;
        width: 164px;
    }
    .sec05_card .arrow {
        height: 12px;
        width: 12px;
    }
    .sec05_absolute_deco {
        right: -118px;
        top: 84px;
        width: 230px;
    }
    .title_36 {
        letter-spacing: 1px;
        line-height: 1.5;
    }
    .before_dot {
        gap: 12px;
    }
    .sec06_flex {
        display: block;
    }
    .sec06_left {
        margin: 0 auto 32px;
        max-width: 420px;
        width: 100%;
    }
    .sec06_right {
        max-width: none;
    }
    .sec06_right > p {
        font-size: 17px;
        line-height: 2;
    }
    .sec06_right > .green_53B95F {
        font-size: 17px;
        line-height: 1.6;
    }
    .sec06_name_flex {
        align-items: flex-start;
        display: block;
    }
    .sec06_name_ja {
        font-size: 30px;
        letter-spacing: 3px;
    }
    .sec06_name_eng {
        font-size: 17px;
        margin-top: 6px;
        padding-bottom: 0;
    }
    .sec06_more_btn {
        justify-content: flex-start;
        margin-top: 24px;
    }
    .sec06_more_btn a {
        font-size: 17px;
        gap: 14px;
    }
    .sec06_absolute_deco {
        left: -118px;
        top: 176px;
        width: 250px;
    }
    .sec06_scroll img {
        width: 280px;
    }
    .sec07_flex {
        display: block;
    }
    .sec07_flex::after {
        height: 220px;
        right: -116px;
        top: 268px;
        width: 220px;
    }
    .sec07_left {
        max-width: none;
        width: 100%;
    }
    .sec07_logo {
        margin: 0 auto;
        max-width: 312px;
    }
    .sec07_tel {
        font-size: 17px;
        text-align: center;
    }
    .sec07_tel a {
        gap: 8px;
    }
    .tel_large {
        font-size: 36px;
    }
    .sec07_access_flex {
        display: block;
        margin-top: 18px;
    }
    .sec07_access_left {
        font-size: 17px;
        justify-content: center;
        max-width: none;
        width: 100%;
    }
    .sec07_access_map {
        margin-top: 14px;
        text-align: center;
    }
    .sec07_access_map a {
        font-size: 17px;
        padding: 10px 18px 11px;
    }
    .sec07_table {
        margin-top: 28px;
        overflow-x: auto;
        padding-bottom: 6px;
    }
    .sec07_table table {
        min-width: 620px;
    }
    .indent_list {
        margin-top: 18px;
    }
    .indent_list li {
        font-size: 17px;
        line-height: 1.9;
    }
    .sec07_map {
        height: 360px;
        margin-top: 32px;
        max-width: none;
        width: 100%;
    }
    .footer {
        padding: 44px 0 28px;
    }
    .footer .container1600 {
        width: calc(100% - 40px);
    }
    .footer::before {
        background: rgba(68, 68, 68, 0.62);
    }
    .f_flex {
        display: block;
    }
    .f_left {
        max-width: none;
        padding-top: 0;
    }
    .f_left p {
        font-size: 17px;
        line-height: 1.9;
    }
    .f_logo {
        margin: 0 auto;
        max-width: 320px;
    }
    .f_nav {
        display: block;
        margin-top: 30px;
        max-width: none;
        padding-top: 0;
    }
    .f_nav ul + ul {
        margin-top: 18px;
    }
    .f_nav li > a, .f_nav li > span {
        font-size: 17px;
    }
    .f_sub {
        margin-top: 12px;
    }
    .f_sub p {
        font-size: 17px;
        line-height: 1.8;
    }
    .copyright {
        font-size: 13px;
        line-height: 1.8;
        margin-top: 28px;
        text-align: left;
    }
    /********************************************************

  	当院について

  ********************************************************/
    .fv_in_relative {
        padding: 8px 0 0;
    }
    .main_size img {
        min-height: 320px;
        object-fit: cover;
    }
    .fv_in_title_absolute {
        width: calc(100% - 40px);
    }
    .title_in_ja {
        font-size: clamp(20px, 8.718vw, 34px);
        letter-spacing: 1.4px;
        line-height: 1.5;
    }
    .title_in_eng {
        font-size: 17px;
        letter-spacing: 3px;
        margin-top: 10px;
    }
    /************************/
    .ab02_flex_wrap {
        margin-top: 34px;
    }
    .ab02_flex {
        display: block;
        padding: 34px 0;
    }
    .ab02_img {
        margin-bottom: 24px;
        max-width: none;
        width: 100%;
    }
    .ab02_img img {
        border-radius: 24px 52px 24px 24px;
    }
    .ab02_flex:nth-child(even) .ab02_img img {
        border-radius: 52px 24px 24px 24px;
    }
    .ab02_content {
        max-width: none;
        width: 100%;
    }
    .ab02_num_flex {
        gap: 8px 14px;
    }
    .title_af_bb60 {
        padding-bottom: 18px;
    }
    /************************/
    .before_dot_title {
        gap: 10px;
    }
    .before_dot_title.dot_big_style:before {
        margin-top: 15px;
    }
    .ab03_grid {
        display: block;
        gap: 20px;
    }
    .ab03_grid > div {
        width: 100%;
    }
    .ab03_grid > div + div {
        margin-top: 30px;
    }
    .ab03_grid.ab03_sp_grid {
        display: flex;
    }
    .ab03_grid.ab03_sp_grid > div {
        width: calc((100% - 20px) / 2);
    }
    .ab03_grid.ab03_sp_grid > div + div {
        margin-top: 0;
    }
    /************************/
    .ab03_flex_wrap {
        gap: 34px;
    }
    .ab03_flex {
        display: block;
    }
    .ab03_left {
        margin: 0 auto 24px;
        width: 100%;
    }
    .ab03_right {
        max-width: none;
    }
    /********************************************************

  	医師紹介

  ********************************************************/
    .padding55_55 {
        padding: 30px;
    }
    .doc01_flex {
        display: block;
    }
    .doc01_left {
        margin: 0 auto 52px;
        max-width: 457px;
        width: 100%;
    }
    .doc01_img {
        margin-left: 27px;
        max-width: 430px;
        width: calc(100% - 27px);
    }
    .doc01_name_absolute {
        bottom: 16px;
        height: 146px;
        width: 116px;
    }
    .doc01_name_post {
        left: 17px;
        top: 22px;
    }
    .doc01_name_wrap {
        left: 60px;
        top: 20px;
    }
    .doc01_name_ja {
        letter-spacing: 1.6px;
    }
    .doc01_name_kana {
        font-size: 12px;
        left: 104px;
        top: 24px;
    }
    .doc01_right {
        max-width: none;
        padding-top: 0;
    }
    .doc01_his_flex {
        display: block;
    }
    .doc01_his_left {
        width: 100%;
    }
    .doc01_his_left + .doc01_his_left {
        margin-top: 34px;
    }
    .doc01_his_table, .doc01_his_list {
        margin-top: 20px;
    }
    .doc01_his_table {
        gap: 15px;
    }
    .doc01_his_table li {
        display: block;
    }
    .doc01_his_cell1 {
        max-width: none;
        width: 100%;
    }
    .doc01_his_cell2 {
        margin-top: 4px;
    }
    .doc01_absolute_deco1 {
        left: -18%;
        top: 20px;
        width: 64%;
    }
    /************************/
    .doc02_flex {
        display: block;
    }
    .doc02_box {
        display: block;
        width: 100%;
        padding: 30px;
    }
    .doc02_box + .doc02_box {
        margin-top: 54px;
    }
    .doc02_name_wrap {
        max-width: none;
        padding-top: 0;
        width: 100%;
    }
    .doc02_name_flex {
        flex-wrap: wrap;
        gap: 8px 14px;
    }
    .doc02_name {
        letter-spacing: 0.08em;
    }
    .doc02_right {
        margin-top: 24px;
        max-width: none;
    }
    /********************************************************

  	内科・循環器内科

  ********************************************************/
    .internal01_text_wrap {
        line-height: 2.2;
    }
    .internal02_flex {
        display: block;
    }
    .internal02_box {
        padding: 13px 13px 24px;
        width: 100%;
    }
    .internal02_box + .internal02_box {
        margin-top: 24px;
    }
    .internal02_title {
        letter-spacing: 1.6px;
    }
    .internal02_note {
        padding: 16px 18px;
    }
    .internal03_title_wrap, .internal04_title_wrap {
        padding-bottom: 14px;
    }
    .internal03_title_flex, .internal04_title_flex {
        gap: 12px;
        padding-left: 0;
    }
    .internal03_icon, .internal04_icon {
        width: 32px;
    }
    .internal03_title_text, .internal04_title_text {
        letter-spacing: 2px;
    }
    .internal04_list li::before {
        top: 10px;
    }
    .internal05_flex {
        display: block;
    }
    .internal05_box {
        width: 100%;
    }
    .internal05_box + .internal05_box {
        margin-top: 15px;
    }
    .internal05_absolute_deco1 {
        right: -110px;
        top: 94px;
        width: 220px;
    }
    .internal06_text_wrap {
        line-height: 2.2;
    }
    .internal06_absolute_deco1 {
        left: -98px;
        top: -10px;
        width: 180px;
    }
    /********************************************************

  	禁煙外来

  ********************************************************/
    .smoking01_text_wrap, .smoking03_text_wrap, .smoking04_text_wrap, .smoking05_text {
        line-height: 2.2;
    }
    .smoking02_flex {
        display: block;
    }
    .smoking02_left, .smoking02_right {
        max-width: none;
        width: 100%;
    }
    .smoking02_right {
        margin-top: 30px;
    }
    .smoking02_right img {
        border-radius: 52px 20px 20px 20px;
        width: 100%;
    }
    .smoking03_title, .smoking05_title {
        letter-spacing: 1px;
        line-height: 1.6;
    }
    .smoking03_condition_box {
        padding: 26px 18px 28px;
    }
    .smoking03_condition_list li {
        padding-left: 20px;
    }
    .smoking03_condition_list li::before {
        top: 15px;
    }
    .smoking03_note, .smoking05_note {
        text-align: left;
    }
    .smoking03_schedule_scroll {
        overflow-x: auto;
        padding: 34px 20px 24px;
    }
    .smoking03_schedule_inner {
        width: 100%;
        min-width: 860px;
    }
    .smoking03_flex {
        display: block;
    }
    .smoking03_card {
        padding: 30px 20px;
        width: 100%;
    }
    .smoking03_card + .smoking03_card {
        margin-top: 20px;
    }
    .smoking03_card_title {
        padding-left: 0;
    }
    .smoking04_flex {
        display: block;
    }
    .smoking04_card {
        padding: 28px 20px 30px;
        width: 100%;
    }
    .smoking04_card + .smoking04_card {
        margin-top: 20px;
    }
    .smoking04_card_flex {
        display: block;
    }
    .smoking04_icon {
        margin: 0 auto 20px;
    }
    .smoking04_card_text {
        max-width: none;
    }
    .smoking05_table_wrap {
        overflow-x: auto;
        padding-bottom: 6px;
    }
    .smoking05_table {
        min-width: 760px;
    }
    .faq_q, .faq_a_inner {
        gap: 14px;
        min-height: 0;
    }
    .faq_wrap {
        width: 100%;
    }
    .faq_q {
        align-items: flex-start;
        padding: 18px 0 16px;
    }
    .faq_a {
        padding: 0 0 18px;
    }
    .faq_a_inner {
        align-items: flex-start;
    }
    .faq_q_only .faq_q {
        padding: 18px 0 16px;
    }
    .faq_q_text {
        padding-top: 6px;
    }
    /********************************************************

  	予防接種

  ********************************************************/
    .vaccination01_text_wrap {
        line-height: 2.2;
    }
    .vaccination01_absolute_deco1 {
        bottom: 240px;
        height: 180px;
        left: -100px;
        width: 200px;
    }
    .vaccination01_absolute_deco2 {
        height: 180px;
        right: -98px;
        top: 380px;
        width: 200px;
    }
    .vaccination01_table_title {
        padding-left: 0;
        padding-right: 0;
    }
    .vaccination01_table_scroll {
        overflow-x: auto;
        padding-bottom: 6px;
    }
    .vaccination01_table_main {
        min-width: 760px;
    }
    .vaccination01_head, .vaccination01_name_cell, .vaccination01_fee_cell {
        padding-left: 18px;
        padding-right: 18px;
    }
    .vaccination01_fee_sub br {
        display: none;
    }
    .vaccination02_card {
        padding: 28px 20px;
    }
    .vaccination02_card_title {
        padding-left: 0;
        padding-right: 0;
    }
    .vaccination02_card_text_wrap {
        padding: 0;
    }
    /********************************************************

  	睡眠時無呼吸症候群

  ********************************************************/
    .sleep01_text_wrap, .sleep02_text_wrap, .sleep03_text, .sleep03_text_wrap, .sleep04_text, .sleep05_text_wrap, .sleep05_item_text, .sleep06_text_wrap {
        line-height: 2.2;
    }
    .sleep02_flex {
        display: block;
    }
    .sleep02_content, .sleep02_img {
        max-width: none;
        width: 100%;
    }
    .sleep02_img {
        margin-top: 24px;
    }
    .sleep02_img img {
        border-radius: 40px 10px 10px 10px;
    }
    .sleep02_flex_reverse .sleep02_img {
        margin-top: 0;
        margin-bottom: 24px;
    }
    .sleep02_sub_title, .sleep03_title {
        letter-spacing: 1.6px;
        padding-bottom: 14px;
    }
    .sleep03_box {
        padding: 28px 20px;
    }
    .sleep03_box_osa, .sleep03_box_csa {
        padding-left: 20px;
        padding-right: 20px;
    }
    .sleep03_text_wrap_osa {
        padding-left: 0;
    }
    .sleep03_osa_flex {
        margin-top: 34px;
        gap: 10px;
    }
    .sleep03_osa_item {
        width: 50%;
    }
    .sleep03_badge {
        font-size: 17px;
        letter-spacing: 1.2px;
        min-height: 38px;
        padding-left: 24px;
        padding-right: 24px;
    }
    .sleep03_badge_fill {
        min-width: 168px;
    }
    .sleep03_normal_img {
        margin-top: 24px;
        max-width: 120px;
    }
    .sleep03_abnormal_img {
        margin-top: 24px;
        max-width: 250px;
    }
    .sleep03_normal_label {
        font-size: 17px;
        left: 12px;
        top: 28px;
    }
    .sleep03_air_flex {
        gap: 8px;
        justify-content: center;
        margin-top: 24px;
    }
    .sleep03_air_arrow {
        width: 34px;
    }
    .sleep04_box {
        padding: 28px 20px;
    }
    .sleep04_flex {
        display: block;
    }
    .sleep04_list {
        width: 100%;
    }
    .sleep04_list + .sleep04_list {
        margin-top: 24px;
    }
    .sleep05_flex {
        display: block;
        padding: 34px 0;
    }
    .sleep05_img, .sleep05_content {
        max-width: none;
        width: 100%;
    }
    .sleep05_img {
        margin-bottom: 24px;
    }
    .sleep05_img img {
        border-radius: 40px 10px 10px 10px;
    }
    .sleep06_flex {
        display: block;
    }
    .sleep06_left, .sleep06_right {
        max-width: none;
        width: 100%;
    }
    .sleep06_right {
        margin-top: 30px;
    }
    .sleep06_right img {
        border-radius: 40px 10px 10px 10px;
    }
    .sleep06_absolute_deco1 {
        right: -92px;
        top: 110px;
        width: 200px;
    }
    .sleep07_head {
        overflow-x: auto;
        padding-bottom: 6px;
    }
    .sleep07_head_item {
        flex: none;
        min-width: 170px;
    }
    .sleep07_head_item p {
        letter-spacing: 2px;
    }
    .sleep07_row {
        min-height: 100px;
    }
    .sleep07_no {
        flex: 0 0 70px;
        width: 70px;
    }
    .sleep07_no::after {
        bottom: -38px;
        top: 43px;
    }
    .sleep07_content {
        padding: 18px 16px;
    }
    .sleep07_title {
        letter-spacing: 1px;
        text-align: left;
    }
    .sleep07_sub {
        text-align: left;
    }
    .sleep07_absolute_deco1 {
        left: -96px;
        top: 64px;
        width: 190px;
    }
    .sleep07_absolute_deco2 {
        bottom: 30px;
        right: -86px;
        width: 170px;
    }
    /********************************************************

  	呼吸器内科・アレルギー科

  ********************************************************/
    .respiratory01_text_wrap, .respiratory03_text_wrap, .respiratory04_text_wrap, .respiratory05_text_wrap, .respiratory05_lead, .respiratory05_conclusion, .respiratory06_text_wrap, .respiratory06_box_text, .respiratory07_content {
        line-height: 2.2;
    }
    .respiratory01_flex, .respiratory03_flex, .respiratory06_flex, .respiratory07_flex {
        display: block;
    }
    .respiratory01_left, .respiratory01_right, .respiratory03_text_wrap, .respiratory03_img, .respiratory06_left, .respiratory06_right {
        max-width: none;
        width: 100%;
    }
    .respiratory01_right, .respiratory06_left {
        margin-top: 24px;
    }
    .respiratory02_grid {
        grid-template-columns: repeat(1, minmax(0, 1fr));
    }
    .respiratory02_grid li {
        padding-left: 44px;
    }
    .respiratory03_flex_reverse .respiratory03_img, .respiratory03_flex_reverse .respiratory03_text_wrap {
        order: initial;
    }
    .respiratory03_img {
        margin-top: 24px;
    }
    .respiratory03_flex_reverse .respiratory03_img {
        margin-bottom: 24px;
        margin-top: 0;
    }
    .respiratory04_grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .respiratory04_more {
        grid-column: auto;
        justify-self: end;
    }
    .respiratory05_box {
        padding: 30px 20px;
    }
    .respiratory05_box_title {
        letter-spacing: 1.6px;
        padding-left: 0;
        padding-right: 0;
    }
    .respiratory05_compare, .respiratory05_list_2col, .respiratory05_trigger_flex, .respiratory05_treatment_flex, .respiratory05_intro_flex {
        display: block;
    }
    .respiratory05_compare_box {
        min-height: 0;
        width: 100%;
    }
    .respiratory05_compare_box + .respiratory05_compare_box {
        margin-top: 40px;
    }
    .respiratory05_compare_lung {
        height: 132px;
    }
    .respiratory05_copd_panel {
        min-height: 0;
        padding: 24px 20px 20px;
    }
    .respiratory05_copd_panel_normal::before, .respiratory05_copd_panel_alert::before {
        border-bottom-width: 18px;
        border-left-width: 18px;
        border-right-width: 18px;
        top: -18px;
    }
    .respiratory05_list_2col > ul {
        width: 100%;
    }
    .respiratory05_list_2col > ul + ul {
        margin-top: 5px;
    }
    .respiratory05_trigger_icons {
        margin-left: auto;
        margin-right: auto;
        max-width: 360px;
    }
    .respiratory05_trigger_row {
        flex-wrap: wrap;
        gap: 12px;
        justify-content: center;
    }
    .respiratory05_trigger_row_sub {
        margin-top: 12px;
    }
    .respiratory05_trigger_list, .respiratory05_treatment_list, .respiratory05_intro_text {
        margin-top: 24px;
        max-width: none;
        width: 100%;
    }
    .respiratory05_treatment_img, .respiratory05_intro_img {
        margin-left: auto;
        margin-right: auto;
        margin-top: 24px;
        width: 100%;
    }
    .respiratory05_treatment_img {
        max-width: 306px;
    }
    .respiratory05_intro_img {
        max-width: 206px;
    }
    .respiratory06_left {
        margin: 0 auto 24px;
        max-width: 513px;
    }
    .respiratory06_box {
        padding: 30px 20px;
    }
    .respiratory06_box_title {
        letter-spacing: 1.6px;
        padding-left: 0;
    }
    .respiratory07_card {
        padding: 28px 20px;
        width: 100%;
    }
    .respiratory07_card + .respiratory07_card {
        margin-top: 20px;
    }
    .respiratory07_card_flex {
        display: block;
    }
    .respiratory07_icon {
        margin: 0 auto 20px;
        max-width: 150px;
        width: 100%;
    }
    .respiratory07_content {
        max-width: none;
    }
    .respiratory01_absolute_deco1 {
        width: 56%;
    }
    .respiratory04_absolute_deco1 {
        width: 50%;
    }
    .respiratory06_absolute_deco1 {
        right: -118px;
        top: 18px;
        width: 58%;
    }
    .respiratory07_absolute_deco1 {
        left: -110px;
        top: -6px;
        width: 60%;
    }
    /********************************************************

  	アクセス

  ********************************************************/
    .access01_map {
        border-radius: 24px;
        height: 300px;
    }
    .access01_absolute_deco1 {
        right: -116px;
        top: 64px;
        width: 58%;
    }
    .access02_section {
        padding: 60px 0 100px;
    }
    .access02_flex {
        display: block;
    }
    .access02_photo {
        margin: 0 auto 30px;
        max-width: 641px;
        width: 100%;
    }
    .access02_content {
        max-width: none;
    }
    .access02_address {
        line-height: 1.9;
    }
    .access02_pin {
        margin-top: 8px;
    }
    .access02_info_row {
        gap: 14px;
    }
    .access02_card_flex {
        display: block;
    }
    .access02_card {
        padding: 30px 20px 34px;
        width: 100%;
    }
    .access02_card + .access02_card {
        margin-top: 20px;
    }
    .access02_card_title {
        letter-spacing: 1.4px;
        padding-bottom: 14px;
    }
    .access02_absolute_deco1 {
        left: -118px;
        top: 118px;
        width: 58%;
    }
    /********************************************************

  	お知らせ一覧

  ********************************************************/
    .news01_link {
        display: block;
        min-height: 0;
        padding: 20px 20px 20px 0;
    }
    .news01_date {
        font-size: 17px;
        margin-right: 0;
        width: auto;
    }
    .news01_title {
        display: block;
        font-size: 17px;
        margin-top: 8px;
        padding-right: 24px;
    }
    .news01_arrow {
        margin-left: 0;
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
    }
    .news01_link:hover .news01_arrow {
        transform: translateY(-50%) translateX(4px);
    }
    .pagenation ul {
        justify-content: center;
    }
    .pagenation li {
        height: 36px;
        width: 50px;
    }
    .pagenation li.active {
        font-size: 17px;
    }
    .pagenation li.active::before {
        height: 32px;
        width: 32px;
    }
    .pagenation li a {
        font-size: 17px;
    }
}