/* Genspark 解説サイト - カスタムスタイル */

html {
  scroll-behavior: smooth;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* テキスト省略 */
.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* キーフレーム */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes gradient {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* IntersectionObserver でアニメ用 */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* details 要素のマーカー削除 */
details summary::-webkit-details-marker {
  display: none;
}

/* スクロールバー */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: #f1f5f9;
}
::-webkit-scrollbar-thumb {
  background: linear-gradient(to bottom, #3a62ff, #8b5cf6);
  border-radius: 5px;
}
::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(to bottom, #2244f0, #7c3aed);
}

/* テーブル横スクロール時の影 */
.overflow-x-auto {
  scrollbar-width: thin;
}

/* セレクション色 */
::selection {
  background: rgba(58, 98, 255, 0.25);
  color: #1d2e7f;
}

/* リンクのフォーカススタイル */
a:focus-visible,
button:focus-visible {
  outline: 2px solid #3a62ff;
  outline-offset: 2px;
  border-radius: 4px;
}
