/*
Theme Name: Karada Blog
Theme URI: https://example.com/karada-blog
Author: Karada Blog
Description: トレーナー・治療院向けの信頼構築型ブログテーマ。Muum(TCD085)インスパイアのヒーロースライダー、タブ式カテゴリ一覧、カードグリッドを搭載。SEO・アフィリエイト対応。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
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: karada-blog
Tags: blog, minimalist, wellness, two-columns, right-sidebar, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --accent:        #4A7C6B;
  --accent-light:  #EAF2EF;
  --accent-dark:   #335A4D;
  --accent-rgb:    74,124,107;
  --warning:       #E8935A;
  --warning-light: #FEF3EB;
  --base:          #FFFFFF;
  --surface:       #F8F9F7;
  --surface-2:     #F2F5F3;
  --border:        #E4EAE7;
  --border-dark:   #C8D6D1;
  --tx-1:          #182320;
  --tx-2:          #4E6560;
  --tx-3:          #8AA49E;
  --cta-bg:        linear-gradient(135deg,#4A7C6B 0%,#2F5F50 100%);

  --serif:  'Noto Serif JP','Yu Mincho','YuMincho',Georgia,serif;
  --sans:   'Noto Sans JP','Hiragino Kaku Gothic ProN','Meiryo',sans-serif;

  --sz-xs:   clamp(.688rem,1.4vw,.75rem);
  --sz-sm:   clamp(.813rem,1.8vw,.875rem);
  --sz-base: clamp(.938rem,2vw,1rem);
  --sz-md:   clamp(1rem,2.2vw,1.063rem);
  --sz-lg:   clamp(1.063rem,2.5vw,1.25rem);
  --sz-xl:   clamp(1.25rem,3vw,1.5rem);
  --sz-2xl:  clamp(1.5rem,4vw,1.875rem);
  --sz-3xl:  clamp(1.875rem,5vw,2.375rem);
  --sz-hero: clamp(1.75rem,5.5vw,2.75rem);

  --sp-1:.25rem; --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem;
  --sp-5:1.25rem; --sp-6:1.5rem; --sp-8:2rem; --sp-10:2.5rem;
  --sp-12:3rem; --sp-16:4rem; --sp-20:5rem; --sp-24:6rem;

  --r-sm:4px; --r-md:8px; --r-lg:14px; --r-xl:20px; --r-full:9999px;

  --sh-xs:0 1px 4px rgba(0,0,0,.06);
  --sh-sm:0 2px 8px rgba(0,0,0,.08);
  --sh-md:0 4px 20px rgba(0,0,0,.10);
  --sh-lg:0 8px 36px rgba(0,0,0,.13);
  --sh-card:0 2px 16px rgba(74,124,107,.09);

  --dur-f:.15s; --dur-b:.25s; --dur-s:.4s;
  --ease:cubic-bezier(.4,0,.2,1);

  --w-content:760px;
  --w-wide:1160px;
  --w-sidebar:300px;
  --header-h:64px;
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{font-family:var(--sans);font-size:var(--sz-base);line-height:1.85;
  color:var(--tx-1);background:var(--base);-webkit-font-smoothing:antialiased}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color var(--dur-f)}
a:hover{color:var(--accent-dark)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ============================================================
   UTILITY
   ============================================================ */
.container{width:100%;max-width:var(--w-wide);margin:0 auto;padding:0 var(--sp-6)}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================================================
   LOADING SCREEN
   ============================================================ */
#page-loading{
  position:fixed;inset:0;z-index:9999;background:var(--base);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s var(--ease), visibility .5s;
}
#page-loading.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.loading-logo{
  font-family:var(--serif);font-size:var(--sz-2xl);font-weight:900;
  color:var(--accent);letter-spacing:.08em;
  animation:loadingPulse 1.2s ease-in-out infinite;
}
@keyframes loadingPulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ============================================================
   SCROLL PROGRESS
   ============================================================ */
.scroll-progress{
  position:fixed;top:var(--header-h);left:0;width:0;height:3px;z-index:200;
  background:linear-gradient(90deg,var(--accent),#7ABBA8);
  transition:width .08s linear;
}

/* ============================================================
   SITE HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;height:var(--header-h);
  background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;max-width:var(--w-wide);margin:0 auto;padding:0 var(--sp-6);
  gap:var(--sp-8);
}
.site-logo{
  font-family:var(--serif);font-size:var(--sz-lg);font-weight:900;
  color:var(--tx-1);letter-spacing:.04em;white-space:nowrap;flex-shrink:0;
}
.site-logo span{color:var(--accent)}
.site-logo img{height:36px;width:auto}

.header-nav{display:flex;align-items:center;gap:var(--sp-6)}
.header-nav a{
  font-size:var(--sz-sm);color:var(--tx-2);font-weight:600;
  letter-spacing:.02em;white-space:nowrap;
  transition:color var(--dur-f);
}
.header-nav a:hover{color:var(--accent)}

.header-actions{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}
.header-search-btn{
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;color:var(--tx-2);transition:background var(--dur-f),color var(--dur-f);
}
.header-search-btn:hover{background:var(--accent-light);color:var(--accent)}
.header-cta{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-2) var(--sp-5);background:var(--accent);color:#fff;
  font-size:var(--sz-xs);font-weight:700;border-radius:var(--r-full);
  letter-spacing:.05em;transition:background var(--dur-f),transform var(--dur-f);
}
.header-cta:hover{background:var(--accent-dark);color:#fff;transform:translateY(-1px)}

/* ハンバーガー */
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;padding:4px;
}
.hamburger span{
  display:block;height:2px;background:var(--tx-1);border-radius:2px;
  transition:transform .3s var(--ease),opacity .3s;
}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* モバイルメニュー */
.mobile-menu{
  display:none;position:fixed;inset:var(--header-h) 0 0 0;
  background:rgba(255,255,255,.98);backdrop-filter:blur(12px);
  z-index:99;overflow-y:auto;padding:var(--sp-8) var(--sp-6);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
.mobile-menu.is-open{opacity:1;visibility:visible}
.mobile-menu a{
  display:block;padding:var(--sp-4) 0;font-size:var(--sz-lg);
  font-weight:700;color:var(--tx-1);border-bottom:1px solid var(--border);
}
.mobile-menu-cta{
  display:block;margin-top:var(--sp-6);padding:var(--sp-4);
  background:var(--accent);color:#fff !important;text-align:center;
  border-radius:var(--r-lg);font-weight:700;font-size:var(--sz-lg);
}

@media(max-width:1023px){
  .header-nav{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:block}
}
@media(max-width:600px){.header-cta{display:none}}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb-bar{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:var(--sp-3) 0;
}
.breadcrumb{
  display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-2);
  font-size:var(--sz-xs);color:var(--tx-3);
}
.breadcrumb a{color:var(--tx-3);transition:color var(--dur-f)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb__sep{color:var(--border-dark)}
.breadcrumb__current{color:var(--tx-2)}

/* ============================================================
   HERO SLIDER  (Muum風 全幅ヒーロー)
   ============================================================ */
.hero{
  position:relative;width:100%;
  height:clamp(460px,65vh,720px);
  overflow:hidden;background:var(--tx-1);
}
.hero-slides{position:relative;width:100%;height:100%}

.hero-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity .8s var(--ease);pointer-events:none;
}
.hero-slide.is-active{opacity:1;pointer-events:auto}

.hero-slide__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1.06);
  transition:transform 7s linear;
}
.hero-slide.is-active .hero-slide__bg{transform:scale(1)}

.hero-slide__bg--placeholder{
  background:linear-gradient(135deg,#1B3A34 0%,#4A7C6B 60%,#6ABEAA 100%);
}

.hero-slide__overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to top,
    rgba(15,28,25,.9) 0%,
    rgba(15,28,25,.5) 45%,
    rgba(15,28,25,.18) 100%
  );
}

.hero-slide__body{
  position:absolute;bottom:0;left:0;right:0;
  padding:0 0 var(--sp-16);
}
.hero-slide__body-inner{
  max-width:var(--w-wide);margin:0 auto;padding:0 var(--sp-6);
}

.hero-slide__cat{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:var(--accent);color:#fff;
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.1em;
  padding:3px var(--sp-4);border-radius:var(--r-full);
  margin-bottom:var(--sp-4);text-transform:uppercase;
}
.hero-slide__title{
  font-family:var(--serif);font-size:var(--sz-hero);font-weight:900;
  color:#fff;line-height:1.38;letter-spacing:-.01em;
  max-width:680px;margin-bottom:var(--sp-3);
}
.hero-slide__title a{color:#fff}
.hero-slide__title a:hover{color:rgba(255,255,255,.85)}
.hero-slide__excerpt{
  font-size:var(--sz-sm);color:rgba(255,255,255,.75);
  line-height:1.75;max-width:540px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin-bottom:var(--sp-3);
}
.hero-slide__meta{
  font-size:var(--sz-xs);color:rgba(255,255,255,.5);letter-spacing:.03em;
}

/* スライダーUI */
.hero-ui{
  position:absolute;bottom:var(--sp-6);right:var(--sp-6);
  display:flex;align-items:center;gap:var(--sp-4);z-index:10;
}
.hero-dots{display:flex;gap:var(--sp-2)}
.hero-dot{
  width:8px;height:8px;border-radius:50%;border:none;padding:0;
  background:rgba(255,255,255,.35);cursor:pointer;
  transition:background var(--dur-f),transform var(--dur-f);
}
.hero-dot.is-active{background:#fff;transform:scale(1.4)}

.hero-arrows{display:flex;gap:var(--sp-2)}
.hero-arrow{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);
  color:#fff;display:flex;align-items:center;justify-content:center;
  transition:background var(--dur-f);
}
.hero-arrow:hover{background:rgba(255,255,255,.28)}
.hero-arrow svg{width:18px;height:18px}

/* プログレスバー（スライド） */
.hero-progress{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:rgba(255,255,255,.15);z-index:10;
}
.hero-progress-bar{
  height:100%;background:var(--accent);width:0%;
  transition:width 0s linear;
}

@media(max-width:767px){
  .hero{height:clamp(320px,52vw,480px)}
  .hero-slide__excerpt{display:none}
  .hero-arrows{display:none}
  .hero-slide__body{padding-bottom:var(--sp-12)}
}

/* ============================================================
   CATEGORY TABS  (Muum風タブ)
   ============================================================ */
.cat-tabs-wrap{
  background:var(--base);
  border-bottom:2px solid var(--border);
  position:sticky;top:var(--header-h);z-index:90;
}
.cat-tabs{
  display:flex;overflow-x:auto;scrollbar-width:none;
  max-width:var(--w-wide);margin:0 auto;padding:0 var(--sp-6);
}
.cat-tabs::-webkit-scrollbar{display:none}
.cat-tab{
  flex-shrink:0;padding:var(--sp-4) var(--sp-5);
  font-size:var(--sz-sm);font-weight:700;color:var(--tx-2);
  border-bottom:3px solid transparent;white-space:nowrap;
  transition:color var(--dur-f),border-color var(--dur-f);
  letter-spacing:.02em;background:none;border-top:none;border-left:none;border-right:none;
  border-radius:0;cursor:pointer;
}
.cat-tab:hover{color:var(--accent)}
.cat-tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}
.cat-tab__count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 4px;
  background:var(--accent-light);color:var(--accent);
  font-size:.62rem;font-weight:700;border-radius:var(--r-full);margin-left:5px;
}

/* ============================================================
   MAIN LAYOUT
   ============================================================ */
.main-layout{
  display:grid;
  grid-template-columns:1fr var(--w-sidebar);
  gap:var(--sp-10);
  max-width:var(--w-wide);margin:0 auto;
  padding:var(--sp-10) var(--sp-6);
  align-items:start;
}
@media(max-width:1100px){
  .main-layout{grid-template-columns:1fr;gap:var(--sp-10)}
}

/* ============================================================
   POST GRID  (カードグリッド)
   ============================================================ */
.grid-header{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:var(--sp-6);gap:var(--sp-4);
}
.grid-title{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:900;
  color:var(--tx-1);display:flex;align-items:center;gap:var(--sp-3);
}
.grid-title::before{
  content:'';display:block;width:4px;height:1.2em;
  background:var(--accent);border-radius:2px;flex-shrink:0;
}
.grid-subtitle{font-size:var(--sz-xs);color:var(--tx-3)}

/* 3カラムグリッド */
.post-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-5);
}

/* フィーチャードカード（1枚目：2カラム幅） */
.post-card--featured{
  grid-column:1/-1;
  display:grid;grid-template-columns:1.55fr 1fr;
  border-radius:var(--r-xl);overflow:hidden;
  background:var(--base);border:1px solid var(--border);
  box-shadow:var(--sh-card);
  transition:transform var(--dur-b) var(--ease),box-shadow var(--dur-b) var(--ease);
}
.post-card--featured:hover{
  transform:translateY(-5px);box-shadow:var(--sh-md);
}
.post-card--featured .card-thumb-link{
  display:block;overflow:hidden;min-height:260px;
}
.post-card--featured .card-thumb{
  width:100%;height:100%;object-fit:cover;
  transition:transform var(--dur-s) var(--ease);
}
.post-card--featured:hover .card-thumb{transform:scale(1.04)}
.post-card--featured .card-body{
  padding:var(--sp-8) var(--sp-7);
  display:flex;flex-direction:column;justify-content:center;
}
.post-card--featured .card-title{font-size:var(--sz-xl)}
.post-card--featured .card-excerpt{display:-webkit-box}

/* 通常カード */
.post-card{
  background:var(--base);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
  transition:transform var(--dur-b) var(--ease),box-shadow var(--dur-b) var(--ease);
  display:flex;flex-direction:column;
}
.post-card:not(.post-card--featured):hover{
  transform:translateY(-5px);box-shadow:var(--sh-md);
}

.card-thumb-link{display:block;overflow:hidden;flex-shrink:0}
.card-thumb{
  width:100%;aspect-ratio:16/9;object-fit:cover;
  transition:transform var(--dur-s) var(--ease);background:var(--surface-2);
}
.post-card:hover .card-thumb{transform:scale(1.04)}
.card-thumb--empty{
  aspect-ratio:16/9;background:var(--accent-light);
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;opacity:.35;
}

.card-body{padding:var(--sp-5);flex:1;display:flex;flex-direction:column}

.card-cat{
  display:inline-flex;align-items:center;
  background:var(--accent-light);color:var(--accent);
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.06em;
  padding:2px var(--sp-3);border-radius:var(--r-full);
  margin-bottom:var(--sp-2);transition:background var(--dur-f),color var(--dur-f);
  align-self:flex-start;
}
.card-cat:hover{background:var(--accent);color:#fff}

.card-title{
  font-family:var(--serif);font-size:var(--sz-md);font-weight:700;
  line-height:1.55;color:var(--tx-1);flex:1;
  margin-bottom:var(--sp-3);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.card-title a{color:inherit;transition:color var(--dur-f)}
.card-title a:hover{color:var(--accent)}

.card-excerpt{
  font-size:var(--sz-sm);color:var(--tx-2);line-height:1.75;
  margin-bottom:var(--sp-4);
  display:none; /* featuredのみ表示 */
  -webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}

.card-meta{
  display:flex;align-items:center;gap:var(--sp-3);
  font-size:var(--sz-xs);color:var(--tx-3);margin-top:auto;
}
.card-meta time{}
.card-reading::before{content:'⏱ ';font-size:.85em}

/* レスポンシブ */
@media(max-width:1100px){
  .post-grid{grid-template-columns:repeat(2,1fr)}
  .post-card--featured{
    grid-column:1/-1;grid-template-columns:1fr;
  }
  .post-card--featured .card-thumb-link{min-height:220px}
}
@media(max-width:600px){
  .post-grid{grid-template-columns:1fr;gap:var(--sp-4)}
  .post-card--featured{grid-template-columns:1fr}
}

/* ============================================================
   ANIMATION CLASSES (フェードイン)
   ============================================================ */
.fade-up{
  opacity:0;transform:translateY(24px);
  transition:opacity .55s var(--ease),transform .55s var(--ease);
}
.fade-up.is-visible{opacity:1;transform:none}
.fade-up:nth-child(1){transition-delay:.05s}
.fade-up:nth-child(2){transition-delay:.12s}
.fade-up:nth-child(3){transition-delay:.19s}
.fade-up:nth-child(4){transition-delay:.26s}
.fade-up:nth-child(5){transition-delay:.33s}
.fade-up:nth-child(6){transition-delay:.4s}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination{margin-top:var(--sp-10)}
.pagination .page-numbers{
  display:flex;flex-wrap:wrap;gap:var(--sp-2);
  justify-content:center;list-style:none;padding:0;
}
.pagination .page-numbers a,
.pagination .page-numbers span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 var(--sp-3);
  border:1px solid var(--border);border-radius:var(--r-md);
  font-size:var(--sz-sm);font-weight:700;color:var(--tx-2);
  background:var(--base);transition:all var(--dur-f);
}
.pagination .page-numbers a:hover{
  background:var(--accent-light);border-color:var(--accent);color:var(--accent)
}
.pagination .page-numbers .current{
  background:var(--accent);border-color:var(--accent);color:#fff;
}
.pagination .page-numbers .prev,
.pagination .page-numbers .next{font-size:var(--sz-xs);letter-spacing:.03em}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar{position:sticky;top:calc(var(--header-h) + var(--sp-6));display:flex;flex-direction:column;gap:var(--sp-5)}

.widget{
  background:var(--base);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-6);
}
.widget-title{
  font-family:var(--serif);font-size:var(--sz-base);font-weight:900;
  color:var(--tx-1);padding-bottom:var(--sp-3);margin-bottom:var(--sp-4);
  border-bottom:2px solid var(--border);position:relative;
}
.widget-title::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:28px;height:2px;background:var(--accent);
}

/* サイドCTA */
.widget-cta{
  background:var(--cta-bg);border:none;border-radius:var(--r-lg);
  padding:var(--sp-6);text-align:center;color:#fff;
}
.widget-cta__title{
  font-family:var(--serif);font-size:var(--sz-lg);font-weight:900;
  margin-bottom:var(--sp-3);line-height:1.4;
}
.widget-cta__desc{font-size:var(--sz-xs);opacity:.82;line-height:1.7;margin-bottom:var(--sp-5)}
.widget-cta__btn{
  display:block;padding:var(--sp-3) var(--sp-5);
  background:#fff;color:var(--accent) !important;font-weight:800;
  font-size:var(--sz-sm);border-radius:var(--r-full);
  transition:transform var(--dur-f),box-shadow var(--dur-f);
}
.widget-cta__btn:hover{transform:scale(1.03);box-shadow:var(--sh-sm)}

/* 検索 */
.widget-search form{display:flex;gap:var(--sp-2)}
.widget-search input[type=search]{
  flex:1;padding:var(--sp-2) var(--sp-3);
  border:1px solid var(--border);border-radius:var(--r-md);
  font-family:var(--sans);font-size:var(--sz-sm);color:var(--tx-1);
  transition:border-color var(--dur-f);
}
.widget-search input[type=search]:focus{outline:none;border-color:var(--accent)}
.widget-search button{
  padding:var(--sp-2) var(--sp-3);background:var(--accent);color:#fff;
  border-radius:var(--r-md);font-size:var(--sz-sm);font-weight:700;
  transition:background var(--dur-f);
}
.widget-search button:hover{background:var(--accent-dark)}

/* 人気記事 */
.popular-list{display:flex;flex-direction:column;gap:var(--sp-4)}
.popular-item{display:flex;gap:var(--sp-3);align-items:flex-start}
.popular-rank{
  width:22px;height:22px;border-radius:50%;background:var(--border);
  color:var(--tx-3);font-size:.65rem;font-weight:800;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;margin-top:2px;
}
.popular-rank.r1{background:#F0C040;color:#fff}
.popular-rank.r2{background:#BABABA;color:#fff}
.popular-rank.r3{background:#C8935A;color:#fff}
.popular-item__link{display:flex;gap:var(--sp-3);flex:1;align-items:flex-start}
.popular-item__thumb{
  width:62px;height:62px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0;
}
.popular-item__thumb--empty{
  background:var(--accent-light);display:flex;align-items:center;
  justify-content:center;font-size:1.2rem;opacity:.4;flex-shrink:0;
  width:62px;height:62px;border-radius:var(--r-sm);
}
.popular-item__title{
  font-size:var(--sz-xs);font-weight:600;line-height:1.55;
  color:var(--tx-1);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  transition:color var(--dur-f);
}
.popular-item__link:hover .popular-item__title{color:var(--accent)}
.popular-item__date{font-size:.62rem;color:var(--tx-3);display:block;margin-top:3px}

/* カテゴリ */
.cat-list{display:flex;flex-direction:column}
.cat-list a{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-2) 0;border-bottom:1px dashed var(--border);
  font-size:var(--sz-sm);color:var(--tx-2);
  transition:color var(--dur-f),padding-left var(--dur-f);
}
.cat-list li:last-child a{border-bottom:none}
.cat-list a:hover{color:var(--accent);padding-left:var(--sp-2)}
.cat-count{
  background:var(--accent-light);color:var(--accent);
  font-size:.62rem;font-weight:700;padding:1px 6px;border-radius:var(--r-full);
}

/* プロフィール */
.profile-widget__top{display:flex;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-3)}
.profile-widget__avatar{
  width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0;
}
.profile-widget__name{font-size:var(--sz-md);font-weight:800;color:var(--tx-1)}
.profile-widget__role{font-size:var(--sz-xs);color:var(--accent);font-weight:600;margin-top:2px}
.profile-widget__bio{font-size:var(--sz-xs);color:var(--tx-2);line-height:1.75}

/* タグ */
.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--sp-2)}
.tag-link{
  padding:3px var(--sp-3);background:var(--surface-2);
  border:1px solid var(--border);color:var(--tx-2);
  font-size:var(--sz-xs);font-weight:600;border-radius:var(--r-full);
  transition:all var(--dur-f);
}
.tag-link:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}

/* ============================================================
   ARTICLE LAYOUT
   ============================================================ */
.article-wrap{
  display:grid;
  grid-template-columns:1fr var(--w-sidebar);
  gap:var(--sp-10);
  max-width:var(--w-wide);margin:0 auto;
  padding:var(--sp-10) var(--sp-6);
  align-items:start;
}
@media(max-width:1100px){
  .article-wrap{grid-template-columns:1fr}
}

/* 記事ヘッダー */
.article-header{margin-bottom:var(--sp-10)}
.article-cat{
  display:inline-flex;align-items:center;
  background:var(--accent-light);color:var(--accent);
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.08em;
  padding:3px var(--sp-4);border-radius:var(--r-full);
  margin-bottom:var(--sp-4);text-transform:uppercase;
}
.article-title{
  font-family:var(--serif);
  font-size:clamp(1.6rem,5vw,2.5rem);
  font-weight:900;line-height:1.35;letter-spacing:-.01em;
  color:var(--tx-1);margin-bottom:var(--sp-5);
}
.article-lead{
  font-size:var(--sz-lg);line-height:1.9;color:var(--tx-2);
  border-left:3px solid var(--accent);padding-left:var(--sp-5);
  margin-bottom:var(--sp-6);
}
.article-meta{
  display:flex;align-items:center;gap:var(--sp-5);flex-wrap:wrap;
  font-size:var(--sz-xs);color:var(--tx-3);
  padding-bottom:var(--sp-6);border-bottom:1px solid var(--border);
  margin-bottom:var(--sp-8);
}
.article-meta__item{display:flex;align-items:center;gap:var(--sp-2)}
.article-meta svg{width:13px;height:13px;color:var(--accent)}
.article-eyecatch{
  width:100%;aspect-ratio:16/9;object-fit:cover;
  border-radius:var(--r-xl);margin-bottom:var(--sp-8);box-shadow:var(--sh-md);
}

/* TOCインライン */
.toc-inline{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:var(--sp-6);margin-bottom:var(--sp-8);
}
.toc-inline__title{
  font-family:var(--serif);font-size:var(--sz-md);font-weight:800;
  color:var(--tx-1);margin-bottom:var(--sp-4);
  display:flex;align-items:center;gap:var(--sp-3);
}
.toc-inline__title::before{content:'📋';font-size:1.1rem}
.toc-list{display:flex;flex-direction:column;gap:var(--sp-1)}
.toc-list a{
  font-size:var(--sz-sm);color:var(--tx-2);padding:var(--sp-2) 0;
  border-bottom:1px dashed var(--border);display:block;
  transition:color var(--dur-f),padding-left var(--dur-f);
}
.toc-list a:last-child{border-bottom:none}
.toc-list a:hover,.toc-list a.is-active{color:var(--accent);padding-left:var(--sp-2)}
.toc-list a.toc-h3{padding-left:var(--sp-5);font-size:var(--sz-xs)}

/* ============================================================
   ARTICLE BODY
   ============================================================ */
.article-body{font-size:var(--sz-md);line-height:1.95;color:var(--tx-1)}

.article-body h2{
  font-family:var(--serif);font-size:var(--sz-2xl);font-weight:900;
  color:var(--tx-1);margin-top:var(--sp-16);margin-bottom:var(--sp-6);
  padding:var(--sp-4) var(--sp-5);
  background:var(--surface);border-left:4px solid var(--accent);
  border-radius:0 var(--r-md) var(--r-md) 0;line-height:1.4;
}
.article-body h3{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:700;
  color:var(--tx-1);margin-top:var(--sp-10);margin-bottom:var(--sp-4);
  padding-bottom:var(--sp-2);border-bottom:2px solid var(--accent-light);
  position:relative;
}
.article-body h3::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:36px;height:2px;background:var(--accent);
}
.article-body h4{
  font-size:var(--sz-lg);font-weight:700;color:var(--tx-1);
  margin-top:var(--sp-8);margin-bottom:var(--sp-3);
}
.article-body p{margin-bottom:var(--sp-5)}
.article-body strong{font-weight:700;color:var(--tx-1)}
.article-body em{font-style:italic}
.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

.article-body ul,.article-body ol{margin-bottom:var(--sp-5);padding-left:var(--sp-2)}
.article-body ul li,.article-body ol li{
  position:relative;padding-left:var(--sp-6);margin-bottom:var(--sp-3);line-height:1.8;
}
.article-body ul li::before{
  content:'';position:absolute;left:0;top:.68em;
  width:8px;height:8px;background:var(--accent);border-radius:50%;
}
.article-body ol{counter-reset:ol-c}
.article-body ol li{counter-increment:ol-c}
.article-body ol li::before{
  content:counter(ol-c);position:absolute;left:0;top:.1em;
  width:22px;height:22px;background:var(--accent);color:#fff;
  font-size:.68rem;font-weight:800;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.article-body blockquote{
  border-left:4px solid var(--accent);padding:var(--sp-4) var(--sp-6);
  background:var(--surface);border-radius:0 var(--r-md) var(--r-md) 0;
  margin:var(--sp-6) 0;font-style:italic;color:var(--tx-2);
}
.article-body table{
  width:100%;border-collapse:collapse;margin:var(--sp-6) 0;font-size:var(--sz-sm);
  overflow-x:auto;display:block;
}
.article-body th,.article-body td{
  padding:var(--sp-3) var(--sp-4);border:1px solid var(--border);text-align:left;
}
.article-body th{background:var(--accent);color:#fff;font-weight:700}
.article-body tr:nth-child(even) td{background:var(--surface)}
.article-body img{border-radius:var(--r-md);margin:var(--sp-4) 0;box-shadow:var(--sh-sm)}
.article-body hr{border:none;border-top:2px solid var(--border);margin:var(--sp-10) 0}

/* ============================================================
   CUSTOM BLOCKS (ショートコード出力)
   ============================================================ */

/* 問題提起 */
.kb-problem{
  background:linear-gradient(135deg,#FEF9F1,#FFF6EE);
  border:1px solid #F0D9B8;border-radius:var(--r-xl);
  padding:var(--sp-8);margin:var(--sp-10) 0;position:relative;overflow:hidden;
}
.kb-problem::after{
  content:'🤔';font-size:5rem;position:absolute;right:var(--sp-6);top:var(--sp-3);opacity:.08;
}
.kb-problem__badge{
  display:inline-block;background:var(--warning);color:#fff;
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.1em;
  padding:2px var(--sp-4);border-radius:var(--r-full);margin-bottom:var(--sp-4);
}
.kb-problem__title{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:900;
  color:#4A3010;margin-bottom:var(--sp-5);line-height:1.45;
}
.kb-problem__list{display:flex;flex-direction:column;gap:var(--sp-3)}
.kb-problem__item{
  display:flex;align-items:flex-start;gap:var(--sp-3);
  padding:var(--sp-3) var(--sp-4);
  background:rgba(255,255,255,.75);border-radius:var(--r-md);
  font-size:var(--sz-md);color:#4A3010;
}
.kb-problem__item::before{
  content:'✓';color:var(--warning);font-weight:700;flex-shrink:0;
}

/* ステップ */
.kb-steps{margin:var(--sp-10) 0}
.kb-steps__title{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:900;
  margin-bottom:var(--sp-6);display:flex;align-items:center;gap:var(--sp-3);
}
.kb-steps__title::before{
  content:'';width:4px;height:1.3em;background:var(--accent);border-radius:2px;
}
.step-list{position:relative;display:flex;flex-direction:column}
.step-list::before{
  content:'';position:absolute;left:20px;top:22px;bottom:22px;
  width:2px;background:var(--border);z-index:0;
}
.step-item{display:flex;gap:var(--sp-5);padding:var(--sp-4) 0;position:relative;z-index:1}
.step-num{
  width:42px;height:42px;background:var(--accent);color:#fff;
  font-size:var(--sz-sm);font-weight:900;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 4px var(--base),0 0 0 5px var(--border);
}
.step-content{flex:1;padding-top:var(--sp-2) var(--sp-4)}
.step-content{padding-top:var(--sp-1)}
.step-title{font-weight:700;font-size:var(--sz-lg);margin-bottom:var(--sp-2)}
.step-desc{font-size:var(--sz-base);color:var(--tx-2);line-height:1.8}

/* ポイントカード */
.kb-point-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:var(--sp-4);margin:var(--sp-8) 0;
}
.point-card{
  background:var(--base);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:var(--sp-6);text-align:center;
  box-shadow:var(--sh-card);
  transition:transform var(--dur-b),box-shadow var(--dur-b);
}
.point-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.point-card__icon{font-size:2.2rem;margin-bottom:var(--sp-3)}
.point-card__title{font-weight:700;font-size:var(--sz-base);margin-bottom:var(--sp-2)}
.point-card__desc{font-size:var(--sz-sm);color:var(--tx-2);line-height:1.75}

/* 事例 */
.kb-case{
  background:var(--base);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;margin:var(--sp-10) 0;box-shadow:var(--sh-sm);
}
.kb-case__head{
  background:var(--accent);padding:var(--sp-4) var(--sp-6);
  display:flex;align-items:center;gap:var(--sp-3);color:#fff;
  font-size:var(--sz-sm);font-weight:700;letter-spacing:.05em;
}
.kb-case__body{padding:var(--sp-6) var(--sp-8)}
.kb-case__profile{
  display:flex;align-items:center;gap:var(--sp-4);
  padding-bottom:var(--sp-5);margin-bottom:var(--sp-5);
  border-bottom:1px solid var(--border);
}
.kb-case__avatar{
  width:52px;height:52px;border-radius:50%;background:var(--accent-light);
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;
}
.kb-case__profile-info strong{display:block;font-weight:700}
.kb-case__profile-info span{font-size:var(--sz-xs);color:var(--tx-3)}
.kb-before-after{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin-top:var(--sp-4);
}
.kb-before,.kb-after{padding:var(--sp-4);border-radius:var(--r-md);font-size:var(--sz-sm)}
.kb-before{background:#FEF2F2;border:1px solid #FECACA}
.kb-after{background:var(--accent-light);border:1px solid #B6D9CF}
.kb-before__label{color:#DC2626;font-size:var(--sz-xs);font-weight:700;display:block;margin-bottom:var(--sp-2)}
.kb-after__label{color:var(--accent);font-size:var(--sz-xs);font-weight:700;display:block;margin-bottom:var(--sp-2)}
@media(max-width:600px){.kb-before-after{grid-template-columns:1fr}}

/* インフォボックス */
.kb-info{
  display:flex;gap:var(--sp-4);padding:var(--sp-5) var(--sp-6);
  border-radius:var(--r-md);margin:var(--sp-6) 0;font-size:var(--sz-sm);line-height:1.8;
}
.kb-info--tip{background:var(--accent-light);border-left:4px solid var(--accent)}
.kb-info--warn{background:#FEF9E7;border-left:4px solid #F0C040}
.kb-info--caution{background:#FEF2F2;border-left:4px solid #E05252}
.kb-info__icon{font-size:1.4rem;flex-shrink:0}
.kb-info__content strong{display:block;font-weight:700;margin-bottom:3px;font-size:var(--sz-base)}

/* アフィリエイト */
.kb-affiliate{
  border:2px dashed var(--warning);border-radius:var(--r-xl);
  padding:var(--sp-2);margin:var(--sp-12) 0;position:relative;
}
.kb-affiliate::before{
  content:'PR / アフィリエイト';
  position:absolute;top:-12px;left:var(--sp-5);
  background:var(--base);padding:0 var(--sp-3);
  font-size:var(--sz-xs);font-weight:700;color:var(--warning);letter-spacing:.06em;
}
.aff-card{background:var(--base);border-radius:var(--r-lg);padding:var(--sp-6)}
.aff-card__row{display:flex;gap:var(--sp-5);align-items:flex-start;margin-bottom:var(--sp-5)}
.aff-card__img{
  width:100px;height:100px;object-fit:cover;border-radius:var(--r-md);
  flex-shrink:0;background:var(--surface-2);
}
.aff-card__name{font-size:var(--sz-lg);font-weight:900;margin-bottom:var(--sp-2)}
.aff-card__desc{font-size:var(--sz-sm);color:var(--tx-2);line-height:1.75;margin-bottom:var(--sp-3)}
.aff-tags{display:flex;gap:var(--sp-2);flex-wrap:wrap}
.aff-tag{
  padding:2px var(--sp-3);background:var(--accent-light);color:var(--accent);
  font-size:var(--sz-xs);font-weight:700;border-radius:var(--r-full);
}
.aff-pros-cons{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);
  padding-top:var(--sp-4);border-top:1px solid var(--border);margin-top:var(--sp-4);
  font-size:var(--sz-sm);
}
.aff-pros h5{color:var(--accent);font-size:var(--sz-xs);font-weight:700;letter-spacing:.06em;margin-bottom:var(--sp-2)}
.aff-cons h5{color:#E05252;font-size:var(--sz-xs);font-weight:700;letter-spacing:.06em;margin-bottom:var(--sp-2)}
.aff-pros ul li,.aff-cons ul li{
  padding-left:var(--sp-4);margin-bottom:3px;position:relative;color:var(--tx-2);line-height:1.7;
}
.aff-pros ul li::before{content:'○';position:absolute;left:0;color:var(--accent)}
.aff-cons ul li::before{content:'△';position:absolute;left:0;color:#E05252}
.aff-cta{text-align:center;margin-top:var(--sp-5)}
.btn-aff{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-4) var(--sp-8);background:var(--warning);color:#fff;
  font-weight:800;font-size:var(--sz-base);border-radius:var(--r-full);
  box-shadow:0 4px 16px rgba(232,147,90,.35);
  transition:background var(--dur-f),transform var(--dur-f),box-shadow var(--dur-f);
}
.btn-aff:hover{
  background:#D07A45;color:#fff;
  transform:translateY(-2px);box-shadow:0 6px 22px rgba(232,147,90,.45);
}
.aff-note{font-size:.68rem;color:var(--tx-3);text-align:center;margin-top:var(--sp-2)}
@media(max-width:600px){
  .aff-card__row{flex-direction:column}
  .aff-card__img{width:100%;height:180px}
  .aff-pros-cons{grid-template-columns:1fr}
}

/* CTA */
.kb-cta{
  background:var(--cta-bg);border-radius:var(--r-xl);
  padding:var(--sp-10) var(--sp-8);text-align:center;
  margin:var(--sp-12) 0;position:relative;overflow:hidden;
}
.kb-cta::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/svg%3E");
}
.kb-cta__eyebrow{
  display:inline-block;background:rgba(255,255,255,.18);color:#fff;
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.1em;
  padding:2px var(--sp-4);border-radius:var(--r-full);margin-bottom:var(--sp-4);
}
.kb-cta__title{
  font-family:var(--serif);font-size:var(--sz-2xl);font-weight:900;
  color:#fff;line-height:1.45;margin-bottom:var(--sp-4);
}
.kb-cta__desc{
  color:rgba(255,255,255,.82);font-size:var(--sz-base);line-height:1.8;
  max-width:500px;margin:0 auto var(--sp-8);
}
.kb-cta__btns{display:flex;gap:var(--sp-4);justify-content:center;flex-wrap:wrap}
.btn-cta-primary{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-4) var(--sp-10);background:#fff;color:var(--accent) !important;
  font-size:var(--sz-base);font-weight:900;border-radius:var(--r-full);
  box-shadow:0 4px 22px rgba(0,0,0,.22);
  transition:transform var(--dur-b),box-shadow var(--dur-b);
}
.btn-cta-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.28)}
.btn-cta-secondary{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-4) var(--sp-8);background:transparent;color:#fff !important;
  font-size:var(--sz-base);font-weight:700;border-radius:var(--r-full);
  border:2px solid rgba(255,255,255,.55);
  transition:border-color var(--dur-f),background var(--dur-f);
}
.btn-cta-secondary:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.kb-cta__note{margin-top:var(--sp-5);font-size:var(--sz-xs);color:rgba(255,255,255,.55)}

/* まとめ */
.kb-summary{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:var(--sp-8);margin:var(--sp-10) 0;
}
.kb-summary__title{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:900;
  display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-5);
}
.kb-summary__title::before{content:'📝';font-size:1.3rem}
.kb-summary__list{display:flex;flex-direction:column;gap:var(--sp-3)}
.kb-summary__item{
  display:flex;align-items:flex-start;gap:var(--sp-3);
  padding:var(--sp-3) var(--sp-4);background:var(--base);
  border-radius:var(--r-md);border-left:3px solid var(--accent);
  font-size:var(--sz-base);line-height:1.75;
}
.kb-summary__item::before{content:'✓';color:var(--accent);font-weight:700;flex-shrink:0}

/* ============================================================
   AUTHOR BOX
   ============================================================ */
.author-box{
  display:flex;gap:var(--sp-6);align-items:flex-start;
  padding:var(--sp-6) var(--sp-7);
  background:var(--surface);border-radius:var(--r-xl);
  margin:var(--sp-12) 0;border:1px solid var(--border);
}
.author-box__avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box__name{font-weight:900;font-size:var(--sz-lg);margin-bottom:2px}
.author-box__role{font-size:var(--sz-xs);color:var(--accent);font-weight:700;margin-bottom:var(--sp-3)}
.author-box__bio{font-size:var(--sz-sm);color:var(--tx-2);line-height:1.8}
@media(max-width:600px){.author-box{flex-direction:column}}

/* ============================================================
   RELATED POSTS
   ============================================================ */
.related-posts{margin:var(--sp-12) 0}
.related-posts__title{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:900;
  margin-bottom:var(--sp-6);display:flex;align-items:center;gap:var(--sp-3);
}
.related-posts__title::before{
  content:'';width:4px;height:1.2em;background:var(--accent);border-radius:2px;
}
.related-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-4);
}
.related-card{
  background:var(--base);border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;display:block;color:var(--tx-1);
  transition:transform var(--dur-b),box-shadow var(--dur-b);
}
.related-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.related-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.related-card__body{padding:var(--sp-4)}
.related-card__cat{font-size:var(--sz-xs);color:var(--accent);font-weight:700;margin-bottom:var(--sp-1)}
.related-card__title{
  font-size:var(--sz-sm);font-weight:700;line-height:1.6;color:var(--tx-1);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}

/* ============================================================
   ARTICLE TAGS
   ============================================================ */
.article-tags{
  display:flex;flex-wrap:wrap;gap:var(--sp-2);
  margin:var(--sp-8) 0;padding-top:var(--sp-6);border-top:1px solid var(--border);
}
.article-tag{
  padding:3px var(--sp-3);background:var(--surface-2);
  border:1px solid var(--border);color:var(--tx-2);
  font-size:var(--sz-xs);border-radius:var(--r-full);
  transition:all var(--dur-f);
}
.article-tag:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}

/* ============================================================
   ARCHIVE HERO
   ============================================================ */
.archive-hero{
  background:linear-gradient(135deg,#142B26 0%,#2F5F50 100%);
  padding:var(--sp-12) 0 var(--sp-10);position:relative;overflow:hidden;
}
.archive-hero::after{
  content:'';position:absolute;right:-80px;top:-80px;
  width:350px;height:350px;border-radius:50%;
  background:rgba(74,124,107,.15);pointer-events:none;
}
.archive-hero .breadcrumb a,.archive-hero .breadcrumb{color:rgba(255,255,255,.45)}
.archive-hero .breadcrumb__current{color:rgba(255,255,255,.75)}
.archive-hero__badge{
  display:inline-block;background:rgba(74,124,107,.3);color:var(--accent);
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.2em;
  padding:2px var(--sp-4);border-radius:var(--r-full);margin-bottom:var(--sp-3);
  margin-top:var(--sp-4);
}
.archive-hero__title{
  font-family:var(--serif);font-size:var(--sz-3xl);font-weight:900;
  color:#fff;margin-bottom:var(--sp-3);line-height:1.3;
}
.archive-hero__desc{font-size:var(--sz-base);color:rgba(255,255,255,.65);line-height:1.8;max-width:560px}

/* ============================================================
   SEARCH / 404 / PAGE
   ============================================================ */
.empty-state{text-align:center;padding:var(--sp-16) var(--sp-6)}
.empty-state__icon{font-size:3.5rem;margin-bottom:var(--sp-4)}
.empty-state__title{font-size:var(--sz-lg);font-weight:700;color:var(--tx-2);margin-bottom:var(--sp-6)}

.error-404-hero{text-align:center;padding:var(--sp-20) var(--sp-6)}
.error-404-hero__num{
  font-family:var(--serif);font-size:clamp(5rem,18vw,9rem);
  font-weight:900;color:var(--accent);line-height:1;letter-spacing:-.05em;margin-bottom:var(--sp-4);
}
.error-404-hero__title{font-family:var(--serif);font-size:var(--sz-2xl);font-weight:900;margin-bottom:var(--sp-4)}
.error-404-hero__desc{color:var(--tx-2);line-height:1.8;margin-bottom:var(--sp-8)}
.btn-go-home{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-8);background:var(--accent);color:#fff;
  border-radius:var(--r-full);font-weight:700;font-size:var(--sz-sm);
  transition:background var(--dur-f);margin-top:var(--sp-4);
}
.btn-go-home:hover{background:var(--accent-dark);color:#fff}

.page-layout{
  display:grid;grid-template-columns:1fr var(--w-sidebar);
  gap:var(--sp-10);max-width:var(--w-wide);margin:0 auto;
  padding:var(--sp-10) var(--sp-6);align-items:start;
}
@media(max-width:1100px){.page-layout{grid-template-columns:1fr}}
.page-header{padding-bottom:var(--sp-6);border-bottom:2px solid var(--border);margin-bottom:var(--sp-8);position:relative}
.page-header::after{content:'';position:absolute;bottom:-2px;left:0;width:46px;height:2px;background:var(--accent)}
.page-title{font-family:var(--serif);font-size:var(--sz-3xl);font-weight:900;line-height:1.3}

/* ============================================================
   FLOATING MOBILE CTA
   ============================================================ */
.floating-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;
  padding:var(--sp-3) var(--sp-4);
  background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
  border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.08);
}
@media(max-width:767px){.floating-bar{display:flex;gap:var(--sp-3)}}
.floating-bar__btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-2);border-radius:var(--r-md);
  font-size:var(--sz-sm);font-weight:700;text-align:center;
}
.floating-bar__btn--main{background:var(--accent);color:#fff !important}
.floating-bar__btn--sub{
  background:var(--surface-2);color:var(--tx-2) !important;border:1px solid var(--border);
}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer{
  background:var(--tx-1);color:rgba(255,255,255,.65);
  padding:var(--sp-16) 0 var(--sp-8);margin-top:var(--sp-20);
}
.footer-inner{
  max-width:var(--w-wide);margin:0 auto;padding:0 var(--sp-6);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--sp-10);margin-bottom:var(--sp-12);
}
.footer-brand__name{
  font-family:var(--serif);font-size:var(--sz-xl);font-weight:900;
  color:#fff;margin-bottom:var(--sp-3);
}
.footer-brand__desc{font-size:var(--sz-xs);line-height:1.8;opacity:.65}
.footer-col__title{font-size:var(--sz-xs);font-weight:700;color:#fff;letter-spacing:.08em;margin-bottom:var(--sp-4)}
.footer-col a{
  display:block;font-size:var(--sz-sm);color:rgba(255,255,255,.55);
  padding:var(--sp-1) 0;transition:color var(--dur-f);
}
.footer-col a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding-top:var(--sp-6);
  display:flex;justify-content:space-between;align-items:center;
  font-size:var(--sz-xs);opacity:.45;flex-wrap:wrap;gap:var(--sp-3);
}
@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================================
   SEARCH FORM (共通)
   ============================================================ */
.search-form-wrap{display:flex;gap:var(--sp-2)}
.search-form-wrap input[type=search]{
  flex:1;padding:var(--sp-2) var(--sp-3);border:1px solid var(--border);
  border-radius:var(--r-md);font-family:var(--sans);font-size:var(--sz-sm);
  color:var(--tx-1);transition:border-color var(--dur-f);
}
.search-form-wrap input[type=search]:focus{outline:none;border-color:var(--accent)}
.search-form-wrap button{
  padding:var(--sp-2) var(--sp-4);background:var(--accent);color:#fff;
  border-radius:var(--r-md);font-size:var(--sz-sm);font-weight:700;
  transition:background var(--dur-f);
}
.search-form-wrap button:hover{background:var(--accent-dark)}

/* ============================================================
   PRINT
   ============================================================ */
@media print{
  .site-header,.sidebar,.floating-bar,.scroll-progress,
  .kb-affiliate,.kb-cta,.related-posts,#page-loading{display:none}
  .article-wrap{grid-template-columns:1fr}
  .article-body h2,.article-body h3{break-after:avoid}
}
