header {
    align-items: center;
    background-color: #000000dd;
    display: flex;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 100
}

.headLogo {
    display: block;
    max-width: 164px;
    padding: 8px 0 8px 8px;
    width: 40%
}

.headLogo img {
    width: 100%
}

header>div {
    height: 100%;
    position: absolute;
    right: 0
}

header .menu,
header .menu li {
    display: flex;
    height: 100%
}

header .menu li {
    align-items: center;
    justify-content: center
}

header .menu li a {
    color: #fff;
    font-family: Cinzel, "Noto Serif JP", serif;
    font-size: 16px;
    font-weight: 500;
    padding: 12px;
    position: relative
}


.mv {
    display: block;
    height: calc(100svh - 64px);
    position: relative;
    width: 100%;
    background: #fff;
}
.mv span {
    display: block;
    background-size: cover;
    background-repeat: no-repeat;
}

.mv:after {
    right: 0;
    z-index: 21
}

.mv:after,
.mv:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
}

.mv:before {
    z-index: 22
}
@media screen and (min-width: 901px) {
    .mv span {
        position: absolute;
        top: 0;
        right: 0;
        width: 85%;
        height: 100%;
        background-image: url(../img/mv_img_pc.jpg);
        background-position: center;
    }
    .mv span:after {
        content: "";
        position: absolute;
        width: 10%;
        height: 100%;
        display: block;
        left: 0%;
        background-image: linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
    }
    .mv:after {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-image: url(../img/mv_bg_02.png);
        background-size: cover;
    }
    .mv:before {
        position: absolute;
        top: 0;
        left: 0;
        width: 50%;
        height: 100%;
        background-image: url(../img/mv_bg_01.png);
        background-size: cover;
        background-position: right;
    }
}
@media screen and (max-width: 900px) {
    .mv span {
        position: absolute;
        bottom: 0;
        right: 0;
        width: 100%;
        height: 50%;
        background-image: url(../img/mv_img_sp.jpg);
        background-position: center;
    }
    .mv span:after {
        content: "";
        position: absolute;
        width: 100%;
        height: 10%;
        display: block;
        left: 0%;
        top: 0;
        background-image: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
    }
    .mv:after {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-image: url(../img/mv_bg_02_sp.png);
        background-size: cover;
        background-position: left bottom;
    }
    .mv:before {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 65%;
        background-image: url(../img/mv_bg_01_sp.png);
        background-size: cover;
        background-position: right bottom;
    }
}

.mvTxt {
    left: 10%;
    position: absolute;
    text-align: center;
    top: 0;
    bottom: 0;
    margin: auto;
    height: 100%;
    z-index: 25;
    display: flex;
    width: 380px;
    align-items: center;
    justify-content: center;
}
.mvTxt img {
    width: 100%;
}

.mvTxt p {
    color: #fff;
    font-family: Shippori Mincho, serif;
    font-size: 24px;
    font-weight: 500;
    letter-spacing: .2em;
    padding-top: 24px
}
@media screen and (max-width: 1300px) {
    .mvTxt {
        left: 7%;
        width: 320px;
        max-width: 380px;
    }
}
@media screen and (max-width: 1200px) {
    .mvTxt {
        left: 4%;
        width: 300px;
    }
}
@media screen and (max-width: 900px) {
    .mv {
        height: 100svh;
    }
    .mvTxt {
        width: 80%;
        left: 0;
        right: 0;
        text-align: center;
        top: 4%;
        margin: 0 auto;
        height: 50%;
        z-index: 25;
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

.news {
    background-color: #e0e0e0;
    padding: 56px 0
}

.news .wrap {
    background-color: #fff;
    margin: auto;
    max-width: 1000px;
    padding: 40px;
    width: 92%
}

.news .container {
    display: block;
}

.news .container a {
    display: grid;
    gap: 10px;
    grid-template-columns: 140px 1fr;
    position: relative;
    width: 100%;
    margin-bottom: 18px;
    align-items: center;
}

.news h2 {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700
}

.news h3 {
    color: #4b4b4b;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .06em;
}

.news time {
    font-size: 14px;
    color: #a7a7a7;
}
.news p {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    display: -webkit-box;
    font-size: 14px;
    margin-top: 10px;
    overflow: hidden
}

.news .thumb {
    aspect-ratio: 4/3;
    display: block;
    object-position: center;
    overflow: hidden;
    width: 100%;
    border: 1px solid #ececec
}

.news .thumb img {
    height: auto;
    min-height: 100%;
    min-width: 100%;
    object-fit: cover;
    overflow: hidden;
    width: auto
}

.news span {
    align-items: center;
    bottom: 0;
    color: #4b4b4b;
    display: flex;
    font-family: Cinzel, serif;
    font-size: 18px;
    font-weight: 500;
    justify-content: right;
    line-height: 1em;
    padding-right: 20px;
    position: absolute;
    right: 0
}

.news span:after {
    background-color: #4b4b4b;
    content: "";
    display: inline-block;
    height: 9px;
    -webkit-mask: url(../img/icon-right.svg);
    mask: url(../img/icon-right.svg);
    -webkit-mask-size: cover;
    mask-size: cover;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    vertical-align: middle;
    width: 5px
}

.nayami .head {
    background-color: #525252;
    text-align: center;
    width: 100%
}

.nayami .head p {
    color: #fff;
    font-family: Shippori Mincho, serif;
    font-size: 24px;
    font-weight: 400;
    padding: 32px 0 26px
}

.nayami .main {
    background-image: url(../img/nayami-bg.jpg);
    background-position: 50%;
    background-size: cover;
    padding: 56px 0 122px;
    position: relative;
    width: 100%
}

.nayami .main:after {
    border-color: transparent transparent transparent #fff;
    border-width: 80px 0 0 51vw;
    left: 0
}

.nayami .main:after,
.nayami .main:before {
    border-style: solid;
    bottom: -1px;
    content: "";
    height: 0;
    position: absolute;
    width: 0
}

.nayami .main:before {
    border-color: transparent transparent #fff;
    border-width: 0 0 80px 51vw;
    right: 0
}

.nayami .main ul {
    display: grid;
    gap: 18px;
    grid-template-columns: 1fr 1fr;
    margin: auto;
    max-width: 1000px;
    width: 92%
}

.nayami .main li {
    align-items: center;
    color: #fff;
    display: flex;
    font-size: 18px;
    font-weight: 500;
    gap: 10px
}

.nayami .main li:before {
    background-color: #fff;
    content: "";
    display: inline-block;
    height: 13px;
    -webkit-mask: url(../img/icon-check.svg);
    mask: url(../img/icon-check.svg);
    -webkit-mask-size: cover;
    mask-size: cover;
    vertical-align: middle;
    width: 18px
}

.image .head {
    padding: 36px 0 32px;
    text-align: center
}

.image .head span {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 500;
    line-height: 1.4em
}

.image .head p {
    color: #c8ac31;
    font-family: Shippori Mincho, serif;
    font-size: 26px
}

.image .content {
    align-items: center;
    display: grid;
    gap: 40px;
    grid-template-columns: 1fr 480px 480px 1fr;
    padding-bottom: 40px
}

.image .content .txt {
    grid-column: 2/3
}

.image .content .txt h3 {
    color: #c8ac31;
    font-family: Shippori Mincho, serif;
    font-size: 26px;
    font-weight: 500;
    margin-bottom: 24px
}

.image .content .txt h3 span {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 32px;
    font-weight: 500
}

.image .content .txt p,
.image .content .txt p span {
    font-size: 16px;
    font-weight: 400
}

.image .content .txt p span {
    background: linear-gradient(transparent 94%, #c8ac31 0);
    display: inline
}

.image .content .img {
    display: block;
    grid-column: 3/5;
    object-fit: cover;
    overflow: hidden
}

.price {
    background-color: #e0e0e0;
    padding: 56px 0
}

.price .wrap {
    margin: auto;
    max-width: 1000px;
    width: 94%
}

.price .wrap>p {
    font-size: 14px;
    margin-top: 12px
}

.price h2 {
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700
}

.price h2,
.price h2 span {
    color: #c8ac31
}

.price .mds {
    display: flex;
    margin-bottom: 24px;
    margin-top: 48px
}

.price .mds h3 {
    font-family: Shippori Mincho, serif;
    font-size: 18px;
    font-weight: 500
}

.price .mds p {
    align-items: center;
    display: flex;
    font-family: Cinzel, serif;
    font-size: 22px;
    font-weight: 700;
    gap: 6px;
    margin-right: 6px;
    position: relative
}

.price .mds p:after {
    background-color: #4b4b4b;
    content: "";
    display: block;
    height: 1px;
    width: 28px
}

.price .pc table {
    width: 100%
}

.price .pc td {
    background-color: #fff;
    border: 1px solid #4b4b4b;
    line-height: 1.3em;
    padding: 9px 2px;
    text-align: center;
    vertical-align: middle;
    width: 14%
}

.price .pc .ttl {
    background-color: #525252;
    color: #fff;
    font-size: 18px;
    padding: 9px 2px
}

.price .pc .ttl span {
    color: #fff;
    display: block;
    font-size: 12px
}

.price .pc td:first-of-type {
    background-color: #525252;
    color: #fff;
    width: 145px
}

.price .pc .none {
    background-color: #e0e0e0 !important;
    border-left: 1px solid #e0e0e0;
    border-top: 1px solid #e0e0e0
}

.price .pc .off span {
    color: #49aa00;
    display: block
}

.price .pc .mid {
    background-color: #f2ffe7
}

.price .smt .tab {
    display: inline-block;
    width: 100%
}

.price .smt .button {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    margin-bottom: 0
}

.price .smt .tablinks {
    appearance: none;
    background-color: transparent;
    border: 1px solid #4b4b4b;
    border-right: 0;
    cursor: pointer;
    margin: 0;
    outline: none;
    padding: 0;
    text-align: center;
    width: 100%;
    line-height: 1.4em;
}

.price .smt .tablinks:last-of-type {
    border-right: 1px solid #4b4b4b
}

.price .smt .tablinks {
    background-color: #525252;
    color: #fff;
    font-family: Shippori Mincho, serif;
    font-size: 17px;
    padding: 9px 2px
}

.price .smt .tablinks span {
    color: #fff;
    display: block;
    font-family: Shippori Mincho, serif;
    font-size: 12px
}

.price .smt .tabcontent {
    background-color: #fff;
    border: 1px solid #4b4b4b;
    border-top: 0;
    padding: 24px 8px
}

.price .smt .tablinks.active {
    background-color: #fff;
    border-bottom: 0;
    color: #525252
}

.price .smt .tablinks.active span {
    color: #525252;
    font-size: 11px
}

.price .smt table {
    width: 100%
}

.price .smt td {
    background-color: #fff;
    border: 1px solid #4b4b4b;
    line-height: 1.3em;
    padding: 9px 2px;
    text-align: center;
    vertical-align: middle;
    width: 14%
}

.price .smt .ttl {
    background-color: #525252;
    color: #fff;
    font-size: 18px;
    padding: 9px 2px
}

.price .smt .ttl span {
    color: #fff;
    display: block;
    font-size: 12px
}

.price .smt td:first-of-type {
    background-color: #525252;
    color: #fff
}

.price .smt .none {
    background-color: #e0e0e0 !important;
    border-left: 1px solid #e0e0e0;
    border-top: 1px solid #e0e0e0
}

.price .smt .off span {
    color: #64c411;
    display: block
}

.price .smt .mid {
    background-color: #f2ffe7
}

.price .discount .content {
    display: block;
}
.price .discount .content .img {
    width: 100%;
    height: 100%;
}
.price .discount .content h4 {
    color: #49aa00;
    font-size: 18px;
    margin-bottom: 8px;
    background-color: #525252;
    color: #fff;
    padding: 4px 8px;
}
.price .discount .content p {
    margin-bottom: 24px;
}
.price .discount table {
    width: 100%
}

.price .discount td {
    background-color: #fff;
    border: 1px solid #4b4b4b;
    line-height: 1.3em;
    padding: 9px 2px;
    text-align: center;
    vertical-align: middle;
    width: calc(33% - 50px)
}

.price .discount .ttl {
    background-color: #525252;
    color: #fff;
    font-size: 18px;
    padding: 9px 2px
}

.price .discount .ttl span {
    color: #fff;
    display: block;
    font-size: 12px
}

.price .discount td:first-of-type {
    background-color: #525252;
    color: #fff;
    width: 145px
}

.price .discount .none {
    background-color: #e0e0e0 !important;
    border-left: 1px solid #e0e0e0;
    border-top: 1px solid #e0e0e0
}

.price .discount span {
    color: #49aa00;
    font-size: 18px
}

.price .option {
    display: grid;
    gap: 40px;
    grid-template-columns: 1fr 1fr;
    width: 100%
}

.price .option .content {
    display: flex;
    justify-content: space-between;
    position: relative
}

.price .option .content p {
    background-color: #e0e0e0;
    z-index: 3
}

.price .option .content p:first-of-type {
    padding-right: 8px
}

.price .option .content p:last-of-type {
    padding-left: 8px
}

.price .option .content:after {
    border-bottom: 1px dotted #4b4b4b;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    top: 18px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 100%;
    z-index: 2
}

.cta,
.cta h2 {
    width: 100%
}

.cta h2 {
    background-image: linear-gradient(150deg, #c8ac31, #638fa2 68%);
    color: #fff;
    font-family: Shippori Mincho, serif;
    font-size: 24px;
    padding: 28px 0 30px;
    text-align: center
}

.cta .top {
    background-image: url(../img/cta-bg-top.jpg);
    background-position: 50%;
    background-size: cover;
    padding: 50px 0 90px
}

.cta .top .wrap {
    align-items: center;
    display: grid;
    grid-template-columns: 1fr 388px;
    justify-content: space-between;
    margin: auto;
    max-width: 1000px;
    width: 92%
}

.cta .top .wrap p {
    color: #fff
}

.cta .top .wrap .content a {
    align-items: center;
    border-top: 1px solid #fff;
    display: grid;
    gap: 42px;
    grid-template-columns: 40px 1fr;
    justify-content: flex-start;
    padding: 10px 24px;
    position: relative
}

.cta .top .wrap .content a:last-of-type {
    border-bottom: 1px solid #fff
}

.cta .top .wrap .content a:after {
    background-image: url(../img/icon-right.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 9px;
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 4px
}

.cta .top .wrap .content a p {
    font-size: 18px;
    line-height: 1em
}

.cta .top .wrap .content a p span {
    color: #fff;
    display: block;
    font-size: 14px
}

.cta .top .wrap .content a:last-of-type p {
    font-size: 22px
}

.cta .bottom {
    display: flex;
    width: 100%
}

.cta .left,
.cta .right {
    background-image: url(../img/cta-bg-left.jpg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    display: inline-block;
    padding: 125px 12px;
    text-align: center;
    width: 50%
}

.cta .bottom a,
.cta .left,
.cta .right {
    color: #fff;
    font-size: 18px;
    position: relative
}

.cta .bottom a {
    border: 1px solid #fff;
    display: block;
    margin: auto;
    max-width: 300px;
    padding: 12px 24px;
    width: 80%
}

.cta .bottom a:after {
    background-image: url(../img/icon-right.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 9px;
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 4px
}

.cta .right {
    background-image: url(../img/cta-bg-right.jpg)
}

.cta .popup {
    background-color: #fff;
    color: #4b4b4b;
    font-family: Shippori Mincho, serif;
    font-size: 16px;
    left: 50%;
    padding: 8px 22px;
    position: absolute;
    top: 30%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%)
}

.cta .popup span {
    color: #64c411;
    font-family: Cinzel, serif;
    font-size: 22px
}

.cta .popup:after {
    border-color: #fff transparent transparent;
    border-style: solid;
    border-width: 4px 5.5px 0;
    bottom: -4px;
    content: "";
    height: 0;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    width: 0
}

.cta .right .popup {
    padding: 2px 22px
}

.plan {
    background-color: #e0e0e0;
    padding: 56px 0 28px;
    width: 100%
}

.plan .wrap {
    background-color: #fff;
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin: auto;
    max-width: 1000px;
    width: 92%
}

.plan .wrap>img {
    object-fit: cover
}

.plan .wrap h2 {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700
}

.plan .mds {
    display: flex;
    margin-bottom: 1px
}

.plan .mds h3 {
    align-items: center;
    display: flex;
    font-family: Shippori Mincho, serif;
    font-size: 18px;
    font-weight: 500;
    gap: 6px;
    margin-left: 6px
}

.plan .mds p {
    font-family: Cinzel, serif;
    font-size: 22px;
    font-weight: 700;
    margin-right: 6px;
    position: relative
}

.plan .mds h3:before {
    background-color: #4b4b4b;
    content: "";
    display: block;
    height: 1px;
    width: 28px
}

.plan ul {
    list-style: disc;
    margin-bottom: 18px;
    padding-left: 20px
}

.plan .content {
    padding: 40px
}

.plan .content p {
    text-align: right
}

.plan .content p span {
    color: #64c411;
    font-family: Roboto, sans-serif;
    font-size: 44px;
    font-style: italic
}

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

.plan .img img {
    height: auto;
    min-height: 100%;
    min-width: 100%;
    object-fit: cover;
    width: auto
}

.qa {
    background-color: #e0e0e0;
    padding: 28px 0 56px;
    width: 100%
}

.qa .wrap {
    background-color: #fff;
    margin: auto;
    max-width: 1000px;
    padding: 40px;
    width: 92%
}

.qa .wrap h2 {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700
}

.qa .box,
.qa .wrap h2 {
    padding-bottom: 33px
}

.qa .box li:first-of-type {
    border-bottom: 1px solid #000;
    font-size: 18px;
    font-weight: 500;
    padding: 8px 0
}

.qa .box li:first-of-type:before {
    content: "Q";
    font-family: Roboto, sans-serif;
    font-size: 26px;
    font-style: italic;
    font-weight: 700;
    padding-right: 9px
}

.qa .box li:last-of-type {
    font-size: 14px;
    font-weight: 500;
    padding: 8px 0
}

.qa .box li:last-of-type:before {
    content: "A";
    font-family: Roboto, sans-serif;
    font-size: 26px;
    font-style: italic;
    font-weight: 700;
    padding-right: 9px
}

.trainer {
    background-color: #fff;
    padding: 64px 0 72px
}

.trainer .wrap {
    display: grid;
    gap: 4%;
    grid-template-columns: 40% 56%;
    margin: auto;
    max-width: 1000px;
    width: 92%
}

.trainer .nsca {
    font-size: 18px;
    margin-bottom: 14px
}

.trainer .nsca,
.trainer h2 {
    font-family: Shippori Mincho, serif;
    font-weight: 500
}

.trainer h2 {
    font-size: 24px;
    margin-bottom: 18px
}

.trainer .list {
    line-height: 2em;
    margin-bottom: 24px
}

.trainer .list,
.trainer .txt {
    font-size: 16px;
    font-weight: 500
}

.trainer .txt {
    line-height: 1.6em
}

.concept {
    background-image: url(../img/conept-bg.jpg);
    background-position: 50%;
    background-size: cover;
    padding: 52px 0 140px
}

.concept .wrap {
    margin: auto;
    max-width: 1000px;
    width: 92%
}

.concept h2 {
    padding-bottom: 33px
}

.concept .copy span,
.concept h2 {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700
}

.concept .copy span {
    line-height: .8em
}

.concept .copy p {
    color: #c8ac31;
    font-size: 26px;
    font-weight: 400;
    margin-bottom: 24px
}

.concept .list {
    display: grid;
    gap: 20px;
    grid-template-columns: 1fr 1fr 1fr;
    margin: 24px 0 0
}

.concept .list h3 {
    align-items: center;
    background-color: #525252;
    color: #fff;
    display: flex;
    font-size: 16px;
    font-weight: 600;
    justify-content: center;
    line-height: 1.5em;
    min-height: 64px;
    padding: 8px;
    text-align: center
}

.concept .list img {
    padding: 16px
}

.concept .list p {
    font-size: 14px;
    padding: 0 16px 16px
}

.info {
    background-color: #e0e0e0;
    padding: 56px 0 0;
    width: 100%
}

.info .wrap {
    background-color: #fff;
    margin: auto;
    max-width: 1000px;
    padding: 36px 40px 40px;
    width: 92%
}

.info .img {
    display: block;
    height: 100%;
    width: 100%
}

.info .img img {
    height: auto;
    min-height: 100%;
    min-width: 100%;
    object-fit: cover;
    width: auto
}

.info h2 {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700;
    padding-bottom: 33px
}

.info .content {
    display: grid;
    gap: 18px;
    grid-template-columns: 316px 1fr
}

.info .content .insta {
    align-items: center;
    background-image: linear-gradient(150deg, #f7a60c 10%, #ff2257 40%, #9a27ee 68%, #2366f7 90%);
    display: grid;
    grid-template-columns: 1fr 1fr;
    justify-content: space-between;
    margin-bottom: 20px;
    padding: 15px 22px
}

.info .content .insta a {
    align-items: center;
    border: 1px solid #fff;
    display: grid;
    gap: 42px;
    grid-template-columns: 25px 1fr;
    justify-content: flex-start;
    padding: 10px 24px;
    position: relative
}

.info .content .insta p {
    color: #fff;
    font-size: 14px
}

.info .content .insta a:after {
    background-image: url(../img/icon-right.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 9px;
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 4px
}

.info .content .insta a p {
    font-size: 12px;
    line-height: 1em
}

.info .content .insta a p span {
    color: #fff;
    display: block;
    font-size: 14px
}

.info .txt>p {
    font-family: Shippori Mincho, serif;
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 8px
}

.info .txt>p span {
    font-size: 14px
}

.info .link {
    gap: 16px;
    grid-template-columns: 1fr 1fr;
    justify-content: space-between
}

.info .link,
.info .link a {
    align-items: center;
    display: grid
}

.info .link a {
    border: 1px solid #000;
    gap: 42px;
    grid-template-columns: 30px 1fr;
    justify-content: flex-start;
    min-height: 60px;
    height: 100%;
    padding: 10px 24px;
    position: relative
}

.info .link p {
    font-size: 14px
}

.info .link a:after {
    background-color: #4b4b4b;
    content: "";
    display: inline-block;
    height: 9px;
    -webkit-mask: url(../img/icon-right.svg);
    mask: url(../img/icon-right.svg);
    -webkit-mask-size: cover;
    mask-size: cover;
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    vertical-align: middle;
    width: 5px
}

.info .link a p {
    font-size: 12px;
    line-height: 1em
}

.info .link a p span {
    display: block;
    font-size: 9px
}
@media screen and (max-width: 900px) {
    .info .content .insta a p {
        font-size: 15px;
        line-height: 1em
    }
    .info .link a p {
        font-size: 16px;
        line-height: 1em
    }
    .info .link a p span {
        display: block;
        font-size: 12px
    }
}

.info iframe {
    height: 330px;
    margin-top: 20px;
    width: 100%
}

.copyright {
    background-color: #e0e0e0;
    padding: 18px
}

.copyright p {
    font-size: 12px;
    text-align: center
}

.price .smt {
    display: none
}

.news .container a .thumb,
.news .container a:hover .thumb,
.news .container a:hover span,
.news .container a:hover span:after {
    transition: .3s
}

.news .container a:hover .thumb {
    opacity: .7
}

.news .container a:hover span {
    color: #49aa00
}

.news .container a:hover span:after {
    background-color: #49aa00
}

header .menu li a:hover {
    color: #000
}

.cta .top .wrap .content a:hover {
    background-color: #64c411
}

.cta .bottom {
    background-color: #000
}

.cta .bottom a:hover {
    background-color: #fff;
    color: #49aa00
}

.info .content .insta a:hover {
    background-color: #436574
}

.info .link a:hover {
    background-color: #d9eaf1
}

.protein {
    background-color: #fff;
    margin-top: 32px;
    padding: 14px 12px
}

.protein h3 {
    padding-bottom: 12px
}

.map {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: 1fr 1fr
}

.map h3 {
    font-family: Shippori Mincho, serif;
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 8px
}

.map img {
    border: 1px solid #aaa
}

@media screen and (max-width: 1200px) {
    .image .content {
        gap: 24px;
        grid-template-columns: 1fr 1fr
    }

    .image .content .txt {
        grid-column: 1/2
    }

    .image .content>img {
        display: block;
        grid-column: 2/3
    }

    .image {
        padding: 24px 2%
    }
}

@media screen and (max-width: 1040px) {
    .plan .mds {
        display: block;
        margin-bottom: 12px
    }

    .plan .content .mds p {
        text-align: left
    }

    .plan .mds h3 {
        line-height: 1em;
        margin-left: 0
    }

    .news .container {
        display: block
    }

    .news .container a {
        grid-template-columns: 120px 1fr;
        margin-bottom: 18px;
        width: 100%
    }

    .image .content {
        display: block;
        gap: 24px
    }

    .image .content .txt {
        margin-bottom: 24px
    }

    .price .discount table.smt,
    .price .discount table.smt tbody,
    .price .discount table.smt td,
    .price .discount table.smt tr {
        display: block;
        width: 100%
    }

    .price .discount table.smt td {
        border-bottom: 0
    }

    .price .discount table.smt td:last-of-type {
        border: 1px solid #4b4b4b
    }

    .cta h2 {
        font-size: 18px;
        padding: 18px 0
    }

    .cta .top .wrap {
        gap: 18px;
        grid-template-columns: 1fr
    }

    .cta .top {
        padding: 32px 0 60px
    }

    .cta .bottom {
        display: block
    }

    .cta .left,
    .cta .right {
        font-size: 18px;
        padding: 70px 12px;
        width: 100%
    }

    .plan .wrap,
    .trainer .wrap {
        display: block
    }

    .trainer .txt {
        margin-top: 18px
    }

    .concept .copy span {
        font-size: 32px
    }

    .concept .list {
        display: grid;
        gap: 20px;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 1fr 1fr;
        margin: 24px 0 0
    }

    .concept .list img,
    .trainer .wrap img {
        width: 100%
    }

    .info .content {
        display: grid;
        gap: 18px;
        grid-template-columns: 1fr
    }
}

@media screen and (max-width: 900px) {
    .price .pc {
        display: none
    }

    .price .smt {
        display: initial
    }


    .news {
        padding: 24px 0
    }
    .news .wrap {
        padding: 24px 18px
    }
    .news .container a {
        grid-template-columns: 88px 1fr;
        margin-bottom: 18px;
        width: 100%
    }

    .nayami .head p {
        font-size: 22px;
        padding: 18px 0
    }

    .nayami .main ul {
        display: grid;
        gap: 18px;
        gap: 8px;
        grid-template-columns: 1fr;
        margin: auto;
        max-width: 1000px;
        width: 92%
    }

    .nayami .main li {
        font-size: 16px;
        gap: 10px
    }

    .image {
        margin: auto;
        padding: 24px 0;
        width: 92%
    }

    .image .head span {
        font-size: 24px
    }

    .image .head p {
        font-size: 20px
    }

    .image .content .txt h3 {
        font-size: 18px;
        margin-bottom: 16px
    }

    .image .content .txt h3 span {
        font-size: 22px
    }

    .price .smt .tablinks span {
        font-size: 11px
    }

    .price .option {
        gap: 12px;
        grid-template-columns: 1fr
    }

    .cta h2 {
        font-size: 16px;
        padding: 18px 0
    }

    .plan .content,
    .qa .wrap {
        padding: 32px 18px
    }

    .qa .box {
        padding-bottom: 18px
    }

    .trainer {
        padding: 8px 0 72px
    }

    .trainer .nsca {
        font-size: 16px;
        margin-bottom: 12px
    }

    .trainer h2 {
        font-size: 22px;
        margin-bottom: 12px
    }

    .trainer .list {
        font-size: 15px;
        line-height: 1.7em;
        margin-bottom: 12px
    }

    .trainer .txt {
        font-size: 15px
    }

    .concept .copy p {
        font-size: 22px;
        margin-bottom: 24px
    }

    .concept .copy span {
        line-height: 1.4em
    }

    .info .wrap {
        padding: 24px 18px
    }

    .info .content .insta {
        gap: 12px;
        grid-template-columns: 1fr
    }

    .info .txt>p {
        font-size: 15px;
        margin-bottom: 2px
    }

    .info .link {
        gap: 8px;
        grid-template-columns: 1fr;
        margin-top: 12px
    }

    .concept {
        padding: 52px 0
    }

    .headLogo {
        max-width: 100%;
        padding-bottom: 32px;
        width: 100%
    }



    .qa .wrap h2 {
        padding-bottom: 18px
    }

    .price .mds {
        display: flex;
        margin-bottom: 18px;
    }

    .concept .copy p {
        font-size: 18px;
        margin-bottom: 18px
    }

    .concept .list {
        margin: 40px 0 0
    }

    .info h2 {
        padding-bottom: 10px
    }

    .cta .popup {
        top: -6px;
        width: 60%
    }

    .price .smt td:first-of-type {
        font-size: 14px
    }

    .map {
        display: grid;
        gap: 14px;
        grid-template-columns: 1fr
    }
}

.smt {
    display: none
}

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

    .smt {
        display: inherit
    }
}

.scrollin {
    opacity: 0;
    transition: .3s
}

.scrollin.visible {
    animation-duration: .3s;
    animation-fill-mode: forwards;
    animation-name: fadeUpAnime;
    opacity: 1;
    opacity: 0;
    transition: .3s
}

@keyframes fadeUpAnime {
    0% {
        opacity: 0;
        transform: translateY(40px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.float {
    display: none
}

@media screen and (max-width: 900px) {
    .home .copyright {
        padding-bottom: 80px
    }

    .float {
        bottom: 0;
        display: block;
        height: 68px;
        position: fixed;
        width: 100%;
        z-index: 90
    }

    .float a {
        align-items: center;
        background-color: #64c411;
        color: #fff;
        display: flex;
        font-size: 14px;
        height: 100%;
        justify-content: center;
        text-align: center;
        width: 100%
    }

    .float a:after {
        background-image: url(../img/icon-right.svg);
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: contain;
        content: "";
        height: 6px;
        position: absolute;
        right: 12px;
        top: 50%;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        width: 3px
    }
}

.single {
    background-color: #e0e0e0;
    padding: 56px 0 40px
}

.single .head {
    margin: 56px auto 40px;
    max-width: 1000px;
    width: 96%
}

.single .head p {
    color: #c8ac31;
    font-family: Cinzel, serif;
    font-size: 40px;
    font-weight: 700
}

.single .head ul {
    display: flex;
    flex-wrap: wrap
}

.single .head li {
    display: flex;
    gap: 8px
}

.single .head li:after {
    color: #5c5c5c;
    content: ">";
    padding-right: 8px
}

.single .head li:last-of-type:after {
    content: ""
}

.single .head li a {
    color: #c8ac31
}

.single article {
    background-color: #fff;
    margin: 56px auto 80px;
    max-width: 1000px;
    padding: 24px 32px;
    width: 96%
}

.single .mds time {
    font-family: Cinzel, serif;
    font-size: 15px
}

.single .mds h2 {
    border-bottom: 1px solid #5c5c5c;
    font-size: 24px;
    margin-bottom: 24px;
    padding-bottom: 10px
}

.single .container .thumb img {
    height: auto;
    margin-bottom: 32px;
    width: 100%
}

.single .container h1 {
    background-color: #4b4b4b;
    color: #fff;
    font-size: 26px;
    margin: 16px 0;
    padding: 4px 12px
}

.single .container h2 {
    border: 1px solid #4b4b4b;
    font-size: 25px;
    margin: 16px 0 24px;
    padding: 4px 12px
}

.single .container h3 {
    border-left: 4px solid #4b4b4b;
    font-size: 24px;
    padding: 4px 0 4px 12px
}

.single .container h3,
.single .container h4 {
    border-bottom: 1px solid #4b4b4b;
    margin: 16px 0
}

.single .container h4 {
    font-size: 23px;
    padding: 4px 0
}

.single .container h5 {
    font-size: 22px;
    margin: 16px 0
}

.single .container h6 {
    font-size: 18px;
    margin: 16px 0
}

.single .container p {
    font-size: 16px;
    margin: 16px 0
}

.single .container a {
    color: #06a;
    font-weight: 700;
    text-decoration: underline
}

.single .container b,
.single .container strong {
    font-weight: 700
}

.single a,
.single h1,
.single h2,
.single h3,
.single h4,
.single h5,
.single h6,
.single li,
.single p,
.single pre,
.single span,
.single table,
.single td,
.single tr,
.single ul {
    text-transform: capitalize
}

@media screen and (max-width: 900px) {
    .single .head {
        margin: 56px auto 24px
    }

    .single article {
        margin: 24px auto 80px;
        padding: 24px 18px
    }

    .single .container h1,
    .single .container h2,
    .single .container h3,
    .single .container h4,
    .single .container h5,
    .single .container h6,
    .single .container p {
        margin: 24px 0
    }
}

.archivewrap {
    min-height: 100vh
}

.archivewrap .archive {
    background-color: #fff;
    display: block;
    max-width: 1000px;
    margin: auto;
    width: 96%;
    padding: 32px 16px;
}

.archivewrap .archive .wrap {
    display: block
}

.archivewrap .archive-inner {
    background-color: #fff;
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 10px;
    align-items: center;
    margin-bottom: 18px;
}
.archivewrap .archive-inner:last-of-type {
    margin-bottom: 0;
}

.archivewrap .archive-inner img {
    aspect-ratio: 4/3;
    display: block;
    height: auto;
    object-fit: cover;
    overflow: hidden;
    width: 100%;
    border: 1px solid #ececec;
}


.single .archive-inner .mds time {
    color: #49aa00;
    font-family: Cinzel, serif;
    font-size: 15px
}

.archive-inner .mds h2 {
    border-bottom: 0 solid #5c5c5c;
    font-size: 18px;
    margin-bottom: 0;
    padding-bottom: 0
}
.pagination {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-top: 40px;
}
.pagination a {
    padding: 4px 12px;
    border: 1px solid #4b4b4b;
}
.current {
    padding: 4px 12px;
    border: 1px solid #4b4b4b;
    background-color: #4b4b4b;
    color: #e0e0e0;
}
@media screen and (max-width: 900px) {
    .archivewrap .archive-inner {
        grid-template-columns: 88px 1fr;
    }
}
@media screen and (max-width: 600px) {
    .archivewrap .archive-inner .mds h2 {
        font-size: 16px;
    }
}
.btn {
    display: block;
    border: #4b4b4b 1px solid;
    padding: 8px 12px;
    display: block;
    margin: 32px auto 0;
    width: 320px;
    text-align: center;
}
.wp-block-button__link {
    color: #fff !important;
    text-decoration: none !important;
}
.wp-block-button__link:hover {
    filter: brightness(-100%);
}
.wp-block-button__link:hover {
    filter: brightness(0.8);
}


.fprice {
    font-size: 18px;
    font-weight: 500;
}

/* 240401追加 */
.price .tickets table {
    width: 100%;
}
.price .tickets td:first-of-type {
    background-color: #525252;
    color: #fff;
    width: 145px
}
.price .tickets .none {
    background-color: #e0e0e0 !important;
    border-left: 1px solid #e0e0e0;
    border-top: 1px solid #e0e0e0
}
.price .tickets .ttl {
    background-color: #525252;
    color: #fff;
    font-size: 18px;
    padding: 9px 2px;
    width: 20%;
}
.price .tickets td {
    background-color: #fff;
    border: 1px solid #4b4b4b;
    line-height: 1.3em;
    padding: 9px 2px;
    text-align: center;
    vertical-align: middle;
    width: 20%;
}
.price .tickets td span {
    letter-spacing: 0em;
}
.smtbr {
    display: none;
}
@media screen and (max-width: 600px) {
    .price .tickets td span {
        font-size: 12px;
        letter-spacing: 0em;
    }
    .smtbr {
        display: block;
    }
}


/* 20241021追加 */
.secSlider {
    padding: 56px 0px 66px;
    max-width: 1000px;
    width: 94%;
    margin: 0 auto;
    position: relative;
}
.secSlider .txt {
    margin-bottom: 32px;
}
.secSlider .txt h3 {
    color: #c8ac31;
    font-size: 26px;
    font-weight: 500;
    margin-bottom: 12px;
}
.slick-item {
    margin: 0 4px;
}
.slick-next {
    right: 8px !important;
}
.slick-prev {
    left: 8px !important;
}
.slick-prev,
.slick-next {
    z-index: 1 !important;
    width: 40px !important;
    height: 40px !important;
    background-color: #333333e8 !important;
    border-radius: 50%;
}
.slick-dots {
    bottom: -35px !important;
}
.slick-prev:before,
.slick-next:before {
    font-family: initial !important;
    color: #ffffff !important;
    /*黒にする*/
    opacity: 1 !important;
    /*デフォルトは.75が指定されている*/
    font-size: 21px !important;
}
.slick-dots li {
    margin: 0 !important;
}

@media screen and (max-width: 767px) {
    .secSlider {
        padding: 20px 0px 56px;
    }
    .slick-prev:before,
    .slick-next:before {
        font-size: 16px !important;
    }
    .slick-prev,
    .slick-next {
        width: 30px !important;
        height: 30px !important;
    }
    .secSlider .txt p br {
        display: none;
    }
    .secSlider .txt h3 {
        font-size: 20px;
        margin-bottom: 16px;
    }
}

/* 20251125追加 */
.rightmenu {
    display: flex;
    align-items: center;
    gap: 10px;
}
.rightmenu .rightmenuInner {
    display: flex;
    gap: 4px;
    align-items: center;
    padding-right: 12px;
}

.rightmenu .rightmenuInner a {
    display: flex;
    align-items: center;
    gap: 8px;
    background-color: #64C424;
    padding: 2px 14px 6px 8px;
    position: relative;
}
.rightmenu .rightmenuInner a::after {
    position: absolute;
    right: 2px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: block;
    background-image: url(../img/icon-right.svg);
    width: 3px;
    height: 7px;
    background-size: cover;
    background-position: right center;
}
.rightmenu .rightmenuInner a img {
    width: 35px;
    height: auto;
    display: block;
}
.rightmenu .rightmenuInner span {
    font-family: sans-serif;
    color: #fff;
    font-size: 14px;
    line-height: 1em;
}
.rightmenu .rightmenuInner p {
    font-family: sans-serif;
    color: #fff;
    font-size: 18px;
    line-height: 1em;
}

.nayami ul li p,
.nayami ul li span {
    align-items: center;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
}
.nayami ul li span {
    border-bottom: 1px solid #fff;
}

.nayami .main ul {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin: auto;
    max-width: 1000px;
    width: fit-content
}
@media screen and (max-width: 1089px) {
    #header {
        display: none;
    }
}
@media screen and (max-width: 900px) {
    .nayami ul li p,
    .nayami ul li span {
        font-size: 16px;
    }
}

@media screen and (max-width: 900px) {
    .home .copyright {
        padding-bottom: 80px
    }

    .float {
        bottom: 0;
        display: grid;
        grid-template-columns: 1fr 1fr;
        height: 68px;
        position: fixed;
        width: 100%;
        z-index: 90
    }
    .float a {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 3px;
        background-color: #64C424;
        padding: 2px 4px 6px 0px;
        position: relative;
        width: 100%;
        height: 100%;
    }
    .float a:last-of-type {
        border-left: 1px solid #fff;
    }
    .float a::after {
        position: absolute;
        right: 4px;
        top: 0;
        bottom: 0;
        margin: auto;
        content: "";
        display: block;
        background-image: url(../img/icon-right.svg);
        width: 3px;
        height: 7px;
        background-size: cover;
        background-position: right center;
    }
    .floatr a img {
        width: 35px;
        height: auto;
        display: block;
    }
    .float span {
        font-family: sans-serif;
        color: #fff;
        font-size: 13px;
        line-height: 1em;
        letter-spacing: -0.02em;
        font-weight: 400;
        text-align: left;
    }
    .float p {
        font-family: sans-serif;
        color: #fff;
        font-size: 18px;
        line-height: 1em;
        font-weight: 600;
        text-align: left;
    }
}
.visible-sp {
    display: none;
}
@media screen and (max-width: 900px) {
    .visible-sp {
        display: block;
    }
}
.tanpatsu {
    margin-top: 16px;
}
.tanpatsu table {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px 24px;
}
.tanpatsu table td {
    background-color: #fff;
    border: 1px solid #4b4b4b;
    line-height: 1.3em;
    padding: 9px 2px;
    text-align: center;
    vertical-align: middle;
    width: 14%
}
.tanpatsu table td:first-of-type {
    background-color: #525252;
    color: #fff;
}
@media screen and (max-width: 900px) {
    .tanpatsu table {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px 24px;
    }
}
.smt-head .menu {
    display: block
}

.smt-head .menu li {
    border-bottom: 1px solid #fff;
    border-top: 0 solid #fff
}

.smt-head .menu li:first-child {
    border-bottom: 1px solid #fff;
    border-top: 1px solid #fff;
    margin-top: 32px
}

.smt-head .rightmenuInner {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 32px;
}
.smt-head .rightmenuInner a {
    background-color: #64c411;
    border-bottom: 0;
    border-top: 0;
    font-size: 14px;
    margin-left: 0;
    margin-top: 24px;
    padding: 0 30px
}
.smt-head .rightmenuInner a {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background-color: #64C424;
    padding: 2px 14px 6px 8px !important;
    position: relative;
    text-align: left !important;
    margin-top: 0px !important;
}
.smt-head .rightmenuInner a::after {
    position: absolute;
    right: 2px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: block;
    background-image: url(../img/icon-right.svg);
    width: 3px;
    height: 7px;
    background-size: cover;
    background-position: right center;
}
.smt-head .rightmenuInner a img {
    width: 35px;
    height: auto;
    display: block;
}
.smt-head .rightmenuInner span {
    font-family: sans-serif;
    color: #fff;
    font-size: 14px;
    line-height: 1em;
}
.smt-head .rightmenuInner p {
    font-family: sans-serif;
    color: #fff;
    font-size: 18px;
    line-height: 1em;
}
.lettersmall {
    text-transform: lowercase;
}