@charset "UTF-8";
/* ============================================================
   ニッポン監視室 デザインシステム v2
   コンセプト: 公文書館 × データジャーナリズム
   - 見出し: Shippori Mincho B1（明朝＝報道・公記録の重み）
   - 本文:   Noto Sans JP
   - 数字:   IBM Plex Mono + tabular-nums（台帳の数字）
   - 色:     生成りの紙 × 墨 × 弁柄(朱)1点
   - 絵文字禁止。分類は漢字一字の「分類印」バッジで表す
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@600;800&family=Noto+Sans+JP:wght@400;500;700&family=IBM+Plex+Mono:wght@500;600&display=swap');

:root {
  --paper: #f6f4ee;        /* 生成りの紙 */
  --paper-dark: #edeae1;
  --ink: #1d1c19;          /* 墨 */
  --ink-soft: #45433d;
  --dim: #6f6b61;
  --line: #d9d4c8;         /* 罫線 */
  --line-strong: #1d1c19;
  --accent: #a83218;       /* 弁柄色（朱）。政党色を避けた和の赤 */
  --accent-ink: #7c2410;
  --accent-paper: #f4e9e2;
  --serif: "Shippori Mincho B1", "Hiragino Mincho ProN", serif;
  --sans: "Noto Sans JP", system-ui, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, monospace;
  --maxw: 920px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--sans); font-weight: 400; color: var(--ink);
  background: var(--paper); line-height: 1.85; font-size: 15px;
  -webkit-text-size-adjust: 100%; font-feature-settings: "palt"; }
a { color: var(--accent-ink); text-decoration: underline; text-underline-offset: 3px;
  text-decoration-thickness: 1px; transition: color .15s; }
a:hover { color: var(--accent); }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

h1, h2, h3, .serif { font-family: var(--serif); font-weight: 800; letter-spacing: .02em; }
.num, .mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }

/* ---- ラベル体（小さく・間を張る。台帳の項目名） ---- */
.label { font-size: 11px; letter-spacing: .22em; color: var(--dim); font-weight: 500;
  text-transform: uppercase; }

/* ---- 分類印: 漢字一字の角枠バッジ（絵文字の代替） ---- */
.seal { display: inline-flex; align-items: center; justify-content: center;
  width: 1.7em; height: 1.7em; border: 1.5px solid currentColor; border-radius: 3px;
  font-family: var(--serif); font-weight: 800; font-size: .82em; line-height: 1;
  flex: 0 0 auto; }
.seal.accent { color: var(--accent); }

/* ---- 兄弟ナビ（墨帯・明朝・句読点区切り） ---- */
.sibling-nav { display: flex; gap: 0; align-items: center; overflow-x: auto;
  white-space: nowrap; background: var(--ink); color: #efece4; padding: 0 12px;
  font-size: 12.5px; scrollbar-width: none; }
.sibling-nav::-webkit-scrollbar { display: none; }
.sibling-nav a { color: #b7b2a6; text-decoration: none; flex: 0 0 auto;
  padding: 9px 11px; border-left: 1px solid rgba(255,255,255,.12); letter-spacing: .04em; }
.sibling-nav a:first-of-type { border-left: none; }
.sibling-nav a:hover { color: #fff; background: rgba(255,255,255,.06); }
.sibling-nav a[aria-current="page"] { color: #fff; font-weight: 700;
  box-shadow: inset 0 -2px 0 var(--accent); }
.sibling-brand { font-family: var(--serif); font-weight: 800; color: #efece4;
  padding-right: 12px; flex: 0 0 auto; letter-spacing: .1em; }

/* ---- ヒーロー（墨地に明朝白抜き＝一面の題字） ---- */
.hero { background: var(--ink); color: #f2efe7; padding: 44px 0 36px;
  border-bottom: 3px solid var(--accent); }
.hero h1 { margin: 0 0 10px; font-size: clamp(26px, 5.4vw, 40px); line-height: 1.3; }
.hero .lead { margin: 0; color: #cfcabd; font-size: 15.5px; font-weight: 500; }
.hero .subcopy { margin: 10px 0 0; color: #98937f; font-size: 13px; }

/* 監視ステータス（点滅する記録中ドット） */
.live { display: inline-flex; align-items: center; gap: 7px; font-family: var(--mono);
  font-size: 11px; letter-spacing: .2em; color: #98937f; }
.live::before { content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); animation: pulse 2.2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1 } 50% { opacity: .25 } }

/* デカ数字（台帳の集計欄） */
.bignums { display: flex; gap: 0; margin-top: 26px; border: 1px solid rgba(255,255,255,.22); }
.bignum { flex: 1 1 0; padding: 14px 18px 12px; border-left: 1px solid rgba(255,255,255,.22); }
.bignum:first-child { border-left: none; }
.bignum b, .bignum .v { display: block; font-family: var(--mono); font-weight: 600;
  font-size: clamp(24px, 5vw, 34px); line-height: 1.15; color: #f2efe7;
  font-variant-numeric: tabular-nums; }
.bignum.accent b, .bignum.accent .v { color: #e8a58f; }
.bignum small, .bignum .k { display: block; margin-top: 2px; font-size: 11px;
  letter-spacing: .18em; color: #98937f; }

/* ---- 本文セクション ---- */
.section-title { display: flex; align-items: baseline; gap: 12px; margin: 34px 0 6px;
  padding-bottom: 8px; border-bottom: 2px solid var(--line-strong); }
.section-title h2 { margin: 0; font-size: 19px; }
.section-title .label { margin-left: auto; }

.notice { background: transparent; border: 1px solid var(--line); border-left: 3px solid var(--dim);
  color: var(--ink-soft); padding: 12px 16px; font-size: 12.5px; margin: 18px 0; line-height: 1.8; }

/* ---- 記録カード（角丸・影なし。罫線と余白で構造を出す） ---- */
.card { background: #fdfcf9; border: 1px solid var(--line); border-radius: 2px;
  padding: 20px 22px; margin: 14px 0; position: relative; }
.card.flagged { border-left: 3px solid var(--accent); }
.card h3 { margin: 0 0 8px; font-size: 16.5px; line-height: 1.55; }

/* ランキング番号（明朝の大きな号数） */
.rank-badge { font-family: var(--serif); font-weight: 800; font-size: 30px;
  color: var(--ink); line-height: 1; letter-spacing: 0; }
.rank-badge::before { content: "第"; font-size: 12px; color: var(--dim); margin-right: 2px; }
.rank-badge::after { content: "位"; font-size: 12px; color: var(--dim); margin-left: 2px; }
.card:first-of-type .rank-badge, .rank-badge.top { color: var(--accent); }

/* タグ（角丸ピル廃止 → 角の立った小札） */
.tag { display: inline-block; background: var(--paper-dark); color: var(--ink-soft);
  border-radius: 2px; padding: 1px 9px; font-size: 11.5px; margin: 2px 6px 2px 0;
  letter-spacing: .06em; }
.tag.flag { background: var(--accent-paper); color: var(--accent-ink);
  border: 1px solid #dcb9a8; }

/* 審議タイムライン（工程表） */
.timeline { display: flex; flex-wrap: wrap; gap: 0; margin: 12px 0; border: 1px solid var(--line); }
.timeline .step { flex: 1 1 auto; min-width: 86px; padding: 8px 12px 7px;
  border-left: 1px solid var(--line); }
.timeline .step:first-child { border-left: none; }
.timeline .step .k { display: block; font-size: 10.5px; letter-spacing: .14em; color: var(--dim); }
.timeline .step .v { font-family: var(--mono); font-size: 13px; font-weight: 600; }
.timeline .step.hit .v { color: var(--accent); }
/* 実装側の別名(.s-label/.s-date/.arrow)にも対応。矢印は罫線で足りるため非表示 */
.timeline .s-label { display: block; font-size: 10.5px; letter-spacing: .14em; color: var(--dim); }
.timeline .s-date { display: block; font-family: var(--mono); font-size: 13px; font-weight: 600;
  font-variant-numeric: tabular-nums; }
.timeline .step.done .s-date { color: var(--ink); }
.timeline .arrow { display: none; }

/* 大きな日数表示 */
.days { font-family: var(--mono); font-weight: 600; font-size: 30px; color: var(--accent);
  font-variant-numeric: tabular-nums; line-height: 1; }
.days small { font-size: 12px; color: var(--dim); font-family: var(--sans); margin-left: 4px; }

/* ---- AI解説（欄外注の体裁） ---- */
.ai-explain { border-top: 1px dotted var(--line-strong); border-bottom: 1px dotted var(--line-strong);
  padding: 10px 2px; margin: 14px 0; font-size: 13.5px; background: transparent; }
.ai-explain .ai-note { color: var(--dim); font-size: 11px; margin-top: 6px; letter-spacing: .05em; }

/* ---- ボタン ---- */
.btn { display: inline-flex; align-items: center; gap: 8px; background: var(--ink);
  color: #f2efe7; border: 1px solid var(--ink); border-radius: 2px; padding: 8px 18px;
  font-size: 13px; font-weight: 500; letter-spacing: .08em; text-decoration: none;
  cursor: pointer; transition: background .15s; }
.btn:hover { background: #37352e; color: #fff; }
.btn.ghost { background: transparent; color: var(--ink); }
.btn.ghost:hover { background: var(--paper-dark); }

/* リアクション（漢字一字の評決ボタン） */
.reactions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.react-btn { display: inline-flex; align-items: center; gap: 6px; background: transparent;
  border: 1px solid var(--line); border-radius: 2px; padding: 4px 10px; cursor: pointer;
  font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); transition: all .15s; }
.react-btn .seal { font-size: .9em; width: 1.6em; height: 1.6em; }
.react-btn:hover { border-color: var(--accent); color: var(--accent-ink); }
.react-btn .count { font-family: var(--mono); font-size: 11.5px; }

/* ---- タブ ---- */
.tabs { display: flex; gap: 0; border-bottom: 2px solid var(--line-strong); margin: 26px 0 0;
  overflow-x: auto; scrollbar-width: none; }
.tabs::-webkit-scrollbar { display: none; }
.tab { appearance: none; background: transparent; border: none; cursor: pointer;
  font-family: var(--serif); font-weight: 600; font-size: 14.5px; color: var(--dim);
  padding: 10px 16px 9px; letter-spacing: .05em; white-space: nowrap;
  border-bottom: 3px solid transparent; margin-bottom: -2px; }
.tab:hover { color: var(--ink); }
.tab.active, .tab[aria-selected="true"] { color: var(--ink); border-bottom-color: var(--accent); }

/* ---- 入力 ---- */
input[type="search"], input[type="text"], select {
  font-family: var(--sans); font-size: 14px; color: var(--ink); background: #fdfcf9;
  border: 1px solid var(--line); border-radius: 2px; padding: 8px 12px; }
input:focus, select:focus { outline: none; border-color: var(--ink); }

/* ---- 広告枠 ---- */
.ad-slot { margin: 20px 0; }
.ad-placeholder { display: flex; align-items: center; justify-content: center; min-height: 80px;
  border: 1px dashed var(--line); border-radius: 2px; color: var(--dim); font-size: 11px;
  letter-spacing: .2em; background: transparent; }
.ad-affiliate img { max-width: 100%; height: auto; display: block; margin: 0 auto; }

/* ---- 兄弟サイトフッター（奥付） ---- */
.sibling-footer { border-top: 3px double var(--line-strong); margin-top: 56px;
  padding: 30px 20px 40px; background: var(--paper); }
.sibling-footer h2 { font-family: var(--serif); font-size: 14px; letter-spacing: .2em;
  color: var(--ink-soft); margin: 0 auto 16px; max-width: var(--maxw); }
.sib-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1px; max-width: var(--maxw); margin: 0 auto; background: var(--line);
  border: 1px solid var(--line); }
.sib-card { display: flex; flex-direction: column; gap: 3px; text-decoration: none;
  color: var(--ink); padding: 14px 16px; background: #fdfcf9; transition: background .15s; }
.sib-card:hover { background: var(--accent-paper); }
.sib-head { display: flex; align-items: center; gap: 8px; }
.sib-name { font-family: var(--serif); font-weight: 800; font-size: 14px; }
.sib-tag { color: var(--dim); font-size: 11.5px; line-height: 1.6; }
.footer-note { max-width: var(--maxw); margin: 20px auto 0; color: var(--dim);
  font-size: 11px; line-height: 1.9; letter-spacing: .03em; }

/* ---- パンくず ---- */
.breadcrumb { font-size: 11.5px; color: var(--dim); letter-spacing: .05em; margin: 16px 0 0; }
.breadcrumb a { color: var(--dim); }

/* ============================================================
   参加型モジュール（アンケート・コメント）v1
   base.css のトークン/クラスに準拠（明朝見出し・弁柄・角丸2px・絵文字禁止）
   ============================================================ */

/* ---- アンケート ---- */
.poll { border: 1px solid var(--line); border-radius: 2px; padding: 14px 16px; margin: 14px 0; background: #fdfcf9; }
.poll-question { font-family: var(--serif); font-weight: 700; font-size: 14.5px; margin: 0 0 10px; }
.poll-buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.poll-btn { appearance: none; background: transparent; border: 1px solid var(--line); border-radius: 2px;
  padding: 7px 16px; font-family: var(--sans); font-size: 13px; color: var(--ink-soft); cursor: pointer;
  transition: all .15s; }
.poll-btn:hover { border-color: var(--accent); color: var(--accent-ink); background: var(--accent-paper); }

.poll-bars { display: flex; flex-direction: column; gap: 8px; }
.poll-bar-row { display: grid; grid-template-columns: 88px 1fr 92px; align-items: center; gap: 10px; }
.poll-bar-label { font-size: 12.5px; color: var(--ink-soft); }
.poll-bar-track { height: 10px; background: var(--paper-dark); border: 1px solid var(--line); border-radius: 2px; overflow: hidden; }
.poll-bar-fill { height: 100%; background: var(--accent); }
.poll-bar-pct { font-family: var(--mono); font-size: 11.5px; color: var(--dim); text-align: right;
  font-variant-numeric: tabular-nums; }
.poll-total { margin-top: 10px; font-size: 11px; color: var(--dim); letter-spacing: .05em; }
.poll-pending .poll-note { font-size: 12.5px; color: var(--dim); }

@media (max-width: 600px) {
  .poll-bar-row { grid-template-columns: 70px 1fr 78px; gap: 6px; }
}

/* ---- コメント ---- */
.comments { border: 1px solid var(--line); border-radius: 2px; padding: 16px 18px; margin: 18px 0; background: #fdfcf9; }
.comments-title { font-family: var(--serif); font-weight: 700; font-size: 15px; margin: 0 0 4px; }
.comments-disclaimer { font-size: 11px; color: var(--dim); margin: 0 0 12px; line-height: 1.7; }

.comment-form { margin-bottom: 16px; }
.comment-input { width: 100%; min-height: 64px; resize: vertical; font-family: var(--sans); font-size: 13.5px;
  color: var(--ink); background: #fff; border: 1px solid var(--line); border-radius: 2px; padding: 10px 12px;
  box-sizing: border-box; }
.comment-input:focus { outline: none; border-color: var(--ink); }
.comment-form-row { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; gap: 10px; }
.comment-counter { font-family: var(--mono); font-size: 11px; color: var(--dim); }
.comment-submit-btn { appearance: none; background: var(--ink); color: #f2efe7; border: 1px solid var(--ink);
  border-radius: 2px; padding: 7px 18px; font-size: 12.5px; font-weight: 500; letter-spacing: .05em;
  cursor: pointer; transition: background .15s; }
.comment-submit-btn:hover { background: #37352e; }
.comment-submit-btn:disabled { opacity: .5; cursor: default; }
.comment-status { font-size: 12px; margin-top: 6px; min-height: 1.4em; }
.comment-status-ok { color: var(--ink-soft); }
.comment-status-ng, .comment-status-pending { color: var(--accent-ink); }

.comment-list { display: flex; flex-direction: column; gap: 10px; }
.comment { border-top: 1px solid var(--line); padding-top: 10px; }
.comment:first-child { border-top: none; padding-top: 0; }
.comment-body { font-size: 13.5px; color: var(--ink); line-height: 1.75; white-space: pre-wrap; word-break: break-word; }
.comment-meta { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; }
.comment-date { font-family: var(--mono); font-size: 10.5px; color: var(--dim); }
.comment-report-btn { appearance: none; background: transparent; border: none; color: var(--dim);
  font-size: 11px; letter-spacing: .05em; cursor: pointer; text-decoration: underline;
  text-underline-offset: 2px; padding: 0; }
.comment-report-btn:hover { color: var(--accent-ink); }
.comment-report-btn:disabled { color: var(--dim); text-decoration: none; cursor: default; opacity: .7; }
.comment-note { font-size: 12.5px; color: var(--dim); padding: 6px 0; }

@media (max-width: 600px) {
  body { font-size: 14px; }
  .card { padding: 16px; }
  .bignums { flex-direction: row; }
  .bignum { padding: 10px 12px 9px; }
}
