@charset "UTF-8";
/* Scss Document */
.flex_30 {
    width: 30%;
}
.flex_31 {
    width: 31%;
}
.flex_32 {
    width: 32%;
}
.flex_33 {
    width: 33%;
}
.flex_34 {
    width: 34%;
}
.flex_35 {
    width: 35%;
}
.flex_36 {
    width: 36%;
}
.flex_37 {
    width: 37%;
}
.flex_38 {
    width: 38%;
}
.flex_39 {
    width: 39%;
}
.flex_40 {
    width: 40%;
}
.flex_41 {
    width: 41%;
}
.flex_42 {
    width: 42%;
}
.flex_43 {
    width: 43%;
}
.flex_44 {
    width: 44%;
}
.flex_45 {
    width: 45%;
}
.flex_46 {
    width: 46%;
}
.flex_47 {
    width: 47%;
}
.flex_48 {
    width: 48%;
}
.flex_49 {
    width: 49%;
}
.flex_50 {
    width: 50%;
}
.flex_51 {
    width: 51%;
}
.flex_52 {
    width: 52%;
}
.flex_53 {
    width: 53%;
}
.flex_54 {
    width: 54%;
}
.flex_55 {
    width: 55%;
}
.flex_56 {
    width: 56%;
}
.flex_57 {
    width: 57%;
}
.flex_58 {
    width: 58%;
}
.flex_59 {
    width: 59%;
}
.flex_60 {
    width: 60%;
}
.flex_61 {
    width: 61%;
}
.flex_62 {
    width: 62%;
}
.flex_63 {
    width: 63%;
}
.flex_64 {
    width: 64%;
}
.flex_65 {
    width: 65%;
}
.flex_66 {
    width: 66%;
}
.flex_67 {
    width: 67%;
}
.flex_68 {
    width: 68%;
}
.flex_69 {
    width: 69%;
}
.flex_70 {
    width: 70%;
}
.padding100 {
    padding-top: 100px;
    padding-bottom: 100px;
}
.padding110 {
    padding-top: 110px;
    padding-bottom: 110px;
}
.padding120 {
    padding-top: 120px;
    padding-bottom: 120px;
}
.padding130 {
    padding-top: 130px;
    padding-bottom: 130px;
}
.padding140 {
    padding-top: 140px;
    padding-bottom: 140px;
}
.padding150 {
    padding-top: 150px;
    padding-bottom: 150px;
}
.padding160 {
    padding-top: 160px;
    padding-bottom: 160px;
}
.padding170 {
    padding-top: 170px;
    padding-bottom: 170px;
}
.padding180 {
    padding-top: 180px;
    padding-bottom: 180px;
}
.padding190 {
    padding-top: 190px;
    padding-bottom: 190px;
}
.padding200 {
    padding-top: 200px;
    padding-bottom: 200px;
}
.padding210 {
    padding-top: 210px;
    padding-bottom: 210px;
}
.padding220 {
    padding-top: 220px;
    padding-bottom: 220px;
}
.padding230 {
    padding-top: 230px;
    padding-bottom: 230px;
}
.padding240 {
    padding-top: 240px;
    padding-bottom: 240px;
}
.padding250 {
    padding-top: 250px;
    padding-bottom: 250px;
}
.padding260 {
    padding-top: 260px;
    padding-bottom: 260px;
}
.padding270 {
    padding-top: 270px;
    padding-bottom: 270px;
}
.padding280 {
    padding-top: 280px;
    padding-bottom: 280px;
}
.padding290 {
    padding-top: 290px;
    padding-bottom: 290px;
}
.padding300 {
    padding-top: 300px;
    padding-bottom: 300px;
}
.margin100 {
    margin-top: 100px;
    margin-bottom: 100px;
}
.margin110 {
    margin-top: 110px;
    margin-bottom: 110px;
}
.margin120 {
    margin-top: 120px;
    margin-bottom: 120px;
}
.margin130 {
    margin-top: 130px;
    margin-bottom: 130px;
}
.margin140 {
    margin-top: 140px;
    margin-bottom: 140px;
}
.margin150 {
    margin-top: 150px;
    margin-bottom: 150px;
}
.margin160 {
    margin-top: 160px;
    margin-bottom: 160px;
}
.margin170 {
    margin-top: 170px;
    margin-bottom: 170px;
}
.margin180 {
    margin-top: 180px;
    margin-bottom: 180px;
}
.margin190 {
    margin-top: 190px;
    margin-bottom: 190px;
}
.margin200 {
    margin-top: 200px;
    margin-bottom: 200px;
}
.margin210 {
    margin-top: 210px;
    margin-bottom: 210px;
}
.margin220 {
    margin-top: 220px;
    margin-bottom: 220px;
}
.margin230 {
    margin-top: 230px;
    margin-bottom: 230px;
}
.margin240 {
    margin-top: 240px;
    margin-bottom: 240px;
}
.margin250 {
    margin-top: 250px;
    margin-bottom: 250px;
}
.margin260 {
    margin-top: 260px;
    margin-bottom: 260px;
}
.margin270 {
    margin-top: 270px;
    margin-bottom: 270px;
}
.margin280 {
    margin-top: 280px;
    margin-bottom: 280px;
}
.margin290 {
    margin-top: 290px;
    margin-bottom: 290px;
}
.margin300 {
    margin-top: 300px;
    margin-bottom: 300px;
}
.pt-110 {
    padding-top: 110px;
}
.pt-120 {
    padding-top: 120px;
}
.pt-130 {
    padding-top: 130px;
}
.pt-140 {
    padding-top: 140px;
}
.pt-150 {
    padding-top: 150px;
}
.pt-160 {
    padding-top: 160px;
}
.pt-170 {
    padding-top: 170px;
}
.pt-180 {
    padding-top: 180px;
}
.pt-190 {
    padding-top: 190px;
}
.pt-200 {
    padding-top: 200px;
}
.pt-210 {
    padding-top: 210px;
}
.pt-220 {
    padding-top: 220px;
}
.pt-230 {
    padding-top: 230px;
}
.pt-240 {
    padding-top: 240px;
}
.pt-250 {
    padding-top: 250px;
}
.pt-260 {
    padding-top: 260px;
}
.pt-270 {
    padding-top: 270px;
}
.pt-280 {
    padding-top: 280px;
}
.pt-290 {
    padding-top: 290px;
}
.pt-300 {
    padding-top: 300px;
}
.pb-110 {
    padding-bottom: 110px;
}
.pb-120 {
    padding-bottom: 120px;
}
.pb-130 {
    padding-bottom: 130px;
}
.pb-140 {
    padding-bottom: 140px;
}
.pb-150 {
    padding-bottom: 150px;
}
.pb-160 {
    padding-bottom: 160px;
}
.pb-170 {
    padding-bottom: 170px;
}
.pb-180 {
    padding-bottom: 180px;
}
.pb-190 {
    padding-bottom: 190px;
}
.pb-200 {
    padding-bottom: 200px;
}
.pb-210 {
    padding-bottom: 210px;
}
.pb-220 {
    padding-bottom: 220px;
}
.pb-230 {
    padding-bottom: 230px;
}
.pb-240 {
    padding-bottom: 240px;
}
.pb-250 {
    padding-bottom: 250px;
}
.pb-260 {
    padding-bottom: 260px;
}
.pb-270 {
    padding-bottom: 270px;
}
.pb-280 {
    padding-bottom: 280px;
}
.pb-290 {
    padding-bottom: 290px;
}
.pb-300 {
    padding-bottom: 300px;
}
.mt-110 {
    margin-top: 110px;
}
.mt-120 {
    margin-top: 120px;
}
.mt-130 {
    margin-top: 130px;
}
.mt-140 {
    margin-top: 140px;
}
.mt-150 {
    margin-top: 150px;
}
.mt-160 {
    margin-top: 160px;
}
.mt-170 {
    margin-top: 170px;
}
.mt-180 {
    margin-top: 180px;
}
.mt-190 {
    margin-top: 190px;
}
.mt-200 {
    margin-top: 200px;
}
.mt-210 {
    margin-top: 210px;
}
.mt-220 {
    margin-top: 220px;
}
.mt-230 {
    margin-top: 230px;
}
.mt-240 {
    margin-top: 240px;
}
.mt-250 {
    margin-top: 250px;
}
.mt-260 {
    margin-top: 260px;
}
.mt-270 {
    margin-top: 270px;
}
.mt-280 {
    margin-top: 280px;
}
.mt-290 {
    margin-top: 290px;
}
.mt-300 {
    margin-top: 300px;
}
.mb-110 {
    margin-bottom: 110px;
}
.mb-120 {
    margin-bottom: 120px;
}
.mb-130 {
    margin-bottom: 130px;
}
.mb-140 {
    margin-bottom: 140px;
}
.mb-150 {
    margin-bottom: 150px;
}
.mb-160 {
    margin-bottom: 160px;
}
.mb-170 {
    margin-bottom: 170px;
}
.mb-180 {
    margin-bottom: 180px;
}
.mb-190 {
    margin-bottom: 190px;
}
.mb-200 {
    margin-bottom: 200px;
}
.mb-210 {
    margin-bottom: 210px;
}
.mb-220 {
    margin-bottom: 220px;
}
.mb-230 {
    margin-bottom: 230px;
}
.mb-240 {
    margin-bottom: 240px;
}
.mb-250 {
    margin-bottom: 250px;
}
.mb-260 {
    margin-bottom: 260px;
}
.mb-270 {
    margin-bottom: 270px;
}
.mb-280 {
    margin-bottom: 280px;
}
.mb-290 {
    margin-bottom: 290px;
}
.mb-300 {
    margin-bottom: 300px;
}
* {
    text-decoration: none !important;
}
.lineMove {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: 100;
    pointer-events: none;
    overflow: hidden;
}
.lineMove .line {
    position: absolute;
    background-color: #FFF;
    width: 20%;
    animation: lineMove 6s ease 0s infinite;
    clip-path: inset(0 100% 0 0);
}
.line01 {
    top: 20vh;
    left: 3%;
    height: 10px;
}
.line02 {
    top: 30vh;
    left: 50%;
    height: 10px;
}
.line03 {
    top: 53vh;
    left: 13%;
    height: 30px;
}
.line04 {
    top: 50vh;
    left: 60%;
    height: 25px;
}
.line05 {
    top: 80vh;
    left: 40%;
    height: 10px;
}
@keyframes lineMove {
    0% {
        transform: translateX(0);
        clip-path: inset(0 100% 0 0);
    }
    90% {
        transform: translateX(0);
        clip-path: inset(0 100% 0 0);
    }
    93% {
        transform: translateX(3%);
        clip-path: inset(0 90% 0 0);
    }
    94% {
        transform: translateX(3%);
        clip-path: inset(0 0 0 0);
    }
    100% {
        transform: translateX(100%);
        clip-path: inset(0 0 0 100%);
    }
}
/************/
.top_fadein {
    animation: fadeIn_ani 2s;
}
@keyframes fadeIn_ani {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
.logo {
    position: absolute;
    top: 40px;
    left: 40px;
    width: 191px;
    z-index: 1000;
}
.logo img {
    width: 100%;
    height: auto;
}
.cy_header_btn {
    max-width: 230px;
    width: 100%;
    position: absolute;
    top: 40px;
    right: 160px;
    z-index: 1000;
    border-radius: 50px;
    overflow: hidden;
}
.cy_header_btn:before {
    content: "";
    background-color: #1b1b1b;
    position: absolute;
    z-index: 2;
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    top: 2px;
    left: 2px;
    border-radius: 100px;
    transition: 0.5s ease;
    opacity: 0;
}
.cy_header_btn:after {
    content: "";
    background: linear-gradient(90deg, #5a0e92, #4b34c2 20%, #3551cf 40%, #0b6bdd 60%, #0690d9 80%, #08b1d0 100%);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}
.cy_header_btn:hover:before {
    opacity: 1;
}
.cy_header_btn a {
    color: #fff;
    display: block;
    width: 100%;
    font-size: 16px;
    padding: 14px 10px;
    text-align: center;
    position: relative;
    z-index: 500;
}
/* ファーストビュー */
#mv {
    position: relative;
    background: url("../images/main_bg.webp") 50% 0/cover no-repeat;
}
.movie {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
    mix-blend-mode: screen;
}
.mv_copy {
    position: absolute;
    left: 8vw;
    top: 17vw;
    z-index: 10;
    max-width: 938px;
    width: 80%;
}
.mv_copy img {
    width: 100%;
}
.catch_under {
    margin-top: 30px;
}
.eng_style {
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 2px #ffffff;
    text-stroke: 2px #ffffff;
}
/* 流れる文字 */
/* ---------------------------- */
.loop_wrapper {
    position: absolute;
    bottom: 0;
    font-size: 250px;
    display: flex;
    overflow: hidden;
    text-align: center;
    width: 100%;
}
.loop_wrapper_text {
    display: inline-block;
    white-space: nowrap;
    animation: scrollTxt 40s linear infinite;
    margin-right: 40px;
    line-height: 1.1;
}
@keyframes scrollTxt {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-100%);
    }
}
/* フェード画像 */
.flexslider {
    width: 100% !important;
    overflow: hidden;
    height: clamp(600px, 50vw, 970px) !important;
}
/************************/
.line-height12 {
    line-height: 1.2;
}
.line-height16 {
    line-height: 1.6;
}
.title_30 {
    font-size: 30px;
    letter-spacing: 0.1em;
}
.title_35 {
    font-size: 35px;
}
.title_40 {
    font-size: 40px;
}
.title_45 {
    font-size: 45px;
    letter-spacing: 0.1em;
}
.title_50 {
    font-size: 50px;
}
.title_110 {
    font-size: 110px;
}
.en_title_120 {
    font-size: 120px;
}
.center {
    text-align: center;
}
.bold {
    font-weight: bold;
}
.indent_p {
    text-indent: -1.1em;
    padding-left: 1.1em;
}
.title_bb {
    position: relative;
    border-bottom: 1px solid #707070;
}
.title_bb::before {
    content: "";
    display: block;
    border-bottom: 1px solid #2f7dd4;
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 130px;
    z-index: 10;
}
.top_bg {
    /*background: url(../images/top_bg.webp);*/
    background-color: #1b1b1b;
    background-repeat: no-repeat;
    background-size: cover;
}
.sp_none {
    display: none;
}
.sec01 .pc_title {
    max-width: 1212px;
    margin: 0 auto 100px;
}
.sec01 .pc_title img {
    width: 100%;
}
.sec01 .pc_subtitle {
    max-width: 1110px;
    margin: 0 auto 100px;
}
.sec01 .pc_subtitle img {
    width: 100%;
}
.sec02 {
    border-bottom: 1px solid #fff;
}
.sec02 li {
    display: flex;
    justify-content: space-between;
    padding: 80px 0;
    border-top: 1px solid #fff;
}
.sec02_left {
    width: 60%;
}
.sec02_right {
    width: 33%;
    max-width: 480px;
}
.sec03 {
    display: flex;
}
.sec03 li {
    width: 50%;
    border: 1px solid #fff;
    padding: 80px 30px;
    text-align: center;
}
.clinic_table {
    width: 100%;
    font-size: 20px;
}
.clinic_table tr:first-of-type {
    border-top: 1px solid #fff;
}
.clinic_table tr th {
    width: 20%;
    min-width: 8em;
    padding: 32px 10px 32px 25px;
    border-bottom: 1px solid #fff;
    vertical-align: baseline;
}
.clinic_table tr td {
    padding: 32px 10px 32px 25px;
    border-bottom: 1px solid #fff;
}
.clinic_table tr td .map {
    max-width: 700px;
    height: 400px;
    margin-bottom: 10px;
}
.clinic_table tr td .map iframe {
    width: 100%;
    height: inherit;
}
.sec05_bg {
    background: url(../images/top8.webp);
    background-repeat: no-repeat;
    background-size: cover;
    padding: 170px 0;
}
.sec05_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.contact_btn {
    width: 400px;
}
.contact_btn a {
    position: relative;
    width: 100%;
    display: block;
    text-align: center;
    padding: 33px 20px;
    border: 1px solid #fff;
    border-radius: 50px;
    color: #fff;
    font-size: 20px;
    transition: 0.3s ease;
}
.contact_btn a::before {
    content: "";
    background: url(../images/arrow_w.svg) left 0/100% 100% no-repeat;
    width: 10px;
    height: 16px;
    position: absolute;
    right: 8%;
    top: 50%;
    transform: translateY(-50%);
    transition: 0.3s ease;
}
.contact_btn a:hover {
    background-color: #fff;
    color: #000;
}
.contact_btn a:hover::before {
    background: url(../images/arrow_b.svg) left 0/100% 100% no-repeat;
}
.footer_link {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 1.5vw;
    row-gap: 1.5vw;
}
.footer_link img {
    width: 100%;
}
.copy {
    background-color: #000;
    text-align: center;
    font-size: 15px;
    letter-spacing: 0.12em;
    padding: 30px 0;
}
/*************************************************************

    contact

*************************************************************/
.h_padding {
    padding-top: 200px;
}
.contact_bg {
    background-color: #1f2020;
}
.bg_item {
    position: absolute;
    bottom: 0;
    right: 0;
    overflow: hidden;
}
.bg_000 {
    background-color: #000;
}
.h_main p {
    font-size: 165px;
    letter-spacing: 0.04em;
    font-family: "Anton-Regular";
    line-height: 1.15;
}
.h_main h2 {
    font-size: 36px;
    font-weight: bold;
    letter-spacing: 0.1em;
}
.tel_num {
    font-size: 60px;
    font-family: "Anton-Regular";
}
.tel_num span {
    font-size: 45px;
}
.tel_txt {
    font-size: 30px;
}
.contact_flex {
    display: flex;
    border: 1px solid #fff;
}
.contact_flex li {
    width: 50%;
    padding: 4vw 5vw;
    white-space: nowrap;
}
.contact_flex li:first-of-type {
    border-right: 1px solid #fff;
}
.contact_flex li .line_banner {
    width: 100%;
}
.contact_flex li .line_banner a {
    position: relative;
    width: 100%;
    display: block;
    background-color: #22ac38;
    color: #fff;
    font-size: 20px;
    padding: 34px 45px;
    text-align: center;
    pointer-events: none;
}
.contact_flex li .line_banner a::before {
    content: "";
    background: url(../images/line_icon.webp) left 0/100% 100% no-repeat;
    width: 50px;
    height: 50px;
    position: absolute;
    left: 45px;
    top: 50%;
    transform: translateY(-50%);
}
.contact_flex li .line_banner a::after {
    content: "";
    background: url(../images/line_arrow.svg) left 0/100% 100% no-repeat;
    width: 24px;
    height: 17px;
    position: absolute;
    right: 30px;
    top: 50%;
    transform: translateY(-50%);
}
.contact_table {
    position: relative;
    z-index: 10;
}
.contact_table > div {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 25px;
    align-items: center;
    border-bottom: 1px solid #707070;
    padding: 50px 0 50px 45px;
}
.contact_table > div:first-of-type {
    border-top: 1px solid #707070;
}
.e_cell1 {
    display: flex;
    align-items: center;
    font-size: 18px;
    letter-spacing: 0.08em;
    line-height: 1.9;
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-weight: 500;
    font-style: normal;
}
/* .e_cell2 {
  width: calc(100% - 300px);
} */
.hissu {
    background-color: #2f7dd4;
    width: 45px;
    color: #FFF;
    text-align: center;
    font-size: 14px;
    margin-right: 30px;
}
.size input {
    height: 70px;
}
.size input {
    width: 100%;
    max-width: 870px;
    background-color: #111111;
    border: 1px solid #111111;
    padding: 10px 20px;
}
.area textarea {
    width: 100%;
    height: 200px;
    background-color: #111111;
    border: 1px solid #111111;
    padding: 10px 20px;
}
/* 個人情報保護方針 */
.check_box {
    display: flex;
    justify-content: center;
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-weight: 500;
    font-style: normal;
}
.check_box input[type=checkbox] {
    display: none;
    position: relative;
    z-index: 10;
}
.check_box .wpcf7-list-item {
    display: inline-block;
    margin: 0 !important;
}
.check_box .wpcf7-list-item-label::after {
    content: "";
    position: absolute;
    top: 60%;
    left: -20px;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 3px;
    border: 1px solid #d2d2d2;
}
.check_box .wpcf7-list-item-label::before {
    content: "";
    position: absolute;
    top: 2px;
    left: -7px;
    width: 13px;
    height: 20px;
    border-right: 2px solid #2f7dd4;
    border-bottom: 2px solid #2f7dd4;
    transform: rotate(45deg);
    opacity: 0;
    z-index: 10;
    display: block;
}
.check_box a {
    color: #fff;
    border-bottom: 1px solid #fff;
    padding-bottom: 5px;
    margin-left: 20px;
    position: relative;
    z-index: 100;
}
.check_box p {
    display: flex;
}
.check_box p span {
    font-size: 18px;
}
.wpcf7-form-control-wrap {
    position: relative;
}
#checkbox {
    position: relative;
}
input[type=checkbox]:checked + .wpcf7-list-item-label::before {
    opacity: 1;
}
/************************/
.wpcf7-not-valid-tip {
    margin-top: 15px;
}
.wpcf7-spinner {
    display: none !important;
}
/************************/
.submit {
    position: relative;
    z-index: 10;
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}
.submit input {
    position: relative;
    background: linear-gradient(270deg, #0683d3 0%, #5c1fab 100%);
    border: 1px solid #1f2020;
    color: #fff;
    font-size: 22px;
    letter-spacing: 0.12em;
    width: 100%;
    padding: 44px 10px;
    border-radius: 60px;
}
.submit .shape {
    position: absolute;
    right: 50px;
    top: 50%;
    transform: translateY(-50%);
}
.submit .shape img {
    width: 22px;
    height: auto;
    transition: 0.5s ease;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
}
.link_text {
    color: #fff;
}
.link_text:hover {
    color: #fff;
    text-decoration: none;
}
.break-word {
    overflow-wrap: break-word;
}
/************************/
/******************************************************************************************************

    トップページ

/****************************************************************************************************/
.moveSection {
    overflow: hidden;
}
.sec01_title {
    text-align: center;
}
.sec01_title2 {
    text-align: center;
}
.max_img100 img {
    max-width: 100%;
    height: auto;
}
.sec01_img {
    display: flex;
    justify-content: space-between;
    align-items: center;
    column-gap: 30px;
}
.sec01_img img {
    max-width: 100%;
    height: auto;
}
.sec01_img > div {
    position: relative;
}
.sec01_img > div.sec01_1:after, .sec01_img > div.sec01_3:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.sec01_1:after {
    background: url("../images/top_new3.webp") 50% 0/cover no-repeat;
    animation: circleRight 30s linear infinite;
}
.sec01_3:after {
    background: url("../images/top_new5.webp") 50% 0/cover no-repeat;
    animation: circleLeft 30s linear infinite;
}
@keyframes circleRight {
    0% {
        transform: translate(-50%, -50%) rotate(0);
    }
    100% {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}
@keyframes circleLeft {
    0% {
        transform: translate(-50%, -50%) rotate(0);
    }
    100% {
        transform: translate(-50%, -50%) rotate(-360deg);
    }
}
.se01_title_move {
    position: relative;
    max-width: 1178px;
    margin: 0 auto;
    width: 100%;
}
.moveTitle1 {
    position: absolute;
    top: 0;
    left: 0;
}
.moveTitle2 {
    position: absolute;
    top: 0;
    left: 0;
}
.sec01_part {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
.sec01_part canvas {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}
.more {
    width: 320px;
    border: 1px solid #FFF;
    border-radius: 50px;
    transition: 0.5s ease;
    font-size: 17px;
}
.more.more_c {
    margin-left: auto;
    margin-right: auto;
}
.more a {
    display: block;
    padding: 20px 0;
    text-align: center;
    color: #FFF;
    position: relative;
}
.more .arrow {
    position: absolute;
    right: 40px;
    top: calc(50% + 2px);
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.more .arrow img {
    position: absolute;
}
.more .off {
    top: 0;
    left: 0;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.more .on {
    opacity: 0;
    top: 20px;
    left: -20px;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.more:hover {
    background-color: #111111;
}
.more:hover .off {
    opacity: 0;
    top: -22px;
    left: 22px;
}
.more:hover .on {
    opacity: 1;
    top: 0;
    left: 0;
}
/*****ANIMATION*************/
.targetActive .fadeInUp {
    animation: fadeInUp 0.6s ease 0.3s forwards;
}
.targetActive.fadeInUp {
    animation: fadeInUp 0.6s ease 0.3s forwards;
}
.targetActive .fadeInLeft {
    animation: fadeInLeft 0.6s ease 0.3s forwards;
}
.targetActive.fadeInLeft {
    animation: fadeInLeft 0.6s ease 0.3s forwards;
}
.targetActive .glitch:before {
    animation: glitch-it 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1s forwards;
}
.targetActive .glitch:after {
    animation: glitch-it 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1s reverse forwards;
}
.targetActive.glitch {
    animation: fadeInLeft 0.6s ease 0.3s forwards;
}
.targetActive.glitch:before {
    animation: glitch-it 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1s forwards;
}
.targetActive.glitch:after {
    animation: glitch-it 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1s reverse forwards;
}
.sec08_width .fadeInUp {
    animation-delay: 0.8s;
}
.sec08_width .fadeInLeft {
    animation-delay: 0.8s;
}
.sec08_width .glitch:before {
    animation-delay: 1.6s;
}
.sec08_width .glitch:after {
    animation-delay: 1.6s;
}
.fadeInUp {
    opacity: 0;
    transform: translateY(40px);
}
@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(40px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
.fadeInLeft {
    opacity: 0;
    transform: translateX(-60px);
}
@keyframes fadeInLeft {
    0% {
        opacity: 0;
        transform: translateX(-60px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}
.glitch {
    position: relative;
}
/* 改行をそのまま表示させる */
.glitch, .glitch:before, .glitch:after {
    white-space: pre-wrap;
}
.glitch:before, .glitch:after {
    display: block;
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0.8;
    /* clip の代わり */
    clip-path: inset(0 0 0 0);
}
.glitch:before {
    color: #00FFFF;
    z-index: -1;
}
.glitch:after {
    color: #FF00FF;
    z-index: -2;
}
@keyframes glitch-it {
    0% {
        transform: translate(0);
        clip-path: inset(45% 0 52% 0);
    }
    20% {
        transform: translate(-4px, 4px);
        clip-path: inset(10% 0 80% 0);
    }
    40% {
        transform: translate(-4px, -4px);
        clip-path: inset(70% 0 20% 0);
    }
    60% {
        transform: translate(4px, 4px);
        clip-path: inset(35% 0 55% 0);
    }
    80% {
        transform: translate(4px, -4px);
        clip-path: inset(85% 0 5% 0);
    }
    100% {
        transform: translate(0);
        clip-path: inset(55% 0 40% 0);
    }
}
/**************/
.sec02_container {
    width: calc(100% - 40px);
    max-width: 1760px;
    margin-left: auto;
}
/* ------------------------------
   loopSlider
------------------------------ */
.loopSliderWrap {
    top: 0;
    right: 0;
    height: 760px;
    overflow: hidden;
    position: absolute;
}
.loopSlider {
    margin: 0 auto;
    width: 100%;
    height: 760px;
    text-align: left;
    position: relative;
    overflow: hidden;
}
.loopSlider ul {
    height: 760px;
    float: left;
    display: flex;
    overflow: hidden;
}
.loopSlider ul li {
    width: 1300px;
    height: 760px;
    margin: 0 5px;
    float: left;
    display: inline;
    overflow: hidden;
}
.loopSlider ul li img {
    width: 100%;
    height: auto;
}
/* ------------------------------
   CLEARFIX ELEMENTS
------------------------------ */
.loopSliderWrap:after {
    content: "";
    display: none;
    clear: none;
}
/****/
.eng_140 {
    font-size: 140px;
    line-height: 1em;
    letter-spacing: 0.04em;
}
.sec02_title {
    margin-top: -100px;
}
.title30 {
    font-size: 30px;
    font-weight: bold;
}
/*****************************/
.blog {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 85px;
    row-gap: 85px;
}
.blog a {
    display: block;
    color: #FFF;
}
.blog .img100 {
    overflow: hidden;
}
.blog .img100 img {
    max-height: 380px;
    min-height: 250px;
    height: 100%;
    width: 100%;
    object-fit: cover;
}
.blog.top_blog > div:nth-child(4) {
    display: none;
}
.blog_time {
    color: #8e8f8f;
    font-size: 16px;
    margin-top: 15px;
}
.blog_title {
    font-size: 22px;
    line-height: 1.6em;
    margin-top: 7px;
}
/*****************************/
/* ------------------------------
   loopSlider
------------------------------ */
.sec04_slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.sec04_slider .loopSliderWrap {
    height: 100%;
}
.sec04_slider.loopSlider {
    height: 100%;
}
.sec04_slider.loopSlider ul {
    height: 100%;
}
.sec04_slider.loopSlider ul li {
    width: 650px;
    height: 100%;
}
.sec04_slider.loopSlider img {
    width: 650px;
    height: auto;
    object-fit: cover;
    min-height: 100%;
}
.fit_center {
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}
/****************/
.sec06_flex {
    display: flex;
    justify-content: space-between;
}
.sec06_left {
    width: 49%;
    padding: 60px 0;
}
.sec06_right {
    width: 43%;
}
.sec06_right img {
    width: calc(100% + 80px);
    height: 100%;
    object-fit: cover;
}
/***************/
.sec07_flex {
    border: 1px solid #ffffff;
    display: flex;
    justify-content: space-between;
}
.sec07_flex > div {
    width: 50%;
    padding: 100px 20px;
    text-align: center;
}
.sec07_flex > div:nth-child(1) {
    border-right: 1px solid #FFF;
}
.sec07_flex .icon {
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}
.sec07_flex h3 {
    font-size: 40px;
    margin-top: 15px;
}
.sec07_time {
    font-size: 50px;
    line-height: 1.6em;
    margin-top: 5px;
}
.sec07_time.small {
    font-size: 26px;
    line-height: 1.6em;
    margin-top: 5px;
}
.sec07_text {
    margin-top: 15px;
}
.sec07_absolute {
    position: absolute;
    right: 0;
    top: -240px;
}
/***************************/
.sec07_cont {
    width: calc(100% - 80px);
    max-width: 1760px;
    position: relative;
    overflow: hidden;
}
.sec07_bg_absolute {
    position: absolute;
    right: 0;
    bottom: 0;
    background-color: #1b1b1b;
    padding: 80px 90px 0;
    z-index: 500;
}
.sec07_access {
    border-top: 1px solid #FFF;
    padding-top: 40px;
    margin-top: 40px;
}
.sec07_access h2 {
    font-size: 25px;
}
/*****************/
.sec08_flex {
    display: flex;
    justify-content: space-between;
}
.sec08_flex > div {
    width: 50%;
    position: relative;
    height: 680px;
    transition: 0.5s ease;
    overflow: hidden;
}
.sec08_flex > div:after {
    content: "";
    width: 1060px;
    height: 1060px;
    position: absolute;
    right: -720px;
    bottom: -720px;
    border-radius: 50%;
    z-index: 100;
    filter: blur(80px);
    transition: 0.5s ease;
}
.sec08_flex > div:before {
    content: "";
    transition: 0.5s ease;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}
.sec08_flex > div:hover:before {
    opacity: 1;
}
.sec08_flex > div:hover:after {
    right: 0%;
    bottom: 0%;
    border-radius: 0;
    width: 100%;
    height: 100%;
    opacity: 0.1;
}
.sec08_flex > div > a, .sec08_flex .banner_span {
    padding: 140px 20px;
    color: #FFF;
    display: block;
    height: 100%;
    position: relative;
    z-index: 500;
}
.sec08_flex > div > a:hover .sec08_more {
    background-color: #FFF;
}
.sec08_flex > div > a:hover .off {
    opacity: 0;
    top: -22px;
    left: 22px;
}
.sec08_flex a:hover .on {
    opacity: 1;
    top: 0;
    left: 0;
}
.sec08_left {
    background: url("../images/c_banner1.webp") 50% 0/cover no-repeat;
}
.sec08_left:after {
    background-color: #2f7dd4;
    opacity: 0.2;
}
.sec08_left:before {
    background: url("../images/top_new9_on.webp") 50% 0/cover no-repeat;
}
.sec08_right {
    background: url("../images/c_banner2.webp") 50% 0/cover no-repeat;
}
.sec08_right:after {
    background-color: #b71084;
    opacity: 0.1;
}
.sec08_right:before {
    background: url("../images/top_new10_on.webp") 50% 0/cover no-repeat;
}
.sec08_width {
    max-width: 560px;
    margin: 0 auto;
}
.eng_100 {
    font-size: 100px;
    line-height: 1em;
}
.sec08_more {
    position: absolute;
    right: 100px;
    bottom: 100px;
    width: 80px;
    height: 80px;
    border: 1px solid #FFF;
    border-radius: 50%;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
    z-index: 500;
}
.sec08_more .arrow {
    position: absolute;
    right: 49px;
    top: calc(50% - 10px);
    transform: translateY(-50%);
}
.sec08_more .arrow img {
    position: absolute;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.sec08_more .off {
    top: 0;
    left: 0;
}
.sec08_more .on {
    opacity: 0;
    top: 20px;
    left: -20px;
}
.sec08_item_center {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}
.sec08_flex .ab_more_btn {
    max-width: 260px;
    width: 100%;
}
.sec08_flex .ab_more_btn a {
    font-size: 15px;
    height: 40px;
    max-width: 260px;
    width: 100%;
}
.sec08_flex .ab_more_btn a .arrow {
    width: 24px;
    height: 24px;
}
.sec08_flex .ab_more_btn a .arrow img {
    width: 10px;
    height: auto;
}
.sec08_more_flex {
    display: flex;
    justify-content: space-between;
    max-width: 550px;
    column-gap: 15px;
}
/**********************************/
.f_banner {
    background-color: #000000;
    padding: 120px 0;
}
/*******/
.f_flex {
    padding: 130px 0;
    display: flex;
    justify-content: space-between;
}
.f_left {
    width: 420px;
}
.f_left p {
    font-size: 16px;
}
.f_right {
    width: calc(100% - 420px);
    max-width: 690px;
}
.f_nav {
    display: flex;
    justify-content: space-between;
}
.f_nav a {
    color: #FFF;
}
.f_nav p {
    line-height: 1.3em;
}
.f_nav .font_anton {
    font-size: 12px;
}
.f_nav .ja {
    font-size: 16px;
    display: block;
}
.f_nav > div > p:nth-child(n+2) {
    margin-top: 30px;
}
.f_copy {
    background-color: #000;
    padding: 25px 0;
    text-align: center;
    font-size: 15px;
}
/**************************************************************************

    PHYSIXとは　

/**************************************************************************/
.main_in {
    padding: 220px 0 0;
    text-align: center;
}
.title_box {
    padding: 0 40px 130px;
}
.title_eng {
    width: fit-content;
    margin: 0 auto;
    position: relative;
    line-height: 1em;
    font-size: min(13vw, 170px);
    letter-spacing: 0.06em;
}
.title_eng:after, .title_eng:before {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
}
.title_eng:before {
    color: #9b4dd7;
    top: 0;
    left: 0;
}
.title_eng:after {
    color: #3979d4;
    top: 0;
    left: 0;
}
.fit_relative {
    width: fit-content;
    margin: 0 auto;
    position: relative;
}
.fit_relative .title1, .fit_relative .title2 {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0;
    animation: main_title 0.2s ease 1.6s forwards;
}
.fit_relative .title1 {
    color: #9b4dd7;
}
.fit_relative .title2 {
    color: #3979d4;
}
.title_ja {
    font-size: 32px;
    font-weight: bold;
    margin-top: 15px;
    line-height: 1.8em;
    letter-spacing: 0.13em;
}
@keyframes main_title {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
.main_img {
    width: calc(100% - 80px);
}
.main_img img {
    max-height: 800px;
    height: 100%;
    min-height: 500px;
    width: 100%;
    object-fit: cover;
}
.fade-img-box {
    height: 17vw;
}
.fade-img-box img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto !important;
    object-fit: cover;
}
.fade-img-box2 {
    height: 17vw;
}
.fade-img-box2 img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto !important;
    object-fit: cover;
}
/**************************/
.ab01_text {
    text-align: center;
    font-size: 22px;
}
/**/
.ab01_flex {
    display: flex;
    justify-content: space-between;
}
.ab01_flex > div {
    width: 50%;
    background-position: 50% 0;
    background-size: cover;
    background-repeat: no-repeat;
    padding: 160px 0;
    overflow: hidden;
    position: relative;
}
.ab01_width {
    width: 90%;
    margin: 0 auto;
    max-width: 680px;
    position: relative;
    z-index: 500;
    padding-left: 80px;
}
.check_list {
    max-width: 580px;
    margin-left: auto;
}
.check_list li {
    margin: 20px 0;
    border: 1px solid #FFF;
    background-color: rgba(255, 255, 255, 0.08);
    padding: 20px 20px 20px 75px;
    position: relative;
    font-size: 22px;
    font-size: min(1.6vw, 22px);
    line-height: 1.8em;
}
.check_list li img {
    position: absolute;
    top: 30px;
    left: 30px;
}
.check_list li:nth-child(2) {
    animation-delay: 0.4s;
}
.check_list li:nth-child(3) {
    animation-delay: 0.5s;
}
.check_list li:nth-child(4) {
    animation-delay: 0.6s;
}
.ab01_eng {
    position: absolute;
    left: -7px;
    top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    writing-mode: vertical-rl;
    font-size: 110px;
    line-height: 1em;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.6);
    text-stroke: 1px rgba(255, 255, 255, 0.6);
}
/***************/
.bb_title {
    font-size: 45px;
    display: inline;
    background-position: left -100% center;
    padding-bottom: 1.8em;
    font-weight: bold;
    background-size: 200% 4px;
    line-height: 1.8em;
    background-repeat: repeat-x;
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 50%, #FFF 50%);
}
.ab01_figure {
    text-align: center;
    margin-top: -80px;
}
.ab01_figure img {
    max-width: 100%;
    height: auto;
}
/*********************/
.ab02_list > div {
    padding: 80px 0;
    border-bottom: 1px solid #FFF;
}
.ab02_list > div:nth-child(1) {
    border-top: 1px solid #FFF;
}
.ab02_flex {
    display: flex;
    justify-content: space-between;
    gap: 40px;
}
.ab02_left {
    width: 60%;
}
.ab02_right {
    width: 40%;
    max-width: max-content;
}
.ab02_right img {
    width: 100%;
    height: auto;
}
.ab02_bg {
    background-color: #111111;
    padding: 70px 80px;
}
.ab02_grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 80px;
    row-gap: 40px;
}
.ab02_grid > div {
    position: relative;
}
.ab02_grid > div:after {
    content: "";
    background: url("../images/about12.webp") 50% 0/54px 53px no-repeat;
    position: absolute;
    right: -78px;
    width: 78px;
    height: 53px;
    top: 50%;
    text-align: center;
    transform: translateY(-50%);
}
.ab02_grid > div:last-child:after {
    display: none;
}
.ab02_grid > div img {
    width: 100%;
    height: auto;
}
.ab02_grid > div:nth-child(2) {
    animation-delay: 0.4s;
}
.ab02_grid > div:nth-child(3) {
    animation-delay: 0.5s;
}
.ab02_grid > div:nth-child(4) {
    animation-delay: 0.6s;
}
/**************/
.ab03_grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 40px;
    row-gap: 40px;
}
.ab03_grid > div {
    position: relative;
}
.ab03_grid > div:nth-child(2) {
    animation-delay: 0.4s;
}
.ab03_grid > div:nth-child(3) {
    animation-delay: 0.5s;
}
.ab03_grid > div:nth-child(4) {
    animation-delay: 0.6s;
}
.ab03_grid p {
    margin-top: 20px;
    font-size: min(1.2vw, 20px);
}
.ab03_grid p br {
    display: none;
}
.ab03_grid .arrow_b {
    position: absolute;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 35px;
    height: 35px;
    border: 1px solid #FFF;
    border-radius: 50%;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
    z-index: 500;
}
.ab03_grid .arrow_b .arrow {
    position: absolute;
    right: 22px;
    top: calc(50% - 6px);
    transform: translateY(-50%);
}
.ab03_grid .arrow_b .arrow img {
    position: absolute;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.ab03_grid .arrow_b img {
    width: 11px;
    height: 11px;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.ab03_grid .arrow_b .off {
    top: 0;
    left: 0;
}
.ab03_grid .arrow_b .on {
    opacity: 0;
    top: 20px;
    left: -20px;
}
.ab03_grid a {
    display: block;
    color: #FFF;
}
.ab03_grid a:hover .off {
    opacity: 0;
    top: -22px;
    left: 22px;
}
.ab03_grid a:hover .on {
    opacity: 1;
    top: 0;
    left: 0;
}
.ab03_grid .arrow_color1 a:hover .arrow_b {
    background-color: #43bbb4;
    border-color: #43bbb4;
}
.ab03_grid .arrow_color2 a:hover .arrow_b {
    background-color: #3b54a4;
    border-color: #3b54a4;
}
.ab03_grid .arrow_color3 a:hover .arrow_b {
    background-color: #b71084;
    border-color: #b71084;
}
.ab03_grid .arrow_color4 a:hover .arrow_b {
    background-color: #187e9f;
    border-color: #187e9f;
}
/**20260202追加***********************/
.ab_bg_title {
    width: 100%;
    max-width: 680px;
    border: 3px solid #2dd4bf;
    padding: 6px;
}
.ab_bg_title h3 {
    background-color: #2dd4bf;
    min-height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #FFF;
    padding: 10px;
}
.ab_bg_title.style_1a8174 {
    border-color: #1a8174;
}
.ab_bg_title.style_1a8174 h3 {
    background-color: #1a8174;
}
.ab_bg_title.style_2d93d4 {
    border-color: #2d93d4;
}
.ab_bg_title.style_2d93d4 h3 {
    background-color: #2d93d4;
}
.ab_bg_title.style_1d577b {
    border-color: #1d577b;
}
.ab_bg_title.style_1d577b h3 {
    background-color: #1d577b;
}
.ab_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 25px;
    row-gap: 40px;
    max-width: 1440px;
}
.ab_grid p {
    text-align: center;
    margin-top: 20px;
}
.ab_more_btn a {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #FFF;
    border-radius: 50px;
    height: 75px;
    font-size: clamp(22px, 2.5vw, 30px);
    font-weight: bold;
    column-gap: 20px;
    color: #134e4a;
    width: 100%;
    max-width: 580px;
    letter-spacing: 0.1em;
    padding-left: 25px;
    border: 1px solid #FFF;
    transition: 0.3s ease;
}
.ab_more_btn a:hover {
    opacity: 0.7;
}
.ab_more_btn .arrow {
    border: 1px solid #134e4a;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    width: 38px;
    height: 38px;
}
/**************************************************************************

    料金　

/**************************************************************************/
.fee_flex {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    column-gap: 40px;
    grid-row-gap: 20px;
}
.fee_right {
    padding-bottom: 2px;
    text-indent: -1.1em;
    padding-left: 1.1em;
}
.fee_title {
    font-size: 55px;
    position: relative;
    padding: 35px 0 0 200px;
    display: flex;
}
.fee_title .font_anton {
    font-size: 150px;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px #FFF;
    text-stroke: 1px #FFF;
    position: absolute;
    top: 0;
    left: 0;
    letter-spacing: 0.1em;
}
.fee_tale01 table {
    width: 100%;
}
.fee_tale01 table th, .fee_tale01 table td {
    padding: 25px 40px;
    border: 1px solid #383838;
}
.fee_tale01 table th {
    background-color: #131313;
    font-size: 22px;
    width: 400px;
}
.fee_tale01 table td {
    background-color: #222222;
    font-size: 20px;
}
.text20 {
    font-size: 20px;
    line-height: 1.8em;
}
/********/
.title_28 {
    font-size: 28px;
}
.be_bb {
    position: relative;
    padding-left: 45px;
}
.be_bb:before {
    content: "";
    border-bottom: 2px solid #FFF;
    width: 25px;
    position: absolute;
    top: 22px;
    left: 0;
}
.be_bb2 {
    position: relative;
    padding-left: 45px;
}
.be_bb2:before {
    content: "";
    border-bottom: 3px solid #FFF;
    width: 25px;
    position: absolute;
    top: 30px;
    left: 0;
}
.fee_tale02 table {
    width: 100%;
}
.fee_tale02 table th, .fee_tale02 table td {
    padding: 20px 5px;
    border: 1px solid #383838;
    text-align: center;
    font-size: 20px;
    line-height: 1.6em;
    height: 120px;
}
.fee_tale02 table tr:nth-child(1) th, .fee_tale02 table tr:nth-child(1) td {
    font-size: 22px;
    background-color: #131313;
    height: auto;
}
.fee_tale02 table th {
    background-color: #131313;
    width: 320px;
}
.fee_tale02 table td {
    background-color: #222222;
    width: 13%;
}
.fee_tale02 table td:empty {
    background-image: linear-gradient(to top left, transparent, transparent 49%, #383838 49%, #383838 49%, transparent 50%, transparent);
}
/********************************/
.fee_tale03 table {
    overflow: hidden;
    width: 100%;
}
.fee_tale03 table th, .fee_tale03 table td {
    padding: 30px 5px;
    border: 1px solid #383838;
    text-align: center;
    font-size: 20px;
    line-height: 1.6em;
}
.fee_tale03 table th.bt0, .fee_tale03 table td.bt0 {
    border-top: 0;
}
.fee_tale03 table th.bb0, .fee_tale03 table td.bb0 {
    border-bottom: 0;
}
.fee_tale03 table th.br0, .fee_tale03 table td.br0 {
    border-right: 0;
}
.fee_tale03 table p {
    line-height: 1.2em;
}
.fee_tale03 table .icon {
    margin-bottom: 13px;
}
.fee_tale03 table tr:nth-child(1) th, .fee_tale03 table tr:nth-child(1) td, .fee_tale03 table tr:nth-child(2) th, .fee_tale03 table tr:nth-child(2) td {
    padding: 20px 5px;
    font-size: 22px;
    background-color: #131313;
    height: auto;
}
.fee_tale03 table th {
    background-color: #131313;
    width: 130px;
}
.fee_tale03 table td {
    background-color: #222222;
}
.fee_tale03 table .td_border_calc {
    border: 0;
    position: relative;
    width: 15%;
}
.fee_tale03 table .td_border_calc:after {
    content: "";
    border-right: 1px solid #383838;
    position: absolute;
    right: 0;
    top: -150px;
    height: calc(100% + 2000px);
}
.fee3_menu {
    text-align: center;
    border: 1px solid #FFF;
    border-radius: 50px;
    max-width: 580px;
    width: 90%;
    margin: 0 auto;
    background-color: #131313;
    position: relative;
    z-index: 500;
    padding: 8px 0 13px;
}
.fee3_arrow {
    position: relative;
}
.fee3_arrow:before {
    content: "";
    background-color: #2f7dd4;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    height: 7px;
    right: 20px;
}
.fee3_arrow:after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 20px solid #2f7dd4;
    border-right: 0;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
/*************/
.fee_tale01.td_center th.w360 {
    width: 360px;
}
.fee_tale01.td_center tr:nth-child(1) th, .fee_tale01.td_center tr:nth-child(1) td {
    padding: 15px 0;
}
.fee_tale01.td_center .yellow {
    color: #ffba00;
}
.fee_tale01.td_center .red {
    color: #ff0000;
}
.fee_tale01.td_center.td_center td {
    text-align: center;
}
.fee_tale01.td_center .bg_131313 {
    background-color: #131313;
}
.fee_tale01.td_center td {
    width: 35%;
}
.fee_tale01.td_center td:nth-of-type(1), .fee_tale01.td_center td:nth-of-type(2) {
    width: 20%;
}
.fee_02_midashibox {
    display: flex;
    justify-content: space-between;
    padding: 10px 2vw;
    border: 2px solid #fff;
    border-radius: 30px;
    max-width: 684px;
}
.fee_02_midashibox p {
    font-size: 27px;
    line-height: 1.4;
}
.fee_02_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 2.4vw;
    row-gap: 3vw;
}
.fee_02_grid li {
    border: 1px solid #fff;
    padding: 2.6vw 2vw;
    text-align: center;
}
.fee_02_img {
    width: 62px;
    height: auto;
    margin: 0 auto;
}
.fee_02_img img {
    width: 100%;
    height: auto;
}
.title_22 {
    font-size: 22px;
}
.fee_tale04 table {
    width: 100%;
}
.fee_tale04 table th, .fee_tale04 table td {
    padding: 25px 40px;
    border: 1px solid #383838;
}
.fee_tale04 table th {
    background-color: #131313;
    font-size: 22px;
    width: 400px;
}
.fee_tale04 table td {
    background-color: #222222;
    font-size: 20px;
}
.fee_tale04 .td_border_calc {
    position: relative;
}
.fee_tale04 .td_border_calc:after {
    content: "";
    border-right: 1px solid #383838;
    position: absolute;
    right: 0;
    top: -100px;
    height: calc(100% + 100px);
}
.fee_tale04 .border_bottom0 {
    border-bottom: 0 !important;
}
.fee_tale04 .border_top0 {
    border-top: 0 !important;
}
.fee_tale04 .border_right0 {
    border-right: 0 !important;
}
.fee_tale04 .border_left0 {
    border-left: 0 !important;
}
.fee_tale04.td_center th.w360 {
    width: 360px;
}
.fee_tale04.td_center tr:nth-child(1) th, .fee_tale04.td_center tr:nth-child(1) td {
    padding: 15px 0;
}
.fee_tale04.td_center .yellow {
    color: #ffba00;
}
.fee_tale04.td_center .red {
    color: #ff0000;
}
.fee_tale04.td_center.td_center td {
    text-align: center;
}
.fee_tale04.td_center .bg_131313 {
    background-color: #131313;
}
.fee_tale04.td_center td {
    width: 35%;
}
.fee_tale04.td_center td:nth-of-type(1), .fee_tale04.td_center td:nth-of-type(2) {
    width: 20%;
}
.fee4_menu {
    text-align: center;
    border: 1px solid #FFF;
    background-color: #222222;
    border-radius: 50px;
    max-width: 950px;
    width: 100%;
    margin: 0 auto;
    position: relative;
    z-index: 500;
    padding: 3px 0 3px;
}
.fee4_flex {
    max-width: 230px;
    text-align: center;
    margin: 0 auto;
    line-height: 1.7;
}
.fee4_flex_left {
    width: 110px;
    text-align: left;
    display: inline-block;
}
.fee4_flex_right {
    text-align: left;
    display: inline-block;
}
/**************************************************************************

    トレーナー紹介　

/**************************************************************************/
.trainer_flex > div {
    display: flex;
    justify-content: space-between;
}
.trainer_flex > div:nth-child(n+2) {
    margin-top: 110px;
}
.trainer_left {
    width: 40%;
    max-width: 460px;
}
.trainer_left img {
    width: 100%;
    height: 520px;
    object-fit: cover;
}
.trainer_right {
    width: 56%;
}
.trainer_name {
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px #FFF;
    text-stroke: 1px #FFF;
    font-size: 90px;
    line-height: 1em;
    position: relative;
}
.trainer_table > div {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.trainer_table > div:nth-child(n+2) {
    margin-top: 20px;
}
.trainer_table p {
    font-size: 18px;
}
.tr_cell1 {
    background-color: #FFF;
    border-radius: 50px;
    width: 90px;
    text-align: center;
    color: #1b1b1b;
    line-height: 1.3em;
    position: relative;
    top: 4px;
}
.tr_cell2 {
    width: calc(100% - 110px);
    line-height: 1.8em;
}
/* バナー追加 */
.top_banner {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    column-gap: 3vw;
    row-gap: 30px;
    max-width: 800px;
    margin: 0 auto 120px;
}
.top_banner img {
    width: 100%;
    height: auto;
}
/**************************************************************************

    ブログ　

/**************************************************************************/
/*Pagenation*/
.pagenation {
    text-align: center;
    margin: 120px auto 0;
}
.pagenation:after, .pagenation ul:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    visibility: hidden;
}
.pagenation ul {
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.pagenation li {
    list-style: none outside none;
    margin: 0 6px;
    font-size: 22px;
}
.pagenation li:first-child {
    margin-left: 0;
}
.pagenation li.active {
    background-color: #2f7dd4;
    color: #FFFFFF;
    cursor: not-allowed;
    width: 65px;
    height: 65px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.pagenation li a {
    width: 65px;
    height: 65px;
    color: #FFF;
    border: 1px solid #FFF;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
}
.pagenation .prev a, .pagenation .next a {
    background-color: none;
    border-radius: 0;
    color: #99b250;
    width: auto;
    height: auto;
    border: 0;
}
.pagenation .prev span, .pagenation .next span {
    position: relative;
    top: -1px;
    margin: 0 5px;
}
/**************************************************************************

    施設・設備紹介　

/**************************************************************************/
.facility_grid {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    row-gap: 80px;
}
.facility_grid > div {
    max-width: 670px;
    width: 48%;
}
.facility_grid p {
    font-size: 31px;
    line-height: 1.6em;
    margin-top: 20px;
    font-size: clamp(20px, 2.5vw, 31px);
}
/**************************************************************************

    営業時間・アクセス　

/**************************************************************************/
.ac01_border {
	border: 1px solid #FFF;
	padding: 60px 20px;
	text-align: center;
}
.ac01_border .sec07_time {
	margin-top: 20px;
	font-size: clamp(24px,2.5vw, 31px);
}

.access_table > div {
    display: flex;
    justify-content: space-between;
    padding: 40px 15px;
    border-bottom: 1px solid #FFF;
}
.access_table > div:nth-child(1) {
    border-top: 1px solid #FFF;
}
.access_table > div p {
    font-size: 20px;
}
.ac_cell1 {
    width: 290px;
}
.ac_cell2 {
    width: calc(100% - 290px);
}
.map iframe {
    width: 100%;
    height: 600px;
}
/**************************************************************************

    お問い合わせ　

/**************************************************************************/
.contact_flex {
    display: flex;
    justify-content: center;
    border: 1px solid #FFF;
    text-align: center;
}
.contact_flex > div {
    width: 50%;
    padding: 85px 10px;
}
/* .contact_flex>div:nth-child(1) {
    border-right: 1px solid #FFF;
} */
.contact_flex h3 {
    font-size: 30px;
    font-weight: bold;
}
.c_tel {
    font-size: 45px;
    line-height: 1.5em;
    margin-top: 35px;
}
.c_tel span {
    font-size: 60px;
    margin-left: 15px;
}
.more.line_more {
    width: 100%;
    max-width: 450px;
    margin: 20px auto 0;
    border-radius: 100px;
    background-color: #22ac38;
    border: 2px solid #22ac38;
}
.more.line_more a {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 32px 80px;
    font-size: 20px;
}
.more.line_more .line {
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-50%);
}
.more.line_more:hover {
    background-color: rgba(0, 0, 0, 0);
}
/****************/
.contact_form {
    border-top: 1px solid #707070;
}
.contact_form > div {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #707070;
    padding: 50px 55px;
}
.contact_form p {
    line-height: 1.5em;
}
.c_f_cell1 {
    width: 300px;
    display: flex;
    align-items: center;
}
.c_f_cell2 {
    width: calc(100% - 300px);
}
.eq {
    background-color: #2f7dd4;
    border-radius: 50px;
    width: 50px;
    text-align: center;
    font-size: 14px;
    display: inline-block;
    margin-right: 25px;
}
.size {
    background-color: #111111;
    width: 100%;
    border: 0;
}
.size {
    height: 70px;
    /* margin: 0 15px; */
}
.area {
    width: 100%;
    border: 0;
    height: 200px;
    /* margin: 0 15px; */
}
.check_pri {
    padding-left: 360px;
}
.check_pri a {
    color: inherit;
    font-size: 20px;
    border-bottom: 1px solid #FFF;
    padding-bottom: 5px;
}
input[type=checkbox] {
    position: relative;
    width: 40px;
    height: 40px;
    border-radius: 3px;
    border: 1px solid #FFF;
    vertical-align: -15px;
    margin-right: 20px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
input[type=checkbox]:checked:before {
    position: absolute;
    top: 1px;
    left: 50%;
    transform: translateX(-50%) rotate(40deg);
    width: 15px;
    height: 25px;
    border-right: 2px solid #3979d4;
    border-bottom: 2px solid #3979d4;
    content: "";
}
.submit_p {
    position: relative;
    border-radius: 100px;
    overflow: hidden;
    width: 100%;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    font-size: 24px;
}
.submit_p:before {
    content: "";
    background-color: #1b1b1b;
    position: absolute;
    z-index: 2;
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    top: 2px;
    left: 2px;
    border-radius: 100px;
    transition: 0.5s ease;
    opacity: 0;
}
.submit_p:after {
    content: "";
    background: linear-gradient(90deg, #5a0e92, #4b34c2 20%, #3551cf 40%, #0b6bdd 60%, #0690d9 80%, #08b1d0 100%);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}
.submit_p input {
    padding: 45px 10px;
    display: block;
    text-align: center;
    width: 100%;
    background-color: rgba(0, 0, 0, 0);
    border: 0;
    color: #FFF;
    position: relative;
    z-index: 500;
    letter-spacing: 0.12em;
}
.submit_p .arrow {
    position: absolute;
    right: 40px;
    top: calc(50% + 2px);
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 500;
}
.submit_p .arrow img {
    position: absolute;
}
.submit_p .off {
    top: 0;
    left: 0;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.submit_p .on {
    opacity: 0;
    top: 20px;
    left: -20px;
    transition: 0.8s cubic-bezier(1, 0, 0, 1);
}
.submit_p:hover:before {
    opacity: 1;
}
.submit_p:hover .off {
    opacity: 0;
    top: -22px;
    left: 22px;
}
.submit_p:hover .on {
    opacity: 1;
    top: 0;
    left: 0;
}
.c_shape {
    position: absolute;
    right: 0;
    bottom: 0;
}
/***************************************************************

	初動負荷トレーニング

***************************************************************/
.text22 {
    font-size: clamp(18px, 1.7vw, 22px);
}
/*********************/
.ini02_bg {
    background: url("../images/initial2.webp") 50% 0/cover no-repeat;
    overflow: hidden;
}
.ini2_absolute {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    writing-mode: vertical-rl;
    font-size: 248px;
    white-space: nowrap;
    text-box: trim-both cap alphabetic;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 2px #FFF;
    text-stroke: 2px #FFF;
    opacity: 0.5;
}
/***************************/
.ini03_flex_wrap {
    border-top: 1px solid #FFF;
}
.ini03_flex_wrap > div {
    border-bottom: 1px solid #FFF;
    padding: 60px 0;
}
.ini03_flex {
    display: flex;
    justify-content: space-between;
    gap: 40px 30px;
}
.ini03_right {
    order: 2;
    max-width: max-content;
    width: 35%;
}
.ini03_right img {
    max-width: 100%;
    height: auto;
}
.ini03_left {
    width: 65%;
}
.ini03_bg {
    background-color: #111111;
    padding: 55px clamp(30px, 11%, 80px);
}
.ini03_grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 50px;
}
.ini03_grid img {
    width: 100%;
    height: auto;
}
/*****************/
.bg_111 {
    background-color: #111;
}
.se01_title_move.ini04_style {
    max-width: max-content;
    margin: 0 auto;
}
.ini04_circle_absolute {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 100%;
    text-align: center;
}
.ini04_circle_absolute img {
    max-width: 100%;
    height: auto;
}
/**********************/
.ini05_flex {
    display: flex;
    justify-content: space-between;
    gap: 40px;
}
.ini05_inner {
    width: 50%;
    max-width: 680px;
}
.ini05_title {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px 15px;
}
.ini05_cat {
    background-color: #FFF;
    border-radius: 50px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #005bbb;
    font-weight: bold;
    font-size: 20px;
    padding: 0 30px;
}
.ini05_cat.green {
    color: #134e4a;
}
.ini05_bg_list {
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.ini05_bg_card {
    background-color: #2d2d2d;
    padding: 25px 30px;
}
.ini05_check {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 15px;
}
.ini05_check:before {
    content: "";
    background: url("../images/check_w.webp") 50% 0/100% 100% no-repeat;
    width: 26px;
    height: 20px;
    position: relative;
    top: 7px;
}
/********************/
.ini06_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    text-align: center;
}
.ini06_grid > div {
    position: relative;
    width: calc(100% + 65px);
    position: relative;
}
.ini06_grid > div:after {
    content: "";
    background: url("../images/initial_close.webp") 50% 0/85px 85px no-repeat;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 10px;
    width: 85px;
    height: 85px;
}
.ini06_grid > div:nth-child(1) .ini06_circle img {
    animation: circleRightRotate 30s linear infinite;
}
.ini06_grid > div:nth-child(2) {
    margin-left: -40px;
    z-index: 500;
}
.ini06_grid > div:nth-child(2) .ini06_circle img {
    animation: circleLeftRotate 30s linear infinite;
}
.ini06_grid > div:nth-child(2):after {
    right: 0;
}
.ini06_grid > div:nth-child(3) {
    margin-left: -65px;
}
.ini06_grid > div:nth-child(3) .ini06_circle img {
    animation: circleRightRotate 30s linear infinite;
}
.ini06_grid > div:nth-child(3):after {
    display: none;
}
.ini06_circle img {
    width: 100%;
    height: auto;
}
.ini06_absolute {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}
.ini06_absolute p {
    font-size: clamp(20px, 2.2vw, 30px);
    text-align: center;
}
.ini06_absolute .img {
    width: 100%;
    padding: 0 40px 20px;
}
.ini06_absolute img {
    max-width: 100%;
    height: auto;
}
@keyframes circleRightRotate {
    0% {
        transform: rotate(0);
    }
    100% {
        transform: rotate(360deg);
    }
}
@keyframes circleLeftRotate {
    0% {
        transform: rotate(0);
    }
    100% {
        transform: rotate(-360deg);
    }
}
.ini06_flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 80px 0;
}
.ini06_bg_inner {
    background-color: #FFF;
    width: 48%;
    border-radius: 30px;
    max-width: 675px;
    padding: 30px 50px;
}
.ini06_bg_inner h4 {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 20px;
    color: #134e4a;
    letter-spacing: 0.1em;
}
.ini06_bg_inner p {
    color: #000;
    font-size: 16px;
    letter-spacing: 0.04em;
}
/****************************/
.ini07_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 75px;
    row-gap: 30px;
}
.ini07_inner {
    background-color: #111111;
    padding: 28px;
}
.ini07_inner h3 {
    font-size: clamp(20px, 2vw, 25px);
    font-weight: bold;
    margin: 20px 0;
}
/*************************/
.ini08_list {
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.ini08_inner {
    background-color: #111111;
    padding: 25px 45px;
}
.q_table {
    font-size: clamp(20px, 2vw, 25px);
    font-weight: bold;
    display: flex;
}
.q_table .cell1 {
    width: 30px;
    flex-shrink: 0;
}
.q_table .cell2 {
    flex-grow: 2;
}
.a_table {
    display: flex;
    column-gap: 5px;
    margin-top: 5px;
}
.a_table .cell1 {
    white-space: nowrap;
    flex-shrink: 0;
}
.a_table .cell2 {
    flex-grow: 2;
}
/*********************/
.ini09_flex_wrap {
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.bg_green_f0f9ff {
    background-color: #f0f9ff;
}
.ini09_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
    color: #000;
    border-radius: 30px;
    padding: 45px 65px;
}
.green_134e4a {
    color: #134e4a;
}
.ini09_left {
    flex-grow: 2;
}
.ini09_right {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 5px 60px;
}
.ini09_price {
    font-size: clamp(25px, 3.5vw, 40px);
    font-weight: bold;
    line-height: 1.2em;
    white-space: nowrap;
}
.ini09_price .small {
    font-size: clamp(16px, 1.7vw, 20px);
    margin-right: 20px;
}
.bg_red_fef2f2 {
    background-color: #fef2f2;
}
.red_dc2626 {
    color: #dc2626;
}
/****************************/
.ini10_bg {
    background: url("../images/initial23.webp") 50% 0/cover no-repeat;
}
.ini10_style a {
    margin: 0 auto;
}
/***********************************************************

	料金プラン

***********************************************************/
.fee_title_flex {
    display: flex;
    align-items: flex-end;
    gap: 30px;
}
.fee_num {
    font-size: clamp(60px, 11.5vw, 150px);
    flex-shrink: 0;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px #FFF;
    text-stroke: 1px #FFF;
    line-height: 1em;
}
.fee_title_right {
    flex-grow: 2;
}
.fee_bg_title {
    background-color: #FFF;
    border-radius: 50px;
    font-size: clamp(14px, 1.7vw, 20px);
    font-weight: bold;
    color: #134e4a;
    padding: 3px 25px;
    letter-spacing: 0.1em;
    width: fit-content;
    line-height: 1.3em;
}
.fee_inner_flex {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 65px;
    font-weight: bold;
    margin-top: 20px;
}
.title_55 {
    font-size: clamp(24px, 4.8vw, 55px);
    line-height: 1.2em;
}
/******************/
.fee01_flex {
    display: flex;
    justify-content: space-between;
    gap: 40px;
}
.fee01_left {
    width: 50%;
    display: flex;
    align-items: center;
}
.fee_check_list {
    display: flex;
    flex-direction: column;
    gap: 60px;
}
.fee_check_list li {
    display: flex;
    align-items: center;
    gap: 40px;
    font-size: clamp(18px, 2.2vw, 28px);
    font-weight: bold;
    line-height: 1.3em;
}
.fee_check_list li:before {
    content: "";
    background: url("../images/check_icon.webp") 50% 0/100% 100% no-repeat;
    width: 57px;
    height: 52px;
    flex-shrink: 0;
}
.fee01_right {
    width: 50%;
    max-width: max-content;
}
.fee01_right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 30px;
}
/*******/
.fee01_table {
    overflow-x: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.fee01_table::-webkit-scrollbar {
    display: none;
}
.fee01_table table {
    width: 100%;
}
.fee01_table.table_height150 tr:nth-child(n+2) th, .fee01_table.table_height150 tr:nth-child(n+2) td {
    text-align: center;
    white-space: nowrap;
    height: 120px;
    border: 1px solid #383838;
}
.fee01_table th, .fee01_table td {
    padding: 15px 10px;
    text-align: center;
    white-space: nowrap;
    border: 1px solid #383838;
}
.fee01_table th {
    width: 310px;
    background-color: #131313;
    font-size: 19px;
}
.fee01_table tr.td_bg_222222 td {
    background-color: #222222;
}
.fee01_table td {
    font-size: 20px;
}
.fee01_table td.group {
    background-color: #116e69;
    font-size: 22px;
}
.fee01_table td.personal30 {
    background-color: #134e4a;
    font-size: 22px;
}
.fee01_table td.personal50 {
    background-color: #1e293b;
    font-size: 22px;
}
/************************/
.text16 {
    font-size: 16px;
}
.w100 {
    width: 100%;
}
.fee02_flex {
    display: flex;
    justify-content: space-between;
    background-color: #ffffff;
    border-radius: 30px;
    color: #000;
    padding: 25px 55px;
    column-gap: 40px;
}
.fee02_price_flex {
    display: flex;
    justify-content: flex-end;
    gap: 5px 60px;
}
/**********************/
.max_w1070 {
    max-width: 1070px;
}
.fee03_title_flex {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    column-gap: 15px;
}
.fee03_order1 {
    order: 2;
}
.fee03_order2 {
    order: 1;
}
.fee03_order3 {
    order: 3;
}
/************************/
.fee02_flex.fee04_bg_red {
    background-color: #fef2f2;
}
.fee02_flex.fee04_bg_green1 {
    background-color: #f0f9ff;
}
.fee02_flex.fee04_bg_green2 {
    background-color: #2dd4bf;
}
.fee04_flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-row-gap: 10px;
}
.fee04_flex li {
    width: 48%;
    max-width: 610px;
    display: flex;
    justify-content: space-between;
    column-gap: 20px;
}
.fee04_cell2 {
    white-space: nowrap;
}
/**************************************/
.fee05_btn_flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
	grid-row-gap: 30px;
}
.fee05_btn_flex > p {
    width: 100%;
    max-width: 580px;
}
.fee05_tel_wrap {
    text-align: center;
}
.fee05_tel a {
    font-size: clamp(32px, 5vw, 55px);
    font-weight: bold;
    color: #FFF;
    letter-spacing: 0.08em;
}
.scroll_p {
    display: none;
}
/* PPC用
------------------------------------------------------------*/
@media only screen and (max-width: 1699px) {
    .mv_copy {
        max-width: 800px;
    }
}
@media only screen and (max-width: 1600px) {
    .fee03_title_flex {
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        column-gap: 15px;
    }
    .fee03_order1 {
        order: 1;
        margin-bottom: 10px;
    }
    .fee03_order2 {
        order: 2;
    }
    .fee03_order3 {
        order: 3;
    }
}
@media only screen and (max-width: 1500px) {
    .fee_tale04 .fee4_padding td {
        padding: 20px 5px;
    }
}
@media only screen and (max-width: 1400px) {
    .title_50 {
        font-size: 40px;
    }
    .title_110 {
        font-size: 90px;
    }
    .mv_copy {
        max-width: 700px;
    }
    .contact_btn {
        width: 320px;
    }
    .contact_btn a {
        position: relative;
        width: 100%;
        display: block;
        text-align: center;
        padding: 26px 20px;
        border: 1px solid #fff;
        border-radius: 50px;
        color: #fff;
        font-size: 20px;
        transition: 0.3s ease;
    }
    /* 流れる文字 */
    /* ---------------------------- */
    .loop_wrapper {
        font-size: 180px;
    }
    /*************************************************************

      contact

  *************************************************************/
    .tel_num {
        font-size: 55px;
        font-family: "Anton-Regular";
    }
    .tel_num span {
        font-size: 40px;
    }
}
@media only screen and (max-width: 1300px) {
    .eng_100 {
        font-size: 70px;
        line-height: 1em;
    }
    .ab03_grid p {
        margin-top: 20px;
        font-size: min(1.4vw, 20px);
        line-height: 1.5em;
    }
    .ab03_grid p br {
        display: block;
    }
}
@media only screen and (max-width: 1200px) {
    .title_110 {
        font-size: 80px;
    }
    .en_title_120 {
        font-size: 100px;
    }
    .mv_copy {
        max-width: 560px;
        top: 35%;
    }
    .sec05_flex {
        display: block;
    }
    .contact_btn {
        margin-top: 60px;
    }
    .eng_style {
        color: rgba(255, 255, 255, 0);
        -webkit-text-stroke: 1px #ffffff;
        text-stroke: 1px #ffffff;
    }
    /* 流れる文字 */
    /* ---------------------------- */
    .loop_wrapper {
        font-size: 140px;
    }
    .fee4_flex_left {
        text-align: center;
    }
    /*************************************************************

      contact

  *************************************************************/
    .h_main p {
        font-size: 130px;
    }
    .tel_num {
        font-size: 50px;
        font-family: "Anton-Regular";
    }
    .tel_num span {
        font-size: 35px;
    }
    .contact_flex li {
        width: 50%;
        padding: 3vw 4vw;
    }
    .contact_flex li .line_banner {
        width: 100%;
    }
    .contact_flex li .line_banner a {
        font-size: 18px;
        padding: 25px 10px;
    }
    .contact_flex li .line_banner a::before {
        content: "";
        width: 40px;
        height: 40px;
        left: 30px;
    }
    /***********************************************************

  	料金プラン

  ***********************************************************/
    .fee02_flex {
        flex-wrap: wrap;
        border-radius: 30px;
        color: #000;
        padding: 25px 55px;
        gap: 20px;
    }
    .fee02_price_flex {
        display: flex;
        justify-content: flex-end;
        margin-left: auto;
        gap: 5px 60px;
    }
    /**********************/
    .max_w1070 {
        max-width: 1070px;
    }
    .fee03_title_flex {
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        column-gap: 15px;
    }
    .fee04_flex {
        justify-content: space-between;
        grid-row-gap: 10px;
        max-width: 600px;
    }
    .fee04_flex li {
        width: 100%;
        max-width: 100%;
        display: flex;
        justify-content: space-between;
        column-gap: 20px;
    }
    .fee04_cell2 {
        white-space: nowrap;
    }
    /**************************************/
    .fee05_btn_flex {
        justify-content: center;
        gap: 20px;
    }
    .fee05_btn_flex > p {
        width: 100%;
        max-width: 580px;
    }
}
@media only screen and (max-width: 1024px) {
    .padding100 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding110 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding120 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding130 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding140 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding150 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding160 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding170 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding180 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding190 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding200 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding210 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding220 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding230 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding240 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding250 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding260 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding270 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding280 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding290 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding300 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .margin100 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin110 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin120 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin130 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin140 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin150 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin160 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin170 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin180 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin190 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin200 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin210 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin220 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin230 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin240 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin250 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin260 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin270 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin280 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin290 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin300 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .pt-120 {
        padding-top: 120px;
    }
    .pt-130 {
        padding-top: 120px;
    }
    .pt-140 {
        padding-top: 120px;
    }
    .pt-150 {
        padding-top: 120px;
    }
    .pt-160 {
        padding-top: 120px;
    }
    .pt-170 {
        padding-top: 120px;
    }
    .pt-180 {
        padding-top: 120px;
    }
    .pt-190 {
        padding-top: 120px;
    }
    .pt-200 {
        padding-top: 120px;
    }
    .pt-210 {
        padding-top: 120px;
    }
    .pt-220 {
        padding-top: 120px;
    }
    .pt-230 {
        padding-top: 120px;
    }
    .pt-240 {
        padding-top: 120px;
    }
    .pt-250 {
        padding-top: 120px;
    }
    .pt-260 {
        padding-top: 120px;
    }
    .pt-270 {
        padding-top: 120px;
    }
    .pt-280 {
        padding-top: 120px;
    }
    .pt-290 {
        padding-top: 120px;
    }
    .pt-300 {
        padding-top: 120px;
    }
    .pb-120 {
        padding-bottom: 120px;
    }
    .pb-130 {
        padding-bottom: 120px;
    }
    .pb-140 {
        padding-bottom: 120px;
    }
    .pb-150 {
        padding-bottom: 120px;
    }
    .pb-160 {
        padding-bottom: 120px;
    }
    .pb-170 {
        padding-bottom: 120px;
    }
    .pb-180 {
        padding-bottom: 120px;
    }
    .pb-190 {
        padding-bottom: 120px;
    }
    .pb-200 {
        padding-bottom: 120px;
    }
    .pb-210 {
        padding-bottom: 120px;
    }
    .pb-220 {
        padding-bottom: 120px;
    }
    .pb-230 {
        padding-bottom: 120px;
    }
    .pb-240 {
        padding-bottom: 120px;
    }
    .pb-250 {
        padding-bottom: 120px;
    }
    .pb-260 {
        padding-bottom: 120px;
    }
    .pb-270 {
        padding-bottom: 120px;
    }
    .pb-280 {
        padding-bottom: 120px;
    }
    .pb-290 {
        padding-bottom: 120px;
    }
    .pb-300 {
        padding-bottom: 120px;
    }
    .mt-120 {
        margin-top: 120px;
    }
    .mt-130 {
        margin-top: 120px;
    }
    .mt-140 {
        margin-top: 120px;
    }
    .mt-150 {
        margin-top: 120px;
    }
    .mt-160 {
        margin-top: 120px;
    }
    .mt-170 {
        margin-top: 120px;
    }
    .mt-180 {
        margin-top: 120px;
    }
    .mt-190 {
        margin-top: 120px;
    }
    .mt-200 {
        margin-top: 120px;
    }
    .mt-210 {
        margin-top: 120px;
    }
    .mt-220 {
        margin-top: 120px;
    }
    .mt-230 {
        margin-top: 120px;
    }
    .mt-240 {
        margin-top: 120px;
    }
    .mt-250 {
        margin-top: 120px;
    }
    .mt-260 {
        margin-top: 120px;
    }
    .mt-270 {
        margin-top: 120px;
    }
    .mt-280 {
        margin-top: 120px;
    }
    .mt-290 {
        margin-top: 120px;
    }
    .mt-300 {
        margin-top: 120px;
    }
    .mb-120 {
        margin-bottom: 120px;
    }
    .mb-130 {
        margin-bottom: 120px;
    }
    .mb-140 {
        margin-bottom: 120px;
    }
    .mb-150 {
        margin-bottom: 120px;
    }
    .mb-160 {
        margin-bottom: 120px;
    }
    .mb-170 {
        margin-bottom: 120px;
    }
    .mb-180 {
        margin-bottom: 120px;
    }
    .mb-190 {
        margin-bottom: 120px;
    }
    .mb-200 {
        margin-bottom: 120px;
    }
    .mb-210 {
        margin-bottom: 120px;
    }
    .mb-220 {
        margin-bottom: 120px;
    }
    .mb-230 {
        margin-bottom: 120px;
    }
    .mb-240 {
        margin-bottom: 120px;
    }
    .mb-250 {
        margin-bottom: 120px;
    }
    .mb-260 {
        margin-bottom: 120px;
    }
    .mb-270 {
        margin-bottom: 120px;
    }
    .mb-280 {
        margin-bottom: 120px;
    }
    .mb-290 {
        margin-bottom: 120px;
    }
    .mb-300 {
        margin-bottom: 120px;
    }
    /******************/
    .title_30 {
        font-size: 24px;
    }
    .title_35 {
        font-size: 22px;
    }
    .title_40 {
        font-size: 30px;
    }
    .title_45 {
        font-size: 30px;
    }
    .title_50 {
        font-size: 32px;
    }
    .title_110 {
        font-size: 58px;
    }
    .cy_header_btn {
        top: 30px;
        right: 150px;
        z-index: 1000;
    }
    .logo {
        width: 160px;
    }
    .mv_copy {
        max-width: 500px;
    }
    .sec01 .pc_title {
        margin: 0 auto 80px;
    }
    .sec01 .pc_subtitle {
        margin: 0 auto 80px;
    }
    .sec02 li {
        padding: 40px 0 50px;
    }
    .footer_link {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 1.5vw;
        row-gap: 1.5vw;
    }
    /*************************************************************

      contact

  *************************************************************/
    .h_main p {
        font-size: 120px;
        letter-spacing: 0.04em;
        font-family: "Anton-Regular";
        line-height: 1.15;
    }
    .h_main h2 {
        font-size: 28px;
    }
    .contact_flex li {
        width: 50%;
        padding: 3vw 4vw;
        text-align: center;
    }
    .contact_flex li .line_banner {
        width: 100%;
    }
    .contact_flex li .line_banner a {
        font-size: 16px;
        padding: 25px 10px;
        letter-spacing: 0.05em;
    }
    .contact_flex li .line_banner a::before {
        width: 30px;
        height: 30px;
        left: 20px;
    }
    .contact_flex li .line_banner a::after {
        width: 18px;
        height: 18px;
        right: 15px;
    }
    .tel_num {
        font-size: 36px;
        font-family: "Anton-Regular";
    }
    .tel_num span {
        font-size: 22px;
    }
    .tel_txt {
        font-size: 22px;
    }
    .contact_table > div {
        display: flex;
        justify-content: space-between;
        align-items: center;
        border-bottom: 1px solid #707070;
        padding: 40px 0 40px 30px;
    }
    .contact_table > div:first-of-type {
        border-top: 1px solid #707070;
    }
    .e_cell1 {
        width: 260px;
    }
    .e_cell2 {
        width: calc(100% - 260px);
    }
    /******************************************************************************************************

      トップページ

  /****************************************************************************************************/
    .sec01_title1 {
        text-align: left;
    }
    .sec01_title1 img {
        width: 55%;
        height: auto;
    }
    .moveTitle1 {
        position: absolute;
        top: 3px;
        left: 3px;
    }
    .moveTitle2 {
        position: absolute;
        top: -3px;
        left: -3px;
    }
    /*****************************/
    .blog {
        column-gap: 25px;
        row-gap: 40px;
    }
    /***************************/
    .sec07_cont {
        width: calc(100% - 80px);
        max-width: 1760px;
        position: relative;
        overflow: hidden;
    }
    .sec07_img img {
        height: 500px;
        width: 100%;
        object-fit: cover;
    }
    .sec07_bg_absolute {
        position: static;
        right: 0;
        bottom: 0;
        background-color: #1b1b1b;
        padding: 80px 0 0 80px;
        z-index: 500;
        margin-top: -150px;
        width: calc(100% - 80px);
        margin-left: auto;
    }
    .sec07_access {
        border-top: 1px solid #FFF;
        padding-top: 40px;
        margin-top: 40px;
    }
    .sec07_access h2 {
        font-size: 25px;
    }
    /*****************/
    .sec08_flex {
        display: block;
    }
    .sec08_flex > div {
        width: 100%;
        height: 400px;
    }
    .sec08_flex > div > a, .sec08_flex .banner_span {
        padding: 60px 20px;
    }
    .sec08_more {
        right: 40px;
        bottom: 40px;
    }
    /*******/
    .f_flex {
        padding: 100px 0;
        display: block;
    }
    .f_left {
        width: 100%;
    }
    .f_left p {
        font-size: 16px;
    }
    .f_right {
        width: 100%;
        max-width: 100%;
        margin-top: 50px;
    }
    /**************************************************************************

      PHYSIXとは　

  /**************************************************************************/
    .ab01_flex {
        display: block;
    }
    .ab01_flex > div {
        width: 100%;
        padding: 100px 0;
    }
    .check_list li {
        font-size: 22px;
    }
    /***************/
    .bb_title {
        font-size: 35px;
    }
    .ab01_figure {
        margin-top: 40px;
    }
    /**********/
    .ab02_bg {
        padding: 40px;
    }
    .ab02_grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        column-gap: 45px;
        row-gap: 40px;
    }
    .ab02_grid > div {
        position: relative;
    }
    .ab02_grid > div:after {
        content: "";
        background: url("../images/about12.webp") 50% 0/30px 30px no-repeat;
        position: absolute;
        right: -37px;
        width: 30px;
        height: 30px;
        top: 50%;
        text-align: center;
        transform: translateY(-50%);
    }
    .ab02_grid > div:last-child:after {
        display: none;
    }
    .ab02_grid > div img {
        width: 100%;
        height: auto;
    }
    .ab02_grid > div:nth-child(2) {
        animation-delay: 0.4s;
    }
    .ab02_grid > div:nth-child(3) {
        animation-delay: 0.5s;
    }
    .ab02_grid > div:nth-child(4) {
        animation-delay: 0.6s;
    }
    /**************/
    .ab03_grid {
        grid-template-columns: repeat(2, 1fr);
        column-gap: 40px;
        row-gap: 40px;
    }
    .ab03_grid p {
        font-size: min(2.6vw, 20px);
    }
    /**************************************************************************

      料金　

  /**************************************************************************/
    .fee_tale01 table {
        width: 100%;
    }
    .fee_tale01 table th, .fee_tale01 table td {
        padding: 25px 20px;
    }
    .fee_tale01 table th {
        font-size: 18px;
        width: 180px;
    }
    .fee_tale01 table td {
        font-size: 16px;
    }
    /********/
    .fee_tale02 table th, .fee_tale02 table td {
        padding: 20px 5px;
        font-size: 16px;
    }
    .fee_tale02 table tr:nth-child(1) th, .fee_tale02 table tr:nth-child(1) td {
        font-size: 18px;
    }
    .fee_tale02 table th {
        width: 320px;
    }
    .fee_tale02 table td {
        width: 13%;
    }
    /********************************/
    .fee_tale03 table th, .fee_tale03 table td {
        font-size: 16px;
    }
    .fee_tale03 table tr:nth-child(1) th, .fee_tale03 table tr:nth-child(1) td, .fee_tale03 table tr:nth-child(2) th, .fee_tale03 table tr:nth-child(2) td {
        padding: 20px 5px;
        font-size: 18px;
    }
    .fee_tale03 table th {
        width: 130px;
    }
    /*************/
    .fee_tale01.td_center td {
        width: 36%;
    }
    .fee_tale01.td_center td:nth-of-type(1), .fee_tale01.td_center td:nth-of-type(2) {
        width: 21%;
    }
    .fee_tale04 table {
        width: 100%;
    }
    .fee_tale04 table th, .fee_tale04 table td {
        padding: 25px 20px;
    }
    .fee_tale04 table th {
        font-size: 18px;
        width: 180px;
    }
    .fee_tale04 table td {
        font-size: 16px;
    }
    .fee_tale04 .td_border_calc:after {
        top: -90px;
        height: calc(100% + 90px);
    }
    .fee_tale04.td_center td {
        width: 36%;
    }
    .fee_tale04.td_center td:nth-of-type(1), .fee_tale04.td_center td:nth-of-type(2) {
        width: 21%;
    }
    .title_22 {
        font-size: 18px;
    }
    /* バナー追加 */
    .top_banner {
        margin: 0 auto 80px;
    }
    /**************************************************************************

      トレーナー紹介　

  /**************************************************************************/
    .trainer_left img {
        height: 450px;
    }
    .trainer_name {
        font-size: min(9.5vw, 90px);
    }
    /**************************************************************************

      お問い合わせ　

  /**************************************************************************/
    .contact_flex {
        display: block;
    }
    .contact_flex > div {
        width: 100%;
        padding: 45px 10px;
    }
    .contact_flex > div:nth-child(1) {
        border-right: 0;
        border-bottom: 1px solid #FFF;
    }
    /****************/
    .contact_form > div {
        padding: 50px 25px;
    }
    /**************************************************************************

      初動負荷トレーニング　

  /**************************************************************************/
    .ini03_grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 30px;
    }
    /**********************/
    .ini05_flex {
        flex-wrap: wrap;
    }
    .ini05_inner {
        width: 100%;
        max-width: 100%;
    }
    /****************************/
    .ini07_grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        column-gap: 20px;
        row-gap: 30px;
    }
}
@media only screen and (max-width: 740px) {
    .flex_30 {
        width: 100%;
    }
    .flex_31 {
        width: 100%;
    }
    .flex_32 {
        width: 100%;
    }
    .flex_33 {
        width: 100%;
    }
    .flex_34 {
        width: 100%;
    }
    .flex_35 {
        width: 100%;
    }
    .flex_36 {
        width: 100%;
    }
    .flex_37 {
        width: 100%;
    }
    .flex_38 {
        width: 100%;
    }
    .flex_39 {
        width: 100%;
    }
    .flex_40 {
        width: 100%;
    }
    .flex_41 {
        width: 100%;
    }
    .flex_42 {
        width: 100%;
    }
    .flex_43 {
        width: 100%;
    }
    .flex_44 {
        width: 100%;
    }
    .flex_45 {
        width: 100%;
    }
    .flex_46 {
        width: 100%;
    }
    .flex_47 {
        width: 100%;
    }
    .flex_48 {
        width: 100%;
    }
    .flex_49 {
        width: 100%;
    }
    .flex_50 {
        width: 100%;
    }
    .flex_51 {
        width: 100%;
    }
    .flex_52 {
        width: 100%;
    }
    .flex_53 {
        width: 100%;
    }
    .flex_54 {
        width: 100%;
    }
    .flex_55 {
        width: 100%;
    }
    .flex_56 {
        width: 100%;
    }
    .flex_57 {
        width: 100%;
    }
    .flex_58 {
        width: 100%;
    }
    .flex_59 {
        width: 100%;
    }
    .flex_60 {
        width: 100%;
    }
    .flex_61 {
        width: 100%;
    }
    .flex_62 {
        width: 100%;
    }
    .flex_63 {
        width: 100%;
    }
    .flex_64 {
        width: 100%;
    }
    .flex_65 {
        width: 100%;
    }
    .flex_66 {
        width: 100%;
    }
    .flex_67 {
        width: 100%;
    }
    .flex_68 {
        width: 100%;
    }
    .flex_69 {
        width: 100%;
    }
    .flex_70 {
        width: 100%;
    }
    .padding100 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding110 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding120 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding130 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding140 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding150 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding160 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding170 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding180 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding190 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding200 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding210 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding220 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding230 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding240 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding250 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding260 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding270 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding280 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding290 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .padding300 {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .margin100 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin110 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin120 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin130 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin140 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin150 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin160 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin170 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin180 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin190 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin200 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin210 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin220 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin230 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin240 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin250 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin260 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin270 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin280 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin290 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .margin300 {
        margin-top: 100px;
        margin-bottom: 100px;
    }
    .pt-110 {
        padding-top: 100px;
    }
    .pt-120 {
        padding-top: 100px;
    }
    .pt-130 {
        padding-top: 100px;
    }
    .pt-140 {
        padding-top: 100px;
    }
    .pt-150 {
        padding-top: 100px;
    }
    .pt-160 {
        padding-top: 100px;
    }
    .pt-170 {
        padding-top: 100px;
    }
    .pt-180 {
        padding-top: 100px;
    }
    .pt-190 {
        padding-top: 100px;
    }
    .pt-200 {
        padding-top: 100px;
    }
    .pt-210 {
        padding-top: 100px;
    }
    .pt-220 {
        padding-top: 100px;
    }
    .pt-230 {
        padding-top: 100px;
    }
    .pt-240 {
        padding-top: 100px;
    }
    .pt-250 {
        padding-top: 100px;
    }
    .pt-260 {
        padding-top: 100px;
    }
    .pt-270 {
        padding-top: 100px;
    }
    .pt-280 {
        padding-top: 100px;
    }
    .pt-290 {
        padding-top: 100px;
    }
    .pt-300 {
        padding-top: 100px;
    }
    .pb-110 {
        padding-bottom: 100px;
    }
    .pb-120 {
        padding-bottom: 100px;
    }
    .pb-130 {
        padding-bottom: 100px;
    }
    .pb-140 {
        padding-bottom: 100px;
    }
    .pb-150 {
        padding-bottom: 100px;
    }
    .pb-160 {
        padding-bottom: 100px;
    }
    .pb-170 {
        padding-bottom: 100px;
    }
    .pb-180 {
        padding-bottom: 100px;
    }
    .pb-190 {
        padding-bottom: 100px;
    }
    .pb-200 {
        padding-bottom: 100px;
    }
    .pb-210 {
        padding-bottom: 100px;
    }
    .pb-220 {
        padding-bottom: 100px;
    }
    .pb-230 {
        padding-bottom: 100px;
    }
    .pb-240 {
        padding-bottom: 100px;
    }
    .pb-250 {
        padding-bottom: 100px;
    }
    .pb-260 {
        padding-bottom: 100px;
    }
    .pb-270 {
        padding-bottom: 100px;
    }
    .pb-280 {
        padding-bottom: 100px;
    }
    .pb-290 {
        padding-bottom: 100px;
    }
    .mt-110 {
        margin-top: 100px;
    }
    .mt-120 {
        margin-top: 100px;
    }
    .mt-130 {
        margin-top: 100px;
    }
    .mt-140 {
        margin-top: 100px;
    }
    .mt-150 {
        margin-top: 100px;
    }
    .mt-160 {
        margin-top: 100px;
    }
    .mt-170 {
        margin-top: 100px;
    }
    .mt-180 {
        margin-top: 100px;
    }
    .mt-190 {
        margin-top: 100px;
    }
    .mt-200 {
        margin-top: 100px;
    }
    .mt-210 {
        margin-top: 100px;
    }
    .mt-220 {
        margin-top: 100px;
    }
    .mt-230 {
        margin-top: 100px;
    }
    .mt-240 {
        margin-top: 100px;
    }
    .mt-250 {
        margin-top: 100px;
    }
    .mt-260 {
        margin-top: 100px;
    }
    .mt-270 {
        margin-top: 100px;
    }
    .mt-280 {
        margin-top: 100px;
    }
    .mt-290 {
        margin-top: 100px;
    }
    .mt-300 {
        margin-top: 100px;
    }
    .mb-110 {
        margin-bottom: 100px;
    }
    .mb-120 {
        margin-bottom: 100px;
    }
    .mb-130 {
        margin-bottom: 100px;
    }
    .mb-140 {
        margin-bottom: 100px;
    }
    .mb-150 {
        margin-bottom: 100px;
    }
    .mb-160 {
        margin-bottom: 100px;
    }
    .mb-170 {
        margin-bottom: 100px;
    }
    .mb-180 {
        margin-bottom: 100px;
    }
    .mb-190 {
        margin-bottom: 100px;
    }
    .mb-200 {
        margin-bottom: 100px;
    }
    .mb-210 {
        margin-bottom: 100px;
    }
    .mb-220 {
        margin-bottom: 100px;
    }
    .mb-230 {
        margin-bottom: 100px;
    }
    .mb-240 {
        margin-bottom: 100px;
    }
    .mb-250 {
        margin-bottom: 100px;
    }
    .mb-260 {
        margin-bottom: 100px;
    }
    .mb-270 {
        margin-bottom: 100px;
    }
    .mb-280 {
        margin-bottom: 100px;
    }
    .mb-290 {
        margin-bottom: 100px;
    }
    .mb-300 {
        margin-bottom: 100px;
    }
    /*****************/
    .title_110 {
        font-size: 54px;
    }
    .en_title_120 {
        font-size: 56px;
    }
    .title_22 {
        font-size: 17px;
    }
    .pc_none {
        display: none;
    }
    .sp_none {
        display: block;
    }
    .mv_copy {
        top: 46%;
        left: 50%;
        transform: translateX(-50%);
        width: 90%;
    }
    .catch_under {
        margin-top: 20px;
        font-size: 16px;
    }
    .logo {
        top: 30px;
        left: 6vw;
    }
    .cy_header_btn {
        position: fixed;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        top: auto;
    }
    /* 流れる文字 */
    /* ---------------------------- */
    .loop_wrapper {
        font-size: 110px;
    }
    .sec01 .pc_title {
        max-width: 400px;
        margin: 0 auto 60px;
    }
    .sec01 .pc_title img {
        width: 100%;
    }
    .sec01 .pc_subtitle {
        max-width: 460px;
        margin: 0 auto 60px;
    }
    .sec01 .pc_subtitle img {
        width: 100%;
    }
    .sec02 li {
        display: block;
    }
    .sec02_left {
        width: 100%;
    }
    .sec02_right {
        width: 100%;
        max-width: 100%;
        margin-top: 40px;
    }
    .sec03 {
        display: block;
    }
    .sec03 li {
        width: 100%;
        border: 1px solid #fff;
        padding: 60px 20px;
        text-align: center;
    }
    .clinic_table {
        width: 100%;
        font-size: 18px;
    }
    .clinic_table tr:first-of-type {
        border-top: 1px solid #fff;
    }
    .clinic_table tr th {
        display: block;
        width: 100%;
        min-width: 8em;
        padding: 20px 10px 10px 10px;
        border: none;
        vertical-align: baseline;
    }
    .clinic_table tr td {
        display: block;
        width: 100%;
        padding: 0 10px 20px 10px;
        border-bottom: 1px solid #fff;
    }
    .clinic_table tr td .map {
        height: 300px;
    }
    .clinic_table tr td .map iframe {
        width: 100%;
        height: inherit;
    }
    .sec05_bg {
        padding: 100px 0;
    }
    .footer_link {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        row-gap: 3vw;
    }
    /* バナー追加 */
    .top_banner {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
    }
    /*************************************************************

      contact

  *************************************************************/
    .h_main p {
        font-size: 70px;
    }
    .h_main h2 {
        font-size: 24px;
    }
    .h_padding {
        padding-top: 180px;
    }
    .bg_item {
        position: absolute;
        bottom: 0;
        right: 0;
        width: 400px;
    }
    .contact_flex {
        display: block;
        border: 1px solid #fff;
    }
    .contact_flex li {
        width: 100%;
        padding: 60px 20px;
        white-space: nowrap;
    }
    .contact_flex li:first-of-type {
        border-right: none;
        border-bottom: 1px solid #fff;
    }
    .contact_flex li .line_banner {
        max-width: 450px;
        margin: 0 auto;
    }
    .contact_flex li .line_banner a {
        font-size: 18px;
    }
    .contact_flex li .line_banner a::before {
        width: 40px;
        height: 40px;
        left: 30px;
    }
    .contact_flex li .line_banner a::after {
        width: 24px;
        height: 17px;
        right: 30px;
    }
    .contact_table > div {
        display: block;
        padding: 20px 0 20px 0;
    }
    .contact_table > div:first-of-type {
        border-top: 1px solid #707070;
    }
    .e_cell1 {
        font-size: 17px;
    }
    .e_cell2 {
        width: 100%;
        margin-top: 10px;
    }
    .hissu {
        font-size: 15px;
        width: 40px;
        margin-right: 20px;
    }
    .size input {
        height: 70px;
    }
    .size input, .area textarea {
        width: 100%;
        max-width: 870px;
        background-color: #111111;
        border: 1px solid #111111;
    }
    .area textarea {
        height: 200px;
    }
    .submit input {
        font-size: 17px;
        padding: 30px 10px;
        border-radius: 60px;
    }
    .submit .shape {
        position: absolute;
        right: 50px;
        top: 50%;
        transform: translateY(-50%);
    }
    .submit .shape img {
        width: 22px;
        height: auto;
        transition: 0.5s ease;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 0;
    }
    .tel_num {
        font-size: 38px;
        font-family: "Anton-Regular";
    }
    .tel_num span {
        font-size: 30px;
    }
    /******************************************************************************************************

      トップページ

  /****************************************************************************************************/
    .sec01_img {
        column-gap: 0;
        width: calc(100% + 40px);
        margin-left: -20px;
    }
    .sec01_img img {
        max-width: 100%;
        height: auto;
    }
    .sec01_img > div {
        position: relative;
    }
    .sec01_img > div:nth-child(2) {
        width: 80px;
    }
    .sec01_img > div:nth-child(2) img {
        width: 100%;
        height: auto;
    }
    .more {
        font-size: 17px;
    }
    .more a {
        padding: 15px 0;
    }
    .more .arrow {
        right: 30px;
    }
    /**************/
    .sec02_container {
        width: calc(100% - 30px);
    }
    /* ------------------------------
     loopSlider
  ------------------------------ */
    .loopSliderWrap {
        height: 292px;
    }
    .loopSlider {
        height: 292px;
    }
    .loopSlider ul {
        height: 292px;
    }
    .loopSlider ul li {
        width: 500px;
        height: 292px;
    }
    /****/
    .eng_140 {
        font-size: 60px;
        line-height: 1em;
        letter-spacing: 0.04em;
    }
    .sec02_title {
        margin-top: -40px;
    }
    .title30 {
        font-size: 24px;
    }
    /*****************************/
    .blog {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 25px;
        row-gap: 30px;
    }
    .blog .img100 img {
        max-height: 300px;
        min-height: 200px;
    }
    .blog.top_blog > div:nth-child(4) {
        display: block;
    }
    .blog_time {
        font-size: 14px;
        margin-top: 15px;
    }
    .blog_title {
        font-size: 17px;
        line-height: 1.6em;
        margin-top: 0;
    }
    /****************/
    .sec06_flex {
        display: block;
    }
    .sec06_left {
        width: 100%;
        padding: 0;
    }
    .sec06_right {
        width: 100%;
        margin-top: 60px;
    }
    .sec06_right img {
        width: calc(100% + 30px);
        height: 350px;
        object-fit: cover;
    }
    /***************/
    .sec07_flex {
        border: 1px solid #ffffff;
        display: block;
    }
    .sec07_flex > div {
        width: 100%;
        padding: 40px 20px;
        text-align: center;
    }
    .sec07_flex > div:nth-child(1) {
        border-right: 0;
        border-bottom: 1px solid #FFF;
    }
    .sec07_flex h3 {
        font-size: 28px;
        margin-top: 15px;
    }
    .sec07_time {
        font-size: 40px;
        line-height: 1.6em;
        margin-top: 5px;
    }
    .sec07_text {
        margin-top: 15px;
    }
    /***************************/
    .sec07_cont {
        width: calc(100% - 30px);
    }
    .sec07_img img {
        height: 400px;
    }
    .sec07_bg_absolute {
        padding: 40px 0 0 40px;
        margin-top: -100px;
        width: calc(100% - 30px);
    }
    .sec07_access {
        border-top: 1px solid #FFF;
        padding-top: 40px;
        margin-top: 40px;
    }
    .sec07_access h2 {
        font-size: 22px;
    }
    /*****************/
    .sec08_flex {
        display: block;
    }
    .sec08_flex > div {
        width: 100%;
        height: 400px;
    }
    .sec08_flex > div > a, .sec08_flex .banner_span {
        padding: 60px 30px;
    }
    .eng_100 {
        font-size: 60px;
        line-height: 1em;
    }
    .sec08_more {
        right: 50px;
        bottom: 50px;
        width: 60px;
        height: 60px;
    }
    .sec08_more .arrow {
        right: 40px;
    }
    .sec08_more_flex {
        margin-top: 50px;
    }
    /**********************************/
    .f_banner {
        padding: 35px 0;
    }
    /*******/
    .f_flex {
        padding: 60px 0;
    }
    .f_logo img {
        width: 200px;
        height: auto;
    }
    .f_right {
        width: 100%;
        max-width: 100%;
        margin-top: 50px;
    }
    .f_nav {
        display: block;
    }
    .f_nav p {
        line-height: 1.3em;
    }
    .f_nav .font_anton {
        font-size: 14px;
    }
    .f_nav .ja {
        font-size: 17px;
        display: block;
        margin-top: 5px;
    }
    .f_nav > div > p:nth-child(n+2) {
        margin-top: 30px;
    }
    .f_nav > div:nth-child(n+2) {
        margin-top: 30px;
    }
    .f_copy {
        padding: 20px 0;
        font-size: 15px;
    }
    /**************************************************************************

      PHYSIXとは　

  /**************************************************************************/
    .main_in {
        padding: 160px 0 0;
        text-align: center;
    }
    .title_box {
        padding: 0 20px 80px;
    }
    .title_eng {
        line-height: 1em;
        font-size: min(13vw, 170px);
    }
    .title_ja {
        font-size: 24px;
        margin-top: 10px;
    }
    .main_img {
        width: calc(100% - 30px);
    }
    .main_img img {
        max-height: 800px;
        height: 100%;
        min-height: 250px;
        width: 100%;
    }
    /**************************/
    .ab01_text {
        font-size: 17px;
    }
    /**************************************************************************

      PHYSIXとは　

  /**************************************************************************/
    .ab01_flex > div {
        padding: 80px 0;
    }
    .ab01_width {
        padding-left: 65px;
    }
    .check_list {
        max-width: 580px;
        margin-left: auto;
    }
    .check_list li {
        padding: 20px 20px 20px 65px;
        font-size: 18px;
    }
    .check_list li img {
        top: 28px;
        left: 20px;
    }
    .ab01_eng {
        left: -7px;
        top: 50%;
        font-size: 85px;
    }
    .fade-img-box {
        height: 58vw;
    }
    .fade-img-box2 {
        height: 58vw;
    }
    /***************/
    .bb_title {
        font-size: 26px;
        background-size: 200% 2px;
        line-height: 2em;
    }
    .ab01_figure {
        text-align: center;
        margin-top: 0px;
    }
    .ab01_figure img {
        max-width: 100%;
        height: auto;
    }
    /*********************/
    .ab02_list > div {
        padding: 40px 0;
    }
    .ab02_flex {
        display: block;
    }
    .ab02_flex .title_40 {
        font-size: 24px;
    }
    .ab02_left {
        width: 100%;
    }
    .ab02_right {
        width: 100%;
        max-width: 100%;
        margin-top: 30px;
    }
    .ab02_right img {
        height: 250px;
    }
    .ab02_bg {
        background-color: #111111;
        padding: 30px;
    }
    .ab02_grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 20px;
        row-gap: 20px;
        position: relative;
    }
    .ab02_grid > div {
        position: relative;
    }
    .ab02_grid > div:after {
        display: none;
    }
    .ab02_grid > div:last-child:after {
        display: none;
    }
    .ab02_grid > div img {
        width: 100%;
        height: auto;
    }
    .ab02_grid:after {
        content: "";
        background: url("../images/about12.webp") 50% 0/54px 53px no-repeat;
        position: absolute;
        left: 50%;
        width: 78px;
        height: 53px;
        top: 50%;
        text-align: center;
        transform: translate(-50%, -50%);
    }
    /**************/
    .ab03_grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 20px;
        row-gap: 30px;
    }
    .ab03_grid p {
        margin-top: 10px;
        font-size: 16px;
        line-height: 1.5em;
    }
    .ab03_grid br {
        display: block;
    }
    /**20260202追加***********************/
    .ab_bg_title .title_40 {
        min-height: 80px;
        padding: 5px;
        font-size: 22px;
    }
    .ab_grid {
        grid-template-columns: repeat(1, 1fr);
        row-gap: 40px;
    }
    .ab_grid p {
        text-align: center;
        margin-top: 10px;
    }
    .ab_more_btn a {
        height: 65px;
        font-size: 18px;
    }
    /**************************************************************************

      料金　

  /**************************************************************************/
    .fee_title {
        font-size: 30px;
        padding: 13px 0 0 85px;
        display: flex;
    }
    .fee_title .font_anton {
        font-size: 60px;
        top: 0;
        left: 0;
    }
    .fee_tale01 table th, .fee_tale01 table td {
        padding: 15px 20px;
    }
    .fee_tale01 table th {
        font-size: 17px;
        width: 100px;
    }
    .fee_tale01 table td {
        font-size: 16px;
    }
    .text20 {
        font-size: 17px;
    }
    .sp_title24 {
        font-size: 24px;
    }
    /********/
    .title_28 {
        font-size: 20px;
    }
    .be_bb:before {
        top: 16px;
        left: 0;
    }
    .be_bb2:before {
        top: 20px;
        left: 0;
    }
    .fee_tale02 {
        overflow-x: scroll;
    }
    .fee_tale02 table {
        width: 880px;
    }
    .fee_tale02 table th, .fee_tale02 table td {
        padding: 15px 5px;
        font-size: 17px;
        height: 80px;
    }
    .fee_tale02 table tr:nth-child(1) th, .fee_tale02 table tr:nth-child(1) td {
        font-size: 17px;
    }
    .fee_tale02 table th {
        width: 320px;
    }
    .fee_tale02 table td {
        width: 13%;
    }
    /********************************/
    .fee_tale03 {
        overflow-x: scroll;
    }
    .fee_tale03 table {
        width: 1000px;
        overflow: hidden;
    }
    .fee_tale03 table th, .fee_tale03 table td {
        padding: 15px 5px;
        font-size: 17px;
    }
    .fee_tale03 table p {
        line-height: 1.2em;
    }
    .fee_tale03 table .icon {
        margin-bottom: 13px;
    }
    .fee_tale03 table tr:nth-child(1) th, .fee_tale03 table tr:nth-child(1) td, .fee_tale03 table tr:nth-child(2) th, .fee_tale03 table tr:nth-child(2) td {
        padding: 15px 5px;
        font-size: 17px;
        background-color: #131313;
        height: auto;
    }
    .fee3_menu {
        padding: 8px 0 8px;
    }
    .fee3_arrow:before {
        width: calc(100% - 10px);
    }
    /*************/
    .fee_tale01.td_center {
        overflow-x: scroll;
    }
    .fee_tale01.td_center table {
        width: 870px;
    }
    .fee_tale01.td_center th.w360 {
        width: 360px;
    }
    .fee_tale01.td_center tr:nth-child(1) th, .fee_tale01.td_center tr:nth-child(1) td {
        padding: 15px 0;
    }
    .fee_tale01.td_center td {
        width: 37%;
    }
    .fee_tale01.td_center td:nth-of-type(1), .fee_tale01.td_center td:nth-of-type(2) {
        width: 18%;
    }
    .fee_tale04 {
        overflow-x: scroll;
    }
    .fee_tale04 table {
        width: 800px;
        overflow: hidden;
    }
    .fee_tale04 table th, .fee_tale04 table td {
        padding: 15px 20px;
    }
    .fee_tale04 table th {
        font-size: 17px;
        width: 100px;
        min-width: 100px;
    }
    .fee_tale04 table td {
        font-size: 16px;
    }
    .fee_tale04 .fee4_padding td {
        min-width: 200px;
    }
    .fee_tale04 .td_border_calc:after {
        top: -70px;
        height: calc(100% + 70px);
    }
    .fee4_flex_left {
        text-align: left;
    }
    .fee_02_midashibox {
        padding: 10px 8px;
        max-width: 500px;
    }
    .fee_02_midashibox p {
        font-size: 17px;
    }
    .fee_02_grid {
        grid-template-columns: repeat(1, 1fr);
        row-gap: 20px;
    }
    .fee_02_grid li {
        padding: 30px;
    }
    /**************************************************************************

      トレーナー紹介　

  /**************************************************************************/
    .trainer_flex > div {
        display: block;
    }
    .trainer_flex > div:nth-child(n+2) {
        margin-top: 60px;
    }
    .trainer_left {
        width: 100%;
        max-width: 100%;
    }
    .trainer_left img {
        width: 100%;
        height: auto;
        object-fit: cover;
    }
    .trainer_right {
        width: 100%;
        margin-top: 30px;
    }
    .trainer_name {
        color: rgba(255, 255, 255, 0);
        -webkit-text-stroke: 1px rgba(255, 255, 255, 0.7);
        text-stroke: 1px rgba(255, 255, 255, 0.7);
        line-height: 1em;
        font-size: min(14.5vw, 80px);
    }
    .trainer_table > div {
        display: block;
    }
    .trainer_table > div:nth-child(n+2) {
        margin-top: 25px;
    }
    .trainer_table p {
        font-size: 17px;
    }
    .tr_cell1 {
        width: 90px;
        top: 0;
    }
    .tr_cell2 {
        width: 100%;
        line-height: 1.8em;
        margin-top: 12px;
    }
    /**************************************************************************

      ブログ　

  /**************************************************************************/
    /*Pagenation*/
    .pagenation {
        margin: 60px auto 0;
    }
    .pagenation li {
        margin: 0 6px;
        font-size: 20px;
    }
    .pagenation li.active {
        width: 45px;
        height: 45px;
        padding-top: 2px;
    }
    .pagenation li a {
        width: 45px;
        height: 45px;
        padding-top: 2px;
    }
    /**************************************************************************

      施設・設備紹介　

  /**************************************************************************/
    .facility_grid {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        row-gap: 40px;
    }
    .facility_grid > div {
        max-width: 100%;
        width: 100%;
    }
    .facility_grid p {
        font-size: 22px;
        line-height: 1.6em;
        margin-top: 15px;
    }
    /**************************************************************************

      営業時間・アクセス　

  /**************************************************************************/
    .access_table > div {
        display: block;
        justify-content: space-between;
        padding: 20px 5px;
        border-bottom: 1px solid #FFF;
    }
    .access_table > div:nth-child(1) {
        border-top: 1px solid #FFF;
    }
    .access_table > div p {
        font-size: 17px;
    }
    .access_table > div .ac_cell1 {
        font-size: 20px;
    }
    .ac_cell1 {
        width: 100%;
    }
    .ac_cell2 {
        width: 100%;
        margin-top: 5px;
    }
    .map iframe {
        width: 100%;
        height: 300px;
    }
    /**************************************************************************

      お問い合わせ　

  /**************************************************************************/
    .contact_flex > div {
        padding: 40px 10px;
    }
    .contact_flex h3 {
        font-size: 22px;
    }
    .c_tel {
        font-size: 25px;
        margin-top: 25px;
    }
    .c_tel span {
        font-size: 40px;
    }
    .more.line_more {
        max-width: 350px;
        margin: 30px auto 0;
    }
    .more.line_more a {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 20px 40px 20px 45px;
        font-size: 20px;
    }
    .more.line_more .line {
        position: absolute;
        left: 25px;
        top: 50%;
        transform: translateY(-50%);
    }
    .more.line_more .line img {
        width: 40px;
        height: auto;
    }
    /****************/
    .contact_form > div {
        display: block;
        padding: 25px 15px;
    }
    .c_f_cell1 {
        width: 100%;
    }
    .c_f_cell2 {
        width: 100%;
        margin-top: 20px;
    }
    .eq {
        font-size: 14px;
        margin-right: 20px;
    }
    .size {
        /* padding: 0 15px; */
        /* margin: 15px; */
        height: 50px;
    }
    .area {
        /* padding: 15px; */
        height: 180px;
    }
    .check_pri {
        padding-left: 15px;
    }
    .check_pri a {
        font-size: 18px;
    }
    input[type=checkbox] {
        width: 30px;
        height: 30px;
        vertical-align: -12px;
    }
    input[type=checkbox]:checked:before {
        top: 2px;
        width: 10px;
        height: 20px;
    }
    .submit_p {
        font-size: 20px;
        max-width: 400px;
    }
    .submit_p input {
        padding: 25px 10px;
    }
    .submit_p .arrow {
        right: 30px;
        top: calc(50% + 1px);
    }
    /***************************************************************

  	初動負荷トレーニング

  ***************************************************************/
    .ini01 .title_50 {
        font-size: 26px;
    }
    /*********************/
    .ini2_absolute {
        opacity: 0.1;
    }
    .glitch::before, .glitch::after {
        white-space: pre-line; /* \n（改行）を改行として表示 */
        content: attr(data-text);
    }
    /***************************/
    .ini03_flex_wrap {
        border-top: 1px solid #FFF;
    }
    .ini03_flex_wrap > div {
        border-bottom: 1px solid #FFF;
        padding: 60px 0;
    }
    .ini03_flex_wrap .title_40 {
        font-size: 24px;
    }
    .ini03_flex {
        flex-wrap: wrap;
        gap: 30px 30px;
    }
    .ini03_right {
        order: 1;
        max-width: 100%;
        width: 100%;
    }
    .ini03_left {
        width: 100%;
        order: 2;
    }
    .ini03_bg {
        background-color: #111111;
        padding: 30px 30px;
    }
    .ini03_grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    /*****************/
    .ini04 .title_50 {
        font-size: 26px;
    }
    /**********************/
    .ini05_bg_list {
        gap: 20px;
    }
    /********************/
    .ini06_grid {
        grid-template-columns: repeat(1, 1fr);
    }
    .ini06_grid > div {
        width: 100%;
    }
    .ini06_grid > div:after {
        top: calc(100% - 80px);
        transform: translateX(50%);
        right: 50%;
        background-size: 100% 100%;
        width: 70px;
        height: 70px;
    }
    .ini06_grid > div:nth-child(2):after {
        top: calc(100% - 80px);
        right: 50%;
    }
    .ini06_grid > div:nth-child(2) {
        margin-left: 0;
        margin-top: -100px;
        z-index: 500;
    }
    .ini06_grid > div:nth-child(3) {
        margin-left: 0;
        margin-top: -100px;
    }
    .ini06_circle img {
        width: 100%;
        height: auto;
    }
    .ini06_absolute .img {
        width: 100%;
        padding: 0 60px 20px;
    }
    .ini06_flex {
        flex-wrap: wrap;
        gap: 20px 0;
    }
    .ini06_bg_inner {
        width: 100%;
        padding: 30px 40px;
    }
    .ini06_bg_inner h4 {
        font-size: 20px;
        font-weight: bold;
        margin-bottom: 20px;
        color: #134e4a;
        letter-spacing: 0.1em;
    }
    .ini06_bg_inner p {
        color: #000;
        font-size: 16px;
        letter-spacing: 0.04em;
    }
    /****************************/
    .ini07_grid {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 20px;
        row-gap: 20px;
    }
    .ini07_inner {
        padding: 20px;
    }
    .ini07_inner h3 {
        font-size: 22px;
        margin: 20px 0 10px;
    }
    /*************************/
    .ini08_list {
        gap: 20px;
    }
    .ini08_inner {
        padding: 25px 25px;
    }
    /*********************/
    .ini09_flex_wrap {
        gap: 20px;
    }
    .ini09_flex {
        gap: 30px;
        padding: 35px 35px;
        display: block;
    }
    .ini09_right {
        margin-top: 15px;
        column-gap: 20px;
    }
    .ini09_price {
        font-size: 22px;
    }
    .ini09_price .small {
        font-size: 20px;
        margin-right: 20px;
    }
    /***********************************************************

  	料金プラン

  ***********************************************************/
    .fee_title_flex {
        gap: 20px;
        align-items: flex-start;
    }
    .fee_title_flex .sp_title24 {
        font-size: 22px;
    }
    .fee_num {
        font-size: 90px;
    }
    .fee_bg_title {
        font-size: 15px;
        padding: 3px 15px;
        letter-spacing: 0.05em;
    }
    .fee_inner_flex {
        gap: 10px 65px;
        margin-top: 15px;
    }
    .title_55 {
        font-size: 30px;
    }
    /******************/
    .fee01_flex {
        flex-wrap: wrap;
        gap: 40px;
    }
    .fee01_left {
        width: 100%;
        order: 2;
    }
    .fee_check_list {
        gap: 25px;
    }
    .fee_check_list li {
        gap: 15px;
        font-size: clamp(18px, 2.2vw, 28px);
    }
    .fee_check_list li:before {
        width: 37px;
        height: 32px;
    }
    .fee01_right {
        width: 100%;
        max-width: 100%;
    }
    .fee01_right img {
        height: auto;
    }
    /*******/
    .scroll_p {
        display: block;
        text-align: center;
        width: max-content;
        margin: 0 auto 30px;
        border-bottom: 1px solid #FFF;
        padding-bottom: 5px;
    }
    .fee01_table.table_height150 tr:nth-child(n+2) th, .fee01_table.table_height150 tr:nth-child(n+2) td {
        height: 80px;
    }
    .fee01_table th, .fee01_table td {
        padding: 10px 10px;
    }
    .fee01_table th {
        width: 310px;
        font-size: 15px;
    }
    .fee01_table td {
        font-size: 16px;
    }
    .fee01_table td.group {
        font-size: 17px;
    }
    .fee01_table td.personal30 {
        font-size: 17px;
    }
    .fee01_table td.personal50 {
        font-size: 17px;
    }
    /************************/
    .fee02_flex {
        flex-wrap: wrap;
        border-radius: 30px;
        color: #000;
        padding: 25px 30px;
        gap: 20px;
    }
    .fee02_right {
        text-align: right;
        width: 100%;
    }
    .fee02_price_flex {
        flex-wrap: wrap;
        gap: 5px 20px;
        text-align: right;
        width: 100%;
    }
    /**********************/
    .fee03_title_flex {
        column-gap: 15px;
        grid-row-gap: 10px;
    }
    /************************/
    .fee04_flex li {
        column-gap: 10px;
    }
    /**************************************/
    .fee05_btn_flex {
        justify-content: center;
        gap: 10px;
    }
    .fee05_btn_flex > p {
        width: 100%;
        max-width: 580px;
    }
}
/* スマートフォン 縦(ポートレート) */