/* ============================================================
   layout.css — レイアウト骨格（SPファースト → Tablet → PC）
   SP: ~767 / Tablet: 768-1023 / PC: 1024-
   ============================================================ */

/* ---------- コンテナ ---------- */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad-x); }

/* ---------- サイトヘッダー ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--c-glass); backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-bottom: 1px solid var(--c-line);
}
.header-bar { display: flex; align-items: center; gap: 12px; height: var(--header-h); }
.brand { display: flex; align-items: center; gap: 9px; }
.brand .glyph {
  width: 30px; height: 30px; border-radius: 8px; background: var(--accent);
  display: grid; place-items: center; color: var(--accent-ink); font-size: 15px; font-weight: 500; flex: 0 0 auto;
}
.brand .name { font-size: 17px; font-weight: 500; letter-spacing: .08em; }
.header-tools { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.icon-btn { width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; color: var(--c-ink-2); transition: background .15s, color .15s; }
.icon-btn:hover { background: var(--c-surface-2); color: var(--accent); }

/* PCヘッダー内 検索（SPでは隠す） */
.header-search { display: none; }
.header-search form { display: flex; align-items: center; gap: 8px; background: var(--c-surface-2); border: 1px solid var(--c-line-2); border-radius: 10px; padding: 8px 12px; min-width: 240px; }
.header-search input { flex: 1; border: none; outline: none; background: transparent; font-size: var(--fz-sm); color: var(--c-ink); min-width: 0; }
.header-search input::placeholder { color: var(--c-ink-3); }
.header-search button { color: var(--c-ink-3); display: grid; }

/* ジャンルナビ（SP=横スクロール / PC=インライン） */
.genre-nav { border-top: 1px solid var(--c-line); }
.genre-nav ul { display: flex; gap: 7px; overflow-x: auto; padding: 9px 0; scrollbar-width: none; }
.genre-nav ul::-webkit-scrollbar { display: none; }
.genre-nav a {
  flex: 0 0 auto; font-size: var(--fz-xs); color: var(--c-ink-2);
  padding: 6px 13px; border-radius: 20px; background: var(--c-surface-2); white-space: nowrap;
  transition: background .15s, color .15s;
}
.genre-nav a:hover, .genre-nav a.is-active { background: var(--accent); color: var(--accent-ink); }

/* ---------- メイン領域：コンテンツ＋サイドバー ---------- */
.site-content { padding: 22px 0 60px; }
.layout { display: block; }            /* SP: 1カラム */
.content-main { min-width: 0; }
.sidebar { margin-top: 40px; }         /* SP: 記事下に回る（要件） */

/* ---------- フッター ---------- */
.site-footer { background: var(--c-surface-3); border-top: 1px solid var(--c-line); padding: 34px 0 30px; }
.footer-inner { display: grid; gap: 22px; }
.footer-brand .glyph { width: 26px; height: 26px; border-radius: 7px; background: var(--accent); display: grid; place-items: center; color: var(--accent-ink); font-size: 13px; }
.footer-brand { display: flex; align-items: center; gap: 8px; }
.footer-brand .name { font-size: 15px; font-weight: 500; letter-spacing: .06em; }
.footer-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 14px; }
.footer-cols h4 { font-size: var(--fz-xs); font-weight: 500; margin-bottom: 9px; }
.footer-cols a { display: block; font-size: var(--fz-xs); color: var(--c-ink-2); padding: 4px 0; }
.footer-note { font-size: var(--fz-micro); color: var(--c-ink-3); line-height: 1.8; border-top: 1px solid var(--c-line-2); padding-top: 15px; }
.footer-copy { font-size: var(--fz-micro); color: var(--c-ink-3); letter-spacing: .04em; }

/* ===========================================================
   TABLET 768+
   =========================================================== */
@media (min-width: 768px) {
  :root { --pad-x: 28px; }
  .header-search { display: block; }
  .genre-nav ul { flex-wrap: wrap; overflow: visible; }
  .footer-cols { grid-template-columns: repeat(4, 1fr); }
  .footer-inner { grid-template-columns: 1.4fr 2.6fr; align-items: start; gap: 30px; }
}

/* ===========================================================
   PC 1024+ : コンテンツ＋追従サイドバー
   =========================================================== */
@media (min-width: 1024px) {
  :root {
    --fz-hero: 34px; --fz-h1: 30px; --fz-h2: 23px; --fz-h3: 18px;
    --fz-lead: 18px; --fz-body: 16px; --fz-sm: 14px;
    --header-h: 68px;
  }
  .site-content { padding: 34px 0 80px; }
  .layout { display: grid; grid-template-columns: minmax(0,1fr) var(--sidebar-w); gap: 44px; align-items: start; }
  .sidebar { margin-top: 0; position: sticky; top: calc(var(--header-h) + 20px); }
  .sidebar.with-nav { top: calc(var(--header-h) + 64px); }
  /* PCはジャンルナビをヘッダー1段に統合できるが、可読性優先で2段維持も可 */
}

/* 超ワイド抑制 */
@media (min-width: 1440px) { :root { --maxw: 1240px; } }
