/* ============================================================
   ナマズオ速報 — 和モダンテーマ
   マスコット由来: クリーム地 / 朱(半纏) / 金(鈴) / 墨(文字)
   ============================================================ */
:root {
  --bg: #f6f0e3;            /* 温かいクリーム地 */
  --bg-2: #efe7d5;
  --surface: #fffdf8;       /* カード(ほぼ白・少し温かい) */
  --surface-2: #f7f1e4;     /* パネル */
  --line: #e6dcc6;          /* 温かい罫線 */
  --line-strong: #d8cbae;
  --ink: #2f2a22;           /* 墨色(本文) */
  --ink-soft: #4a4338;
  --muted: #93897a;         /* 補助テキスト */
  --vermilion: #c8402e;     /* 朱色(半纏) */
  --vermilion-d: #a8331f;
  --vermilion-l: #e06a52;
  --gold: #c4982f;          /* 金(鈴) */
  --gold-d: #a37e22;
  --indigo: #2f5d83;        /* 藍(差し色) */
  --x: #2f2a22;
  --reddit: #d9521f;
  --lodestone: #2f5d83;
  --radius: 14px;
  --shadow: 0 4px 16px rgba(80, 60, 30, .10);
  --shadow-lg: 0 12px 30px rgba(80, 60, 30, .16);
  --font-serif: "Hiragino Mincho ProN", "Yu Mincho", YuMincho, "Shippori Mincho", "MS PMincho", serif;
  --font-sans: "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", Meiryo, system-ui, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: var(--vermilion-d); text-decoration: none; }
a:hover { text-decoration: underline; }
::selection { background: rgba(200, 64, 46, .18); }

/* ---------- ヘッダー(朱の暖簾風) ---------- */
.site-header {
  position: sticky; top: 0; z-index: 20;
  background: linear-gradient(180deg, #c8402e, #b3381f);
  border-bottom: 3px solid var(--gold);
  box-shadow: 0 2px 10px rgba(120, 40, 20, .25);
}
.bar {
  max-width: 1080px; margin: 0 auto; padding: 0 22px;
  height: 66px; display: flex; align-items: center; justify-content: space-between;
}
.logo {
  display: flex; align-items: center; gap: 11px;
  font-family: var(--font-serif);
  font-size: 1.4rem; font-weight: 700; letter-spacing: .04em;
  color: #fff; text-shadow: 0 1px 2px rgba(90, 25, 12, .4);
}
.logo:hover { text-decoration: none; color: #fff; filter: brightness(1.05); }
.logo-icon {
  width: 40px; height: 40px; border-radius: 50%;
  margin: 0; vertical-align: middle;
  border: 2px solid rgba(255, 240, 200, .85);
  background: #fff; box-shadow: 0 2px 6px rgba(90, 25, 12, .3);
}
.nav { display: flex; align-items: center; gap: 4px; }
.nav a {
  color: #fdeede; font-size: .92rem; font-weight: 600;
  padding: 7px 14px; border-radius: 8px; white-space: nowrap;
  transition: background .15s, color .15s;
}
.nav a:hover { color: #fff; background: rgba(255, 255, 255, .15); text-decoration: none; }
.nav .rss-link { border: 1px solid rgba(255, 240, 200, .4); }

.container { max-width: 1080px; margin: 0 auto; padding: 30px 22px 70px; }

/* ---------- レイアウト ---------- */
.layout { display: grid; grid-template-columns: 1fr 290px; gap: 32px; }
@media (max-width: 860px) { .layout { grid-template-columns: 1fr; } }

.page-head { display: flex; align-items: center; gap: 14px; margin-bottom: 6px; }
.page-title {
  font-family: var(--font-serif);
  font-size: 1.5rem; font-weight: 700; margin: 0 0 20px;
  display: flex; align-items: center; gap: 12px; color: var(--ink);
}
.page-title::before {
  content: ""; width: 6px; height: 1.15em; border-radius: 3px;
  background: linear-gradient(180deg, var(--vermilion), var(--gold));
}
.clear-filter { font-size: .85rem; color: var(--muted); }

/* ---------- ヒーロー(青海波の和柄) ---------- */
.hero {
  position: relative; overflow: hidden;
  border-radius: var(--radius); border: 1px solid var(--line-strong);
  margin-bottom: 30px; min-height: 168px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; gap: 8px; padding: 30px 24px;
  background-color: #fbf4e6;
  background-image:
    radial-gradient(circle at 100% 50%, transparent 21%, rgba(196, 152, 47, .18) 21% 24%, transparent 24%),
    radial-gradient(circle at 0% 50%, transparent 21%, rgba(196, 152, 47, .18) 21% 24%, transparent 24%);
  background-size: 54px 72px;
  background-position: 0 0, 27px 36px;
}
.hero::after {  /* 上に淡いクリームのベール(柄を主張させすぎない) */
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 50%, rgba(251,244,230,.78), rgba(251,244,230,.92));
  pointer-events: none;
}
.hero-text { position: relative; z-index: 1; }
.hero-text h1 {
  font-family: var(--font-serif);
  margin: 0 0 10px; font-size: 2.2rem; font-weight: 700; letter-spacing: .06em;
  color: var(--vermilion-d); text-shadow: 0 1px 0 #fff;
}
.hero-text h1::after {  /* 金の下線飾り */
  content: ""; display: block; width: 64px; height: 3px; margin: 10px auto 0;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.hero-text p { margin: 0; color: var(--ink-soft); font-size: .96rem; letter-spacing: .02em; }
@media (max-width: 640px) {
  .hero { min-height: 0; padding: 26px 20px; }
  .hero-text h1 { font-size: 1.6rem; }
}

/* ---------- 記事カード ---------- */
.card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 18px 22px; margin-bottom: 16px;
  display: flex; gap: 20px; align-items: stretch;
  box-shadow: var(--shadow);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.card:hover {
  transform: translateY(-2px); box-shadow: var(--shadow-lg);
  border-color: var(--gold);
}
.card-body { flex: 1; min-width: 0; }
.card-thumb {
  flex-shrink: 0; width: 156px; min-height: 106px; align-self: center;
  border-radius: 11px; overflow: hidden; position: relative;
  border: 1px solid var(--line); display: block;
}
.card-thumb img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; display: block; z-index: 1; transition: transform .25s ease;
}
.card:hover .card-thumb img { transform: scale(1.05); }
.thumb-ph {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 1.7rem; color: rgba(160, 130, 80, .5);
  background: linear-gradient(135deg, #f3ead6, #ece0c6);
}
.card-title {
  font-family: var(--font-serif);
  font-size: 1.18rem; font-weight: 700; margin: 9px 0 6px; line-height: 1.55;
}
.card-title a { color: var(--ink); }
.card-title a:hover { color: var(--vermilion-d); text-decoration: none; }
.card-lead {
  color: var(--ink-soft); font-size: .9rem; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.card-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.date { color: var(--muted); font-size: .78rem; font-variant-numeric: tabular-nums; }
.comment-badge { color: var(--vermilion-d); font-size: .78rem; font-weight: 600; }
@media (max-width: 560px) {
  .card { flex-direction: column-reverse; }
  .card-thumb { width: 100%; height: 170px; }
}

/* ---------- チップ・バッジ ---------- */
.chip {
  font-size: .74rem; font-weight: 700; padding: 3px 12px; border-radius: 999px;
  border: 1px solid transparent; white-space: nowrap;
}
.chip.cat { color: #fff; background: var(--vermilion); }
.chip.cat[data-cat="公式・パッチ情報"] { background: #c0392b; }
.chip.cat[data-cat="攻略・Tips"]       { background: #2e7d5b; }
.chip.cat[data-cat="イベント"]         { background: #d98a2b; }
.chip.cat[data-cat="創作・スクリーンショット"] { background: #8a5fa8; }
.chip.cat[data-cat="コミュニティ・話題"] { background: #2f5d83; }
.chip.cat[data-cat="その他"]           { background: #8a7f6c; }

.badge {
  font-size: .72rem; font-weight: 700; padding: 2px 9px; border-radius: 5px;
  border: 1px solid; background: #fff;
}
.badge.src-x { color: var(--x); border-color: #cfc6b4; }
.badge.src-reddit { color: var(--reddit); border-color: #f0c2a6; }
.badge.src-lodestone { color: var(--lodestone); border-color: #aec6da; }
.badge.src-tieba { color: #b3381f; border-color: #e6b9a8; }
.badge.src-dcinside { color: #2f5d83; border-color: #aec6da; }

/* ---------- サイドバー ---------- */
.sidebar { position: sticky; top: 88px; align-self: start; }
@media (max-width: 860px) { .sidebar { position: static; } }
.widget {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 16px 19px; margin-bottom: 18px; box-shadow: var(--shadow);
}
.widget-title {
  font-family: var(--font-serif);
  font-size: 1rem; font-weight: 700; color: var(--ink);
  margin: 0 0 12px; padding-bottom: 9px; border-bottom: 2px solid var(--line);
  display: flex; align-items: center; gap: 8px;
}
.widget-title::before {
  content: ""; width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
  background: radial-gradient(circle at 35% 30%, #e8c869, var(--gold) 60%, var(--gold-d));
  box-shadow: inset 0 -1px 1px rgba(120,80,10,.4);
}
.cat-list, .src-list, .recent-list { list-style: none; margin: 0; padding: 0; }
.cat-list a, .src-list a {
  display: flex; align-items: center; gap: 9px; padding: 7px 10px; margin: 0 -10px;
  border-radius: 8px; color: var(--ink); font-size: .9rem; transition: background .15s;
}
.cat-list a:hover, .src-list a:hover { background: var(--surface-2); text-decoration: none; }
.cat-list a.active, .src-list a.active { background: #fbeee8; color: var(--vermilion-d); font-weight: 700; }
.count { margin-left: auto; color: var(--muted); font-size: .78rem; font-variant-numeric: tabular-nums; }
.dot { width: 9px; height: 9px; border-radius: 50%; background: var(--vermilion); flex-shrink: 0; }
.dot[data-cat="公式・パッチ情報"] { background: #c0392b; }
.dot[data-cat="攻略・Tips"]       { background: #2e7d5b; }
.dot[data-cat="イベント"]         { background: #d98a2b; }
.dot[data-cat="創作・スクリーンショット"] { background: #8a5fa8; }
.dot[data-cat="コミュニティ・話題"] { background: #2f5d83; }
.dot[data-cat="その他"]           { background: #8a7f6c; }
.recent-list li { padding: 9px 0; border-bottom: 1px dashed var(--line); font-size: .86rem; line-height: 1.6; }
.recent-list li:last-child { border-bottom: none; padding-bottom: 0; }
.recent-list a { color: var(--ink); }
.recent-list a:hover { color: var(--vermilion-d); text-decoration: none; }

/* ---------- 記事ページ ---------- */
.post {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 34px 40px; box-shadow: var(--shadow);
}
@media (max-width: 600px) { .post { padding: 24px 20px; } }
.post-title {
  font-family: var(--font-serif);
  font-size: 1.6rem; font-weight: 700; line-height: 1.5; margin: 12px 0 22px;
  padding-bottom: 16px; border-bottom: 2px solid var(--line);
}
.post-body { font-size: 1rem; color: var(--ink); }
.post-body p { margin: 0 0 1.1em; }
.post-body blockquote {
  margin: 18px 0; padding: 16px 20px;
  background: var(--surface-2); border: 1px solid var(--line);
  border-left: 4px solid var(--gold); border-radius: 0 10px 10px 0; color: var(--ink-soft);
}
.post-body blockquote a { font-size: .84rem; }
.post-body img { max-width: 100%; max-height: 480px; border-radius: 10px; border: 1px solid var(--line); display: block; margin: 6px 0; }
.post-body h2 {
  font-family: var(--font-serif);
  font-size: 1.12rem; font-weight: 700; letter-spacing: .03em;
  margin: 32px 0 14px; padding: 9px 16px; border-radius: 8px;
  background: linear-gradient(180deg, #c8402e, #b3381f); color: #fff;
}
.post-body h2 + ul { list-style: none; padding: 0; margin: 0; }
.post-body h2 + ul li {
  background: var(--surface-2); border: 1px solid var(--line);
  border-left: 3px solid var(--gold);
  padding: 11px 16px; margin: 8px 0; border-radius: 8px;
  font-size: .93rem; color: var(--ink-soft);
}
.back { display: inline-block; margin-top: 22px; color: var(--muted); font-size: .9rem; }
.preview-banner {
  background: #fdf3da; border: 1px solid var(--gold); color: var(--gold-d);
  padding: 11px 15px; border-radius: 9px; margin-bottom: 16px; font-size: .87rem;
}
.share-row { margin-top: 26px; padding-top: 18px; border-top: 1px solid var(--line); }
.share-x {
  display: inline-flex; align-items: center; gap: 7px;
  background: #15171a; color: #fff; font-weight: 700; font-size: .88rem;
  padding: 9px 20px; border-radius: 999px;
  transition: filter .15s, transform .1s;
}
.share-x:hover { filter: brightness(1.3); text-decoration: none; transform: translateY(-1px); }

.empty {
  color: var(--muted); background: var(--surface); border: 1px dashed var(--line-strong);
  border-radius: var(--radius); padding: 30px; text-align: center;
}

/* ---------- コメント ---------- */
.comments {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px 32px; margin-top: 20px; box-shadow: var(--shadow);
}
.comments-title {
  font-family: var(--font-serif);
  font-size: 1.1rem; font-weight: 700; margin: 0 0 16px;
  display: flex; align-items: center; gap: 10px;
}
.comments-count {
  font-size: .78rem; font-weight: 700; padding: 2px 11px; border-radius: 999px;
  background: var(--vermilion); color: #fff;
}
.comments-empty { color: var(--muted); font-size: .9rem; }
.comment { padding: 13px 0; border-bottom: 1px solid var(--line); }
.comment-head { display: flex; align-items: center; gap: 9px; font-size: .8rem; margin-bottom: 4px; }
.comment-num { color: var(--muted); font-variant-numeric: tabular-nums; }
.comment-name { font-weight: 700; color: var(--vermilion-d); }
.comment-date { color: var(--muted); font-size: .74rem; }
.comment-body { font-size: .93rem; white-space: pre-line; color: var(--ink); }
.comment-body .anchor { color: var(--vermilion-d); font-weight: 600; }
.comment-form { margin-top: 18px; }

/* ---------- フォーム共通 ---------- */
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.form-row { margin-bottom: 10px; }
.form-row.two { display: flex; gap: 10px; }
.form-row input[type="text"], .form-row textarea, .form-row select {
  width: 100%; padding: 10px 13px; font-size: .9rem; font-family: inherit;
  background: #fff; color: var(--ink);
  border: 1px solid var(--line-strong); border-radius: 8px; resize: vertical;
}
.form-row.two select { width: auto; flex-shrink: 0; }
.form-row input:focus, .form-row textarea:focus, .form-row select:focus {
  outline: none; border-color: var(--vermilion);
  box-shadow: 0 0 0 3px rgba(200, 64, 46, .12);
}

/* ---------- 掲示板 ---------- */
.board-toolbar {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
  gap: 12px; margin-bottom: 18px;
}
.board-cats { display: flex; flex-wrap: wrap; gap: 7px; }
.board-cat {
  font-size: .8rem; font-weight: 600; padding: 5px 14px; border-radius: 999px;
  border: 1px solid var(--line-strong); color: var(--ink-soft); background: var(--surface);
}
.board-cat:hover { color: var(--vermilion-d); text-decoration: none; background: #fbeee8; }
.board-cat.active { background: var(--vermilion); color: #fff; border-color: var(--vermilion-d); }
.board-sort { font-size: .8rem; color: var(--muted); display: flex; gap: 7px; }
.board-sort a { color: var(--muted); }
.board-sort a.active { color: var(--vermilion-d); font-weight: 700; }

.thread-list { margin-bottom: 24px; }
.thread-row {
  display: flex; align-items: center; gap: 18px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 12px;
  padding: 14px 20px; margin-bottom: 10px; color: var(--ink);
  box-shadow: var(--shadow); transition: border-color .15s, transform .15s;
}
.thread-row:hover { text-decoration: none; border-color: var(--gold); transform: translateY(-1px); }
.thread-main { flex: 1; min-width: 0; }
.thread-title { font-family: var(--font-serif); font-weight: 700; font-size: 1rem; display: flex; align-items: center; gap: 9px; }
.thread-excerpt { color: var(--muted); font-size: .8rem; margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.thread-stats { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; flex-shrink: 0; }
.thread-count { font-weight: 800; color: var(--vermilion-d); font-size: 1.05rem; font-variant-numeric: tabular-nums; }
.thread-count small { font-size: .68rem; color: var(--muted); font-weight: 600; margin-left: 2px; }
.thread-date { color: var(--muted); font-size: .72rem; }
.thread-head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.thread-page-title { font-family: var(--font-serif); font-size: 1.35rem; font-weight: 700; margin: 0; }
.post-list { margin-bottom: 22px; }
.board-post { background: var(--surface); border: 1px solid var(--line); border-radius: 12px; padding: 14px 20px; margin-bottom: 10px; box-shadow: var(--shadow); }
.board-post:target { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(196, 152, 47, .2); }
.board-post-head { display: flex; align-items: center; gap: 9px; font-size: .8rem; margin-bottom: 5px; }
.reply-btn { margin-left: auto; background: none; border: none; cursor: pointer; color: var(--muted); font-size: .76rem; padding: 2px 6px; border-radius: 5px; }
.reply-btn:hover { color: var(--vermilion-d); background: #fbeee8; }
.new-thread, .reply-form { margin-top: 8px; }

/* ---------- 管理画面 ---------- */
.panel {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px 26px; margin-bottom: 22px; box-shadow: var(--shadow);
}
.panel-head { display: flex; align-items: center; justify-content: space-between; }
.panel-title { font-family: var(--font-serif); font-size: 1.05rem; font-weight: 700; margin: 0 0 16px; }
.panel-head .panel-title { margin: 0; }
.admin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 720px) { .admin-grid { grid-template-columns: 1fr; } }
.pipeline { display: flex; flex-direction: column; gap: 12px; }
.step-group { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; padding: 14px 16px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 11px; }
.step-label { font-weight: 700; font-size: .87rem; color: var(--vermilion-d); min-width: 64px; }
.score { font-size: .84rem; color: var(--muted); display: inline-flex; align-items: center; gap: 7px; }
.score input { width: 58px; padding: 5px 8px; border: 1px solid var(--line-strong); border-radius: 7px; background: #fff; color: var(--ink); }

.btn {
  background: var(--surface-2); border: 1px solid var(--line-strong); color: var(--ink);
  padding: 8px 16px; border-radius: 9px; font-size: .86rem; cursor: pointer; font-weight: 600;
  transition: background .15s, border-color .15s, transform .1s;
}
.btn:hover { background: #efe6d3; }
.btn:active { transform: scale(.98); }
.btn.primary { background: linear-gradient(180deg, #c8402e, #b3381f); border-color: var(--vermilion-d); color: #fff; }
.btn.primary:hover { filter: brightness(1.07); }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn.small { padding: 6px 13px; font-size: .82rem; }
.btn.tiny { padding: 4px 11px; font-size: .78rem; }
.btn.danger { color: var(--vermilion-d); border-color: #e6b9a8; background: #fbeee8; }
.btn.danger:hover { background: #f6ddd4; }

.run-status { margin-top: 14px; font-size: .88rem; font-weight: 600; color: var(--muted); }
.run-status.running { color: var(--indigo); }
.run-status.ok { color: #2e7d5b; }
.run-status.err { color: var(--vermilion); }
.log { background: #2f2a22; border: 1px solid var(--line-strong); color: #e8dcc4; padding: 14px 16px; border-radius: 10px; font-size: .78rem; max-height: 280px; overflow: auto; white-space: pre-wrap; margin-top: 10px; }
.log:empty { display: none; }

.stat-list { list-style: none; margin: 0; padding: 0; }
.stat-list li { padding: 6px 0; font-size: .88rem; }
.stat-line { font-size: .88rem; margin: 6px 0; }
.hist { margin-top: 14px; }
.hist-row { display: flex; align-items: center; gap: 9px; margin: 4px 0; font-size: .76rem; }
.hist-score { width: 18px; text-align: right; color: var(--muted); font-variant-numeric: tabular-nums; }
.hist-bar { height: 10px; background: linear-gradient(90deg, var(--gold), var(--vermilion)); border-radius: 5px; min-width: 2px; }
.hist-n { color: var(--muted); font-variant-numeric: tabular-nums; }

.art-table { width: 100%; border-collapse: collapse; font-size: .86rem; }
.art-table th { text-align: left; color: var(--muted); font-weight: 600; padding: 8px 10px; border-bottom: 2px solid var(--line); font-size: .76rem; }
.art-table td { padding: 11px 10px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.art-table tr:hover td { background: var(--surface-2); }
.t-title { max-width: 380px; }
.t-title a { color: var(--ink); }
.t-title a:hover { color: var(--vermilion-d); }
.status { font-size: .73rem; font-weight: 700; padding: 3px 10px; border-radius: 999px; }
.status-published { background: #e3f1e8; color: #2e7d5b; border: 1px solid #b8ddc6; }
.status-draft { background: var(--surface-2); color: var(--muted); border: 1px solid var(--line); }
.status.announced { background: #fbeee8; color: var(--vermilion-d); border: 1px solid #e6b9a8; margin-left: 5px; }
.actions { display: flex; gap: 6px; }
.actions form { margin: 0; }
.mod-list { list-style: none; margin: 0; padding: 0; }
.mod-list li { padding: 11px 0; border-bottom: 1px solid var(--line); }
.mod-list li:last-child { border-bottom: none; }
.mod-meta { font-size: .84rem; display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.mod-link { font-size: .76rem; }
.mod-body { color: var(--muted); font-size: .84rem; margin: 4px 0 7px; }

/* ---------- About ---------- */
.about { max-width: 760px; margin: 0 auto; }
.about .panel p { font-size: .92rem; color: var(--ink); margin: 10px 0; }
.about-list { margin: 10px 0; padding-left: 22px; font-size: .92rem; color: var(--ink); }
.about-list li { margin: 5px 0; }
.about-table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.about-table th { text-align: left; color: var(--muted); font-weight: 600; width: 130px; padding: 9px 10px 9px 0; border-bottom: 1px solid var(--line); vertical-align: top; }
.about-table td { padding: 9px 0; border-bottom: 1px solid var(--line); color: var(--ink); }
.copyright-line { font-size: .8rem !important; color: var(--muted) !important; line-height: 1.8; }

/* ---------- フッター ---------- */
.site-footer {
  text-align: center; color: var(--muted); font-size: .8rem;
  padding: 34px 22px 44px; border-top: 3px solid var(--gold);
  background: linear-gradient(180deg, #f0e7d4, #ebe1cd);
}
.footer-nav { display: flex; justify-content: center; flex-wrap: wrap; gap: 6px 22px; margin-bottom: 14px; }
.footer-nav a { color: var(--vermilion-d); font-weight: 600; }
.footer-nav a:hover { color: var(--vermilion); }
.site-footer .copyright { margin-top: 14px; font-size: .72rem; line-height: 1.9; color: #a89d89; }
