/*
Theme Name: Cocoon Child
Theme URI: https://wp-cocoon.com/
Template: cocoon-master
Author: わいひら
Author URI: https://nelog.jp/
Description: SEO・高速化・モバイルファースト最適化済みの無料テーマ。
Tags: two-columns,left-sidebar,right-sidebar
Version: 2.9.3.1.1781056258
Updated: 2026-06-10 10:50:58
*/

/* ============================
   CSS変数（共通）
============================ */
:root {
  --t-navy:   #1E293B;
  --t-blue:   #3B82F6;
  --t-bl:     #EFF6FF;
  --t-bm:     #DBEAFE;
  --t-cyan:   #06B6D4;
  --t-cl:     #ECFEFF;
  --t-bg:     #FFFFFF;
  --t-bg2:    #F8FAFC;
  --t-bg3:    #F1F5F9;
  --t-text:   #0F172A;
  --t-muted:  #64748B;
  --t-border: #E2E8F0;
  --t-fen:    'Outfit', sans-serif;
  --t-fja:    'Noto Sans JP', sans-serif;
  --t-rsm:    8px;
  --t-rmd:    14px;
  --t-rlg:    20px;
  --t-rxl:    28px;
  --t-ease:   0.22s cubic-bezier(0.4,0,0.2,1);
  --t-sh1:    0 1px 4px rgba(0,0,0,0.06);
  --t-sh2:    0 4px 20px rgba(0,0,0,0.07);
  --t-sh3:    0 8px 40px rgba(0,0,0,0.09);
  --t-max:    1080px;
  --t-gap:    5rem;
}

/* ============================
   ベース
============================ */
body { font-family: var(--t-fja) !important; background: var(--t-bg) !important; color: var(--t-text) !important; }

/* ============================
   共通ユーティリティ
============================ */
.t-wrap { max-width: var(--t-max); margin: 0 auto; padding: 0 1.5rem; }
.t-sec { padding: var(--t-gap) 0; }
.t-bg2 { background: var(--t-bg2); }
.t-center { text-align: center; }
.t-eyebrow { display: inline-flex; align-items: center; gap: 6px; font-family: var(--t-fen); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--t-blue); margin-bottom: 0.75rem; }
.t-eyebrow::before { content: ''; width: 18px; height: 2px; background: var(--t-blue); border-radius: 2px; display: block; }
.t-center .t-eyebrow::before { display: none; }
.t-sec-title { font-size: clamp(1.5rem, 2.8vw, 2rem) !important; font-weight: 700 !important; color: var(--t-navy) !important; line-height: 1.35 !important; margin-bottom: 0.85rem !important; }
.t-sec-desc { color: var(--t-muted); font-size: 0.92rem; line-height: 1.9; }
.t-sec-hd { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2rem; flex-wrap: wrap; gap: 1rem; }
.t-more { font-size: 0.83rem; font-weight: 600; color: var(--t-blue); display: flex; align-items: center; gap: 4px; }
.t-more svg { width: 14px; height: 14px; }

/* ============================
   ボタン
============================ */
.t-btn-p { display: inline-flex; align-items: center; gap: 6px; background: var(--t-navy); color: #fff !important; font-weight: 600; font-size: 0.88rem; padding: 0.75rem 1.4rem; border-radius: var(--t-rsm); text-decoration: none !important; transition: background var(--t-ease), transform var(--t-ease); }
.t-btn-p:hover { background: #334155; transform: translateY(-1px); }
.t-btn-s { display: inline-flex; align-items: center; gap: 6px; border: 1.5px solid var(--t-border); color: var(--t-navy) !important; font-weight: 500; font-size: 0.88rem; padding: 0.75rem 1.3rem; border-radius: var(--t-rsm); text-decoration: none !important; transition: border-color var(--t-ease), background var(--t-ease); }
.t-btn-s:hover { border-color: #94a3b8; background: var(--t-bg3); }
.t-btn-navy { display: inline-flex; align-items: center; gap: 6px; background: var(--t-navy); color: #fff !important; font-weight: 600; font-size: 0.86rem; padding: 0.75rem 1.35rem; border-radius: var(--t-rsm); white-space: nowrap; text-decoration: none !important; transition: background var(--t-ease); }
.t-btn-navy:hover { background: #334155; }
.t-btn-outline { display: inline-flex; align-items: center; gap: 6px; border: 1.5px solid #bfdbfe; color: #2563eb !important; font-weight: 500; font-size: 0.86rem; padding: 0.75rem 1.35rem; border-radius: var(--t-rsm); white-space: nowrap; text-decoration: none !important; transition: background var(--t-ease); }
.t-btn-outline:hover { background: rgba(59,130,246,0.07); }
.t-btn-ghost { display: inline-flex; align-items: center; gap: 6px; border: 1.5px solid var(--t-border); color: var(--t-navy) !important; font-weight: 500; font-size: 0.86rem; padding: 0.7rem 1.4rem; border-radius: var(--t-rsm); text-decoration: none !important; transition: border-color var(--t-ease), background var(--t-ease); }
.t-btn-ghost:hover { border-color: #94a3b8; background: var(--t-bg3); }

/* ============================
   ヘッダー（全ページ共通）
============================ */
.t-hdr { position: fixed; top: 0; left: 0; right: 0; width: 100%; z-index: 9999; background: rgba(255,255,255,0.94); backdrop-filter: blur(16px); border-bottom: 1px solid var(--t-border); transition: background var(--t-ease), border-color var(--t-ease); }
.t-hdr-in { display: flex; align-items: center; justify-content: space-between; height: 64px; max-width: var(--t-max); margin: 0 auto; padding: 0 1.5rem; width: 100%; }
.t-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.t-logo-mark { width: 34px; height: 34px; border-radius: var(--t-rsm); background: var(--t-navy); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.t-logo-mark svg { width: 18px; height: 18px; }
.t-logo-name { font-size: 0.95rem; font-weight: 700; color: var(--t-navy); }
.t-logo-sub { font-family: var(--t-fen); font-size: 0.58rem; color: var(--t-muted); letter-spacing: 0.06em; display: block; }
.t-nav { display: flex; align-items: center; gap: 2px; }
.t-nav a { font-size: 0.84rem; font-weight: 500; color: var(--t-muted); padding: 0.4rem 0.7rem; border-radius: var(--t-rsm); transition: color var(--t-ease), background var(--t-ease); text-decoration: none; }
.t-nav a:hover { color: var(--t-navy); background: var(--t-bg3); }
.t-nav-btn { background: var(--t-navy) !important; color: #fff !important; margin-left: 8px; font-size: 0.82rem !important; }
.t-nav-btn:hover { background: #334155 !important; }
.t-nav-active { color: var(--t-blue) !important; }
.t-hbg { display: none; flex-direction: column; gap: 5px; padding: 8px; border-radius: var(--t-rsm); border: none; background: none; cursor: pointer; }
.t-hbg span { display: block; width: 20px; height: 2px; background: var(--t-navy); border-radius: 2px; }

/* モバイルナビ */
.t-mnav { position: fixed; inset: 0; background: rgba(15,23,42,0.97); z-index: 999; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.5rem; opacity: 0; pointer-events: none; transition: opacity var(--t-ease); }
.t-mnav.open { opacity: 1; pointer-events: auto; }
.t-mnav a { font-size: 1.15rem; font-weight: 700; color: #cbd5e1; text-decoration: none; }
.t-mnav-close { position: absolute; top: 1.25rem; right: 1.25rem; width: 42px; height: 42px; border-radius: var(--t-rsm); border: 1px solid rgba(255,255,255,0.1); color: #cbd5e1; display: flex; align-items: center; justify-content: center; cursor: pointer; background: none; font-size: 1.1rem; }

/* Back to top */
.t-btt { position: fixed; bottom: 1.5rem; right: 1.5rem; width: 42px; height: 42px; background: var(--t-navy); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: var(--t-sh2); opacity: 0; transform: translateY(8px); transition: opacity var(--t-ease), transform var(--t-ease); cursor: pointer; z-index: 50; border: none; }
.t-btt.vis { opacity: 1; transform: none; }

/* フッター */
.t-footer { background: var(--t-navy); color: #94a3b8; padding: 3.5rem 0 2rem; }
.t-ft-in { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3rem; padding-bottom: 2.5rem; border-bottom: 1px solid rgba(255,255,255,0.07); margin-bottom: 1.75rem; }
.t-ft-brand { font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: 0.65rem; }
.t-ft-desc { font-size: 0.8rem; line-height: 1.8; max-width: 240px; margin-bottom: 1.1rem; }
.t-ft-sns { display: flex; gap: 8px; }
.t-ft-sns a { width: 34px; height: 34px; border-radius: var(--t-rsm); border: 1px solid rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; text-decoration: none; color: #94a3b8; transition: border-color var(--t-ease), background var(--t-ease); }
.t-ft-sns a:hover { border-color: rgba(255,255,255,0.3); background: rgba(255,255,255,0.05); color: #fff; }
.t-ft-col-ttl { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; margin-bottom: 1rem; }
.t-ft-col ul { display: flex; flex-direction: column; gap: 0.55rem; list-style: none; padding: 0; margin: 0; }
.t-ft-col ul a { font-size: 0.8rem; color: #94a3b8; text-decoration: none; transition: color var(--t-ease); }
.t-ft-col ul a:hover { color: #cbd5e1; }
.t-ft-btm { max-width: var(--t-max); margin: 0 auto; padding: 0 1.5rem; font-size: 0.73rem; color: #475569; }

/* ============================
   トップページ専用
============================ */
.t-front { margin: 0 !important; padding: 0 !important; }
.t-front * { box-sizing: border-box; }

/* Cocoon要素を非表示 */
.t-front .header, .t-front .footer, .t-front .sidebar,
.t-front #header, .t-front #footer, .t-front .navi,
.t-front .bc-list, .t-front .breadcrumb,
.t-front .footer-widget, .t-front .footer-widgets,
.t-front #footer-widget-area, .t-front .cocoon-block-widget-area,
.t-front #navi-footer-in, .t-front .footer-nav,
.t-front .site-footer { display: none !important; }

/* Hero */
.t-hero { padding: 8rem 0 5rem; background: var(--t-bg); position: relative; overflow: hidden; }
.t-hero-deco { position: absolute; inset: 0; pointer-events: none; }
.t-hero-deco::before { content: ''; position: absolute; top: -120px; right: -120px; width: 560px; height: 560px; border-radius: 50%; background: radial-gradient(circle, rgba(59,130,246,0.07) 0%, transparent 70%); }
.t-hero-in { display: grid; grid-template-columns: 1fr 400px; gap: 4rem; align-items: center; }
.t-badge { display: inline-flex; align-items: center; gap: 7px; background: var(--t-bl); border: 1px solid var(--t-bm); border-radius: 100px; padding: 0.3rem 0.9rem; font-size: 0.75rem; font-weight: 600; color: #2563eb; margin-bottom: 1.5rem; }
.t-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--t-blue); animation: t-pulse 2s infinite; }
@keyframes t-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }
.t-front h1 { font-size: clamp(1.9rem,4vw,3rem) !important; font-weight: 700 !important; line-height: 1.28 !important; color: var(--t-navy) !important; margin-bottom: 1.1rem !important; letter-spacing: -0.02em !important; }
.t-gr { background: linear-gradient(90deg, var(--t-blue), var(--t-cyan)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.t-hero-sub { font-size: 0.95rem; color: var(--t-muted); margin-bottom: 2rem; }
.t-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 2rem; }
.t-tag { font-size: 0.76rem; padding: 0.25rem 0.7rem; border-radius: 100px; border: 1px solid var(--t-border); color: var(--t-muted); background: var(--t-bg2); }
.t-cta { display: flex; gap: 10px; flex-wrap: wrap; }
.t-stats { display: flex; gap: 2rem; margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid var(--t-border); }
.t-stat-num { font-family: var(--t-fen); font-size: 1.6rem; font-weight: 700; color: var(--t-navy); display: block; line-height: 1; }
.t-stat-num small { font-size: 0.85rem; font-weight: 400; color: var(--t-muted); }
.t-stat-lbl { font-size: 0.75rem; color: var(--t-muted); margin-top: 4px; }

/* プロフィールカード */
.t-card { background: var(--t-bg2); border: 1px solid var(--t-border); border-radius: var(--t-rxl); padding: 2rem; position: relative; display: block; text-decoration: none; transition: transform var(--t-ease), box-shadow var(--t-ease), border-color var(--t-ease); }
.t-card:hover { transform: translateY(-4px); box-shadow: var(--t-sh3); border-color: var(--t-bm); }
.t-card-bdg { position: absolute; top: -12px; right: 20px; background: var(--t-blue); color: #fff; font-size: 0.72rem; font-weight: 700; padding: 0.25rem 0.75rem; border-radius: 100px; }
.t-card-top { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.t-ava { width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, var(--t-bm), var(--t-cl)); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; flex-shrink: 0; }
.t-card-name { font-size: 1rem; font-weight: 700; color: var(--t-navy); }
.t-card-role { font-size: 0.78rem; color: var(--t-muted); margin-top: 2px; }
.t-card-desc { font-size: 0.84rem; color: var(--t-muted); line-height: 1.8; margin-bottom: 1.5rem; }
.t-card-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.t-cs { background: var(--t-bg); border: 1px solid var(--t-border); border-radius: var(--t-rmd); padding: 0.9rem; text-align: center; }
.t-cs-num { font-family: var(--t-fen); font-size: 1.1rem; font-weight: 700; color: var(--t-navy); display: block; line-height: 1; }
.t-cs-lbl { font-size: 0.7rem; color: var(--t-muted); margin-top: 3px; }
.t-card-ft { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 1.25rem; padding-top: 1.1rem; border-top: 1px solid var(--t-border); font-size: 0.8rem; font-weight: 600; color: var(--t-muted); transition: color var(--t-ease); }
.t-card:hover .t-card-ft { color: var(--t-blue); }
.t-card-ft svg { width: 14px; height: 14px; transition: transform var(--t-ease); }
.t-card:hover .t-card-ft svg { transform: translateX(3px); }

/* カテゴリー（トップ） */
.t-cat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px,1fr)); gap: 1rem; }
.t-cat-card { background: var(--t-bg); border: 1px solid var(--t-border); border-radius: var(--t-rlg); padding: 1.4rem; display: block; text-decoration: none; transition: transform var(--t-ease), box-shadow var(--t-ease), border-color var(--t-ease); }
.t-cat-card:hover { transform: translateY(-3px); box-shadow: var(--t-sh2); border-color: transparent; }
.t-cat-icon { width: 44px; height: 44px; border-radius: var(--t-rsm); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; margin-bottom: 0.9rem; transition: transform var(--t-ease); }
.t-cat-card:hover .t-cat-icon { transform: scale(1.12) rotate(-4deg); }
.t-cat-name { font-size: 0.9rem; font-weight: 700; color: var(--t-navy); margin-bottom: 3px; }
.t-cat-sub { font-size: 0.72rem; color: var(--t-muted); }
.t-cat-desc { font-size: 0.78rem; color: var(--t-muted); margin-top: 0.5rem; line-height: 1.65; }

/* 人気記事（トップ） */
.t-posts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px,1fr)); gap: 1.1rem; }
.t-post-card { background: var(--t-bg); border: 1px solid var(--t-border); border-radius: var(--t-rlg); overflow: hidden; display: block; text-decoration: none; transition: transform var(--t-ease), box-shadow var(--t-ease); }
.t-post-card:hover { transform: translateY(-4px); box-shadow: var(--t-sh3); }
.t-post-thumb { aspect-ratio: 16/9; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.t-post-img { width: 100%; height: 100%; object-fit: cover; }
.t-post-body { padding: 1.1rem; }
.t-post-badge { font-size: 0.68rem; font-weight: 700; border-radius: 100px; padding: 2px 10px; display: inline-block; margin-bottom: 0.55rem; background: var(--t-bl); color: #1d4ed8; }
.t-post-title { font-size: 0.9rem; font-weight: 700; color: var(--t-navy); line-height: 1.55; margin-bottom: 0.5rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.t-post-meta { font-size: 0.7rem; color: var(--t-muted); }

/* 運営報告（トップ） */
.t-report-in { max-width: 720px; margin: 0 auto; }
.t-report-hd { text-align: center; margin-bottom: 2.5rem; }
.t-report-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.t-rc { background: var(--t-bg); border: 1px solid var(--t-border); border-radius: var(--t-rlg); padding: 1.4rem; text-align: center; }
.t-rc-icon { font-size: 1.5rem; margin-bottom: 0.6rem; }
.t-rc-num { font-family: var(--t-fen); font-size: 1.7rem; font-weight: 700; color: var(--t-navy); display: block; line-height: 1; }
.t-rc-unit { font-size: 0.85rem; font-weight: 400; color: var(--t-blue); }
.t-rc-lbl { font-size: 0.75rem; color: var(--t-muted); margin-top: 5px; }
.t-report-note { text-align: center; font-size: 0.75rem; color: var(--t-muted); margin-bottom: 1.5rem; }

/* プロフィールCTA（トップ） */
.t-pcta { background: linear-gradient(135deg, var(--t-bl), var(--t-cl)); border: 1px solid var(--t-bm); border-radius: var(--t-rxl); padding: 3rem 3.5rem; display: grid; grid-template-columns: 1fr auto; gap: 3rem; align-items: center; }
.t-pcta-title { font-size: 1.45rem !important; font-weight: 700 !important; color: var(--t-navy) !important; line-height: 1.45 !important; margin-bottom: 0.7rem !important; }
.t-pcta-btns { display: flex; flex-direction: column; gap: 0.65rem; }

/* レスポンシブ（トップ） */
@media (max-width: 860px) {
  .t-hero-in { grid-template-columns: 1fr; gap: 2.5rem; }
  .t-hero-text { order: 1; }
  .t-card-area { order: 2; }
  .t-pcta { grid-template-columns: 1fr; padding: 2rem; }
  .t-pcta-btns { flex-direction: row; flex-wrap: wrap; }
  .t-ft-in { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .t-nav { display: none; }
  .t-hbg { display: flex; }
  .t-hero { padding: 8rem 0 3rem; }
  .t-stats { flex-direction: column; gap: 1.1rem; }
  .t-ft-in { grid-template-columns: 1fr; }
}

/* ============================
   プロフィールページ専用
============================ */
.t-profile-page { margin: 0 !important; padding: 0 !important; }
.t-profile-page .header, .t-profile-page .footer, .t-profile-page .sidebar,
.t-profile-page #header, .t-profile-page #footer, .t-profile-page .navi,
.t-profile-page .bc-list { display: none !important; }

.p-wrap { max-width: 820px; margin: 0 auto; padding: 0 1.5rem; }
.p-breadcrumb { padding: 5.5rem 0 0; background: var(--t-bg2); }
.p-breadcrumb nav { padding: 1rem 0; font-size: 0.78rem; color: var(--t-muted); }
.p-breadcrumb a { color: var(--t-muted); text-decoration: none; transition: color var(--t-ease); }
.p-breadcrumb a:hover { color: var(--t-blue); }
.p-hero { background: var(--t-bg2); padding: 2rem 0 3.5rem; border-bottom: 1px solid var(--t-border); }
.p-hero-in { display: flex; align-items: center; gap: 2.5rem; flex-wrap: wrap; }
.p-avatar { width: 100px; height: 100px; border-radius: 50%; background: linear-gradient(135deg, var(--t-bm), var(--t-cl)); display: flex; align-items: center; justify-content: center; font-size: 2.8rem; border: 4px solid var(--t-bg); box-shadow: var(--t-sh2); flex-shrink: 0; }
.p-name { font-size: 1.6rem; font-weight: 700; color: var(--t-navy); margin-bottom: 4px; }
.p-handle { font-family: var(--t-fen); font-size: 0.82rem; color: var(--t-muted); margin-bottom: 0.75rem; }
.p-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 1rem; }
.p-tag { font-size: 0.75rem; padding: 0.25rem 0.7rem; border-radius: 100px; background: var(--t-bl); color: #2563eb; font-weight: 500; border: 1px solid var(--t-bm); }
.p-sns { display: flex; gap: 8px; flex-wrap: wrap; }
.p-sns-link { display: inline-flex; align-items: center; gap: 5px; font-size: 0.78rem; font-weight: 600; color: var(--t-muted); border: 1px solid var(--t-border); border-radius: var(--t-rsm); padding: 0.3rem 0.75rem; text-decoration: none; transition: color var(--t-ease), border-color var(--t-ease), background var(--t-ease); }
.p-sns-link:hover { color: var(--t-navy); border-color: #94a3b8; background: var(--t-bg3); }
#p-main { padding: 4rem 0; }
.p-sec { margin-bottom: 4rem; }
.p-eyebrow { display: inline-flex; align-items: center; gap: 6px; font-family: var(--t-fen); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--t-blue); margin-bottom: 0.75rem; }
.p-eyebrow::before { content: ''; width: 18px; height: 2px; background: var(--t-blue); border-radius: 2px; display: block; }
.p-sec-title { font-size: clamp(1.4rem, 2.5vw, 1.8rem) !important; font-weight: 700 !important; color: var(--t-navy) !important; line-height: 1.35 !important; margin-bottom: 0.85rem !important; }
.p-sec-desc { color: var(--t-muted); font-size: 0.92rem; line-height: 1.9; margin-bottom: 1.5rem; }
.p-text { font-size: 0.95rem; line-height: 2; color: var(--t-text); }
.p-text p + p { margin-top: 1.1rem; }
.p-spec-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1rem; margin-top: 1.5rem; }
.p-spec-card { background: var(--t-bg2); border: 1px solid var(--t-border); border-radius: var(--t-rlg); padding: 1.25rem; }
.p-spec-icon { font-size: 1.4rem; margin-bottom: 0.6rem; }
.p-spec-label { font-size: 0.7rem; font-weight: 600; color: var(--t-muted); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 4px; font-family: var(--t-fen); }
.p-spec-value { font-size: 0.95rem; font-weight: 700; color: var(--t-navy); }
.p-spec-sub { font-size: 0.78rem; color: var(--t-muted); margin-top: 3px; line-height: 1.5; }
.p-ach-list { display: flex; flex-direction: column; gap: 1rem; margin-top: 1.5rem; }
.p-ach-item { background: var(--t-bg2); border: 1px solid var(--t-border); border-radius: var(--t-rmd); padding: 1.1rem 1.25rem; display: flex; align-items: center; gap: 1rem; }
.p-ach-icon { width: 44px; height: 44px; border-radius: var(--t-rsm); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; flex-shrink: 0; }
.p-ach-body { flex: 1; }
.p-ach-title { font-size: 0.9rem; font-weight: 700; color: var(--t-navy); margin-bottom: 2px; }
.p-ach-desc { font-size: 0.8rem; color: var(--t-muted); line-height: 1.6; }
.p-ach-badge { font-family: var(--t-fen); font-size: 0.72rem; font-weight: 700; color: var(--t-blue); background: var(--t-bl); border: 1px solid var(--t-bm); border-radius: 100px; padding: 2px 10px; white-space: nowrap; flex-shrink: 0; }
.p-timeline { position: relative; margin-top: 1.5rem; }
.p-timeline::before { content: ''; position: absolute; left: 27px; top: 0; bottom: 0; width: 2px; background: linear-gradient(to bottom, var(--t-blue), var(--t-cyan)); border-radius: 2px; }
.p-tl-item { display: flex; gap: 1.25rem; margin-bottom: 2rem; opacity: 0; transform: translateX(-12px); transition: opacity 0.4s ease, transform 0.4s ease; }
.p-tl-item.p-vis { opacity: 1; transform: none; }
.p-tl-dot { width: 56px; height: 56px; border-radius: 50%; background: var(--t-bg); border: 2px solid var(--t-border); display: flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; z-index: 1; font-size: 1.3rem; transition: border-color var(--t-ease), box-shadow var(--t-ease); }
.p-tl-item.p-vis .p-tl-dot { border-color: var(--t-blue); box-shadow: 0 0 0 5px var(--t-bl); }
.p-tl-body { padding: 0.4rem 0; flex: 1; }
.p-tl-period { font-family: var(--t-fen); font-size: 0.7rem; font-weight: 600; color: var(--t-blue); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 3px; }
.p-tl-title { font-size: 0.95rem !important; font-weight: 700 !important; color: var(--t-navy) !important; margin-bottom: 4px !important; }
.p-tl-desc { font-size: 0.84rem; color: var(--t-muted); line-height: 1.75; }
.p-tl-badge { display: inline-flex; align-items: center; gap: 4px; margin-top: 6px; background: var(--t-bl); color: #1d4ed8; border-radius: 100px; padding: 2px 10px; font-size: 0.7rem; font-weight: 600; }
.p-tools-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: 0.75rem; margin-top: 1.5rem; }
.p-tool-item { background: var(--t-bg2); border: 1px solid var(--t-border); border-radius: var(--t-rmd); padding: 0.9rem 1rem; display: flex; align-items: center; gap: 0.75rem; }
.p-tool-emoji { font-size: 1.2rem; flex-shrink: 0; }
.p-tool-name { font-size: 0.84rem; font-weight: 700; color: var(--t-navy); }
.p-tool-use { font-size: 0.72rem; color: var(--t-muted); }
.p-message { background: linear-gradient(135deg, var(--t-bl), var(--t-cl)); border: 1px solid var(--t-bm); border-radius: var(--t-rxl); padding: 2.5rem; margin-top: 1.5rem; }
.p-message p { font-size: 0.95rem; line-height: 2; color: var(--t-navy); }
.p-message p + p { margin-top: 1rem; }
.p-message-sign { margin-top: 1.5rem; font-size: 0.85rem; font-weight: 700; color: var(--t-navy); text-align: right; }
.p-cta { background: var(--t-bg2); border: 1px solid var(--t-border); border-radius: var(--t-rxl); padding: 2.5rem; text-align: center; margin-top: var(--t-gap); }
.p-cta-title { font-size: 1.2rem; font-weight: 700; color: var(--t-navy); margin-bottom: 0.6rem; }
.p-cta-desc { font-size: 0.88rem; color: var(--t-muted); margin-bottom: 1.75rem; }
.p-cta-btns { display: flex; justify-content: center; gap: 0.75rem; flex-wrap: wrap; }
@media (max-width: 600px) {
  .p-hero-in { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
  .p-avatar { width: 80px; height: 80px; font-size: 2.2rem; }
  .p-ach-item { flex-direction: column; align-items: flex-start; }
  .p-ach-badge { align-self: flex-start; }
}

/* ============================
   記事・アーカイブ共通
============================ */
/* Cocoonデフォルトヘッダー・フッターを非表示 */
#header, .header, .site-header, #navi, .navi, .footer, #footer, .site-footer { display: none !important; }

/* ヘッダー分の余白 */
body.single, body.archive, body.page { padding-top: 64px !important; }

.wrap, #wrap, .site-content, .content-area, .entry-content-wrap, .entry, .article {
  max-width: var(--t-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* アイキャッチ画像 */
.eye-catch, .eye-catch img, .post-thumbnail, .post-thumbnail img {
  max-width: min(var(--t-max), 100%) !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: block !important;
}

/* ============================
   記事ページ 本文デザイン
============================ */
.entry-content, .article-body { font-family: var(--t-fja) !important; font-size: 1rem !important; line-height: 1.9 !important; color: var(--t-text) !important; }
.entry-content h2 { font-size: 1.25rem !important; font-weight: 700 !important; color: var(--t-navy) !important; border-left: 4px solid var(--t-blue) !important; border-bottom: none !important; background: var(--t-bg2) !important; padding: 0.75rem 1rem !important; border-radius: 0 var(--t-rsm) var(--t-rsm) 0 !important; margin-bottom: 1.5rem !important; }
.entry-content h3 { font-size: 1.1rem !important; font-weight: 700 !important; color: var(--t-navy) !important; border-left: 3px solid var(--t-cyan) !important; padding-left: 0.75rem !important; margin-bottom: 1rem !important; background: none !important; }
.entry-content a { color: var(--t-blue) !important; text-decoration: underline !important; text-underline-offset: 3px !important; }
.entry-content a:hover { color: #1d4ed8 !important; }
.entry-content p { margin-bottom: 1.5rem !important; }

/* ============================
   カテゴリー・アーカイブページ
============================ */
/* 幅をヘッダーに統一（bodyに直接配置されているため要素に直接指定） */
#archive-title, #list, .pagination, .pagination-next, #breadcrumb {
  max-width: var(--t-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
  box-sizing: border-box !important;
}

/* カテゴリータイトル */
#archive-title {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--t-navy) !important;
  border-left: 4px solid var(--t-blue) !important;
  padding-left: 0.75rem !important;
  margin-bottom: 2rem !important;
  margin-top: 2rem !important;
}

/* 記事一覧グリッド */
#list.ect-entry-card {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.25rem !important;
}
@media (max-width: 860px) { #list.ect-entry-card { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 600px) { #list.ect-entry-card { grid-template-columns: 1fr !important; } }

/* カードリンク */
a.entry-card-wrap { background: var(--t-bg) !important; border: 1px solid var(--t-border) !important; border-radius: var(--t-rlg) !important; overflow: hidden !important; display: flex !important; flex-direction: column !important; text-decoration: none !important; transition: transform var(--t-ease), box-shadow var(--t-ease) !important; margin-bottom: 0 !important; }
a.entry-card-wrap:hover { transform: translateY(-4px) !important; box-shadow: var(--t-sh3) !important; }
a.entry-card-wrap article.entry-card { display: flex !important; flex-direction: column !important; height: 100% !important; }

/* サムネイル */
a.entry-card-wrap .entry-card-thumb { width: 100% !important; margin: 0 !important; flex-shrink: 0 !important; }
a.entry-card-wrap .entry-card-thumb img { width: 100% !important; height: auto !important; aspect-ratio: 16/9 !important; object-fit: cover !important; display: block !important; }
a.entry-card-wrap .entry-card-thumb .cat-label { display: none !important; }

/* カード本文 */
a.entry-card-wrap .entry-card-content { padding: 1rem !important; flex: 1 !important; margin: 0 !important; }
a.entry-card-wrap .entry-card-title { font-size: 0.92rem !important; font-weight: 700 !important; color: var(--t-navy) !important; line-height: 1.55 !important; margin-bottom: 0.5rem !important; border: none !important; background: none !important; padding: 0 !important; }
a.entry-card-wrap .entry-card-snippet { font-size: 0.8rem !important; color: var(--t-muted) !important; line-height: 1.7 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
a.entry-card-wrap .entry-card-meta { margin-top: 0.5rem !important; font-size: 0.72rem !important; color: var(--t-muted) !important; font-family: var(--t-fen) !important; }

/* 固定ページの幅統一 */
.page .entry,
.page .article,
.page .entry-content {
  max-width: var(--t-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* 固定ページタイトルの幅統一 */
.page .entry-title,
.page .article-title {
  max-width: var(--t-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}