/**
 * WordPress CSS
 * WordPress専用スタイル - 投稿本文、Gutenberg、エディター対応
 * 高橋運輸興業 Webサイトリニューアル
 *
 * このファイルはWordPress化の際に必要となるスタイルを定義します。
 * 管理画面からの編集に対応したクラス設計になっています。
 */

/* ===================================
   WordPress投稿本文コンテナ
   管理画面から入力されたコンテンツ用
   =================================== */

/* メインコンテナ */
.wp-content {
  line-height: var(--leading-loose);
  font-size: var(--text-base);
  color: var(--text-primary);
}

/* ===================================
   見出しスタイル
   =================================== */

/*
 * 見出し階層設計:
 * 記事タイトル（.blog-article-title）: 1.8rem, 濃い青
 * H2: 1.4rem, 濃い青, 背景なし, 下線あり
 * H3: 1.2rem, 濃い青, 装飾なし
 * H4: 1.1rem, やや薄い色
 * H5/H6: 1rem, さらに薄い色
 */

.wp-content h2 {
  color: var(--heading-primary);
  font-size: 1.4rem;
  font-weight: 700;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 3px solid var(--primary-blue);
}

.wp-content h3 {
  color: var(--heading-primary);
  font-size: 1.2rem;
  font-weight: 600;
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

.wp-content h4 {
  color: var(--heading-secondary);
  font-size: 1.1rem;
  font-weight: 600;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

.wp-content h5 {
  color: var(--text-secondary);
  font-size: 1rem;
  font-weight: 600;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

.wp-content h6 {
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-weight: 600;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

/* ===================================
   段落・テキスト
   =================================== */

.wp-content p {
  margin-bottom: 1rem;
  line-height: var(--leading-loose);
}

.wp-content p:last-child {
  margin-bottom: 0;
}

.wp-content strong {
  font-weight: 600;
  color: var(--heading-secondary);
}

.wp-content em {
  font-style: italic;
}

.wp-content small {
  font-size: 0.9em;
}

/* ===================================
   リスト
   =================================== */

.wp-content ul,
.wp-content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
  line-height: var(--leading-loose);
}

.wp-content li {
  margin-bottom: 0.5rem;
}

.wp-content ul li {
  list-style-type: disc;
}

.wp-content ol li {
  list-style-type: decimal;
}

.wp-content ul ul,
.wp-content ol ol,
.wp-content ul ol,
.wp-content ol ul {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

/* ===================================
   リンク
   =================================== */

.wp-content a:not(.wp-block-button__link) {
  color: var(--secondary-blue);
  text-decoration: underline;
  transition: color var(--transition-fast);
}

.wp-content a:not(.wp-block-button__link):hover,
.wp-content a:not(.wp-block-button__link):visited:hover {
  color: var(--primary-blue);
  opacity: 1;
}

.wp-content a:not(.wp-block-button__link):visited {
  color: var(--secondary-blue);
}

/* ===================================
   画像
   =================================== */

.wp-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--border-radius);
  margin: 1.5rem 0;
  box-shadow: var(--shadow);
}

/* 画像配置クラス（WordPress標準） */
.wp-content .alignleft {
  float: left;
  margin: 0.5rem 1.5rem 1rem 0;
}

.wp-content .alignright {
  float: right;
  margin: 0.5rem 0 1rem 1.5rem;
}

.wp-content .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
  clear: both;
}

.wp-content .alignnone {
  margin: 1.5rem 0;
}

/* 画像キャプション */
.wp-content .wp-caption {
  margin: 1.5rem 0;
  max-width: 100%;
}

.wp-content .wp-caption-text {
  margin-top: 0.5rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
  text-align: center;
}

/* ===================================
   テーブル
   =================================== */

.wp-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5rem;
}

.wp-content th {
  background: var(--light-blue);
  color: var(--heading-primary);
  padding: 0.75rem;
  text-align: left;
  font-weight: 600;
  border: 1px solid var(--border-color);
}

.wp-content td {
  padding: 0.75rem;
  border: 1px solid var(--border-color);
}

.wp-content tbody tr:nth-child(even) {
  background: #f9f9f9;
}

/* ===================================
   引用
   =================================== */

.wp-content blockquote {
  background: var(--light-blue);
  border-left: 4px solid var(--secondary-blue);
  padding: 1rem 1.5rem;
  margin: 1.5rem 0;
  font-style: italic;
}

.wp-content blockquote p:last-child {
  margin-bottom: 0;
}

.wp-content cite {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
  text-align: right;
}

/* ===================================
   コード
   =================================== */

.wp-content code {
  background: #f4f4f4;
  padding: 0.2rem 0.4rem;
  border-radius: 3px;
  font-family: 'Courier New', monospace;
  font-size: 0.9em;
}

.wp-content pre {
  background: #f4f4f4;
  padding: 1rem;
  border-radius: var(--border-radius);
  overflow-x: auto;
  margin-bottom: 1.5rem;
}

.wp-content pre code {
  background: transparent;
  padding: 0;
  font-size: 0.9rem;
}

/* ===================================
   区切り線
   =================================== */

.wp-content hr {
  border: 0;
  height: 1px;
  background: var(--border-color);
  margin: 2rem 0;
}

/* ===================================
   WordPress ニュース記事専用
   =================================== */

/* ニュース記事ヘッダー */
.news-article-header {
  background: var(--light-blue);
  padding: 2rem;
  border-radius: var(--border-radius-lg);
  margin-bottom: 2rem;
}

.news-article-title {
  color: var(--heading-primary);
  font-size: 2rem;
  margin-bottom: 1rem;
  line-height: 1.4;
}

.news-article-meta {
  display: flex;
  gap: 1.5rem;
  color: var(--text-secondary);
  font-size: 0.9rem;
  flex-wrap: wrap;
}

.news-article-date {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.news-article-category {
  display: inline-block;
  background: var(--secondary-blue);
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: var(--border-radius);
  font-size: 0.85rem;
}

/* ニュース記事本文（wp-contentクラスと併用） */
.news-article-content {
  /* wp-contentクラスのスタイルを継承 */
}

/* ===================================
   WordPress Gutenbergブロック対応
   =================================== */

/* ボタンブロック - サイト標準(.btn-primary)に準拠 */
.wp-block-button__link {
  display: inline-block;
  background: var(--accent-red);
  color: white;
  padding: 0.8rem 2rem;
  border-radius: var(--border-radius);
  text-decoration: none;
  font-weight: 500;
  transition: all var(--transition);
}

.wp-block-button__link:hover {
  background: #d91d33;
  transform: translateY(-2px);
}

/* アウトラインボタン */
.is-style-outline .wp-block-button__link {
  background: transparent;
  border: 2px solid var(--accent-red);
  color: var(--accent-red);
}

.is-style-outline .wp-block-button__link:hover {
  background: var(--accent-red);
  color: white;
}

/* カラムブロック */
.wp-block-columns {
  display: flex;
  gap: 2rem;
  margin-bottom: 2rem;
}

.wp-block-column {
  flex: 1;
}

/* グループブロック */
.wp-block-group {
  padding: 2rem;
  margin-bottom: 2rem;
}

.wp-block-group.has-background {
  border-radius: var(--border-radius-lg);
}

/* メディア&テキストブロック */
.wp-block-media-text {
  display: flex;
  align-items: center;
  gap: 2rem;
  margin-bottom: 2rem;
}

.wp-block-media-text__media {
  flex: 1;
}

.wp-block-media-text__content {
  flex: 1;
}

/* カバーブロック */
.wp-block-cover {
  position: relative;
  padding: 4rem 2rem;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  background-size: cover;
  background-position: center;
  border-radius: var(--border-radius-lg);
}

.wp-block-cover__inner-container {
  position: relative;
  z-index: 1;
  color: white;
  text-align: center;
  max-width: 800px;
}

/* ギャラリーブロック */
.wp-block-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.wp-block-gallery .wp-block-image {
  margin: 0;
}

/* 引用ブロック */
.wp-block-quote {
  border-left: 4px solid var(--secondary-blue);
  padding-left: 1.5rem;
  margin: 2rem 0;
  font-style: italic;
}

.wp-block-quote cite {
  display: block;
  margin-top: 1rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

/* セパレーターブロック */
.wp-block-separator {
  border: 0;
  height: 2px;
  background: var(--border-color);
  margin: 2rem 0;
}

.wp-block-separator.is-style-wide {
  width: 100%;
}

.wp-block-separator.is-style-dots {
  background: none;
  text-align: center;
  height: auto;
}

.wp-block-separator.is-style-dots::before {
  content: "···";
  font-size: 2rem;
  letter-spacing: 1rem;
  color: var(--text-secondary);
}

/* ===================================
   エディタースタイル
   管理画面のエディターで使用
   =================================== */

.editor-styles-wrapper {
  font-family: var(--font-family-base);
  color: var(--text-primary);
  line-height: var(--leading-loose);
}

.editor-styles-wrapper h1,
.editor-styles-wrapper h2,
.editor-styles-wrapper h3,
.editor-styles-wrapper h4,
.editor-styles-wrapper h5,
.editor-styles-wrapper h6 {
  color: var(--heading-primary);
}

.editor-styles-wrapper a {
  color: var(--secondary-blue);
}

/* ===================================
   WordPress管理バー対応
   =================================== */

/* 管理バー表示時のヘッダー位置調整 */
.admin-bar .main-header {
  top: 32px;
}

@media (max-width: 782px) {
  /* モバイル時の管理バーは高さ46px */
  .admin-bar .main-header {
    top: 46px;
  }
}

/* 管理バー表示時のモバイルメニュー位置調整 */
@media (max-width: 768px) {
  .admin-bar .main-nav.active {
    top: calc(61px + 46px);
    max-height: calc(100vh - 61px - 46px);
  }
}

/* ===================================
   レスポンシブ対応
   =================================== */

@media (max-width: 768px) {
  /* カラムブロック */
  .wp-block-columns {
    flex-direction: column;
  }

  /* メディア&テキストブロック */
  .wp-block-media-text {
    flex-direction: column;
  }

  /* ギャラリー */
  .wp-block-gallery {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  }

  /* テーブル */
  .wp-content table {
    font-size: 0.9rem;
  }

  .wp-content th,
  .wp-content td {
    padding: 0.5rem;
  }

  /* 画像配置 */
  .wp-content .alignleft,
  .wp-content .alignright {
    float: none;
    display: block;
    margin: 1rem auto;
  }
}