/*------------------------------------*\
  #BASE STYLES
\*------------------------------------*/

:root {
  --primary-color: #007BFF;
  --primary-hover-color: #0056b3;
  --background-color: #f4f4f4;
  --card-background-color: #ffffff;
  --text-color-dark: #333;
  --text-color-medium: #555;
  --text-color-light: #777;
  --border-color-light: #eee;
  --error-color: #dc3545;
  --error-background-color: #ffe0e6;

  --spacing-small: 10px;
  --spacing-medium: 20px;
  --spacing-large: 35px;

  --border-radius-default: 8px;
  --box-shadow-small: 0 2px 10px rgba(0, 0, 0, 0.1);
  --box-shadow-medium: 0 4px 12px rgba(0, 0, 0, 0.08);
}

body {
  font-family: Arial, sans-serif;
  margin: 0 auto;
  padding: 0;
  background-color: var(--background-color);
  line-height: 1.6; /* 全体的な行の高さを設定 */
}

/*------------------------------------*\
  #LAYOUT
\*------------------------------------*/

main {
  max-width: 800px;
  margin: var(--spacing-medium) auto;
  padding: var(--spacing-medium);
  background-color: var(--card-background-color);
  border-radius: var(--border-radius-default);
  box-shadow: var(--box-shadow-small);
}

.box {
  display: flex;
  justify-content: space-around;
  margin-bottom: var(--spacing-large);
}

/*------------------------------------*\
  #TYPOGRAPHY
\*------------------------------------*/

h1 {
  font-size: 18px; /* 35px から変更 */
  margin: var(--spacing-medium) 0;
  text-align: center;
  color: var(--text-color-dark);
}

h2 {
  font-size: 0.875em; /* 14px から変更 */
  margin: 1em 0; /* em に統一 */
  text-align: center;
  color: var(--text-color-medium);
}

/* 意味的なタグへの直接スタイルは避けるか、クラスを推奨 */
em {
  font-size: 18px; /* h1 と同様のサイズに */
  font-style: normal; /* 斜体を解除したい場合 */
  position: fixed; right: 10px; bottom: 10px;  display: flex; justify-content: center; align-items: center; z-index: auto;
}

b {
  font-size: 1.25em; /* 20px から変更 */
}

a {
  text-decoration: none;
  color: var(--primary-color);
  font-weight: bold;
  transition: color 0.2s ease-in-out;
}

a:hover {
  text-decoration: underline;
  color: var(--primary-hover-color);
}

/*------------------------------------*\
  #BUTTONS
\*------------------------------------*/

button {
  display: block;
  justify-content: center;
  align-items: center;
  text-align: center;
  background-color: var(--primary-color);
  color: white;
  border: none;
  border-radius: 5px;
  padding: 0.7em 1em; /* rem/em に変更 */
  margin: 0 auto; /* rem/em に変更 */
  cursor: pointer;
  font-size: 1.5em; /* 30px から変更 */
  transition: background-color 0.2s ease-in-out;
  width: 100%;
  height: auto;
  gap: 0;
}

button:hover {
  background-color: var(--primary-hover-color);
}

/*------------------------------------*\
  #IMAGES
\*------------------------------------*/

img {
  max-width: 100%;
  height: auto; /* 高さを固定せず、アスペクト比を保持 */
  display: block;
  margin: 0 auto var(--spacing-medium);
}

/*------------------------------------*\
  #COMPONENTS - FEED CARD
\*------------------------------------*/

.feed-card {
  background-color: var(--card-background-color);
  border-radius: var(--border-radius-default);
  box-shadow: var(--box-shadow-medium);
  width: 100%;
  
  padding: 1.5em; /* 25px から変更 */
  box-sizing: border-box;
  transition: transform 0.2s ease-in-out;
  margin-bottom: var(--spacing-medium); /* カード間の余白 */
}

.feed-card:hover {
  transform: translateY(-5px);
}

.feed-card__title {
  font-size: 1.6em;
  color: var(--text-color-dark);
  margin-top: 0;
  margin-bottom: 0.6em; /* 10px から変更 */
  line-height: 1.4;
}

.feed-card__title a {
  text-decoration: none;
  color: var(--primary-color);
  transition: color 0.2s ease-in-out;
}

.feed-card__title a:hover {
  color: var(--primary-hover-color);
  text-decoration: underline;
}

.feed-card__description {
  font-size: 0.95em;
  color: var(--text-color-medium);
  line-height: 1.6;
  margin-bottom: 1em; /* 15px から変更 */
}

.feed-card__meta {
  font-size: 0.85em;
  color: var(--text-color-light);
  border-top: 1px solid var(--border-color-light);
  padding-top: 1em; /* 15px から変更 */
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-small);
}

.feed-card__date,
.feed-card__author {
  white-space: nowrap;
}

/*------------------------------------*\
  #COMPONENTS - ERROR MESSAGE
\*------------------------------------*/

.error-message {
  color: var(--error-color);
  background-color: var(--error-background-color);
  border: 1px solid var(--error-color);
  padding: 1em; /* 15px から変更 */
  border-radius: 5px;
  text-align: center;
  max-width: 800px;
  width: 100%;
  margin: var(--spacing-medium) auto; /* 中央揃えのため追加 */
}

/*------------------------------------*\
  #MEDIA QUERIES
\*------------------------------------*/

@media (max-width: 600px) {
  main {
    margin: var(--spacing-medium) 0; /* スマホでは左右のマージンをなくす */
    padding: var(--spacing-small); /* パディングを少し減らす */
  }

  .feed-card {
    padding: 1.25em; /* 20px から変更 */
    border-radius: 0;
    box-shadow: none;
  }

  .feed-card__title {
    font-size: 1.4em;
  }

  .feed-card__description {
    font-size: 0.9em;
  }

  .feed-card__meta {
    flex-direction: column;
    align-items: flex-start;
  }
}
/*------------------------------------*\
  #COMPONENTS - PAGE TOP BUTTON
\*------------------------------------*/

.pagetop {
  /* 配置 */
  position: fixed; /* 画面に固定 */
  bottom: 20px;    /* 下から20px */
  right: 20px;     /* 右から20px */
  z-index: 1000;   /* 他の要素より手前に表示 */

  /* サイズと形状 */
  width: 50px;
  height: 50px;
  border-radius: 50%; /* 円形にする */
  display: flex; /* 中央揃えのためにflexboxを使用 */
  justify-content: center;
  align-items: center;
  cursor: pointer; /* クリック可能であることを示す */
  
  /* 色と影 */
  background-color: var(--primary-color); /* 定義済みのプライマリカラーを使用 */
  color: white;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2); /* 軽めの影 */
  
  /* アニメーション */
  transition: background-color 0.3s ease, opacity 0.3s ease, transform 0.3s ease;
  
  /* 初期状態では非表示 (JavaScriptで表示/非表示を切り替える) */
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px); /* 最初は少し下にずらしておく */
}

/* ホバー時のスタイル */
.pagetop:hover {
  background-color: var(--primary-hover-color); /* ホバー時の色 */
  transform: translateY(0) scale(1.05); /* 少し拡大するエフェクト */
}

/* JavaScriptで表示される時に付与するクラス */
.pagetop.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* ボタン内のアイコンやテキストのスタイル */
.pagetop::before {
  content: '▲'; /* 上矢印のアイコンをCSSで生成 (またはFont Awesomeなどのアイコンを使用) */
  font-size: 1.5em;
  line-height: 1; /* 行の高さを調整 */
}

/* スマートフォン向け調整 */
@media (max-width: 600px) {
  .pagetop {
    width: 45px;
    height: 45px;
    bottom: 15px;
    right: 15px;
  }

  .pagetop::before {
    font-size: 1.3em;
  }
}

/* アラート全体の背景 */
        .alert-overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0, 0, 0, 0.6);
            display: none; /* 初期状態は非表示 */
            justify-content: center;
            align-items: center;
            z-index: 9999;
        }

        /* アラートを表示する時用のクラス */
        .is-show {
            display: flex;
        }

        .alert-card {
            background: white;
            width: 320px;
            padding: 30px;
            border-radius: 15px;
            text-align: center;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
            animation: popIn 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
        }

        .alert-message {
            font-size: 16px;
            font-weight: bold;
            color: #333;
            margin-bottom: 20px;
        }

        .alert-button {
            background-color: #28a745; /* 確認用なので緑色にしてみました */
            color: white;
            border: none;
            padding: 12px 30px;
            border-radius: 25px;
            font-weight: bold;
            cursor: pointer;
            transition: transform 0.2s;
        }

        .alert-button:hover {
            transform: scale(1.05);
            background-color: #218838;
        }

        @keyframes popIn {
            0% { opacity: 0; transform: scale(0.5); }
            100% { opacity: 1; transform: scale(1); }
        }