/* =====================================================================
   ADKICKS — SEO Blog Article styles (article.css)
   読みやすさ × SEO評価を高める記事レイアウト。adkicks.css に上乗せ。
   ===================================================================== */

.art{--art-w:840px;max-width:var(--art-w);margin:0 auto;padding:0 var(--pad);}
.art-wide{max-width:1060px;margin:0 auto;padding:0 var(--pad);}

/* ---------- パンくず ---------- */
.breadcrumb{font-size:12.5px;color:var(--sub);display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:26px 0 0;}
.breadcrumb a{color:var(--sub);text-decoration:none;}
.breadcrumb a:hover{color:var(--blue);}
.breadcrumb .sep{opacity:.5;}
.breadcrumb [aria-current]{color:var(--ink);white-space:nowrap;}

/* ---------- 記事ヘッダー ---------- */
.art-head{padding:18px 0 6px;}
.art-cat{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-disp);font-size:12px;font-weight:700;
  letter-spacing:.04em;color:#fff;background:var(--grad);padding:6px 14px;border-radius:100px;white-space:nowrap;}
.art-title{font-size:clamp(28px,4.6vw,42px);font-weight:900;line-height:1.32;letter-spacing:-.01em;
  margin:18px 0 0;color:var(--ink);text-wrap:balance;}
.art-meta{display:flex;flex-wrap:wrap;gap:14px 22px;align-items:center;margin-top:20px;font-size:13px;color:var(--sub);}
.art-meta .am{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.art-meta svg{width:15px;height:15px;stroke:var(--sub);fill:none;stroke-width:1.7;}
.art-meta time b{color:var(--ink-2);font-weight:600;}

.art-hero{aspect-ratio:16/9;border-radius:18px;overflow:hidden;margin:28px 0 0;position:relative;
  background:linear-gradient(120deg,var(--paper-2),#dfe2ee);}
.art-hero img{width:100%;height:100%;object-fit:cover;display:block;}

/* ---------- この記事でわかること ---------- */
.takeaway{margin:34px 0 0;border:1px solid var(--line);border-radius:16px;background:var(--surface);
  padding:24px 26px;box-shadow:0 18px 44px -34px rgba(20,16,50,.4);}
.takeaway h2{font-size:15px;font-weight:800;color:var(--ink);margin:0 0 14px;display:flex;align-items:center;gap:9px;}
.takeaway h2::before{content:"";width:22px;height:22px;border-radius:6px;background:var(--grad);flex:none;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/></svg>") center/16px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/></svg>") center/16px no-repeat;}
.takeaway ul{list-style:none;margin:0;padding:0;display:grid;gap:11px;}
.takeaway li{position:relative;padding-left:26px;font-size:14.5px;line-height:1.7;color:var(--ink-2);}
.takeaway li::before{content:"";position:absolute;left:2px;top:.5em;width:8px;height:8px;border-radius:50%;
  background:var(--hot);}

/* ---------- 目次 (TOC) ---------- */
.toc{margin:30px 0 0;border:1px solid var(--line);border-radius:16px;background:var(--paper);padding:22px 26px;}
.toc-h{font-size:13px;font-weight:800;letter-spacing:.06em;color:var(--sub);text-transform:uppercase;margin:0 0 14px;
  display:flex;align-items:center;gap:8px;}
.toc-h::before{content:"目次";font-family:var(--ff-jp);letter-spacing:.04em;}
.toc-h span{display:none;}
.toc ol{list-style:none;counter-reset:toc;margin:0;padding:0;display:grid;gap:3px;}
.toc li a{counter-increment:toc;display:flex;gap:12px;align-items:baseline;padding:8px 6px;border-radius:8px;
  font-size:14.5px;line-height:1.6;color:var(--ink-2);text-decoration:none;transition:background .15s,color .15s;}
.toc li a::before{content:counter(toc,decimal-leading-zero);font-family:var(--ff-disp);font-weight:800;font-size:12px;
  color:var(--blue);flex:none;min-width:22px;}
.toc li a:hover{background:#fff;color:var(--blue);}
.toc li.sub a{padding-left:30px;font-size:13.5px;color:var(--sub);}
.toc li.sub a::before{content:"–";color:var(--line);}

/* ---------- 本文タイポグラフィ ---------- */
.art-body{margin-top:40px;font-size:17px;line-height:2.05;color:var(--ink-2);}
.art-body > p{margin:0 0 24px;text-wrap:pretty;}
.art-body h2{position:relative;font-size:clamp(22px,3vw,28px);font-weight:800;line-height:1.45;color:var(--ink);
  margin:56px 0 22px;padding:0 0 14px;border-bottom:2px solid var(--line);scroll-margin-top:90px;}
.art-body h2::after{content:"";position:absolute;left:0;bottom:-2px;width:64px;height:2px;background:var(--grad);}
.art-body h3{font-size:clamp(18px,2.3vw,21px);font-weight:800;color:var(--ink);margin:40px 0 14px;
  padding-left:14px;border-left:4px solid var(--blue);line-height:1.5;scroll-margin-top:90px;}
.art-body strong,.art-body b{font-weight:700;color:var(--ink);
  background:linear-gradient(transparent 62%,rgba(236,26,123,.16) 62%);}
.art-body a{color:var(--blue);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px;}
.art-body a:hover{color:var(--hot);}
.art-body ul,.art-body ol{margin:0 0 24px;padding-left:0;list-style:none;display:grid;gap:12px;}
.art-body ul li{position:relative;padding-left:28px;line-height:1.85;}
.art-body ul li::before{content:"";position:absolute;left:4px;top:.62em;width:9px;height:9px;border-radius:3px;
  background:var(--grad);}
.art-body ol{counter-reset:li;}
.art-body ol li{position:relative;padding-left:42px;line-height:1.85;counter-increment:li;}
.art-body ol li::before{content:counter(li);position:absolute;left:0;top:.1em;width:26px;height:26px;border-radius:8px;
  background:var(--ink);color:#fff;font-family:var(--ff-disp);font-weight:800;font-size:13px;
  display:flex;align-items:center;justify-content:center;}
.art-body figure{margin:30px 0;}
.art-body figure img{width:100%;border-radius:14px;display:block;}
.art-body figcaption{font-size:12.5px;color:var(--sub);text-align:center;margin-top:10px;}

/* ---------- コールアウト（ポイント / 注意 / 補足）---------- */
.callout{margin:30px 0;border-radius:14px;padding:20px 22px 20px 56px;position:relative;font-size:15px;line-height:1.85;
  border:1px solid var(--line);background:var(--surface);}
.callout .ico{position:absolute;left:18px;top:20px;width:26px;height:26px;border-radius:8px;display:flex;
  align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;}
.callout-title{display:block;font-weight:800;color:var(--ink);margin-bottom:5px;font-size:14px;letter-spacing:.02em;}
.callout p{margin:0;color:var(--ink-2);}
.callout.point{background:linear-gradient(180deg,rgba(42,69,230,.05),rgba(236,26,123,.04));border-color:rgba(122,54,198,.25);}
.callout.point .ico{background:var(--grad);}
.callout.warn{background:rgba(236,26,123,.05);border-color:rgba(236,26,123,.28);}
.callout.warn .ico{background:var(--hot);}
.callout.note{background:var(--paper);}
.callout.note .ico{background:var(--ink);}

/* ---------- 比較テーブル ---------- */
.art-table{margin:28px 0;overflow-x:auto;}
.art-table table{width:100%;border-collapse:separate;border-spacing:0;font-size:14.5px;min-width:480px;
  border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.art-table th,.art-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.7;}
.art-table thead th{background:var(--ink);color:#fff;font-weight:700;font-size:13.5px;}
.art-table tbody th{background:var(--paper);font-weight:700;color:var(--ink);white-space:nowrap;}
.art-table tbody tr:last-child th,.art-table tbody tr:last-child td{border-bottom:0;}
.art-table .hl{color:var(--blue);font-weight:700;}

/* ---------- 内部リンクカード（回遊性＝SEO）---------- */
.linkcard{display:flex;gap:16px;align-items:center;margin:28px 0;border:1px solid var(--line);border-radius:14px;
  padding:16px 18px;text-decoration:none;background:var(--surface);transition:border-color .2s,box-shadow .2s,transform .2s;}
.linkcard:hover{border-color:var(--purple);box-shadow:0 20px 40px -28px rgba(20,16,50,.4);transform:translateY(-2px);}
.linkcard .lc-thumb{width:84px;height:64px;border-radius:10px;flex:none;background:linear-gradient(120deg,var(--paper-2),#dfe2ee);
  background-size:cover;background-position:center;}
.linkcard .lc-k{font-family:var(--ff-disp);font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--hot);text-transform:uppercase;}
.linkcard .lc-t{font-size:15px;font-weight:700;color:var(--ink);line-height:1.5;margin-top:3px;}
.linkcard .lc-ar{margin-left:auto;color:var(--blue);font-size:20px;flex:none;}

/* ---------- まとめ ---------- */
.summary{margin:52px 0 0;border-radius:18px;padding:30px 30px 28px;background:var(--ink);color:#fff;}
.summary h2{font-size:21px;font-weight:800;margin:0 0 16px;color:#fff;border:0;padding:0;}
.summary h2::after{display:none;}
.summary ul{display:grid;gap:11px;margin:0;padding:0;list-style:none;}
.summary li{position:relative;padding-left:28px;line-height:1.8;color:rgba(255,255,255,.9);font-size:15px;}
.summary li::before{content:"";position:absolute;left:2px;top:.55em;width:10px;height:10px;border-radius:50%;background:var(--hot);}

/* ---------- FAQ（FAQスキーマ対応）---------- */
.faq{margin:50px 0 0;}
.faq-h{font-size:clamp(22px,3vw,28px);font-weight:800;color:var(--ink);margin:0 0 8px;}
.faq-sub{font-size:14px;color:var(--sub);margin:0 0 22px;}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--surface);margin-bottom:12px;overflow:hidden;}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 54px 20px 52px;position:relative;font-weight:700;
  font-size:15.5px;color:var(--ink);line-height:1.6;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::before{content:"Q";position:absolute;left:18px;top:18px;width:24px;height:24px;border-radius:7px;
  background:var(--grad);color:#fff;font-family:var(--ff-disp);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;}
.faq-item summary::after{content:"";position:absolute;right:20px;top:24px;width:11px;height:11px;border-right:2px solid var(--sub);
  border-bottom:2px solid var(--sub);transform:rotate(45deg);transition:transform .25s;}
.faq-item[open] summary::after{transform:rotate(-135deg);}
.faq-a{padding:0 22px 22px 52px;font-size:14.5px;line-height:1.9;color:var(--ink-2);}

/* ---------- CTA ---------- */
.art-cta{margin:50px 0 0;border-radius:20px;padding:38px 34px;text-align:center;position:relative;overflow:hidden;
  background:var(--grad);color:#fff;}
.art-cta h2{font-size:clamp(22px,3.2vw,30px);font-weight:900;margin:0;color:#fff;border:0;padding:0;line-height:1.4;}
.art-cta h2::after{display:none;}
.art-cta p{margin:14px auto 24px;max-width:520px;font-size:15px;line-height:1.85;color:rgba(255,255,255,.95);}
.art-cta .btn-white{display:inline-flex;align-items:center;gap:9px;background:#fff;color:var(--ink);font-weight:800;
  padding:15px 30px;border-radius:100px;text-decoration:none;font-size:15px;transition:transform .2s,box-shadow .2s;}
.art-cta .btn-white:hover{transform:translateY(-2px);box-shadow:0 18px 40px -16px rgba(0,0,0,.4);}

/* ---------- 著者プロフィール（E-E-A-T）---------- */
.author{margin:46px 0 0;display:flex;gap:18px;align-items:flex-start;border:1px solid var(--line);border-radius:16px;
  padding:24px 26px;background:var(--surface);}
.author .av{width:62px;height:62px;border-radius:50%;flex:none;background:var(--grad);display:flex;align-items:center;
  justify-content:center;color:#fff;font-family:var(--ff-disp);font-weight:800;font-size:22px;}
.author .a-k{font-family:var(--ff-disp);font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--hot);text-transform:uppercase;}
.author .a-n{font-size:16px;font-weight:800;color:var(--ink);margin:3px 0 8px;}
.author .a-d{font-size:13.5px;line-height:1.8;color:var(--sub);margin:0;}

/* ---------- 関連記事 ---------- */
.related{margin:60px 0 0;}
.related-h{font-size:clamp(20px,2.6vw,25px);font-weight:800;color:var(--ink);margin:0 0 22px;}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.rel-card{text-decoration:none;color:inherit;display:flex;flex-direction:column;}
.rel-card .rc-thumb{aspect-ratio:16/10;border-radius:12px;background:linear-gradient(120deg,var(--paper-2),#dfe2ee);
  background-size:cover;background-position:center;margin-bottom:13px;}
.rel-card .rc-m{font-size:11.5px;color:var(--sub);margin-bottom:6px;}
.rel-card .rc-t{font-size:15px;font-weight:700;line-height:1.55;color:var(--ink);}
.rel-card:hover .rc-t{color:var(--blue);}

/* ---------- 読了プログレスバー ---------- */
.read-bar{position:fixed;left:0;top:0;height:3px;width:0;z-index:200;background:var(--grad);transition:width .1s linear;}

@media (max-width:680px){
  .art-body{font-size:16px;line-height:1.95;}
  .related-grid{grid-template-columns:1fr;gap:16px;}
  .author{flex-direction:column;gap:14px;}
  .faq-item summary{padding-right:46px;}
}
@media (prefers-reduced-motion: reduce){
  .read-bar{transition:none;}
  .linkcard:hover{transform:none;}
}
