:root{--ink:#111827;--muted:#6b7280;--border:#e5e7eb;--bg:#f7f7f9;}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Noto Sans JP",sans-serif;color:var(--ink);background:var(--bg)}
.site-header{background:#111827;color:#fff}
.brand{font-weight:700;text-decoration:none;color:#fff}
.nav a{color:#fff;margin-left:12px;text-decoration:none}
.site-footer{border-top:1px solid var(--border);margin-top:24px}
h1,h2,h3{line-height:1.35}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.tag{display:inline-block;border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:12px;margin-right:6px}
.btn{display:inline-block;border:1px solid var(--border);border-radius:2px;padding:8px 12px;text-decoration:none;color:#111;background:#fff}
.cover{width:100%;height:auto;border-radius:1px;border:1px solid var(--border);margin:8px 0}
.prose .content p{line-height:1.9}
.prose pre{padding:12px;border-radius:2px;background:#f0f2f5;overflow:auto;border:1px solid var(--border)}
img{max-width:100%;}

.container{
  max-width:1100px;
  margin:0 auto;
  padding:16px;
}

iframe{
 max-width:100%;
}

.sidebar h2 {
  font-size: 18px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
  margin-top: 24px;
}
.sidebar ul {
  list-style: none;
  padding: 0;
}
.sidebar ul a {
  text-decoration: none;
  color: var(--ink);
}

/* 2カラムレイアウト */
.main-wrapper{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px; /* 本文 / サイドバー */
  gap:32px;
}

/* 本文エリア */
.content-area{
  min-width:0; /* テキスト折返し安定 */
  background-color: #fff;
  padding:20px;
  box-sizing: border-box;
}

/* サイドバー */
.sidebar{
  width:100%;
  align-self:start;
  background-color: #fff;
  padding:20px;
  box-sizing: border-box;
}

/* カード全体をリンクにするための見た目調整 */
.link-card {
  display: block;
  text-decoration: none;
  color: inherit;
  border-radius: 1px;

  box-shadow: 0 1px 1px rgba(0,0,0,.06);
  background: var(--card-bg, #fff);
}

.link-card:hover {
  background: #f7f7f7;
}

.card-body { padding: 16px; }

.card .cover {
  width: 100%;
  height: auto;
  display: block;
  margin: 8px 0 12px;
  object-fit: cover;
}

/* 既存の .card-title/.card-meta があればそのままでOK。なければ軽く整える */
.card-title { font-size: 1.05rem; line-height: 1.45; margin: 0 0 6px; }
.card-meta { font-size: .9rem; color: #666; margin: 0 0 8px; }
.summary   { margin: 0; color: #444; }

@media (max-width: 1100px){
.container{max-width:100%;}
}

/* レスポンシブ：狭い画面では1カラムに */
@media (max-width: 960px){
  .main-wrapper{ grid-template-columns:1fr; }
  .sidebar{ margin-top:24px; }
}

/* 記事内の画像がはみ出さないように */
.content img, .prose img{
  max-width:100%;
  height:auto;
  display:block;
  margin:16px 0;
}

