/* ============================================
   名著探究 コラム（課題図書・書き方ガイド）共通スタイル
   LP本体（index.html）の世界観を踏襲：生成り紙・墨・藍・朱・金
   ============================================ */
:root{
  --paper:#F7F4ED; --paper-deep:#EFEAE0; --paper-dark:#E4DECF;
  --sumi:#2A2A28; --sumi-soft:#4A463E; --faint:#7E7768;
  --ai:#1F3A5F; --shu:#C73E3A; --gold:#E8C77B;
  --serif:'Zen Old Mincho',serif; --sans:'Zen Kaku Gothic New',sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--sumi);font-family:var(--sans);line-height:2;
  font-feature-settings:"palt";-webkit-font-smoothing:antialiased;overflow-x:hidden}

.grain{position:fixed;inset:0;pointer-events:none;z-index:60;opacity:.5;mix-blend-mode:multiply;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="160" height="160"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.82" numOctaves="2"/><feColorMatrix type="saturate" values="0"/><feComponentTransfer><feFuncA type="linear" slope="0.028"/></feComponentTransfer></filter><rect width="160" height="160" filter="url(%23n)"/></svg>')}

/* ───── ヘッダー ───── */
.col-head{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 22px;background:rgba(247,244,237,.92);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--paper-dark)}
.col-brand{font-family:var(--serif);font-weight:700;font-size:17px;letter-spacing:.14em;
  color:var(--sumi);text-decoration:none;display:flex;align-items:baseline;gap:10px}
.col-brand small{font-size:11px;font-weight:500;color:var(--faint);letter-spacing:.18em}
.col-head-cta{font-family:var(--serif);font-size:13px;letter-spacing:.16em;color:var(--paper);
  background:var(--ai);text-decoration:none;padding:9px 18px;white-space:nowrap;transition:opacity .25s}
.col-head-cta:hover{opacity:.85}

/* ───── 記事レイアウト ───── */
.col-wrap{max-width:760px;margin:0 auto;padding:46px 24px 90px}
.breadcrumb{font-size:12px;color:var(--faint);letter-spacing:.06em;margin-bottom:34px}
.breadcrumb a{color:var(--faint);text-decoration:none;border-bottom:1px solid var(--paper-dark)}
.breadcrumb a:hover{color:var(--ai)}
.breadcrumb .sep{margin:0 8px;color:var(--paper-dark)}

.col-eyebrow{font-family:var(--serif);font-size:13px;letter-spacing:.34em;color:var(--shu);margin-bottom:14px}
h1{font-family:var(--serif);font-weight:700;font-size:clamp(25px,4.6vw,34px);line-height:1.7;
  letter-spacing:.06em;margin-bottom:18px}
.col-lede{color:var(--sumi-soft);font-size:15px;margin-bottom:14px}
.col-meta{font-size:12px;color:var(--faint);letter-spacing:.08em;padding-bottom:30px;margin-bottom:40px;
  border-bottom:1px solid var(--paper-dark)}

h2{font-family:var(--serif);font-weight:700;font-size:clamp(20px,3.4vw,24px);line-height:1.8;
  letter-spacing:.08em;margin:64px 0 22px;padding-left:16px;border-left:4px solid var(--ai)}
h3{font-family:var(--serif);font-weight:600;font-size:17px;letter-spacing:.08em;margin:40px 0 14px;color:var(--ai)}
p{margin-bottom:1.4em;font-size:15px}
strong{font-weight:700;background:linear-gradient(transparent 68%,rgba(232,199,123,.55) 68%)}
a{color:var(--ai)}
ul,ol{margin:0 0 1.6em 1.4em}
li{margin-bottom:.5em;font-size:15px}

/* 書誌カード */
.book-card{display:flex;gap:26px;align-items:flex-start;background:#fff;border:1px solid var(--paper-dark);
  padding:26px;margin:36px 0}
.book-card img{width:128px;height:auto;box-shadow:3px 4px 14px rgba(42,42,40,.18);flex-shrink:0}
.book-card .t{font-family:var(--serif);font-size:19px;font-weight:700;letter-spacing:.06em;margin-bottom:6px}
.book-card .cred{font-size:13px;color:var(--sumi-soft);margin-bottom:10px}
.book-card .tag{display:inline-block;font-size:11.5px;letter-spacing:.14em;color:var(--shu);
  border:1px solid var(--shu);padding:3px 10px;margin-bottom:12px}
.book-card .buy{font-size:13px}
@media(max-width:560px){.book-card{flex-direction:column;align-items:center;text-align:center}}

/* 購入導線 */
.book-card .cv-link{flex-shrink:0;display:block;line-height:0}
.book-card .cv-link img{transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.book-card .cv-link:hover img{transform:translateY(-3px);box-shadow:5px 8px 20px rgba(42,42,40,.26)}
.buy-btn{display:inline-block;font-family:var(--serif);font-size:13.5px;letter-spacing:.18em;
  color:var(--shu);text-decoration:none;border:1px solid var(--shu);padding:10px 26px;margin-top:2px;
  transition:background .25s,color .25s}
.buy-btn:hover{background:var(--shu);color:var(--paper)}
.buy-note{font-size:11.5px;color:var(--faint);letter-spacing:.04em;margin:8px 0 0}
.buy-inline{font-size:13px;margin-left:6px;white-space:nowrap}
@media(max-width:560px){.book-card .buy-btn{width:100%;text-align:center}}

/* 問いボックス */
.toi{background:var(--paper-deep);border-top:2px solid var(--ai);padding:24px 26px;margin:30px 0}
.toi .toi-label{font-family:var(--serif);font-size:13px;letter-spacing:.3em;color:var(--ai);margin-bottom:12px}
.toi p{margin-bottom:.8em;font-family:var(--serif);font-size:16px;line-height:2}
.toi p:last-child{margin-bottom:0}

/* 引用・注意 */
.note{font-size:13px;color:var(--faint);border-left:3px solid var(--paper-dark);padding-left:14px;margin:24px 0}

/* 表 */
table{width:100%;border-collapse:collapse;margin:26px 0;font-size:14px}
th,td{border:1px solid var(--paper-dark);padding:10px 14px;text-align:left;vertical-align:top}
th{background:var(--paper-deep);font-family:var(--serif);font-weight:600;letter-spacing:.1em;white-space:nowrap}

/* ───── 講座CTA帯 ───── */
.course-band{background:var(--ai);color:var(--paper);padding:44px 30px;margin:70px 0 0;text-align:center}
.course-band .cb-kicker{font-family:var(--serif);font-size:12.5px;letter-spacing:.32em;color:var(--gold);margin-bottom:14px}
.course-band .cb-title{font-family:var(--serif);font-size:clamp(20px,3.6vw,26px);font-weight:700;
  letter-spacing:.1em;line-height:1.8;margin-bottom:12px}
.course-band p{font-size:14px;color:rgba(247,244,237,.85);max-width:560px;margin:0 auto 24px}
.course-band a.cb-btn{display:inline-block;font-family:var(--serif);font-size:15px;letter-spacing:.22em;
  color:var(--paper);background:var(--shu);text-decoration:none;padding:15px 44px;
  box-shadow:0 6px 22px rgba(199,62,58,.32);transition:transform .25s}
.course-band a.cb-btn:hover{transform:translateY(-2px)}

/* ───── 関連記事 ───── */
.related{margin-top:70px;padding-top:34px;border-top:1px solid var(--paper-dark)}
.related .rel-label{font-family:var(--serif);font-size:14px;letter-spacing:.3em;color:var(--faint);margin-bottom:20px}
.rel-list{list-style:none;margin:0}
.rel-list li{margin-bottom:12px;font-size:14.5px}
.rel-list a{font-family:var(--serif);letter-spacing:.04em;text-decoration:none;border-bottom:1px solid var(--paper-dark)}
.rel-list a:hover{color:var(--shu);border-color:var(--shu)}
.rel-list .cat{display:inline-block;font-size:11px;color:var(--faint);letter-spacing:.12em;margin-right:10px}

/* ───── フッター ───── */
.col-foot{background:var(--paper-deep);border-top:1px solid var(--paper-dark);
  padding:36px 24px;text-align:center;font-size:12.5px;color:var(--faint);letter-spacing:.1em}
.col-foot a{color:var(--sumi-soft);text-decoration:none;border-bottom:1px solid var(--paper-dark)}
.col-foot .ft-brand{font-family:var(--serif);font-size:15px;color:var(--sumi);letter-spacing:.2em;margin-bottom:10px}
