/* ============================================================
   士業未来戦略会議 — 共有スタイル
   Design system: 和モダン × ペーパー基調 × 黒×金アクセント
   ============================================================ */
:root{
  --bg:#f6f1e8;
  --bg-soft:#fbf8f2;
  --paper:#fffdfa;
  --paper-deep:#f3ece1;
  --text:#2e2a25;
  --muted:#6b645b;
  --line:#ddd3c6;
  --gold:#b7862f;
  --gold-deep:#8a6320;
  --gold-soft:#d9bd7b;
  --red:#9f3b30;
  --ink:#191614;
  --ink-2:#23201c;
  --shadow:0 12px 28px rgba(44,32,18,.07);
  --shadow-lg:0 24px 60px rgba(36,26,12,.12);
  --max:1120px;
  --radius:14px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  line-height:1.85;
  background:
    radial-gradient(circle at right top, rgba(183,134,47,.06), transparent 22%),
    linear-gradient(180deg,var(--bg-soft),var(--bg));
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
input,select,textarea,button{font:inherit}
h1,h2,h3,.brand,.date-main,.quote,.serif{font-family:"Yu Mincho","Hiragino Mincho ProN",serif}
h1,h2,h3{color:var(--ink);text-wrap:balance;line-height:1.4}
p,li,dd,dt{word-break:normal;overflow-wrap:break-word;text-wrap:pretty}
.container{width:min(var(--max),calc(100% - 36px));margin:auto}

/* ---------- ナビ ---------- */
.nav{position:sticky;top:0;z-index:30;background:rgba(251,248,242,.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.05);transition:box-shadow .25s ease}
.nav.scrolled{box-shadow:0 6px 20px rgba(44,32,18,.07)}
.navin{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{font-size:1.18rem;font-weight:800;letter-spacing:.04em;color:var(--ink)}
.brand span{color:var(--gold)}
.links{display:flex;align-items:center;gap:22px;font-size:.93rem;color:#4f473f}
.links a{white-space:nowrap;position:relative;padding:4px 0;transition:color .18s}
.links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:width .22s ease}
.links a:not(.btn):hover{color:var(--gold-deep)}
.links a:not(.btn):hover::after,.links a.active::after{width:100%}
.links a.active{color:var(--gold-deep);font-weight:700}

/* ---------- ボタン ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:0 24px;border-radius:8px;font-weight:700;transition:transform .18s ease,box-shadow .18s ease;cursor:pointer}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#1f160b;box-shadow:0 10px 22px rgba(183,134,47,.18)}
.btn-primary:hover{box-shadow:0 16px 30px rgba(183,134,47,.28)}
.btn-outline{background:#fff;border:1px solid var(--gold);color:var(--gold-deep)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.1)}

/* ---------- ハンバーガー（モバイル） ---------- */
.burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:10px;background:#fff}
.burger span{display:block;width:22px;height:2px;background:var(--ink);transition:.25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- ヒーロー ---------- */
.hero{position:relative;overflow:hidden;min-height:620px;background:url('../header-visual.png') center right/cover no-repeat;display:flex;align-items:center}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(246,241,232,.96) 0%,rgba(246,241,232,.93) 34%,rgba(246,241,232,.82) 52%,rgba(246,241,232,.40) 72%,rgba(246,241,232,.12) 100%)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(180deg,rgba(246,241,232,0),rgba(246,241,232,.98))}
.hero-inner{position:relative;z-index:1;padding:84px 0 96px;max-width:640px}
.kicker{display:inline-block;padding:7px 13px;border-radius:999px;border:1px solid rgba(159,59,48,.16);background:rgba(255,255,255,.78);color:var(--red);font-size:.82rem;font-weight:700;letter-spacing:.06em}
.hero h1{margin:18px 0 16px;font-size:clamp(2.6rem,6vw,4.7rem);line-height:1.28;letter-spacing:.03em}
.hero h1 strong{color:var(--gold-deep);font-weight:800}
.lead{font-size:1.05rem;color:var(--muted);max-width:58ch}
.actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.summary{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.summary span{padding:8px 13px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.82);font-size:.88rem;color:#4d453d}
.strip{margin-top:24px;padding:14px 18px;border-left:5px solid var(--gold);background:rgba(255,255,255,.78);border-radius:0 10px 10px 0;color:#4a433a;font-size:.95rem}

/* 下位ページ用のコンパクトなページヘッダー */
.pagehead{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--ink),var(--ink-2));color:#f4ece0;padding:64px 0 56px}
.pagehead::after{content:"";position:absolute;right:-40px;top:-40px;width:320px;height:320px;background:radial-gradient(circle,rgba(217,189,123,.22),transparent 70%)}
.pagehead .crumb{font-size:.84rem;color:#cdbf9f;letter-spacing:.04em;position:relative;z-index:1}
.pagehead .crumb a:hover{color:#fff}
.pagehead h1{position:relative;z-index:1;margin:10px 0 8px;color:#fff;font-size:clamp(2rem,4.4vw,3rem)}
.pagehead p{position:relative;z-index:1;margin:0;color:#d9cdb8;max-width:64ch}

/* ---------- セクション ---------- */
.section{padding:84px 0}
.section.tight{padding:60px 0}
.alt{background:rgba(255,255,255,.46)}
.heading{margin-bottom:30px}
.heading.center{text-align:center}
.heading.center p{margin-left:auto;margin-right:auto}
.heading .mini{display:inline-block;color:var(--red);font-weight:700;font-size:.82rem;letter-spacing:.08em;margin-bottom:8px}
.heading h2{margin:0;font-size:clamp(1.95rem,4vw,2.9rem);line-height:1.5;max-width:20em}
.heading p{margin:14px 0 0;color:var(--muted);max-width:72ch}

/* ---------- 汎用カード／グリッド ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card,.panel,.event-box,.report,.note-box,.cta-box,.faq,.host,.audience,.flow{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card{padding:26px}
.card .num{display:inline-block;color:var(--gold);font-size:1.5rem;font-weight:800;margin-bottom:10px}
.card h3{margin:0 0 8px;font-size:1.08rem}
.card p{margin:0;color:var(--muted)}

/* コンセプト2カラム */
.concept{display:grid;grid-template-columns:1.02fr .98fr;gap:28px;align-items:start}
.panel{padding:30px}
.quote{padding:0 0 0 18px;margin:0 0 18px;border-left:4px solid var(--gold);font-size:1.16rem;line-height:1.9;color:var(--ink)}
.panel-list{display:grid;gap:12px}
.panel-item{padding:16px 18px;background:var(--paper-deep);border-radius:10px}
.panel-item strong{display:block;color:var(--ink);margin-bottom:4px}

/* 開催情報 */
.event-layout{display:grid;grid-template-columns:320px 1fr;gap:22px;align-items:start}
.event-box{padding:28px;background:linear-gradient(180deg,#fffefb,#f8f2e8)}
.date-year{color:#705f3f;font-weight:700}
.date-main{font-size:2.75rem;line-height:1.35;color:var(--ink);margin:6px 0 12px}
.date-time{font-size:1.34rem;font-weight:800;color:var(--ink);line-height:1.65}
.info-list{display:grid;gap:0}
.info-row{display:flex;justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:none}
.info-row dt{color:var(--muted)}
.info-row dd{margin:0;text-align:right;color:var(--ink);font-weight:700}

/* 残席バッジ */
.seat-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:rgba(159,59,48,.1);border:1px solid rgba(159,59,48,.25);color:var(--red);font-weight:800;font-size:.9rem}
.seat-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 rgba(159,59,48,.5);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(159,59,48,.45)}70%{box-shadow:0 0 0 9px rgba(159,59,48,0)}100%{box-shadow:0 0 0 0 rgba(159,59,48,0)}}

/* 特典 */
.benefit-card{padding:30px;background:linear-gradient(180deg,#fffefb,#f7efe3)}
.benefit-card .label{display:inline-block;padding:4px 10px;border-radius:999px;background:rgba(183,134,47,.12);color:var(--gold-deep);font-weight:700;font-size:.82rem}
.benefit-card h3{margin:14px 0 10px;font-size:1.42rem;line-height:1.65}
.benefit-card p{margin:0;color:var(--muted)}
.note-box{margin-top:18px;padding:20px 22px;border-left:5px solid var(--red);background:linear-gradient(180deg,#fffdfa,#f9f2e8)}
.note-box strong{display:block;color:var(--red);margin-bottom:4px}

/* こんな方へ */
.audience{padding:26px;position:relative;padding-left:60px}
.audience .ic{position:absolute;left:22px;top:26px;font-size:1.4rem}
.audience h3{margin:0 0 6px;font-size:1.05rem}
.audience p{margin:0;color:var(--muted);font-size:.96rem}

/* 当日の流れ（タイムライン） */
.flow{padding:30px 34px}
.timeline{display:grid;gap:0;margin:0;padding:0;list-style:none}
.timeline li{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:18px 0;border-bottom:1px dashed var(--line);position:relative}
.timeline li:last-child{border-bottom:none}
.timeline .t{font-weight:800;color:var(--gold-deep)}
.timeline .ev strong{display:block;color:var(--ink);margin-bottom:2px}
.timeline .ev span{color:var(--muted);font-size:.95rem}

/* 比較表 */
.compare{width:100%;border-collapse:collapse;overflow:hidden;background:var(--paper);box-shadow:var(--shadow);border-radius:12px}
.compare th,.compare td{padding:16px 18px;border:1px solid var(--line);text-align:left;vertical-align:top}
.compare th{background:#f5ecdc;color:var(--ink)}
.compare td:last-child{background:rgba(183,134,47,.05);font-weight:600}

/* ラボ */
.lab{display:grid;grid-template-columns:1fr .95fr;gap:26px;align-items:start;padding:34px}
.list{display:grid;gap:10px;margin-top:18px}
.list div{position:relative;padding-left:22px;color:var(--muted)}
.list div::before{content:"✓";position:absolute;left:0;top:0;color:var(--gold);font-weight:900}
.mini-cta{margin-top:20px}

/* 主催者 */
.host{display:grid;grid-template-columns:200px 1fr;gap:28px;align-items:center;padding:30px}
.host .ph{width:100%;aspect-ratio:1;border-radius:14px;background:linear-gradient(135deg,var(--ink),var(--ink-2));display:flex;align-items:center;justify-content:center;color:var(--gold-soft);font-family:"Yu Mincho",serif;font-size:2.4rem;overflow:hidden}
.host h3{margin:0 0 4px;font-size:1.3rem}
.host .role{color:var(--gold-deep);font-weight:700;font-size:.92rem;margin-bottom:10px}
.host p{margin:0 0 6px;color:var(--muted)}

/* レポート */
.reports{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.report{padding:24px;transition:transform .2s ease,box-shadow .2s ease}
.report:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.report .tag{display:inline-block;color:var(--red);font-size:.8rem;font-weight:700;margin-bottom:10px;letter-spacing:.04em}
.report h3{margin:0 0 8px;font-size:1.05rem;color:var(--ink)}
.report p{margin:0;color:var(--muted)}

/* FAQ */
.faq{padding:6px 26px;margin-bottom:14px}
.faq summary{cursor:pointer;list-style:none;padding:20px 0;font-weight:700;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q{position:relative;padding-left:30px}
.faq summary .q::before{content:"Q";position:absolute;left:0;top:-2px;color:var(--gold-deep);font-family:"Yu Mincho",serif;font-weight:800;font-size:1.15rem}
.faq summary .plus{flex:0 0 auto;width:22px;height:22px;position:relative;transition:transform .25s}
.faq summary .plus::before,.faq summary .plus::after{content:"";position:absolute;background:var(--gold-deep);border-radius:2px}
.faq summary .plus::before{left:0;top:10px;width:22px;height:2px}
.faq summary .plus::after{left:10px;top:0;width:2px;height:22px;transition:transform .25s}
.faq[open] summary .plus::after{transform:rotate(90deg);opacity:0}
.faq .a{padding:0 0 20px 30px;color:var(--muted)}

/* CTA帯（黒×金・ポスター世界観） */
.cta{position:relative;overflow:hidden;padding:90px 0;background:linear-gradient(135deg,var(--ink),var(--ink-2));color:#f4ece0}
.cta::before{content:"";position:absolute;right:-60px;top:-60px;width:360px;height:360px;background:radial-gradient(circle,rgba(217,189,123,.2),transparent 70%)}
.cta::after{content:"";position:absolute;left:-80px;bottom:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(159,59,48,.16),transparent 70%)}
.cta .container{position:relative;z-index:1}
.cta .kicker{background:rgba(255,255,255,.08);border-color:rgba(217,189,123,.3);color:var(--gold-soft)}
.cta h2{margin:14px 0 12px;color:#fff;font-size:clamp(1.95rem,4vw,2.9rem);line-height:1.5;max-width:18em}
.cta p{margin:0 0 8px;color:#d9cdb8;max-width:60ch}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}

/* フォーム */
.cta-box{padding:36px;box-shadow:var(--shadow-lg)}
.cta-box h2{margin:8px 0 12px;font-size:clamp(1.8rem,3.6vw,2.5rem);line-height:1.5;max-width:16em}
.cta-box p{margin:0;color:var(--muted)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.field{display:grid;gap:6px}
.field.full{grid-column:1/-1}
label{font-size:.9rem;color:#544c43}
label .req{color:var(--red);font-size:.78rem;margin-left:6px}
input,select,textarea{width:100%;padding:14px 15px;border-radius:10px;border:1px solid #d8cfc3;background:#fffefb;color:var(--ink);transition:border-color .18s,box-shadow .18s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(183,134,47,.15)}
textarea{min-height:120px;resize:vertical}

/* 申込みの流れ（横ステップ） */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.step{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:22px;position:relative}
.step .n{display:inline-flex;width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#1f160b;font-weight:800;align-items:center;justify-content:center;margin-bottom:10px}
.step h3{margin:0 0 6px;font-size:1.02rem}
.step p{margin:0;color:var(--muted);font-size:.95rem}

/* フッター */
.footer{padding:40px 0 30px;border-top:1px solid rgba(0,0,0,.06);background:rgba(255,255,255,.5);color:#786f65;font-size:.88rem}
.footgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px;margin-bottom:24px}
.footgrid .fb-brand{font-family:"Yu Mincho",serif;font-size:1.15rem;color:var(--ink);font-weight:800;margin-bottom:8px}
.footgrid .fb-brand span{color:var(--gold)}
.footgrid h4{margin:0 0 10px;font-size:.92rem;color:var(--ink)}
.footnav{display:grid;gap:8px}
.footnav a:hover{color:var(--gold-deep)}
.footin{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:18px;border-top:1px solid var(--line)}

/* モバイル固定CTA */
.mobile-cta{display:none}

/* スクロール演出（JS有効時のみ隠す＝no-JSでも必ず表示） */
.reveal{transition:opacity .6s ease,transform .6s ease}
.js .reveal{opacity:0;transform:translateY(22px)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
  .seat-badge .dot{animation:none}
}

/* ---------- レスポンシブ ---------- */
@media (max-width:920px){
  .links{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:rgba(251,248,242,.99);backdrop-filter:blur(12px);padding:8px 18px 18px;border-bottom:1px solid var(--line);box-shadow:0 18px 30px rgba(0,0,0,.08);transform:translateY(-130%);transition:transform .3s ease;max-height:calc(100vh - 72px);overflow:auto}
  .links.open{transform:none}
  .links a{padding:14px 4px;border-bottom:1px solid var(--line)}
  .links a.btn{margin-top:12px;border-bottom:none}
  .burger{display:flex}
  .hero{min-height:unset;background-position:64% center}
  .hero::before{background:linear-gradient(180deg,rgba(246,241,232,.95) 0%,rgba(246,241,232,.92) 46%,rgba(246,241,232,.78) 100%)}
  .hero-inner{max-width:none}
  .grid-3,.reports{grid-template-columns:1fr 1fr}
  .concept,.event-layout,.lab,.host{grid-template-columns:1fr}
  .host{text-align:center}.host .ph{max-width:160px;margin:auto}
  .steps{grid-template-columns:1fr}
  .footgrid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .section,.cta{padding:64px 0}
  .hero-inner{padding:64px 0 76px}
  .hero h1{font-size:2.75rem;line-height:1.34}
  .heading h2,.cta-box h2{max-width:none}
  .grid-3,.grid-2,.reports,.form,.footgrid{grid-template-columns:1fr}
  .date-main{font-size:2.2rem;line-height:1.4}
  .cta-box{padding:26px}
  .timeline li{grid-template-columns:90px 1fr;gap:12px}
  .mobile-cta{display:flex;position:fixed;left:12px;right:12px;bottom:12px;z-index:40;min-height:54px;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#20170a;font-weight:800;box-shadow:0 12px 28px rgba(0,0,0,.16)}
  body.has-mcta{padding-bottom:74px}
}

/* ============================================================
   ナレッジ（メディア）
   ============================================================ */
/* カテゴリのフィルタ／タグ */
.cat-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.cat{display:inline-block;padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;color:#5b534a;font-size:.9rem;font-weight:700;transition:.18s}
.cat:hover,.cat.active{background:linear-gradient(135deg,var(--gold-soft),var(--gold));border-color:transparent;color:#1f160b}

/* 記事一覧カード */
.kn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.kn-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}
.kn-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.kn-card .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--ink),var(--ink-2));display:flex;align-items:center;justify-content:center;color:var(--gold-soft);font-family:"Yu Mincho",serif;font-size:1.5rem;letter-spacing:.08em;position:relative;overflow:hidden;padding:18px;text-align:center;line-height:1.5}
.kn-card .thumb::after{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;background:radial-gradient(circle,rgba(217,189,123,.22),transparent 70%)}
.kn-card .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.kn-card .meta{display:flex;gap:10px;align-items:center;font-size:.78rem;color:var(--gold-deep);font-weight:700}
.kn-card .meta .tagx{padding:3px 9px;border-radius:999px;background:rgba(183,134,47,.12)}
.kn-card h3{margin:2px 0 0;font-size:1.1rem;line-height:1.5}
.kn-card p{margin:0;color:var(--muted);font-size:.94rem;flex:1}
.kn-card .more{color:var(--gold-deep);font-weight:700;font-size:.9rem;margin-top:6px}

/* 記事本文 */
.article{max-width:760px;margin:0 auto}
.article .a-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;color:var(--muted);font-size:.85rem;margin-bottom:18px}
.article .a-meta .tagx{padding:4px 11px;border-radius:999px;background:rgba(183,134,47,.12);color:var(--gold-deep);font-weight:700}
.article .lead-p{font-size:1.1rem;color:#4a433a;line-height:1.95;margin:0 0 8px}
.article h2{font-size:clamp(1.5rem,3vw,2rem);margin:48px 0 14px;padding-bottom:10px;border-bottom:2px solid var(--line);line-height:1.5}
.article h3{font-size:1.22rem;margin:32px 0 10px;padding-left:14px;border-left:4px solid var(--gold)}
.article p{margin:0 0 18px;line-height:1.95}
.article ul,.article ol{margin:0 0 20px;padding-left:1.4em}
.article li{margin-bottom:8px;line-height:1.85}
.article strong{color:var(--ink);font-weight:700;background:linear-gradient(transparent 60%,rgba(217,189,123,.4) 60%)}
.article blockquote{margin:24px 0;padding:18px 22px;border-left:4px solid var(--gold);background:var(--paper-deep);border-radius:0 10px 10px 0;color:var(--ink);font-size:1.05rem}
.article blockquote p:last-child{margin:0}
.article .callout{margin:24px 0;padding:22px 24px;border:1px solid var(--line);border-left:5px solid var(--red);background:linear-gradient(180deg,#fffdfa,#f9f2e8);border-radius:0 12px 12px 0}
.article .callout strong{background:none;display:block;color:var(--red);margin-bottom:6px}
.article hr{border:none;border-top:1px solid var(--line);margin:40px 0}
.article figure{margin:24px 0}
.article .toc{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:20px 24px;margin:0 0 36px}
.article .toc strong{display:block;background:none;color:var(--gold-deep);margin-bottom:10px;font-size:.9rem;letter-spacing:.04em}
.article .toc ol{margin:0;padding-left:1.3em}
.article .toc a{color:#4a433a}
.article .toc a:hover{color:var(--gold-deep)}

/* 記事末・関連／CTA */
.share-note{margin-top:30px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:.88rem}
.related{margin-top:14px}
@media (max-width:920px){
  .kn-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .kn-grid{grid-template-columns:1fr}
  .article h2{margin:36px 0 12px}
}

/* ============================================================
   会議の中身（問い／Before→After／参加者の声）
   ============================================================ */
/* 当日扱う問い */
.qcard{padding:24px;background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--gold-soft);border-radius:14px;box-shadow:var(--shadow)}
.qcard .qmark{display:inline-block;font-family:"Yu Mincho",serif;color:var(--gold-deep);font-weight:800;font-size:1.05rem;letter-spacing:.04em;margin-bottom:8px}
.qcard p{margin:0;color:var(--ink);font-weight:600;line-height:1.75}

/* Before → After */
.ba-grid{display:grid;gap:14px}
.ba{display:grid;grid-template-columns:1fr 56px 1fr;align-items:stretch;background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.ba .b,.ba .a{padding:20px 22px;line-height:1.7}
.ba .b{background:var(--paper-deep);color:var(--muted)}
.ba .a{color:var(--ink);font-weight:600}
.ba .arrow{display:flex;align-items:center;justify-content:center;background:var(--paper-deep);color:var(--gold);font-weight:900;font-size:1.3rem}
.ba .lbl{display:block;font-size:.72rem;font-weight:800;letter-spacing:.08em;margin-bottom:6px}
.ba .b .lbl{color:#a59986}
.ba .a .lbl{color:var(--gold-deep)}

/* 参加者の声 */
.voice{padding:26px;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.voice .qt{font-family:"Yu Mincho",serif;font-size:1.05rem;color:var(--ink);line-height:1.85;margin:0 0 14px;position:relative;padding-left:26px}
.voice .qt::before{content:"\201C";position:absolute;left:0;top:-8px;font-size:2.1rem;color:var(--gold-soft);font-family:serif;line-height:1}
.voice .who{color:var(--muted);font-size:.88rem}
.voice.placeholder{border-style:dashed;background:rgba(255,255,255,.5)}
.voice.placeholder .qt{color:var(--muted)}

@media (max-width:640px){
  .ba{grid-template-columns:1fr}
  .ba .arrow{padding:6px 0;font-size:1.1rem;transform:rotate(90deg)}
}

/* ============================================================
   主催者プロフィール
   ============================================================ */
.profile{display:grid;grid-template-columns:240px 1fr;gap:34px;align-items:start;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px}
.profile .photo{position:relative;width:100%;aspect-ratio:3/4;border-radius:14px;background:radial-gradient(circle at 50% 18%,#2c2620,var(--ink) 70%);display:flex;align-items:flex-end;justify-content:center;color:var(--gold-soft);font-family:"Yu Mincho",serif;font-size:3rem;overflow:hidden}
.profile .photo::after{content:"";position:absolute;left:50%;top:8%;width:78%;height:60%;transform:translateX(-50%);background:radial-gradient(circle,rgba(217,189,123,.22),transparent 70%);pointer-events:none}
.profile .photo img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center top}
.profile .name{margin:0 0 4px;font-size:1.6rem}
.profile .role{color:var(--gold-deep);font-weight:700;margin-bottom:14px}
.profile .bio{color:var(--muted);margin:0 0 16px}
.profile .sns{display:flex;gap:12px;flex-wrap:wrap}
.profile .edit-hint{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:6px;background:rgba(159,59,48,.08);color:var(--red);font-size:.7rem;font-weight:700;vertical-align:middle}
.deflist{display:grid;gap:0}
.deflist .row{display:grid;grid-template-columns:160px 1fr;gap:18px;padding:16px 0;border-bottom:1px solid var(--line)}
.deflist .row:last-child{border-bottom:none}
.deflist dt{margin:0;color:var(--gold-deep);font-weight:700}
.deflist dd{margin:0;color:var(--ink)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:20px;text-align:center}
.stat .v{font-family:"Yu Mincho",serif;font-size:1.7rem;font-weight:800;color:var(--gold-deep);line-height:1.2}
.stat .l{display:block;margin-top:6px;color:var(--muted);font-size:.84rem}
@media (max-width:640px){.stats{grid-template-columns:1fr 1fr}}

/* 登壇実績 */
.talks{display:grid;gap:20px}
.talk{display:grid;grid-template-columns:260px 1fr;gap:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.talk.upcoming{border:1px solid rgba(183,134,47,.45);box-shadow:0 14px 34px rgba(183,134,47,.14)}
.talk .pic{position:relative;background:radial-gradient(circle at 50% 30%,#2c2620,var(--ink) 75%);min-height:180px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.talk .pic img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.talk .pic .ph-note{color:var(--gold-soft);font-size:.82rem;text-align:center;padding:16px;line-height:1.6;font-family:"Yu Mincho",serif}
.talk .pic.duo{display:grid;grid-template-rows:1fr 1fr;gap:4px}
.talk .pic.duo img{position:static;width:100%;height:100%;object-fit:cover}
.talk .body{padding:24px 26px}
.talk .when{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border-radius:999px;background:rgba(183,134,47,.12);color:var(--gold-deep);font-weight:800;font-size:.84rem;margin-bottom:10px}
.talk.upcoming .when{background:rgba(159,59,48,.1);color:var(--red)}
.talk .body h3{margin:0 0 6px;font-size:1.18rem;line-height:1.5}
.talk .body .meta{color:var(--gold-deep);font-weight:700;font-size:.9rem;margin-bottom:8px}
.talk .body p{margin:0;color:var(--muted)}
.talk .mini-voices{margin-top:14px;display:grid;gap:8px}
.talk .mini-voices .v{font-size:.9rem;color:#5b534a;padding-left:18px;position:relative;line-height:1.7}
.talk .mini-voices .v::before{content:"\201C";position:absolute;left:0;top:-1px;color:var(--gold);font-family:serif;font-weight:700}
@media (max-width:640px){
  .talk{grid-template-columns:1fr}
  .talk .pic{min-height:200px}
}
@media (max-width:640px){
  .profile{grid-template-columns:1fr;text-align:center}
  .profile .photo{max-width:200px;margin:0 auto}
  .profile .sns{justify-content:center}
  .deflist .row{grid-template-columns:1fr;gap:2px}
}
