@charset 'UTF-8';

:root {
    --cl-main: #a7d246;
    --cl-text: #000;
    --bgc: transparent;
    --bgi: none;
    --fs: normal;
    --fw: 400;
    --fz: 3.2vw;
    --lh: 2;
    --ff: 'Noto Sans JP', "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", sans-serif;
    --cw: 93.33vw;
    --pt: 0;
    --pr: 0;
    --pb: 0;
    --pl: 0;
    --mt: 0;
    --mr: 0;
    --mb: 0;
    --ml: 0;
    --rg: 2em;
    --cg: 2em;
    scroll-behavior: smooth
}

@media only screen and (min-width:1150px) {
    :root {
        --fz: 24px
    }
}

@media only screen and (min-width:1150px) {
    :root {
        --cw: 1148px
    }
}

* {
    color: var(--cl-text);
    background-color: var(--bgc);
    font-style: var(--fs);
    font-weight: var(--fw);
    font-size: var(--fz);
    line-height: var(--lh);
    font-family: var(--ff);
    padding: var(--pt) var(--pr) var(--pb) var(--pl);
    margin: var(--mt) var(--mr) var(--mb) var(--ml);
    gap: var(--rg) var(--cg)
}

:last-child {
    margin-bottom: 0
}

html {
    box-sizing: border-box
}

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

::-moz-selection {
    background-color: #d3e8a3
}

::selection {
    background-color: #d3e8a3
}

body {
    text-align: justify;
    line-break: strict;
    overflow-wrap: break-word;
    font-kerning: normal;
    -webkit-font-smoothing: subpixel-antialiased;
    -moz-osx-font-smoothing: auto;
    text-rendering: optimizeLegibility;
    text-underline-offset: 3px;
    background-color: #fff;
    min-height: 100vh
}

address:not(:last-child),
p:not(:last-child) {
    --mb: 1em
}

strong {
    --fw: 800
}

small {
    --fz: 0.92rem
}

s {
    --cl-text: #808080
}

summary {
    display: block
}

summary .summary-inner {
    cursor: pointer;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    padding: .6em 0
}

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

summary+.content {
    overflow: hidden
}

summary+.content .content-inner {
    padding: 1em 1.5em
}

.h1,
.h2,
.h3,
.h4,
.h5,
h1,
h2,
h3,
h4,
h5 {
    --fw: 800;
    --lh: 1.26;
    margin-bottom: 1em;
    font-feature-settings: "palt";
    letter-spacing: .05em;
    text-align: center
}

.h-banzai {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-end;
    --cg: 0.3em
}

@media only screen and (min-width:1150px) {
    .h-banzai>span {
        padding-bottom: .5em
    }
}

.h-banzai::after,
.h-banzai::before {
    content: '';
    display: block;
    width: 3.13rem;
    border-top: .13rem solid currentColor
}

.h-banzai::before {
    transform-origin: 100% 0;
    transform: rotateZ(60deg)
}

.h-banzai::after {
    transform-origin: 0 0;
    transform: rotateZ(-60deg)
}

.h-underline {
    --fz: 1.33rem;
    --pb: 0.3em;
    --mb: 0.3em;
    border-bottom: .42rem solid var(--cl-main)
}

a {
    transition: all .3s cubic-bezier(.42, 0, .58, 1);
    cursor: pointer;
    --cl-text: #a7d246
}

a:link {
    --cl-text: #a7d246;
    text-decoration: underline
}

a:visited {
    --cl-text: #551b8c
}

html:not([data-whatinput=touch]) a:hover {
    --cl-text: #99cbe8;
    text-decoration: none;
    transition: all .3s cubic-bezier(.42, 0, .58, 1)
}

a:active {
    outline: 0
}

a:focus {
    outline: thin;
    outline-style: dotted;
    text-decoration: underline
}

a.db {
    width: 100%;
    height: 100%
}

ul {
    --lh: 1.4;
    --li-mb: 1em;
    margin-bottom: 1.6em
}

ul ul {
    padding-left: 1em;
    margin-top: 1em
}

ul {
    list-style-type: none
}

li {
    margin-bottom: var(--li-mb)
}

figure:not(:last-child) {
    --mb: 1em
}

img {
    vertical-align: middle;
    max-width: 100%;
    height: auto
}

img.full-width {
    width: 100%
}

embed,
iframe {
    width: 100%;
    max-width: 100%;
    border: 0
}

#l-footer {
    background-color: #eef5dc;
    padding-top: 1.38rem;
    padding-bottom: 1.83rem
}

@media only screen and (min-width:1150px) {
    #l-footer {
        padding-bottom: 0
    }
}

#l-footer h2 img {
    width: 7.54rem
}

#l-footer>p.intro {
    --fz: 1.17rem;
    --lh: 1.4286
}

@media only screen and (min-width:1150px) {
    #l-footer>p.intro {
        --fz: 24px
    }
}

#l-footer>p.logo img {
    width: 21rem
}

@media only screen and (min-width:1150px) {
    #l-footer>p.logo img {
        width: 656px
    }
}

#l-footer>p.address {
    --lh: 1.5833
}

#l-header {
    background: url("../img/bg-l-header-01.webp") no-repeat center top/100% 4.58rem;
    height: 4.58rem;
    padding-top: .4em;
    position: relative;
    z-index: 1000
}

@media only screen and (min-width:1150px) {
    #l-header {
        height: 186px;
        background: url("../img/bg-l-header-01-pc.webp");
        background-size: 100% 100%;
        overflow: hidden
    }
}

#l-header h1 {
    text-align: center
}

@media only screen and (min-width:1150px) {
    #l-header h1 {
        --fz: 18.5px;
        --cg: 1.5em;
        display: flex;
        align-items: center;
        justify-content: center;
        padding-right: 6em
    }
}

#l-header h1 span.txt {
    display: none
}

@media only screen and (min-width:1150px) {
    #l-header h1 span.txt {
        display: block;
        padding-top: 1em
    }
}

#l-header h1 img {
    width: 15.75rem
}

#site-navigation-area {
    overflow: hidden
}

#site-menu-btn {
    display: none
}

#site-menu-btnIcon {
    background: url("../img/bg-menu-btn.webp") no-repeat right top/5.5rem;
    position: fixed;
    top: 0;
    right: 0;
    width: 5.5rem;
    height: 4.67rem;
    cursor: pointer;
    z-index: 1001
}

@media only screen and (min-width:1440px) {
    #site-menu-btnIcon {
        background: url("../img/bg-menu-btn-pc.webp") no-repeat left top/198px;
        width: 198px;
        height: 111px;
        right: 78px
    }
}

#site-menu-btnIcon img[src$="open.webp"] {
    display: block;
    width: 2.08rem;
    --mt: 0.92rem;
    --ml: 2.25rem
}

#site-menu-btn:checked+#site-menu-btnIcon {
    background: 0 0
}

#site-menu-btn:checked+#site-menu-btnIcon>img {
    content: url("../img/btn-menu-close.webp")
}

#site-menu-btn:checked~#site-menu {
    pointer-events: auto;
    visibility: visible;
    transform: scale3d(1, 1, 1);
    transform-origin: right center;
    opacity: 1;
    transition: all .35s cubic-bezier(.25, .46, .45, .94)
}

#site-menu {
    background: var(--cl-main) url("../img/bg-g-nav.webp") no-repeat center/30.63rem;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    max-width: 100%;
    height: 100%;
    max-height: 100%;
    overflow-y: auto;
    z-index: 102;
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    transform: scale3d(0, 1, 1);
    transform-origin: right center;
    transition: all .35s cubic-bezier(.455, .03, .515, .955);
    scrollbar-width: none;
    overscroll-behavior: none
}

#site-menu::-webkit-scrollbar {
    display: none
}

@media only screen and (min-width:1150px) {
    #site-menu {
        background: var(--cl-main) url("../img/bg-g-nav-pc.webp") no-repeat calc(50% + 193px) 70px/837px
    }
}

#site-navigation-wrapper {
    width: 100%;
    height: calc(100% + 1px);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2em
}

@media only screen and (min-width:1150px) {
    #site-navigation-wrapper {
        align-items: flex-start;
        padding: 0
    }
}

#site-navigation-group {
    color: #fff;
    max-height: 80dvh;
    overflow-y: auto;
    overscroll-behavior: contain
}

@media only screen and (min-width:1150px) {
    #site-navigation-group {
        height: 100%;
        margin-top: 110px;
        margin-left: 320px
    }
}

#site-navigation {
    width: 70.93vw
}

@media only screen and (min-width:1150px) {
    #site-navigation {
        width: 602px;
        height: 100%;
        overflow-y: visible;
        margin-left: auto;
        display: inline-block
    }
}

#site-navigation>.nav-title {
    margin: 0;
    position: absolute;
    left: 2.04rem;
    top: 1.38rem
}

#site-navigation>.nav-title img {
    width: 15.75rem;
    display: block
}

@media only screen and (min-width:1150px) {
    #site-navigation>.nav-title {
        left: calc(50% - 530px);
        top: 21px
    }
}

#site-navigation-list {
    --li-mb: 0;
    display: grid;
    grid-template-rows: auto;
    grid-auto-flow: row;
    gap: 0;
    border-top: 1px solid #dbdcdc
}

@media only screen and (min-width:1150px) {
    #site-navigation-list {
        border-top: none
    }
}

#site-navigation-list>li:first-child img {
    width: 7.38rem
}

#site-navigation-list>li:nth-child(2) img {
    width: 14.13rem
}

#site-navigation-list>li:nth-child(3) img {
    width: 7.42rem
}

#site-navigation-list>li:nth-child(4) img {
    width: 14.21rem
}

#site-navigation-list>li:nth-child(5) img {
    width: 15rem
}

#site-navigation-list>li:nth-child(6) img {
    width: 13.46rem
}

.site-navigation-item {
    --fz: 0.92rem;
    letter-spacing: .1em;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: .5em;
    padding: 1em 0 1.5em;
    border-bottom: 1px solid #dbdcdc
}

@media only screen and (min-width:1150px) {
    .site-navigation-item {
        --fz: 18px;
        justify-content: space-between;
        padding: 1.5em 2em
    }
}

.site-navigation-item,
.site-navigation-item:active,
.site-navigation-item:focus,
.site-navigation-item:link,
.site-navigation-item:visited,
html:not([data-whatinput=touch]) .site-navigation-item:hover {
    --cl-text: #fff;
    text-decoration: none
}

.site-navigation-item .txt {
    flex: 1 1 100%
}

@media only screen and (min-width:1150px) {
    .site-navigation-item .txt {
        text-align: right;
        flex: 0 1 7em
    }
}

#l-main {
    min-height: 70vh
}

#l-main>div>*,
#l-main>section>* {
    width: -moz-fit-content;
    width: fit-content;
    max-width: var(--cw);
    margin-left: auto;
    margin-right: auto
}

#l-main>div>.full-width,
#l-main>section>.full-width {
    width: 100%
}

.accordion {
    background: #ffa;
    padding: 0 1.5em
}

@media only screen and (min-width:1150px) {
    .accordion {
        border-radius: 16px
    }
}

.accordion:not(:last-child) {
    margin-bottom: 1.13rem
}

.accordion .accordion-title {
    --fz: 0.96rem;
    position: relative;
    padding-left: 1.6em;
    padding-right: 2em
}

.accordion .accordion-title::before {
    content: '';
    display: block;
    width: 1.13rem;
    height: 1.13rem;
    background: url("../img/qa-Q.webp") no-repeat center/cover;
    position: absolute;
    left: 0;
    top: 1.1em
}

.accordion .accordion-title::after {
    content: '\002B';
    display: block;
    color: #b3b3b3;
    font-size: 150%;
    position: absolute;
    right: 0;
    top: 0
}

.accordion[open] .accordion-title::after {
    content: '\2212'
}

.accordion .accordion-content {
    --fz: 0.88rem;
    --lh: 1.8;
    padding-bottom: 1.5em
}

.accordion .accordion-content .content-inner {
    position: relative;
    background: #fff;
    padding-left: 3.5em;
    border-radius: .63rem
}

.accordion .accordion-content .content-inner::before {
    content: '';
    display: block;
    width: 1.04rem;
    height: 1.04rem;
    background: url("../img/qa-A.webp") no-repeat center/cover;
    position: absolute;
    left: 1.5em;
    top: 1.3em
}

.accordion .accordion-content .content-inner .fzSm {
    font-size: .87em
}

.card {
    padding: 1.5em;
    background: #fff;
    border-radius: 2.42rem
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(1em)
    }

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

@keyframes fuwafuwa {
    0% {
        transform: translate(0, 0) rotate(-7deg)
    }

    50% {
        transform: translate(0, -7px) rotate(0)
    }

    100% {
        transform: translate(0, 0) rotate(7deg)
    }
}

@keyframes poyoyon {
    0% {
        transform: translateX(140px);
        opacity: 0
    }

    50% {
        transform: translateX(0)
    }

    65% {
        transform: translateX(30px)
    }

    100% {
        transform: translateX(0)
    }

    100%,
    20% {
        opacity: 1
    }
}

.is-animation-fadeInUp {
    animation: fadeInUp 1.8s 0s ease-out both paused
}

.is-animation-fadeInUp.inView {
    animation-play-state: running
}

.is-animation-fuwafuwa {
    animation: fuwafuwa 3s ease-in-out infinite alternate
}

.is-animation-poyoyon {
    animation: poyoyon .5s cubic-bezier(.12, 0, .39, 0) 1 both paused
}

.is-animation-poyoyon.inView {
    animation-play-state: running
}

.clMain {
    --cl-text: var(--cl-main)
}

.clWhite {
    --cl-text: #fff
}

.bgMain {
    background-color: var(--cl-main)
}

.bgYellow {
    background-color: #fff7ab
}

.bgWhite {
    background-color: #fff
}

.bgPat1 {
    background: url("../img/bg-pat-01.webp") repeat left top/2.29rem 2.29rem
}

.db {
    display: block
}

.vhc {
    display: flex;
    justify-content: center;
    align-items: center
}

.max-width-none {
    max-width: none !important
}

.posr {
    position: relative
}

.posa {
    position: absolute
}

.embed-figure {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%
}

@media only screen and (min-width:1150px) {
    .embed-figure {
        padding-bottom: 590px
    }
}

.embed-figure embed,
.embed-figure iframe,
.embed-figure>* {
    position: absolute !important;
    top: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border: 0 !important
}

.l-fx {
    display: flex;
    flex-wrap: wrap
}

.l-cw>* {
    width: -moz-fit-content;
    width: fit-content;
    max-width: var(--cw);
    margin-left: auto;
    margin-right: auto
}

.l-cw>.full-width {
    width: 100%
}

.ffsPalt {
    font-feature-settings: "palt"
}

.fwNormal {
    --fw: 400
}

.fwMed {
    --fw: 500
}

.fwBold {
    --fw: 800
}

.fzSm {
    --fz: 0.92rem
}

.fzXl {
    --fz: 1.42rem
}

.fzXxl {
    --fz: 1.58rem
}

.taC {
    text-align: center
}

.il-show-lg {
    display: none
}

@media only screen and (min-width:1150px) {
    .il-show-lg {
        display: inline
    }
}

.il-hide-lg {
    display: inline
}

@media only screen and (min-width:1150px) {
    .il-hide-lg {
        display: none
    }
}

.bl-show-lg {
    display: none
}

@media only screen and (min-width:1150px) {
    .bl-show-lg {
        display: block
    }
}

.bl-hide-lg {
    display: block
}

@media only screen and (min-width:1150px) {
    .bl-hide-lg {
        display: none
    }
}

#intro {
    --cw: 100%;
    margin-top: -1.67rem
}

@media only screen and (min-width:1150px) {
    #intro {
        margin-top: -94px
    }
}

#intro img {
    width: 100%
}

#classes {
    --cg: 0.67rem;
    --cw: 100%;
    flex-wrap: nowrap;
    align-items: flex-end;
    justify-content: center;
    z-index: 3;
    left: 0;
    bottom: -2.87rem
}

@media only screen and (min-width:1150px) {
    #classes {
        bottom: -6.25vw
    }
}

#classes h2 {
    --fz: 147.75%;
    --lh: 1.1337;
    margin-bottom: .4em;
    letter-spacing: .1em
}

@media only screen and (min-width:1150px) {
    #classes h2 {
        --fz: 2.92vw
    }
}

#classes p {
    --fz: 62.5%;
    --mr: auto;
    --ml: auto;
    width: 5.92rem;
    border-radius: .54rem
}

@media only screen and (min-width:1150px) {
    #classes p {
        --fz: 1.25vw;
        width: 9.44em;
        border-radius: .89em
    }
}

#classes>div {
    flex: 0 0 9.17rem
}

@media only screen and (min-width:1150px) {
    #classes>div {
        flex-basis: 18.26vw
    }
}

#classes .class1 {
    --cl-main: #9FD9F6;
    padding-top: 4.63rem;
    background: url("../img/bg-classes-01.webp") no-repeat left top/100% auto;
    aspect-ratio: 220/247
}

@media only screen and (min-width:1150px) {
    #classes .class1 {
        padding-top: 9.03vw
    }
}

#classes .class2 {
    --cl-main: #F4B4D0;
    padding-top: 4.25rem;
    background: url("../img/bg-classes-02.webp") no-repeat left top/100% auto;
    aspect-ratio: 220/265
}

@media only screen and (min-width:1150px) {
    #classes .class2 {
        padding-top: 8.54vw
    }
}

#classes .class3 {
    --cl-main: #F7B52C;
    padding-top: 4.88rem;
    background: url("../img/bg-classes-03.webp") no-repeat left top/100% auto;
    aspect-ratio: 220/255
}

@media only screen and (min-width:1150px) {
    #classes .class3 {
        padding-top: 9.72vw
    }
}

#event {
    --cw: 100%;
    overflow: hidden;
    padding-top: 4rem;
    padding-bottom: 3.63rem;
    margin-bottom: 2.5rem
}

@media only screen and (min-width:1150px) {
    #event {
        margin-bottom: 104px
    }
}

#event img {
    width: 100%
}

#concept {
    background: rgba(119, 203, 225, .26) url("../img/bg-concept-01.webp") no-repeat left top/100%;
    min-height: 38.42rem
}

@media only screen and (min-width:1150px) {
    #concept {
        background: url("../img/bg-concept-04-pc.webp") no-repeat right bottom/543px, url("../img/bg-concept-03-pc.webp") no-repeat left bottom/295px, url("../img/bg-concept-02-pc.webp") no-repeat left top/506px, rgba(119, 203, 225, .26) url("../img/bg-concept-01-pc.webp") no-repeat calc(50% - 323px) center/471px;
        min-height: 446px
    }
}

#concept h2 {
    padding-top: 2.33rem
}

@media only screen and (min-width:1150px) {
    #concept h2 {
        text-align: left;
        width: 537px;
        padding-top: 40px;
        margin-bottom: .4em;
        margin-left: calc(50% - 70px)
    }
}

#concept h2 img {
    width: 10rem
}

#concept h2+p {
    --fz: 104.17%;
    --pt: 0.42rem;
    letter-spacing: .04em
}

@media only screen and (min-width:1150px) {
    #concept h2+p {
        --fz: 20px;
        width: 537px;
        margin-left: calc(50% - 70px)
    }
}

#hope {
    padding-top: 1.96rem
}

@media only screen and (min-width:1150px) {
    #hope h2 {
        margin-bottom: 1.5em
    }
}

#hope h2 img {
    width: 4.08rem;
    margin-bottom: .7em
}

#hope .hopes-area {
    min-height: 40.58rem;
    --lh: 1.6667
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area {
        min-height: 616px;
        width: 1058px !important;
        margin: auto
    }
}

#hope .hopes-area>li:first-child {
    animation-delay: .2s
}

#hope .hopes-area>li:nth-child(2) {
    animation-delay: .4s
}

#hope .hopes-area>li:nth-child(3) {
    animation-delay: .6s
}

#hope .hopes-area>li:nth-child(4) {
    animation-delay: .8s
}

#hope .hopes-area>li:nth-child(5) {
    animation-delay: 1s
}

#hope .hopes-area>li:nth-child(6) {
    animation-delay: 1.2s
}

#hope .hopes-area>li:nth-child(7) {
    animation-delay: 1.4s
}

#hope .hopes-area .hope1 {
    background: url("../img/bg-hope-01.webp") no-repeat left top/100%;
    width: 11.02rem;
    height: 12.06rem;
    left: 4.04rem;
    top: 0;
    --pl: 0rem;
    --pt: 2.92rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope1 {
        left: 0;
        top: 78px
    }
}

#hope .hopes-area .hope2 {
    background: url("../img/bg-hope-02.webp") no-repeat left top/100%;
    width: 12.58rem;
    height: 10.96rem;
    left: 16.13rem;
    top: 0;
    --pt: 3rem;
    --pr: 1.25rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope2 {
        left: 259px;
        top: 12px
    }
}

#hope .hopes-area .hope3 {
    background: url("../img/bg-hope-03.webp") no-repeat left top/100%;
    width: 10.9rem;
    height: 11.13rem;
    left: .81rem;
    top: 11.42rem;
    --pl: 0rem;
    --pt: 3.33rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope3 {
        left: 810px;
        top: 0
    }
}

#hope .hopes-area .hope4 {
    background: url("../img/bg-hope-04.webp") no-repeat left top/100%;
    width: 10.94rem;
    height: 12.71rem;
    left: 10.63rem;
    top: 16.38rem;
    --pl: 0rem;
    --pt: 4.75rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope4 {
        left: 545px;
        top: 16px
    }
}

#hope .hopes-area .hope5 {
    background: url("../img/bg-hope-05.webp") no-repeat left top/100%;
    width: 10.9rem;
    height: 11.15rem;
    left: 19.63rem;
    top: 10.79rem;
    --pl: 0rem;
    --pt: 3.29rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope5 {
        left: 207px;
        top: 285px
    }
}

#hope .hopes-area .hope6 {
    background: url("../img/bg-hope-06.webp") no-repeat left top/100%;
    width: 11.08rem;
    height: 11.38rem;
    left: 3.17rem;
    top: 27.21rem;
    --pl: 0rem;
    --pt: 3.21rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope6 {
        left: 472px;
        top: 316px
    }
}

#hope .hopes-area .hope7 {
    background: url("../img/bg-hope-07.webp") no-repeat left top/100%;
    width: 12.75rem;
    height: 11.06rem;
    left: 18.33rem;
    top: 26.96rem;
    --pt: 3.21rem;
    --pr: 1.46rem
}

@media only screen and (min-width:1150px) {
    #hope .hopes-area .hope7 {
        left: 754px;
        top: 274px
    }
}

#forte {
    padding-top: 6rem;
    padding-bottom: 3rem;
    --cl-main: #e95383
}

#forte .card {
    padding: 2em 1.5em
}

@media only screen and (min-width:1150px) {
    #forte .card {
        padding: 1.5em 2em;
        text-align: center
    }
}

#forte .card .catch {
    --lh: 1.7188
}

#forte .card .body {
    letter-spacing: .05em
}

#support {
    background: url("../img/bg-support-04.webp") no-repeat center bottom/20.54rem;
    padding-top: 1.46rem;
    padding-bottom: 22.29rem
}

@media only screen and (min-width:1150px) {
    #support {
        --cw: 1081px;
        background: url("../img/bg-support-04.webp") no-repeat calc(50% + 270px) 357px/495px;
        padding-top: 70px;
        padding-bottom: 92px
    }
}

#support ul {
    --cw: 27.71rem
}

@media only screen and (min-width:1150px) {
    #support ul {
        --cw: 1081px;
        display: flex;
        flex-wrap: nowrap;
        gap: 0;
        justify-content: center;
        margin-top: 2em;
        margin-bottom: 2.2em
    }
}

#support li {
    display: flex;
    align-items: center;
    justify-content: center;
    --fz: 1.17rem;
    --lh: 1.7143
}

@media only screen and (min-width:1150px) {
    #support li {
        --fz: 22px;
        padding-top: .5em
    }
}

#support li:first-child {
    background: url("../img/bg-support-01.webp") no-repeat center top/27.71rem;
    height: 10.96rem
}

@media only screen and (min-width:1150px) {
    #support li:first-child {
        background: url("../img/bg-support-01-pc.webp") no-repeat center top/14.83rem;
        height: 8.6rem;
        flex: 0 0 14.83rem
    }
}

#support li:nth-child(2) {
    background: url("../img/bg-support-02.webp") no-repeat center top/27.29rem;
    height: 10.38rem
}

@media only screen and (min-width:1150px) {
    #support li:nth-child(2) {
        background: url("../img/bg-support-02-pc.webp") no-repeat center top/15.25rem;
        height: 7.98rem;
        flex: 0 0 15.25rem
    }
}

#support li:nth-child(3) {
    background: url("../img/bg-support-03.webp") no-repeat center top/27.1rem;
    height: 9.38rem
}

@media only screen and (min-width:1150px) {
    #support li:nth-child(3) {
        background: url("../img/bg-support-03-pc.webp") no-repeat center top/14.52rem;
        height: 8.13rem;
        flex: 0 0 14.52rem
    }
}

#support h3 {
    --fz: 1.33rem;
    --pt: 1em
}

@media only screen and (min-width:1150px) {
    #support h3 {
        --fz: 27px;
        margin-right: 50%
    }
}

@media only screen and (min-width:1150px) {
    #support p.body {
        --fz: 18px;
        width: 490px;
        margin-right: 50%
    }
}

#goldenage {
    --cl-main: #9bd2f0;
    padding-top: 2rem;
    padding-bottom: 2.58rem
}

@media only screen and (min-width:1150px) {
    #goldenage {
        padding-top: 76px;
        padding-bottom: 105px
    }
}

#goldenage .card {
    --lh: 1.6667;
    padding: .6em 1em;
    border-radius: 1.33rem
}

@media only screen and (min-width:1150px) {
    #goldenage .card {
        --fz: 22px;
        --cw: 1086px
    }
}

@media only screen and (min-width:1150px) {
    #goldenage .body {
        font-size: 18px
    }
}

@media only screen and (min-width:1150px) {
    #goldenage figure img {
        width: 840px
    }
}

#goldenage+.arrow {
    margin-top: -.08rem;
    margin-bottom: 1.88rem
}

#goldenage+.arrow img {
    width: 5.46rem
}

#course>.intro {
    padding-top: 1.5rem
}

@media only screen and (min-width:1150px) {
    #course>.intro {
        background: 0 0;
        padding-bottom: 34px
    }
}

#course>.intro h2 {
    width: 7.5rem;
    height: 2.33rem;
    border-radius: 1.17rem;
    --mb: 0.5em
}

#course>section {
    padding-top: 1.5rem
}

@media only screen and (max-width:1149px) {
    #course>section {
        max-width: none
    }
}

@media only screen and (min-width:1150px) {
    #course>section {
        border-radius: 51px
    }
}

#course>section>.card {
    padding-bottom: 1.7em
}

@media only screen and (min-width:1150px) {
    #course>section>.card {
        --cw: 1046px;
        width: 100%;
        position: relative
    }
}

#course>section>.card:not(:last-child) {
    margin-bottom: 1.96rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card:not(:last-child) {
        margin-bottom: 27px
    }
}

#course>section>.card>h4 {
    --pt: 0.3em;
    --pb: 0.3em;
    --ml: auto;
    --mr: auto;
    --mb: 0.4em;
    width: 18.25rem;
    font-size: 1.25rem;
    border-radius: 1rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>h4 {
        width: 362px;
        font-size: 25px;
        position: absolute;
        left: 23px;
        top: 23px
    }
}

#course>section>.card>h4 small {
    font-size: .92rem;
    vertical-align: .15em
}

@media only screen and (min-width:1150px) {
    #course>section>.card>h4 small {
        font-size: 18px
    }
}

#course>section>.card>.age {
    --pt: 0.5em;
    --pb: 0.6em;
    --pl: 3em;
    --pr: 3em;
    --ml: auto;
    --mr: auto;
    --mt: -2.8em;
    --fz: 0.92rem;
    --lh: 1;
    width: -moz-fit-content;
    width: fit-content;
    border-radius: 1rem
}

#course>section>.card>.catch {
    --fz: 1.08rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.catch {
        --fz: 20px;
        position: absolute;
        left: 406px;
        top: 24px
    }
}

#course>section>.card>.body-area {
    flex-wrap: nowrap;
    --cg: 1em;
    margin-bottom: 1em
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.body-area {
        display: block
    }
}

#course>section>.card>.body-area>.eye-catch {
    flex: 0 0 11.25rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.body-area>.eye-catch {
        width: 269px;
        position: absolute;
        left: 409px;
        top: 67px
    }
}

#course>section>.card>.body-area>.body {
    --fz: 0.96rem;
    --lh: 1.74
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.body-area>.body {
        --fz: 18px;
        width: 337px;
        position: absolute;
        left: 38px;
        top: 89px
    }

    #course>section>.card>.body-area>.body small {
        font-size: 18px
    }
}

#course>section>.card>.price-area {
    --lh: 1;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: 0
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area {
        display: block
    }
}

#course>section>.card>.price-area:not(:last-child) {
    margin-bottom: 1.5em
}

#course>section>.card>.price-area>.headings {
    padding-top: .5em
}

#course>section>.card>.price-area>.headings h5 {
    --fz: 1.25rem;
    --mb: 0.2em
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.headings h5 {
        --fz: 21px;
        position: absolute;
        left: 700px;
        top: 69px
    }
}

#course>section>.card>.price-area>.headings h5 small {
    --fz: 0.92rem;
    vertical-align: .1em
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.headings h5 small {
        --fz: 16px
    }
}

#course>section>.card>.price-area>.headings>.time {
    --fz: 0.83rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.headings>.time {
        --fz: 16px;
        position: absolute;
        left: 824px;
        top: 74px
    }
}

#course>section>.card>.price-area>.headings>.note {
    --fz: 0.82rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.headings>.note {
        --fz: 14px;
        position: absolute;
        left: 864px;
        top: 211px
    }
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.prices {
        width: 321px;
        position: absolute;
        left: 705px;
        top: 99px
    }
}

#course>section>.card>.price-area>.prices>.price {
    --mb: 0;
    --cg: 0.83rem;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.prices>.price>.time {
        --fz: 18px
    }
}

#course>section>.card>.price-area>.prices>.price>.amount>.num {
    --fz: 2.92rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.prices>.price>.amount>.num {
        --fz: 50px
    }
}

#course>section>.card>.price-area>.prices>.price>.amount>.yen {
    --fz: 1.33rem
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.price-area>.prices>.price>.amount>.yen {
        --fz: 26px
    }
}

@media only screen and (min-width:1150px) {
    #course>section>.card>.practice-image {
        width: 1002px;
        position: absolute;
        left: 23px;
        top: 232px
    }
}

#course>section>.card>.practice-image img {
    width: 100%
}

#course>section.gymnastics-class {
    padding-bottom: 3.42rem;
    margin-bottom: 2.38rem
}

#course>section.gymnastics-class>h3 {
    --cl-main: #1ca9cd
}

@media only screen and (min-width:1150px) {
    #course>section.gymnastics-class>.card {
        height: 386px
    }
}

#course>section.gymnastics-class>.card:first-of-type {
    --cl-main: #e95383
}

#course>section.gymnastics-class>.card:nth-of-type(2) {
    --cl-main: #00b1a2
}

#course>section.gymnastics-class>.card:nth-of-type(3) {
    --cl-main: #1ca9cd
}

#course>section.gymnastics-class>.card:nth-of-type(5) {
    --cl-main: #f7931e
}

#course>section.backflip-class {
    /* background-color: #9bd2f0; */
    background-color: #fff7ab;
    padding-bottom: 2.08rem;
    margin-bottom: 2.38rem;
    --cl-main: #F7B52C
}

#course>section.backflip-class>h3+p {
    --mb: 2em
}

#course>section.backflip-class>.card>.age {
    --mb: 2em
}

@media only screen and (min-width:1150px) {
    #course>section.backflip-class>.card {
        height: 328px
    }

    #course>section.backflip-class>.card .eye-catch {
        width: 300px;
        left: 359px;
        top: 48px
    }

    #course>section.backflip-class>.card .body {
        line-height: 1.9444;
        width: 300px;
        left: 36px;
        top: 55px
    }

    #course>section.backflip-class>.card>.price-area>.headings h5 {
        left: 694px;
        top: 102px
    }

    #course>section.backflip-class>.card>.price-area>.headings>.time {
        left: 827px;
        top: 107px
    }

    #course>section.backflip-class>.card>.price-area>.headings>.note {
        left: 841px;
        top: 249px
    }

    #course>section.backflip-class>.card>.price-area>.prices {
        left: 699px;
        top: 135px
    }
}

#course>section.spoiku-class {
    /* --cl-main: #f7931e; */
    --cl-main: #F4B4D0;
    background-color: #ffa;
    padding-bottom: 2.08rem;
    margin-bottom: 2.38rem
}

#course>section.spoiku-class>h3+p {
    text-align: center;
    --mb: 2em
}

@media only screen and (min-width:1150px) {
    #course>section.spoiku-class>.card {
        height: 668px
            /* height: 1260px; */
    }

    #course>section.spoiku-class>.card>.catch {
        width: 100%;
        --lh: 1.6;
        left: 0;
        top: 40px
    }

    #course>section.spoiku-class>.card .eye-catch {
        width: 300px;
        left: 372px;
        top: 124px
    }

    #course>section.spoiku-class>.card .body {
        line-height: 1.9444;
        width: 300px;
        left: 42px;
        top: 151px
    }

    #course>section.spoiku-class>.card>.price-area>.headings h5 {
        left: 689px;
        top: 158px
    }

    #course>section.spoiku-class>.card>.price-area>.headings>.time {
        left: 822px;
        top: 164px
    }

    #course>section.spoiku-class>.card>.price-area>.headings>.note {
        left: 836px;
        top: 300px
    }

    #course>section.spoiku-class>.card>.price-area>.prices {
        left: 695px;
        top: 187px
    }

    #course>section.spoiku-class>.card>.practice-image {
        width: 968px;
        left: 40px;
        top: 396px
    }
}

#qa {
    padding-bottom: 4.17rem
}

#qa h2 {
    --mb: 2em
}

#qa h2 img {
    width: 7.54rem
}

@media only screen and (max-width:1149px) {
    #qa .qa-list {
        --cw: none
    }
}

.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    width: 1px;
    word-wrap: normal !important;
    word-break: normal
}

@media print {

    *,
    :after,
    :before {
        text-shadow: none !important;
        background: 0 0 !important;
        box-shadow: none !important;
        color: #000 !important
    }

    a,
    a:visited {
        text-decoration: underline
    }

    a[href]::after {
        content: " (" attr(href) ")"
    }

    img {
        page-break-inside: avoid
    }

    h2,
    h3,
    p {
        orphans: 3;
        widows: 3
    }

    h2,
    h3 {
        page-break-after: avoid
    }
}

#banner {
    position: fixed;
    bottom: 0;
    z-index: 10;
    background: #EEF5DC;
    width: 100%;
    padding: 0;
}

#banner a {
    width: 100%;
    height: 5vw;
    margin: 0.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 100%;
}

#banner a img {
    width: 39%;
    display: inline-block;
}

@media screen and (max-width:1150px) {
    #banner {
        position: fixed;
        bottom: 0;
        z-index: 10;
        background: #EEF5DC;
        width: 100%;
        padding: 0;
    }

    #banner a {
        width: 100%;
        height: 19vw;
        margin: 0;
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        max-width: 100%;
    }

    #banner a img {
        width: 80%;
        display: inline-block;
    }
}