/**
 * AI News Lab theme — main stylesheet
 *
 * Phase 2: Stillpoint デザインの本格移植。
 * Stillpoint 元 CSS のセリフ多用箇所は、フォント方針に従い原則ゴシック化。
 *
 * フォント方針（必ず守る）:
 *   - 記事本文 / 記事タイトル / 記事一覧 / メタ情報 / サイドバー本文 → ゴシック (--sans-jp)
 *   - セリフ (--serif) は限定用途のみ:
 *       a) ロゴ仮テキスト (.site-brand / .foot-brand .avatar .mark / .brand .mark)
 *       b) ヒーロー装飾的な大見出し (.hero-display-h1 — Phase 3で必要に応じて使う)
 *       c) 特集アクセント (任意、コメント必須)
 */

/* =========================================================
 * Design Tokens
 * ========================================================= */
:root {
    /* Color */
    --bg: #ffffff;
    --panel: #ffffff;
    --ink: #1c1a17;
    --ink-2: #3a352e;
    --muted: #8a8278;
    --rule: #e8e8e6;
    --rule-soft: #f1f1ef;

    /* Accent (Stillpoint brass を ティールに置換) */
    --accent: #4FD1C5;
    --accent-ink: #2D9A8E;
    --tag: #4FD1C5;

    /* Dark surfaces (placeholder, hero card) */
    --dark-surface: #2b2722;

    /* Typography */
    --sans-jp: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans",
               "BIZ UDPGothic", system-ui, "Segoe UI", Meiryo, sans-serif;
    --sans-en: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --serif: "Cormorant Garamond", "Noto Serif JP", "Times New Roman", serif;
    --mono: "JetBrains Mono", "Menlo", "Consolas", ui-monospace, monospace;

    /* Layout */
    --content-max: 1200px;
    --gutter: 28px;

    /* ===== Fluid typography 階段 (PC 1200px max ↔ SP 320px min で線形補間)
       式: clamp(SP値, calc(切片 + 係数 vw), PC値)
       係数 = (PC値 - SP値) * 100 / (1200 - 320) = (PC値 - SP値) / 8.8
       切片 = SP値 - 係数 * 3.2
       1200px (PC) で PC 値に到達、320px (SP) で SP 値で頭打ち。 */
    --fs-h1:           clamp(22px, calc(18.36px + 1.13636vw), 32px);  /* PC 32 / SP 22 */
    --fs-h2-wide:      clamp(18px, calc(15.82px + 0.68182vw), 24px);  /* PC 24 / SP 18 (.wide h2) */
    --fs-h2-hero:      clamp(17px, calc(15.18px + 0.56818vw), 22px);  /* PC 22 / SP 17 (.hero .slide h2) */
    --fs-h2-body:      clamp(17px, calc(15.91px + 0.34091vw), 20px);  /* PC 20 / SP 17 (.entry .body h2) */
    --fs-h3-body:      clamp(15px, calc(14.27px + 0.22727vw), 17px);  /* PC 17 / SP 15 (.entry .body h3 / .post-card h3 / .arch-row h3) */
    --fs-card-min:     clamp(16px, calc(15.27px + 0.22727vw), 18px);  /* PC 18 / SP 16 (.post-card-min__title) */
    --fs-mini:         clamp(13px, calc(12.64px + 0.11364vw), 14px);  /* PC 14 / SP 13 (.hero-side .card h3 / .mini h4) */
    --fs-sec-title:    clamp(14px, calc(11.82px + 0.68182vw), 20px);  /* PC 20 / SP 14 (.sec-title / .strip-title) */
}

/* =========================================================
 * Reset
 * ========================================================= */
*,
*::before,
*::after { box-sizing: border-box; }

html,
body { margin: 0; padding: 0; }

/* Smooth scroll for in-page anchor links (e.g. 目次 → 各 H2 へ). */
/* Phase 1 で対応した範囲: 記事本文のスムーススクロール。 */
/* Phase 1 では :focus-visible での即時ジャンプは強制せず、ブラウザ既定に任せる。 */
html {
    scroll-behavior: smooth;
}
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
}

img,
svg,
video { max-width: 100%; display: block; height: auto; }

a {
    color: inherit;
    text-decoration: none;
}
a:hover { color: var(--accent-ink); }

button { font-family: inherit; }

/* =========================================================
 * Base
 * ========================================================= */
body {
    background: var(--bg);
    color: var(--ink);
    font-family: var(--sans-jp);
    font-size: 15px;
    line-height: 1.75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

.wrap {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 0 var(--gutter);
}

/* =========================================================
 * Top utility bar (Phase 2 mark up only, default非表示)
 * ========================================================= */
.util {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.16em;
    color: var(--ink-2);
    width: 1200px;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}
.util-tagline {
    margin: 0;
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.04em;
    color: var(--ink-2);
}
/* タグラインを util に移動したので .brand .tag は PC でも非表示 */
.brand .tag { display: none; }
.util .social { display: flex; gap: 14px; align-items: center; }
.util .social .ico {
    width: 14px; height: 14px;
    display: none;                  /* SNSアイコンは MVP では非表示。Phase で要なら有効化 */
    align-items: center; justify-content: center;
    color: var(--ink);
}
/* <nav class="nav"> 自体はレイアウト指定なし。flex 並びは内側 <ul.nav__list> で行う */
.util .nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 28px;
}
.util .nav__list a { position: relative; }
.util .nav__list a:hover { color: var(--accent-ink); }

/* =========================================================
 * Brand (Stillpoint .brand 等価。Phase 1 の .site-brand と併存)
 * ========================================================= */
.brand,
.site-header__inner {
    text-align: center;
    padding: 40px 0 6px;
}
.brand .mark {
    /* ロゴ画像コンテナ */
    margin: 0 auto 10px;
    line-height: 1;
}
.brand .mark a {
    /* 親 .mark (block) を基準に % を解決させたいので block で出す。
       brand text-align:center により内部の img はセンタリングされる */
    display: block;
    color: inherit;
    text-decoration: none;
}
/* ロゴ画像: PC は固定 width: 450px、SP は親に合わせて縮小 */
.brand .brand-logo {
    display: block;
    width: 450px;
    max-width: 100%;
    height: auto;
    margin: 0 auto 20px auto;
}
/* Phase 1 残置のテキストロゴ用クラス（旧マークアップ用、フォールバック） */
.site-brand {
    font-family: var(--serif);
    font-weight: 500;
    font-size: 36px;
    letter-spacing: 0.4em;
    padding-left: 0.4em;
    color: var(--ink);
    margin: 0 0 6px;
}
.site-brand a { color: inherit; }
.brand .tag,
.site-tagline {
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.18em;
    color: var(--muted);
    margin: 0 0 14px;
}

/* =========================================================
 * Primary nav (.pnav は Stillpoint オリジナル枠線スタイル、
 * Phase 1 の .site-pnav は枠線無しのフラット版。両対応)
 * ========================================================= */
.pnav {
    display: flex;
    justify-content: center;
    margin: 22px 0 36px;
}
.pnav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    border: 1px solid var(--rule);
    background: var(--panel);
}
.pnav li { border-right: 1px solid var(--rule); }
.pnav li:last-child { border-right: none; }
.pnav a {
    display: block;
    padding: 16px 32px;
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.22em;
    color: var(--ink-2);
}
.pnav a.on,
.pnav a:hover { color: var(--accent-ink); }
.pnav a.on { position: relative; }
.pnav a.on::after {
    content: "";
    position: absolute;
    left: 50%; bottom: 7px;
    transform: translateX(-50%);
    width: 18px; height: 1px;
    background: var(--accent);
}

/* Phase 1 のフラット版（中央揃え横並び） */
.site-pnav { margin-top: 14px; }
.site-pnav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 28px;
    justify-content: center;
    font-family: var(--sans-jp);
}
.site-pnav__list li { line-height: 1; }
.site-pnav__list a {
    display: inline-block;
    padding: 8px 4px;
    font-size: 12.5px;
    letter-spacing: 0.18em;
    color: var(--ink-2);
}
.site-pnav__list a:hover { color: var(--accent-ink); }
.site-pnav__placeholder {
    color: var(--muted);
    font-size: 12px;
    margin: 0;
}

/* =========================================================
 * Site header (Phase 1)
 * ========================================================= */
.site-header {
    border-bottom: 1px solid var(--rule);
    padding: 26px 0 22px;
    background: var(--panel);
}

/* =========================================================
 * Section title
 * ========================================================= */
.sec-title {
    color: var(--accent);
    font-family: var(--sans-jp);
    font-size: var(--fs-sec-title);  /* fluid: PC 20px → SP 14px */
    letter-spacing: 0.16em;
    font-weight: 500;
    margin: 0 0 18px;
    text-transform: uppercase;
}

/* =========================================================
 * Main
 * ========================================================= */
.site-main { background: var(--bg); }
.site-main__inner { padding: 40px 0 60px; }

.page-header { margin: 0 0 28px; }
.page-title {
    margin: 0;
    font-family: var(--sans-jp);    /* ゴシック：ニュース系見出し */
    font-weight: 700;
    font-size: 22px;
    letter-spacing: 0.02em;
    color: var(--ink);
}

/* =========================================================
 * カテゴリタグ (.tag) を全ページで非表示にする
 *
 * ユーザー指示: HERO スライダー / 右サイドカード / wide / 個別記事ページ
 * (.entry-hero) / 各カードテンプレ (post-card / mini / arch-row / rec-card)
 * すべての .tag を消す。
 *
 * HTML 側 (front-page.php / template-parts / single.php) には残しているが、
 * CSS で display:none にして表示を消す。将来「ここだけ復活」と決まれば
 * 個別セレクタで上書き復活可能。
 * ========================================================= */
.hero .slide .tag,
.hero-side .card .tag,
.wide .tag,
.entry-hero .tag,
.post-card .tag,
.mini .tag,
.arch-row .tag,
.rec-card .tag,
.feat3 .tag {
    display: none;
}

/* =========================================================
 * SP バーガーメニュー (.burger / .sp-drawer)
 *
 * PC (>= 901px): .burger / .sp-drawer は非表示、.util / .pnav が通常表示
 * SP (<= 900px): .burger を表示、.util / .pnav を隠す、.sp-drawer を展開可能に
 * ========================================================= */
.burger {
    display: none; /* PC では非表示、SP メディアクエリで block に */
    position: absolute;
    top: 0;
    right: 0;
    width: 56px;
    height: 100%;       /* ヘッダ高さいっぱい (浮かない、ぴったり収まる) */
    padding: 0;
    background: transparent; /* 背景なし、親ヘッダの白が透ける */
    border: 0;
    border-radius: 0;
    cursor: pointer;
    z-index: 60;
}
.burger:hover { background: transparent; }
.burger:focus-visible { outline: 2px solid var(--accent-ink); outline-offset: -2px; }
.burger-line {
    display: block;
    width: 22px;
    height: 2px;
    background: #111; /* 線色 (黒寄りのダーク) */
    margin: 5px auto;
    border-radius: 1px;
    transition: transform 250ms cubic-bezier(.22,.61,.36,1), opacity 200ms, background 200ms;
    transform-origin: center;
}
.burger:hover .burger-line { background: var(--accent-ink); }
.burger[aria-expanded="true"] .burger-line-1 { transform: translateY(6px) rotate(45deg); }
.burger[aria-expanded="true"] .burger-line-2 { opacity: 0; }
.burger[aria-expanded="true"] .burger-line-3 { transform: translateY(-6px) rotate(-45deg); }

.sp-drawer {
    display: none; /* PC では非表示、SP メディアクエリで block に */
    position: fixed;
    /* SP ヘッダの実高さに自動追従 (JS で --sp-header-h を毎回セット)。
       フォールバックは 58px (測定値)。 */
    top: var(--sp-header-h, 58px);
    left: 0;
    right: 0;
    background: #2a2a2a; /* sp-menu-2.jpg 準拠のダークグレー */
    color: #fff;
    z-index: 40;   /* ヘッダ (50) / バーガー (60) より下、コンテンツより上 */
    transform: translateY(-110%);
    transition: transform 350ms cubic-bezier(.22,.61,.36,1);
    max-height: calc(100vh - var(--sp-header-h, 58px));
    overflow-y: auto;
    padding: 0 0 32px;
    box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.sp-drawer.is-open { transform: translateY(0); }
.sp-drawer-inner { padding: 0; }

/* ドロワー内のナビ (ainews_render_pnav の出力を内包) */
.sp-drawer-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.sp-drawer-nav li {
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.sp-drawer-nav a {
    display: block;
    padding: 18px 24px;
    color: #fff;
    font-family: var(--sans-jp);
    font-size: 15px;
    letter-spacing: 0.04em;
    text-decoration: none;
    transition: color 200ms;
}
.sp-drawer-nav a:hover,
.sp-drawer-nav a:focus-visible {
    color: var(--accent);
}

/* ドロワー内のユーティリティリンク (運営者プロフィール / お問い合わせ / RSS) */
.sp-drawer-util {
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid rgba(255,255,255,.18);
}
.sp-drawer-util li { margin: 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.sp-drawer-util a {
    display: block;
    padding: 14px 24px;
    color: rgba(255,255,255,.78);
    font-family: var(--sans-jp);
    font-size: 13px;
    letter-spacing: 0.04em;
    text-decoration: none;
}
.sp-drawer-util a:hover { color: var(--accent); }

/* ドロワー背後のクリックで閉じる用 backdrop (透明、is-open 時のみ被さる) */
.sp-drawer-backdrop {
    display: none;
    position: fixed;
    /* ヘッダ高さに追従、バーガークリックを邪魔しない */
    inset: var(--sp-header-h, 58px) 0 0 0;
    background: transparent;
    border: 0;
    cursor: pointer;
    z-index: 35;
}
.sp-drawer-backdrop.is-visible { display: block; }

/* SP 切替: .pnav と util を隠して .burger と .sp-drawer を有効化 */
@media (max-width: 900px) {
    .util { display: none; }
    .pnav { display: none; }
    .burger { display: block; }
    .sp-drawer { display: block; }
    .brand { position: relative; }
}

/* =========================================================
 * Hero (front-page)
 * ========================================================= */
.hero {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 0;
    margin-bottom: 54px;
}
/* ----- 左の縦スライダー (.hero-slider) ----- */
/* 3 枚のスライドを重ね、JS で is-active / is-prev クラスを付け替えて
   下から上へスライドさせる (下から次のスライドが現れる)。
   ドットインジケータは .hero .dots (既存定義) を再利用。 */
.hero .hero-slider {
    position: relative;
    height: 500px;
    overflow: hidden;
    background: var(--dark-surface);
}
.hero .hero-slider .slide {
    position: absolute;
    inset: 0;
    height: 100%;
    transform: translateY(100%); /* 初期: 画面下に待機 */
    transition: transform 1400ms cubic-bezier(.22, .61, .36, 1);
    will-change: transform;
}
.hero .hero-slider .slide.is-active {
    transform: translateY(0); /* 現在表示中 */
    z-index: 2;
}
.hero .hero-slider .slide.is-prev {
    transform: translateY(-100%); /* 上にスライドアウト済み */
    z-index: 1;
}
/* JS が起動する前の最初の描画でも 1 枚目を表示したい */
.hero .hero-slider .slide:first-child:not(.is-active):not(.is-prev) {
    transform: translateY(0);
}
.hero .slide {
    position: relative;
    display: block;
    height: 500px;
    overflow: hidden;
    background: var(--dark-surface);
}
.hero .slide .tag {
    position: absolute;
    left: 0; top: 14px;
    background: var(--tag);
    color: #fff;
    font-family: var(--sans-jp);
    font-size: 10px;
    letter-spacing: 0.22em;
    padding: 5px 12px;
    z-index: 3;
}
.hero .slide .scrim {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 60%;
    z-index: 1;
    background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.78));
}
.hero .slide .meta {
    position: absolute;
    left: 22px; right: 22px; bottom: 22px;
    z-index: 2;
    color: #fff;
}
.hero .slide h2 {
    font-family: var(--sans-jp);
    font-weight: 700;
    font-size: var(--fs-h2-hero);
    line-height: 1.5;
    margin: 0;
    color: #fff;
    text-wrap: pretty;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.hero .slide .stamp {
    font-family: var(--mono);
    font-size: 14px;
    color: #d9d0c0;
    letter-spacing: 0.18em;
    margin-top: 8px;
}
.hero .dots {
    position: absolute;
    right: 14px; top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 9px;
    z-index: 2;
}
.hero .dots i {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,.45);
    display: block;
    border: 1px solid rgba(255,255,255,.7);
}
.hero .dots i.on { background: #fff; }
.hero .dots i { cursor: pointer; transition: background 200ms; }
.hero .dots i:hover { background: rgba(255,255,255,.8); }

.hero-side {
    display: grid;
    grid-template-rows: 1fr 1fr;
    gap: 0;
    /* スライダー側の 500px に合わせる (1fr 1fr 自動分配 = 各 250px) */
}
.hero-side .card {
    position: relative;
    overflow: hidden;
    background: var(--dark-surface);
}
.hero-side .card .tag {
    position: absolute;
    left: 0; top: 12px;
    background: var(--tag);
    color: #fff;
    font-family: var(--sans-jp);
    font-size: 10px;
    letter-spacing: 0.18em;
    padding: 4px 11px;
    z-index: 3;
}
.hero-side .card .scrim {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 60%;
    z-index: 1;
    background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.78));
}
.hero-side .card .meta {
    position: absolute;
    left: 16px; right: 16px; bottom: 14px;
    z-index: 2;
}
.hero-side .card h3 {
    /* カード内見出し：ゴシック化、タイトルは 2 行で省略 */
    font-family: var(--sans-jp);
    font-weight: 500;
    font-size: var(--fs-mini);
    line-height: 1.55;
    margin: 0;
    color: #fff;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* オプション: ヒーロー大見出し用クラス。font-policy で「ヒーロー装飾的な大見出し」例外。
   front-page.php の特集記事タイトルで使う想定。任意採用。 */
.hero-display-h1 {
    font-family: var(--serif);
    font-weight: 400;
    font-size: 30px;
    line-height: 1.25;
    margin: 0;
    color: #fff;
}

/* =========================================================
 * Featured grid (3-up)
 * ========================================================= */
.feat3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    margin-bottom: 58px;
}

/* Post card (Stillpoint .post-card、見出しはゴシック化) */
.post-card .thumb {
    position: relative;
    height: 200px;
    overflow: hidden;
    background: var(--dark-surface);
}
.post-card .tag {
    position: absolute;
    left: 0; top: 14px;
    background: var(--tag);
    color: #fff;
    font-family: var(--sans-jp);
    font-size: 10px;
    letter-spacing: 0.18em;
    padding: 5px 12px;
}
.post-card h3 {
    /* 記事カード見出し：強制ゴシック（Stillpoint は serif）
       タイトルは最大 2 行で省略 (3 行以上のタイトルでカード並びがガタつくのを防ぐ)。
       1 行タイトルでも min-height で 2 行分の高さを確保し、カードの上下が揃う。 */
    font-family: var(--sans-jp);
    font-weight: 600;
    font-size: var(--fs-h3-body);
    line-height: 1.55;
    margin: 14px 0 8px;
    color: var(--ink);
    text-wrap: pretty;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(17px * 1.55 * 2);
}
.post-card h3 a:hover { color: var(--accent-ink); }
.post-card p {
    /* 本文 excerpt も 2 行で省略、カード並びの高さを揃える */
    margin: 0 0 10px;
    color: var(--ink-2);
    font-size: 14px;
    line-height: 1.7;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(14px * 1.7 * 2);
}
.post-card .stamp {
    font-family: var(--mono);
    font-size: 14px;
    color: var(--muted);
    padding-top: 8px;
    border-top: 1px solid var(--rule);
    display: flex;
    gap: 14px;
}
.post-card .stamp .sep { color: var(--rule); }

/* Phase 1 minimum post card */
.post-list { display: grid; gap: 28px; }
.post-card-min {
    padding-bottom: 24px;
    border-bottom: 1px solid var(--rule-soft);
}
.post-card-min__title {
    margin: 0 0 8px;
    font-family: var(--sans-jp);
    font-weight: 600;
    font-size: var(--fs-card-min);
    line-height: 1.55;
    color: var(--ink);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(18px * 1.55 * 2);
}
.post-card-min__title a:hover { color: var(--accent-ink); }
.post-card-min__stamp {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    color: var(--muted);
    margin-bottom: 8px;
    display: flex;
    gap: 10px;
}
.post-card-min__stamp .sep { color: var(--rule); }
.post-card-min__excerpt {
    font-family: var(--sans-jp);
    font-size: 14px;
    color: var(--ink-2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* =========================================================
 * Two-column main (news + sidebar)
 * ========================================================= */
.twocol {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 36px;
    margin-bottom: 48px;
}
.twocol .news {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    align-content: start;
}
.twocol .post-card .thumb { height: 200px; }

/* =========================================================
 * Sidebar profile card
 * ========================================================= */
.profile {
    border: 1px solid var(--rule);
    background: #fff;
    padding: 28px 22px 22px;
    text-align: center;
    font-family: var(--sans-jp);
}
.profile .avatar {
    width: 104px; height: 104px;
    border-radius: 50%;
    margin: 0 auto 14px;
    overflow: hidden;
    position: relative;
}
.profile .avatar-note {
    display: block;
    font-size: 12px;
    color: var(--muted);
    margin-top: 6px;
    letter-spacing: 0.04em;
}
.profile p {
    margin: 0 0 18px;
    color: var(--ink-2);
    font-size: 14px;
    line-height: 1.8;
    text-align: left;
    font-family: var(--sans-jp);
}
.profile .btn {
    display: block;
    background: var(--ink);
    color: #fff;
    text-align: center;
    padding: 13px 0;
    font-family: var(--sans-jp);
    font-size: 11px;
    letter-spacing: 0.32em;
}
.profile .btn:hover { background: var(--accent-ink); color: #fff; }
.profile .socials {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-top: 16px;
    color: var(--ink);
}
.profile .socials svg { display: none; }    /* SNS非表示 (MVP) */

/* =========================================================
 * Banner strip
 * ========================================================= */
.banner {
    height: 78px;
    position: relative;
    overflow: hidden;
    margin: 18px 0 32px;
    background: #161310;
    color: #f1e9da;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 26px;
}
.banner .left {
    font-family: var(--sans-jp);    /* Stillpoint は serif 但しゴシック化 */
    font-size: 16px;
    letter-spacing: 0.04em;
}
.banner .right {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.22em;
    color: #bda984;
}
.banner.alt {
    background: #fbf9f5;
    color: var(--ink);
    border: 1px solid var(--rule);
}
.banner.alt .right { color: var(--accent-ink); }
.banner .ornament {
    position: absolute;
    left: 50%; top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
    width: 24px; height: 24px;
    border: 1px solid #5a4a3a;
    transform-origin: center;
}

/* =========================================================
 * Wide feature card
 * ========================================================= */
.wide {
    position: relative;
    display: block;          /* <a class="wide"> は既定で inline のため明示 */
    height: 380px;
    overflow: hidden;
    margin-bottom: 22px;
    background: var(--dark-surface);
    color: #f5efe4;
}
.wide .tag {
    position: absolute;
    left: 0; top: 18px;
    background: var(--tag);
    color: #fff;
    font-family: var(--sans-jp);
    font-size: 10px;
    letter-spacing: 0.22em;
    padding: 6px 14px;
}
.wide .meta {
    position: absolute;
    left: 28px; right: 28px; bottom: 26px;
    color: #f5efe4;
}
.wide h2 {
    /* ユーザー指示でゴシック統一 (旧: 例外でセリフ採用していた)。
       タイトルは 2 行で省略、line-clamp + overflow-wrap で長文タイトルでも崩れない。 */
    font-family: var(--sans-jp);
    font-weight: 700;
    font-size: var(--fs-h2-wide);
    line-height: 1.4;
    margin: 0;
    max-width: 80%;
    color: #f5efe4;
    overflow-wrap: anywhere;
    text-wrap: pretty;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* =========================================================
 * Special posts (2x2 mini cards)
 * ========================================================= */
.special {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.mini {
    position: relative;
    height: 158px;
    overflow: hidden;
    background: var(--dark-surface);
    color: #fff;
}
.mini .tag {
    position: absolute;
    left: 0; top: 10px;
    background: var(--tag);
    color: #fff;
    font-family: var(--sans-jp);
    font-size: 9px;
    letter-spacing: 0.18em;
    padding: 4px 10px;
}
.mini .meta {
    position: absolute;
    left: 12px; right: 12px; bottom: 10px;
}
.mini h4 {
    /* mini card 見出し：ゴシック化（Stillpoint は serif） */
    font-family: var(--sans-jp);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.45;
    margin: 0 0 4px;
}
.mini .stamp {
    font-family: var(--mono);
    font-size: 12px;
    color: #d9d0c0;
}

/* =========================================================
 * Pick up
 * ========================================================= */
.pick .post-card .thumb { height: 200px; }
.pick .post-card h3 { font-size: 16px; }

/* =========================================================
 * Lower section (3 cols)
 * ========================================================= */
.lower {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 28px;
    margin-bottom: 48px;
}
.lower .post-card .thumb { height: 200px; }

/* =========================================================
 * Category & archives grid (sidebar)
 * ========================================================= */
.meta-grid {
    /* カテゴリは縦並びにする (旧: 2列 grid → 1列 stack) */
    display: block;
    border-top: 1px solid var(--rule);
    border-left: 1px solid var(--rule);
    border-right: 1px solid var(--rule);
}
.meta-grid a {
    padding: 14px 16px;
    border-bottom: 1px solid var(--rule);
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.22em;
    color: var(--ink-2);
    display: flex;
    align-items: center;
    gap: 10px;
}
.meta-grid a::before {
    content: "";
    width: 6px; height: 6px;
    background: var(--accent);
    display: inline-block;
    border-radius: 50%;
}
.meta-grid a:hover { color: var(--accent-ink); }

.archives select {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--rule);
    background: var(--panel);
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.22em;
    color: var(--ink-2);
    appearance: none;
    background-image:
      linear-gradient(45deg, transparent 50%, var(--muted) 50%),
      linear-gradient(135deg, var(--muted) 50%, transparent 50%);
    background-position:
      calc(100% - 18px) 50%,
      calc(100% - 13px) 50%;
    background-size: 5px 5px, 5px 5px;
    background-repeat: no-repeat;
}

/* =========================================================
 * Load more (Phase 1 の .pagination との両対応)
 * ========================================================= */
.loadmore {
    display: flex;
    justify-content: center;
    margin: 8px 0 60px;
}
.loadmore button,
.loadmore a {
    display: inline-block;
    border: 1px solid var(--rule);
    background: var(--panel);
    padding: 14px 60px;
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.16em;
    color: var(--ink-2);
    cursor: pointer;
    text-decoration: none;
}
.loadmore button:hover,
.loadmore a:hover {
    color: var(--accent-ink);
    border-color: var(--accent);
}

.pagination {
    margin-top: 36px;
    display: flex;
    justify-content: center;
}
.pagination .nav-links {
    display: flex;
    gap: 8px;
    font-family: var(--mono);
    font-size: 12px;
}
.pagination .page-numbers {
    padding: 8px 14px;
    border: 1px solid var(--rule);
    color: var(--ink-2);
}
.pagination .page-numbers.current {
    background: var(--ink);
    color: #fff;
    border-color: var(--ink);
}
.pagination a.page-numbers:hover {
    color: var(--accent-ink);
    border-color: var(--accent);
}

/* =========================================================
 * Carousel strip (FROM THE ARCHIVE)
 * ========================================================= */
.strip-title,
.strip-wrap h4 {
    /* h4 を .strip-wrap の外に出した (矢印を .strip の中央に置くため)。
       旧 `.strip-wrap h4` と完全同値で見た目を維持。 */
    color: var(--accent);
    font-family: var(--sans-jp);
    font-size: var(--fs-sec-title);  /* fluid: PC 20px → SP 14px、.sec-title と同じ */
    letter-spacing: 0.16em;
    margin: 0 0 20px;
    font-weight: 500;
    text-transform: uppercase;
}
.strip-wrap {
    position: relative;
    margin: 20px 0 70px;
}
.strip-wrap h4 {
    color: var(--accent);
    font-family: var(--sans-jp);
    font-size: 20px;
    letter-spacing: 0.16em;
    margin: 0 0 20px;
    font-weight: 500;
    text-transform: uppercase;
}
.strip {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    /* height は cell の aspect-ratio に従う (PC でも正方形) */
    overflow: hidden;
    position: relative;
}
.strip .cell {
    position: relative;
    overflow: hidden;
    background: var(--dark-surface);
    aspect-ratio: 1 / 1;  /* PC でも正方形 */
}
.strip.strip-auto { display: block; }
.strip-track {
    display: flex;
    gap: 2px;
    will-change: transform;
}
.strip-track > .cell {
    flex: 0 0 calc((100% - 12px) / 7);
    aspect-ratio: 1 / 1;
}
.strip-wrap .arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 36px; height: 36px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--rule);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-2);
    cursor: pointer;
}
.strip-wrap .arrow.l { left: -46px; }
.strip-wrap .arrow.r { right: -46px; }

/* =========================================================
 * Footer
 * ========================================================= */
.site-footer,
footer.site-footer {
    border-top: 1px solid var(--rule);
    padding: 28px 0;
    background: #fafafa;
    color: var(--muted);
    font-family: var(--sans-jp);
    font-size: 12px;
}
.site-footer__copy {
    margin: 0 0 4px;
    text-align: center;
    letter-spacing: 0.06em;
}
.site-footer__note {
    margin: 0;
    text-align: center;
    font-size: 11px;
    color: var(--muted);
}

/* Stillpoint 拡張フッター */
.foot-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1.4fr;
    gap: 36px;
    align-items: flex-start;
    padding: 56px 0 24px;
}
/* PC では .foot-cols は2列分（MENU + SECTIONS の横並び）を占有する。
   SP メディアクエリで .foot-grid が 1fr 化されたとき grid-column: span 2 が
   余分な空列を作る不具合があったため、インラインstyleではなくCSSで管理する。 */
@media (min-width: 901px) {
    .foot-grid > .foot-cols { grid-column: span 2; }
}
.foot-brand .avatar {
    width: 100%;
    aspect-ratio: 1/1;
    background: var(--dark-surface);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.foot-brand .avatar .mark {
    /* フッターロゴ：font-policy のロゴ例外でセリフ採用 */
    font-family: var(--serif);
    font-size: 24px;
    letter-spacing: 0.36em;
    color: #f5efe4;
    padding-left: 0.36em;
    position: relative;
    z-index: 2;
}
.foot-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.foot-col h5 {
    margin: 0 0 14px;
    color: var(--accent);
    font-family: var(--sans-jp);
    font-size: 20px;
    letter-spacing: 0.16em;
    font-weight: 600;
    text-transform: uppercase;
}
.foot-col ul { list-style: none; margin: 0; padding: 0; }
.foot-col li {
    padding: 8px 0;
    border-bottom: 1px solid var(--rule-soft);
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.08em;
    color: var(--ink-2);
}
.foot-col li a:hover { color: var(--accent-ink); }

.foot-recent {
    display: grid;
    grid-template-columns: repeat(3, 133px);
    gap: 14px;
}
.frec { width: 133px; }
.frec .thumb {
    position: relative;
    aspect-ratio: 1 / 1;  /* 133px × 133px の正方形 */
    overflow: hidden;
    background: var(--dark-surface);
}
.frec h6 {
    /* RECENTLY 記事タイトル：ゴシック */
    font-family: var(--sans-jp);
    font-weight: 500;
    font-size: 14px;
    line-height: 1.5;
    color: var(--ink-2);
    margin: 8px 0 4px;
}
.frec .date {
    font-family: var(--mono);
    font-size: 12px;
    color: var(--muted);
}

.foot-bottom {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--rule);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--sans-jp);
    font-size: 12px;
    letter-spacing: 0.18em;
    color: var(--muted);
}
/* <nav class="links"> 自体はレイアウト指定なし。flex 並びは内側 <ul.foot-bottom__list> で行う */
.foot-bottom__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 22px;
    flex-wrap: wrap;
}

/* =========================================================
 * Image / Striped placeholder system
 * Stillpoint .ph を踏襲。アイキャッチ未設定時のフォールバック。
 * ========================================================= */
img.ph {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    background: linear-gradient(180deg, #3b332b, #1a1612);
}
.ph {
    position: absolute;
    inset: 0;
    background:
      repeating-linear-gradient(135deg,
        rgba(255,255,255,.05) 0 14px,
        rgba(255,255,255,0) 14px 28px),
      linear-gradient(180deg, var(--ph-top, #3b332b), var(--ph-bot, #1a1612));
}
.ph::after {
    content: attr(data-ph);
    position: absolute;
    left: 14px; bottom: 10px;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    color: rgba(255,255,255,.55);
    background: rgba(0,0,0,.28);
    padding: 3px 7px;
}
/* data-ph 未設定 or 空値の場合は ::after を抑止
   Stillpoint デモのデバッグ用画像ラベルは本番では出さない */
.ph[data-ph=""]::after,
.ph:not([data-ph])::after {
    content: none;
}
/* tonal variations */
.ph.sky   { --ph-top: #5b6b78; --ph-bot: #2a323a; }
.ph.dawn  { --ph-top: #a07758; --ph-bot: #4a3526; }
.ph.stone { --ph-top: #6a655c; --ph-bot: #2a2620; }
.ph.deep  { --ph-top: #312a23; --ph-bot: #0e0b08; }
.ph.glass { --ph-top: #5a4a6a; --ph-bot: #221a30; }
.ph.sea   { --ph-top: #4a6a78; --ph-bot: #1a2830; }
.ph.gold  { --ph-top: #a87544; --ph-bot: #3a2616; }

/* =========================================================
 * PR Disclosure (旅ログ playbook §2.2 準拠)
 * ========================================================= */
.promotion-notice {
    font-family: var(--sans-jp);
    font-size: 12.5px;
    color: var(--muted);
    margin: 0 0 22px;
    line-height: 1.5;
    padding: 8px 12px;
    background: #fafafa;
    border-left: 2px solid var(--rule);
    letter-spacing: 0.04em;
}

/* =========================================================
 * Affiliate Card Shortcode
 * [afcard id="..." layout="vertical|horizontal|compact"] の出力スタイル。
 *
 * 使い分けガイド:
 *   - compact    : 本文中インライン推奨。テキスト中心、最も自然
 *   - horizontal : 本文中の補助導線として基本。画像左 + テキスト右
 *   - vertical   : 記事末尾 / 専用セクション向け。本文中の連発は避ける
 *
 * デザイン方針:
 *   - 白背景 / 薄い枠線 / 控えめな角丸 / 読みやすい余白
 *   - 画像・ロゴが主役になりすぎない（縦型でも max-height で抑える）
 *   - CTAは目立たせるが派手すぎない
 * ========================================================= */
.afcard {
    margin: 22px 0;
    border: 1px solid var(--rule);
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    transition: border-color .15s ease, box-shadow .15s ease;
    font-family: var(--sans-jp);
}
.afcard:hover {
    border-color: var(--accent);
    box-shadow: 0 1px 8px rgba(0,0,0,.04);
}
.afcard a {
    display: block;
    color: inherit;
    padding: 0;
}
.afcard__thumb {
    position: relative;
    overflow: hidden;
    background: var(--dark-surface);
}
.afcard__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.afcard__body {
    padding: 14px 18px 16px;
}
.afcard__cat {
    display: inline-block;
    font-family: var(--mono);
    font-size: 14px;
    letter-spacing: 0.18em;
    color: var(--accent-ink);
    text-transform: uppercase;
    margin-bottom: 6px;
}
.afcard__name {
    margin: 0 0 6px;
    font-family: var(--sans-jp);    /* ゴシック */
    font-weight: 600;
    font-size: 16px;
    line-height: 1.55;
    color: var(--ink);
}
.afcard__desc {
    margin: 0 0 12px;
    font-family: var(--sans-jp);
    font-size: 14px;
    line-height: 1.7;
    color: var(--ink-2);
}
.afcard__cta {
    display: inline-block;
    font-family: var(--mono);
    font-size: 14px;
    letter-spacing: 0.18em;
    color: var(--accent-ink);
    text-transform: uppercase;
    padding: 2px 0;
    border-bottom: 1px solid var(--accent);
}
.afcard a:hover .afcard__cta {
    border-bottom-color: var(--accent-ink);
}

/* ---------- Vertical (記事末尾 / 専用セクション向け) ----------
   画像エリアの高さを max-height で抑え、広告バナー感を出さない。 */
.afcard--vertical .afcard__thumb {
    height: 200px;
    max-height: 200px;
}
@media (max-width: 640px) {
    .afcard--vertical .afcard__thumb {
        height: 160px;
        max-height: 160px;
    }
}

/* ---------- Horizontal (本文中の補助導線：基本これを使う) ---------- */
.afcard--horizontal a {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 16px;
    align-items: stretch;
}
.afcard--horizontal .afcard__thumb {
    height: 100%;
    min-height: 110px;
    max-height: 140px;
}
.afcard--horizontal .afcard__body {
    padding: 12px 16px 12px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.afcard--horizontal .afcard__name { font-size: 14px; }
.afcard--horizontal .afcard__desc {
    font-size: 12px;
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
@media (max-width: 480px) {
    .afcard--horizontal a {
        grid-template-columns: 100px 1fr;
        gap: 12px;
    }
    .afcard--horizontal .afcard__thumb { min-height: 90px; max-height: 110px; }
}

/* ---------- Compact (テキスト中心、画像なし。本文に最も自然に溶け込む) ---------- */
.afcard--compact {
    margin: 18px 0;
}
.afcard--compact a {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 16px;
    padding: 12px 16px;
}
.afcard--compact .afcard__thumb { display: none; }
.afcard--compact .afcard__body { padding: 0; }
.afcard--compact .afcard__cat {
    font-size: 9px;
    margin-bottom: 3px;
}
.afcard--compact .afcard__name {
    font-size: 13.5px;
    line-height: 1.5;
    margin: 0 0 2px;
}
.afcard--compact .afcard__desc {
    font-size: 12px;
    margin: 0;
    color: var(--muted);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.afcard--compact .afcard__cta {
    border-bottom: none;
    padding: 7px 12px;
    border: 1px solid var(--accent);
    border-radius: 4px;
    font-size: 10px;
    color: var(--accent-ink);
    white-space: nowrap;
    transition: background-color .15s ease, color .15s ease;
}
.afcard--compact a:hover .afcard__cta {
    background: var(--accent);
    color: #fff;
}
@media (max-width: 480px) {
    .afcard--compact a {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .afcard--compact .afcard__cta {
        justify-self: start;
    }
}

/* =========================================================
 * Sidebar (Phase 3 本実装)
 * front-page.php は独自構成のため使わない。
 * ========================================================= */
.site-sidebar {
    font-family: var(--sans-jp);
    color: var(--ink-2);
    font-size: 13px;
}
.site-sidebar > * + * { margin-top: 24px; }
.site-sidebar__placeholder {
    border: 1px dashed var(--rule);
    padding: 14px;
    text-align: center;
    margin: 0;
}

/* ---------- Search form ---------- */
.searchform {
    display: flex;
    border: 1px solid var(--rule);
    background: #fff;
}
.searchform__input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 12px 14px;
    font-family: var(--sans-jp);
    font-size: 13px;
    color: var(--ink);
    outline: none;
}
.searchform__input::placeholder { color: var(--muted); }
.searchform__submit {
    background: var(--ink);
    color: #fff;
    border: none;
    padding: 0 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
}
.searchform__submit:hover { background: var(--accent-ink); }

/* ---------- Sidebar tabs (CSS のみで切替) ---------- */
.sidebar-tabs {
    position: relative;
}
.sidebar-tabs input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 1px;
    height: 1px;
}
.sidebar-tabs__nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border: 1px solid var(--rule);
}
.sidebar-tabs__nav label {
    padding: 12px 8px;
    text-align: center;
    font-family: var(--sans-jp);
    font-size: 14px;
    letter-spacing: 0.22em;
    color: var(--muted);
    background: #fafafa;
    cursor: pointer;
    border-bottom: 2px solid transparent;
}
.sidebar-tabs__panel {
    display: none;
    border: 1px solid var(--rule);
    border-top: none;
    background: #fff;
}
.sidebar-tabs__panel ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.sidebar-tabs__panel li {
    padding: 12px 14px;
    border-bottom: 1px solid var(--rule-soft);
    font-family: var(--sans-jp);
    font-size: 14px;
    line-height: 1.55;
    color: var(--ink-2);
}
.sidebar-tabs__panel li:last-child { border-bottom: none; }
.sidebar-tabs__panel a { color: inherit; }
.sidebar-tabs__panel a:hover { color: var(--accent-ink); }
.sidebar-tabs__empty {
    color: var(--muted);
    font-size: 11.5px;
}

/* チェック状態に応じて表示切替 */
#ainews-tab-rec:checked ~ .sidebar-tabs__nav label[for="ainews-tab-rec"],
#ainews-tab-new:checked ~ .sidebar-tabs__nav label[for="ainews-tab-new"] {
    background: #fff;
    color: var(--accent-ink);
    border-bottom-color: var(--accent);
}
#ainews-tab-rec:checked ~ .sidebar-tabs__panel--rec,
#ainews-tab-new:checked ~ .sidebar-tabs__panel--new {
    display: block;
}

/* キーボードフォーカス時のラベル強調（accessibility） */
.sidebar-tabs input[type="radio"]:focus-visible + .sidebar-tabs__nav label {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
}

/* =========================================================
 * No posts
 * ========================================================= */
.no-posts {
    color: var(--muted);
    font-size: 14px;
}

/* =========================================================
 * WordPress standard utility classes
 * ========================================================= */
.screen-reader-text {
    position: absolute !important;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    width: 1px;
    overflow: hidden;
    word-wrap: normal !important;
}
.alignleft   { float: left;  margin: 0 1em 1em 0; }
.alignright  { float: right; margin: 0 0 1em 1em; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.wp-caption {
    max-width: 100%;
    background: #fafafa;
    padding: 8px;
    margin-bottom: 1em;
}
.wp-caption .wp-caption-text {
    font-family: var(--sans-jp);
    font-size: 11px;
    color: var(--muted);
    margin: 6px 0 0;
}
.sticky { /* WP requirement */ }
.bypostauthor { /* WP requirement */ }

/* =========================================================
 * Responsive (Phase 3 で .brand / .pnav / .page の SP 対応強化)
 * ========================================================= */
@media (max-width: 900px) {
    /* SP: 主要セクションを 1 カラム積み重ね (sp-design-home.png レイアウト準拠)。
       要素追加・デザイン変更はせず、grid 列数だけを 1fr に揃える。 */
    .hero { grid-template-columns: 1fr; }
    .feat3 { grid-template-columns: 1fr; }
    .twocol { grid-template-columns: 1fr; }
    .twocol .news { grid-template-columns: 1fr; }
    .lower { grid-template-columns: 1fr; }
    .foot-grid { grid-template-columns: 1fr 1fr; }
    .foot-recent { grid-template-columns: 1fr 1fr; }
    /* サイドバーは .page で1カラム化される（partials.css の .page メディアクエリ参照） */
    .site-sidebar { width: 100%; }

    /* SP: HERO スライダーをビューポート幅まで広げ、高さも同じで正方形に。
       transform 中央配置は副作用が出るので使わず、margin で .wrap の左右
       padding (var(--gutter)) だけ外側に押し出す形にする。 */
    .wrap > .hero .hero-slider {
        margin-left: calc(-1 * var(--gutter));
        margin-right: calc(-1 * var(--gutter));
        width: auto; /* 親 grid item の幅に従う (= .hero の content 幅) */
        height: 100vw; /* ビューポート幅と同じ = 正方形 */
        aspect-ratio: auto;
    }
    .wrap > .hero .hero-slider .slide {
        height: 100%;
    }

    /* SP: FROM THE ARCHIVE スライダーを 3 列・正方形・矢印非表示に
       (PC では grid 7 列 / 高さ 220px / 矢印あり、その元の状態を維持) */
    .strip { grid-template-columns: repeat(3, 1fr); height: auto; }
    .strip .cell { aspect-ratio: 1 / 1; }
    .strip-track { height: auto; }
    .strip-track > .cell {
        flex: 0 0 calc((100% - 4px) / 3);
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .strip-wrap .arrow { display: none; }

    /* SP ヘッダー: sp-menu-1.jpg 準拠
       - ロゴ中央寄せ
       - バーガー右上 (absolute)
       - タグライン非表示
       - スクロール追従 (position: sticky)
       - 背景白 + 下罫線 + 軽いシャドウで浮いている感を出す
       - z-index: 50 (ドロワー 40 より上、バーガー 60 がさらに上) */
    .brand {
        padding: 14px var(--gutter);
        text-align: center;
        position: sticky;
        top: 0;
        z-index: 50;
        background: #fff;
        border-bottom: 1px solid var(--rule);
        box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
    }
    .brand .mark { margin: 0 auto; line-height: 1; }
    .brand .brand-logo {
        width: 200px;
        max-width: 56%;
        margin: 0 auto;
    }
    .brand .tag { display: none; }
    /* バーガーは右端 / 上下いっぱいに収める (浮かない、ヘッダの一部のように見える) */
    .burger { top: 0; right: 0; transform: none; }
    .burger[aria-expanded="true"] { transform: none; }
}
@media (max-width: 640px) {
    :root { --gutter: 18px; }
    .feat3, .twocol .news, .lower { grid-template-columns: 1fr; }
    .foot-grid { grid-template-columns: 1fr; padding: 36px 0 18px; gap: 28px; }
    .strip-wrap .arrow.l { left: 4px; }
    .strip-wrap .arrow.r { right: 4px; }

    /* SP: .wide ヒーロー特集枠は高さ・文字サイズを縮め、長文タイトルでも崩れないように */
    .wide { height: 280px; }
    .wide .meta { left: 18px; right: 18px; bottom: 18px; }
    .wide h2 { font-size: 19px; line-height: 1.45; max-width: 100%; }

    /* SP: .hero メインスライドのメタ調整。
       高さは 900px 以下の aspect-ratio 1/1 を維持し、ここでは padding/フォントだけ調整 */
    .hero { gap: 12px; margin-bottom: 36px; }
    .hero .slide .meta { left: 16px; right: 16px; bottom: 16px; }
    .hero .slide h2 { font-size: 17px; line-height: 1.45; }
    .hero .slide .stamp { font-size: 10px; letter-spacing: 0.12em; }
    /* SP: .hero-side のサイドカード 2 枚を縦 1 列に (sp-design-home.png 準拠) */
    .hero-side { grid-template-rows: unset; grid-template-columns: 1fr; gap: 12px; }
    .hero-side .card { height: 180px; }
    .hero-side .card h3 { font-size: 13px; -webkit-line-clamp: 2; }

    /* SP: 各種カードのサムネ高さを少し詰める */
    .post-card .thumb { height: 180px; }
    .pick .post-card .thumb { height: 180px; }
    .lower .post-card .thumb { height: 180px; }

    /* SP: feat3 / twocol .news / lower のギャップ詰め (1カラム積み重ね前提) */
    .feat3 { gap: 28px; margin-bottom: 36px; }
    .twocol { gap: 36px; margin-bottom: 36px; }
    .twocol .news { gap: 28px; }
    .lower { gap: 28px; margin-bottom: 36px; }

    /* SP brand: 900px 設定を踏襲、640px ではロゴをさらに小さく */
    .brand .brand-logo { width: 180px; max-width: 56%; }
    /* Phase 1 残置のテキストロゴ用 SP override */
    .site-brand {
        font-size: 22px;
        letter-spacing: 0.16em;
        padding-left: 0.16em;
        line-height: 1.3;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: clip;
    }
    /* .brand .tag は 900px で display: none、.site-tagline 系も同方針 */
    .site-tagline { display: none; }

    /* SP: util-bar コンパクト化、内容 wrap 許容 */
    .util {
        padding: 10px 16px;
        font-size: 10.5px;
        letter-spacing: 0.1em;
        gap: 8px;
        flex-wrap: wrap;
    }
    .util .nav__list { gap: 12px; flex-wrap: wrap; }

    /* SP: pnav は枠線を消して横スクロール許容のスクロールバー風に */
    .pnav { margin: 8px 0 20px; padding: 0 var(--gutter); }
    .pnav ul {
        flex-wrap: nowrap;
        overflow-x: auto;
        max-width: 100%;
        border-left: none;
        border-right: none;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }
    .pnav ul::-webkit-scrollbar { display: none; }
    .pnav li { border-right: 1px solid var(--rule); flex: 0 0 auto; }
    .pnav a {
        padding: 12px 18px;
        font-size: 11.5px;
        letter-spacing: 0.16em;
        white-space: nowrap;
    }

    /* SP: 装飾バナー (.banner) は1行に収まらないので可変高さ + 中央オーナメント非表示 */
    .banner {
        height: auto;
        min-height: 64px;
        padding: 14px var(--gutter);
        flex-wrap: wrap;
        gap: 6px;
    }
    .banner .ornament { display: none; }
    .banner .left, .banner .right {
        font-size: 12px;
        letter-spacing: 0.1em;
    }

    /* SP: .page のサイドバー本文下配置 (partials.css で1カラム化済み) のマージン整理 */
    .wrap > .page { gap: 32px; }
    .site-sidebar > * + * { margin-top: 20px; }

    /* SP: フッター RECENTLY を 133px × 2 列、中央寄せ。thumb は正方形 */
    .foot-recent {
        grid-template-columns: 133px 133px;
        justify-content: center;
    }
    .frec { width: 133px; }
    .frec .thumb {
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .foot-bottom {
        flex-direction: column;
        align-items: center;
        gap: 10px;
        text-align: center;
    }
    .foot-bottom__list { justify-content: center; }

    /* sec-title は :root の --fs-sec-title (clamp) で自動最適化、SP 上書き不要 */
    .sec-title { letter-spacing: 0.28em; margin-bottom: 14px; }
}

@media (max-width: 480px) {
    .brand .brand-logo { width: 160px; max-width: 56%; }
    /* Phase 1 残置のテキストロゴ用 SP-480 override */
    .site-brand {
        font-size: 19px;
        letter-spacing: 0.12em;
        padding-left: 0.12em;
    }
    .pnav a { padding: 10px 14px; font-size: 11px; letter-spacing: 0.14em; }

    /* 極狭画面: hero-side は 640px から既に 1 列、ここでは高さだけ詰める。
       hero-slider は aspect-ratio 1/1 を 480px でも維持 (ビューポート幅と同じ高さ) */
    .hero-side .card { height: 160px; }
    .hero .slide h2 { font-size: 15.5px; }
    .post-card .thumb { height: 200px; }
    .wide { height: 240px; }
    .wide h2 { font-size: 17px; }

    /* util バーの SNS / ナビ余白詰め */
    .util { padding: 8px 12px; font-size: 10px; }
    .util .nav__list { gap: 10px; }
}
