@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.4
*/

/************************************
** CYBER TECH THEME - Full Redesign
************************************/

/* ========================================
   CSS変数
   ======================================== */
:root {
  --cy-bg: #06060e;
  --cy-bg2: #0c0c1a;
  --cy-bg3: #111128;
  --cy-card: #0e0e1e;
  --cy-text: #c8c8e0;
  --cy-text-bright: #eeeef8;
  --cy-muted: #6a6a90;
  --cy-cyan: #00e5ff;
  --cy-purple: #a855f7;
  --cy-pink: #ec4899;
  --cy-green: #22d3ee;
  --cy-border: rgba(0, 229, 255, 0.12);
  --cy-border-hover: rgba(0, 229, 255, 0.45);
  --cy-glow: 0 0 20px rgba(0, 229, 255, 0.25);
  --cy-glow-strong: 0 0 40px rgba(0, 229, 255, 0.35), 0 0 80px rgba(0, 229, 255, 0.1);
  --cy-glow-purple: 0 0 20px rgba(168, 85, 247, 0.3);
  --cy-grad: linear-gradient(135deg, #00e5ff, #a855f7);
  --cy-grad-pink: linear-gradient(135deg, #a855f7, #ec4899);
  --cy-grad-bg: linear-gradient(180deg, #06060e 0%, #0a0a20 50%, #06060e 100%);
  --cy-font-display: 'Orbitron', 'Rajdhani', sans-serif;
  --cy-font-body: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, sans-serif;
  --cy-radius: 12px;
  --cy-radius-sm: 6px;
  --cy-ease: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Cocoonオーバーライド */
:root {
  --cocoon-text-color: #c8c8e0;
  --cocoon-background-color: #06060e;
  --cocoon-basic-border-color: rgba(0, 229, 255, 0.12);
  --cocoon-white-color: #0e0e1e;
  --cocoon-black-color: #eeeef8;
}

/* ========================================
   キーフレームアニメーション
   ======================================== */

/* スキャンライン（画面全体に走る水平光線） */
@keyframes scanline {
  0% {
    transform: translateY(-100vh);
  }

  100% {
    transform: translateY(100vh);
  }
}

/* ネオンパルス */
@keyframes neonPulse {

  0%,
  100% {
    opacity: 1;
    text-shadow: 0 0 10px rgba(0, 229, 255, 0.5), 0 0 30px rgba(0, 229, 255, 0.3);
  }

  50% {
    opacity: 0.9;
    text-shadow: 0 0 20px rgba(0, 229, 255, 0.8), 0 0 60px rgba(0, 229, 255, 0.4), 0 0 100px rgba(0, 229, 255, 0.2);
  }
}

/* グリッチ */
@keyframes glitch {

  0%,
  90%,
  100% {
    transform: translate(0);
  }

  92% {
    transform: translate(-3px, 1px);
  }

  94% {
    transform: translate(3px, -1px);
  }

  96% {
    transform: translate(-2px, -1px);
  }

  98% {
    transform: translate(2px, 1px);
  }
}

@keyframes glitchColor {

  0%,
  90%,
  100% {
    text-shadow: none;
  }

  92% {
    text-shadow: -2px 0 #ec4899, 2px 0 #00e5ff;
  }

  94% {
    text-shadow: 2px 0 #ec4899, -2px 0 #00e5ff;
  }

  96% {
    text-shadow: -1px 0 #a855f7, 1px 0 #00e5ff;
  }

  98% {
    text-shadow: 1px 0 #a855f7, -1px 0 #ec4899;
  }
}

/* ボーダーグロウアニメーション */
@keyframes borderGlow {

  0%,
  100% {
    border-color: rgba(0, 229, 255, 0.15);
  }

  50% {
    border-color: rgba(0, 229, 255, 0.35);
  }
}

/* フローティング（上下に浮遊） */
@keyframes float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-8px);
  }
}

/* グラデーション移動 */
@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

/* ロゴの呼吸アニメーション */
@keyframes logoBreathe {

  0%,
  100% {
    text-shadow: 0 0 10px rgba(0, 229, 255, 0.4), 0 0 30px rgba(0, 229, 255, 0.2);
    filter: brightness(1);
  }

  50% {
    text-shadow: 0 0 25px rgba(0, 229, 255, 0.7), 0 0 60px rgba(0, 229, 255, 0.3), 0 0 100px rgba(0, 229, 255, 0.15);
    filter: brightness(1.1);
  }
}

/* フェードアップ */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* パーティクル浮遊 */
@keyframes particleFloat {

  0%,
  100% {
    transform: translateY(0) translateX(0);
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 1;
  }

  100% {
    transform: translateY(-100vh) translateX(20px);
    opacity: 0;
  }
}

/* ========================================
   ベーススタイル
   ======================================== */
body {
  background: var(--cy-grad-bg) !important;
  background-attachment: fixed !important;
  color: var(--cy-text) !important;
  font-family: var(--cy-font-body) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden !important;
  position: relative !important;
}

/* スキャンラインオーバーレイ */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, transparent, rgba(0, 229, 255, 0.15), transparent);
  animation: scanline 8s linear infinite;
  z-index: 9999;
  pointer-events: none;
}

/* グリッドパターン背景 */
body::after {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image:
    linear-gradient(rgba(0, 229, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 229, 255, 0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  z-index: -1;
  pointer-events: none;
}

/* リンク */
a {
  color: var(--cy-cyan) !important;
  text-decoration: none !important;
  transition: all 0.3s var(--cy-ease) !important;
  position: relative !important;
}

a:hover {
  color: #fff !important;
  text-shadow: 0 0 12px rgba(0, 229, 255, 0.6) !important;
}

::selection {
  background: rgba(168, 85, 247, 0.4);
  color: #fff;
}

/* スクロールバー */
::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: var(--cy-bg);
}

::-webkit-scrollbar-thumb {
  background: var(--cy-grad);
  border-radius: 3px;
}

/* ========================================
   ヘッダー
   ======================================== */
#header-container {
  background: rgba(6, 6, 14, 0.85) !important;
  border-bottom: 1px solid var(--cy-border) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  transition: all 0.5s var(--cy-ease) !important;
  position: relative !important;
  z-index: 100 !important;
}

/* ヘッダー下部のグラデーションライン */
#header-container::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, var(--cy-cyan), var(--cy-purple), transparent) !important;
  opacity: 0.6 !important;
}

/* ヘッダーがスクロールで濃くなるクラス（JSで付与） */
#header-container.is-scrolled {
  background: rgba(6, 6, 14, 0.97) !important;
  box-shadow: 0 4px 40px rgba(0, 229, 255, 0.1) !important;
}

#header-container.is-scrolled::after {
  opacity: 1 !important;
}

/* サイトロゴ */
#header .logo a,
.logo-text a,
.logo-header a,
#header .site-name-text,
.site-name-text a {
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-weight: 900 !important;
  letter-spacing: 3px !important;
  animation: logoBreathe 4s ease-in-out infinite !important;
}

/* ロゴホバーでグリッチ */
#header .logo a:hover,
.logo-text a:hover,
.logo-header a:hover {
  animation: glitch 0.5s ease-in-out, glitchColor 0.5s ease-in-out !important;
}

.tagline {
  color: var(--cy-muted) !important;
  font-size: 0.8em !important;
  letter-spacing: 2px !important;
}

/* ========================================
   ナビゲーション
   ======================================== */
#navi {
  background: rgba(12, 12, 26, 0.9) !important;
  border-bottom: 1px solid var(--cy-border) !important;
  backdrop-filter: blur(15px) !important;
  -webkit-backdrop-filter: blur(15px) !important;
}

#navi .navi-in>ul>li>a {
  color: var(--cy-text) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 0 24px !important;
  transition: all 0.3s var(--cy-ease) !important;
  position: relative !important;
}

/* ナビのホバーアンダーライン */
#navi .navi-in>ul>li>a::before {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 50% !important;
  width: 0 !important;
  height: 2px !important;
  background: var(--cy-grad) !important;
  transition: all 0.4s var(--cy-ease) !important;
  transform: translateX(-50%) !important;
  border-radius: 2px !important;
}

#navi .navi-in>ul>li>a:hover {
  color: var(--cy-cyan) !important;
}

#navi .navi-in>ul>li>a:hover::before {
  width: 100% !important;
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.4) !important;
}

/* サブメニュー */
#navi .sub-menu {
  background: rgba(12, 12, 26, 0.97) !important;
  border: 1px solid var(--cy-border) !important;
  border-top: 2px solid var(--cy-cyan) !important;
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.6), 0 0 30px rgba(0, 229, 255, 0.08) !important;
  border-radius: 0 0 var(--cy-radius-sm) var(--cy-radius-sm) !important;
  animation: fadeUp 0.3s var(--cy-ease) !important;
}

#navi .sub-menu a {
  font-size: 10px !important;
  padding: 10px 20px !important;
  border-bottom: 1px solid rgba(0, 229, 255, 0.06) !important;
}

#navi .sub-menu a:hover {
  background: rgba(0, 229, 255, 0.08) !important;
  padding-left: 28px !important;
}

/* ========================================
   メインレイアウト
   ======================================== */
#content,
.wrap,
#main {
  background-color: transparent !important;
}

/* ========================================
   エントリーカード（記事一覧） ★ 3Dチルトエフェクト対応
   ======================================== */
.entry-card-wrap {
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  overflow: hidden !important;
  margin-bottom: 24px !important;
  transition: all 0.4s var(--cy-ease) !important;
  position: relative !important;
  /* 3Dチルト用 */
  transform-style: preserve-3d !important;
  perspective: 1000px !important;
}

/* カード上部のグラデーションライン */
.entry-card-wrap::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: var(--cy-grad) !important;
  opacity: 0 !important;
  transition: opacity 0.4s var(--cy-ease) !important;
  z-index: 2 !important;
}

/* カードのグロウオーバーレイ */
.entry-card-wrap::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: var(--cy-radius) !important;
  background: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(0, 229, 255, 0.06), transparent 60%) !important;
  opacity: 0 !important;
  transition: opacity 0.4s var(--cy-ease) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.entry-card-wrap:hover {
  border-color: var(--cy-border-hover) !important;
  box-shadow: 0 8px 40px rgba(0, 229, 255, 0.12), 0 0 80px rgba(0, 229, 255, 0.04) !important;
  transform: translateY(-6px) !important;
}

.entry-card-wrap:hover::before {
  opacity: 1 !important;
}

.entry-card-wrap:hover::after {
  opacity: 1 !important;
}

/* カードタイトル */
.entry-card-title,
.card-title {
  color: var(--cy-text-bright) !important;
  font-weight: 700 !important;
  transition: all 0.3s var(--cy-ease) !important;
  line-height: 1.5 !important;
}

.entry-card-wrap:hover .entry-card-title,
.entry-card-wrap:hover .card-title {
  color: #fff !important;
  text-shadow: 0 0 8px rgba(0, 229, 255, 0.3) !important;
}

/* カードスニペット */
.entry-card-snippet,
.card-snippet {
  color: var(--cy-muted) !important;
  font-size: 0.88em !important;
  line-height: 1.6 !important;
}

/* カードメタ */
.entry-card-meta,
.card-meta {
  color: var(--cy-muted) !important;
  font-size: 0.8em !important;
}

/* カテゴリラベル */
.cat-label {
  background: var(--cy-grad) !important;
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-size: 9px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
  padding: 3px 10px !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 10px rgba(0, 229, 255, 0.2) !important;
}

/* サムネイル */
.entry-card-thumb {
  position: relative !important;
  overflow: hidden !important;
}

.entry-card-thumb::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, transparent 50%, rgba(6, 6, 14, 0.8)) !important;
  opacity: 0 !important;
  transition: opacity 0.4s var(--cy-ease) !important;
  pointer-events: none !important;
}

.entry-card-thumb img {
  transition: all 0.6s var(--cy-ease) !important;
}

.entry-card-wrap:hover .entry-card-thumb img {
  transform: scale(1.08) !important;
  filter: brightness(1.15) saturate(1.2) !important;
}

.entry-card-wrap:hover .entry-card-thumb::after {
  opacity: 1 !important;
}

/* ========================================
   記事ページ
   ======================================== */
.article {
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  padding: 2.5em !important;
  position: relative !important;
}

/* 記事上部グラデーション */
.article::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: var(--cy-grad) !important;
  border-radius: var(--cy-radius) var(--cy-radius) 0 0 !important;
}

/* 記事タイトル */
.entry-title {
  color: #fff !important;
  font-weight: 900 !important;
  font-size: 1.9em !important;
  line-height: 1.4 !important;
  padding-bottom: 0.6em !important;
  margin-bottom: 0.8em !important;
  border-bottom: none !important;
  position: relative !important;
}

.entry-title::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 120px !important;
  height: 3px !important;
  background: var(--cy-grad) !important;
  border-radius: 3px !important;
}

/* 見出し h2 - サイバーバー */
.article h2 {
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 1.4em !important;
  padding: 0.8em 1em 0.8em 1.2em !important;
  margin: 2em 0 1.2em !important;
  background: linear-gradient(90deg, rgba(0, 229, 255, 0.08), transparent 80%) !important;
  border: none !important;
  border-left: 4px solid !important;
  border-image: var(--cy-grad) 1 !important;
  border-radius: 0 var(--cy-radius) var(--cy-radius) 0 !important;
  position: relative !important;
}

.article h2::before {
  content: '///' !important;
  color: var(--cy-cyan) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 0.6em !important;
  margin-right: 0.5em !important;
  opacity: 0.5 !important;
}

/* 見出し h3 */
.article h3 {
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 1.2em !important;
  padding: 0.5em 0 !important;
  margin: 1.8em 0 1em !important;
  border: none !important;
  border-bottom: 1px solid transparent !important;
  border-image: linear-gradient(90deg, var(--cy-cyan), var(--cy-purple), transparent) 1 !important;
  position: relative !important;
}

.article h3::before {
  content: '>' !important;
  color: var(--cy-purple) !important;
  font-family: var(--cy-font-display) !important;
  margin-right: 0.4em !important;
  opacity: 0.6 !important;
}

/* 見出し h4 */
.article h4 {
  color: var(--cy-cyan) !important;
  font-weight: 700 !important;
  font-size: 1.05em !important;
  padding: 0.3em 0 !important;
  margin: 1.5em 0 0.8em !important;
}

/* 本文 */
.entry-content {
  color: var(--cy-text) !important;
  line-height: 2 !important;
}

.entry-content p {
  color: var(--cy-text) !important;
  margin-bottom: 1.5em !important;
}

/* リンク（本文内）ホバーでアンダーラインアニメ */
.entry-content a {
  background-image: linear-gradient(var(--cy-cyan), var(--cy-cyan)) !important;
  background-size: 0 1px !important;
  background-position: 0 100% !important;
  background-repeat: no-repeat !important;
  transition: all 0.4s var(--cy-ease) !important;
}

.entry-content a:hover {
  background-size: 100% 1px !important;
}

/* 引用 */
.entry-content blockquote {
  background: rgba(168, 85, 247, 0.06) !important;
  border: 1px solid rgba(168, 85, 247, 0.15) !important;
  border-left: 4px solid var(--cy-purple) !important;
  border-radius: 0 var(--cy-radius) var(--cy-radius) 0 !important;
  color: var(--cy-muted) !important;
  padding: 1.5em 1.8em !important;
  position: relative !important;
  font-style: italic !important;
}

.entry-content blockquote::before {
  content: '"' !important;
  position: absolute !important;
  top: -10px !important;
  left: 15px !important;
  font-size: 3em !important;
  color: var(--cy-purple) !important;
  opacity: 0.3 !important;
  font-family: Georgia, serif !important;
}

/* コード */
.entry-content pre {
  background: #08081a !important;
  color: var(--cy-cyan) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius-sm) !important;
  padding: 1.5em !important;
  overflow-x: auto !important;
  position: relative !important;
  font-family: 'JetBrains Mono', 'Fira Code', 'Source Code Pro', monospace !important;
  font-size: 0.9em !important;
  line-height: 1.7 !important;
}

/* コードブロック左上に "CODE" ラベル */
.entry-content pre::before {
  content: 'CODE' !important;
  position: absolute !important;
  top: 8px !important;
  right: 12px !important;
  font-family: var(--cy-font-display) !important;
  font-size: 9px !important;
  letter-spacing: 2px !important;
  color: var(--cy-muted) !important;
  opacity: 0.5 !important;
}

.entry-content code {
  background: rgba(0, 229, 255, 0.08) !important;
  color: var(--cy-cyan) !important;
  border: 1px solid rgba(0, 229, 255, 0.1) !important;
  border-radius: 3px !important;
  padding: 0.15em 0.5em !important;
  font-size: 0.88em !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
}

.entry-content pre code {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

/* テーブル */
.entry-content table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius-sm) !important;
  overflow: hidden !important;
}

.entry-content th {
  background: rgba(0, 229, 255, 0.1) !important;
  color: var(--cy-cyan) !important;
  font-weight: 700 !important;
  border-color: var(--cy-border) !important;
  padding: 0.8em 1em !important;
  font-family: var(--cy-font-display) !important;
  font-size: 0.85em !important;
  letter-spacing: 1px !important;
}

.entry-content td {
  border-color: var(--cy-border) !important;
  color: var(--cy-text) !important;
  padding: 0.7em 1em !important;
}

.entry-content tr:hover td {
  background: rgba(0, 229, 255, 0.03) !important;
}

/* リストマーカー */
.entry-content ul li::marker {
  color: var(--cy-cyan);
}

.entry-content ol li::marker {
  color: var(--cy-purple);
  font-family: var(--cy-font-display);
  font-weight: 700;
}

/* 画像にホバーエフェクト */
.entry-content img {
  border-radius: var(--cy-radius-sm) !important;
  transition: all 0.4s var(--cy-ease) !important;
}

.entry-content img:hover {
  box-shadow: 0 8px 40px rgba(0, 229, 255, 0.15) !important;
}

/* ========================================
   サイドバー
   ======================================== */
#sidebar {
  background-color: transparent !important;
}

.widget-sidebar {
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  padding: 1.5em !important;
  margin-bottom: 24px !important;
  position: relative !important;
  transition: all 0.4s var(--cy-ease) !important;
}

.widget-sidebar:hover {
  border-color: rgba(0, 229, 255, 0.25) !important;
}

/* ウィジェットタイトル */
.widget-sidebar-title,
.widget-sidebar-scroll-title {
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding-bottom: 0.6em !important;
  margin-bottom: 1em !important;
  position: relative !important;
  border-bottom: none !important;
}

.widget-sidebar-title::after,
.widget-sidebar-scroll-title::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 60px !important;
  height: 2px !important;
  background: var(--cy-grad) !important;
  border-radius: 2px !important;
}

.widget-sidebar a {
  color: var(--cy-text) !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.widget-sidebar a:hover {
  color: var(--cy-cyan) !important;
  padding-left: 4px !important;
}

/* ========================================
   フッター
   ======================================== */
#footer {
  background: var(--cy-bg2) !important;
  position: relative !important;
  border-top: none !important;
}

/* グラデーションライン */
#footer::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, var(--cy-cyan), var(--cy-purple), var(--cy-pink), transparent) !important;
  background-size: 200% 100% !important;
  animation: gradientShift 4s ease infinite !important;
}

#footer,
#footer a,
.footer-bottom {
  color: var(--cy-muted) !important;
}

#footer a:hover {
  color: var(--cy-cyan) !important;
}

.footer-title {
  color: #fff !important;


  font-family: var(--cy-font-display) !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

/* ========================================
   パンくずリスト
   ======================================== */
#breadcrumb {
  background: rgba(12, 12, 26, 0.6) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  padding: 0.7em 1.2em !important;
  margin-bottom: 1.2em !important;
  font-size: 0.82em !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

#breadcrumb a {
  color: var(--cy-muted) !important;
}

#breadcrumb a:hover {
  color: var(--cy-cyan) !important;
}

.breadcrumb-caption {
  color: var(--cy-text) !important;
}

#breadcrumb .sp {
  color: var(--cy-cyan) !important;
  opacity: 0.5 !important;
}

/* ========================================
   ページネーション
   ======================================== */
.pagination .page-numbers {
  background: var(--cy-card) !important;
  color: var(--cy-text) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius-sm) !important;
  transition: all 0.3s var(--cy-ease) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 0.9em !important;
}

.pagination .page-numbers:hover {
  background: rgba(0, 229, 255, 0.1) !important;
  border-color: var(--cy-cyan) !important;
  color: var(--cy-cyan) !important;
  transform: translateY(-2px) !important;
}

.pagination .page-numbers.current {
  background: var(--cy-grad) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: var(--cy-glow), 0 4px 15px rgba(0, 229, 255, 0.2) !important;
  transform: translateY(-2px) !important;
}

.pagination-next-link,
.list-more-button {
  background: transparent !important;
  color: var(--cy-cyan) !important;
  border: 1px solid var(--cy-cyan) !important;
  border-radius: var(--cy-radius) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  transition: all 0.4s var(--cy-ease) !important;
  position: relative !important;
  overflow: hidden !important;
}

/* ボタンホバーでスイープエフェクト */
.pagination-next-link::before,
.list-more-button::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(0, 229, 255, 0.15), transparent) !important;
  transition: left 0.5s var(--cy-ease) !important;
}

.pagination-next-link:hover,
.list-more-button:hover {
  box-shadow: var(--cy-glow) !important;
  background: rgba(0, 229, 255, 0.05) !important;
}

.pagination-next-link:hover::before,
.list-more-button:hover::before {
  left: 100% !important;
}

/* ========================================
   コメントエリア
   ======================================== */
#comment-area {
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  padding: 2em !important;
}

.comment-title,
.comment-reply-title {
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-size: 14px !important;
  letter-spacing: 1px !important;
}

.comment-body {
  border-color: var(--cy-border) !important;
  color: var(--cy-text) !important;
}

.comment-btn,
#comment-reply-btn,
.submit {
  background: var(--cy-grad) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--cy-radius-sm) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 11px !important;
  letter-spacing: 1.5px !important;
  padding: 12px 28px !important;
  cursor: pointer !important;
  transition: all 0.3s var(--cy-ease) !important;
  text-transform: uppercase !important;
}

.comment-btn:hover,
#comment-reply-btn:hover,
.submit:hover {
  box-shadow: var(--cy-glow-strong) !important;
  transform: translateY(-2px) !important;
}

/* フォーム入力 */
#comment-area input[type="text"],
#comment-area input[type="email"],
#comment-area input[type="url"],
#comment-area textarea,
input[type="text"],
input[type="email"],
input[type="url"],
textarea {
  background: var(--cy-bg) !important;
  color: var(--cy-text) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius-sm) !important;
  padding: 10px 14px !important;
  transition: all 0.3s var(--cy-ease) !important;
}

#comment-area input:focus,
#comment-area textarea:focus,
input:focus,
textarea:focus {
  border-color: var(--cy-cyan) !important;
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.15), inset 0 0 15px rgba(0, 229, 255, 0.03) !important;
  outline: none !important;
}

/* ========================================
   検索フォーム
   ======================================== */
.search-edit {
  background: var(--cy-bg) !important;
  color: var(--cy-text) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius-sm) 0 0 var(--cy-radius-sm) !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.search-edit:focus {
  border-color: var(--cy-cyan) !important;
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.15) !important;
  outline: none !important;
}

.search-submit {
  background: var(--cy-grad) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0 var(--cy-radius-sm) var(--cy-radius-sm) 0 !important;
  cursor: pointer !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.search-submit:hover {
  box-shadow: var(--cy-glow) !important;
}

/* ========================================
   SNSボタン
   ======================================== */
.sns-share-message,
.sns-follow-message {
  color: var(--cy-muted) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 11px !important;
  letter-spacing: 1px !important;
}

.sns-share-buttons a,
.sns-buttons a {
  border-radius: var(--cy-radius-sm) !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.sns-share-buttons a:hover,
.sns-buttons a:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.4) !important;
}

/* PC用フォローボタン */
@media screen and (min-width: 1024px) {
  .sns-follow-buttons .follow-button {
    width: 70px !important;
    height: 70px !important;
    font-size: 70px !important;
    background: transparent !important;
    border: 1px solid var(--cy-border) !important;
    color: var(--cy-cyan) !important;
    box-shadow: none !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 0 !important;
    transition: all 0.4s var(--cy-ease) !important;
    border-radius: var(--cy-radius) !important;
  }

  .sns-follow-buttons .follow-button:hover {
    background: rgba(0, 229, 255, 0.08) !important;
    border-color: var(--cy-cyan) !important;
    color: #fff !important;
    box-shadow: var(--cy-glow) !important;
    transform: translateY(-4px) !important;
  }

  .sns-follow-buttons .follow-button span,
  .sns-follow-buttons .follow-button span::before,
  .sns-follow-buttons .follow-button i,
  .sns-follow-buttons .follow-button i::before {
    font-size: 70px !important;
    line-height: 1 !important;
    display: block !important;
    width: auto !important;
    height: auto !important;
  }
}

/* ========================================
   関連記事
   ======================================== */
.related-entry-heading .main-caption {
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-size: 13px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

.related-entry-card-wrap {
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  transition: all 0.4s var(--cy-ease) !important;
  overflow: hidden !important;
}

.related-entry-card-wrap:hover {
  border-color: var(--cy-border-hover) !important;
  box-shadow: 0 6px 30px rgba(0, 229, 255, 0.1) !important;
  transform: translateY(-4px) !important;
}

.related-entry-card-title {
  color: var(--cy-text-bright) !important;
}

.related-entry-card-snippet {
  color: var(--cy-muted) !important;
}

/* ========================================
   前後記事ナビ
   ======================================== */
.pager-post-navi a {
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  transition: all 0.4s var(--cy-ease) !important;
  overflow: hidden !important;
}

.pager-post-navi a:hover {
  border-color: var(--cy-border-hover) !important;
  box-shadow: 0 6px 30px rgba(0, 229, 255, 0.1) !important;
  transform: translateY(-3px) !important;
}

.prev-post-title,
.next-post-title {
  color: var(--cy-text) !important;
}

/* ========================================
   目次 (TOC)
   ======================================== */
.toc {
  background: var(--cy-bg2) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  padding: 1.5em !important;
}

.toc-title {
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

.toc a {
  color: var(--cy-text) !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.toc a:hover {
  color: var(--cy-cyan) !important;
  padding-left: 4px !important;
}

/* ========================================
   ボックス・通知
   ======================================== */
.blank-box,
.information-box,
.question-box,
.alert-box {
  background: var(--cy-card) !important;
  border-color: var(--cy-border) !important;
  color: var(--cy-text) !important;
  border-radius: var(--cy-radius-sm) !important;
}

/* ========================================
   トップへ戻るボタン
   ======================================== */
/* トップへ戻るボタン非表示 (Goodpatch流に不要) */
.go-to-top-button {
  display: none !important;
  background: var(--cy-grad) !important;
  color: #fff !important;
  border-radius: var(--cy-radius) !important;
  box-shadow: var(--cy-glow) !important;
  transition: all 0.3s var(--cy-ease) !important;
  border: none !important;
  width: 48px !important;
  height: 48px !important;
}

.go-to-top-button:hover {
  box-shadow: var(--cy-glow-strong) !important;
  transform: translateY(-4px) !important;
}

/* ========================================
   モバイルメニュー
   ======================================== */
.mobile-header-menu-buttons,
.mobile-footer-menu-buttons {
  background: rgba(6, 6, 14, 0.95) !important;
  border-color: var(--cy-border) !important;
  backdrop-filter: blur(15px) !important;
  -webkit-backdrop-filter: blur(15px) !important;
}

.menu-button {
  color: var(--cy-text) !important;
  transition: color 0.3s var(--cy-ease) !important;
}

.menu-button:hover,
.menu-button:active {
  color: var(--cy-cyan) !important;
}

/* モバイルスライドメニュー */
.menu-content {
  background: var(--cy-bg2) !important;
  border-right: 1px solid var(--cy-border) !important;
}

.menu-content a {
  color: var(--cy-text) !important;
  border-bottom: 1px solid rgba(0, 229, 255, 0.06) !important;
}

.menu-content a:hover {
  background: rgba(0, 229, 255, 0.05) !important;
  color: var(--cy-cyan) !important;
}

/* ========================================
   タブインデックス
   ======================================== */
.index-tab-buttons .index-tab-button {
  background: var(--cy-card) !important;
  color: var(--cy-text) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius-sm) var(--cy-radius-sm) 0 0 !important;
  transition: all 0.3s var(--cy-ease) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 10px !important;
  letter-spacing: 1px !important;
}

.index-tab-buttons .index-tab-button:hover,
.index-tab-buttons .index-tab-button.is-active {
  background: rgba(0, 229, 255, 0.08) !important;
  border-color: var(--cy-cyan) !important;
  color: var(--cy-cyan) !important;
}

/* ========================================
   アピールエリア
   ======================================== */
.appeal-button {
  background: var(--cy-grad) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--cy-radius) !important;
  font-family: var(--cy-font-display) !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  padding: 14px 36px !important;
  transition: all 0.4s var(--cy-ease) !important;
  text-transform: uppercase !important;
}

.appeal-button:hover {
  box-shadow: var(--cy-glow-strong) !important;
  transform: translateY(-3px) scale(1.02) !important;
}

/* ========================================
   フェードイン・スクロールアニメーション
   ======================================== */
.cy-fade-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s var(--cy-ease), transform 0.7s var(--cy-ease);
}

.cy-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* 各カードの遅延（JSで --delay を設定） */
.cy-fade-up {
  transition-delay: var(--delay, 0s);
}

/* ========================================
   パーティクルキャンバス背景
   ======================================== */
#cy-particles {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
}

/* ========================================
   カスタムカーソルトレイル
   ======================================== */
.cy-cursor-dot {
  position: fixed;
  width: 6px;
  height: 6px;
  background: var(--cy-cyan);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10000;
  transition: transform 0.1s, opacity 0.3s;
  box-shadow: 0 0 10px var(--cy-cyan), 0 0 20px rgba(0, 229, 255, 0.3);
  mix-blend-mode: screen;
}

.cy-cursor-ring {
  position: fixed;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(0, 229, 255, 0.4);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10000;
  transition: all 0.15s var(--cy-ease);
  mix-blend-mode: screen;
}

.cy-cursor-ring.is-hovering {
  width: 50px;
  height: 50px;
  border-color: var(--cy-cyan);
  background: rgba(0, 229, 255, 0.05);
}

/* ========================================
   トップページ固有
   ======================================== */
.home .date-tags,
.home .post-date,
.home .post-update {
  display: none !important;
}

.home #navi {
  display: none !important;
}

/* ========================================
   レスポンシブ
   ======================================== */
@media screen and (max-width: 1023px) {
  .article {
    padding: 1.5em !important;
  }

  .entry-title {
    font-size: 1.5em !important;
  }

  /* カーソルエフェクトはPC限定 */
  .cy-cursor-dot,
  .cy-cursor-ring {
    display: none !important;
  }
}

@media screen and (max-width: 834px) {
  #navi .navi-in>ul>li>a {
    font-size: 10px !important;
    padding: 0 14px !important;
    letter-spacing: 1px !important;
  }

  .article {
    padding: 1.2em !important;
  }
}

@media screen and (max-width: 480px) {
  .article {
    padding: 1em !important;
    border-radius: var(--cy-radius-sm) !important;
  }

  .entry-title {
    font-size: 1.2em !important;
  }

  .entry-card-wrap:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 4px 20px rgba(0, 229, 255, 0.08) !important;
  }

  /* スキャンラインを控えめに */
  body::before {
    opacity: 0.5;
  }

  /* パーティクル数を減らす（JSで制御） */
}

/* ========================================
   ★★★ ローディング画面 ★★★
   ======================================== */
#cy-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--cy-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}

#cy-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.cy-loader-inner {
  text-align: center;
  position: relative;
}

/* 回転リング */
.cy-loader-ring {
  width: 100px;
  height: 100px;
  border: 2px solid transparent;
  border-top: 2px solid var(--cy-cyan);
  border-right: 2px solid var(--cy-cyan);
  border-radius: 50%;
  margin: 0 auto 24px;
  animation: loaderSpin 1.2s linear infinite;
  position: relative;
}

.cy-loader-ring-2 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 70px;
  height: 70px;
  border: 2px solid transparent;
  border-bottom: 2px solid var(--cy-purple);
  border-left: 2px solid var(--cy-purple);
  margin: 0;
  animation: loaderSpin 0.8s linear infinite reverse;
}

@keyframes loaderSpin {
  to {
    transform: rotate(360deg);
  }
}

.cy-loader-ring-2 {
  animation: loaderSpinReverse 0.8s linear infinite;
}

@keyframes loaderSpinReverse {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(-360deg);
  }
}

/* ローディングテキスト */
.cy-loader-text {
  font-family: var(--cy-font-display);
  font-size: 14px;
  letter-spacing: 6px;
  color: var(--cy-cyan);
  margin-bottom: 20px;
  animation: neonPulse 2s ease-in-out infinite;
}

/* プログレスバー */
.cy-loader-bar {
  width: 200px;
  height: 2px;
  background: rgba(0, 229, 255, 0.15);
  border-radius: 2px;
  margin: 0 auto;
  overflow: hidden;
}

.cy-loader-bar-fill {
  width: 0%;
  height: 100%;
  background: var(--cy-grad);
  border-radius: 2px;
  transition: width 0.3s ease;
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.5);
}

/* ========================================
   ★★★ ページ遷移オーバーレイ ★★★
   ======================================== */
#cy-transition {
  position: fixed;
  inset: 0;
  z-index: 99998;
  pointer-events: none;
  display: flex;
}

.cy-transition-line {
  flex: 1;
  background: var(--cy-bg);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.5s cubic-bezier(0.77, 0, 0.175, 1);
}

#cy-transition.is-active .cy-transition-line {
  transform: scaleY(1);
}

.cy-transition-line-1 {
  transition-delay: 0s;
}

.cy-transition-line-2 {
  transition-delay: 0.08s;
}

.cy-transition-line-3 {
  transition-delay: 0.16s;
}

#cy-transition.is-leaving .cy-transition-line {
  transform-origin: bottom;
  transform: scaleY(0);
}

/* ========================================
   ★★★ 読了プログレスバー（記事ページ上部） ★★★
   ======================================== */
#cy-reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  z-index: 10001;
  background: transparent;
}

#cy-reading-fill {
  height: 100%;
  width: 0%;
  background: var(--cy-grad);
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.4), 0 0 30px rgba(0, 229, 255, 0.2);
  transition: width 0.1s linear;
  border-radius: 0 2px 2px 0;
}

/* ========================================
   ★★★ ヒーローセクション（トップページ） ★★★
   ======================================== */
#cy-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  z-index: 1;
}

/* 背景グラデ＆ビネット */
.cy-hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(0, 229, 255, 0.08), transparent 50%),
    radial-gradient(ellipse at 80% 50%, rgba(168, 85, 247, 0.08), transparent 50%),
    radial-gradient(ellipse at 50% 50%, transparent 40%, var(--cy-bg));
  z-index: 0;
}

/* ヒーローグリッド（3Dパース感） */
.cy-hero-grid {
  position: absolute;
  bottom: 0;
  left: -10%;
  width: 120%;
  height: 50%;
  background-image:
    linear-gradient(rgba(0, 229, 255, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 229, 255, 0.08) 1px, transparent 1px);
  background-size: 40px 40px;
  transform: perspective(500px) rotateX(60deg);
  transform-origin: bottom center;
  z-index: 0;
  mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent 80%);
  -webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent 80%);
}

/* コンテンツ */
.cy-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 20px;
}

/* バッジ */
.cy-hero-badge {
  display: inline-block;
  font-family: var(--cy-font-display);
  font-size: 11px;
  letter-spacing: 4px;
  color: var(--cy-cyan);
  border: 1px solid var(--cy-border);
  padding: 6px 20px;
  border-radius: 30px;
  margin-bottom: 24px;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.8s 0.5s forwards;
}

/* ヒーロータイトル */
.cy-hero-title {
  font-family: var(--cy-font-display) !important;
  font-size: clamp(2rem, 7vw, 5rem) !important;
  font-weight: 900 !important;
  color: #fff !important;
  letter-spacing: 6px !important;
  line-height: 1.2 !important;
  margin-bottom: 16px !important;
  background: linear-gradient(135deg, #fff 0%, var(--cy-cyan) 50%, var(--cy-purple) 100%);
  background-size: 200% 200%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 6s ease infinite, fadeUp 0.8s 0.7s backwards;
}

/* サブテキスト */
.cy-hero-desc {
  font-family: var(--cy-font-body) !important;
  font-size: 1.05em !important;
  color: var(--cy-muted) !important;
  letter-spacing: 1px !important;
  margin-bottom: 40px !important;
  max-width: 500px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.8s 0.9s forwards;
}

/* 統計カウンター */
.cy-hero-stats {
  display: flex;
  justify-content: center;
  gap: 48px;
  margin-bottom: 40px;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.8s 1.1s forwards;
}

.cy-hero-stat {
  text-align: center;
}

.cy-hero-stat-num {
  display: block;
  font-family: var(--cy-font-display);
  font-size: 2.5em;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
  text-shadow: 0 0 20px rgba(0, 229, 255, 0.3);
}

.cy-hero-stat-label {
  font-family: var(--cy-font-display);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--cy-muted);
}

/* CTAボタン */
.cy-hero-cta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-family: var(--cy-font-display) !important;
  font-size: 13px !important;
  letter-spacing: 3px !important;
  color: #fff !important;
  background: var(--cy-grad) !important;
  padding: 14px 36px !important;
  border-radius: 50px !important;
  transition: all 0.4s var(--cy-ease) !important;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.8s 1.3s forwards, float 3s 2.5s ease-in-out infinite;
}

.cy-hero-cta:hover {
  box-shadow: var(--cy-glow-strong) !important;
  transform: translateY(-4px) scale(1.05) !important;
}

/* スクロールヒント */
.cy-hero-scroll-hint {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 2;
  opacity: 0;
  animation: fadeUp 0.8s 2s forwards;
}

.cy-hero-mouse {
  width: 24px;
  height: 38px;
  border: 2px solid rgba(0, 229, 255, 0.4);
  border-radius: 12px;
  position: relative;
}

.cy-hero-mouse-wheel {
  width: 3px;
  height: 8px;
  background: var(--cy-cyan);
  border-radius: 3px;
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  animation: mouseScroll 2s ease-in-out infinite;
}

@keyframes mouseScroll {

  0%,
  100% {
    opacity: 1;
    top: 6px;
  }

  50% {
    opacity: 0.3;
    top: 18px;
  }
}

.cy-hero-scroll-hint span {
  font-family: var(--cy-font-display);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--cy-muted);
}

/* ========================================
   ★★★ 記事一覧 グリッドレイアウト化 ★★★
   ======================================== */
/* Old #list grid styles removed */

/* ========================================
   ★★★ サイドプログレスバー（記事ページ） ★★★
   ======================================== */
#cy-side-progress {
  position: fixed;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1000;
  opacity: 0;
  transition: opacity 0.5s ease;
}

#cy-side-progress.is-visible {
  opacity: 1;
}

.cy-side-progress-track {
  width: 3px;
  height: 150px;
  background: rgba(0, 229, 255, 0.1);
  border-radius: 3px;
  position: relative;
}

.cy-side-progress-fill {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0%;
  background: var(--cy-grad);
  border-radius: 3px;
  transition: height 0.15s linear;
}

.cy-side-progress-thumb {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 11px;
  height: 11px;
  background: var(--cy-cyan);
  border-radius: 50%;
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.5);
  bottom: 0%;
  transition: bottom 0.15s linear;
}

@media screen and (max-width: 1023px) {
  #cy-side-progress {
    display: none !important;
  }
}

/* ========================================
   ★★★ 画像リビールエフェクト ★★★
   ======================================== */
.cy-img-reveal {
  position: relative;
  overflow: hidden;
}

.cy-img-reveal img {
  filter: blur(15px) saturate(0);
  transform: scale(1.1);
  transition: filter 0.8s ease, transform 0.8s ease;
}

.cy-img-reveal.is-revealed img {
  filter: blur(0) saturate(1);
  transform: scale(1);
}

/* リビールオーバーレイ */
.cy-img-reveal::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--cy-grad);
  transform: translateX(-101%);
}

.cy-img-reveal.is-revealing::after {
  animation: imgRevealSwipe 0.8s cubic-bezier(0.77, 0, 0.175, 1) forwards;
}

@keyframes imgRevealSwipe {
  0% {
    transform: translateX(-101%);
  }

  50% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(101%);
  }
}

/* ========================================
   ★★★ マグネティックボタン ★★★
   ======================================== */
.cy-magnetic {
  transition: transform 0.3s var(--cy-ease) !important;
}

/* ========================================
   ★★★ トップへ戻るボタン - プログレスリング ★★★
   ======================================== */
/* Old Top Button styles removed (Now forced hidden) */

/* ========================================
   ★★★ 記事ページ - フルリデザイン ★★★
   ======================================== */

/* --- アイキャッチをヒーロー化 --- */
.eye-catch-wrap {
  margin: -2.5em -2.5em 0 -2.5em !important;
  border-radius: var(--cy-radius) var(--cy-radius) 0 0 !important;
  overflow: hidden !important;
  position: relative !important;
}

.eye-catch {
  position: relative !important;
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

.eye-catch-image {
  width: 100% !important;
  height: 360px !important;
  object-fit: cover !important;
  display: block !important;
  filter: brightness(0.7) !important;
  transition: filter 0.6s var(--cy-ease), transform 0.6s var(--cy-ease) !important;
}

.eye-catch:hover .eye-catch-image {
  filter: brightness(0.8) !important;
  transform: scale(1.03) !important;
}

/* アイキャッチの下にグラデーションオーバーレイ */
.eye-catch::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 60% !important;
  background: linear-gradient(to top, var(--cy-card), transparent) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

/* アイキャッチ上のカテゴリラベル */
.eye-catch .cat-label {
  z-index: 2 !important;
  top: 16px !important;
  left: 16px !important;
  font-size: 10px !important;
  padding: 5px 14px !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
}

/* アイキャッチのキャプション */
.eye-catch-caption {
  z-index: 2 !important;
  background: rgba(0, 0, 0, 0.6) !important;
  color: var(--cy-muted) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  padding: 8px 16px !important;
  font-size: 0.8em !important;
}

/* --- 記事ヘッダーの刷新 --- */
.article-header {
  position: relative !important;
}

/* タイトルをアイキャッチの上に重ねる（アイキャッチがある場合） */
.eye-catch-wrap+.sns-share,
.eye-catch-wrap~.date-tags {
  position: relative;
  z-index: 2;
}

/* 記事タイトル - より大きくドラマチックに */
.single .entry-title,
.page .entry-title {
  font-size: 2em !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
  letter-spacing: 0.5px !important;
  margin-top: 1.2em !important;
  margin-bottom: 0.6em !important;
  padding-bottom: 0.6em !important;
}

/* --- 日付・メタ情報バッジ化 --- */
.date-tags {
  text-align: left !important;
  margin-bottom: 1.5em !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}

.post-date,
.post-update {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 0.78em !important;
  color: var(--cy-muted) !important;
  background: rgba(0, 229, 255, 0.06) !important;
  border: 1px solid var(--cy-border) !important;
  padding: 4px 12px !important;
  border-radius: 30px !important;
  font-family: var(--cy-font-display) !important;
  letter-spacing: 0.5px !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.post-date:hover,
.post-update:hover {
  border-color: var(--cy-cyan) !important;
  color: var(--cy-cyan) !important;
}

.post-date .fa,
.post-update .fa {
  color: var(--cy-cyan) !important;
  font-size: 0.9em !important;
}

/* --- 読了時間バッジ --- */
.read-time {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 0.78em !important;
  color: var(--cy-muted) !important;
  background: rgba(168, 85, 247, 0.06) !important;
  border: 1px solid rgba(168, 85, 247, 0.15) !important;
  padding: 4px 12px !important;
  border-radius: 30px !important;
  margin-bottom: 1.5em !important;
}

.read-time .fa {
  color: var(--cy-purple) !important;
}

/* --- カテゴリ・タグリンク --- */
.entry-categories-tags {
  margin: 2em 0 !important;
  padding: 1.5em 0 !important;
  border-top: 1px solid var(--cy-border) !important;
  border-bottom: 1px solid var(--cy-border) !important;
}

.cat-link {
  display: inline-block !important;
  background: rgba(0, 229, 255, 0.08) !important;
  border: 1px solid var(--cy-border) !important;
  color: var(--cy-cyan) !important;
  padding: 4px 14px !important;
  border-radius: 30px !important;
  font-size: 0.82em !important;
  margin: 3px 4px 3px 0 !important;
  transition: all 0.3s var(--cy-ease) !important;
  font-family: var(--cy-font-display) !important;
  letter-spacing: 0.5px !important;
}

.cat-link:hover {
  background: rgba(0, 229, 255, 0.15) !important;
  border-color: var(--cy-cyan) !important;
  box-shadow: 0 0 12px rgba(0, 229, 255, 0.15) !important;
}

.tag-link {
  display: inline-block !important;
  background: rgba(168, 85, 247, 0.06) !important;
  border: 1px solid rgba(168, 85, 247, 0.12) !important;
  color: var(--cy-purple) !important;
  padding: 4px 14px !important;
  border-radius: 30px !important;
  font-size: 0.82em !important;
  margin: 3px 4px 3px 0 !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.tag-link:hover {
  background: rgba(168, 85, 247, 0.12) !important;
  border-color: var(--cy-purple) !important;
  box-shadow: 0 0 12px rgba(168, 85, 247, 0.15) !important;
}

/* --- 著者情報 --- */
.footer-meta {
  text-align: left !important;
  margin-top: 2em !important;
  padding-top: 1.5em !important;
  border-top: 1px solid var(--cy-border) !important;
}

.author-info {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--cy-bg2) !important;
  border: 1px solid var(--cy-border) !important;
  padding: 8px 18px !important;
  border-radius: var(--cy-radius) !important;
  transition: all 0.3s var(--cy-ease) !important;
}

.author-info:hover {
  border-color: rgba(0, 229, 255, 0.3) !important;
}

.author-info .fa {
  color: var(--cy-cyan) !important;
}

.author-name {
  color: var(--cy-text-bright) !important;
  font-weight: 600 !important;
}

/* --- 本文の装飾強化 --- */

/* 最初の段落を大きく */
.entry-content>p:first-of-type {
  font-size: 1.1em !important;
  line-height: 2.1 !important;
  color: var(--cy-text-bright) !important;
}

/* 最初の1文字をドロップキャップ風に */
.entry-content>p:first-of-type::first-letter {
  font-size: 2.8em;
  font-weight: 900;
  float: left;
  line-height: 1;
  margin-right: 10px;
  margin-top: 4px;
  color: var(--cy-cyan);
  font-family: var(--cy-font-display);
  text-shadow: 0 0 20px rgba(0, 229, 255, 0.3);
}

/* 強調テキスト */
.entry-content strong,
.entry-content b {
  color: var(--cy-text-bright) !important;
  font-weight: 700 !important;
  background: linear-gradient(transparent 60%, rgba(0, 229, 255, 0.12) 60%) !important;
}

/* マーカー（Cocoonのハイライト）*/
.entry-content .marker-under,
.entry-content .marker-under-red,
.entry-content .marker-under-blue {
  background-image: none !important;
}

.entry-content .marker-under {
  border-bottom: 3px solid var(--cy-cyan) !important;
  padding-bottom: 1px !important;
}

/* 水平線をサイバー風に */
.entry-content hr {
  border: none !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, var(--cy-cyan), var(--cy-purple), transparent) !important;
  margin: 2.5em 0 !important;
  opacity: 0.5 !important;
}

/* iframeコンテンツ（YouTube等）にグロウ枠 */
.entry-content iframe {
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.4) !important;
}

.entry-content iframe:hover {
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.4), 0 0 30px rgba(0, 229, 255, 0.08) !important;
}

/* Cocoonのボックス系スタイル統一 */
.entry-content .wp-block-group,
.entry-content .blank-box,
.entry-content .information-box,
.entry-content .question-box,
.entry-content .alert-box,
.entry-content .memo-box {
  background: var(--cy-bg2) !important;
  border-radius: var(--cy-radius) !important;
  padding: 1.5em !important;
  border-color: var(--cy-border) !important;
}

/* Cocoonのアコーディオン */
.entry-content .toggle-wrap {
  background: var(--cy-bg2) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
}

.entry-content .toggle-title {
  color: var(--cy-text-bright) !important;
}

/* Cocoonのタブボックス */
.entry-content .tab-caption-box {
  border-color: var(--cy-border) !important;
}

.entry-content .tab-caption-box-label {
  background: var(--cy-grad) !important;
  color: #fff !important;
}

.entry-content .tab-caption-box-content {
  background: var(--cy-bg2) !important;
  color: var(--cy-text) !important;
}

/* --- 関連記事セクションの刷新 --- */
#related-entries {
  margin-top: 2em !important;
}

.related-entry-heading {
  position: relative !important;
  padding-bottom: 0.6em !important;
  margin-bottom: 1.5em !important;
}

.related-entry-heading::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 80px !important;
  height: 2px !important;
  background: var(--cy-grad) !important;
  border-radius: 2px !important;
}

.related-entry-heading .sub-caption {
  color: var(--cy-muted) !important;
  font-size: 0.8em !important;
}

/* 関連記事もグリッド化 */
.related-list {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 16px !important;
}

@media screen and (max-width: 834px) {
  .related-list {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media screen and (max-width: 480px) {
  .related-list {
    grid-template-columns: 1fr !important;
  }
}

/* --- 前後記事ナビの刷新 --- */
.pager-post-navi {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  margin-top: 2em !important;
}

.pager-post-navi a {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px !important;
}

.pager-post-navi a .prev-next-home {
  text-align: center !important;
}

.prev-post-thumb,
.next-post-thumb {
  width: 70px !important;
  height: 70px !important;
  border-radius: var(--cy-radius-sm) !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

.prev-post-thumb img,
.next-post-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

@media screen and (max-width: 480px) {
  .pager-post-navi {
    grid-template-columns: 1fr !important;
  }
}

/* --- コメントセクション刷新 --- */
.comment-list {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.comment-list .comment {
  padding: 1.2em !important;
  margin-bottom: 12px !important;
  background: var(--cy-bg2) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
}

.comment-author {
  color: var(--cy-text-bright) !important;
  font-weight: 600 !important;
}

.comment-author img {
  border-radius: 50% !important;
  border: 2px solid var(--cy-border) !important;
}

.comment-meta {
  color: var(--cy-muted) !important;
  font-size: 0.8em !important;
}

/* --- レスポンシブ対応（記事ページ） --- */
@media screen and (max-width: 1023px) {
  .eye-catch-wrap {
    margin: -1.5em -1.5em 0 -1.5em !important;
  }

  .eye-catch-image {
    height: 260px !important;
  }

  .single .entry-title,
  .page .entry-title {
    font-size: 1.6em !important;
  }
}

@media screen and (max-width: 480px) {
  .eye-catch-wrap {
    margin: -1em -1em 0 -1em !important;
  }

  .eye-catch-image {
    height: 200px !important;
  }

  .single .entry-title,
  .page .entry-title {
    font-size: 1.3em !important;
  }

  .entry-content>p:first-of-type::first-letter {
    font-size: 2.2em;
  }
}

/* ========================================
   カテゴリナビセクション (New)
   ======================================== */
#cy-cat-section {
  position: relative !important;
  z-index: 10 !important;
  padding: 80px 4% 120px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}

/* セクション見出し */
.cy-section-header {
  display: flex !important;
  align-items: center !important;
  margin-bottom: 60px !important;
}

.cy-section-title {
  font-family: var(--cy-font-display) !important;
  font-size: 2em !important;
  font-weight: 900 !important;
  color: #fff !important;
  text-shadow: 0 0 10px rgba(0, 229, 255, 0.5) !important;
  letter-spacing: 4px !important;
  margin-right: 20px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cy-section-line {
  flex-grow: 1 !important;
  height: 2px !important;
  background: linear-gradient(90deg, var(--cy-cyan), transparent) !important;
  box-shadow: 0 0 8px rgba(0, 229, 255, 0.4) !important;
}

/* グリッドレイアウト */
.cy-cat-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 30px !important;
}

/* カードスタイル */
.cy-cat-card {
  position: relative !important;
  height: 220px !important;
  background: #000 !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  overflow: hidden !important;
  text-decoration: none !important;
  transition: all 0.4s var(--cy-ease) !important;
  transform-style: preserve-3d !important;
}

/* カード背景画像 */
.cy-cat-bg {
  position: absolute !important;
  inset: 0 !important;
  background-size: cover !important;
  background-position: center !important;
  opacity: 0.4 !important;
  transition: all 0.6s var(--cy-ease) !important;
  filter: grayscale(80%) contrast(1.2) !important;
}

/* カードオーバーレイグラデーション */
.cy-cat-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, transparent 0%, rgba(6, 6, 14, 0.9) 100%) !important;
  z-index: 1 !important;
}

/* カードコンテンツ */
.cy-cat-content {
  position: absolute !important;
  bottom: 20px !important;
  left: 20px !important;
  right: 20px !important;
  z-index: 2 !important;
  transform: translateY(0) !important;
  transition: transform 0.4s var(--cy-ease) !important;
}

.cy-cat-icon {
  color: var(--cy-cyan) !important;
  margin-bottom: 10px !important;
  opacity: 0.8 !important;
  transform: translateX(-10px) !important;
  opacity: 0 !important;
  transition: all 0.4s var(--cy-ease) !important;
}

.cy-cat-name {
  font-family: var(--cy-font-display) !important;
  color: #fff !important;
  font-size: 1.4em !important;
  font-weight: 700 !important;
  margin: 0 0 5px !important;
  letter-spacing: 1px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8) !important;
}

.cy-cat-count {
  display: block !important;
  font-family: var(--cy-font-display) !important;
  font-size: 0.8em !important;
  color: var(--cy-muted) !important;
  letter-spacing: 2px !important;
}

/* スキャンラインエフェクト (カード内) */
.cy-cat-scanline {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, transparent 50%, rgba(0, 229, 255, 0.05) 50%) !important;
  background-size: 100% 4px !important;
  z-index: 3 !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transition: opacity 0.4s !important;
}

/* ボーダーグロウ */
.cy-cat-border-glow {
  position: absolute !important;
  inset: 0 !important;
  border: 1px solid var(--cy-cyan) !important;
  border-radius: var(--cy-radius) !important;
  opacity: 0 !important;
  box-shadow: inset 0 0 20px rgba(0, 229, 255, 0.3) !important;
  transition: all 0.4s var(--cy-ease) !important;
  z-index: 4 !important;
  pointer-events: none !important;
}

/* ホバーエフェクト */
.cy-cat-card:hover {
  transform: translateY(-8px) scale(1.02) !important;
  box-shadow: 0 10px 40px rgba(0, 229, 255, 0.2), 0 0 20px rgba(0, 229, 255, 0.1) !important;
  border-color: var(--cy-cyan) !important;
}

.cy-cat-card:hover .cy-cat-bg {
  opacity: 0.7 !important;
  filter: grayscale(0%) contrast(1.1) !important;
  transform: scale(1.1) !important;
}

.cy-cat-card:hover .cy-cat-content {
  transform: translateY(-5px) !important;
}

.cy-cat-card:hover .cy-cat-icon {
  transform: translateX(0) !important;
  opacity: 1 !important;
}

.cy-cat-card:hover .cy-cat-name {
  color: #fff !important;
  text-shadow: 0 0 8px var(--cy-cyan) !important;
}

.cy-cat-card:hover .cy-cat-count {
  color: var(--cy-text-bright) !important;
}

.cy-cat-card:hover .cy-cat-scanline {
  opacity: 1 !important;
  animation: scanline 2s linear infinite !important;
}

.cy-cat-card:hover .cy-cat-border-glow {
  opacity: 1 !important;
}

/* ========================================
   トップページの既存コンテンツ非表示
   ======================================== */
body.home #content,
body.front-page #content,
body.home #main,
body.front-page #main,
body.home .content-top,
body.front-page .content-top,
body.home .content-bottom,
body.front-page .content-bottom {
  display: none !important;
}


/* ========================================
   Goodpatch-inspired Overhaul (FINAL)
   ======================================== */

:root {
  --cy-font-body: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  --cy-bg-dark: #06060e;
  --cy-text-main: #fff;
  --cy-accent: #00e5ff;
}

body {
  background-color: var(--cy-bg-dark) !important;
  font-family: var(--cy-font-body) !important;
}

/* 共通コンテナ */
.cy-container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 4% !important;
  position: relative !important;
}

.cy-section-padded {
  padding: 120px 0 !important;
  position: relative !important;
  z-index: 10 !important;
}

/* タイポグラフィ */
.cy-heading-xl {
  font-size: 5rem !important;
  font-weight: 900 !important;
  margin-bottom: 20px !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
}

.cy-heading-lg {
  font-size: 3rem !important;
  font-weight: 700 !important;
  margin-bottom: 30px !important;
}

.cy-heading-sub {
  display: block !important;
  font-size: 1rem !important;
  color: var(--cy-accent) !important;
  letter-spacing: 2px !important;
  margin-bottom: 10px !important;
  text-transform: uppercase !important;
}

.cy-text-body {
  font-size: 1.1rem !important;
  line-height: 2 !important;
  color: #ccc !important;
  margin-bottom: 40px !important;
}

/* ボタン (Outline) */
.cy-btn-outline {
  display: inline-block !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  color: #fff !important;
  padding: 15px 40px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  transition: all 0.3s !important;
}

.cy-btn-outline:hover {
  border-color: var(--cy-accent) !important;
  color: var(--cy-accent) !important;
}

.cy-btn-text {
  color: #fff !important;
  font-size: 1.2rem !important;
  text-decoration: none !important;
  border-bottom: 1px solid #fff !important;
  padding-bottom: 5px !important;
}

/* ========================================
   1. HERO
   ======================================== */
#cy-hero {
  height: 100vh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  padding-top: 0 !important;
}

.cy-hero-title-massive {
  font-size: clamp(3rem, 9vw, 10rem) !important;
  font-weight: 900 !important;
  line-height: 0.85 !important;
  letter-spacing: -0.04em !important;
  margin-bottom: 40px !important;
}

.cy-line-reveal {
  display: block !important;
  overflow: hidden !important;
}

.cy-line-inner {
  display: block !important;
  transform: translateY(110%);
  opacity: 0;
  transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1), opacity 1.2s ease !important;
}

.cy-line-reveal.is-in-view .cy-line-inner {
  transform: translateY(0);
  opacity: 1;
}

.cy-scroll-indicator {
  position: absolute !important;
  bottom: 50px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  font-size: 0.8rem !important;
  letter-spacing: 2px !important;
  opacity: 0.7 !important;
}

.cy-scroll-line {
  width: 1px !important;
  height: 60px !important;
  background: #fff !important;
  margin: 10px auto 0 !important;
  animation: scrollLine 2s infinite !important;
}

@keyframes scrollLine {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }

  50% {
    transform-origin: top;
    transform: scaleY(1);
  }

  51% {
    transform-origin: bottom;
    transform: scaleY(1);
  }

  100% {
    transform-origin: bottom;
    transform: scaleY(0);
  }
}

/* ========================================
   2. VISION (Split)
   ======================================== */
.cy-split-layout {
  display: flex !important;
  align-items: center !important;
  gap: 60px !important;
}

.cy-split-left {
  flex: 1 !important;
}

.cy-split-right {
  flex: 1 !important;
}

.cy-vision-graphic {
  width: 100% !important;
  aspect-ratio: 1/1 !important;
  background: radial-gradient(circle, rgba(0, 229, 255, 0.1) 0%, transparent 70%) !important;
  position: relative !important;
}

.cy-circle-morph {
  width: 60% !important;
  height: 60% !important;
  background: var(--cy-accent) !important;
  border-radius: 50% !important;
  position: absolute !important;
  top: 20% !important;
  left: 20% !important;
  filter: blur(60px) !important;
  animation: morph 8s infinite alternate !important;
}

@keyframes morph {
  0% {
    transform: scale(1);
    border-radius: 50%;
  }

  100% {
    transform: scale(1.2);
    border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%;
  }
}

/* ========================================
   3. WORKS (Staggered Grid)
   ======================================== */
/* ========================================
   Works Section (Meta Style)
   ======================================== */
.cy-works-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 40px 24px;
  /* Row gap increased for text space */
  margin-top: 40px;
}

/* Mobile Horizontal Scroll */
@media (max-width: 768px) {
  .cy-works-grid {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 16px;
    padding-bottom: 20px;
    /* Space for scrollbar */
    margin-right: -20px;
    /* Offset container padding */
    padding-right: 20px;
    -webkit-overflow-scrolling: touch;
  }

  .cy-work-card {
    flex: 0 0 85%;
    /* Show part of next card */
    scroll-snap-align: center;
  }

  .cy-work-card:first-child {
    margin-left: 0;
  }
}

.cy-work-card {
  display: block;
  position: relative;
  text-decoration: none;
  /* Stagger effect handled by scroll reveal usually, 
     but keeping simple for now */
}



.cy-work-img-layer {
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 4 / 3;
  /* Standard card ratio */
  background: var(--cy-card);
  transition: transform 0.4s var(--cy-ease), box-shadow 0.4s var(--cy-ease);
  /* Meta-like subtle border */
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.cy-work-card:hover .cy-work-img-layer {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  border-color: rgba(255, 255, 255, 0.2);
}

.cy-work-img-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--cy-ease);
  display: block;
}

.cy-work-card:hover .cy-work-img-layer img {
  transform: scale(1.05);
  /* Subtle zoom */
}

/* Text Layer - Below Image */
.cy-work-text-layer {
  margin-top: 16px;
  text-align: center;
}

.cy-work-title-pill {
  display: inline-block;
  font-family: var(--cy-font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--cy-text-bright);
  letter-spacing: 0.5px;
  transition: color 0.3s ease;
}

.cy-work-card:hover .cy-work-title-pill {
  color: #fff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.3);
}



/* ========================================
   4. NEWS (Card Grid)
   ======================================== */
.cy-news-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 30px !important;
}

.cy-news-card {
  background: rgba(255, 255, 255, 0.05) !important;
  padding: 30px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  color: #fff !important;
  transition: background 0.3s !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 200px !important;
}

.cy-news-card:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

.cy-news-date {
  font-size: 0.9rem !important;
  color: #888 !important;
  margin-bottom: 15px !important;
}

.cy-news-title {
  font-size: 1.1rem !important;
  line-height: 1.5 !important;
  margin-bottom: auto !important;
}

.cy-news-arrow {
  align-self: flex-end !important;
  margin-top: 20px !important;
  color: var(--cy-accent) !important;
}

/* ========================================
   5. FOOTER
   ======================================== */
#cy-footer {
  padding: 80px 0 40px !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: #000 !important;
}

.cy-footer-logo {
  font-size: 2rem !important;
  font-weight: 700 !important;
  margin-bottom: 30px !important;
}

.cy-footer-nav a {
  color: #fff !important;
  margin-right: 30px !important;
  text-decoration: none !important;
  font-size: 1.1rem !important;
}

/* ========================================
   Responsive
   ======================================== */
@media screen and (max-width: 768px) {
  .cy-split-layout {
    flex-direction: column !important;
    gap: 40px !important;
  }

  .cy-works-grid {
    grid-template-columns: 1fr !important;
    gap: 60px !important;
  }

  .cy-stagger-low {
    margin-top: 0 !important;
  }

  .cy-news-grid {
    grid-template-columns: 1fr !important;
  }
}

/* フェードアップ */
.fade-up {
  opacity: 0 !important;
  transform: translateY(40px) !important;
  transition: all 1s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.fade-up.is-in-view {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* 遅延 */
.delay-200 {
  transition-delay: 0.2s !important;
}

.delay-600 {
  transition-delay: 0.6s !important;
}

/* キャンバス背景 (流用) */
#cy-bg-canvas {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: -1 !important;
  pointer-events: none !important;
  opacity: 0.5 !important;
}

/* 既存隠し */
body.home #content,
body.home #main,
body.home #footer {
  display: none !important;
}

/* ========================================
   ★★★ Force Hide Page Top Button (FINAL) ★★★
   ======================================== */
.go-to-top-button,
#go-to-top,
.page-top,
#page-top,
.page_top_btn,
a[href="#top"] {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
  z-index: -9999 !important;
  width: 0 !important;
  height: 0 !important;
}

/* ========================================
   ★★★ Design Consistency: Ambient Graphics ★★★
   ======================================== */

/* --- 1. WORKS: Hex/Geometric Morph (Purple/Blue) --- */
.cy-graphic-works {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

.cy-hex-morph {
  position: absolute !important;
  top: 10% !important;
  right: -10% !important;
  width: 600px !important;
  height: 600px !important;
  background: linear-gradient(135deg, rgba(120, 50, 255, 0.15), rgba(0, 50, 255, 0.1)) !important;
  border-radius: 30% 70% 70% 30% / 30% 30% 70% 70% !important;
  filter: blur(80px) !important;
  animation: hexMorph 12s infinite alternate ease-in-out !important;
  opacity: 0.6 !important;
}

@keyframes hexMorph {
  0% {
    border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
    transform: rotate(0deg) scale(1);
    background: linear-gradient(135deg, rgba(120, 50, 255, 0.15), rgba(0, 50, 255, 0.1));
  }

  50% {
    border-radius: 50% 50% 30% 70% / 50% 50% 60% 40%;
    transform: rotate(180deg) scale(1.1);
    background: linear-gradient(135deg, rgba(0, 150, 255, 0.15), rgba(120, 50, 255, 0.1));
  }

  100% {
    border-radius: 70% 30% 30% 70% / 60% 40% 30% 70%;
    transform: rotate(360deg) scale(1);
    background: linear-gradient(135deg, rgba(120, 50, 255, 0.15), rgba(0, 50, 255, 0.1));
  }
}

/* --- 2. NEWS: Grid Pulse (White/Cyan) --- */
.cy-graphic-news {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

.cy-grid-pulse {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 100% !important;
  height: 100% !important;
  background-image:
    linear-gradient(rgba(0, 229, 255, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 229, 255, 0.05) 1px, transparent 1px) !important;
  background-size: 40px 40px !important;
  mask-image: radial-gradient(circle at center, black 0%, transparent 70%) !important;
  -webkit-mask-image: radial-gradient(circle at center, black 0%, transparent 70%) !important;
  opacity: 0.6 !important;
  animation: gridPulse 8s infinite ease-in-out !important;
}

@keyframes gridPulse {

  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.4;
  }

  50% {
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0.7;
  }
}

/* --- Ensure Content Stacking --- */
.cy-works-grid,
.cy-news-grid,
.cy-section-header,
.cy-works-more {
  position: relative !important;
  z-index: 2 !important;
}

/* ========================================
   アーカイブ・カテゴリページ修正 (Archive Fix)
   ======================================== */
/* アーカイブタイトル（カテゴリ名など） */
.archive-header,
.category-header {
  margin: 4em 0 3em !important;
  padding-bottom: 2em !important;
  border-bottom: 1px solid var(--cy-border) !important;
  text-align: center !important;
  position: relative;
}

/* タイトル装飾 */
.archive-title,
.category-title {
  color: #fff !important;
  font-family: var(--cy-font-display) !important;
  font-size: 2.2rem !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  text-shadow: 0 0 20px rgba(0, 229, 255, 0.4) !important;
  margin-bottom: 0.5em !important;
  display: inline-block;
}

/* パンくずリスト */
.breadcrumb {
  background: transparent !important;
  border: none !important;
  color: var(--cy-muted) !important;
  font-size: 0.9em !important;
  margin: 1em 0 2em !important;
  font-family: var(--cy-font-display) !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}

.breadcrumb-home {
  margin-right: 0.5em;
}

.breadcrumb a {
  color: var(--cy-cyan) !important;
  text-decoration: none !important;
}

.breadcrumb .sp {
  margin: 0 0.5em;
  color: var(--cy-purple) !important;
}

/* メインコンテンツ幅調整 */
body.archive .content,
body.category .content,
body.archive .main,
body.category .main {
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
  background: transparent !important;
}

/* サイドバー非表示 (グリッドを目立たせるため) - 必要に応じて調整 */
body.archive .sidebar,
body.category .sidebar {
  display: none !important;
}

/* ========================================
   アーカイブ・カテゴリページ修正 (Global Fix)
   ======================================== */

/* リストコンテナ: グリッドレイアウト強制 */
body.archive .list,
body.category .list,
body.archive .ect-tile-card,
body.category .ect-tile-card {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important;
  gap: 30px !important;
  height: auto !important;
  /* Masonry高さ0対策 */
}

/* スマホは1カラム */
@media screen and (max-width: 575px) {

  body.archive .list,
  body.category .list,
  body.archive .ect-tile-card,
  body.category .ect-tile-card {
    grid-template-columns: 1fr !important;
  }
}

/* カードラッパー: Masonry無効化 & 表示強制 */
body.archive .entry-card-wrap,
body.category .entry-card-wrap,
body.archive .list .a-wrap,
body.category .list .a-wrap {
  display: flex !important;
  flex-direction: column !important;
  background: var(--cy-card) !important;
  border: 1px solid var(--cy-border) !important;
  border-radius: var(--cy-radius) !important;
  overflow: hidden !important;

  /* Masonry対策 */
  position: relative !important;
  top: auto !important;
  left: auto !important;
  width: 100% !important;
  height: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
  margin-bottom: 0 !important;
}

/* 内部のarticleタグ: 高さ崩れ防止 (最重要) */
body.archive .entry-card,
body.category .entry-card,
body.archive .list .entry-card,
body.category .list .entry-card {
  height: auto !important;
  min-height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
}


body.archive .entry-card-wrap:hover,
body.category .entry-card-wrap:hover {
  border-color: var(--cy-border-hover) !important;
  box-shadow: 0 8px 40px rgba(0, 229, 255, 0.12) !important;
  transform: translateY(-6px) !important;
}

/* サムネイル */
body.archive .entry-card-thumb,
body.category .entry-card-thumb {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  aspect-ratio: 16/9 !important;
  overflow: hidden !important;
}

body.archive .entry-card-thumb img,
body.category .entry-card-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.6s var(--cy-ease) !important;
}

body.archive .entry-card-wrap:hover .entry-card-thumb img,
body.category .entry-card-wrap:hover .entry-card-thumb img {
  transform: scale(1.1) !important;
}

/* テキストエリア */
body.archive .entry-card-content,
body.category .entry-card-content {
  margin: 0 !important;
  padding: 1.5em !important;
  width: 100% !important;
  float: none !important;
  flex-grow: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  background: transparent !important;
}

/* タイトル */
body.archive .entry-card-title,
body.category .entry-card-title {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--cy-text-bright) !important;
  margin-bottom: 0.8em !important;
  line-height: 1.4 !important;
}

/* スニペット */
body.archive .entry-card-snippet,
body.category .entry-card-snippet {
  font-size: 0.85rem !important;
  color: var(--cy-muted) !important;
  margin-bottom: auto !important;
  /* これで日付などを下に押しやる */
  line-height: 1.6 !important;
}

/* メタ情報 (日付など) */
body.archive .entry-card-meta,
body.category .entry-card-meta {
  margin-top: 1em !important;
  font-size: 0.8em !important;
  color: var(--cy-muted) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

/* デフォルトのアーカイブタイトルを非表示 (重複防止) */
.archive-title {
  display: none !important;
}

/* ========================================
   ★★★ Worksセクション（階層表示） ★★★
   ======================================== */
.cy-works-container {
  display: flex;
  flex-direction: column;
  gap: 60px;
}

.cy-works-group {
  position: relative;
}

/* 親カテゴリタイトル */
.cy-works-group-title {
  font-size: 1.8rem;
  font-family: var(--cy-font-display);
  color: var(--cy-cyan);
  margin-bottom: 24px;
  padding-left: 16px;
  border-left: 4px solid var(--cy-purple);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  position: relative;
}

.cy-works-group-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, var(--cy-border), transparent);
  transform: translateY(8px);
}

/* 子カテゴリグリッド */
.cy-works-sub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}

/* カード調整（既存のスタイルを微調整） */
.cy-work-card {
  aspect-ratio: 16/9;
  border-radius: var(--cy-radius);
  overflow: hidden;
  position: relative;
  border: 1px solid var(--cy-border);
  transition: all 0.3s var(--cy-ease);
}

.cy-work-card:hover {
  transform: translateY(-4px);
  border-color: var(--cy-cyan);
  box-shadow: 0 4px 20px rgba(0, 229, 255, 0.2);
}

.cy-work-card-inner {
  width: 100%;
  height: 100%;
  position: relative;
}

.cy-work-img-layer {
  width: 100%;
  height: 100%;
}

.cy-work-img-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--cy-ease);
}

.cy-work-card:hover .cy-work-img-layer img {
  transform: scale(1.1);
}

.cy-work-text-layer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 16px;
  background: linear-gradient(to top, rgba(3, 3, 8, 0.9), transparent);
  display: flex;
  align-items: flex-end;
}

.cy-work-title-pill {
  background: rgba(0, 0, 0, 0.6);
  border: 1px solid var(--cy-cyan);
  color: var(--cy-cyan);
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 0.9rem;
  backdrop-filter: blur(4px);
}

@media screen and (max-width: 767px) {
  .cy-works-sub-grid {
    grid-template-columns: 1fr;
  }
}

/* ========================================
   アーカイブ・カテゴリページでのおすすめカード非表示
   ======================================== */
body.archive .recommended,
body.category .recommended {
  display: none !important;
}
/* ========================================
   iPhone表示不具合対策(.article透明化回避)
   ======================================== */
@media (max-width: 1024px) {
  .article.cy-fade-up {
    opacity: 1 !important;
    transform: none !important;
  }
}
