/* villio /article — エディトリアル・スタイル（AIっぽさを避けた落ち着いた誌面） */
:root{
  --paper:#F6F3EC; --ink:#1B2430; --ink-soft:#5A6675; --navy:#13314F;
  --accent:#C75B39; --accent-soft:#E9D9C9; --line:#D9D2C5; --white:#fff;
  --serif:'Noto Serif JP','Hiragino Mincho ProN','Yu Mincho',serif;
  --sans:'Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;
  --wrap:1080px; --narrow:720px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.95;
  -webkit-font-smoothing:antialiased;font-size:17px}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:var(--narrow);margin:0 auto;padding:0 24px}

/* ヘッダー */
.site-header{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--serif);font-weight:700;font-size:24px;color:var(--navy)}
.brand span{color:var(--accent)}
.site-header nav{display:flex;gap:22px;align-items:center;font-size:14px;font-weight:500}
.site-header nav a{color:var(--ink-soft)}
.site-header nav a:hover{color:var(--navy)}
.nav-cta{background:var(--navy);color:var(--white)!important;padding:9px 18px;border-radius:6px}

/* 記事一覧 */
.index-hero{padding:64px 0 40px;max-width:760px}
.kicker{font-size:13px;font-weight:700;letter-spacing:.18em;color:var(--accent);margin-bottom:14px}
.index-hero h1{font-family:var(--serif);font-size:40px;line-height:1.45;color:var(--navy);margin-bottom:18px;font-weight:700}
.index-hero .lede{color:var(--ink-soft);font-size:17px;line-height:2}
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;padding:24px 0 80px}
.card{background:var(--white);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(19,49,79,.10)}
.card-img{aspect-ratio:1200/630;background:var(--paper);overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-body{padding:22px 24px 26px}
.card-cat{font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--accent);margin-bottom:10px}
.card-body h2{font-family:var(--serif);font-size:21px;line-height:1.5;color:var(--navy);margin-bottom:10px;font-weight:700}
.card-desc{font-size:14px;color:var(--ink-soft);line-height:1.8;margin-bottom:14px}
.card-meta{font-size:12px;color:var(--ink-soft)}
.empty{padding:80px 0;text-align:center;color:var(--ink-soft)}

/* 記事ページ */
.article{padding:48px 0 80px}
.article .kicker{margin-bottom:16px}
.article h1{font-family:var(--serif);font-size:34px;line-height:1.55;color:var(--navy);font-weight:700;margin-bottom:18px}
.article .meta{font-size:13px;color:var(--ink-soft);margin-bottom:32px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.article .meta .cat{background:var(--accent-soft);color:var(--navy);padding:2px 10px;border-radius:100px;font-weight:700}
.hero-img{margin:0 auto 40px}
.hero-img img{border-radius:12px;border:1px solid var(--line);width:100%}
.body{font-size:17px}
.body h2{font-family:var(--serif);font-size:26px;color:var(--navy);font-weight:700;line-height:1.5;
  margin:54px 0 18px;padding-top:10px;border-top:2px solid var(--accent-soft)}
.body h3{font-size:20px;color:var(--navy);font-weight:700;margin:36px 0 12px}
.body p{margin:0 0 22px}
.body ul,.body ol{margin:0 0 24px;padding-left:1.4em}
.body li{margin-bottom:10px}
.body strong{color:var(--navy);font-weight:700}
.body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.body blockquote{border-left:3px solid var(--accent);background:var(--white);
  margin:24px 0;padding:16px 22px;color:var(--ink-soft);border-radius:0 8px 8px 0}
.body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px;background:var(--white)}
.body th,.body td{border:1px solid var(--line);padding:10px 14px;text-align:left}
.body th{background:var(--navy);color:var(--white);font-weight:700}

/* 要点ボックス */
.takeaways{background:var(--white);border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:8px;padding:24px 26px;margin:0 0 40px}
.tk-title{font-weight:700;color:var(--navy);margin-bottom:12px;font-size:15px;letter-spacing:.04em}
.takeaways ul{margin:0;padding-left:1.2em}
.takeaways li{margin-bottom:8px;color:var(--ink);font-size:15.5px}

/* 目次 */
.toc{background:var(--white);border:1px solid var(--line);border-radius:8px;padding:20px 24px;margin:0 0 40px}
.toc-title{font-weight:700;color:var(--navy);margin-bottom:10px;font-size:14px}
.toc ul{list-style:none;padding:0;margin:0}
.toc li{margin:6px 0;font-size:14.5px}
.toc li.lv3{padding-left:18px;font-size:13.5px}
.toc a{color:var(--ink-soft)}
.toc a:hover{color:var(--accent)}

/* 図解 */
figure.diagram{margin:34px 0;text-align:center}
figure.diagram svg{max-width:100%;height:auto;border-radius:12px}
figure.diagram figcaption{font-size:13px;color:var(--ink-soft);margin-top:10px;line-height:1.6}

/* FAQ */
.faq{margin-top:56px}
.faq h2{font-family:var(--serif);font-size:26px;color:var(--navy);margin-bottom:20px}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:8px;padding:20px 24px;margin-bottom:14px}
.faq-q{font-weight:700;color:var(--navy);margin-bottom:8px}
.faq-q::before{content:"Q. ";color:var(--accent)}
.faq-a{color:var(--ink-soft);font-size:15.5px;line-height:1.85}

/* CTA */
.cta{background:var(--navy);color:var(--white);border-radius:14px;padding:40px 36px;margin:56px 0 0;text-align:center}
.cta h3{font-family:var(--serif);font-size:23px;line-height:1.5;margin-bottom:14px;font-weight:700}
.cta p{color:#D7E0EA;font-size:15px;line-height:1.9;margin-bottom:24px;max-width:560px;margin-left:auto;margin-right:auto}
.cta-btn{display:inline-block;background:var(--accent);color:var(--white);font-weight:700;
  padding:15px 36px;border-radius:8px;font-size:16px;transition:background .2s}
.cta-btn:hover{background:#b14f30}

/* フッター */
.site-footer{background:var(--white);border-top:1px solid var(--line);padding:48px 0;margin-top:64px}
.f-brand{font-family:var(--serif);font-weight:700;color:var(--navy);font-size:20px;margin-bottom:8px}
.f-desc{color:var(--ink-soft);font-size:14px;max-width:560px;margin-bottom:16px;line-height:1.8}
.f-links{font-size:14px;color:var(--ink-soft);margin-bottom:12px}
.f-links a:hover{color:var(--accent)}
.f-copy{font-size:12px;color:var(--ink-soft)}

@media(max-width:760px){
  body{font-size:16px}
  .index-hero h1{font-size:30px}
  .index-hero{padding:44px 0 28px}
  .card-grid{grid-template-columns:1fr;gap:22px;padding:16px 0 56px}
  .article h1{font-size:27px}
  .body h2{font-size:22px}
  .cta{padding:32px 24px}
}
