/* style.css */
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c&family=Noto+Sans+JP:wght@100..900&display=swap');
body {
  margin: 0;
  font-family: 'Noto Sans JP', 'M PLUS Rounded 1c',sans-serif;
  background-color: #0a0a0a;
  color: #ffffff;
}

header {
  background: linear-gradient(90deg, #00d0ff, #004466);
  padding: 60px 20px;
  text-align: center;
  color: #fff;
}

header h1 {
  margin: 0;
  font-size: 3em;
  letter-spacing: 2px;
}

header p {
  font-size: 1.2em;
  margin: 10px 0 20px 0;
}

.buttons {
  margin-top: 20px;
}

.btn {
  text-decoration: none;
  background-color: #00cfff;
  color: #000;
  padding: 12px 30px;
  margin: 0 10px;
  border-radius: 25px;
  font-weight: bold;
  transition: 0.3s;
}

.btn:hover {
  background-color: #0099cc;
  color: #fff;
}

main {
  padding: 50px 20px;
}

section {
  margin-bottom: 50px;
}

section h2 {
  color: #00cfff;
  margin-bottom: 20px;
  border-bottom: 2px solid #00cfff;
  display: inline-block;
  padding-bottom: 5px;
}

pre {
  background-color: #111;
  padding: 15px;
  border-radius: 10px;
  overflow-x: auto;
}

footer {
  background-color: #111;
  text-align: center;
  padding: 20px;
  color: #888;
}

footer a {
  color: #00cfff;
  text-decoration: none;
}

footer a:hover {
  text-decoration: underline;
}

.code-tabs { margin-top: 20px; }
.tab-buttons { margin-bottom: 10px; }
.tab-btn {
  background: #00cfff;
  border: none;
  color: #000;
  padding: 8px 18px;
  margin-right: 8px;
  border-radius: 5px;
  cursor: pointer;
  font-weight: bold;
}
.tab-btn.active {
  background: #0099cc;
  color: #fff;
}
.code-content { display: none; }
.code-content.active { display: block; }

/* スマホ対応（画面幅600px以下） */
@media (max-width: 600px) {

  header {
    padding: 35px 15px;
  }

  header h1 {
    font-size: 1.8em !important;   /* 明確に小さくする */
    line-height: 1.2;
    letter-spacing: 1px;           /* スマホでは詰める */
    word-break: break-word;        /* 強制改行許可 */
    overflow-wrap: break-word;     /* 横にはみ出さない */
    white-space: normal;           /* 折り返し有効化 */
    text-align: center;
  }

  header p {
    font-size: 1em;
  }

  /* ボタンを縦並びにする */
  .buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }

  .btn {
    width: 85%;
    margin: 0;
    padding: 14px 10px;
    text-align: center;
    font-size: 1em;
  }

  main {
    padding: 25px 15px;
  }

  section h2 {
    font-size: 1.4em;
  }

  /* コードブロックをスマホ向けに調整 */
  pre {
    font-size: 0.9em;
    padding: 12px;
    white-space: pre-wrap; /* スマホでは折り返す */
    word-wrap: break-word;
  }
}

/* ==== CHANGELOG 用スタイル ==== */

.changelog {
  max-width: 900px;
  margin: 0 auto;
}

.version-block {
  background: #111;
  padding: 20px;
  border-left: 5px solid #00cfff;
  border-radius: 8px;
  margin-bottom: 25px;
}

.version-title {
  font-size: 1.6em;
  color: #00cfff;
  margin: 0 0 10px 0;
}

.version-date {
  font-size: 0.9em;
  color: #999;
  margin-bottom: 15px;
}

.change-list {
  list-style: none;
  padding-left: 0;
}

.change-list li {
  padding: 6px 0;
  border-bottom: 1px solid #222;
}

.change-list li:last-child {
  border-bottom: none;
}

/* 種類ごとの色付け */
.tag-added {
  color: #00ffea; /* 水色寄りの緑 */
  font-weight: bold;
}

.tag-fixed {
  color: #ffdd55;
  font-weight: bold;
}

.tag-changed {
  color: #ff8844;
  font-weight: bold;
}

/* スマホ対応 */
@media (max-width: 600px) {
  .version-block {
    padding: 15px;
  }

  .version-title {
    font-size: 1.3em;
  }
}