/* =========================================
   Migrated from index.php
   ========================================= */

/* --- 余白を極限まで削ったスイッチボタン --- */
.fitted-switch-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0px;
  width: auto;
  height: auto;
  background-color: var(--overlay-fade);
  border: 1px solid var(--line-gold);
  border-radius: 8px;
  padding: 1px 2px;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
  -webkit-tap-highlight-color: transparent;
  backdrop-filter: blur(4px);
}

.fitted-switch-btn:hover {
  background-color: rgba(245,184,0,0.12);
  border-color: var(--gold);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

.fitted-switch-btn.is-active {
  border-color: var(--gold);
  background-color: rgba(245,184,0,0.18);
}

/* --- アイコン部分 --- */
.bookmark-icon {
  width: 20px;
  height: 20px;
  stroke: #9ca3af;
  stroke-width: 2;
  fill: transparent;
  transition: all 0.3s ease;
  display: block;
}

.fitted-switch-btn.is-active .bookmark-icon {
  stroke: #f97316;
  fill: #f97316;
}

@keyframes pop {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.4);
  }

  100% {
    transform: scale(1);
  }
}

.animate-pop .bookmark-icon {
  animation: pop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

/* --- ラベルテキスト部分 --- */
.label-text {
  font-size: 9px;
  font-weight: 800;
  color: #9ca3af;
  user-select: none;
  line-height: 1;
  margin: 0px 0;
}

.fitted-switch-btn.is-active .label-text {
  color: #f97316;
}

/* --- スイッチ部分 --- */
.toggle-switch {
  position: relative;
  width: 24px;
  height: 14px;
  background-color: #e5e7eb;
  border-radius: 99px;
  transition: background-color 0.3s ease;
}

.toggle-switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 10px;
  height: 10px;
  background-color: white;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s cubic-bezier(0.4, 0.0, 0.2, 1);
}

.fitted-switch-btn.is-active .toggle-switch {
  inset: -4px;
  border: 2px solid #ffffaa;
  pointer-events: none;
  box-shadow: 0 0 10px #ffd700;
}

/* ===== Message Text ===== */
.message-text {
  width: 100%;
  line-height: 1.4;
  font-family: 'DotGothic16', sans-serif;
  font-size: clamp(1.2rem, 4vw, 4rem);
  text-align: left;
  /* Shadow for readability */
  text-shadow: 2px 2px 0 var(--text-shadow), 0 0 5px rgba(255, 215, 0, .4);
  color: var(--text-main);
}

/* Highlight Text (Red) */
.highlight {
  color: #ff0000;
  font-size: 1.3em;
  text-shadow:
    2px 2px 0 var(--text-shadow),
    0 0 10px #ff0000;
  font-weight: bold;
}

/* Blink Cursor */
.cursor {
  display: inline-block;
  margin-right: .3em;
  animation: blink .8s step-end infinite;
  color: var(--text-main);
}
.cursor-pixel svg {
  display: inline-block;
  width: 0.85em;
  height: 1.1em;
  vertical-align: -0.12em;
  image-rendering: pixelated;
  filter: drop-shadow(1px 1px 0 rgba(0,0,0,0.35));
}

@keyframes blink {
  50% {
    opacity: 0;
  }
}

/* ボタンアニメーション */
@keyframes btnPush {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(0.90);
  }

  100% {
    transform: scale(1);
  }
}

.btn-push {
  animation: btnPush 0.2s ease-out;
}
/* ============================================================
   DARK THEME FORCE OVERRIDES （最終ブロック）
   Tailwind / WordPress block styles より後に記述して強制上書き
   ============================================================ */

html, body { background-color: var(--bg-body) !important; color: var(--text-main) !important; }

.container {
  background-color: var(--bg-card) !important;
  color: var(--text-main) !important;
  border: 1px solid rgba(245,184,0,0.18) !important;
}

article.post, article.type-machine, article.type-post, article.type-page {
  background: transparent !important;
  color: var(--text-main) !important;
}

.entry-content,
.wp-block-group, .wp-block-columns, .wp-block-column,
.wp-block-cover, .wp-block-group__inner-container,
.is-layout-flow, .is-layout-constrained {
  background: transparent !important;
  color: var(--text-main) !important;
}

.bg-white { background-color: var(--bg-card) !important; color: var(--text-main) !important; }
.bg-gray-50, .bg-gray-100 { background-color: var(--bg-card-hi) !important; color: var(--text-main) !important; }
.bg-blue-50, .bg-orange-50, .bg-yellow-50 { background-color: var(--bg-card-hi) !important; }

.text-gray-600, .text-gray-700, .text-gray-800, .text-gray-900,
.text-blue-900, .text-orange-900, .text-slate-600 { color: var(--text-light) !important; }

.border-gray-100, .border-gray-200, .border-gray-300 { border-color: rgba(245,184,0,0.18) !important; }

.entry-content table,
.wp-block-table table,
.wp-block-table figure table { background: transparent !important; color: var(--text-main) !important; border-color: rgba(245,184,0,0.2) !important; }

.entry-content tr,
.entry-content tbody,
.wp-block-table tr,
.wp-block-table tbody { background: transparent !important; }

.entry-content th,
.wp-block-table th { background: rgba(245,184,0,0.1) !important; color: #f5b800 !important; border-color: rgba(245,184,0,0.25) !important; }

.entry-content td,
.wp-block-table td { background: transparent !important; color: var(--text-main) !important; border-color: rgba(245,184,0,0.15) !important; }

.entry-content tr:nth-child(even) td,
.wp-block-table tr:nth-child(even) td { background: rgba(127,127,127,0.05) !important; }

/* テーブルヘッダーの色付きセル（インライン背景色）も暗くする */
.entry-content td[style*="background"],
.wp-block-table td[style*="background"] { filter: brightness(0.7) saturate(1.3); }

.entry-content blockquote {
  border-left: 4px solid rgba(245,184,0,0.5);
  background: rgba(245,184,0,0.06);
  color: var(--text-light);
  padding: 1rem 1.2rem;
  margin: 1.2rem 0;
}
.entry-content pre, .entry-content code {
  background: var(--bg-white) !important;
  color: #45e2ff !important;
  border: 1px solid rgba(69,226,255,0.2);
}

/* h1 白背景強制リセット */
h1 { background: transparent !important; background-image: none !important; }

/* ===== Easy Table of Contents プラグイン ダーク化 ===== */
.ez-toc-container,
div#ez-toc-container,
div[id^="ez-toc-container"] {
  background: var(--bg-card) !important;
  border: 1px solid rgba(245,184,0,0.25) !important;
  border-radius: 6px !important;
  color: var(--text-main) !important;
  padding: 10px 16px !important;
}
.ez-toc-title-container,
.ez-toc-title {
  color: #f5b800 !important;
  background: transparent !important;
  border-bottom: 1px solid rgba(245,184,0,0.2) !important;
  padding-bottom: 6px !important;
  margin-bottom: 6px !important;
}
.ez-toc-list,
.ez-toc-list li {
  background: transparent !important;
  color: var(--text-main) !important;
}
.ez-toc-list a,
.ez-toc-link {
  color: var(--text-main) !important;
  background: transparent !important;
}
.ez-toc-list a:hover,
.ez-toc-link:hover {
  color: #f5b800 !important;
  text-decoration: underline !important;
}
a.ez-toc-toggle,
.ez-toc-toggle {
  color: #f5b800 !important;
  background: transparent !important;
  border: 1px solid rgba(245,184,0,0.35) !important;
  border-radius: 3px !important;
  padding: 1px 7px !important;
  text-decoration: none !important;
}
a.ez-toc-toggle:hover,
.ez-toc-toggle:hover {
  background: rgba(245,184,0,0.12) !important;
}
.ez-toc-toggle svg,
a.ez-toc-toggle svg {
  fill: #f5b800 !important;
}
.ez-toc-list-level-2 a { color: var(--text-light) !important; }
.ez-toc-list-level-2 a:hover { color: #f5b800 !important; }

/* ライトモード時のTOC可読性強化（サブリンクは黒で表示） */
:root[data-theme="light"] .ez-toc-list-level-2 a,
:root[data-theme="light"] .ez-toc-list-level-3 a,
:root[data-theme="light"] .ez-toc-list-level-4 a,
:root[data-theme="light"] #toc_container ul li ul li a,
:root[data-theme="light"] #toc_container ul li ul li ul li a {
  color: var(--text-main) !important;
}

/* ===== Table of Contents Plus（TOC+）プラグイン ダーク化 ===== */
#toc_container {
  background: var(--bg-card) !important;
  border: 1px solid rgba(245,184,0,0.25) !important;
  border-radius: 6px !important;
  padding: 10px 16px !important;
  color: var(--text-main) !important;
}
#toc_container p.toc_title {
  color: #f5b800 !important;
  background: transparent !important;
  border-bottom: 1px solid rgba(245,184,0,0.2) !important;
  padding-bottom: 4px !important;
}
#toc_container p.toc_title a,
#toc_container .toc_toggle {
  color: #f5b800 !important;
  border: 1px solid rgba(245,184,0,0.35) !important;
  border-radius: 3px !important;
  padding: 0 6px !important;
  text-decoration: none !important;
}
#toc_container ul,
#toc_container ul li {
  background: transparent !important;
}
#toc_container ul li a {
  color: var(--text-main) !important;
}
#toc_container ul li a:hover {
  color: #f5b800 !important;
  text-decoration: underline !important;
}
#toc_container ul li ul li a {
  color: var(--text-light) !important;
}
#toc_container ul li ul li a:hover {
  color: #f5b800 !important;
}

