@charset "utf-8";
/******
		contents
					******/

body {
  background-attachment: fixed;
  background: url(../img/body-bg.jpg) top center / cover no-repeat;
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}

header {
  position: fixed;
  z-index: 999999;
  left: 50%;
  top: 0;
  width: 100%;
  max-width: 590px;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%);
}

.header-reserv a {
  height: 70px;
  padding: 0 24px;
}

.black-bg {
  background: url(../img/header_bg.jpg) top center / cover no-repeat;
}

.ly_bg {
  background: url(../img/header_bg.jpg) top center / cover no-repeat;
  z-index: -1;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ly_bg:before {
  display: block;
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  background-color: #00000080;
  content: "";
}

.ly_left {
  display: grid;
  position: fixed;
  top: 0;
  left: 0;
  place-items: center;
  width: calc(50% - 18.75rem);
  height: 100lvh;
}

.ly_right {
  display: grid;
  position: fixed;
  top: 0;
  right: 0;
  place-items: center;
  width: calc(50% - 18.75rem);
  height: 100lvh;
}

.ly_right ul li a {
  display: flex;
  row-gap: 16px;
  text-align: justify;
  margin-top: 24px;
  align-items: center;
  font-size: 21px;
}

.ly_right ul li a img {
  margin-left: 6px;
  width: 16px;
}

.ly_wrapper {
  position: relative;
  display: block;
  z-index: 100;
  position: relative;
  max-width: 590px;
  width: 100%;
  margin: 0 auto;
}

/******
		SPナビゲーションメニュー
					******/

.global-nav {
  position: fixed;
  right: 00%;
  top: 0;
  width: 100%;
  height: auto;
  padding-top: 40px;
  /* transition: all 0.6s; */
  z-index: 0;
  overflow-y: auto;
  padding: 40px 16px 0 16px;
  box-sizing: border-box;
  opacity: 0;
  display: none;
}

.nav-open .global-nav {
  z-index: 999;
  display: block;
}

.hamburger {
  position: relative;
  margin: 0 0 0 auto;
  width: 100px;
  height: 100px;
  cursor: pointer;
  z-index: 200000;
}
.global-nav__list {
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: left;
}
.global-nav__item {
  text-align: left;
  padding: 0 14px;
  margin: 0 20px;
}

.global-nav__item a:hover {
  background-color: #eee;
}
.hamburger__line {
  position: absolute;
  left: 26px;
  width: 50px;
  height: 3px;
  background-color: #fff;
  transition: all 0.6s;
}
.hamburger__line--1 {
  top: 26px;
  background-color: #fff;
}
.hamburger__line--2 {
  top: 46px;
  background-color: #fff;
}
.hamburger__line--3 {
  top: 66px;
  background-color: #fff;
}
.black-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  max-width: 590px;
  height: 70vh;
  z-index: 100;
  background-color: #ce1719;
  opacity: 0;
  visibility: hidden;
  transition: all 0.6s;
  cursor: pointer;
  border-radius: 0 0 20px 20px;
}
/* 表示された時用のCSS */
.nav-open .global-nav {
  opacity: 1;
}
.nav-open .black-bg {
  opacity: 0.9;
  visibility: visible;
}
.nav-open .hamburger__line--1 {
  transform: rotate(45deg);
  top: 20px;
  background: #fff;
}
.nav-open .hamburger__line--2 {
  width: 0;
  left: 50%;
}
.nav-open .hamburger__line--3 {
  transform: rotate(-45deg);
  top: 20px;
  background: #fff;
}

#sp-navi dt {
  display: block;
  line-height: 24px;
  text-align: center;
  cursor: pointer;
  text-align: left;
  padding-left: 8px;
  padding-top: 4px;
  font-size: 0.929em !important;
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.25);
  padding: 12px 0;
}

#sp-navi dd {
  background: #000;
  line-height: 150%;
  text-align: center;
  display: none;
  text-align: left;
  margin-top: -4px;
  padding-left: 8px;
}

#sp-navi dt {
  font-weight: 100;
  font-size: 14px;
}

#sp-navi dd ul li a {
  background: #000;
  color: #fff;
  font-size: 0.929em;
  line-height: 200%;
}

.none-arrow {
  background: none !important;
}

.border-none {
  border-bottom: none !important;
}

.hamburger {
  width: 60px;
  height: 60px;
  background-color: #ce1719;
}

.header-logo img {
  width: 180px;
}

.hamburger__line {
  left: 16px;
  width: 30px;
  height: 2px;
}

.hamburger__line--1 {
  top: 20px;
}

.hamburger__line--2 {
  top: 30px;
}

.hamburger__line--3 {
  top: 40px;
}

.nav-open .hamburger__line--1 {
  top: 30px;
}
.nav-open .hamburger__line--3 {
  top: 30px;
}

/* ココまでハンバーガーメニュー */

.side-logo {
  width: 180px;
  margin: auto;
}

.side-nav {
  text-align: center;
  margin-top: 32px;
}

.side-nav ul li {
  margin-top: 24px;
}

.side-nav ul li a {
  font-size: 18px;
  font-weight: bold;
}

.side-nav ul li a .nav-icon img {
  width: 26px;
  margin-right: 4px;
}

.side-sns {
  margin-top: 32px;
}

.mv-sec {
  background: url(../img/mv_bg.jpg) top center / cover no-repeat;
  padding: 64px 24px;
}

.mv-mini-text {
  color: #fff;
  font-size: 28px;
  margin-top: 32px;
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.6);
}

.mv-big-text {
  color: #fff;
  font-size: 50px;
  margin-top: 0px;
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.6);
  font-weight: bold;
  text-align: center;
}

/* --- 初期状態：テキストを下部に隠す --- */
.clip-text {
  /* polygon(左上, 右上, 右下, 左下) の座標。初期は全て一番下(100%)に設定 */
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
  transition: clip-path 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

/* --- アニメーション発火時：テキスト全体を表示 --- */
.clip-text.is-active {
  /* 座標を広げて要素全体を表示させる */
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

/* --- 時間差（ディレイ）の指定 --- */
.clip-text.delay-1 {
  transition-delay: 0.5s; /* 1行目から0.2秒遅れて出現 */
}

.contents-inner {
  padding: 0px 24px;
}

.sec-head-title {
  margin: 0 auto;
  text-align: justify;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
  font-size: 36px;
  color: #997931;
  letter-spacing: 4px;
}

.color-bk {
  color: #423932;
}

.color-white {
  color: #fff;
}

.top-about-sec {
  background: url(../img/top_about_bg.jpg) top center / cover no-repeat;
  padding: 64px 0;
  position: relative;
}

.top-about-deco {
  position: absolute;
  top: 24px;
  right: 24px;
  max-width: 200px;
  mix-blend-mode: color-burn;
}

.text-base {
  color: #423932;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.8;
}

.top-about-text {
  margin-top: 32px;
}

.page-btn-box {
  margin: auto;
  max-width: 360px;
  margin-top: 32px;
}

.page-btn-box a {
  background: #ce1719;
  color: #fff;
  padding: 24px 32px;
  border-radius: 50px;
  font-size: 14px;
  transition: 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
}

.page-btn-box span {
  display: flex;
  align-items: center;
  margin-left: 8px;
  justify-content: center;
  margin-top: 2px;
}

.top-menu-box {
  margin-top: 64px;
  position: relative;
}

.big-top-menu-box {
  margin-top: 32px;
}

.top-menu-box-inner {
  position: relative;
  z-index: 10;
}

.top-menu-box::before {
  content: "";
  background-color: #fff;
  position: absolute;
  left: 0;
  width: 100%;
  height: 108%;
  z-index: 1;
  border-radius: 300px;
}

.page-top-menu-sec {
  background: #fbf7ef;
  background-image: url(../img/bg-01.png);
  background-repeat: repeat;
  padding: 64px 0;
}

.top-menu-min {
  margin-top: 16px;
  font-size: 14px;
}

.top-menu-name {
  margin-top: 8px;
  font-size: 21px;
  font-weight: bold;
  color: #aa8f1f;
}

.top-menu-desc {
  margin-top: 8px;
  font-size: 14px;
  color: #666;
  line-height: 1.6;
}

.top-menu-price {
  margin-top: 12px;
  font-size: 24px;
  font-weight: bold;
  color: #aa8f1f;
}

.top-menu-price span {
  font-size: 16px;
}

.top-menu-col {
  display: flex;
  flex-wrap: wrap;
  column-gap: 24px;
  margin-bottom: 64px;
}

.top-menu-col .top-menu-box {
  width: calc(50% - 12px);
  padding: 0px 8px;
}

.top-news-sec {
  padding: 64px 0;
  background-color: #2d4988;
  background-image: url(../img/bg-02.png);
  background-repeat: no-repeat;
  background-position: top 16px right 0px;
  background-size: contain;
}

.top-news-sec .contents-inner {
  padding: 0px;
}

.news-slide-desc {
  text-align: left;
  color: #fff;
}

.news-slide-img img {
  width: 100%;
  object-fit: cover;
  height: 280px;
  border-radius: 6px;
  overflow: hidden;
}

.news-slide-date {
  font-size: 14px;
  margin-top: 10px;
}

.news-slide-title {
  font-size: 18px;
  font-weight: bold;
  margin-top: 6px;
}

.news-slide-mini {
  color: #8ca5d3;
  font-size: 12px;
  margin-top: 6px;
}

.swiper-slide-active img {
  border: 2px solid #fff;
  box-sizing: border-box;
}

.swiper-scrollbar {
  display: none;
}

.swiper-wrapper {
  height: auto !important;
}

.top-shop-sec {
  background-color: #423932;
  background-image: url(../img/shop-bg.png);
  background-repeat: repeat;
  padding: 64px 0;
}

.shop-box {
  background: #fff;
  border-radius: 6px;
  padding: 32px 24px;
}

.shop-label {
  font-size: 22px;
  font-weight: bold;
}

.shop-name {
  font-size: 28px;
  font-weight: bold;
  margin-top: 8px;
}

.shop-address {
  font-size: 16px;
  margin-top: 12px;
}

.shop-time {
  font-size: 14px;
  margin-top: 6px;
}

.map-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 6px;
  margin: auto;
  margin-top: 16px;
  background: #0b57d0;
  color: #fff;
  padding: 12px 20px;
  border-radius: 50px;
  font-size: 14px;
  transition: 0.3s;
  font-weight: bold;
  width: 120px;
}

.map-btn a img {
  margin-left: 6px;
  width: 16px;
}

.shop-img {
  margin: auto;
  margin-top: 24px;
  width: 80%;
}

.fot-nav ul {
  display: flex;
  align-items: center;
  column-gap: 24px;
  justify-content: center;
  font-size: 14px;
  margin-top: 32px;
}

.fot-nav ul li a {
  text-decoration: underline;
}

.fot-copy {
  margin-top: 24px;
  font-size: 14px;
  color: #fff;
}

.single-menu-wrap {
  background: #fbf7ef;
  background-image: url(../img/bg-01.png);
  background-repeat: repeat;
}

.single-mv {
  padding: 64px 0;
}

.menu-mv {
  background: url(../img/menu_mv_bg.png) center center / contain no-repeat;
  background-size: 250px;
}

.single-mv-big {
  font-size: 36px;
  font-weight: bold;
}

.single-mv-eg {
  font-size: 21px;
  margin-top: 4px;
  font-weight: bold;
}

.single-mv-text {
  margin-top: 50px;
  font-size: 16px;
  font-weight: 500;
}

.single-menu-ctg ul {
  display: flex;
  justify-content: center;
  column-gap: 24px;
}

.single-menu-ctg ul li a {
  background: #423932;
  padding: 4px 12px 6px 12px;
  display: block;
  border-radius: 20px;
}

.single-menu-main {
  padding: 0 24px 64px 24px;
}

.single-menu-ctg-box {
  margin-top: 50px;
}

.single-menu-ctg-box-label {
  font-size: 28px;
  font-weight: bold;
}

.single-menu-ctg-name {
  font-size: 18px;
  font-weight: bold;
  margin-top: 8px;
  color: #ce1719;
}

.color-gold {
  color: #aa8f1f;
}

.single-menu-ctg-card {
  display: flex;
  align-items: center;
  padding: 16px 24px 16px 0px;
  text-align: justify;
  background-color: #fff;
  border-radius: 200px;
  column-gap: 16px;
  margin-top: 32px;
}

.single-menu-ctg-card-img {
  width: 200px;
  flex-shrink: 0;
}

.single-menu-ctg-card-text {
  width: calc(100% - 216px);
}

.single-menu-ctg-card-text-name {
  font-size: 24px;
  font-weight: bold;
  margin-top: 8px;
}

.single-menu-ctg-card-text-desc {
  font-size: 16px;
  font-weight: bold;
  margin-top: 8px;
}

.single-menu-ctg-card-text-price {
  font-size: 21px;
  font-weight: bold;
  margin-top: 8px;
}

.single-menu-ctg-card-text-price span {
  font-size: 14px;
  font-weight: bold;
}

.textonly-card {
  margin-top: 24px;
}

.textonly-card .single-menu-ctg-card-text {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0 24px 0 24px;
}

.textonly-card .single-menu-ctg-card-text-name {
  font-size: 24px;
  margin-top: 0px;
}

.textonly-card.single-menu-ctg-card-text-price {
  font-size: 32px;
  margin-top: 0px;
}

.kodawari-mv {
  background: url(../img/kodawari_mv_bg.png) top center / cover no-repeat;
  padding: 90px 0;
}

.kodawari-mv-text {
  color: #fff;
  font-size: 32px;
  text-shadow: 0 0 10px rgba(0, 0, 0, 1);
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  margin: auto;
  margin-top: 32px;
  letter-spacing: 5px;
}

.kodawari-sec-box {
  padding: 64px 24px;
}

.kodawari-box-head {
  font-size: 32px;
  color: #aa8f1f;
  font-weight: bold;
  letter-spacing: -3px;
}

.kodawari-text {
  text-align: justify;
  margin-top: 32px;
  line-height: 1.8;
  font-weight: 500;
}

.cta-menu {
  background: url(../img/cta-menu-bg.png) top center / cover no-repeat;
}

.cta-menu .cta-item-inner {
  background-color: rgb(206, 23, 25, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 200px;
  color: #fff;
  column-gap: 10px;
  font-size: 16px;
  font-weight: bold;
  transition: 0.3s;
}

.cta-menu .cta-item-inner:hover {
  background-color: rgba(223, 15, 15, 0.9);
  transition: 0.3s;
}

.cta-menu .cta-item-inner img {
  display: flex;
  align-items: center;
  justify-content: center;
}

.cta-news {
  background: url(../img/cta-news-bg.png) top center / cover no-repeat;
}

.cta-news .cta-item-inner {
  background-color: rgb(45, 73, 136, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 200px;
  color: #fff;
  column-gap: 10px;
  font-size: 16px;
  font-weight: bold;
  transition: 0.3s;
}

.cta-news .cta-item-inner:hover {
  background-color: rgba(45, 73, 136, 0.9);
  transition: 0.3s;
}

.cta-news .cta-item-inner img {
  display: flex;
  align-items: center;
  justify-content: center;
}

.single-contact-main {
  padding: 0 24px 90px 24px;
}

.form-main {
  padding: 32px 24px;
  background: #fff;
  border-radius: 10px;
  text-align: left;
}

.form-group {
  margin-top: 16px;
}

.form-group:first-child {
  margin-top: 0px;
}

.form-group label {
  display: block;
  margin-bottom: 6px;
  font-weight: bold !important;
}

.form-group input {
  display: block;
  background-color: #e2dfde;
  border: none;
  padding: 12px 16px;
  width: 100%;
  border-radius: 2px;
  font-size: 16px;
  color: #423932;
}

.form-group textarea {
  display: block;
  background-color: #e2dfde;
  border: none;
  padding: 12px 16px;
  width: 100%;
  height: 150px;
  border-radius: 2px;
  font-size: 16px;
  color: #423932;
}

.form-btn {
  text-align: center;
}

.form-btn input {
  margin-top: 24px;
  background: #0b57d0;
  border: none;
  color: #fff;
  padding: 12px 20px;
  text-align: center;
  padding: 16px 24px;
  width: 280px;
  border-radius: 2px;
}

.wpcf7-response-output {
  text-align: center;
  font-size: 14px;
  margin-top: 24px;
}

.news-list-main {
  padding: 0 24px 64px 24px;
}

.news-list-main ul li {
  margin: auto;
  margin-top: 32px;
  max-width: 400px;
}

.news-list-main ul li:first-child {
  margin-top: 0px;
}

.news-list-main ul li .news-list-note {
  text-align: justify;
  color: #423932;
}

.news-list-title {
  font-size: 16px;
  font-weight: bold;
  margin-top: 8px;
  color: #ce1719;
}

.news-list-excerpt {
  margin-top: 8px;
  font-size: 14px;
  color: #666;
  line-height: 1.6;
}

.news-list-date {
  font-size: 12px;
  margin-top: 4px;
  color: #666;
}

.news-list-img img {
  border-radius: 6px;
}

.post-wrap {
  padding-bottom: 64px;
}

.post-img img {
  width: 100%;
  border-radius: 0 0 10px 10px;
}

.post-info {
  padding: 32px 24px;
  text-align: justify;
}

.post-date {
  font-size: 16px;
  margin-top: 4px;
  color: #666;
  font-weight: bold;
}

.post-title {
  font-size: 24px;
  font-weight: bold;
  margin-top: 8px;
  color: #997931;
}

.post-contents {
  padding: 0 24px;
  text-align: left;
}

.post-contents h1 {
  background-color: #eef6ff;
  border-left: 10px solid #002e78;
  text-align: left;
  color: #002e78;
  padding: 16px 30px;
  font-size: 28px;
  font-weight: 900;
  margin-top: 20px;
  display: block;
}

.post-contents h2 {
  border-bottom: 2px solid #ff5d00;
  text-align: left;
  color: #ff5d00;
  padding: 16px 12px 6px 0px;
  font-size: 24px;
  font-weight: 900;
  display: block;
  margin-top: 20px;
}

.post-contents h3 {
  border-bottom: 3px dotted #002e78;
  font-size: 24px;
  font-weight: 900;
  color: #002e78;
  text-align: left;
  margin-top: 20px;
}

.post-contents h4 {
  padding: 16px 12px;
  border-left: 4px solid #002e78;
  color: #002e78;
  font-weight: 900;
  font-size: 21px;
  text-align: left;
  margin-top: 20px;
}

.post-contents h5 {
  padding: 16px 12px;
  border-left: 5px solid #262626;
  background: #dbdbdb;
  font-size: 21px;
  font-weight: 900;
  text-align: left;
  margin-top: 20px;
  color: #262626;
}

.post-contents h6 {
  font-size: 18px;
  font-weight: bold;
  color: #002e78;
  text-align: left;
  margin-top: 20px;
}

.post-contents p {
  font-size: 16px;
  text-align: justify;
  display: block;
  margin-top: 16px;
}

.post-contents figure {
  margin: 0;
}

/* アニメーション前の初期状態（透明 ＆ 少し下に配置） */
.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 0.8s ease-out,
    transform 0.8s ease-out;
}

/* アニメーション完了状態（JSでこのクラスが付与されたら元の位置・不透明になる） */
.fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

#opening-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: #ce1719;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999999;
  transition:
    opacity 0.8s ease,
    visibility 0.8s ease;
}

/* JavaScriptで付与するフェードアウト用のクラス */
#opening-screen.is-loaded {
  opacity: 0;
  visibility: hidden;
}

#main-content {
}

/* ★★★SVG OPアニメーション★★★ */

@-webkit-keyframes animate-svg-fill-1 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-1 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-1 {
  -webkit-animation: animate-svg-fill-1 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.1s both;
  animation: animate-svg-fill-1 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.1s both;
}

@-webkit-keyframes animate-svg-fill-2 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-2 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-2 {
  -webkit-animation: animate-svg-fill-2 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.2s both;
  animation: animate-svg-fill-2 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.2s both;
}

@-webkit-keyframes animate-svg-fill-3 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-3 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-3 {
  -webkit-animation: animate-svg-fill-3 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.30000000000000004s both;
  animation: animate-svg-fill-3 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.30000000000000004s both;
}

@-webkit-keyframes animate-svg-fill-4 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-4 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-4 {
  -webkit-animation: animate-svg-fill-4 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.4s both;
  animation: animate-svg-fill-4 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.4s both;
}

@-webkit-keyframes animate-svg-fill-5 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-5 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-5 {
  -webkit-animation: animate-svg-fill-5 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.5s both;
  animation: animate-svg-fill-5 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.5s both;
}

@-webkit-keyframes animate-svg-fill-6 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-6 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-6 {
  -webkit-animation: animate-svg-fill-6 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.6s both;
  animation: animate-svg-fill-6 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.6s both;
}

@-webkit-keyframes animate-svg-fill-7 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-7 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-7 {
  -webkit-animation: animate-svg-fill-7 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.7000000000000001s both;
  animation: animate-svg-fill-7 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.7000000000000001s both;
}

@-webkit-keyframes animate-svg-fill-8 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-8 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-8 {
  -webkit-animation: animate-svg-fill-8 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s both;
  animation: animate-svg-fill-8 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s both;
}

@-webkit-keyframes animate-svg-fill-9 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-9 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-9 {
  -webkit-animation: animate-svg-fill-9 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s both;
  animation: animate-svg-fill-9 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s both;
}

@-webkit-keyframes animate-svg-fill-10 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-10 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-10 {
  -webkit-animation: animate-svg-fill-10 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1s both;
  animation: animate-svg-fill-10 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1s both;
}

@-webkit-keyframes animate-svg-fill-11 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-11 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-11 {
  -webkit-animation: animate-svg-fill-11 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s both;
  animation: animate-svg-fill-11 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s both;
}

@-webkit-keyframes animate-svg-fill-12 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-12 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-12 {
  -webkit-animation: animate-svg-fill-12 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s both;
  animation: animate-svg-fill-12 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s both;
}

@-webkit-keyframes animate-svg-fill-13 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-13 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-13 {
  -webkit-animation: animate-svg-fill-13 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3000000000000003s both;
  animation: animate-svg-fill-13 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3000000000000003s both;
}

@-webkit-keyframes animate-svg-fill-14 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-14 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-14 {
  -webkit-animation: animate-svg-fill-14 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4000000000000001s both;
  animation: animate-svg-fill-14 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4000000000000001s both;
}

@-webkit-keyframes animate-svg-fill-15 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-15 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-15 {
  -webkit-animation: animate-svg-fill-15 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5000000000000002s both;
  animation: animate-svg-fill-15 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5000000000000002s both;
}

@-webkit-keyframes animate-svg-fill-16 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-16 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-16 {
  -webkit-animation: animate-svg-fill-16 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s both;
  animation: animate-svg-fill-16 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s both;
}

@-webkit-keyframes animate-svg-fill-17 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-17 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-17 {
  -webkit-animation: animate-svg-fill-17 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s both;
  animation: animate-svg-fill-17 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s both;
}

@-webkit-keyframes animate-svg-fill-18 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-18 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-18 {
  -webkit-animation: animate-svg-fill-18 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8000000000000003s both;
  animation: animate-svg-fill-18 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8000000000000003s both;
}

@-webkit-keyframes animate-svg-fill-19 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-19 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-19 {
  -webkit-animation: animate-svg-fill-19 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.9000000000000001s both;
  animation: animate-svg-fill-19 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 1.9000000000000001s both;
}

@-webkit-keyframes animate-svg-fill-20 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-20 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-20 {
  -webkit-animation: animate-svg-fill-20 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2s both;
  animation: animate-svg-fill-20 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2s both;
}

@-webkit-keyframes animate-svg-fill-21 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-21 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-21 {
  -webkit-animation: animate-svg-fill-21 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2.1s both;
  animation: animate-svg-fill-21 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2.1s both;
}

@-webkit-keyframes animate-svg-fill-22 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-22 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-22 {
  -webkit-animation: animate-svg-fill-22 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2.2s both;
  animation: animate-svg-fill-22 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2.2s both;
}

@-webkit-keyframes animate-svg-fill-23 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

@keyframes animate-svg-fill-23 {
  0% {
    fill: transparent;
  }

  100% {
    fill: rgb(255, 255, 255);
  }
}

.svg-elem-23 {
  -webkit-animation: animate-svg-fill-23 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2.3000000000000003s both;
  animation: animate-svg-fill-23 0.2s cubic-bezier(0.47, 0, 0.745, 0.715) 2.3000000000000003s both;
}
