@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;
  /*margin-top: 2em;;*/
}

#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
}

@media only screen and (max-width:1150px) {
.scroll {
    overflow-x: scroll;
  }

  .scroll img{
    width: 100%;
    min-width: 500px
  }
}
.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
}

.fzm {
    --fz: 1.12rem
  }

.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: -4em
  }
}

#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;
  margin-bottom: 4rem;
  --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: #9FD9F6
}

@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: #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: #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
  }
  #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
  }
}


#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;
}
}
.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
  }
}
