:root{--green:#2f7d5b;--green-d:#20573f;--green-deep:#173f2d;--green-soft:#eaf3ee;--green-tint:#f3f8f5;--orange:#e8622e;--orange-d:#b8461f;--ink:#232323;--sub:#555350;--muted:#8f8f8a;--line:#e2e1db;--gray:#f5f6f4;--success:#2e8b57;--success-bg:#e9f5ee;--red:#c0392b}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Noto Sans JP',sans-serif;color:var(--ink);background:#fff;font-size:16px;line-height:1.9}
a{color:var(--green);text-decoration:none}img{display:block;max-width:100%;height:auto}svg{display:block}
.ic svg{stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.wrap{max-width:1160px;margin:0 auto;padding:0 22px}
.header{border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:50}
.hin{max-width:1160px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:11px 22px}
.logo{display:flex;align-items:center;gap:9px;flex-shrink:0}.logo .txt{font-weight:900;font-size:19px;color:var(--green-d);line-height:1.1}.logo .tag{font-size:10px;color:var(--muted)}
.hnav{display:flex;gap:17px;margin-left:4px}.hnav a{font-size:14px;font-weight:700;color:var(--ink);white-space:nowrap}
.hbtn{margin-left:auto;flex-shrink:0;background:var(--orange);color:#fff;font-weight:900;font-size:14px;padding:11px 18px;border-radius:4px}
.breadcrumb{font-size:12px;color:var(--muted);padding:14px 0}.breadcrumb a{color:var(--muted)}.breadcrumb .sep{margin:0 6px}
.content{display:grid;grid-template-columns:1fr 300px;gap:40px;padding-bottom:60px;align-items:start}
.main{min-width:0}
.eyebrow{display:inline-block;background:var(--green-soft);color:var(--green-d);font-size:12px;font-weight:700;padding:4px 12px;border-radius:4px;margin-bottom:12px}
.main h1{font-size:28px;font-weight:900;line-height:1.5;margin-bottom:14px}
.meta{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:22px}
.meta .av{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;text-align:center;line-height:1.1;flex-shrink:0}
.meta .who{font-size:13px;font-weight:900}
.meta .dates{margin-left:auto;text-align:right;font-size:12px;color:var(--muted)}
.meta .dates i{margin-right:5px;color:var(--green)}
.meta .dates .up{color:var(--success);font-weight:700}.meta .dates .up i{color:var(--success)}
.lead{font-size:16px;margin-bottom:8px}
/* 装飾 */
.b{font-weight:900}.r{font-weight:900;color:var(--red)}.mk{background:linear-gradient(transparent 62%,#ffe89f 62%);font-weight:700}
/* 本文段落（1文=1p） */
.main .p{margin-bottom:11px}
/* 結論ボックス */
.conc{border:1.5px solid var(--green);margin:16px 0 24px}
.conc .h{background:var(--green);color:#fff;font-weight:900;padding:11px 16px;font-size:15px;display:flex;gap:8px;align-items:center}.conc .h .ic svg{width:18px;height:18px;stroke:#fff}
.conc .b2{padding:16px}
.conc .row{display:grid;grid-template-columns:130px 1fr;gap:10px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:15px}.conc .row:last-child{border:none}
.conc .k{font-size:13px;color:var(--sub);font-weight:700}.conc .v b{color:var(--orange);font-weight:900}
/* 目次 */
.toc-d{border:1px solid var(--line);margin-bottom:28px}
.toc-d .t{position:relative;padding:12px 16px;font-weight:900;font-size:14px;display:flex;justify-content:center;align-items:center;background:var(--gray);cursor:pointer}
.toc-d .t .tg{position:absolute;right:16px;font-size:12px;color:var(--green);font-weight:700}
.toc-d ol{list-style:none;counter-reset:t;padding:14px 18px;border-top:1px solid var(--line)}
.toc-d.closed ol{display:none}.toc-d li{counter-increment:t;margin-bottom:0}
.toc-d a{font-size:14px;color:var(--sub);display:flex;gap:8px;padding:3px 0}.toc-d a::before{content:counter(t)".";color:var(--orange);font-weight:900}
/* 見出し */
.h2{display:block;font-size:24px;font-weight:900;padding:11px 20px;color:#fff;background:linear-gradient(90deg,var(--green),var(--green-deep));box-shadow:0 4px 9px rgba(23,63,45,.28);margin:40px 0 15px}
.h3{font-size:21px;font-weight:900;padding-left:8px;border-bottom:5px solid var(--green);position:relative;display:block;margin:32px 0 18px}
.h3::after{content:"";position:absolute;left:0;bottom:-5px;width:72px;height:5px;background:var(--orange)}
.h4{font-size:16px;font-weight:900;padding-left:12px;border-left:5px solid var(--orange);margin:22px 0 12px}
/* 表 */
.tbl{width:100%;border-collapse:collapse;font-size:15px;border:1px solid var(--line);margin:8px 0 14px}
.tbl th{background:var(--green);color:#fff;padding:11px}.tbl td{padding:11px;border:1px solid var(--line);text-align:center}
.tbl td:first-child,.tbl th:first-child{background:var(--green-soft);color:var(--green-d);font-weight:700;text-align:left}
.tnote{font-size:12px;color:var(--muted);margin-bottom:14px}
.tblbox{margin:8px 0 14px}.scroll-hint{display:none;text-align:right;font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:700}.scroll-hint i{color:var(--orange)}.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.tscroll .tbl{min-width:480px;margin:0}
/* ポイント */
.pt{background:#fff;border:2px solid var(--green);margin:18px 0}.pt .t{background:var(--green);color:#fff;font-weight:900;padding:9px 16px;font-size:14px}.pt .bd{padding:13px 16px;font-size:15px}
/* ステップ */
.steps{margin:14px 0}
.step{display:grid;grid-template-columns:44px 1fr;gap:14px;position:relative;padding-bottom:20px}
.step:not(:last-child)::before{content:"";position:absolute;left:21px;top:44px;bottom:0;width:2px;background:var(--line)}
.step .n{width:44px;height:44px;border-radius:50%;background:var(--green);color:#fff;font-weight:900;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:16px;line-height:1;z-index:2}.step .n small{font-size:9px;line-height:1;margin-bottom:1px}
.step .sc h4{font-size:15px;font-weight:900;margin-bottom:3px}.step .sc p{font-size:14px;color:var(--sub);margin:0}
/* CTA */
.cta-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:70%;margin:26px auto;background:var(--orange);color:#fff;font-weight:900;font-size:16px;padding:15px 20px;border-radius:999px;box-shadow:0 4px 0 var(--orange-d)}.cta-btn i{font-size:13px}
@media(max-width:640px){.cta-btn{width:100%}}
/* FAQ */
.faq .item{border-bottom:1px solid var(--line);padding:16px 0}.faq .item:first-child{border-top:1px solid var(--line)}
.faq .q{font-weight:900;display:flex;gap:8px;margin-bottom:6px}.faq .q .l{color:var(--orange)}
.faq .a{padding-left:0;font-size:15px;color:var(--sub);display:flex;gap:8px}.faq .a .l{color:var(--green);font-weight:900}.faq .a .atext{flex:1}.faq .a .atext p{margin-bottom:8px}.faq .a .atext p:last-child{margin-bottom:0}
/* 画像プレースホルダ */
.imgph{border:2px dashed var(--green);background:var(--green-tint);padding:16px 18px;margin:0 0 20px;font-size:13px;color:var(--green-d)}
.imgph .lbl{font-weight:900;margin-bottom:4px;display:flex;align-items:center;gap:6px}.imgph .lbl i{color:var(--orange)}
.imgph .note{color:var(--muted);font-size:12px;margin-top:6px}
/* 出典 */
.src{font-size:12px;color:var(--muted);border-top:1px dashed var(--line);padding-top:8px;margin:8px 0 18px}
/* 関連カード */
.relwrap{margin:18px 0}
.rellabel{font-size:12px;font-weight:900;color:var(--green-d);margin-bottom:8px}
.relcard{display:grid;grid-template-columns:120px 1fr auto;gap:16px;align-items:center;border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-bottom:10px}
.relcard img{width:120px;height:80px;object-fit:cover}.relcard .rc{padding:6px 0}.relcard .cat{font-size:11px;color:var(--orange);font-weight:700}.relcard h4{font-size:14px;font-weight:700;line-height:1.5}.relcard .arw{padding-right:16px;color:var(--green)}
/* 著者 */
.author-box{border:1px solid var(--line);background:var(--gray);padding:18px;margin:0 0 26px;display:grid;grid-template-columns:auto 1fr;gap:14px}
.author-box .av{width:52px;height:52px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.author-box .av svg{width:30px;height:30px;display:block}
.author-box .av img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.author-box h4{font-size:14px;font-weight:900}.author-box .role{font-size:12px;color:var(--muted);margin-bottom:5px}.author-box p{font-size:13px;color:var(--sub);margin:0}.author-box .upd{font-size:11px;color:var(--muted);margin-top:6px}
/* sidebar */
.sidebar{position:sticky;top:78px}
.side-toc{border:1px solid var(--line);padding:16px 18px;margin-bottom:20px}.side-toc h4{font-size:13px;font-weight:900;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}.side-toc ol{list-style:none;counter-reset:s}.side-toc li{counter-increment:s;margin-bottom:8px}.side-toc a{font-size:13px;color:var(--sub);display:flex;gap:8px}.side-toc a::before{content:counter(s);color:var(--orange);font-weight:900}
.side-cta{border:2px solid var(--orange);padding:18px;text-align:center;margin-bottom:20px}.side-cta h4{font-size:14px;font-weight:900;margin-bottom:6px}.side-cta p{font-size:12px;color:var(--sub);margin-bottom:12px}.side-cta a{display:block;background:var(--orange);color:#fff;font-weight:900;padding:12px;border-radius:999px;font-size:14px}
.side-list{border:1px solid var(--line)}.side-list .h{background:var(--green-tint);color:var(--green-d);font-size:13px;font-weight:900;padding:11px 16px;border-bottom:1px solid var(--line)}.side-list a{display:flex;justify-content:space-between;padding:11px 16px;font-size:13px;color:var(--ink);border-bottom:1px solid var(--line)}.side-list a:last-child{border:none}.side-list a b{color:var(--orange)}
.footer{background:var(--green-deep);color:#bcd0c4;padding:40px 22px 22px}.fg{max-width:1160px;margin:0 auto 20px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}.fg .brand .txt{color:#fff;font-weight:900}.fg .brand p{font-size:12px;color:#9db5a7;margin-top:8px}.footer h4{color:#fff;font-size:13px;margin-bottom:10px}.footer a{display:block;color:#9db5a7;font-size:13px;margin-bottom:6px}.fbot{border-top:1px solid rgba(255,255,255,.12);padding-top:16px;max-width:1160px;margin:0 auto;font-size:12px;color:#8caa9a}
@media(max-width:900px){.content{grid-template-columns:1fr}.sidebar{position:static}.hnav,.logo .tag{display:none}.fg{grid-template-columns:1fr 1fr}}
@media(max-width:640px){body{font-size:14px}.wrap{padding:0 12px}.hin{padding:11px 12px}.main h1{font-size:23px}.h2{font-size:20px}.h3{font-size:18px}.scroll-hint{display:block}.sidebar{display:none}}
/* ===== 追加パーツ（ショートコード用） ===== */
.acc{border:1px solid var(--line);margin:12px 0}
.acc .q{background:var(--green-tint);padding:14px 16px;font-weight:900;display:flex;justify-content:space-between;align-items:center;gap:10px;cursor:pointer;font-size:15px}
.acc .q .pm svg{width:20px;height:20px;stroke:var(--green);stroke-width:1.8;fill:none;stroke-linecap:round;transition:.2s}
.acc:not(.closed) .q .pm svg{transform:rotate(45deg)}
.acc .a{padding:14px 16px;font-size:15px;color:var(--sub);border-top:1px solid var(--line)}
.acc.closed .a{display:none}
.quote{position:relative;background:var(--green-tint);border-left:5px solid var(--green);padding:20px 22px 18px 52px;margin:14px 0}
.quote .qm{position:absolute;left:16px;top:14px;color:var(--green);opacity:.5;font-size:26px}
.quote p{font-size:15px;margin:0}
.quote cite{display:block;margin-top:8px;font-size:12px;color:var(--muted);font-style:normal}
.clist{list-style:none;margin:12px 0}.clist li{display:flex;gap:10px;align-items:flex-start;font-size:15px;margin:0}
.clist li .ck{width:22px;height:22px;min-width:22px;border-radius:50%;background:var(--success-bg);color:var(--success);display:flex;align-items:center;justify-content:center;margin-top:2px}.clist li .ck i{font-size:12px}
.nlist{list-style:none;margin:12px 0;counter-reset:n}.nlist li{counter-increment:n;display:flex;gap:12px;align-items:flex-start;font-size:15px;margin:0}
.nlist li::before{content:counter(n);width:26px;height:26px;min-width:26px;border-radius:50%;background:var(--orange);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;font-size:13px}

/* CTAボタン キラキラ（なめらか光沢スイープ・等速） */
.cta-btn{position:relative;overflow:hidden}
.cta-btn>*{position:relative;z-index:1}
.cta-btn::after{content:"";position:absolute;top:0;bottom:0;left:0;width:45%;background:linear-gradient(105deg,rgba(255,255,255,0),rgba(255,255,255,.5) 50%,rgba(255,255,255,0));transform:translateX(-200%);pointer-events:none;animation:ctaShine 4.5s linear infinite}
@keyframes ctaShine{0%{transform:translateX(-200%)}22%{transform:translateX(320%)}100%{transform:translateX(320%)}}
@media(prefers-reduced-motion:reduce){.cta-btn::after{animation:none}}

/* 本文の内部リンク（緑・下線） */
.main p a{color:var(--green);text-decoration:underline;text-underline-offset:3px;font-weight:700}
.main p a:hover{color:var(--green-d)}

/* 親ページ内部リンク（導入下） */
.parent-link{display:flex;align-items:center;gap:10px;background:var(--green-tint);border:1px solid var(--line);border-left:4px solid var(--green);padding:11px 16px;margin:0 0 20px;font-size:14px;font-weight:700;color:var(--green-d);text-decoration:none}
.parent-link .pl-ic{color:var(--green)}
.parent-link .pl-a{margin-left:auto;color:var(--orange);font-size:13px}
.parent-link:hover{background:#e4efe8}

/* ===== ヘッダー/フッターをトップと統一 ===== */
:root{--r:4px}
.logo .mk{width:30px;height:30px}
.hnav{display:flex;gap:17px;margin-left:4px;flex-wrap:nowrap}
.hnav a{font-size:14px;font-weight:700;white-space:nowrap;color:var(--ink)}
.hnav a:hover{color:var(--green)}
.hnav .ca{font-size:9px;color:var(--muted)}
.hbtn{margin-left:auto;flex-shrink:0;background:var(--orange);color:#fff;font-weight:900;font-size:14px;padding:11px 18px;border-radius:var(--r)}
.hbtn:hover{background:var(--orange-d)}
.footer{background:var(--green-deep);color:#bcd0c4;padding:44px 22px 22px}
.fg{max-width:1160px;margin:0 auto 24px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:24px}
.fg .brand .logo{display:flex;align-items:center;gap:9px}
.fg .brand .logo .txt{color:#fff;font-weight:900;font-size:19px}
.fg .brand p{font-size:12px;color:#9db5a7;margin-top:8px;line-height:1.7}
.footer h4{color:#fff;font-size:13px;margin-bottom:10px}
.footer a{display:block;color:#9db5a7;font-size:13px;margin-bottom:6px}
.footer a:hover{color:#fff}
.fbot{border-top:1px solid rgba(255,255,255,.12);padding-top:16px;max-width:1160px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12px;color:#8caa9a}
.fbot .lks{display:flex;gap:16px}.fbot a{color:#8caa9a}.fbot a:hover{color:#fff}
@media(max-width:900px){.fg{grid-template-columns:1fr 1fr}.hnav{display:none}}

/* アイキャッチ（記事上部・角丸なし・影あり） */
.ec-hero{aspect-ratio:1200/630;margin:0 0 26px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.12);background:var(--green-tint)}
.ec-hero img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}

/* 記事内の図解画像（.single配下・角丸なし・影あり・比率維持） */
.single img{max-width:100%;height:auto;border-radius:0;box-shadow:0 6px 20px rgba(0,0,0,.16);margin-bottom:15px}
.single .relcard img{width:120px;height:80px;object-fit:cover;box-shadow:none;margin:0}
.single .ec-hero img{height:100%;box-shadow:none;margin:0}
.article-fig,.main figure.wp-block-image,.main figure.wp-caption{margin:18px auto}
.article-fig img{display:block;margin:0 auto}
.article-fig figcaption{font-size:12px;color:var(--muted);margin-top:8px;text-align:center}

/* ===== 記事下エリア ===== */
.post-foot{margin-top:30px}
.share{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:24px}
.share-l{font-size:13px;font-weight:900;color:var(--sub);display:flex;align-items:center;gap:7px;margin-right:4px}
.share .sh{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:16px;border:none;cursor:pointer;text-decoration:none;position:relative}
.share .sh-x{background:#111}.share .sh-fb{background:#1877f2}.share .sh-line{background:#06c755}.share .sh-copy{background:var(--green)}
.share .sh:hover{opacity:.88}
.share .sh-copy.copied::after{content:"コピーしました";position:absolute;bottom:46px;left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--ink);color:#fff;font-size:11px;font-weight:700;padding:4px 8px;border-radius:4px}
.foot-mod{margin:0 0 24px}
.fm-title{font-size:16px;font-weight:900;margin-bottom:12px;display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:2px solid var(--green)}
.fm-title i{color:var(--green)}
.area-chips{display:flex;flex-wrap:wrap;gap:8px}
.area-chips a{background:var(--green-soft);color:var(--green-d);font-size:13px;font-weight:700;padding:8px 14px;border-radius:999px;text-decoration:none}
.area-chips a:hover{background:var(--green);color:#fff}
.useful-list{display:grid;grid-template-columns:1fr 1fr;gap:2px 20px}
.useful-list a{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);text-decoration:none;padding:10px 0;border-bottom:1px solid var(--line)}
.useful-list a i{color:var(--orange);font-size:12px}
.useful-list a:hover{color:var(--green)}
@media(max-width:640px){.useful-list{grid-template-columns:1fr}}

/* 記事下：グリッドカード（関連記事・近隣エリア） */
.relgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.gcard{display:block;border:1px solid var(--line);overflow:hidden;text-decoration:none;background:#fff;transition:.15s}
.gcard:hover{box-shadow:0 6px 16px rgba(0,0,0,.10)}
.gcard img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;box-shadow:none;margin:0}
.gcard .gc{padding:12px 13px}
.gcard .cat{display:inline-block;background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:4px 22px;border-radius:999px}
.gcard h4{font-size:13px;font-weight:700;line-height:1.55;color:var(--ink);margin:7px 0 0}
.gcard .date{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);margin-top:8px}
.gcard .date i{color:var(--green)}
@media(max-width:640px){.relgrid{grid-template-columns:1fr 1fr;gap:10px}.gcard h4{font-size:12px}}

/* 記事フッター上のCTAバンド */
.ctad{margin:36px 0}
.cd-wrap{max-width:1080px;margin:0 auto;padding:0 22px}
.cd{position:relative;background:linear-gradient(120deg,var(--orange),var(--orange-d));overflow:hidden;border-radius:16px;box-shadow:0 10px 26px rgba(0,0,0,.12)}
.cd .in{position:relative;min-height:200px;display:flex;align-items:center}
.cd .img{position:absolute;left:0;top:0;bottom:0;width:46%;clip-path:polygon(0 0,100% 0,calc(100% - 150px) 100%,0 100%)}
.cd .img img{width:100%;height:100%;object-fit:cover;box-shadow:none;margin:0}
.cd .txt{margin-left:48%;padding:20px 30px 20px 20px;text-align:center}
.cd h2{color:#fff;font-size:25px;font-weight:900;line-height:1.5;margin-bottom:14px}
.cd .pts{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-bottom:18px}
.cd .pts span{display:flex;align-items:center;gap:6px;color:#fff;font-size:14px;font-weight:700}
.cd .pts svg{width:18px;height:18px;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}
.cd .cdbtn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--orange-d);font-weight:900;font-size:17px;padding:15px 30px;border-radius:999px;box-shadow:0 6px 0 rgba(0,0,0,.18);text-decoration:none}
.cd .cdbtn:hover{box-shadow:0 4px 0 rgba(0,0,0,.18)}
.cd .cdbtn svg{width:18px;height:18px;stroke:var(--orange-d);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:720px){.cd .in{flex-direction:column;min-height:0}.cd .img{position:relative;width:100%;height:170px;clip-path:none}.cd .txt{margin:0;padding:26px 20px}.cd h2{font-size:20px}.cd .cdbtn{width:100%;justify-content:center}}