/*■■■フォント■■■ */
@font-face {
  font-family: 'font-title';
  src: url('font.ttf');
}

/* ■■■ カラーテーマ■■■ */
:root {
  --main-color: #ACF523;
  --main-dark: #60E6A5;
  --sub-color: #F5EC23;
  --bg-color:  #1a1a1a;
  --text-color: #ffffff;
}

/* ■■■トップページ■■■ */
body {
  background-color: var(--bg-color);
  background-image: url('background.png');
  color: var(--text-color);
  font-family: sans-serif;
  text-align: center;
  margin: 0;
  padding: 50px 20px;
}

.cat-card {
  background: #333;
  border: 3px solid var(--main-color);
  border-radius: 15px;
  padding: 0px;
  width: 300px;
  text-decoration: none;
  color: var(--text-color) ;
  transition: transform 0.3s;
}


.cat-card:hover {
  transform: scale(1.05);
  border: 3px solid var(--main-dark);
  color: var(--sub-color) ;
}

.cat-card img {
  width: 100%;
  border-radius: 10px;
  vertical-align:  bottom;
}


.game-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px;
  margin-top: 50px;
  max-width: 100%;
}

.game-card {
  background: #333;
  border: 3px solid var(--main-color);
  border-radius: 15px;
  padding: 10px;
  width: 400px;
  text-decoration: none;
  color: var(--text-color) ;
  transition: transform 0.3s;
  max-width: 100%;
}

.game-card:hover {
  transform: scale(1.05);
  border: 3px solid var(--main-dark);
  color: var(--sub-color) ;
}

.game-card img {
  width: 100%;
  border-radius: 10px;
}

.title-zone {
  font-family: "font-title" ;
  font-size: 1em;
  color: var(--sub-color);
  margin: auto;
  max-width: 500px;
  width: 50%;
}

.title {
  font-size: 4em;
  text-shadow: 0 0 5px #000000, 0 0 10px var(--sub-color),
   0 0 15px var(--sub-color), 0 0 20px var(--main-color),
   0 0 30px var(--main-color), 0 0 40px var(--main-color),
   0 0 50px var(--main-color), 0 0 70px var(--main-color);
}

.title-add-pre {
  font-size: 1.5em;
  color: var(--main-dark);
  text-align: left;
}

.title-add-post {
  font-size: 1.5em;
  color: var(--main-dark);
  text-align: right;
}

.counter {
  font-family: "font-title";
  font-size: 1em;
  color: var(--sub-color);
  margin: 40px;
}

.countno {
  color: var(--main-color);
}

/* ■■■ゲームページ■■■ */
.container {
  max-width: 900px;
  margin: 0 auto;
  text-align: left;
  padding-bottom: 100px;
}

nav a{
  color: var(--main-color);
  text-decoration: none;
  font-weight: bold;
}

.game-header {
  text-align: center;
  margin-top: 30px;
}

.main-visual {
  width: 100%;
  border-radius: 20px;
  box-shadow: 0 10px 30px rgba(255, 105, 180, 0.3);
  margin-bottom: 20px;
}

.game-info{
  display: flex;
  gap: 40px;
  margin-top: 40px;
}

.description, .screenshot {
  flex: 1;
}

.ss-img {
  width: 100%;
  border: 2px solid #444;
  border-radius: 10px;
}

.btn-play {
  display: inline-block;
  background: var(--main-color);
  color: black;
  padding: 15px 30px;
  border-radius: 50px;
  text-decoration: none;
  font-weight:  bold;
  font-size: 1.2rem;
  margin-top: 20px;
  box-shadow: 0 5px 15px rgba(255,105, 180, 0.4);
}

.btn-play:hover {
  background: var(--main-dark);
  transform: translateY(-2px);
}

.spec-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
}

.spec-table th, .spec-table td{
  border-bottom:  1px solid #444;
  padding: 15px;
}

.spec-table th {
  width: 30%;
  color: var(--main-color);
}

.game-title {
  color: var(--sub-color);
}

.screenshot-area {
  width: calc(33.333% - 10px);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content:  center;
}

.ss-img-multi {
  width: calc(33.333% - 10px);
  min-width: 250px;
  border-radius: 10px;
  border: 2px solid var(--main-color);
}

/* ■■■ブログバナー■■■ */
.blog-banner {
  background: linear-gradient(135deg, #333 0%, #444 100%);
  border-top: 3px solid var(--main-color);
  border-bottom: 3px solid var(--main-color);
  margin: 20px 0;
  padding: 30px 20px;
}

.blog-banner h2 {
  color: var(--main-color);
  margin-top: 0;
  font-size: 1.2rem;
  letter-spacing: 2px;
}

.latest-post {
  margin: 15px 0;
  font-weight: bold;
}

.latest-post a {
  color: var(--sub-color);
  text-decoration:  none;
}

.latest-post a:hover {
  text-decoration:  underline;
}

.btn-blog-list {
  display: inline-block;
  background: var(--main-color);
  color: black;
  padding: 10px 25px;
  border-radius: none;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: bold;
  transition: 0.3s;
  box-shadow: 0 4px 10px rgba(0,0,0,0.3);
}

.btn-blog-list:hover {
  background: var(--main-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 15px rgba(255,105,180,0.4);
}

/* ■■■ブログ一覧■■■ */
.blog-list {
  /*display: grid; */
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  margin-top: 30px;
}

.blog-card {
  display: flex;
  flex-wrap: wrap;
  background: #333;
  border: 3px solid #030303;
  border-radius: 10px;
  text-decoration: none;
  color: white;
  overflow: hidden;
  width: 40%;
  transition: transform 0.3s;
}

.blog-card img {
  width: 100%;
  object-fit: cover;
}

.blog-card-info {
  padding: 20px;
}

.blog-card:hover {
  transform: scale(1.01);
  border: 3px solid var(--main-dark);
  color: var(--sub-color);
}

/* ■■■ブログ記事■■■ */
.blog-article {
  background: #2a2a2a;
  padding: 40px;
  border-radius: 20px;
  margin-top: 30px;
  line-height: 1.8;
}

.article-header {
  text-align:  center;
  border-bottom: 2px solid #444;
  padding-bottom: 30px;
  margin-bottom:  30px;
}

.article-header .date {
  color: var(--main-color);
  font-weight: bold;
}

.article-eyecatch {
  max-width: 100%;
  border-radius: 15px;
  margin-top: 20px;
}

.article-body h2 {
  color: var(--sub-color);
  border-left:  5px solid var(--main-color);
  padding-left: 15px;
  margin-top: 40px;
}

.article-body p {
  margin-bottom:  20px;
}
.all-photo{
  width: 100%;
  max-width: 800px;
}


#photo{
  width: 100%;
  max-width: 800px;
}

.photo{
  width: 100%;
  max-width: 800px;
}

/* ■■■codeblock■■■ */

.code{
  margin: 10px 5px;
  padding: 5px 10px;
  border-radius: 5px;
  background-color:  #111111;
  color: #00FF00;
}

/* ■■■blogcard■■■ */
a{
  color: #FF33FF;
}
.blogcard{
  display: flex;
  text-decoration: none;
  border: 1px solid #00FFFF;
  background:  rgba(255,255,255,0.1);
  margin: 20px 0;
  border-radius:  10px;
  overflow:  hidden;
  height:  120px;
  font-size: 1rem;
}
.blogcard:hover{
  background: #3333AA;
  border: 1px solid #FFFF00;
}
.cardimagewrap{
 width: 120px;
 height: 120px;
 min-width: 120px;
}
.cardimagewrap img {
  width:  100%;
  height:  100%;
  object-fit: cover;
}
.cardimage {
  width: 150px;
  min-width: 150px;
  height:  150px;
  background-size:  cover;
  background-position: center;
}
.cardcontent {
  padding: 15px;
  overflow: hidden;
}

.right-bottom-link {
    position: fixed;        /* 画面に場所をピン留めする魔法の言葉 */
    bottom: 5px;          /* 画面の一番下から 20px 浮かせる */
    right: 10px;            /* 画面の一番左から 20px 離す */
    z-index: 9999;         /* 他の画像や文字に隠されないように一番手前に出す */

    /* ここから下は見やすさ（デザイン）の調整です */
    background-color: rgba(0, 0, 0, 0.7); /* 黒色の少し透明な背景 */
    color: #ffffff;        /* 文字の色（白） */
    padding: 8px 16px;     /* ボタンの中の隙間（押しやすくする） */
    border-radius: 4px;    /* 角を少し丸くする */
    font-size: 14px;       /* 文字の大きさ */
    text-decoration: none; /* リンクの下線を消す */
    box-shadow: 0 2px 8px rgba(0,0,0,0.2); /* ほんのり影をつけて浮き上がらせる */
}
.rss_right-bottom-link {
    position: fixed;        /* 画面に場所をピン留めする魔法の言葉 */
    bottom: 40px;          /* 画面の一番下から 20px 浮かせる */
    right: 10px;            /* 画面の一番左から 20px 離す */
    z-index: 9999;         /* 他の画像や文字に隠されないように一番手前に出す */

    /* ここから下は見やすさ（デザイン）の調整です */
    background-color: rgba(0, 0, 0, 0.7); /* 黒色の少し透明な背景 */
    color: #ffffff;        /* 文字の色（白） */
    padding: 8px 16px;     /* ボタンの中の隙間（押しやすくする） */
    border-radius: 4px;    /* 角を少し丸くする */
    font-size: 14px;       /* 文字の大きさ */
    text-decoration: none; /* リンクの下線を消す */
    box-shadow: 0 2px 8px rgba(0,0,0,0.2); /* ほんのり影をつけて浮き上がらせる */
}



/* マウスを乗せたときに、少し分かりやすく光らせる設定 */
.right-bottom-link:hover,
.rss_right-bottom-link:hover {
    background-color: rgba(0, 0, 0, 0.9); /* 背景を少し濃くする */
    color: var(--main-color);             /* 文字の色をお好みのメインカラーに変えるのもおすすめ */
}

/* ■■■ ボタンをクリックしたときの動き（全ボタン共通） ■■■ */

/* ブログ一覧・カテゴリ一覧ボタン */
.btn-blog-list:active {
  transform: translateY(2px); /* 1 */
  box-shadow: 0 2px 5px rgba(0,0,0,0.3); /* 2 */
}

/* 右下の固定リンク（プライバシーポリシー・RSS） */
.right-bottom-link:active,
.rss_right-bottom-link:active {
  transform: translateY(1px); /* 3 */
  box-shadow: 0 1px 4px rgba(0,0,0,0.3); /* 4 */
}

/* ■■■ページネーション■■ */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-top: 50px;
  padding: 20px 0;
}

.page-link {
  display: inline-block;
  background: #333;
  color: var(--text-color);
  padding: 10px 20px;
  border: 2px solid var(--main-color);
  border-radius: 25px;
  text-decoration: none;
  font-weight: bold;
  transition: all 0.3s;
}

.page-link:hover:not(.disabled){
  background: var(--main-color);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 105, 180, 0.3);
}

.page-link.disabled{
  background: #222;
  brder-color: #444;
  color: #666;
  cursor: not-allowed;
}

.page-info{
  font-weight: bold;
  font-size: 1.1rem;
  color: var(--sub-color);
}

/* ■■■ アクセスカウンタ ■■■ */
.counter {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  font-size: 1.1rem;
}

.countno {
  display: inline-flex;
  margin: 0 5px;
}

.counter-img {
  height: 24px;
  width: auto;
  vertical-align: middle;
}


/* ■■■スマホ対応■■■ */
@media (max-width: 600px) {
  .game-info{flex-direction: column; }
}
