/*
Theme Name: どこで買う？ Brutal
Theme URI: https://dokodekau.com/
Author: dokodekau.com
Author URI: https://dokodekau.com/
Description: dokodekau.com 専用のブルータリスト調モノクロWordPressテーマ。トップ・記事ページのモックアップをそのまま実装。Noto Sans JP + Barlow Condensed。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dokodekau
*/

/* =========================================================
   RESET / VARS
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0D0D0D;--paper:#EEEDE8;--bg:#EEEDE8;--mid:#666;--dim:#E0DFD9;--rule:#C8C7C0;
  --sans:'Noto Sans JP',sans-serif;--en:'Barlow Condensed',sans-serif;
}
html{font-size:16px;background:var(--paper);overflow-x:clip}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* =========================================================
   HEADER
   ========================================================= */
header.site-header{height:54px;background:var(--paper);border-bottom:none;display:flex;align-items:center;justify-content:space-between;padding:0 16px;position:sticky;top:0;z-index:100;}
.header-nav-wrap{background:var(--paper);margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.h-menu{display:flex;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px 0}
.h-menu span{display:block;width:22px;height:2px;background:var(--ink)}
.h-logo{flex:1;text-align:center}
.h-logo a{display:inline-flex;flex-direction:column;align-items:center;text-decoration:none;color:inherit;gap:1px}
.h-logo-tag{display:inline-flex;align-items:center;gap:7px}
.h-logo-tag svg,.h-logo-tag img{width:26px;height:26px;display:block}
.h-logo-sub{font-family:var(--en);font-size:9px;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);display:block}
.h-logo-main{font-size:22px;font-weight:800;display:block;line-height:1.2;letter-spacing:0.04em;font-family:var(--en);text-transform:uppercase}
.h-search{opacity:0.5;cursor:pointer;background:none;border:none;padding:0;display:flex}

/* =========================================================
   CATEGORY NAV
   ========================================================= */
.cat-nav{
  display:block;border-bottom:none;background:var(--paper);
  padding:0 16px;overflow-x:auto;white-space:nowrap;scrollbar-width:none;
}
.cat-nav::-webkit-scrollbar{display:none}
.cat-nav-list{display:flex;align-items:center;gap:0;list-style:none}
.cat-nav-list a{
  display:flex;align-items:center;gap:5px;padding:10px 14px;
  font-family:var(--en);font-size:10px;font-weight:600;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--mid);text-decoration:none;
  transition:color .12s;white-space:nowrap;
}
.cat-nav-list a:hover{color:var(--ink)}
.cat-nav-icon{opacity:.4}

/* =========================================================
   HERO (front page)
   ========================================================= */
.hero{
  background:var(--ink);border-bottom:3px solid var(--ink);
  width:100vw;position:relative;left:50%;margin-left:-50vw;
}
.hero-inner{max-width:1120px;margin:0 auto;padding:36px 16px 32px;}
.hero-label{font-family:var(--en);font-size:13px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:14px}
.hero-headline{font-size:52px;font-weight:900;line-height:1.05;letter-spacing:-0.01em;color:#fff;margin-bottom:28px;font-family:var(--en);text-transform:uppercase}
.search-wrap{display:flex;height:48px}
.search-wrap input{flex:1;background:#fff;border:3px solid #fff;border-right:none;padding:0 14px;font-family:var(--sans);font-size:13px;color:var(--ink);outline:none;min-width:0}
.search-wrap input::placeholder{color:#aaa}
.search-wrap button{background:var(--paper);border:3px solid #fff;border-left:none;padding:0 16px;font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);cursor:pointer;white-space:nowrap}

/* =========================================================
   SECTION HEADS
   ========================================================= */
.sec-head{padding:32px 16px 16px;display:flex;align-items:center;gap:10px;}
.sec-title{font-size:18px;font-weight:800;letter-spacing:0.06em;font-family:var(--en);text-transform:uppercase}
.sec-en{font-family:var(--en);font-size:9px;font-weight:400;letter-spacing:0.18em;text-transform:uppercase;color:#595959}
.sec-more{margin-left:auto;font-family:var(--en);font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--ink);padding-bottom:1px}
.sec-head--ruled{border-bottom:2px solid var(--ink);padding-bottom:14px;}

/* =========================================================
   CARDS (front page)
   ========================================================= */
.bcard{display:block;margin:14px 16px;background:#fff;border:2px solid var(--ink);text-decoration:none;color:inherit;transition:transform .12s,box-shadow .12s}
.bcard:hover{transform:translate(-3px,-3px);box-shadow:5px 5px 0 var(--ink)}
.bcard-img{height:160px;background:var(--paper);border-bottom:2px solid var(--ink);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:14px}
.bcard-img img{width:100%;height:100%;object-fit:cover}
.bcard-img-num{font-family:var(--en);font-size:80px;font-weight:700;color:rgba(0,0,0,.08)}
/* 値札サムネ（プライスタグSVG） */
.ptag{display:block;width:100%;height:100%}
.art-hero .ptag{max-width:560px;margin:0 auto}
.bcard-cat{display:inline-block;background:var(--ink);color:#fff;font-family:var(--en);font-size:9px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;padding:4px 10px;margin:12px 14px 4px}
.bcard-title{font-size:23px;font-weight:800;line-height:1.25;letter-spacing:0.01em;padding:0 14px 8px;font-family:var(--en);text-transform:uppercase}
.bcard-desc{font-size:12px;font-weight:400;color:var(--mid);line-height:1.7;padding:0 14px 14px}

.bcard-sm{display:block;background:#fff;border:2px solid var(--ink);text-decoration:none;color:inherit;padding:14px;transition:transform .12s,box-shadow .12s}
.bcard-sm:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink)}
.bcard-sm-cat{font-family:var(--en);font-size:8px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:#595959;margin-bottom:8px;display:block}
.bcard-sm-title{font-size:18px;font-weight:800;line-height:1.35;letter-spacing:0.02em;font-family:var(--en);text-transform:uppercase}

.card-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 16px 0}

/* =========================================================
   POST LIST (new posts)
   ========================================================= */
.post-list{margin:0 16px}
.post-item{display:grid;grid-template-columns:64px 1fr;gap:0 12px;align-items:start;padding:14px 0;border-bottom:2px solid var(--ink);text-decoration:none;color:inherit;transition:background .1s}
.post-item:hover{background:rgba(0,0,0,.04)}
.post-date{font-family:var(--en);font-size:10px;font-weight:400;color:var(--mid);letter-spacing:0.04em;padding-top:2px}
.post-title{font-size:13px;font-weight:700;line-height:1.65}

/* =========================================================
   CATEGORY GRID
   ========================================================= */
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 16px 0}
.cat-item{background:#fff;border:2px solid var(--ink);padding:14px 12px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:5px;transition:transform .12s,box-shadow .12s}
.cat-item:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink)}
.cat-en{font-family:var(--en);font-size:8px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:#595959}
.cat-jp{font-size:17px;font-weight:800;line-height:1.3;letter-spacing:0.02em;font-family:var(--en);display:flex;align-items:center;gap:8px}
.cat-jp .cat-nav-icon{flex:0 0 auto;opacity:.55}
.cat-arrow{font-size:13px;font-weight:700;margin-top:2px}

/* =========================================================
   ABOUT
   ========================================================= */
.about-block{margin:14px 16px;}
.about-top{background:#E8E8E2;color:var(--ink);padding:28px 20px 24px;border:2px solid var(--ink);border-bottom:none;}
.about-en{font-family:var(--en);font-size:8px;font-weight:400;letter-spacing:0.25em;text-transform:uppercase;color:rgba(0,0,0,.58);margin-bottom:10px}
.about-title{font-size:32px;font-weight:800;margin-bottom:16px;letter-spacing:0.01em;font-family:var(--en);text-transform:uppercase;line-height:1}
.about-text{font-size:13px;font-weight:300;line-height:1.95;color:rgba(0,0,0,.6);margin-bottom:16px}
.about-link{font-size:11px;color:rgba(0,0,0,.5);text-decoration:underline;text-underline-offset:3px;letter-spacing:0.02em}
.about-feats{display:grid;grid-template-columns:repeat(3,1fr);border:2px solid var(--ink);border-top:none;}
.about-feat{padding:18px 16px;display:flex;flex-direction:column;gap:6px;}
.about-feat-icon{color:rgba(0,0,0,.25)}
.about-feat-title{font-size:13px;font-weight:700;letter-spacing:0.01em}
.about-feat-desc{font-size:11px;font-weight:300;color:#5a5a5a;line-height:1.65}

.spacer{height:14px}

/* =========================================================
   SINGLE / ARTICLE
   ========================================================= */
body.single,body.page,body.archive,body.search,body.blog{background:var(--bg)}
/* トップ（固定ページをフロントに設定）は両サイド＝ヘッダーと同じペーパー色に統一 */
body.home{background:var(--paper)}

.breadcrumb{padding:10px 16px;font-size:11px;color:var(--mid);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.breadcrumb a{color:var(--mid);text-decoration:none}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb-sep{font-size:10px;opacity:.5}

.layout{display:block}
.main{background:var(--paper)!important;padding:0;min-width:0}
.sidebar{display:none}

.art-head{padding:24px 16px 20px;border-bottom:2px solid var(--ink)}
.art-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.art-cat{font-family:var(--en);font-size:9px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;background:var(--ink);color:#fff;padding:3px 9px;text-decoration:none}
.art-date{font-family:var(--en);font-size:10px;font-weight:400;color:var(--mid);letter-spacing:0.06em}
.art-title{font-size:24px;font-weight:900;line-height:1.4;letter-spacing:-0.01em;margin-bottom:10px}
.art-title-jp{font-size:14px;font-weight:400;line-height:1.7;letter-spacing:0.01em;color:var(--mid);margin-bottom:0}

.art-hero{background:var(--paper);height:220px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border-bottom:2px solid var(--ink);padding:18px}
.art-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.art-hero-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--en);font-size:140px;font-weight:800;color:rgba(255,255,255,.04);letter-spacing:-0.05em}
.art-hero-label{position:relative;text-align:center;padding:0 16px}
.art-hero-en{font-family:var(--en);font-size:9px;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;color:rgba(255,255,255,.35);display:block;margin-bottom:8px}
.art-hero-text{font-size:30px;font-weight:800;color:#fff;letter-spacing:0.02em;display:block;line-height:1.2}

.art-body{padding:20px 16px}

/* 目次（本文上・モバイル） */
.art-toc{margin-bottom:28px}
.art-toc-title{font-family:var(--en);font-size:10px;font-weight:800;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);margin-bottom:0;padding:8px 0;border-top:2px solid var(--ink);border-bottom:1px solid var(--dim);}
.art-toc ol{padding-left:0;list-style:none;gap:0;counter-reset:toc}
.art-toc li{counter-increment:toc;position:relative;padding-left:32px;border-bottom:1px solid var(--dim);}
.art-toc li::before{content:counter(toc,decimal-leading-zero);position:absolute;left:0;top:10px;font-family:var(--en);font-size:10px;font-weight:600;color:var(--mid);}
.art-toc a{font-size:12px;font-weight:400;color:var(--ink);text-decoration:none;display:block;padding:10px 0;line-height:1.5;transition:opacity .12s;}
.art-toc a:hover{opacity:.5}

/* =========================================================
   ARTICLE BODY — bare HTML tags (the_content output)
   実際の投稿は素の h2/h3/p/table/ul/ol で書かれているため
   クラスなしのタグを直接スタイリングする。
   ========================================================= */
.art-body h2,h2.art-h2{font-size:18px;font-weight:900;line-height:1.45;letter-spacing:0.01em;margin:32px 0 14px;padding:12px 14px;background:var(--ink);color:#fff;scroll-margin-top:64px}
.art-body h3,h3.art-h3{font-size:15px;font-weight:700;line-height:1.5;margin:24px 0 10px;padding-left:10px;border-left:3px solid var(--ink);scroll-margin-top:64px}
.art-body h4{font-size:14px;font-weight:700;margin:20px 0 8px;scroll-margin-top:64px}

.art-body p,p.art-p{font-size:15px;font-weight:400;line-height:2.0;margin-bottom:16px;color:rgba(13,13,13,.92)}
.art-body p strong,p.art-p strong,.art-body strong{font-weight:700;color:var(--ink)}
.art-body a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}

/* リード文（明示クラス時のみ） */
.art-lead{font-size:14px;font-weight:400;line-height:2.0;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--dim);color:var(--ink)}

/* PR表記（記事上部の共通文言） */
.pr-disclosure{font-size:11px;font-weight:400;line-height:1.7;color:var(--mid);background:var(--bg);border:1px solid var(--dim);padding:8px 12px;margin:0 0 20px}

/* テーブル */
.art-table-wrap,.table-scroll{overflow-x:auto;margin-bottom:20px;-webkit-overflow-scrolling:touch}
.art-body table,.art-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:20px}
.art-body table th,.art-table th{background:var(--ink);color:#fff;padding:8px 10px;font-family:var(--en);font-size:11px;font-weight:600;letter-spacing:0.08em;text-align:left;white-space:nowrap}
.art-body table td,.art-table td{padding:8px 10px;border-bottom:1px solid var(--dim);vertical-align:top;line-height:1.6}
.art-body table tr:nth-child(even) td,.art-table tr:nth-child(even) td{background:var(--bg)}
.table-scroll table{margin-bottom:0}
/* 比較表：ヘッダー行(thead)だけ黒、左の見出し列(tbody th)は明るく */
.art-body table tbody th,.art-table tbody th{
  background:#E7E6E0;
  color:var(--ink);
  font-family:inherit;
  font-size:inherit;
  letter-spacing:normal;
  font-weight:700;
  white-space:nowrap;
  border-bottom:1px solid var(--dim);
}
/* スマホ：表のセルを潰さず横スクロールさせる */
@media(max-width:767px){
  .art-body table th,.art-body table td,.art-table th,.art-table td{white-space:nowrap}
  .table-scroll{border:1px solid var(--dim)}
}
/* ScrollHint「スワイプできます」の下地を薄くして下の文字を読めるように */
.scroll-hint-icon{background-color:rgba(0,0,0,.28)!important;box-shadow:none!important}
.scroll-hint-icon-wrap{opacity:.85}

/* リスト */
.art-body ul,.art-ul{padding-left:0;list-style:none;margin-bottom:14px;display:flex;flex-direction:column;gap:6px}
.art-body ul li,.art-ul li{font-size:15px;font-weight:300;line-height:1.85;padding-left:16px;position:relative;color:rgba(13,13,13,.85)}
.art-body ul li::before,.art-ul li::before{content:'—';position:absolute;left:0;color:var(--mid);font-size:11px}

.art-body ol,.art-ol{padding-left:0;list-style:none;margin-bottom:14px;display:flex;flex-direction:column;gap:6px;counter-reset:ol}
.art-body ol li,.art-ol li{counter-increment:ol;font-size:15px;font-weight:300;line-height:1.85;padding-left:28px;position:relative;color:rgba(13,13,13,.85)}
.art-body ol li::before,.art-ol li::before{content:counter(ol,decimal-leading-zero);position:absolute;left:0;font-family:var(--en);font-size:11px;font-weight:600;color:var(--mid)}

.art-body img{margin:16px 0;border:2px solid var(--ink)}
.art-body blockquote{border-left:3px solid var(--ink);padding:8px 14px;margin:16px 0;background:var(--bg);font-size:13px;line-height:1.9;color:rgba(13,13,13,.75)}

/* ハイライトボックス */
.art-box{border:2px solid var(--ink);padding:14px;margin-bottom:20px;background:var(--bg)}
.art-box-title{font-family:var(--en);font-size:10px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:8px}
.art-box p{font-size:12px;font-weight:300;line-height:1.8;color:rgba(13,13,13,.75)}

/* CTAボタン */
.art-cta{display:block;background:var(--ink);color:#fff;text-align:center;padding:14px 16px;font-family:var(--en);font-size:12px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;text-decoration:none;margin:20px 0;transition:opacity .15s}
.art-cta:hover{opacity:.8;color:#fff}

/* FAQ */
.art-faq{margin-bottom:14px;border:1px solid var(--dim)}
.art-faq-q{font-size:13px;font-weight:700;padding:12px 14px;background:var(--bg);display:flex;gap:10px;align-items:start}
.art-faq-q::before{content:'Q';font-family:var(--en);font-size:11px;font-weight:800;flex-shrink:0;margin-top:1px}
.art-faq-a{font-size:13px;font-weight:300;padding:12px 14px;line-height:1.85;display:flex;gap:10px;align-items:start;color:rgba(13,13,13,.75)}
.art-faq-a::before{content:'A';font-family:var(--en);font-size:11px;font-weight:800;flex-shrink:0;margin-top:1px;color:var(--mid)}

/* まとめ */
.art-summary{border:2px solid var(--ink);padding:16px;margin:24px 0;background:var(--bg)}
.art-summary-title{font-family:var(--en);font-size:13px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:12px}

/* 書いた人 */
.author-box{margin:24px 16px;border:2px solid var(--ink);background:var(--paper)}
.author-box-label{font-family:var(--en);font-size:10px;font-weight:800;letter-spacing:0.18em;text-transform:uppercase;color:var(--mid);padding:10px 14px;border-bottom:2px solid var(--ink)}
.author-box-inner{display:flex;gap:14px;align-items:flex-start;padding:14px}
.author-box-avatar{flex:0 0 auto}
.author-box-avatar img{display:block;width:56px;height:56px;border:2px solid var(--ink);object-fit:cover;border-radius:0}
.author-box-bio a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.author-box-body{min-width:0}
.author-box-name{font-size:15px;font-weight:800;line-height:1.3;margin-bottom:4px}
.author-box-bio{font-size:12px;font-weight:300;line-height:1.7;color:rgba(13,13,13,.7)}

/* 関連記事 */
.related{padding:20px 16px;border-top:2px solid var(--ink)}
.related-title{font-family:var(--en);font-size:13px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:14px}
.related-item{display:block;padding:12px 0;border-bottom:1px solid var(--dim);text-decoration:none;color:inherit;font-size:13px;font-weight:400;line-height:1.6;transition:opacity .12s}
.related-item:hover{opacity:.6}
.related-item:last-child{border-bottom:none}
.related-cat{font-family:var(--en);font-size:8px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:4px}

/* =========================================================
   ARCHIVE / SEARCH / INDEX
   ========================================================= */
.page-head{padding:28px 16px 18px;border-bottom:2px solid var(--ink)}
.page-head-en{font-family:var(--en);font-size:9px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:6px}
.page-head-title{font-size:22px;font-weight:800;letter-spacing:0.02em}
.page-head-desc{font-size:12px;font-weight:300;color:var(--mid);line-height:1.8;margin-top:8px}
.archive-main{background:var(--paper)}
.archive-list{margin:0}
.arch-item{display:grid;grid-template-columns:120px 1fr;gap:0 14px;align-items:start;padding:16px;border-bottom:2px solid var(--ink);text-decoration:none;color:inherit;transition:background .1s}
.arch-item:hover{background:rgba(0,0,0,.04)}
.arch-thumb{grid-row:span 2;width:120px;height:74px;background:var(--paper);overflow:visible}
.arch-thumb img{width:100%;height:100%;object-fit:cover}
.arch-date{font-family:var(--en);font-size:10px;font-weight:400;color:var(--mid);letter-spacing:0.04em}
.arch-body{min-width:0}
.arch-cat{font-family:var(--en);font-size:8px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:3px}
.arch-title{font-size:14px;font-weight:700;line-height:1.6}
.no-posts{padding:40px 16px;font-size:13px;font-weight:300;color:var(--mid);line-height:1.9}
@media(min-width:900px){.arch-item{padding:18px 32px}}

/* 固定ページ本文 */
.page-body{padding:24px 16px 32px;background:var(--paper)}
.page-body h2{font-size:18px;font-weight:900;margin:28px 0 12px;padding:10px 14px;background:var(--ink);color:#fff}
.page-body h3{font-size:15px;font-weight:700;margin:22px 0 10px;padding-left:10px;border-left:3px solid var(--ink)}
.page-body p{font-size:13px;font-weight:300;line-height:2.0;margin-bottom:14px;color:rgba(13,13,13,.85)}
.page-body ul,.page-body ol{margin:0 0 14px 1.4em}
.page-body li{font-size:13px;line-height:1.9;margin-bottom:4px}
.page-body a{text-decoration:underline;text-underline-offset:2px}

/* =========================================================
   PAGINATION
   ========================================================= */
.pagination{padding:24px 16px 32px;display:flex;justify-content:center}
.pagination .nav-links{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border:2px solid var(--ink);background:#fff;color:var(--ink);font-family:var(--en);font-size:14px;font-weight:700;text-decoration:none;transition:transform .12s,box-shadow .12s}
.pagination .page-numbers:hover{transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--ink)}
.pagination .page-numbers.current{background:var(--ink);color:#fff}
.pagination .page-numbers.dots{border:none;background:none;box-shadow:none;transform:none}
.pagination .page-numbers.prev,.pagination .page-numbers.next{font-size:12px;letter-spacing:0.08em;text-transform:uppercase}

/* 投稿ナビ（single 前後） */
.post-nav{display:flex;border-top:2px solid var(--ink)}
.post-nav a{flex:1;padding:16px;text-decoration:none;color:inherit;font-size:12px;font-weight:700;line-height:1.5}
.post-nav .nav-prev{border-right:2px solid var(--ink)}
.post-nav .nav-prev:last-child{border-right:none}
.post-nav .nav-label{font-family:var(--en);font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:6px}
.post-nav .nav-next{text-align:right}

/* =========================================================
   FOOTER
   ========================================================= */
footer.site-footer{margin-top:14px;background:var(--ink);color:#fff;border-top:3px solid var(--ink);width:100vw;position:relative;left:50%;margin-left:-50vw;}
.footer-inner{max-width:1120px;margin:0 auto;padding:32px 16px 28px;}
.footer-logo{display:inline-block;text-decoration:none;color:inherit}
.footer-sub{display:block;font-family:var(--en);font-size:8px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:4px}
.footer-main{display:block;font-size:28px;font-weight:800;letter-spacing:0.04em;margin-bottom:22px;font-family:var(--en);text-transform:uppercase}
.footer-logo:hover .footer-main{color:rgba(255,255,255,.85)}
.footer-links{display:flex;flex-direction:column;gap:12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);margin-bottom:22px}
.footer-links a{font-size:12px;font-weight:400;color:rgba(255,255,255,.45);text-decoration:none}
.footer-links a:hover{color:rgba(255,255,255,.8)}
.footer-copy{font-family:var(--en);font-size:9px;color:rgba(255,255,255,.2);letter-spacing:.1em}

/* ヘッダー内検索トグル */
.header-search-bar{background:var(--ink);width:100vw;position:relative;left:50%;margin-left:-50vw}
.header-search-inner{max-width:1120px;margin:0 auto;padding:14px 16px}
.header-search-bar .search-wrap{height:44px}

/* モバイルドロワー */
.mobile-drawer{background:var(--paper);border-bottom:2px solid var(--ink)}
.mobile-drawer-list{list-style:none}
.mobile-drawer-list li{border-bottom:1px solid var(--dim)}
.mobile-drawer-list a{display:block;padding:14px 16px;font-size:14px;font-weight:700;color:var(--ink);text-decoration:none}
.mobile-drawer-list a:hover{background:rgba(0,0,0,.04)}
@media(min-width:900px){.mobile-drawer{display:none!important}.h-menu{visibility:hidden}}

/* スキップリンク（アクセシビリティ） */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:8px 12px;z-index:999}
.skip-link:focus{left:8px;top:8px}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (min-width:768px){
  body{max-width:1120px;margin:0 auto}
  header.site-header{padding:0 32px}
  .hero-inner{padding:56px 48px 48px}
  .hero-headline{font-size:80px}
  .pickup-wrap{padding:0 16px}
  .pickup-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0}
  .bcard{margin:0}
  .bcard-img{height:280px}
  .card-pair{display:flex;flex-direction:column;gap:10px;margin:0}
  .bcard-sm{height:100%;display:flex;flex-direction:column;justify-content:center}
  .sec-head{padding:28px 32px 12px}
  .sec-more{font-size:10px}
  .post-list{margin:0 16px;display:grid;grid-template-columns:repeat(3,1fr)}
  .post-item{grid-template-columns:1fr;border-bottom:none;padding:18px 16px}
  .cat-grid{grid-template-columns:repeat(3,1fr);margin:0 16px}
  .about-block{margin:14px 16px}
  .footer-inner{padding:40px 48px 36px}
  .footer-links{flex-direction:row;gap:28px}
}

@media(min-width:900px){
  /* ヘッダー+ナビ */
  .header-nav-wrap > header.site-header{position:sticky;top:0;z-index:100;max-width:1120px;margin:0 auto;height:54px;border-bottom:none;padding:0 32px;width:100%;display:flex;align-items:center;justify-content:space-between;}
  .header-title-rule{display:none}
  .cat-nav{border-bottom:none;padding:0;justify-content:center}
  .cat-nav-list{justify-content:center}
  .cat-nav-list a{font-size:12px;padding:11px 18px}

  .pickup-wrap,.post-list,.cat-grid,.about-block,.sec-head,.spacer{max-width:1120px;margin-left:auto;margin-right:auto}
  .hero-inner{padding:56px 48px 48px;max-width:1120px;margin:0 auto}
  .hero-headline{font-size:80px}
  .about-feats{grid-template-columns:repeat(3,1fr)}
  .about-feat{border-bottom:none}
  .footer-inner{padding:40px 48px 36px}
  .footer-links{flex-direction:row;gap:28px}

  /* SINGLE 2カラム */
  .breadcrumb{padding:12px 32px}
  .layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;align-items:start;gap:0}
  .single .main,.page .main,.archive .main,.search .main{border-right:2px solid var(--ink)}
  .sidebar{display:block;padding:24px 20px;position:sticky;top:54px}
  .art-head{padding:32px 32px 24px}
  .art-title{font-size:30px}
  .art-title-jp{font-size:16px}
  .art-hero{height:280px}
  .art-hero-text{font-size:42px}
  .art-body{padding:28px 32px}
  .art-body .art-toc{display:none}  /* デスクトップはサイドバー目次を使う */
  .author-box{margin:24px 32px}
  .related{padding:24px 32px}
  .page-links{margin:16px 0;font-family:var(--en);font-weight:700}
  .page-links a,.page-links > span{display:inline-block;min-width:30px;text-align:center;border:2px solid var(--ink);padding:4px 8px;margin:0 3px;text-decoration:none}
  .page-body{padding:32px}
  .page-head{padding:32px 32px 24px}
  .archive-list{padding:0}

  /* サイドバー目次 */
  .sb-toc{margin-bottom:20px}
  .sb-toc-title{font-family:var(--en);font-size:11px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid var(--ink)}
  .sb-toc-list{list-style:none;display:flex;flex-direction:column;gap:0}
  .sb-toc-list li{border-bottom:1px solid var(--dim)}
  .sb-toc-list li.toc-h3 a{padding-left:14px;color:var(--mid)}
  .sb-toc-list a{font-size:11px;font-weight:300;color:var(--ink);text-decoration:none;display:block;padding:8px 0;line-height:1.5}
  .sb-toc-list a:hover{color:var(--mid)}

  .sb-cat{margin-top:20px}
  .sb-cat-title{font-family:var(--en);font-size:11px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid var(--ink)}
  .sb-cat-list{list-style:none;display:flex;flex-direction:column;gap:0}
  .sb-cat-list li{border-bottom:1px solid var(--dim)}
  .sb-cat-list a{font-size:11px;font-weight:300;color:var(--ink);text-decoration:none;display:flex;justify-content:space-between;align-items:center;padding:8px 0}
  .sb-cat-list a:hover{color:var(--mid)}
  .sb-cat-count{font-family:var(--en);font-size:10px;color:var(--mid)}
}
