@charset "UTF-8";
/* 
 * Common Page Styles
 * 共通ページスタイル (トップページなど)
 */
/* ローディング画面 */
.loading-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: white;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 9999;
  -webkit-transition: opacity 0.6s ease;
  transition: opacity 0.6s ease;
}

.loading-screen.fade-out {
  opacity: 0;
}

.loading-content {
  text-align: center;
}

.loading-text {
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}

.loading-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4px;
}

.loading-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--primary);
  -webkit-animation: loadingDot 1.4s ease-in-out infinite;
          animation: loadingDot 1.4s ease-in-out infinite;
}

.loading-dot:nth-child(1) {
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}

.loading-dot:nth-child(2) {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}

.loading-dot:nth-child(3) {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}

@-webkit-keyframes loadingDot {
  0%, 80%, 100% {
    opacity: 0;
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  40% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes loadingDot {
  0%, 80%, 100% {
    opacity: 0;
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  40% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

/* バナーセクション */
.banner-section {
  padding: 60px 0;
  background: #eee;
}

@media (max-width: 768px) {
  .banner-section {
    padding: 40px 0;
  }
}

.banner-wrapper {
  padding: 40px 0;
  max-width: 600px;
  margin: auto;
}

.banner-link {
  display: block;
  -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transition: opacity 0.3s ease, transform 0.3s ease, -webkit-transform 0.3s ease;
}

.banner-link:hover {
  opacity: 0.9;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.banner-image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

@media (max-width: 768px) {
  .banner-image {
    border-radius: 4px;
  }
}
/*# sourceMappingURL=common.css.map */