/* MCP Vetted — 監査レポート/ラボ調のダークテーマ
 * 型: Sora (見出し・本文) + Spline Sans Mono (データ・スコア)
 * 配色: インクネイビー地 + 検証グリーン。グレードは A→E で色分け。
 */
:root {
  --bg: #0b0f14;
  --bg-raised: #10161e;
  --bg-inset: #0d1219;
  --line: #1e2833;
  --line-strong: #2c3947;
  --ink: #e6edf3;
  --ink-dim: #96a4b3;
  --ink-faint: #5d6b7a;
  --accent: #2fe6a8;
  --accent-dim: rgba(47, 230, 168, 0.12);
  --grade-a: #2fe6a8;
  --grade-b: #7dd3fc;
  --grade-c: #fbbf24;
  --grade-d: #fb923c;
  --grade-e: #f87171;
  --mono: "Spline Sans Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --sans: "Sora", -apple-system, "Segoe UI", sans-serif;
  --wrap: 1080px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--bg);
  background-image:
    radial-gradient(1200px 500px at 70% -10%, rgba(47, 230, 168, 0.06), transparent 60%),
    repeating-linear-gradient(0deg, transparent, transparent 47px, rgba(255, 255, 255, 0.015) 48px);
  color: var(--ink);
  font: 15px/1.65 var(--sans);
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }
.wrap { max-width: var(--wrap); margin: 0 auto; padding: 0 20px; }
.mono { font-family: var(--mono); }

/* ---- ヘッダー ---- */
.site-header {
  border-bottom: 1px solid var(--line);
  background: rgba(11, 15, 20, 0.85);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 10;
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; height: 58px; gap: 16px; }
.brand { display: flex; align-items: center; gap: 10px; color: var(--ink); font-weight: 700; font-size: 17px; letter-spacing: -0.02em; }
.brand:hover { text-decoration: none; }
.brand-mark {
  width: 22px; height: 22px; border-radius: 6px;
  background: var(--accent);
  display: inline-flex; align-items: center; justify-content: center;
  color: #06251a; font-family: var(--mono); font-size: 13px; font-weight: 700;
}
.brand .vetted { color: var(--accent); }
.site-nav { display: flex; gap: 4px; flex-wrap: wrap; }
.site-nav a {
  color: var(--ink-dim); font-size: 13.5px; padding: 6px 10px; border-radius: 6px;
}
.site-nav a:hover { color: var(--ink); background: var(--bg-raised); text-decoration: none; }
.site-nav a[aria-current="page"] { color: var(--accent); background: var(--accent-dim); }

/* ---- ヒーロー ---- */
.hero { padding: 56px 0 36px; border-bottom: 1px solid var(--line); }
.hero h1 { font-size: clamp(28px, 5vw, 44px); line-height: 1.12; letter-spacing: -0.03em; margin: 0 0 14px; font-weight: 700; }
.hero h1 em { font-style: normal; color: var(--accent); }
.hero .lede { color: var(--ink-dim); max-width: 640px; margin: 0 0 22px; font-size: 16px; }
.statline { display: flex; flex-wrap: wrap; gap: 10px 28px; font-family: var(--mono); font-size: 13px; color: var(--ink-faint); }
.statline b { color: var(--ink); font-weight: 600; font-size: 15px; margin-right: 6px; }

/* ---- Featured 枠 ---- */
.featured-band { padding: 22px 0; border-bottom: 1px solid var(--line); background: var(--bg-inset); }
.featured-band .band-label { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-faint); margin: 0 0 10px; }
.featured-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.featured-card {
  border: 1px dashed var(--line-strong); border-radius: 10px; padding: 16px 18px;
  display: flex; flex-direction: column; gap: 6px; background: var(--bg-raised);
}
.featured-card.placeholder { align-items: flex-start; }
.featured-card h3 { margin: 0; font-size: 15px; }
.featured-card p { margin: 0; color: var(--ink-dim); font-size: 13px; }
.featured-card .btn { margin-top: 8px; }

/* ---- フィルタ ---- */
.filters { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; padding: 22px 0 4px; }
.filters input[type="search"] {
  flex: 1 1 240px; background: var(--bg-raised); border: 1px solid var(--line-strong);
  color: var(--ink); border-radius: 8px; padding: 9px 12px; font: 14px var(--sans);
}
.filters input[type="search"]:focus { outline: 2px solid var(--accent); outline-offset: -1px; border-color: transparent; }
.filters select {
  background: var(--bg-raised); border: 1px solid var(--line-strong); color: var(--ink);
  border-radius: 8px; padding: 9px 10px; font: 13.5px var(--sans);
}
.result-count { font-family: var(--mono); font-size: 12.5px; color: var(--ink-faint); margin-left: auto; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; padding: 10px 0 4px; }
.chip {
  font-family: var(--mono); font-size: 12px; color: var(--ink-dim);
  border: 1px solid var(--line-strong); border-radius: 999px; padding: 4px 12px;
  background: transparent; cursor: pointer;
}
.chip:hover { color: var(--ink); border-color: var(--ink-faint); }
.chip[aria-pressed="true"] { color: #06251a; background: var(--accent); border-color: var(--accent); font-weight: 600; }

/* ---- サーバー一覧 ---- */
.server-list { list-style: none; margin: 14px 0 48px; padding: 0; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.server-row {
  display: grid;
  grid-template-columns: 52px minmax(220px, 2fr) minmax(0, 3fr) 110px 90px;
  gap: 14px; align-items: center;
  padding: 13px 18px; border-bottom: 1px solid var(--line); background: var(--bg-raised);
}
.server-row:last-child { border-bottom: none; }
.server-row:hover { background: var(--bg-inset); }
.rank { font-family: var(--mono); font-size: 12px; color: var(--ink-faint); }
.srv-name-cell { min-width: 0; }
.srv-name { font-weight: 600; font-size: 14.5px; color: var(--ink); display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.srv-name:hover { color: var(--accent); text-decoration: none; }
.srv-owner { font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint); display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.srv-desc { color: var(--ink-dim); font-size: 13px; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.srv-meta { font-family: var(--mono); font-size: 12px; color: var(--ink-faint); text-align: right; white-space: nowrap; }
.scorecell { display: flex; align-items: center; gap: 8px; justify-content: flex-end; }
.score-num { font-family: var(--mono); font-size: 15px; font-weight: 600; }
.grade-badge {
  font-family: var(--mono); font-weight: 700; font-size: 12px;
  width: 24px; height: 24px; border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #071018;
}
.grade-A { background: var(--grade-a); }
.grade-B { background: var(--grade-b); }
.grade-C { background: var(--grade-c); }
.grade-D { background: var(--grade-d); }
.grade-E { background: var(--grade-e); }
.noscript-note { display: block; font-family: var(--mono); font-size: 12px; color: var(--ink-faint); padding: 10px 0; }

@media (max-width: 760px) {
  .server-row { grid-template-columns: 1fr 90px; grid-auto-rows: auto; }
  .rank, .srv-desc, .srv-meta { display: none; }
}

/* ---- 汎用ページ ---- */
.page { padding: 40px 0 64px; }
.page h1 { font-size: clamp(24px, 4vw, 34px); letter-spacing: -0.02em; line-height: 1.2; margin: 0 0 8px; }
.page h1 em { font-style: normal; color: var(--accent); }
.page .sub { color: var(--ink-dim); margin: 0 0 26px; max-width: 680px; }
.breadcrumb { font-family: var(--mono); font-size: 12px; color: var(--ink-faint); margin-bottom: 18px; }
.breadcrumb .sep { margin: 0 8px; }
.prose { max-width: 720px; }
.prose h2 { font-size: 19px; margin: 34px 0 10px; letter-spacing: -0.01em; }
.prose p, .prose li { color: var(--ink-dim); font-size: 14.5px; }
.prose strong { color: var(--ink); }
.prose code { font-family: var(--mono); font-size: 13px; background: var(--bg-raised); border: 1px solid var(--line); padding: 1px 6px; border-radius: 5px; }

/* ---- 詳細ページ ---- */
.detail-head { display: flex; flex-wrap: wrap; align-items: flex-start; gap: 20px; justify-content: space-between; margin-bottom: 8px; }
.detail-head h1 { margin: 0; }
.score-panel {
  border: 1px solid var(--line-strong); border-radius: 14px; background: var(--bg-raised);
  padding: 18px 22px; display: flex; align-items: center; gap: 18px; min-width: 220px;
}
.score-big { font-family: var(--mono); font-size: 42px; font-weight: 700; line-height: 1; }
.score-big small { font-size: 15px; color: var(--ink-faint); font-weight: 400; }
.score-panel .grade-badge { width: 44px; height: 44px; font-size: 22px; border-radius: 10px; }
.score-panel .vetted-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); display: block; margin-top: 4px; }

.meta-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin: 24px 0; padding: 0; }
.meta-cell { border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px; background: var(--bg-raised); margin: 0; }
.meta-cell dt { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-faint); margin: 0 0 4px; }
.meta-cell dd { margin: 0; font-size: 14px; color: var(--ink); overflow-wrap: anywhere; }

.section { margin: 36px 0; }
.section h2 { font-size: 19px; margin: 0 0 14px; letter-spacing: -0.01em; }

/* スコア内訳 */
.pillars { display: grid; gap: 12px; margin: 0; padding: 0; list-style: none; }
.pillar { border: 1px solid var(--line); border-radius: 12px; background: var(--bg-raised); padding: 14px 18px; }
.pillar-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 8px; }
.pillar-head h3 { margin: 0; font-size: 14.5px; }
.pillar-head .pts { font-family: var(--mono); font-size: 14px; font-weight: 600; }
.pillar-head .pts small { color: var(--ink-faint); font-weight: 400; }
.bar { height: 6px; border-radius: 999px; background: var(--bg-inset); overflow: hidden; margin-bottom: 10px; }
.bar > span { display: block; height: 100%; border-radius: 999px; background: var(--accent); }
.signals { list-style: none; margin: 0; padding: 0; }
.signals li {
  display: flex; justify-content: space-between; gap: 14px;
  font-size: 13px; color: var(--ink-dim); padding: 3px 0;
}
.signals .sig-val { font-family: var(--mono); font-size: 12px; color: var(--ink-faint); white-space: nowrap; }
.signals .sig-pts { font-family: var(--mono); font-size: 12px; color: var(--accent); min-width: 44px; text-align: right; }
.signals .sig-pts.zero { color: var(--ink-faint); }

/* インストール */
.install-list { display: grid; gap: 10px; }
.install-item { border: 1px solid var(--line); border-radius: 10px; background: var(--bg-inset); padding: 12px 14px; }
.install-item .kind { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-faint); display: block; margin-bottom: 6px; }
.install-item code, .install-item a.remote-url { font-family: var(--mono); font-size: 13px; color: var(--ink); overflow-wrap: anywhere; }

/* ボタン */
.btn {
  display: inline-block; border-radius: 8px; padding: 9px 18px; font-size: 14px; font-weight: 600;
  border: 1px solid var(--line-strong); color: var(--ink);
}
.btn:hover { text-decoration: none; border-color: var(--ink-faint); }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #06251a; }
.btn-primary:hover { filter: brightness(1.1); }
.ext { font-size: 12px; }

/* methodology テーブル */
.table-scroll { overflow-x: auto; }
table.data { border-collapse: collapse; width: 100%; font-size: 13.5px; }
table.data th, table.data td { text-align: left; padding: 9px 12px; border-bottom: 1px solid var(--line); }
table.data th { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-faint); }
table.data td { color: var(--ink-dim); }
table.data td:first-child { color: var(--ink); }
table.data .num { text-align: right; font-family: var(--mono); }

.callout {
  border: 1px solid var(--line-strong); border-left: 3px solid var(--accent);
  border-radius: 10px; background: var(--bg-raised); padding: 14px 18px;
  color: var(--ink-dim); font-size: 14px; margin: 22px 0; max-width: 720px;
}
.callout strong { color: var(--ink); }

/* ---- フッター ---- */
.site-footer { border-top: 1px solid var(--line); padding: 28px 0 44px; margin-top: 20px; }
.site-footer .wrap { display: flex; flex-wrap: wrap; gap: 18px; justify-content: space-between; align-items: baseline; }
.footer-note { color: var(--ink-faint); font-size: 13px; max-width: 560px; }
.footer-note b { color: var(--ink-dim); }
.site-footer nav { display: flex; gap: 16px; flex-wrap: wrap; }
.site-footer nav a { color: var(--ink-faint); font-size: 13px; }
.site-footer nav a:hover { color: var(--accent); }
