/*
Theme Name: マジカルイングリッシュパワー
Theme URI: https://example.com
Author: English Lab
Description: 昭和ポップ・バーミリオン系レトロデザインの英語学習テーマ
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mep
Tags: education, japanese, custom-colors, custom-logo, blog, two-columns
*/




*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{
  font-family:'Noto Sans JP',sans-serif;
  color:#1a0a00;
  background-color:#F5EDD8; /* アイボリー */
  background-image:radial-gradient(circle,#c8a870 1px,transparent 1px);
  background-size:22px 22px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1060px;margin:0 auto;padding:0 24px}

:root{
  --verm:  #D94010; /* バーミリオン */
  --deep:  #7A1E00; /* 深朱 */
  --navy:  #B03010; /* 紺 */
  --ivory: #F5EDD8; /* アイボリー */
  --cream: #FFF8EC;
  --black: #1a0a00;
  --gold:  #C8820A;
  --border: 3px solid #1a0a00;
  --sh:    4px 4px 0 #1a0a00;
  --sh-sm: 3px 3px 0 #1a0a00;
}

.skip{position:absolute;top:-60px;left:0;background:var(--verm);color:#fff;padding:8px 16px;font-weight:900;z-index:999;transition:top .15s}
.skip:focus{top:0}

/* ══════════════════════
   のれん風タイトルブロック
══════════════════════ */
.title-block{
  background:#fff;
  border-bottom:5px solid var(--black);
  text-align:center;
  padding:0 0 28px;
  position:relative;
  overflow:hidden;
}
/* 上部バーミリオン帯 */
.title-block::before{display:none}
/* 装飾ドット帯 */
.title-block::after{
  content:'';display:block;
  position:absolute;bottom:0;left:0;right:0;height:8px;
  background:var(--verm);
}
.title-noren{
  display:flex;justify-content:center;gap:3px;
  padding:0 0 8px;
}
.noren-strip{
  width:52px;
  background:var(--ivory);
  border-left:2px solid var(--black);
  border-right:2px solid var(--black);
  border-bottom:4px solid var(--black);
  border-radius:0 0 4px 4px;
  height:36px;
  position:relative;
}
.noren-strip:nth-child(odd){background:var(--verm)}
.title-logo-wrap{padding:18px 24px 10px;position:relative;z-index:1}
.site-logo-img{max-width:440px;width:86%;height:auto;display:inline-block}

/* ══════════════════════
   装飾ナビ
══════════════════════ */
.deco-nav{
  background:var(--verm);
  border-bottom:4px solid var(--black);
}
.deco-nav-inner{
  display:flex;justify-content:center;
  overflow-x:auto;
}
.deco-nav a{
  font-family:'Kaisei Decol',serif;
  font-size:.88rem;font-weight:700;
  color:#fff;
  padding:10px 22px;
  border-left:2px solid rgba(255,255,255,.3);
  letter-spacing:.1em;
  transition:background .12s;
  white-space:nowrap;
}
.deco-nav a:first-child{border-left:none}
.deco-nav a:hover{background:var(--deep)}

/* ══════════════════════
   セクション共通
══════════════════════ */
.section{padding:36px 0}

/* 昭和レトロ感のある見出し */
.sec-head{
  display:flex;align-items:center;
  margin-bottom:22px;
  position:relative;
}
/* 左右の装飾線付き見出し */
.sec-title{
  font-family:'Kaisei Decol',serif;
  font-size:1.35rem;
  font-weight:700;
  letter-spacing:.12em;
  color:#fff;
  background:var(--verm);
  border:3px solid var(--black);
  padding:5px 20px 5px 14px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  box-shadow:var(--sh-sm);
  position:relative;
}
/* 左の縦ライン装飾 */
.sec-title::before{
  content:'';display:inline-block;
  width:6px;height:1.2em;
  background:#fff;
  flex-shrink:0;
}

.sec-more{
  font-family:'Kaisei Decol',serif;
  font-size:.78rem;font-weight:700;letter-spacing:.08em;
  color:var(--black);
  border:2.5px solid var(--black);
  padding:5px 14px;
  background:var(--cream);
  transition:all .12s;
  box-shadow:var(--sh-sm);
}
.sec-more:hover{background:var(--black);color:#fff;box-shadow:none;transform:translate(3px,3px)}

/* 二重罫線区切り */
.retro-divider{
  border:none;
  height:0;
  border-top:3px double var(--black);
  margin:0 0 36px;
}

/* ══════════════════════
   CPILL
══════════════════════ */
.cpill{
  display:inline-block;font-size:.6rem;font-weight:900;
  letter-spacing:.08em;color:#fff;
  padding:2px 9px;border:2px solid var(--black);
  font-family:'Noto Sans JP',sans-serif;
}
.cpill.reading{background:var(--verm)}
.cpill.writing{background:#3A7D44}
.cpill.wagyaku{background:#1A5CA0}
.cpill.grammar{background:var(--gold)}

/* ══════════════════════
   SLIDER
══════════════════════ */
.slider-outer{position:relative}
.slider-viewport{
  overflow:hidden;
  border:4px solid var(--black);
  box-shadow:var(--sh);
}
.slider-track{display:flex;transition:transform .42s cubic-bezier(.4,0,.2,1)}
.slide{
  flex:0 0 100%;
  background:var(--cream);
  display:grid;
  grid-template-columns:1fr 300px;
  min-height:240px;
  text-decoration:none;color:var(--black);
}
.slide-left{position:relative;overflow:hidden;min-height:240px}
.slide-left-bg{position:absolute;inset:0;transition:transform .45s ease}
.slide:hover .slide-left-bg{transform:scale(1.03)}

/* 放射状＋ストライプ */
.slide-left-bg.reading{background:var(--verm)}
.slide-left-bg.writing{background:#C04018}
.slide-left-bg.wagyaku{background:var(--deep)}

.slide-left-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.1) 55%);
  display:flex;flex-direction:column;
  padding:14px 18px 20px;
}
.slide-date-top{
  align-self:flex-end;
  font-size:.82rem;font-weight:900;color:#fff;
  background:var(--black);padding:3px 10px;
  letter-spacing:.06em;
  font-family:'Kaisei Decol',serif;
  border:1.5px solid rgba(255,255,255,.4);
}
.slide-cat{
  display:inline-block;font-size:.6rem;font-weight:900;
  letter-spacing:.1em;color:#fff;
  background:rgba(0,0,0,.55);border:1.5px solid #fff;
  padding:2px 9px;margin-bottom:7px;align-self:flex-start;
}
.slide-main-title{
  font-size:1.2rem;font-weight:900;color:#fff;line-height:1.42;
  font-family:'Kaisei Decol',serif;letter-spacing:.04em;
}
.slide-left-bottom{align-self:flex-end;width:100%}
.slide-right{
  padding:20px 22px;
  display:flex;flex-direction:column;justify-content:center;gap:10px;
  border-left:4px solid var(--black);
  background:var(--cream);
  position:relative;
}
/* 右パネルの右上に家紋風コーナー装飾 */
.slide-right::before{
  content:'❖';
  position:absolute;top:8px;right:10px;
  font-size:.8rem;color:var(--gold);opacity:.6;
}
.slide-excerpt{font-size:.82rem;color:#3a1a00;line-height:1.8}
.slide-lv{font-size:.7rem;color:#7a4a20;font-weight:700}
.slide-read{
  display:inline-block;font-size:.78rem;font-weight:900;
  color:#fff;background:var(--verm);
  border:2.5px solid var(--black);padding:6px 16px;
  margin-top:4px;letter-spacing:.06em;
  transition:all .12s;box-shadow:var(--sh-sm);
  font-family:'Kaisei Decol',serif;
  align-self:flex-start;
}
.slide-read:hover{background:var(--deep);box-shadow:none;transform:translate(3px,3px)}

.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;
  background:var(--ivory);border:3px solid var(--black);
  cursor:pointer;font-size:1rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  z-index:10;box-shadow:var(--sh-sm);transition:all .12s;
  font-family:sans-serif;
}
.slider-btn:hover{background:var(--verm);color:#fff;box-shadow:none;transform:translateY(-50%) translate(3px,3px)}
.slider-btn.prev{left:-18px}.slider-btn.next{right:-18px}
.slider-dots{display:flex;justify-content:center;gap:8px;margin-top:14px}
.sdot{width:10px;height:10px;background:var(--black);border:2px solid var(--black);cursor:pointer;padding:0;opacity:.2;transition:opacity .2s;border-radius:50%}
.sdot.active{opacity:1;background:var(--verm);border-color:var(--verm)}

/* ══════════════════════
   カテゴリー（のれん風）
══════════════════════ */
.cat-section{
  padding:32px 0;
}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat-card{
  border:3px solid var(--black);
  box-shadow:var(--sh);
  padding:24px 16px 18px;
  display:flex;flex-direction:column;
  text-decoration:none;color:#fff;
  transition:all .12s;
  position:relative;overflow:hidden;
}
.cat-card:hover{transform:translate(4px,4px);box-shadow:none}
.cat-card.reading {background:#D94010}
.cat-card.writing {background:#3A7D44}
.cat-card.wagyaku{background:#1A5CA0}
.cat-card.grammar{background:#C8820A}
/* カード右下の家紋風装飾 */
.cat-card::after{
  content:'';
  position:absolute;right:-16px;bottom:-16px;
  width:60px;height:60px;
  border:3px solid rgba(255,255,255,.18);
  border-radius:50%;
}
.cat-card-icon{font-size:1.6rem;margin-bottom:6px;display:block;line-height:1}
.cat-card-name{
  font-family:'Kaisei Decol',serif;
  font-size:1.05rem;font-weight:700;letter-spacing:.08em;
}
.cat-card-sub{font-size:.68rem;opacity:.75;margin-top:4px;letter-spacing:.04em}
.cat-card-arrow{font-size:.72rem;font-weight:900;opacity:.8;margin-top:auto;padding-top:10px;letter-spacing:.06em}

/* ══════════════════════
   連載（ラベル風）
══════════════════════ */
.series-section{
  padding:36px 0;
}
.series-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.series-card{
  border:3px solid var(--black);box-shadow:var(--sh);
  overflow:hidden;background:#fff;display:block;transition:all .12s;
}
.series-card:hover{transform:translate(4px,4px);box-shadow:none}
.series-img{
  height:96px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  color:#fff;position:relative;overflow:hidden;
  border-bottom:3px solid var(--black);
}
.series-img.s1{background:var(--verm)}
.series-img.s2{background:#3A7D44}
.series-img.s3{background:#1A5CA0}
/* 放射線装飾 */
.series-img::before{display:none}
.series-img-icon{font-size:1.5rem;position:relative;z-index:1;line-height:1;margin-bottom:4px}
.series-img-title{font-size:.68rem;font-weight:900;letter-spacing:.12em;position:relative;z-index:1;font-family:'Kaisei Decol',serif}
.series-num{
  position:absolute;top:6px;left:8px;
  font-size:.58rem;font-weight:700;
  background:rgba(0,0,0,.4);color:#fff;
  padding:1px 6px;border:1px solid rgba(255,255,255,.4);
  z-index:2;letter-spacing:.06em;
}
.series-body{padding:11px 14px 13px;background:var(--cream)}
.series-title{font-size:.9rem;font-weight:900;color:var(--black);margin-bottom:3px;font-family:'Kaisei Decol',serif;letter-spacing:.04em}
.series-sub{font-size:.7rem;color:#6a3a10}
.series-add{
  border:3px dashed #aaa;min-height:148px;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:900;letter-spacing:.08em;color:#bbb;
  background:var(--cream);
}

/* ══════════════════════
   タグ
══════════════════════ */
.tags-section{
  padding:32px 0;
}
.tags-box{
  background:#fff;border:3px solid var(--black);
  box-shadow:var(--sh);padding:20px;
}
/* タグの上の装飾ライン */
.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}
.tag{
  display:inline-block;font-size:.75rem;font-weight:900;
  padding:4px 14px;
  border:2.5px solid var(--black);
  background:#fff;color:var(--black);
  transition:all .12s;letter-spacing:.04em;
  font-family:'Noto Sans JP',sans-serif;
}
.tag:hover{transform:translate(2px,2px)}
.tag.verm {background:#FFE0D8;color:var(--verm);border-color:var(--verm)}.tag.verm:hover{background:var(--verm);color:#fff}
.tag.deep {background:#FFD0C0;color:var(--deep);border-color:var(--deep)}.tag.deep:hover{background:var(--deep);color:#fff}
.tag.navy {background:#FFD0C0;color:var(--deep);border-color:var(--deep)}.tag.navy:hover{background:var(--deep);color:#fff}
.tag.gold {background:#FFF0C0;color:var(--gold);border-color:var(--gold)}.tag.gold:hover{background:var(--gold);color:#fff}
.tag.neutral{color:#5a3a10;border-color:#8a6a40}.tag.neutral:hover{background:#5a3a10;color:#fff;border-color:#5a3a10}

/* ══════════════════════
   文法まとめ（看板風）
══════════════════════ */
.grammar-section{padding:36px 0}
.grammar-card{
  background:var(--black);
  border:4px solid var(--black);box-shadow:var(--sh);
  padding:30px 36px;
  display:flex;align-items:center;gap:24px;
  text-decoration:none;color:#fff;transition:all .12s;
  position:relative;overflow:hidden;
}
.grammar-card:hover{transform:translate(4px,4px);box-shadow:none}
/* 左の赤帯 */
.grammar-card::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:14px;
  background:var(--verm);
}
/* 右の放射装飾 */
.grammar-card::after{display:none}
.grammar-card-text{padding-left:22px;position:relative;z-index:1}
.grammar-card-eyebrow{
  font-size:.62rem;font-weight:900;letter-spacing:.18em;
  color:rgba(255,255,255,.55);margin-bottom:6px;
}
.grammar-card-title{
  font-family:'Kaisei Decol',serif;
  font-size:1.7rem;font-weight:700;line-height:1.1;
  margin-bottom:6px;letter-spacing:.06em;
}
.grammar-card-sub{font-size:.8rem;color:rgba(255,255,255,.78)}
.grammar-btn{
  flex-shrink:0;position:relative;z-index:1;
  background:var(--verm);color:#fff;
  font-family:'Kaisei Decol',serif;
  font-size:.88rem;font-weight:700;letter-spacing:.1em;
  padding:12px 26px;border:3px solid var(--black);
  cursor:pointer;box-shadow:var(--sh-sm);
  transition:all .12s;white-space:nowrap;
}
.grammar-btn:hover{background:var(--deep);box-shadow:none;transform:translate(3px,3px)}

/* ══════════════════════
   背景アイコン散りばめ（固定・ランダム配置）
══════════════════════ */
.deco-icons{
  position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;
}
.deco-icon{
  position:absolute;opacity:.055;
  font-size:2rem;color:var(--verm);
  transform:rotate(var(--rot));
  user-select:none;
}

/* ══════════════════════
   PAGE CONTENT WRAPPER
══════════════════════ */
.page-content{position:relative;z-index:1}

/* ══════════════════════
   REVEAL
══════════════════════ */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .4s ease,transform .4s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ══════════════════════
   FOOTER
══════════════════════ */
.site-footer{
  background:var(--black);
  color:rgba(255,255,255,.8);
  border-top:5px solid var(--verm);
  padding:40px 0 24px;
}
/* 装飾帯 */
.footer-deco{height:6px;background:var(--verm);margin-bottom:36px;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;margin-bottom:28px}
.footer-brand img{height:26px;width:auto;display:block;margin-bottom:10px;filter:brightness(0) invert(1);opacity:.85}
.footer-brand p{font-size:.77rem;line-height:1.85;color:rgba(255,255,255,.7)}
.footer-col h3{
  font-family:'Kaisei Decol',serif;
  font-size:.78rem;font-weight:700;letter-spacing:.12em;
  color:var(--verm);
  margin-bottom:12px;padding-bottom:6px;
  border-bottom:2px solid #3a1a00;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col a{font-size:.78rem;color:rgba(255,255,255,.75);transition:color .12s}
.footer-col a:hover{color:#fff}
.footer-btm{border-top:1px solid #3a1a00;padding-top:16px;font-size:.7rem;text-align:center;color:rgba(255,255,255,.5)}

/* ══════════════════════
   RESPONSIVE
══════════════════════ */
@media(max-width:860px){
  .slide{grid-template-columns:1fr;min-height:auto}
  .slide-left{min-height:180px}
  .slide-right{border-left:none;border-top:4px solid var(--black)}
  .cat-grid{grid-template-columns:1fr 1fr}
  .series-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px}
}
@media(max-width:560px){
  .cat-grid{grid-template-columns:1fr 1fr}
  .series-grid{grid-template-columns:1fr}
  .grammar-card{flex-direction:column;padding:24px 20px 24px 34px}
  .footer-grid{grid-template-columns:1fr}
  .deco-nav a{padding:10px 14px;font-size:.8rem}
}
a:focus-visible{outline:3px solid var(--verm);outline-offset:2px}


/* ── HEADER（他ページ用） ── */
.site-header{background:#fff;border-bottom:4px solid var(--black)}
.hdr{display:flex;align-items:center;height:56px}
.hdr-logo{display:flex;align-items:center}
.hdr-logo-img{height:34px;width:auto;display:block}
.gnav{display:flex;gap:0}
.gnav a{font-size:.78rem;font-weight:900;font-family:'Kaisei Decol',serif;color:var(--black);padding:0 16px;height:56px;display:flex;align-items:center;border-left:2px solid #ddd;letter-spacing:.08em;transition:background .12s;white-space:nowrap}
.gnav a:hover,.gnav a.current{background:var(--verm);color:#fff}

/* ── BREADCRUMB ── */
.breadcrumb{padding:12px 0;font-size:.72rem;color:#7a4a20}
.breadcrumb ol{display:flex;align-items:center;gap:6px;list-style:none;flex-wrap:wrap}
.breadcrumb li::after{content:'›';margin-left:6px;color:#c8a870}
.breadcrumb li:last-child::after{display:none}
.breadcrumb a{color:var(--verm);font-weight:700}
.breadcrumb a:hover{text-decoration:underline}

/* ── ARTICLE LAYOUT ── */
.article-layout{display:grid;grid-template-columns:1fr 284px;gap:24px;padding-bottom:56px;align-items:start}
.article-card{background:#fff;border:4px solid var(--black);box-shadow:var(--sh)}

/* ── ART HERO ── */
.art-hero{min-height:110px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:18px 24px;border-bottom:4px solid var(--black)}
.art-hero.reading{background:var(--verm)}
.art-hero.writing{background:#3A7D44}
.art-hero.wagyaku{background:#1A5CA0}
.art-hero-info{position:relative;z-index:1}
.art-hero-title{font-size:1.25rem;font-weight:900;color:#fff;line-height:1.38;letter-spacing:.02em;margin-top:8px;font-family:'Kaisei Decol',serif}
.art-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.art-tag{display:inline-block;font-size:.68rem;font-weight:700;color:rgba(255,255,255,.9);background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.45);padding:2px 10px}

/* ── ARTICLE HEADER ── */
.art-header{padding:14px 24px;border-bottom:2px solid #e8d8c0}
.art-meta{display:flex;gap:14px;font-size:.72rem;color:#7a4a20;flex-wrap:wrap}

/* ── ARTICLE BODY ── */
.art-body{padding:4px 24px 28px}
.entry-section{margin-bottom:28px}
.entry-section h3{font-size:.72rem;font-weight:900;letter-spacing:.14em;color:var(--verm);margin-bottom:12px;padding-bottom:5px;border-bottom:2px solid #e8c8a0}
.entry-en{background:#fff8f4;border-left:4px solid var(--verm);padding:18px 20px;margin-bottom:6px}
.entry-en p{font-size:.92rem;line-height:2.1;color:#1a0a00}
.entry-en p+p{margin-top:10px}
.entry-ja{background:#fff8ec;border-left:4px solid var(--gold);padding:18px 20px;margin-bottom:6px}
.entry-ja p{font-size:.88rem;line-height:2;color:#2a1000}
.entry-ja p+p{margin-top:10px}
.entry-vocab{margin-bottom:28px}
.entry-vocab h3{font-size:.72rem;font-weight:900;letter-spacing:.14em;color:var(--deep);margin-bottom:12px;padding-bottom:5px;border-bottom:2px solid #e8c8a0}
.vocab-table{width:100%;border-collapse:collapse;font-size:.84rem}
.vocab-table tr{border-bottom:1px solid #e8d8c0}
.vocab-table tr:last-child{border-bottom:none}
.vocab-table td{padding:9px 4px;vertical-align:top;line-height:1.6}
.vocab-table td:first-child{font-weight:700;color:var(--verm);width:38%;padding-right:16px;font-style:italic}
.entry-quiz{margin-bottom:28px}
.entry-quiz h3{font-size:.72rem;font-weight:900;letter-spacing:.14em;color:var(--deep);margin-bottom:14px;padding-bottom:5px;border-bottom:2px solid #e8c8a0}
.q-item{margin-bottom:20px}
.q-stem{font-size:.88rem;font-weight:700;color:#1a0a00;margin-bottom:10px;display:flex;align-items:baseline;gap:8px}
.q-no{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--verm);color:#fff;font-size:.65rem;font-weight:900;flex-shrink:0}
.choices{list-style:none;display:grid;gap:5px;margin-bottom:10px}
.choice{display:flex;align-items:flex-start;gap:9px;font-size:.84rem;padding:6px 0;cursor:pointer;transition:color .12s}
.choice:hover .choice-lbl{background:var(--verm);color:#fff}
.choice:hover{color:var(--verm)}
.choice-lbl{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;font-size:.65rem;font-weight:900;background:#e8d8c0;color:#7a4a20;transition:background .12s,color .12s}
.toggle-btn{background:none;border:2px solid var(--verm);cursor:pointer;font-family:'Noto Sans JP',sans-serif;font-size:.72rem;font-weight:900;color:var(--verm);display:inline-flex;align-items:center;gap:4px;padding:4px 12px;transition:all .12s;letter-spacing:.04em}
.toggle-btn:hover{background:var(--verm);color:#fff}
.answer-box{display:none;margin-top:8px;background:#fff8f4;border-left:4px solid var(--gold);padding:12px 16px}
.answer-box.open{display:block}
.answer-box .alabel{font-size:.62rem;font-weight:900;color:var(--deep);letter-spacing:.08em;margin-bottom:5px}
.answer-box p{font-size:.8rem;line-height:1.75;color:#1a0a00}
.entry-translation{margin-bottom:28px}
.entry-translation h3{font-size:.72rem;font-weight:900;letter-spacing:.14em;color:var(--deep);margin-bottom:12px;padding-bottom:5px;border-bottom:2px solid #e8c8a0}
.target-sentence{font-size:.88rem;font-weight:700;line-height:1.85;color:#1a0a00;margin-bottom:10px;background:#fff0e8;border-left:4px solid var(--verm);padding:12px 16px}
.trans-label{font-size:.7rem;color:#7a4a20;margin-bottom:4px;display:block}
.trans-input{width:100%;min-height:68px;border:none;border-bottom:2.5px solid #c8a870;padding:8px 4px;font-family:'Noto Sans JP',sans-serif;font-size:.88rem;resize:vertical;color:#1a0a00;background:transparent;transition:border-color .13s}
.trans-input:focus{outline:none;border-bottom-color:var(--verm)}
.ul-w{position:relative;display:inline;border-bottom:2px solid var(--gold);padding-bottom:1px;cursor:help}
.ul-w::after{content:attr(data-vocab);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);background:#1a0a00;color:#fff;font-size:.75rem;font-weight:700;padding:6px 13px;pointer-events:none;opacity:0;transition:opacity .18s ease,transform .18s ease;z-index:50;line-height:1.55;white-space:nowrap}
.ul-w::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%) translateY(4px);border:5px solid transparent;border-top-color:#1a0a00;pointer-events:none;opacity:0;transition:opacity .18s ease,transform .18s ease;z-index:51}
.ul-w:hover::after,.ul-w:hover::before,.ul-w.tip-open::after,.ul-w.tip-open::before{opacity:1;transform:translateX(-50%) translateY(0)}
sup.wn{font-size:.6em;font-weight:900;color:var(--gold);vertical-align:super;margin-left:1px}
.post-cats{padding:20px 24px 24px;border-top:2px solid #e8d8c0}
.post-cats h2{font-size:.78rem;font-weight:900;margin-bottom:12px;color:#7a4a20;letter-spacing:.1em}
.post-cats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pcat-card{border:3px solid var(--black);box-shadow:var(--sh-sm);padding:16px 14px;display:flex;flex-direction:column;text-decoration:none;color:#fff;transition:all .12s}
.pcat-card:hover{transform:translate(3px,3px);box-shadow:none}
.pcat-card.reading{background:#D94010}.pcat-card.writing{background:#3A7D44}.pcat-card.wagyaku{background:#1A5CA0}
.pcat-name{font-size:.95rem;font-weight:900;font-family:'Kaisei Decol',serif;letter-spacing:.04em}
.pcat-arrow{font-size:.7rem;font-weight:700;opacity:.8;margin-top:auto;padding-top:6px}

/* ── SIDEBAR ── */
.sidebar{display:flex;flex-direction:column;gap:14px;position:sticky;top:20px}
.sb{background:#fff;border:3px solid var(--black);box-shadow:var(--sh-sm)}
.sb-head{padding:8px 14px;font-size:.68rem;font-weight:900;letter-spacing:.1em;color:#fff;background:var(--verm);font-family:'Kaisei Decol',serif}
.sb-body{padding:4px 0}
.sb-list{list-style:none}
.sb-list li{border-bottom:1px solid #e8d8c0}
.sb-list li:last-child{border-bottom:none}
.sb-list a{display:block;padding:10px 14px;font-size:.78rem;line-height:1.45;transition:background .12s;color:#1a0a00;text-decoration:none}
.sb-list a:hover{background:#fff8f4}
.sb-date{font-size:.64rem;color:#7a4a20;margin-top:2px;display:block}
.sb-grammar{display:block;background:var(--black);border:3px solid var(--black);box-shadow:var(--sh-sm);padding:18px 16px;color:#fff;transition:all .12s;position:relative;overflow:hidden}
.sb-grammar::before{content:'';position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--verm)}
.sb-grammar:hover{transform:translate(3px,3px);box-shadow:none}
.sb-grammar-label{font-size:.6rem;font-weight:900;letter-spacing:.14em;opacity:.6;margin-bottom:5px;padding-left:10px}
.sb-grammar-title{font-size:.95rem;font-weight:900;font-family:'Kaisei Decol',serif;letter-spacing:.04em;padding-left:10px}
.sb-grammar-arrow{font-size:.72rem;font-weight:700;opacity:.7;margin-top:5px;display:block;padding-left:10px}

/* ── CAT HERO (archive) ── */
.cat-hero{padding:28px 0;border-bottom:4px solid var(--black);position:relative;overflow:hidden}
.cat-hero.reading{background:var(--verm)}.cat-hero.writing{background:#3A7D44}.cat-hero.wagyaku{background:#1A5CA0}
.cat-hero-inner{display:flex;align-items:center;gap:16px;position:relative;z-index:1}
.cat-hero-icon{width:56px;height:56px;background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cat-hero-icon svg{width:26px;height:26px;color:#fff}
.cat-hero h1{font-family:'Kaisei Decol',serif;font-size:1.9rem;font-weight:700;letter-spacing:.06em;color:#fff}
.cat-hero-sub{font-size:.8rem;color:rgba(255,255,255,.8);margin-top:5px}

.filter-bar{background:#fff8f4;border-bottom:3px solid var(--black)}
.filter-inner{display:flex;overflow-x:auto}
.filter-btn{font-family:'Kaisei Decol',serif;font-size:.78rem;font-weight:700;padding:11px 18px;border:none;background:none;cursor:pointer;color:#7a4a20;border-bottom:3px solid transparent;transition:all .13s;white-space:nowrap;letter-spacing:.06em;margin-bottom:-3px}
.filter-btn:hover{color:var(--verm)}
.filter-btn.active{color:var(--verm);border-bottom-color:var(--verm)}

.cat-layout{display:grid;grid-template-columns:1fr 280px;gap:24px;padding:28px 0 56px;align-items:start}
.art-list{display:flex;flex-direction:column;gap:12px}
.art-row{background:#fff;border:3px solid var(--black);box-shadow:var(--sh-sm);padding:16px 20px;display:flex;align-items:flex-start;gap:14px;text-decoration:none;color:#1a0a00;transition:all .12s}
.art-row:hover{transform:translate(3px,3px);box-shadow:none}
.art-row-color{width:60px;height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.art-row-color.reading{background:var(--verm)}.art-row-color.writing{background:#3A7D44}.art-row-color.wagyaku{background:#1A5CA0}
.art-row-color svg{width:24px;height:24px;color:#fff;opacity:.85}
.art-row-body{flex:1}
.art-row-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.lv-tag{background:#f5edd8;border:1.5px solid #c8a870;padding:2px 9px;font-size:.62rem;font-weight:700;color:#7a4a20}
.art-row-date{font-size:.68rem;color:#7a4a20}
.art-row-title{font-size:.95rem;font-weight:900;line-height:1.5;margin-bottom:4px}
.art-row-excerpt{font-size:.78rem;color:#5a3a10;line-height:1.75;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.art-row-arrow{font-size:.9rem;font-weight:900;color:#c8a870;flex-shrink:0;align-self:center;transition:color .12s}
.art-row:hover .art-row-arrow{color:var(--verm)}
.pagination{display:flex;justify-content:center;gap:6px;margin-top:20px}
.page-btn{width:36px;height:36px;border:2.5px solid var(--black);background:#fff;font-family:'Noto Sans JP',sans-serif;font-size:.8rem;font-weight:900;color:#1a0a00;cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}
.page-btn:hover{background:var(--verm);color:#fff;border-color:var(--verm);box-shadow:none;transform:translate(2px,2px)}
.page-btn.active{background:var(--verm);color:#fff;border-color:var(--verm)}

/* ── PAGE HERO (grammar) ── */
.page-hero{background:var(--deep);border-bottom:4px solid var(--black);padding:28px 0}
.page-hero-inner{display:flex;align-items:center;gap:16px}
.page-hero-icon{width:56px;height:56px;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.page-hero-icon svg{width:26px;height:26px;color:#fff}
.page-hero h1{font-family:'Kaisei Decol',serif;font-size:1.9rem;font-weight:700;letter-spacing:.06em;color:#fff}
.page-hero-sub{font-size:.8rem;color:rgba(255,255,255,.78);margin-top:5px}
.search-zone{background:#fff8f4;border-bottom:3px solid var(--black);padding:12px 0;position:sticky;top:0;z-index:100}
.search-zone-inner{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:180px}
.search-input{width:100%;padding:9px 14px 9px 36px;border:2.5px solid var(--black);font-family:'Noto Sans JP',sans-serif;font-size:.82rem;background:#fff;color:#1a0a00;transition:border-color .13s}
.search-input:focus{outline:none;border-color:var(--verm)}
.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#7a4a20}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap}
.fpill{font-family:'Kaisei Decol',serif;font-size:.76rem;font-weight:700;padding:6px 14px;border:2.5px solid var(--black);background:#fff;color:#1a0a00;cursor:pointer;transition:all .12s;white-space:nowrap;letter-spacing:.04em}
.fpill:hover{border-color:var(--verm);color:var(--verm)}
.fpill.active{background:var(--verm);border-color:var(--verm);color:#fff}
.grammar-layout{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:28px 0 56px;align-items:start}
.toc{background:#fff;border:3px solid var(--black);box-shadow:var(--sh-sm);position:sticky;top:68px}
.toc-head{padding:8px 14px;font-size:.68rem;font-weight:900;letter-spacing:.1em;color:#fff;background:var(--deep);font-family:'Kaisei Decol',serif}
.toc-list{list-style:none;padding:4px 0}
.toc-list a{display:block;padding:8px 14px;font-size:.78rem;color:#1a0a00;border-left:4px solid transparent;transition:all .13s;line-height:1.4}
.toc-list a:hover{background:#fff8f4;color:var(--verm);border-left-color:var(--verm)}
.grammar-main{display:flex;flex-direction:column;gap:10px}
.grammar-group{margin-bottom:4px}
.group-head{font-family:'Kaisei Decol',serif;font-size:.8rem;font-weight:700;letter-spacing:.1em;color:#7a4a20;padding:16px 0 10px;display:flex;align-items:center;gap:8px}
.group-head::after{content:'';flex:1;height:2px;background:#e8d8c0}
.gc{background:#fff;border:3px solid var(--black);box-shadow:var(--sh-sm);overflow:hidden;border-left:6px solid var(--black);transition:box-shadow .12s}
.gc:hover{box-shadow:var(--sh)}
.gc.j1{border-left-color:var(--verm)}.gc.j2{border-left-color:#C04018}.gc.j3{border-left-color:var(--deep)}.gc.high{border-left-color:var(--gold)}
.gc-header{padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;user-select:none;transition:background .12s}
.gc-header:hover{background:#fff8f4}
.gc-title-row{display:flex;align-items:center;gap:10px;flex:1}
.gc-num{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:900;color:#fff;flex-shrink:0}
.j1 .gc-num{background:var(--verm)}.j2 .gc-num{background:#C04018}.j3 .gc-num{background:var(--deep)}.high .gc-num{background:var(--gold)}
.gc-title{font-size:.9rem;font-weight:900;font-family:'Kaisei Decol',serif;letter-spacing:.02em}
.gc-sub{font-size:.7rem;color:#7a4a20;margin-top:1px}
.gc-lv{font-size:.62rem;font-weight:900;padding:2px 9px;white-space:nowrap}
.j1 .gc-lv{background:#fff0ec;color:var(--verm)}.j2 .gc-lv{background:#ffe8e0;color:#C04018}.j3 .gc-lv{background:#ffece8;color:var(--deep)}.high .gc-lv{background:#fff8e0;color:var(--gold)}
.gc-arr{width:24px;height:24px;border:2px solid var(--black);display:flex;align-items:center;justify-content:center;color:#7a4a20;transition:all .15s;flex-shrink:0;font-size:.7rem}
.gc-header.open .gc-arr{background:var(--verm);border-color:var(--verm);color:#fff;transform:rotate(180deg)}
.gc-body{display:none;padding:0 16px 16px;border-top:2px solid #e8d8c0}
.gc-body.open{display:block}
.gc-body p{font-size:.82rem;color:#3a1a00;margin-top:12px;line-height:1.8}
.formula{background:#fff8f4;border-left:4px solid var(--verm);padding:12px 16px;margin:12px 0;font-size:.82rem;font-weight:700;color:#3a1a00;line-height:1.6}
.formula-lbl{font-size:.62rem;font-weight:900;letter-spacing:.08em;color:var(--verm);margin-bottom:5px}
.ex-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:.78rem}
.ex-table th{background:#fff0ec;font-weight:700;padding:7px 12px;text-align:left;font-size:.68rem;color:#7a4a20;border-bottom:2px solid #e8d8c0}
.ex-table td{padding:8px 12px;border-bottom:1px solid #e8d8c0;vertical-align:top;line-height:1.6}
.ex-table tr:last-child td{border-bottom:none}
.ex-table td:first-child{font-style:italic;font-weight:700}
.j1 .ex-table td:first-child{color:var(--verm)}.j2 .ex-table td:first-child{color:#C04018}.j3 .ex-table td:first-child{color:var(--deep)}.high .ex-table td:first-child{color:var(--gold)}
.note-box{background:#fff8f4;border:1.5px solid #e8c8a0;padding:11px 15px;margin-top:10px;font-size:.78rem;line-height:1.7}
.note-lbl{font-size:.62rem;font-weight:900;color:var(--verm);margin-bottom:4px;letter-spacing:.06em}

/* ── OTHER CATS sidebar ── */
.other-cats{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px}
.oc{border:2.5px solid var(--black);padding:12px 10px;box-shadow:var(--sh-sm);text-decoration:none;transition:all .12s;display:block}
.oc:hover{transform:translate(3px,3px);box-shadow:none}
.oc.writing{background:#C04018;color:#fff}.oc.wagyaku{background:var(--deep);color:#fff}.oc.grammar{background:var(--gold);color:#fff}
.oc-name{font-size:.85rem;font-weight:900;font-family:'Kaisei Decol',serif}.oc-arrow{font-size:.7rem;opacity:.75;margin-top:5px;display:block}

@media(max-width:820px){
  .article-layout,.cat-layout,.grammar-layout{grid-template-columns:1fr}
  .sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .toc{position:static}.toc-list{display:grid;grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .gnav a:nth-child(n+3){display:none}
  .art-hero-title{font-size:1.05rem}
  .art-body,.art-header{padding-left:16px;padding-right:16px}
  .post-cats-grid{grid-template-columns:1fr 1fr}
  .sidebar{grid-template-columns:1fr}
  .toc-list{grid-template-columns:1fr}
}
a:focus-visible{outline:3px solid var(--verm);outline-offset:2px}



/* ── WordPress カスタムロゴ サイズ制御 ── */

/* ヘッダー内ロゴ */
.site-header .custom-logo-link,
.hdr-logo .custom-logo-link {
  display:flex;
  align-items:center;
}
.site-header .custom-logo,
.hdr-logo .custom-logo,
.hdr-logo-img {
  height:36px;
  width:auto;
  max-width:none;
  display:block;
  filter:none;
}

/* タイトルブロック（トップページ）内ロゴ */
.title-logo-wrap .custom-logo-link {
  display:inline-block;
}
.title-logo-wrap .custom-logo,
.site-logo-img {
  max-width:440px;
  width:86%;
  height:auto;
  display:inline-block;
}

/* フッター内ロゴ */
.footer-brand .custom-logo-link {
  display:block;
  margin-bottom:10px;
}
.footer-brand .custom-logo {
  height:26px;
  width:auto;
  display:block;
  filter:brightness(0) invert(1);
  opacity:.85;
}

.slide-right-deco{display:none}

/* ── アーカイブリンク ── */
.sb-list li a {display:block;padding:10px 14px;font-size:.78rem;color:#1a0a00;text-decoration:none;transition:background .12s;}
.sb-list li a:hover{background:#fff8f4;color:var(--verm)}

/* スライダーボタン SVG アイコン */
.slider-btn svg{display:block;pointer-events:none}

/* ヘッダーロゴの色 */
.hdr-logo-text{
  font-family:'Kaisei Decol',serif;
  font-size:1rem;font-weight:700;
  color:var(--black);
}

/* ============================================================
   投稿本文スタイル（.entry-content, .art-body の通常WP出力）
============================================================ */

/* 見出し */
.entry-content h2,
.art-body > h2 {
  font-family:'Kaisei Decol',serif;
  font-size:1.25rem;
  font-weight:700;
  letter-spacing:.04em;
  color:#fff;
  background:var(--verm);
  border:3px solid var(--black);
  padding:6px 16px;
  margin:28px 0 14px;
  display:inline-block;
  box-shadow:3px 3px 0 var(--black);
}
.entry-content h3,
.art-body > h3 {
  font-family:'Kaisei Decol',serif;
  font-size:1.05rem;
  font-weight:700;
  color:var(--verm);
  border-left:5px solid var(--verm);
  padding:4px 0 4px 12px;
  margin:22px 0 12px;
  background:rgba(217,64,16,.06);
}
.entry-content h4,
.art-body > h4 {
  font-size:.95rem;
  font-weight:900;
  color:var(--black);
  border-bottom:2px solid #e8d8c0;
  padding-bottom:4px;
  margin:18px 0 10px;
}
.entry-content h5,
.art-body > h5 {
  font-size:.9rem;
  font-weight:700;
  color:var(--deep);
  margin:14px 0 8px;
}
.entry-content h6,
.art-body > h6 {
  font-size:.85rem;
  font-weight:700;
  color:#7a4a20;
  margin:12px 0 8px;
}

/* 段落・基本テキスト */
.entry-content p,
.art-body > p {
  font-size:.92rem;
  line-height:1.9;
  color:#1a0a00;
  margin:0 0 14px;
}

/* リスト */
.entry-content ul,
.art-body > ul {
  list-style:none;
  padding:0;
  margin:0 0 16px;
}
.entry-content ul li,
.art-body > ul li {
  font-size:.9rem;
  line-height:1.8;
  padding:4px 0 4px 18px;
  position:relative;
  color:#1a0a00;
  border-bottom:1px solid #f0e8dc;
}
.entry-content ul li::before,
.art-body > ul li::before {
  content:'▶';
  position:absolute;
  left:0;
  font-size:.6rem;
  color:var(--verm);
  top:8px;
}

.entry-content ol,
.art-body > ol {
  list-style:none;
  padding:0;
  margin:0 0 16px;
  counter-reset:mep-ol;
}
.entry-content ol li,
.art-body > ol li {
  font-size:.9rem;
  line-height:1.8;
  padding:4px 0 4px 28px;
  position:relative;
  color:#1a0a00;
  border-bottom:1px solid #f0e8dc;
  counter-increment:mep-ol;
}
.entry-content ol li::before,
.art-body > ol li::before {
  content:counter(mep-ol);
  position:absolute;
  left:0;
  width:20px;
  height:20px;
  background:var(--verm);
  color:#fff;
  font-size:.65rem;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  top:6px;
}

/* 引用 */
.entry-content blockquote,
.art-body > blockquote {
  background:#fff8f4;
  border-left:5px solid var(--verm);
  padding:14px 18px;
  margin:16px 0;
  font-size:.9rem;
  color:#3a1a00;
  line-height:1.85;
}
.entry-content blockquote p,
.art-body > blockquote p {
  margin:0;
}

/* コード */
.entry-content code,
.art-body code {
  background:#f5edd8;
  border:1px solid #c8a870;
  padding:1px 6px;
  font-size:.85em;
  font-family:monospace;
  color:#5a1a00;
}
.entry-content pre,
.art-body pre {
  background:#1a0a00;
  color:#f5edd8;
  padding:16px 18px;
  overflow-x:auto;
  font-size:.82rem;
  line-height:1.7;
  border:3px solid var(--black);
  margin:16px 0;
}
.entry-content pre code,
.art-body pre code {
  background:none;
  border:none;
  padding:0;
  color:inherit;
  font-size:inherit;
}

/* 水平線 */
.entry-content hr,
.art-body hr {
  border:none;
  border-top:3px double var(--black);
  margin:24px 0;
}

/* テーブル */
.entry-content table,
.art-body > table {
  width:100%;
  border-collapse:collapse;
  margin:16px 0;
  font-size:.88rem;
}
.entry-content th,
.art-body > table th {
  background:var(--verm);
  color:#fff;
  padding:8px 12px;
  font-weight:700;
  text-align:left;
  border:2px solid var(--black);
}
.entry-content td,
.art-body > table td {
  padding:8px 12px;
  border:1.5px solid #e8d8c0;
  line-height:1.7;
  vertical-align:top;
}
.entry-content tr:nth-child(even) td,
.art-body > table tr:nth-child(even) td {
  background:#fff8f4;
}

/* 画像 */
.entry-content img,
.art-body img {
  max-width:100%;
  height:auto;
  display:block;
  border:3px solid var(--black);
  box-shadow:3px 3px 0 var(--black);
  margin:12px auto;
}
.entry-content figure,
.art-body figure {
  margin:16px 0;
}
.entry-content figcaption,
.art-body figcaption {
  font-size:.75rem;
  color:#7a4a20;
  text-align:center;
  margin-top:6px;
}

/* リンク */
.entry-content a,
.art-body a {
  color:var(--verm);
  text-decoration:underline;
  text-underline-offset:2px;
}
.entry-content a:hover,
.art-body a:hover {
  color:var(--deep);
}

/* 強調 */
.entry-content strong,
.art-body strong {
  font-weight:900;
  color:var(--verm);
}
.entry-content em,
.art-body em {
  font-style:italic;
  color:var(--deep);
}

/* ============================================================
   英文ブロック内要素（.entry-en 内）
============================================================ */

/* 段落 */
.entry-en p {
  font-size:.95rem;
  line-height:2.2;
  color:#1a0a00;
  margin:0 0 12px;
}
.entry-en p:last-child { margin-bottom:0; }

/* 強調（英文中のbold） */
.entry-en strong {
  font-weight:900;
  color:var(--black);
  background:rgba(217,64,16,.1);
  padding:0 2px;
}
.entry-en em {
  font-style:italic;
  color:var(--deep);
}

/* 下線語ツールチップ */
.entry-en .ul-w {
  border-bottom:2px solid var(--gold);
  cursor:help;
  position:relative;
}

/* 連番上付き文字 */
.entry-en sup.wn {
  font-size:.6em;
  font-weight:900;
  color:var(--gold);
  vertical-align:super;
  margin-left:1px;
}

/* 英文内の引用（問題の英文など） */
.entry-en blockquote {
  border-left:4px solid var(--gold);
  background:rgba(200,130,10,.07);
  padding:10px 16px;
  margin:12px 0;
  font-style:italic;
}

/* 和訳ブロック内 */
.entry-ja p {
  font-size:.9rem;
  line-height:2;
  color:#2a1000;
  margin:0 0 10px;
}
.entry-ja p:last-child { margin-bottom:0; }
.entry-ja strong { font-weight:900; }

/* ============================================================
   ページネーション リンク整形
============================================================ */
.pagination {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:6px;
  margin-top:24px;
}
.pagination a,
.pagination span {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:36px;
  height:36px;
  padding:0 10px;
  border:2.5px solid var(--black);
  background:#fff;
  font-size:.8rem;
  font-weight:900;
  color:var(--black);
  box-shadow:2px 2px 0 var(--black);
  transition:all .12s;
  text-decoration:none;
}
.pagination a:hover {
  background:var(--verm);
  color:#fff;
  border-color:var(--verm);
  box-shadow:none;
  transform:translate(2px,2px);
}
.pagination .current {
  background:var(--verm);
  color:#fff;
  border-color:var(--verm);
  box-shadow:none;
}
.pagination .dots {
  border:none;
  box-shadow:none;
  background:none;
}

/* ── サイドバーアーカイブ（wp_get_archives html format 出力） ── */
.sb-list li {
  border-bottom:1px solid #e8d8c0;
  list-style:none;
}
.sb-list li:last-child { border-bottom:none; }
.sb-list li a {
  display:flex;
  align-items:center;
  
  padding:9px 14px;
  font-size:.78rem;
  color:#1a0a00;
  text-decoration:none;
  transition:background .12s;
}
.sb-list li a:hover {
  background:#fff8f4;
  color:var(--verm);
}

/* 連載カラー追加 */
.series-img.s4{background:var(--deep)}
.series-img.s5{background:#C85A00}
.series-img.s6{background:var(--gold)}

/* アーカイブ select */
.sb-archive-select{padding:12px 14px}
.sb-archive-select select{
  width:100%;padding:9px 14px;
  border:2.5px solid var(--black);
  background:#fff;
  font-family:'Noto Sans JP',sans-serif;
  font-size:.82rem;color:#1a0a00;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--black);
}
.sb-archive-select select:focus{outline:none;border-color:var(--verm)}

/* ── 連載バナー（画像のみ） ── */
.series-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.series-banner {
  display:block;
  border:3px solid var(--black);
  box-shadow:var(--sh);
  overflow:hidden;
  transition:all .12s;
  aspect-ratio:16/9;
  background:#f0e8dc;
}
.series-banner:hover {
  transform:translate(4px,4px);
  box-shadow:none;
}
.series-banner img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border:none;
  box-shadow:none;
  margin:0;
}
.series-banner-placeholder {
  width:100%;height:100%;
  background:var(--verm);
  display:flex;align-items:center;justify-content:center;
  padding:16px;
}
.series-banner-placeholder span {
  font-family:'Kaisei Decol',serif;
  font-size:1rem;font-weight:700;
  color:#fff;text-align:center;
  line-height:1.4;
}
@media(max-width:860px){ .series-grid{grid-template-columns:1fr 1fr} }
@media(max-width:560px){ .series-grid{grid-template-columns:1fr} }

/* ── 投稿一覧ページネーション（the_posts_pagination用） ── */
.pagination .nav-links {
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;
}
.pagination .page-numbers {
  display:inline-flex;align-items:center;justify-content:center;
  min-width:36px;height:36px;padding:0 10px;
  border:2.5px solid var(--black);background:#fff;
  font-size:.8rem;font-weight:900;color:var(--black);
  box-shadow:2px 2px 0 var(--black);
  text-decoration:none;transition:all .12s;
}
.pagination .page-numbers:hover {
  background:var(--verm);color:#fff;
  border-color:var(--verm);box-shadow:none;
  transform:translate(2px,2px);
}
.pagination .page-numbers.current {
  background:var(--verm);color:#fff;
  border-color:var(--verm);box-shadow:none;
}
.pagination .page-numbers.dots {
  border:none;box-shadow:none;background:none;
}

/* アーカイブselectスタイル */
#mep-archive-select {
  width:100%;
  padding:9px 14px;
  border:2.5px solid var(--black);
  background:#fff;
  font-family:'Noto Sans JP',sans-serif;
  font-size:.82rem;
  color:#1a0a00;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--black);
  appearance:auto;
}
#mep-archive-select:focus {
  outline:none;
  border-color:var(--verm);
}

/* ── カスタムロゴリンクの調整 ── */
/* the_custom_logo() が出力する <a class="custom-logo-link"> */
.custom-logo-link {
  display:flex;
  align-items:center;
  text-decoration:none;
  line-height:1;
}
/* screen-reader-text（WPが入れるスクリーンリーダー用テキスト）を隠す */
.screen-reader-text {
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* フッターサイト名テキスト */
.footer-site-name {
  font-family:'Kaisei Decol',serif;
  font-size:.95rem;
  font-weight:700;
  color:#fff;
  margin-bottom:8px;
  letter-spacing:.04em;
}

/* ── サイドバー最新記事：カテゴリーラベルとタイトルの間隔 ── */
.sb-list a {
  display:block;
  padding:12px 14px;
}
.sb-list .cpill {
  display:inline-block;
  margin-bottom:6px;
}
.sb-list a > span {
  display:block;
  font-size:.78rem;
  line-height:1.5;
  color:#1a0a00;
}

/* ── cpill 色を強制（sb-list内でも白文字を維持） ── */
.cpill { color:#fff !important; }
.cpill.grammar { color:#fff !important; }

/* ── サイドバー最新記事：ラベルとタイトルの隙間 ── */
.sb-list a {
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:12px 14px;
}
.sb-list a > span {
  display:block;
  font-size:.78rem;
  line-height:1.5;
  color:#1a0a00;
}

/* ── sec-head：タイトルと「一覧へ」を両端に ── */
.sec-head {
  justify-content:space-between;
}

/* ── サイドバー最新記事：左揃え強制 ── */
.sb-list a {
  align-items:flex-start;
  text-align:left;
}

/* ── サイドバー最新記事 完全リセット ── */
.sb-list,
.sb-list li,
.sb-list a,
.sb-list a * {
  text-align:left !important;
}
.sb-list a {
  display:block !important;
  padding:12px 14px !important;
  align-items:unset !important;
  justify-content:unset !important;
}
.sb-list .cpill {
  display:inline-block !important;
  margin-bottom:6px !important;
  color:#fff !important;
}
.sb-list a > span {
  display:block !important;
  text-align:left !important;
}

/* ── 下付き文字・アンダーライン：バーミリオン太字 ── */
sub,
.entry-content sub,
.art-body sub {
  color:var(--verm);
  font-weight:900;
  font-size:.75em;
  vertical-align:sub;
}

u,
.entry-content u,
.art-body u {
  color:var(--verm);
  font-weight:900;
  text-decoration:underline;
  text-decoration-color:var(--verm);
  text-underline-offset:2px;
  text-decoration-thickness:2px;
}

/* ── 下付き文字・アンダーライン（WPブロックエディタ出力含む完全対応） ── */

/* <sub> タグ */
sub,
.entry-content sub,
.art-body sub,
.wp-block-paragraph sub {
  color:var(--verm) !important;
  font-weight:900 !important;
}

/* WPが出力する vertical-align:sub のspan */
.entry-content span[style*="vertical-align: sub"],
.entry-content span[style*="vertical-align:sub"],
.art-body span[style*="vertical-align: sub"],
.art-body span[style*="vertical-align:sub"] {
  color:var(--verm) !important;
  font-weight:900 !important;
}

/* <u> タグ */
u,
.entry-content u,
.art-body u,
.wp-block-paragraph u {
  color:var(--verm) !important;
  font-weight:900 !important;
  text-decoration:underline !important;
  text-decoration-color:var(--verm) !important;
  text-underline-offset:2px !important;
  text-decoration-thickness:2px !important;
}

/* WPが出力する text-decoration:underline のspan */
.entry-content span[style*="text-decoration: underline"],
.entry-content span[style*="text-decoration:underline"],
.art-body span[style*="text-decoration: underline"],
.art-body span[style*="text-decoration:underline"] {
  color:var(--verm) !important;
  font-weight:900 !important;
  text-decoration-color:var(--verm) !important;
  text-underline-offset:2px !important;
  text-decoration-thickness:2px !important;
}

/* ── WPが自動付与するbodyクラスによる余白・背景の干渉をリセット ── */
body.tag,
body.tag-*,
body.category,
body.archive,
body.date,
body.author {
  background-color:#F5EDD8 !important;
  background-image:radial-gradient(circle,#c8a870 1px,transparent 1px) !important;
  background-size:22px 22px !important;
}

/* WPデフォルトの.page-headerによる余白を除去 */
.page-header,
.archive-header,
.taxonomy-description {
  display:none !important;
}

/* .wrap の上部余白を整合 */
.wrap {
  padding-top:0;
}

/* cat-layout の上余白 */
.cat-layout {
  padding-top:24px;
}

/* ── ヘッダー検索ボタン ── */
.hdr-search-btn {
  background:none;
  border:none;
  cursor:pointer;
  padding:6px;
  color:var(--black);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:color .12s;
  margin-left:8px;
}
.hdr-search-btn:hover { color:var(--verm); }
.hdr-search-btn svg { display:block; }

/* ── 検索バー（トグル） ── */
.hdr-search-bar {
  background:#fff;
  border-bottom:3px solid var(--black);
  max-height:0;
  overflow:hidden;
  transition:max-height .25s ease, padding .25s ease;
  padding:0;
}
.hdr-search-bar.open {
  max-height:100px;
  padding:12px 0;
}

/* ── 検索フォーム ── */
.mep-search-form { width:100%; }
.mep-search-inner {
  display:flex;
  align-items:center;
  border:3px solid var(--black);
  background:#fff;
  box-shadow:3px 3px 0 var(--black);
  max-width:600px;
}
.mep-search-input {
  flex:1;
  border:none;
  outline:none;
  padding:10px 14px;
  font-family:'Noto Sans JP',sans-serif;
  font-size:.9rem;
  color:#1a0a00;
  background:transparent;
}
.mep-search-input::placeholder { color:#c8a870; }
.mep-search-btn {
  background:var(--verm);
  border:none;
  cursor:pointer;
  padding:10px 14px;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .12s;
  border-left:2px solid var(--black);
}
.mep-search-btn:hover { background:var(--deep); }

/* ── サイドバー内検索フォーム ── */
.sb .mep-search-inner {
  box-shadow:2px 2px 0 var(--black);
  border-width:2.5px;
}
.sb .mep-search-input { font-size:.82rem; padding:8px 12px; }
.sb .mep-search-btn { padding:8px 12px; }
.sb .mep-search-btn svg { width:15px; height:15px; }
