@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;500;700;900&display=swap");
body:has(.show-box.active) .top, body:has(.show-box.active) .footer {
  z-index: 500;
}

.wrapper {
  position: relative;
  background-color: #FFFFFF;
  margin: 0;
  font-family: "Noto Sans TC", "微軟正黑體", sans-serif, arial;
  font-weight: 300;
  box-sizing: border-box;
  scroll-behavior: smooth;
  transition: 0.3s;
  transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  font-size: 16px;
  overflow: hidden;
  /* mod_table 開始 */
  /* mod_table 結束 */
  /* mod_tag 開始 */
  /* mod_tag 結束 */
  /* mod_card 開始 */
  /* mod_card 結束 */
}
@media screen and (max-width: 1280px) {
  .wrapper {
    font-size: 15px;
  }
}
@media screen and (max-width: 360px) {
  .wrapper {
    font-size: 12px;
  }
}
.wrapper *, .wrapper *:before, .wrapper *:after {
  position: relative;
  margin: 0;
  font-family: "Noto Sans TC", "微軟正黑體", sans-serif, arial;
  font-weight: 500;
  box-sizing: border-box;
  scroll-behavior: smooth;
  transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.wrapper *:focus {
  outline: none;
}
.wrapper :is(p) {
  font-family: "Noto Sans TC", "微軟正黑體", sans-serif, arial;
}
.wrapper :is(img) {
  display: block;
  width: 100%;
}
.wrapper :is(a:not(.text-link)) {
  text-decoration: none;
}
.wrapper :is(ul, li) {
  display: inline-block;
}
.wrapper .section {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  z-index: 100;
}
.wrapper .section-content {
  display: flex;
  flex-flow: column;
  gap: 2em;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 4em 1em;
}
.wrapper .row {
  display: flex;
  flex-flow: row;
  gap: 2em;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.wrapper .col {
  display: flex;
  flex-flow: column;
  gap: 1em;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.wrapper .content {
  display: flex;
  flex-flow: row nowrap;
  gap: 2em;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 1440px;
}
.wrapper .text-cont {
  display: flex;
  flex-flow: column;
  gap: 0.25em;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 1024px;
}
.wrapper .flex-wrap {
  flex-wrap: wrap;
}
.wrapper .flex-between {
  --justify-content: space-between;
  justify-content: space-between;
}
.wrapper .main-title {
  display: flex;
  flex-flow: column;
  gap: 1em;
  justify-content: center;
  align-items: center;
}
.wrapper .title {
  color: var(--color, #A8AAAE);
  font-size: round(down, 2.5em, 2px);
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
}
.wrapper .title span:not([class^=break-], [class*=" break-"]) {
  display: inline-block;
  font-weight: 700;
}
@media screen and (max-width: 640px) {
  .wrapper .title {
    font-size: round(down, 2.25em, 2px);
  }
}
@media screen and (max-width: 480px) {
  .wrapper .title {
    font-size: 2em;
  }
}
.wrapper .subject {
  color: var(--color, #1D2836);
  font-size: round(down, 1.5em, 2px);
  font-weight: 500;
  text-align: center;
  line-height: 1.25;
}
.wrapper .subject span:not([class^=break-], [class*=" break-"]) {
  display: inline-block;
  font-weight: 500;
}
.wrapper .text {
  color: var(--color, #1D2836);
  font-size: round(down, 1.25em, 2px);
  font-weight: 500;
  text-align: justify;
}
.wrapper .text span:not([class^=break-], [class*=" break-"]) {
  display: inline;
}
.wrapper .text-xl {
  font-size: 1.75em;
}
.wrapper .text-lg {
  font-size: 1.5em;
}
.wrapper .text-sm {
  font-size: 1em;
}
.wrapper .text-xs {
  font-size: 0.875em;
}
.wrapper .text-left {
  text-align: left;
  --text-align: left;
}
.wrapper .text-center {
  text-align: center;
  --text-align: center;
}
.wrapper .text-right {
  text-align: right;
  --text-align: right;
}
.wrapper .text-justify {
  text-align: justify;
  --text-align: justify;
}
.wrapper .text-nowrap {
  white-space: nowrap;
}
.wrapper .text-red {
  color: #E8636E;
  --color: #E8636E;
}
.wrapper .text-red-light {
  color: #FAE0E2;
  --color: #FAE0E2;
}
.wrapper .text-red-thin {
  color: #FEF2F3;
  --color: #FEF2F3;
}
.wrapper .text-blue {
  color: #237FE4;
  --color: #237FE4;
}
.wrapper .text-blue-light {
  color: #DEE6FF;
  --color: #DEE6FF;
}
.wrapper .text-blue-thin {
  color: #F0F5FF;
  --color: #F0F5FF;
}
.wrapper .text-orange {
  color: #F38A3A;
  --color: #F38A3A;
}
.wrapper .text-orange-light {
  color: #FFE7DB;
  --color: #FFE7DB;
}
.wrapper .text-orange-thin {
  color: #FFF5F0;
  --color: #FFF5F0;
}
.wrapper .text-green {
  color: #3CA947;
  --color: #3CA947;
}
.wrapper .text-green-light {
  color: #C9EFCC;
  --color: #C9EFCC;
}
.wrapper .text-green-thin {
  color: #ECFFED;
  --color: #ECFFED;
}
.wrapper .text-white {
  color: #FFFFFF;
  --color: #FFFFFF;
}
.wrapper .text-black {
  color: #000000;
  --color: #000000;
}
.wrapper .text-yellow-sp {
  color: #FFFFB8;
  --color: #FFFFB8;
}
.wrapper .ps-note {
  padding: 0 0 0 round(down, 0.75em, 2px);
  color: #A8AAAE;
  font-size: 16px;
  line-height: 1.25;
  text-align: justify;
}
.wrapper .ps-note:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "*";
  display: block;
  font-size: round(down, 1.25em, 2px);
  color: inherit;
}
@media screen and (max-width: 960px) {
  .wrapper .ps-note {
    font-size: 14px;
  }
}
.wrapper [class^=break-], .wrapper [class*=" break-"] {
  display: inline;
}
@media screen and (max-width: 1920px) {
  .wrapper .break-6xl {
    display: block;
  }
}
@media screen and (max-width: 1680px) {
  .wrapper .break-5xl {
    display: block;
  }
}
@media screen and (max-width: 1440px) {
  .wrapper .break-4xl {
    display: block;
  }
}
@media screen and (max-width: 1360px) {
  .wrapper .break-3xl {
    display: block;
  }
}
@media screen and (max-width: 1280px) {
  .wrapper .break-2xl {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .wrapper .break-xl {
    display: block;
  }
}
@media screen and (max-width: 960px) {
  .wrapper .break-lg {
    display: block;
  }
}
@media screen and (max-width: 800px) {
  .wrapper .break-md {
    display: block;
  }
}
@media screen and (max-width: 640px) {
  .wrapper .break-sm {
    display: block;
  }
}
@media screen and (max-width: 480px) {
  .wrapper .break-xs {
    display: block;
  }
}
@media screen and (max-width: 360px) {
  .wrapper .break-2xs {
    display: block;
  }
}
@media screen and (max-width: 320px) {
  .wrapper .break-3xs {
    display: block;
  }
}
.wrapper .w-full {
  width: 100%;
}
.wrapper .w-auto {
  width: auto;
}
.wrapper .w-6xl {
  --width: 1920px;
  width: var(--width, 1920px);
}
.wrapper .w-max-6xl {
  --width: 1920px;
  max-width: var(--width, 1920px);
}
.wrapper .w-min-6xl {
  --width: 1920px;
  min-width: var(--width, 1920px);
}
.wrapper .w-5xl {
  --width: 1680px;
  width: var(--width, 1680px);
}
.wrapper .w-max-5xl {
  --width: 1680px;
  max-width: var(--width, 1680px);
}
.wrapper .w-min-5xl {
  --width: 1680px;
  min-width: var(--width, 1680px);
}
.wrapper .w-4xl {
  --width: 1440px;
  width: var(--width, 1440px);
}
.wrapper .w-max-4xl {
  --width: 1440px;
  max-width: var(--width, 1440px);
}
.wrapper .w-min-4xl {
  --width: 1440px;
  min-width: var(--width, 1440px);
}
.wrapper .w-3xl {
  --width: 1360px;
  width: var(--width, 1360px);
}
.wrapper .w-max-3xl {
  --width: 1360px;
  max-width: var(--width, 1360px);
}
.wrapper .w-min-3xl {
  --width: 1360px;
  min-width: var(--width, 1360px);
}
.wrapper .w-2xl {
  --width: 1280px;
  width: var(--width, 1280px);
}
.wrapper .w-max-2xl {
  --width: 1280px;
  max-width: var(--width, 1280px);
}
.wrapper .w-min-2xl {
  --width: 1280px;
  min-width: var(--width, 1280px);
}
.wrapper .w-xl {
  --width: 1024px;
  width: var(--width, 1024px);
}
.wrapper .w-max-xl {
  --width: 1024px;
  max-width: var(--width, 1024px);
}
.wrapper .w-min-xl {
  --width: 1024px;
  min-width: var(--width, 1024px);
}
.wrapper .w-lg {
  --width: 960px;
  width: var(--width, 960px);
}
.wrapper .w-max-lg {
  --width: 960px;
  max-width: var(--width, 960px);
}
.wrapper .w-min-lg {
  --width: 960px;
  min-width: var(--width, 960px);
}
.wrapper .w-md {
  --width: 800px;
  width: var(--width, 800px);
}
.wrapper .w-max-md {
  --width: 800px;
  max-width: var(--width, 800px);
}
.wrapper .w-min-md {
  --width: 800px;
  min-width: var(--width, 800px);
}
.wrapper .w-sm {
  --width: 640px;
  width: var(--width, 640px);
}
.wrapper .w-max-sm {
  --width: 640px;
  max-width: var(--width, 640px);
}
.wrapper .w-min-sm {
  --width: 640px;
  min-width: var(--width, 640px);
}
.wrapper .w-xs {
  --width: 480px;
  width: var(--width, 480px);
}
.wrapper .w-max-xs {
  --width: 480px;
  max-width: var(--width, 480px);
}
.wrapper .w-min-xs {
  --width: 480px;
  min-width: var(--width, 480px);
}
.wrapper .w-2xs {
  --width: 360px;
  width: var(--width, 360px);
}
.wrapper .w-max-2xs {
  --width: 360px;
  max-width: var(--width, 360px);
}
.wrapper .w-min-2xs {
  --width: 360px;
  min-width: var(--width, 360px);
}
.wrapper .w-3xs {
  --width: 320px;
  width: var(--width, 320px);
}
.wrapper .w-max-3xs {
  --width: 320px;
  max-width: var(--width, 320px);
}
.wrapper .w-min-3xs {
  --width: 320px;
  min-width: var(--width, 320px);
}
.wrapper .button-cont {
  display: flex;
  flex-flow: row wrap;
  gap: 0.5em;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.wrapper .btn, .wrapper [class^=btn-], .wrapper [class*=" btn-"] {
  background-color: var(--btn-bg-color, #FFFFFF);
  padding: 0.25em 1.25em;
  color: var(--btn-color, #237FE4);
  font-size: 1.25em;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  border: 2px solid var(--btn-border-color, #237FE4);
  border-radius: var(--btn-radius, 2em);
  transition: 0.2s;
  --icon-size: 1em;
}
.wrapper .btn .icon, .wrapper .btn [class^=icon-], .wrapper .btn [class*=" icon-"], .wrapper [class^=btn-] .icon, .wrapper [class^=btn-] [class^=icon-], .wrapper [class^=btn-] [class*=" icon-"], .wrapper [class*=" btn-"] .icon, .wrapper [class*=" btn-"] [class^=icon-], .wrapper [class*=" btn-"] [class*=" icon-"] {
  background-color: var(--btn-color, #FFFFFF);
}
.wrapper .btn .icon-arrow-right, .wrapper [class^=btn-] .icon-arrow-right, .wrapper [class*=" btn-"] .icon-arrow-right {
  margin-right: -0.5em;
}
.wrapper .btn:hover, .wrapper [class^=btn-]:hover, .wrapper [class*=" btn-"]:hover {
  --btn-bg-color: #237FE4;
  --btn-color: #FFFFFF;
  --icon-color: #FFFFFF;
}
.wrapper .btn-w, .wrapper [class^=btn-w-], .wrapper [class*=" btn-w-"] {
  --btn-bg-color: #FFFFFF;
  --btn-color: #237FE4;
  --btn-border-color: #FFFFFF;
}
.wrapper .btn-w:hover, .wrapper [class^=btn-w-]:hover, .wrapper [class*=" btn-w-"]:hover {
  --btn-bg-color: #F0F5FF;
  --btn-color: #237FE4;
  --icon-color: #237FE4;
  --btn-border-color: #237FE4;
}
.wrapper .btn-small {
  font-size: 1em;
  padding: 2px 0.75em;
}
.wrapper .btn-large {
  font-size: 1.5em;
}
.wrapper .btn-red {
  --btn-color: #E8636E;
  --btn-border-color: #E8636E;
}
.wrapper .btn-red:hover {
  --btn-bg-color: #E8636E;
}
.wrapper .btn-w-red {
  --btn-color: #E8636E;
}
.wrapper .btn-w-red:hover {
  --btn-bg-color: #FEF2F3;
  --btn-color: #E8636E;
  --btn-border-color: #E8636E;
}
.wrapper .btn-blue {
  --btn-color: #237FE4;
  --btn-border-color: #237FE4;
}
.wrapper .btn-blue:hover {
  --btn-bg-color: #237FE4;
}
.wrapper .btn-w-blue {
  --btn-color: #237FE4;
}
.wrapper .btn-w-blue:hover {
  --btn-bg-color: #F0F5FF;
  --btn-color: #237FE4;
  --btn-border-color: #237FE4;
}
.wrapper .btn-orange {
  --btn-color: #F38A3A;
  --btn-border-color: #F38A3A;
}
.wrapper .btn-orange:hover {
  --btn-bg-color: #F38A3A;
}
.wrapper .btn-w-orange {
  --btn-color: #F38A3A;
}
.wrapper .btn-w-orange:hover {
  --btn-bg-color: #FFF5F0;
  --btn-color: #F38A3A;
  --btn-border-color: #F38A3A;
}
.wrapper .btn-green {
  --btn-color: #3CA947;
  --btn-border-color: #3CA947;
}
.wrapper .btn-green:hover {
  --btn-bg-color: #3CA947;
}
.wrapper .btn-w-green {
  --btn-color: #3CA947;
}
.wrapper .btn-w-green:hover {
  --btn-bg-color: #ECFFED;
  --btn-color: #3CA947;
  --btn-border-color: #3CA947;
}
.wrapper .btn-white {
  --btn-bg-color: #FFFFFF;
  --btn-border-color: #FFFFFF;
}
.wrapper .btn-white:hover {
  --btn-color: #FFFFFF;
}
.wrapper .btn-black {
  --btn-bg-color: #000000;
  --btn-border-color: #000000;
}
.wrapper .btn-black:hover {
  --btn-color: #000000;
}
.wrapper .btn-yellow-sp {
  --btn-bg-color: #FFFFB8;
  --btn-border-color: #FFFFB8;
}
.wrapper .btn-yellow-sp:hover {
  --btn-color: #FFFFB8;
}
.wrapper .btn-close {
  position: absolute;
  display: block;
  background-color: #FFFFFF;
  width: 3em;
  height: 3em;
  padding: round(down, 0.5em, 2px);
  border: 1px solid #FFFFFF;
  border-radius: 50%;
  cursor: pointer;
}
.wrapper .btn-close:hover {
  background-color: #FFFFFF;
}
.wrapper .btn-close:hover .icon {
  background-color: #237FE4;
}
.wrapper .icon, .wrapper [class^=icon-], .wrapper [class*=" icon-"] {
  display: inline-block;
  background: no-repeat center/cover;
  background-color: var(--icon-color, #FFFFFF);
  background-size: 0 0;
  width: var(--icon-size, 2em);
  height: var(--icon-size, 2em);
  aspect-ratio: 1/1;
  mask: no-repeat center/cover;
  -webkit-mask: no-repeat center/cover;
}
.wrapper .icon-arrow-left {
  background-image: url(../images/icons/arrow-left.svg);
  mask-image: url(../images/icons/arrow-left.svg);
  -webkit-mask-image: url(../images/icons/arrow-left.svg);
}
.wrapper .icon-arrow-right {
  background-image: url(../images/icons/arrow-right.svg);
  mask-image: url(../images/icons/arrow-right.svg);
  -webkit-mask-image: url(../images/icons/arrow-right.svg);
}
.wrapper .icon-arrow-down {
  background-image: url(../images/icons/arrow-down.svg);
  mask-image: url(../images/icons/arrow-down.svg);
  -webkit-mask-image: url(../images/icons/arrow-down.svg);
}
.wrapper .icon-right {
  background-image: url(../images/icons/right.svg);
  mask-image: url(../images/icons/right.svg);
  -webkit-mask-image: url(../images/icons/right.svg);
}
.wrapper .icon-x-mark {
  background-image: url(../images/icons/x-mark.svg);
  mask-image: url(../images/icons/x-mark.svg);
  -webkit-mask-image: url(../images/icons/x-mark.svg);
}
.wrapper .color-primary {
  color: var(--color, #237FE4);
}
.wrapper .color-secondary {
  color: var(--color, #DEE6FF);
}
.wrapper .color-tertiary {
  color: var(--color, #F0F5FF);
}
.wrapper .bg-red {
  --bg-color: #E8636E;
  background-color: var(--bg-color);
}
.wrapper .bg-red-light {
  --bg-color: #FAE0E2;
  background-color: var(--bg-color);
}
.wrapper .bg-red-thin {
  --bg-color: #FEF2F3;
  background-color: var(--bg-color);
}
.wrapper .color-red {
  --color: #E8636E;
  color: var(--color);
}
.wrapper .color-red-light {
  --color: #FAE0E2;
  color: var(--color);
}
.wrapper .color-red-thin {
  --color: #FEF2F3;
  color: var(--color);
}
.wrapper .bg-blue {
  --bg-color: #237FE4;
  background-color: var(--bg-color);
}
.wrapper .bg-blue-light {
  --bg-color: #DEE6FF;
  background-color: var(--bg-color);
}
.wrapper .bg-blue-thin {
  --bg-color: #F0F5FF;
  background-color: var(--bg-color);
}
.wrapper .color-blue {
  --color: #237FE4;
  color: var(--color);
}
.wrapper .color-blue-light {
  --color: #DEE6FF;
  color: var(--color);
}
.wrapper .color-blue-thin {
  --color: #F0F5FF;
  color: var(--color);
}
.wrapper .bg-orange {
  --bg-color: #F38A3A;
  background-color: var(--bg-color);
}
.wrapper .bg-orange-light {
  --bg-color: #FFE7DB;
  background-color: var(--bg-color);
}
.wrapper .bg-orange-thin {
  --bg-color: #FFF5F0;
  background-color: var(--bg-color);
}
.wrapper .color-orange {
  --color: #F38A3A;
  color: var(--color);
}
.wrapper .color-orange-light {
  --color: #FFE7DB;
  color: var(--color);
}
.wrapper .color-orange-thin {
  --color: #FFF5F0;
  color: var(--color);
}
.wrapper .bg-green {
  --bg-color: #3CA947;
  background-color: var(--bg-color);
}
.wrapper .bg-green-light {
  --bg-color: #C9EFCC;
  background-color: var(--bg-color);
}
.wrapper .bg-green-thin {
  --bg-color: #ECFFED;
  background-color: var(--bg-color);
}
.wrapper .color-green {
  --color: #3CA947;
  color: var(--color);
}
.wrapper .color-green-light {
  --color: #C9EFCC;
  color: var(--color);
}
.wrapper .color-green-thin {
  --color: #ECFFED;
  color: var(--color);
}
.wrapper .bg-white {
  --bg-color: #FFFFFF;
  background-color: var(--bg-color);
}
.wrapper .color-white {
  --color: #FFFFFF;
  color: var(--color);
}
.wrapper .bg-black {
  --bg-color: #000000;
  background-color: var(--bg-color);
}
.wrapper .color-black {
  --color: #000000;
  color: var(--color);
}
.wrapper .bg-yellow-sp {
  --bg-color: #FFFFB8;
  background-color: var(--bg-color);
}
.wrapper .color-yellow-sp {
  --color: #FFFFB8;
  color: var(--color);
}
.wrapper .anchor {
  position: absolute;
  top: -8em;
}
@media screen and (max-width: 800px) {
  .wrapper .anchor {
    top: -10em;
  }
}
.wrapper .banner {
  display: flex;
  justify-content: center;
  align-items: center;
  background: no-repeat center/cover;
  background-image: url(../images/banner/bn_bg.jpg);
  background-color: #FFFFFF;
  width: 100%;
  height: auto;
  aspect-ratio: 1920/960;
  margin-top: 65px;
  overflow: hidden;
}
.wrapper .banner .deco-cont .tree {
  position: absolute;
  width: 40%;
  max-width: 720px;
  height: auto;
  aspect-ratio: 720/960;
  animation: tree-swing 10s ease-in-out infinite;
}
.wrapper .banner .deco-cont .tree-left {
  top: -2vw;
  left: -2vw;
  transform-origin: left bottom;
}
.wrapper .banner .deco-cont .tree-right {
  top: -4vw;
  right: -2vw;
  transform-origin: right bottom;
  --rotate: -1.8deg;
}
.wrapper .banner .deco-cont .sunlight {
  position: absolute;
  top: 0;
  left: 1%;
  width: 50%;
  max-width: 960px;
  height: auto;
  aspect-ratio: 960/600;
  opacity: 0.6;
  filter: blur(4px);
  transform-origin: top left;
  animation: sun-light 10s ease infinite;
}
.wrapper .banner .slogn-cont {
  position: absolute;
  top: 20vw;
  left: 12vw;
  display: flex;
  flex-flow: column;
  gap: 0.5em;
  justify-content: flex-start;
  align-items: flex-start;
  width: 36%;
  max-width: 700px;
  filter: drop-shadow(0 4px 8px #21283333);
}
.wrapper .banner .slogn-cont .bubble {
  position: absolute;
  width: 14%;
  max-width: 100px;
  height: auto;
  aspect-ratio: 100/120;
}
.wrapper .banner .slogn-cont .bubble-left {
  top: 36%;
  left: -14%;
}
.wrapper .banner .slogn-cont .bubble-right {
  top: -12%;
  right: -5%;
}
.wrapper .banner .slogn-cont .slogn {
  width: 100%;
  height: auto;
  aspect-ratio: 700/230;
}
.wrapper .banner .slogn-cont .slogn-01 {
  width: 100%;
}
.wrapper .banner .slogn-cont .slogn-02 {
  position: absolute;
  top: 1%;
  right: 26%;
  width: 22%;
  height: auto;
  aspect-ratio: 152/192;
  transform-origin: center bottom;
  animation: fade-shake 3s ease infinite;
}
.wrapper .banner .slogn-cont .bn-btn {
  display: block;
  width: 42%;
  height: auto;
  aspect-ratio: 300/94;
  cursor: pointer;
  transition: 0.2s;
}
.wrapper .banner .slogn-cont .bn-btn:hover {
  filter: brightness(1.2);
}
.wrapper .banner .model-cont {
  position: absolute;
  right: 22vw;
  bottom: -4vw;
  width: 30%;
  max-width: 560px;
  height: auto;
  aspect-ratio: 560/800;
  filter: drop-shadow(0 4px 8px #21283333);
}
.wrapper .banner .model-cont .ginny {
  width: 100%;
}
.wrapper .banner .model-cont .ginny-sign {
  position: absolute;
  top: 64%;
  right: -30%;
  width: 40%;
  height: auto;
  aspect-ratio: 240/120;
}
@media screen and (min-width: 1921px) {
  .wrapper .banner .deco-cont .tree, .wrapper .banner .deco-cont .sunlight {
    max-width: unset;
  }
  .wrapper .banner .slogn-cont {
    max-width: unset;
  }
  .wrapper .banner .model-cont {
    max-width: unset;
  }
}
@media screen and (max-width: 1024px) {
  .wrapper .banner .slogn-cont {
    top: 18vw;
    left: 10vw;
    gap: 0;
    width: 40%;
  }
  .wrapper .banner .model-cont {
    right: 16vw;
    width: 34%;
  }
}
@media screen and (max-width: 640px) {
  .wrapper .banner {
    aspect-ratio: 9/10;
  }
  .wrapper .banner .deco-cont .tree {
    width: 48%;
  }
  .wrapper .banner .deco-cont .sunlight {
    width: 60%;
  }
  .wrapper .banner .slogn-cont {
    top: 11vw;
    left: calc(50% + 1vw);
    align-items: center;
    width: 64%;
    transform: translateX(-50%);
  }
  .wrapper .banner .slogn-cont .bn-btn {
    width: 56%;
    margin-top: -1vw;
  }
  .wrapper .banner .model-cont {
    left: calc(50% - 2vw);
    right: unset;
    width: 50%;
    transform: translateX(-50%);
  }
}
@media screen and (max-width: 480px) {
  .wrapper .banner {
    aspect-ratio: 3/4;
  }
  .wrapper .banner .slogn-cont {
    top: 13vw;
    width: 76%;
  }
  .wrapper .banner .model-cont {
    width: 60%;
  }
}
.wrapper .deco-cont {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.wrapper .wave-shape {
  position: absolute;
  left: 0;
  bottom: -1px;
  display: flex;
  background-color: transparent;
  width: 102vmax;
  height: auto;
  aspect-ratio: 960/30;
}
.wrapper .wave-shape::before, .wrapper .wave-shape::after {
  position: absolute;
  bottom: 0;
  content: "";
  display: block;
  background: no-repeat center;
  background-color: var(--bg-color, #FFFFFF);
  background-size: 0 0;
  width: 200%;
  height: auto;
  aspect-ratio: 1920/30;
  will-change: transform;
  mask: repeat center/auto;
  -webkit-mask: repeat center/auto;
  animation: up-down 6s ease infinite, x-move 200s linear infinite;
}
.wrapper .wave-shape::before {
  left: 0;
  background-image: url(../images/wave_shape_01_960x30.svg);
  mask-image: url(../images/wave_shape_01_960x30.svg);
  -webkit-mask-image: url(../images/wave_shape_01_960x30.svg);
  --start-left: 0;
  --end-left: -100%;
  --y-move: -8px;
}
.wrapper .wave-shape::after {
  left: -100%;
  background-image: url(../images/wave_shape_02_960x30.svg);
  mask-image: url(../images/wave_shape_02_960x30.svg);
  -webkit-mask-image: url(../images/wave_shape_02_960x30.svg);
  --start-left: -100%;
  --end-left: 0;
  --y-move: 8px;
}
.wrapper .list-item {
  display: flex;
  flex-flow: row nowrap;
  gap: 1em;
  justify-content: flex-start;
  align-items: center;
  background-color: #FFFFFF;
  width: calc(33.3333333333% - 1.3333333333em);
  padding: 1em 3em;
  border: 2px solid #FFFFFF;
  border-radius: var(--radius, 24px);
  box-shadow: 0 0 20px #21283322;
  transition: 0.2s;
  transform: translateY(var(--up, 0));
  cursor: pointer;
}
.wrapper .list-item .list-title, .wrapper .list-item .list-text {
  pointer-events: none;
}
.wrapper .list-item .list-title {
  width: 2em;
  color: var(--color, #237FE4);
  font-size: 1.75em;
}
.wrapper .list-item .list-text {
  display: flex;
  flex-flow: column;
  gap: 0.25em;
  justify-content: center;
  align-items: flex-start;
  width: calc(100% - 3em);
  color: var(--color, #1D2836);
  font-size: 1.5em;
}
@media screen and (min-width: 1025px) {
  .wrapper .list-item:hover {
    background-color: #DEE6FF;
    --up: -4px;
  }
}
@media screen and (max-width: 1680px) {
  .wrapper .list-item {
    width: calc(50% - 1em);
  }
}
@media screen and (max-width: 1024px) {
  .wrapper .list-item {
    padding: 1em 1.5em;
  }
}
@media screen and (max-width: 960px) {
  .wrapper .list-item {
    width: 100%;
    padding: 1em 2em;
  }
}
@media screen and (max-width: 640px) {
  .wrapper .list-item {
    gap: 0.75em;
    padding: 1em 1.5em;
    font-size: 11px;
  }
}
.wrapper .notes-cont {
  display: flex;
  flex-flow: row wrap;
  gap: 2em;
  justify-content: center;
  align-items: stretch;
  width: 100%;
}
.wrapper .item-notes {
  display: flex;
  flex-flow: column;
  gap: 0.75em;
  justify-content: flex-start;
  align-items: stretch;
  width: calc(16.6666666667% - 1.6666666667em);
  cursor: pointer;
  transform: translateY(var(--up, 0));
  transition: 0.2s;
}
.wrapper .item-notes .notes-title, .wrapper .item-notes .notes-text {
  padding: 0.75em 1.25em;
  border-radius: 12px;
  pointer-events: none;
}
.wrapper .item-notes .notes-title {
  display: flex;
  flex-flow: row nowrap;
  gap: 1em;
  justify-content: space-between;
  align-items: center;
  background-color: var(--notes-title-bg-color, #237FE4);
}
.wrapper .item-notes .notes-title .text {
  color: var(--color, #FFFFFF);
}
.wrapper .item-notes .notes-title.highlight {
  --color: #FFFFB8;
  --notes-tag-bg-color: #FFFFB8;
  --notes-tag-color: #237FE4;
}
.wrapper .item-notes .notes-text {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  background-color: var(--notes-text-bg-color, #F0F5FF);
  height: 100%;
  text-align: justify;
}
.wrapper .item-notes .notes-tag {
  background-color: var(--notes-tag-bg-color, #FFFFFF);
  padding: 2px 1em;
  color: var(--notes-tag-color, #1D2836);
  font-size: 1em;
  border-radius: 8px;
}
.wrapper .item-notes.notes-jp {
  --notes-title-bg-color: #E8636E;
  --notes-text-bg-color: #FEF2F3;
}
.wrapper .item-notes.notes-jp .highlight {
  --notes-tag-color: #E8636E;
}
@media screen and (min-width: 1025px) {
  .wrapper .item-notes:hover {
    --up: -4px;
    filter: drop-shadow(0 4px 8px #21283333);
  }
}
@media screen and (max-width: 1680px) {
  .wrapper .item-notes {
    width: calc(33.3333333333% - 1.3333333333em);
  }
}
@media screen and (max-width: 960px) {
  .wrapper .item-notes {
    width: calc(50% - 1em);
  }
}
@media screen and (max-width: 640px) {
  .wrapper .item-notes {
    flex-flow: row nowrap;
    gap: 1em;
    width: 100%;
  }
  .wrapper .item-notes .notes-title {
    flex-flow: column;
    gap: 0.5em;
    align-items: center;
    width: 8em;
  }
  .wrapper .item-notes .notes-title .text {
    text-align: center;
  }
  .wrapper .item-notes .notes-text {
    width: calc(100% - 9em);
    align-items: center;
  }
  .wrapper .item-notes .notes-tag {
    font-size: 14px;
  }
}
@media screen and (max-width: 480px) {
  .wrapper .item-notes .notes-title {
    width: 7.5em;
  }
  .wrapper .item-notes .notes-text {
    width: calc(100% - 8.5em);
    align-items: center;
  }
}
.wrapper .float-btn-cont {
  position: fixed;
  right: 1em;
  bottom: 7vmax;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: round(down, 3.75em, 2px);
  height: auto;
  aspect-ratio: 64/120;
  cursor: pointer;
  filter: drop-shadow(0 2px 4px #A8AAAE);
  z-index: 500;
}
.wrapper .float-btn {
  position: absolute;
  width: 100%;
  height: auto;
  aspect-ratio: 64/120;
  transition: 0.2s;
}
.wrapper .float-btn-02 {
  opacity: var(--opacity, 1);
  animation: neon-lights 7s ease infinite;
}
@media screen and (max-width: 640px) {
  .wrapper .float-btn-cont {
    right: round(down, 0.75em, 2px);
    bottom: 4vmax;
    width: 3em;
  }
}
.wrapper .section {
  background-color: #FFFFFF;
}
.wrapper .section .section-content .content {
  max-width: var(--width, 1920px);
}
.wrapper .section .section-content.easy-learning .card .btn-blue {
  margin-top: auto;
}
.wrapper .section .section-content.diverse .card .btn-blue {
  margin-top: auto;
}
.wrapper .section .section-content.life .swiper-slide {
  height: auto !important;
}
.wrapper .section .section-content.life .card {
  cursor: pointer;
}
.wrapper .section .section-content.life .card .card-img, .wrapper .section .section-content.life .card .img-text {
  pointer-events: none;
}
.wrapper .section .section-content.life .card .img-text {
  position: absolute;
  left: 0;
  bottom: 0;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  background-color: #1D283699;
  width: 100%;
  padding: 0.5em;
  font-size: 1.5em;
  color: #FFFFFF;
  backdrop-filter: blur(4px);
}
.wrapper .section .section-content.form .form-cont {
  align-self: stretch;
}
.wrapper .section .section-content.students .swiper-slide {
  height: auto !important;
}
.wrapper .section .section-content.courses .content {
  flex-flow: column;
  padding: 2em;
  border-radius: 32px;
}
@media screen and (max-width: 1024px) {
  .wrapper .section .section-content.form .content {
    flex-flow: column;
    justify-content: center;
    align-items: center;
  }
  .wrapper .section .section-content.form .form-cont {
    align-self: center;
    max-width: 640px;
  }
}
@media screen and (max-width: 640px) {
  .wrapper .section .section-content.courses .content {
    padding: 1em;
  }
}
.wrapper .section-content {
  padding: 3em 1em 5em;
}
@media screen and (min-width: 1921px) {
  .wrapper .section-content {
    padding: 1vw 1em 5vw;
  }
}
@media screen and (max-width: 800px) {
  .wrapper .section-content {
    padding: 2em 1em 5em;
  }
}
.wrapper .main-title {
  display: flex;
  flex-flow: column;
}
.wrapper .main-title .title {
  padding: 0 1.25em;
  --color: #1D2836;
}
.wrapper .main-title .title::before, .wrapper .main-title .title::after {
  position: absolute;
  top: 50%;
  content: "";
  display: block;
  background: no-repeat center/cover;
  background-color: #1D2836;
  background-size: 0 0;
  width: 0.825em;
  height: 0.825em;
  aspect-ratio: 1/1;
  mask: no-repeat center/cover;
  -webkit-mask: no-repeat center/cover;
  transform: translateY(-50%);
}
.wrapper .main-title .title::before {
  left: 0;
  background-image: url(../images/deco_title_01_32.svg);
  mask-image: url(../images/deco_title_01_32.svg);
  -webkit-mask-image: url(../images/deco_title_01_32.svg);
}
.wrapper .main-title .title::after {
  right: 0;
  background-image: url(../images/deco_title_02_32.svg);
  mask-image: url(../images/deco_title_02_32.svg);
  -webkit-mask-image: url(../images/deco_title_02_32.svg);
}
.wrapper .main-title .subject {
  padding: 0;
  border: none;
}
.wrapper .main-title .subject::before, .wrapper .main-title .subject::after {
  content: none;
}
@media screen and (max-width: 360px) {
  .wrapper .main-title {
    font-size: 13px;
  }
}
.wrapper .title {
  --color: #1D2836;
}
.wrapper .subject {
  display: flex;
  flex-flow: column;
  gap: 0.25em;
  justify-content: center;
  align-items: center;
  --color: #237FE4;
}
.wrapper .btn, .wrapper [class^=btn-], .wrapper [class*=" btn-"] {
  display: flex;
  flex-flow: row nowrap;
  gap: 0.25em;
  justify-content: center;
  align-items: center;
  padding: 0.25em 2.5em;
  --icon-size: 1.25em;
  --btn-radius: 16px;
}
.wrapper .btn .icon-right, .wrapper [class^=btn-] .icon-right, .wrapper [class*=" btn-"] .icon-right {
  transition: 0.2s;
}
.wrapper .btn:hover .icon-right, .wrapper [class^=btn-]:hover .icon-right, .wrapper [class*=" btn-"]:hover .icon-right {
  transform: translateX(4px);
}
.wrapper :is(input, select) {
  appearance: none;
  background-color: #FFFFFF;
  width: 100%;
  padding: 0.625em 0.625em 0.625em 5em;
  color: #000000;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: round(down, 0.1em, 1px);
  border: 2px solid transparent;
  border-radius: 12px;
  outline: none;
  transition: 0.2s;
}
.wrapper :is(input, select):focus {
  border-color: var(--label-color, #237FE4);
}
.wrapper :is(input[type=checkbox]) {
  width: 1.25em;
  height: 1.25em;
  padding: 0;
  border-color: var(--label-color, #237FE4);
  border-radius: 4px;
}
.wrapper :is(input[type=checkbox]):checked {
  background-color: var(--label-color, #237FE4);
}
.wrapper :is(input[type=checkbox]):checked:after {
  position: absolute;
  top: calc(50% - round(down, 0.1em, 1px));
  left: 54%;
  content: "✓";
  color: var(--checked-color, #FFFFFF);
  font-size: 1em;
  font-weight: 500;
  transform: translate(-50%, -50%);
}
.wrapper :is(select) {
  padding: 0.625em 3em 0.625em 0.625em;
}
.wrapper ::placeholder {
  color: #9CA3AF;
  opacity: 1;
}
.wrapper :-ms-input-placeholder {
  color: #9CA3AF;
}
.wrapper ::-ms-input-placeholder {
  color: #9CA3AF;
}
.wrapper .form-card {
  display: block;
  width: 100%;
  max-width: 640px;
  height: auto;
  aspect-ratio: 640/360;
  border-radius: 12px;
  overflow: hidden;
}
@media screen and (max-width: 800px) {
  .wrapper .form-card {
    max-width: 640px;
  }
}
.wrapper .form-cont {
  display: flex;
  flex-flow: row wrap;
  gap: 0.75em;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.wrapper .form-cont .input-cont.w-50\%, .wrapper .form-cont .select-cont.w-50\% {
  flex: 1 1 calc(50% - round(down, 0.75em, 2px));
}
.wrapper .form-cont .input-cont.w-100\%, .wrapper .form-cont .select-cont.w-100\% {
  flex: 1 1 100%;
}
.wrapper .form-cont .input-cont {
  display: flex;
}
.wrapper .form-cont .input-cont label {
  position: absolute;
  top: 50%;
  left: 1em;
  color: var(--label-color, #1D2836);
  transform: translateY(-50%);
}
.wrapper .form-cont .select-cont:before {
  position: absolute;
  top: 50%;
  right: 1em;
  content: "";
  display: block;
  background-color: var(--label-color, #237FE4);
  background-image: url(../images/icons/arrow-down.svg);
  background-size: 0 0;
  width: round(down, 1.5em, 2px);
  height: round(down, 1.5em, 2px);
  aspect-ratio: 1/1;
  mask-image: url(../images/icons/arrow-down.svg);
  -webkit-mask-image: url(../images/icons/arrow-down.svg);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: cover;
  -webkit-mask-size: cover;
  transform: translateY(-50%);
  z-index: 10;
  pointer-events: none;
  cursor: pointer;
}
.wrapper .form-cont .statement {
  display: flex;
  flex-flow: row nowrap;
  gap: round(down, 0.5em, 2px);
  justify-content: center;
  align-items: center;
}
.wrapper .form-cont .statement label {
  display: flex;
  justify-content: center;
  align-items: center;
}
.wrapper .form-cont .statement span {
  color: var(--statement-color, #1D2836);
  font-weight: 500;
}
.wrapper .form-cont .statement span a {
  color: var(--statement-a-color, #237FE4);
  font-weight: 500;
  text-decoration: underline;
}
.wrapper .form-cont :where(#sBut, .btn) {
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 800px) {
  .wrapper .form-cont {
    gap: 1em;
    max-width: 640px;
  }
  .wrapper .form-cont .input-cont.w-50\%, .wrapper .form-cont .select-cont.w-50\% {
    flex: 1 1 100%;
  }
}
.wrapper .form-cont {
  --label-color: #237FE4;
  --statement-a-color: #237FE4;
}
.wrapper .table-cont {
  display: flex;
  flex-flow: column;
  width: 100%;
  max-width: var(--table-max-width, 1440px);
  padding: 1.5em;
  border: 2px solid var(--tb-primary-color, #237FE4);
  border-radius: 20px;
}
.wrapper .tb-title {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding-bottom: 0.75em;
  color: var(--tb-primary-color, #237FE4);
  font-size: 2em;
  border-bottom: 2px solid var(--tb-primary-color, #237FE4);
}
@media screen and (max-width: 640px) {
  .wrapper .tb-title {
    font-size: 1.75em;
  }
}
.wrapper .button-cont {
  margin-top: 1.25em;
}
.wrapper .btn {
  --btn-color: var(--tb-primary-color);
  --btn-border-color: var(--tb-primary-color);
}
.wrapper .btn:hover {
  --btn-bg-color: var(--tb-primary-color);
}
.wrapper .color-primary {
  --color: var(--tb-primary-color);
}
.wrapper .color-secondary {
  --color: var(--tb-secondary-color);
}
.wrapper .color-tertiary {
  --color: var(--tb-tertiary-color);
}
.wrapper .tb-body {
  display: table;
  width: 100%;
  color: #1D2836;
  font-size: 1.25em;
  counter-reset: num 0;
  overflow: hidden;
}
.wrapper .tb-body .tb-header, .wrapper .tb-body .tb-row, .wrapper .tb-body .tb-footer {
  display: table-row;
}
.wrapper .tb-body .tb-header {
  display: flex;
  background-color: var(--tb-primary-color, #237FE4);
}
.wrapper .tb-body .tb-row {
  background-color: #FFFFFF;
}
.wrapper .tb-body .tb-row .tb-th, .wrapper .tb-body .tb-row .tb-cell {
  border-bottom: 1px solid;
  border-color: var(--tb-secondary-color, #DEE6FF);
}
.wrapper .tb-body .tb-row:hover {
  background-color: var(--tb-tertiary-color, #F0F5FF);
}
.wrapper .tb-body .tb-th, .wrapper .tb-body .tb-cell {
  display: table-cell;
  padding: 0.75em 0.5em;
  text-align: var(--text-align, center);
  vertical-align: var(--text-vertical, middle);
}
.wrapper .tb-body .tb-th * ~ *, .wrapper .tb-body .tb-cell * ~ * {
  margin-top: 0.5em;
}
.wrapper .tb-body .tb-th {
  color: var(--tb-primary-color, #237FE4);
  font-weight: 700;
  white-space: nowrap;
}
.wrapper .tb-body .tb-w-1 {
  width: 8.3333333333%;
}
.wrapper .tb-body .tb-w-2 {
  width: 16.6666666667%;
}
.wrapper .tb-body .tb-w-3 {
  width: 25%;
}
.wrapper .tb-body .tb-w-4 {
  width: 33.3333333333%;
}
.wrapper .tb-body .tb-w-5 {
  width: 41.6666666667%;
}
.wrapper .tb-body .tb-w-6 {
  width: 50%;
}
.wrapper .tb-body .tb-w-7 {
  width: 58.3333333333%;
}
.wrapper .tb-body .tb-w-8 {
  width: 66.6666666667%;
}
.wrapper .tb-body .tb-w-9 {
  width: 75%;
}
.wrapper .tb-body .tb-w-10 {
  width: 83.3333333333%;
}
.wrapper .tb-body .tb-w-11 {
  width: 91.6666666667%;
}
.wrapper .tb-body .tb-w-12 {
  width: 100%;
}
@media screen and (max-width: 800px) {
  .wrapper .tb-body {
    font-size: 16px;
  }
}
@media screen and (max-width: 640px) {
  .wrapper .tb-body.tb-rwd-640 {
    display: flex;
    flex-flow: column;
    gap: 1em;
    border-radius: unset;
    box-shadow: unset;
    overflow: unset;
  }
  .wrapper .tb-body.tb-rwd-640 .tb-header {
    display: none;
  }
  .wrapper .tb-body.tb-rwd-640 .tb-row {
    display: flex;
    flex-flow: column;
    padding: 0 1em;
    border-radius: 16px;
    box-shadow: 0 4px 8px #21283333;
  }
  .wrapper .tb-body.tb-rwd-640 .tb-row::before, .wrapper .tb-body.tb-rwd-640 .tb-row::after {
    content: none;
  }
  .wrapper .tb-body.tb-rwd-640 .tb-row:last-of-type .tb-cell {
    border-bottom: 1px solid;
    border-color: var(--tb-secondary-color, #DEE6FF);
  }
  .wrapper .tb-body.tb-rwd-640 .tb-row .tb-cell {
    display: flex;
    flex-flow: row nowrap;
    gap: 1em;
    justify-content: flex-start;
    align-items: center;
  }
  .wrapper .tb-body.tb-rwd-640 .tb-row .tb-cell:last-of-type {
    border-bottom: unset;
  }
  .wrapper .tb-body.tb-rwd-640 .tb-row .tb-cell::before {
    flex: 0 0 var(--tb-title-width, 4em);
    content: attr(data-title);
    display: block;
    width: var(--tb-title-width, 4em);
    color: var(--tb-primary-color, #237FE4);
  }
}
.wrapper .table-red {
  --tb-primary-color: #E8636E;
  --tb-secondary-color: #FAE0E2;
  --tb-tertiary-color: #FEF2F3;
}
.wrapper .table-blue {
  --tb-primary-color: #237FE4;
  --tb-secondary-color: #DEE6FF;
  --tb-tertiary-color: #F0F5FF;
}
.wrapper .table-orange {
  --tb-primary-color: #F38A3A;
  --tb-secondary-color: #FFE7DB;
  --tb-tertiary-color: #FFF5F0;
}
.wrapper .table-green {
  --tb-primary-color: #3CA947;
  --tb-secondary-color: #C9EFCC;
  --tb-tertiary-color: #ECFFED;
}
.wrapper .table-cont {
  box-shadow: 0 2px 4px #21283333;
}
.wrapper .tag, .wrapper [class^=tag-], .wrapper [class*=" tag-"] {
  display: flex;
  gap: 0.5em;
  background-color: var(--tag-bg-color, #DEE6FF);
  color: var(--tag-color, #237FE4);
  font-size: 16px;
  padding: 2px 1em;
  border-radius: 8px;
}
@media screen and (max-width: 960px) {
  .wrapper .tag, .wrapper [class^=tag-], .wrapper [class*=" tag-"] {
    font-size: 14px;
  }
}
.wrapper .tag-red {
  --tag-bg-color: #FAE0E2;
  --tag-color: #E8636E;
}
.wrapper .tag-blue {
  --tag-bg-color: #DEE6FF;
  --tag-color: #237FE4;
}
.wrapper .tag-orange {
  --tag-bg-color: #FFE7DB;
  --tag-color: #F38A3A;
}
.wrapper .tag-green {
  --tag-bg-color: #C9EFCC;
  --tag-color: #3CA947;
}
.wrapper .card-cont {
  display: flex;
  flex-flow: row wrap;
  gap: 2em;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  max-width: var(--width, 1024px);
}
.wrapper .card {
  display: flex;
  flex-flow: column;
  background-color: var(--card-bg-color, #FFFFFF);
  border-radius: 20px;
  box-shadow: 0 4px 8px #21283333;
  overflow: hidden;
}
.wrapper .card .row {
  display: flex;
  flex-flow: row nowrap;
  gap: 0.5em;
  justify-content: var(--justify-content, flex-start);
  align-items: center;
}
.wrapper .card .col {
  display: flex;
  flex-flow: column;
  gap: 0.5em;
  justify-content: center;
  align-items: flex-start;
}
.wrapper .card .card-avatar {
  width: 5em;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
  overflow: hidden;
}
.wrapper .card .stars {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
}
.wrapper .card .stars img {
  width: 2em;
  height: auto;
  aspect-ratio: 1/1;
}
.wrapper .card .card-img, .wrapper .card .card-info {
  display: flex;
  flex-flow: column;
  gap: 0.75em;
  justify-content: center;
  align-items: center;
  padding: 1.25em;
}
.wrapper .card .card-icon {
  width: 5em;
  height: auto;
  aspect-ratio: 1/1;
}
.wrapper .card .card-title {
  color: var(--color, #237FE4);
  font-size: 1.5em;
}
.wrapper .card {
  margin: 1.5em 1em;
  box-shadow: 0 0 20px #21283322;
  transform: translateY(var(--up, 0));
  transition: 0.2s;
}
.wrapper .card .card-img {
  padding: 0;
  overflow: hidden;
}
.wrapper .card .card-img img {
  transform: scale(var(--scale, 1));
  transition: 0.2s;
}
.wrapper .card .card-info {
  flex: 1;
  justify-content: flex-start;
}
@media screen and (min-width: 1025px) {
  .wrapper .card:hover:not(.unhover) {
    --up: -5px;
    --scale: 1.05;
  }
  .wrapper .card:hover:not(.unhover) .card-img {
    filter: brightness(1.1);
  }
}
.wrapper .swiper {
  width: calc(100% + 2em);
}
.wrapper .swiper-wrapper {
  width: 100%;
  transition-timing-function: ease;
}
.wrapper .swiper-slide {
  display: flex;
}
.wrapper .sw-page-dot, .wrapper .sw-page-dot.swiper-pagination-bullets {
  bottom: unset;
  display: flex;
  flex-flow: row nowrap;
  gap: 0.75em;
  justify-content: center;
  align-items: center;
  margin-top: -1.5em;
  z-index: 10;
}
.wrapper .sw-page-dot .swiper-pagination-bullet, .wrapper .sw-page-dot.swiper-pagination-bullets .swiper-pagination-bullet {
  background-color: #237FE4;
  width: 5px;
  height: 5px;
  aspect-ratio: 1/1;
  margin: 0;
  opacity: 0.25;
  border-radius: 50%;
  transition: 0.2s;
}
.wrapper .sw-page-dot .swiper-pagination-bullet-active, .wrapper .sw-page-dot.swiper-pagination-bullets .swiper-pagination-bullet-active {
  transform: scale(1.75);
  opacity: 1;
}
@keyframes fade-shake {
  0%, 50%, 60%, 70%, 100% {
    transform: scale(1);
  }
  55%, 65% {
    transform: scale(var(--zoom-in, 1.5));
  }
}
@keyframes tree-swing {
  0%, 100% {
    transform: rotate(var(--start-rotate, -1.5deg));
  }
  40% {
    transform: rotate(var(--end-rotate, 1.2deg));
  }
}
@keyframes sun-light {
  0% {
    opacity: 0;
    filter: blur(4px);
    transform: scale(0.8, 0.7);
  }
  30%, 60% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    filter: blur(10px);
    transform: scale(1.2, 1.8);
  }
}
@keyframes up-down {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(var(--y-move, 0.5em));
  }
}
@keyframes x-move {
  0% {
    left: var(--start-left, 0);
  }
  100% {
    left: var(--end-left, 100%);
  }
}
@keyframes neon-lights {
  0%, 20%, 30%, 40%, 50%, 80%, 84%, 88%, 92%, 100% {
    opacity: 1;
  }
  25%, 35%, 45%, 82%, 86%, 90% {
    opacity: 0.2;
  }
}
@keyframes fade-scale {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(var(--zoom-in, 1.05));
  }
}/*# sourceMappingURL=style.css.map */