/* ===== Tokens ===== */
:root{
  --bg:        #f6f4ee;          /* warm off-white, FT-ish */
  --bg-2:      #efece3;
  --paper:     #ffffff;
  --ink:       #0b1220;          /* near black with blue tint */
  --ink-2:     #2a3344;
  --mute:      #687085;
  --line:      #e2dfd5;
  --line-2:    #d6d2c4;
  --brand:     #0b1220;          /* primary text/black-ish */
  --accent:    #1e6b4a;          /* green (primary accent) */
  --accent-2:  #1f3b73;          /* deep blue */
  --rose:      #b1303a;
  --green:     #1e6b4a;
  --catA:      #1f3b73;          /* 基礎 - blue */
  --catB:      #b1303a;          /* 業者比較 - rose */
  --catC:      #1e6b4a;          /* 課題別 - green */
  --catD:      #6b4a2a;          /* 専門知識 - brown */
  --serif:     "Noto Serif JP", "Noto Sans JP", serif;
  --sans:      "Inter", "Noto Sans JP", system-ui, -apple-system, sans-serif;
  --mono:      "JetBrains Mono", ui-monospace, monospace;
  --maxw:      1240px;
  --radius:    4px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{margin:0;letter-spacing:-.01em}
p{margin:0}

/* ===== Util bar ===== */
.util{background:var(--ink);color:#dcd9cf;font-size:12px}
.util__inner{max-width:var(--maxw);margin:0 auto;padding:8px 24px;display:flex;justify-content:space-between;align-items:center}
.util__live{display:flex;align-items:center;gap:8px;font-family:var(--mono);letter-spacing:.04em}
.util__dot{width:6px;height:6px;background:#e74c3c;border-radius:50%;box-shadow:0 0 0 4px rgba(231,76,60,.2);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(231,76,60,0)}}
.util__nav a{margin-left:18px;color:#dcd9cf;opacity:.85;transition:opacity .15s}
.util__nav a:hover{opacity:1}
.util__lang{font-family:var(--mono);opacity:.7!important}

/* ===== Header ===== */
.hd{position:sticky;top:0;z-index:50;background:rgba(246,244,238,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.hd__inner{max-width:var(--maxw);margin:0 auto;padding:18px 24px;display:flex;align-items:center;gap:36px}
.hd__logo{display:flex;align-items:baseline;gap:10px;font-family:var(--serif);font-weight:900}
.hd__mark{color:var(--accent);font-size:18px}
.hd__name{font-size:22px;letter-spacing:.02em}
.hd__sub{display:inline-block;font-size:11px;font-family:var(--sans);font-weight:500;color:var(--mute);margin-left:8px;letter-spacing:.08em}
.hd__nav{display:flex;gap:24px;margin-left:auto}
.hd__nav a{font-weight:600;font-size:14px;color:var(--ink-2);position:relative;padding:6px 0}
.hd__nav a.is-active,.hd__nav a:hover{color:var(--ink)}
.hd__nav a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent)}
.hd__cta{display:flex;gap:10px;align-items:center}
.hd__search{background:transparent;border:1px solid var(--line-2);border-radius:50%;width:36px;height:36px;display:grid;place-items:center;cursor:pointer;color:var(--ink)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:9px 18px;border-radius:999px;font-weight:700;font-size:13px;letter-spacing:.04em;border:1px solid transparent;transition:transform .12s ease, background .15s}
.btn--primary{background:var(--ink);color:#fff}
.btn--primary:hover{transform:translateY(-1px)}

/* ===== Hero ===== */
.hero{padding:32px 24px 0}
.hero__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.7fr 1fr;gap:28px}
.hero__main{position:relative}
.hero__media{position:relative;display:block;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;background:#0b1220}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.2s ease}
.hero__media:hover .hero__bg{transform:scale(1.04)}
.hero__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:32px 36px;color:#fff}
.tag{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;padding:4px 10px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:2px;color:#fff;width:fit-content}
.tag--feature{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}
.hero__title{font-family:var(--serif);font-weight:900;font-size:clamp(28px,3.4vw,48px);line-height:1.25;margin:18px 0 14px;letter-spacing:-.01em}
.hero__lead{font-size:15px;color:#dcd8cc;max-width:640px;line-height:1.75}
.hero__meta{margin-top:18px;font-size:12px;color:#cfcab9;font-family:var(--mono);display:flex;gap:8px;align-items:center}
.meta__sep{opacity:.5}

/* Side list */
.hero__side{display:flex;flex-direction:column}
.hero__side-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:2px solid var(--ink);padding-bottom:10px;margin-bottom:6px}
.hero__side-label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;font-weight:700}
.hero__side-more{font-size:12px;color:var(--mute)}
.hero__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.hero__list li{display:grid;grid-template-columns:46px 1fr;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.hero__list li:last-child{border-bottom:0}
.rank{font-family:var(--serif);font-weight:900;font-size:28px;color:var(--accent);line-height:1;padding-top:2px}
.cat{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--mute);margin-bottom:4px;text-transform:uppercase}
.hd2{display:block;font-family:var(--serif);font-weight:700;font-size:15px;line-height:1.55;color:var(--ink);transition:color .15s}
.hd2:hover{color:var(--accent-2)}
.sub{display:block;margin-top:6px;font-family:var(--mono);font-size:11px;color:var(--mute)}

/* Ticker */
.ticker{max-width:var(--maxw);margin:28px auto 0;display:flex;align-items:center;gap:16px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 0;overflow:hidden;font-family:var(--mono);font-size:12px}
.ticker__label{flex:0 0 auto;background:var(--ink);color:#fff;padding:5px 10px;letter-spacing:.18em;font-weight:700;font-size:10px}
.ticker__track{display:flex;gap:36px;animation:slide 38s linear infinite;white-space:nowrap}
.ticker__track span b{font-weight:700;margin-right:6px;color:var(--ink-2)}
.ticker__track .up{color:var(--rose);margin-left:6px}
.ticker__track .dn{color:var(--green);margin-left:6px}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Section heads ===== */
.sec__head{max-width:920px;margin:0 0 28px}
.sec__head--row{display:flex;justify-content:space-between;align-items:flex-end;max-width:none;gap:24px;flex-wrap:wrap}
.sec__title{font-family:var(--serif);font-weight:900;font-size:32px;letter-spacing:-.01em;display:flex;align-items:baseline;gap:14px}
.sec__num{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:600;letter-spacing:.18em}
.sec__desc{margin-top:10px;color:var(--mute);font-size:14px}

/* ===== Categories ===== */
.cats{padding:80px 24px}
.cats__inner{max-width:var(--maxw);margin:0 auto}
.cats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat-card{position:relative;background:var(--paper);border:1px solid var(--line);padding:28px 24px 24px;border-radius:var(--radius);overflow:hidden;transition:transform .2s ease, box-shadow .2s ease;display:flex;flex-direction:column;gap:14px;min-height:260px}
.cat-card::before{content:"";position:absolute;left:0;top:0;width:4px;height:100%;background:var(--accent)}
.cat-card--a::before{background:var(--catA)}
.cat-card--b::before{background:var(--catB)}
.cat-card--c::before{background:var(--catC)}
.cat-card--d::before{background:var(--catD)}
.cat-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -20px rgba(11,18,32,.18)}
.cat-card__num{font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:var(--mute);font-weight:600}
.cat-card h3{font-family:var(--serif);font-weight:900;font-size:24px;line-height:1.35;color:var(--ink)}
.cat-card p{color:var(--mute);font-size:13px;flex:1}
.cat-card__count{font-family:var(--mono);font-size:11px;color:var(--ink-2);border-top:1px solid var(--line);padding-top:10px}

/* ===== Latest cards ===== */
.latest{padding:40px 24px 80px;background:var(--bg-2)}
.latest__inner{max-width:var(--maxw);margin:0 auto}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font:inherit;font-size:12px;font-weight:600;padding:8px 14px;border-radius:999px;border:1px solid var(--line-2);background:transparent;color:var(--ink-2);cursor:pointer;transition:all .15s}
.chip:hover{border-color:var(--ink-2)}
.chip.is-on{background:var(--ink);color:#fff;border-color:var(--ink)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;grid-auto-rows:1fr}
.card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .18s ease, box-shadow .18s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 36px -20px rgba(11,18,32,.22)}
.card__img{aspect-ratio:16/10;background:#dcd8cc center/cover}
.card__body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.card__body h3{font-family:var(--serif);font-weight:700;font-size:17px;line-height:1.55;color:var(--ink)}
.card__body p{font-size:13px;color:var(--mute);flex:1}
.card__meta{margin-top:auto;padding-top:8px;font-family:var(--mono);font-size:11px;color:var(--mute);display:flex;gap:8px}
.card .tag{background:#0b1220;color:#fff;border-color:#0b1220;width:fit-content}
.card .tag--a{background:var(--catA);border-color:var(--catA)}
.card .tag--b{background:var(--catB);border-color:var(--catB)}
.card .tag--c{background:var(--catC);border-color:var(--catC)}
.card .tag--d{background:var(--catD);border-color:var(--catD)}

/* Featured large card */
.card--lg{grid-column:span 2;flex-direction:row}
.card--lg .card__img{flex:1.2;aspect-ratio:auto;min-height:320px}
.card--lg .card__body{flex:1;padding:32px 32px 30px;justify-content:center}
.card--lg .card__body h3{font-size:24px;line-height:1.45}

/* ===== Series ===== */
.series{padding:80px 24px;background:var(--ink);color:#e6e2d4}
.series__inner{max-width:var(--maxw);margin:0 auto}
.series .sec__title{color:#fff}
.series .sec__num{color:var(--accent)}
.series .sec__desc{color:#a8a394}
.series__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.series__card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:14px;transition:all .2s;min-height:240px}
.series__card:hover{background:rgba(255,255,255,.08);transform:translateY(-3px)}
.series__no{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);font-weight:600}
.series__title{font-family:var(--serif);font-weight:900;font-size:22px;line-height:1.4;color:#fff}
.series__card p{color:#bdb8a8;font-size:13px;flex:1}
.series__cta{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:600;letter-spacing:.05em}
.series__card--alt{background:linear-gradient(135deg,rgba(30,107,74,.18),rgba(31,59,115,.18));border-color:rgba(30,107,74,.3)}

/* ===== Newsletter ===== */
.news{padding:80px 24px;background:var(--bg)}
.news__inner{max-width:var(--maxw);margin:0 auto;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:48px 56px;display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center}
.news__kicker{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);font-weight:700}
.news__copy h2{font-family:var(--serif);font-weight:900;font-size:28px;line-height:1.45;margin:12px 0 12px}
.news__copy p{color:var(--mute);font-size:14px}
.news__form{display:flex;gap:8px}
.news__form input{flex:1;border:1px solid var(--line-2);background:transparent;padding:14px 16px;border-radius:999px;font:inherit;font-size:14px;outline:none;transition:border-color .15s}
.news__form input:focus{border-color:var(--ink)}

/* ===== Footer ===== */
.ft{background:var(--ink);color:#a8a394;padding:64px 24px 24px}
.ft__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:48px}
.ft__brand .hd__name{color:#fff}
.ft__brand .hd__sub{color:#8a8675}
.ft__brand p{margin-top:14px;font-size:13px;max-width:280px}
.ft__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.ft__cols h4{color:#fff;font-size:13px;font-weight:700;margin-bottom:14px;letter-spacing:.05em}
.ft__cols a{display:block;font-size:13px;color:#a8a394;padding:5px 0;transition:color .15s}
.ft__cols a:hover{color:#fff}
.ft__bot{max-width:var(--maxw);margin:48px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:#6e6a5d;font-family:var(--mono)}

/* ===== Responsive ===== */
@media (max-width:980px){
  .hero__grid{grid-template-columns:1fr}
  .cats__grid{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:repeat(2,1fr)}
  .card--lg{grid-column:span 2;flex-direction:column}
  .card--lg .card__img{min-height:260px}
  .series__grid{grid-template-columns:1fr}
  .news__inner{grid-template-columns:1fr;padding:36px 28px}
  .ft__inner{grid-template-columns:1fr}
  .hd__nav{display:none}
}
@media (max-width:640px){
  .util__nav a{margin-left:10px;font-size:11px}
  .cats__grid,.cards,.ft__cols{grid-template-columns:1fr}
  .hero__overlay{padding:22px}
  .sec__title{font-size:24px}
}
/* ===== Conversion-first additions ===== */

/* Big CTA buttons */
.cta{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;background:var(--ink);color:#fff;padding:18px 32px;border-radius:8px;font-weight:700;letter-spacing:.02em;border:2px solid var(--ink);transition:all .15s ease;box-shadow:0 6px 0 rgba(0,0,0,.15);text-decoration:none;line-height:1.3}
.cta:hover{transform:translateY(-2px);box-shadow:0 8px 0 rgba(0,0,0,.18)}
.cta:active{transform:translateY(2px);box-shadow:0 2px 0 rgba(0,0,0,.15)}
.cta__main{font-size:16px;font-weight:800}
.cta__sub{font-size:11px;font-weight:500;opacity:.85;margin-top:4px;font-family:var(--mono);letter-spacing:.04em}
.cta--xl{padding:20px 36px;font-size:17px}
.cta--xl .cta__main{font-size:18px}
.cta--gold{background:linear-gradient(180deg,#2f8a60,#1e8a5a);color:#ffffff;border-color:#14532d;box-shadow:0 6px 0 #0f3d2c, 0 8px 24px rgba(30,107,74,.35)}
.cta--gold:hover{box-shadow:0 8px 0 #0f3d2c, 0 12px 28px rgba(30,107,74,.4)}
.cta--gold:active{box-shadow:0 2px 0 #0f3d2c}
.cta--ghost{background:transparent;color:var(--ink);border:2px solid var(--ink);box-shadow:none;flex-direction:row;gap:6px;padding:18px 28px}
.cta--ghost:hover{background:var(--ink);color:#fff;box-shadow:none}
.cta--block{display:flex;width:100%;margin-top:12px}
.cta--sm{padding:12px 20px;font-size:14px;box-shadow:0 4px 0 rgba(0,0,0,.15)}
.cta--sm .cta__main{font-size:14px}

/* ===== Hero ===== */
.chero{position:relative;padding:48px 24px 64px;overflow:hidden;background:linear-gradient(135deg,#0b1220 0%,#162542 50%,#1f3b73 100%);color:#fff}
.chero__bg{position:absolute;inset:0;background:
  radial-gradient(circle at 20% 20%,rgba(30,107,74,.18),transparent 40%),
  radial-gradient(circle at 80% 80%,rgba(31,59,115,.4),transparent 50%);
  pointer-events:none}
.chero__inner{position:relative;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
.chero__kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:8px 14px;border-radius:999px;font-family:var(--mono);font-size:12px;letter-spacing:.04em}
.chero__pulse{width:8px;height:8px;background:#5af3a4;border-radius:50%;box-shadow:0 0 0 0 rgba(90,243,164,.7);animation:pulse2 1.6s infinite}
@keyframes pulse2{70%{box-shadow:0 0 0 10px rgba(90,243,164,0)}}
.chero__title{font-family:var(--serif);font-weight:900;font-size:clamp(34px,4.6vw,56px);line-height:1.18;letter-spacing:-.02em;margin:18px 0 18px;color:#fff}
.chero__hl{background:linear-gradient(180deg,transparent 60%,rgba(255,206,77,.5) 60%);padding:0 4px}
.chero__lead{font-size:15px;color:#cfd6e2;line-height:1.85;max-width:560px;margin-bottom:28px}
.chero__cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.chero__cta .cta--ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.chero__cta .cta--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.chero__bullet{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-wrap:wrap;gap:18px;font-size:13px;color:#bdc8da;font-family:var(--mono)}

/* Hero ranking card */
.chero__rank{background:#fff;color:var(--ink);border-radius:14px;box-shadow:0 24px 60px -10px rgba(0,0,0,.4);overflow:hidden;border:1px solid rgba(255,255,255,.5)}
.cr__head{display:flex;align-items:center;gap:14px;padding:18px 22px;background:linear-gradient(135deg,#fff8e1,#fde8a0);border-bottom:1px solid #ecd97c}
.cr__crown{font-size:28px}
.cr__label{display:block;font-family:var(--serif);font-weight:900;font-size:16px;color:var(--ink);line-height:1.2}
.cr__sub{display:block;font-size:11px;color:#8a6c1f;font-family:var(--mono);margin-top:2px}
.cr__list{list-style:none;padding:0;margin:0}
.cr__list li{display:grid;grid-template-columns:36px 1fr auto;gap:14px;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line)}
.cr__list li:last-child{border-bottom:0}
.cr__no{font-family:var(--serif);font-weight:900;font-size:24px;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--mute)}
.cr__no--1{background:linear-gradient(135deg,#2f8a60,#185a3e);color:#ffffff;box-shadow:0 4px 14px rgba(30,107,74,.35)}
.cr__no--2{background:linear-gradient(135deg,#d6dae2,#9aa3b1);color:#2a3344}
.cr__no--3{background:linear-gradient(135deg,#d8a679,#9c6b3a);color:#fff}
.cr__brand{display:block;font-family:var(--serif);font-weight:700;font-size:14px;color:var(--ink)}
.cr__score{display:block;font-size:11px;color:var(--mute);margin-top:2px;font-family:var(--mono)}
.cr__score b{color:var(--rose);font-size:14px;font-weight:800;margin:0 2px}
.cr__bar{display:block;height:4px;background:var(--bg-2);border-radius:2px;margin:6px 0;overflow:hidden}
.cr__bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent))}
.cr__pt{display:block;font-size:11px;color:var(--ink-2);font-family:var(--mono)}
.cr__btn{background:var(--ink);color:#fff;font-size:12px;font-weight:700;padding:8px 12px;border-radius:6px;white-space:nowrap;transition:transform .12s, background .15s}
.cr__btn:hover{transform:translateX(2px);background:var(--accent)}

/* ===== Trust strip ===== */
.trust{padding:28px 24px;background:#fff;border-bottom:1px solid var(--line)}
.trust__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:24px;text-align:center}
.trust__item{display:flex;flex-direction:column;gap:4px;border-right:1px solid var(--line);padding:0 12px}
.trust__item:last-child{border-right:0}
.trust__item b{font-family:var(--serif);font-size:32px;font-weight:900;color:var(--ink);line-height:1}
.trust__item b em{font-style:normal;font-size:14px;color:var(--mute);margin-left:2px;font-family:var(--sans);font-weight:600}
.trust__item span{font-size:12px;color:var(--mute);font-family:var(--mono);letter-spacing:.04em}

/* ===== Ranking ===== */
.ranking{padding:80px 24px;background:var(--bg)}
.ranking__inner{max-width:var(--maxw);margin:0 auto}
.sec__title--big{font-size:clamp(30px,3.6vw,44px);line-height:1.25;letter-spacing:-.02em}
.ranking .sec__head{margin-bottom:40px}
.ranking .sec__num{display:block;margin-bottom:8px}

.rtbl{display:flex;flex-direction:column;gap:20px}
.rrow{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 28px 28px 92px;display:grid;grid-template-columns:1fr 280px;gap:28px;align-items:center;transition:all .2s ease;overflow:hidden}
.rrow:hover{border-color:var(--accent);box-shadow:0 16px 40px -16px rgba(11,18,32,.18);transform:translateY(-2px)}
.rrow--1{border-color:var(--accent);box-shadow:0 12px 32px -12px rgba(30,107,74,.25)}
.rrow--1::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,#2f8a60,#185a3e)}
.rrow--2{border-color:#cdd2db}
.rrow--3{border-color:#d8c0a4}

.rrow__rank{position:absolute;left:20px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:6px}
.rrow__no{font-family:var(--serif);font-weight:900;font-size:42px;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:var(--bg-2);color:var(--ink)}
.rrow--1 .rrow__no{background:linear-gradient(135deg,#2f8a60,#185a3e);color:#ffffff;box-shadow:0 6px 18px rgba(30,107,74,.4)}
.rrow--2 .rrow__no{background:linear-gradient(135deg,#e2e6ed,#9aa3b1);color:#2a3344}
.rrow--3 .rrow__no{background:linear-gradient(135deg,#e6c4a1,#9c6b3a);color:#fff}
.rrow__crown{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--accent);background:rgba(30,107,74,.15);padding:2px 6px;border-radius:3px}

.rrow__main{min-width:0}
.rrow__brand{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
/* 旧 rrow__logo は logo--lg / logo--r1 に置換。互換のため残す */
.rrow__logo{width:56px;height:56px;border-radius:10px;background:linear-gradient(135deg,var(--ink),var(--accent-2));color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:900;font-size:20px;letter-spacing:.02em}
.rrow--1 .rrow__logo{background:linear-gradient(135deg,#2f8a60,#185a3e);color:#ffffff}

/* ======= 法人 / 個人事業主 対応バッジ ======= */
.entity-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.entity-badges--sm{gap:4px}
.entity-badges--md{margin-bottom:8px;gap:8px}
.entity-badges--lg{margin-bottom:12px;gap:10px}
.entity-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--sans);font-weight:700;letter-spacing:.02em;
  border-radius:4px;border:1px solid transparent;
  white-space:nowrap;line-height:1;
}
.entity-badges--sm .entity-badge{font-size:10px;padding:4px 7px}
.entity-badges--md .entity-badge{font-size:12px;padding:6px 10px}
.entity-badges--lg .entity-badge{font-size:13px;padding:8px 12px}

.entity-badge.is-ok{
  background:rgba(30,107,74,.08);
  color:var(--green);
  border-color:rgba(30,107,74,.25);
}
.entity-badge.is-ng{
  background:#f4f1ea;
  color:var(--mute);
  border-color:var(--line);
  opacity:.7;
}
.entity-badge.is-ng::after{content:""}

/* 比較表内：横並びチップとして整列（折返しOK・読みやすさ優先） */
.ctbl .entity-badges{justify-content:center;flex-wrap:wrap;gap:5px;max-width:230px;margin:0 auto}
.ctbl .entity-badge{padding:4px 8px;font-size:10.5px;justify-content:center}

/* rrow (ホームランキング) は本文と並ぶので少し余白 */
.rrow__main .entity-badges{margin:8px 0 4px}

/* ======= 統一ロゴ部品 (テキスト / 画像 兼用) ======= */
.logo{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0;overflow:hidden;background:var(--paper);position:relative}
.logo--sm{width:40px;height:40px}
.logo--md{width:52px;height:52px}
.logo--lg{width:64px;height:64px;border-radius:10px}

/* 画像ロゴ（実ロゴが入った場合） */
.logo--img{background:#fff;border:1px solid var(--line-2);padding:4px}
.logo--img img{width:100%;height:100%;object-fit:contain;display:block}

/* テキストモノグラム（デフォルト） */
.logo--txt{
  background:linear-gradient(145deg,#1a2438 0%,#0b1220 60%,#172238 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 2px 8px -2px rgba(11,18,32,.4);
}
.logo--txt::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.12) 0%,transparent 55%);
  pointer-events:none;
}
.logo--txt::after{
  content:"";position:absolute;right:-6px;bottom:-6px;width:18px;height:18px;
  background:radial-gradient(circle,rgba(30,107,74,.25) 0%,transparent 70%);
  pointer-events:none;
}
.logo--txt > span{
  position:relative;z-index:1;
  font-family:var(--serif);font-weight:700;letter-spacing:-.02em;
  white-space:nowrap;line-height:1;
}
.logo--sm.logo--txt > span{font-size:13px}
.logo--md.logo--txt > span{font-size:17px}
.logo--lg.logo--txt > span{font-size:22px}

/* 文字数で字詰めを自動調整（多文字なら詰める） */
.logo--txt > span{max-width:90%;text-align:center}
.logo--lg.logo--txt > span:where([style*=narrow]),
.logo--md.logo--txt > span:where([style*=narrow]){letter-spacing:-.04em}

/* ランクごとの色味 — 1位は金、2位はシルバー、3位はブロンズ */
.logo--r1.logo--txt{
  background:linear-gradient(145deg,#3fa06e 0%,#1e6b4a 50%,#14532d 100%);
  color:#1a1408;
  border-color:rgba(0,0,0,.15);
}
.logo--r1.logo--txt::before{background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.45) 0%,transparent 55%)}
.logo--r1.logo--txt::after{background:radial-gradient(circle,rgba(255,255,255,.4) 0%,transparent 70%)}

.logo--r2.logo--txt{
  background:linear-gradient(145deg,#e5e7eb 0%,#9ca3af 50%,#64748b 100%);
  color:#0b1220;
  border-color:rgba(0,0,0,.1);
}
.logo--r2.logo--txt::before{background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.6) 0%,transparent 55%)}

.logo--r3.logo--txt{
  background:linear-gradient(145deg,#c89671 0%,#a36c3e 50%,#704728 100%);
  color:#1a0e05;
  border-color:rgba(0,0,0,.15);
}
.logo--r3.logo--txt::before{background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.4) 0%,transparent 55%)}

/* 比較表セル内 (sm) のための背景白枠 */
.ctbl__brand .logo--img{background:#fff}
.rrow__brand h3{font-family:var(--serif);font-weight:900;font-size:22px;line-height:1.3;color:var(--ink);margin:0}
.stars{font-size:14px;color:#f4b400;letter-spacing:.05em;margin-top:4px}
.stars em{font-style:normal;color:var(--ink);font-weight:800;margin-left:6px;font-family:var(--mono)}
.badge{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;padding:4px 8px;border-radius:4px;margin-left:auto}
.badge--gold{background:linear-gradient(135deg,#2f8a60,#185a3e);color:#ffffff}
.badge--silver{background:linear-gradient(135deg,#e2e6ed,#9aa3b1);color:#2a3344}
.badge--bronze{background:linear-gradient(135deg,#e6c4a1,#9c6b3a);color:#fff}

.rrow__pros{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:8px 20px;font-size:13px;color:var(--ink-2);line-height:1.5}
.rrow__pros li{position:relative;padding-left:18px}
.rrow__pros li::before{content:"●";position:absolute;left:0;color:var(--accent);font-size:8px;top:5px}
.rrow__pros b{color:var(--mute);font-weight:600;font-family:var(--mono);font-size:11px;margin-right:6px;letter-spacing:.04em;display:inline-block;min-width:60px}

.rrow__cta{display:flex;flex-direction:column;gap:10px;align-items:stretch}
.rrow__cta .cta{display:flex;width:100%}
.rrow__detail{font-size:12px;color:var(--mute);text-align:center;text-decoration:underline;text-underline-offset:3px}
.rrow__detail:hover{color:var(--ink)}

.ranking__more{display:block;text-align:center;margin-top:32px;padding:18px;background:#fff;border:1px dashed var(--line-2);border-radius:8px;font-weight:700;color:var(--ink-2);transition:all .15s}
.ranking__more:hover{background:var(--ink);color:#fff;border-color:var(--ink);border-style:solid}
.ranking__more-row{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:stretch;margin-top:32px}
.ranking__more-row .ranking__more{margin-top:0}
.ranking__more--sub{background:transparent;border-style:solid;border-color:var(--line);font-size:13px;padding:18px 28px;font-weight:600;color:var(--mute)}
.ranking__more--sub:hover{background:transparent;color:var(--ink);border-color:var(--ink)}
@media (max-width:640px){
  .ranking__more-row{grid-template-columns:1fr}
  .ranking__more--sub{font-size:12px;padding:14px 20px}
}

/* ===== Diagnose ===== */
.diag{padding:80px 24px;background:linear-gradient(135deg,#0b1220 0%,#162542 100%);color:#fff}
.diag__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center}
.diag__kicker{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);font-weight:700}
.diag__copy h2{font-family:var(--serif);font-weight:900;font-size:clamp(28px,3vw,40px);line-height:1.4;margin:14px 0 18px;color:#fff}
.diag__copy p{color:#bdc8da;font-size:14px;line-height:1.85}
.diag__form{background:#fff;color:var(--ink);border-radius:14px;padding:32px;box-shadow:0 24px 60px -10px rgba(0,0,0,.4)}
.diag__step{margin-bottom:22px}
.diag__num{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.12em;background:rgba(30,107,74,.12);padding:3px 8px;border-radius:3px;margin-right:10px}
.diag__q{font-family:var(--serif);font-weight:700;font-size:16px;color:var(--ink)}
.diag__opts{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.diag__opts button{font:inherit;font-size:13px;font-weight:600;padding:10px 16px;border-radius:8px;border:2px solid var(--line-2);background:#fff;color:var(--ink-2);cursor:pointer;transition:all .15s}
.diag__opts button:hover{border-color:var(--ink-2)}
.diag__opts button.is-on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ===== Purpose ===== */
.purpose{padding:80px 24px;background:var(--bg-2)}
.purpose__inner{max-width:var(--maxw);margin:0 auto}
.purpose__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.purpose__more{display:block;text-align:center;margin-top:32px;padding:18px;background:#fff;border:1px dashed var(--line-2);border-radius:8px;font-weight:700;color:var(--ink-2);transition:all .15s;text-decoration:none}
.purpose__more:hover{background:var(--ink);color:#fff;border-color:var(--ink);border-style:solid}
.puc{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:8px;transition:all .18s}
.puc:hover{transform:translateY(-3px);box-shadow:0 16px 36px -16px rgba(11,18,32,.22);border-color:var(--accent)}
.puc__ic{font-size:32px;line-height:1}
.puc h3{font-family:var(--serif);font-weight:800;font-size:18px;color:var(--ink);line-height:1.45;margin-top:8px}
.puc p{font-size:13px;color:var(--mute)}
.puc__cta{margin-top:auto;padding-top:12px;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--accent-2);letter-spacing:.04em}
.puc--alt{background:linear-gradient(135deg,#fff8e1,#fff)}

/* ===== FAQ ===== */
.faq{padding:80px 24px;background:#fff}
.faq__inner{max-width:880px;margin:0 auto}
.faq__list{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.faq details{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:0;overflow:hidden;transition:all .15s}
.faq details[open]{border-color:var(--accent)}
.faq summary{cursor:pointer;font-family:var(--serif);font-weight:700;font-size:16px;color:var(--ink);padding:20px 28px;list-style:none;position:relative;padding-right:50px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:24px;font-weight:300;color:var(--accent);transition:transform .2s}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{padding:0 28px 22px;font-size:14px;color:var(--ink-2);line-height:1.85;margin:0}

/* ===== Bottom CTA ===== */
.botcta{padding:80px 24px;background:linear-gradient(135deg,#14532d 0%,#1e8a5a 50%,#2f8a60 100%);text-align:center}
.botcta__inner{max-width:760px;margin:0 auto}
.botcta h2{font-family:var(--serif);font-weight:900;font-size:clamp(26px,3.4vw,38px);color:#ffffff;line-height:1.4;margin-bottom:14px}
.botcta p{font-size:16px;color:rgba(255,255,255,.9);margin-bottom:32px}
.botcta .cta--gold{background:#0b1220;color:#fff;border-color:#0b1220;box-shadow:0 8px 0 rgba(0,0,0,.3)}
.botcta .cta--gold:hover{background:#162542;box-shadow:0 10px 0 rgba(0,0,0,.3)}

/* ===== Sticky bottom bar ===== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:80;background:rgba(11,18,32,.96);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.1);padding:12px 24px;transform:translateY(100%);transition:transform .35s ease}
.sticky-cta.is-show{transform:translateY(0)}
.sticky-cta__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:18px;justify-content:space-between}
.sticky-cta__copy{color:#fff;display:flex;flex-direction:column;line-height:1.3;min-width:0}
.sticky-cta__copy b{font-family:var(--serif);font-weight:800;font-size:15px}
.sticky-cta__copy span{font-size:12px;color:#bdc8da}

@media (max-width:980px){
  .chero__inner{grid-template-columns:1fr}
  .trust__inner{grid-template-columns:repeat(3,1fr)}
  .trust__item:nth-child(4),.trust__item:nth-child(5){border-right:0}
  .rrow{grid-template-columns:1fr;padding:80px 20px 24px;gap:18px}
  .rrow__rank{position:static;flex-direction:row;justify-content:flex-start;transform:none;margin-bottom:8px}
  .rrow__no{width:48px;height:48px;font-size:28px}
  .rrow__pros{grid-template-columns:1fr}
  .diag__inner{grid-template-columns:1fr}
  .purpose__grid{grid-template-columns:1fr}
  .sticky-cta__copy span{display:none}
  .ranking{padding:60px 16px}
}
@media (max-width:640px){
  .trust__inner{grid-template-columns:repeat(2,1fr)}
  .trust__item:nth-child(3){border-right:0}
  .trust__item:nth-child(5){display:none}
  .chero__bullet{flex-direction:column;gap:8px}
  .cta--xl{padding:16px 24px}
  .rrow__brand h3{font-size:18px}
  .badge{margin-left:0;margin-top:6px}
  .diag__form{padding:22px}
}

/* ===== Archive / Category page ===== */
.cathero{background:var(--bg-2);border-bottom:1px solid var(--line);padding:64px 32px 56px;position:relative;overflow:hidden}
.cathero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 30%,rgba(30,107,74,.06) 0%,transparent 50%);pointer-events:none}
.cathero__inner{max-width:var(--maxw);margin:0 auto;position:relative}
.crumb{font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.08em;display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:36px;text-transform:uppercase}
.crumb a{color:var(--mute);text-decoration:none;transition:color .15s}
.crumb a:hover{color:var(--ink)}
.crumb b{color:var(--ink);font-weight:600}
.cathero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:48px;flex-wrap:wrap}
.cathero .tag{margin-bottom:18px;font-size:11px;padding:6px 14px;letter-spacing:.14em}
.cathero__title{font-family:var(--serif);font-size:56px;font-weight:700;line-height:1.15;color:var(--ink);letter-spacing:-.02em;margin:0}
.cathero__lead{margin-top:20px;font-size:16px;line-height:1.9;color:var(--ink-2);max-width:760px}
.cathero__lead p{margin:0}
.cathero__meta{margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--mute);text-transform:uppercase;padding-top:18px;border-top:1px solid var(--line)}
.cathero__meta strong{color:var(--ink);font-weight:700;font-size:13px}

.catlist{padding:72px 32px 120px;background:var(--bg)}
.catlist__inner{max-width:var(--maxw);margin:0 auto}
.catlist__empty{font-size:15px;color:var(--mute);text-align:center;padding:60px 0}

/* cards grid: 3 列、ゆとりあるギャップ */
.catlist .cards{gap:40px 32px;grid-auto-rows:auto;align-items:start}
/* 特集（1ページ目の先頭）は2列ぶち抜き＋横長 */
.catlist .card{border-radius:6px;border-color:var(--line-2);box-shadow:0 1px 2px rgba(11,18,32,.04);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;align-self:start}
.catlist .card:hover{transform:translateY(-4px);box-shadow:0 22px 50px -22px rgba(11,18,32,.28);border-color:var(--ink-2)}
/* 旧記事のサムネは 1024×569 (≒16/9)、テキスト埋め込み画像なので cover で切れにくい比率に */
.catlist .card__img{aspect-ratio:16/9;background-color:#0b1220;background-size:cover;background-position:center center}
.catlist .card__body{padding:24px 24px 22px;gap:12px}
.catlist .card__body h3{font-size:17px;line-height:1.55;letter-spacing:-.005em}
.card__excerpt{font-size:13px;line-height:1.75;color:var(--mute);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:2px}
.card__meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.card__meta time{font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.06em}
.card__more{font-family:var(--mono);font-size:11px;color:var(--ink);letter-spacing:.06em;font-weight:600;opacity:.6;transition:opacity .2s}
.catlist .card:hover .card__more{opacity:1}

/* 特集カード (1ページ目の先頭・2 col 幅) */
.catlist .card--lg{grid-column:span 2;flex-direction:row;border-color:var(--ink)}
/* 画像は元アスペクト 16/9 を維持。flex を画像 1 / 本文 1 にして横並び。 */
.catlist .card--lg .card__img{flex:1;aspect-ratio:16/9;align-self:stretch}
.catlist .card--lg .card__body{flex:1;padding:36px 40px;justify-content:center;gap:16px}
.catlist .card--lg .card__body h3{font-size:26px;line-height:1.45;letter-spacing:-.015em}
.catlist .card--lg .card__excerpt{font-size:14px;line-height:1.85;-webkit-line-clamp:3;line-clamp:3}

/* プレースホルダ画像 */
.card__img--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-2) 0%,#ded8c8 100%);color:rgba(11,18,32,.18);position:relative}
.card__img--placeholder::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent 0,transparent 12px,rgba(255,255,255,.04) 12px,rgba(255,255,255,.04) 13px);pointer-events:none}
.card__img--placeholder.tag--a{background:linear-gradient(135deg,var(--catA) 0%,#142a52 100%);color:rgba(255,255,255,.28)}
.card__img--placeholder.tag--b{background:linear-gradient(135deg,var(--catB) 0%,#7d1f27 100%);color:rgba(255,255,255,.28)}
.card__img--placeholder.tag--c{background:linear-gradient(135deg,var(--catC) 0%,#0f4a31 100%);color:rgba(255,255,255,.28)}
.card__img--placeholder.tag--d{background:linear-gradient(135deg,var(--catD) 0%,#4a321d 100%);color:rgba(255,255,255,.32)}
.card__img--placeholder span{font-family:var(--serif);font-size:104px;font-weight:700;line-height:1;letter-spacing:-.02em;user-select:none;position:relative;z-index:1}

/* Pagination */
.pager{margin-top:72px;display:flex;justify-content:center}
.pager .nav-links{display:inline-flex;gap:6px;flex-wrap:wrap;align-items:center}
.pager .page-numbers{min-width:44px;height:44px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:var(--paper);color:var(--ink);font-family:var(--mono);font-size:13px;font-weight:500;border-radius:6px;text-decoration:none;transition:all .15s}
.pager .page-numbers:hover{border-color:var(--ink);background:var(--ink);color:#fff;transform:translateY(-1px)}
.pager .page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink);font-weight:700}
.pager .page-numbers.dots{border:none;background:transparent;color:var(--mute)}
.pager .page-numbers.dots:hover{background:transparent;color:var(--mute);transform:none}
.pager .screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

@media (max-width:1100px){
  .cathero{padding:52px 28px 44px}
  .cathero__title{font-size:44px}
  .catlist{padding:56px 28px 96px}
  .catlist .cards{gap:28px 24px}
}
@media (max-width:980px){
  .catlist .cards{grid-template-columns:repeat(2,1fr)}
  .catlist .card--lg{grid-column:span 2;flex-direction:column}
  .catlist .card--lg .card__img{min-height:280px}
  .catlist .card--lg .card__body{padding:28px 28px 28px}
  .catlist .card--lg .card__body h3{font-size:22px}
  .cathero{padding:44px 24px 36px}
  .cathero__title{font-size:34px}
  .catlist{padding:48px 24px 80px}
}
@media (max-width:640px){
  .catlist .cards{grid-template-columns:1fr;gap:20px}
  .catlist .card--lg{grid-column:span 1}
  .cathero{padding:36px 20px 28px}
  .cathero__title{font-size:26px;line-height:1.25}
  .cathero__lead{font-size:14px;margin-top:14px}
  .crumb{margin-bottom:24px}
  .card__img--placeholder span{font-size:80px}
  .catlist .card__body{padding:18px 20px 20px}
  .catlist .card__body h3{font-size:16px}
}

/* =========================================================
   /ranking/ — 詳細スペック比較ページ
   ========================================================= */
.rankpage{background:var(--bg);padding:56px 32px 96px}
.rankpage__inner{max-width:var(--maxw);margin:0 auto}
.rankpage__h2{font-family:var(--serif);font-size:28px;color:var(--ink);font-weight:700;margin:60px 0 28px;padding-bottom:14px;border-bottom:2px solid var(--ink)}

.ctbl-wrap{overflow-x:auto;background:var(--paper);border:1px solid var(--line);border-radius:6px;box-shadow:0 1px 2px rgba(11,18,32,.04)}
.ctbl{width:100%;border-collapse:collapse;font-size:13px;min-width:840px}
.ctbl thead th{background:linear-gradient(180deg,#2f8a60,#1e6b4a);color:#fff;font-weight:700;padding:15px 12px;text-align:center;font-size:12.5px;letter-spacing:.04em;border-bottom:2px solid #185a3e}
.ctbl tbody td{padding:18px 12px;text-align:center;border-bottom:1px solid var(--line);color:var(--ink);vertical-align:middle}
.ctbl tbody tr:nth-child(even){background:#faf9f4}
.ctbl tbody tr:hover{background:rgba(30,107,74,.06)}
.ctbl tbody tr:last-child td{border-bottom:none}
.ctbl__svc{width:248px}
.ctbl__rank{width:64px;text-align:center}
.ctbl__rank b{font-family:var(--serif);font-size:20px;color:var(--ink)}
.ctbl__badge{display:block;font-size:10px;font-weight:600;margin-top:4px}
.ctbl__brand{text-align:left;min-width:180px}
.ctbl__brand a{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;transition:color .15s}
.ctbl__brand a:hover{color:var(--accent-2)}
.ctbl__logo{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--ink);color:#fff;font-family:var(--mono);font-size:11px;font-weight:700;border-radius:4px;flex-shrink:0;letter-spacing:.02em}
.ctbl__name{font-size:13px;font-weight:600;line-height:1.4;color:var(--ink)}
.ctbl__rating{font-size:13px;color:var(--accent);font-weight:600}
.ctbl__cta{width:88px}
.ctbl__cta .cta{padding:8px 14px !important;font-size:12px;width:100%;display:flex;justify-content:center}

/* Detail cards */
.rankpage__cards{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.rcard{background:var(--paper);border:1px solid var(--line-2);border-radius:8px;padding:28px 28px 24px;display:flex;flex-direction:column;gap:18px;scroll-margin-top:80px;transition:border-color .2s,box-shadow .2s}
.rcard:target{border-color:var(--accent);box-shadow:0 0 0 4px rgba(30,107,74,.18)}
.rcard__hd{display:flex;align-items:flex-start;gap:16px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.rcard__rank{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:48px;flex-shrink:0}
.rcard__no{font-family:var(--serif);font-size:36px;font-weight:700;line-height:1;color:var(--ink)}
.rcard__brand{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.rcard__brand .rrow__logo{width:48px;height:48px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:13px;font-weight:700;border-radius:4px;flex-shrink:0}
.rcard__brand h3{font-family:var(--serif);font-size:18px;line-height:1.45;color:var(--ink);margin:0 0 4px;font-weight:700}
.rcard__brand .stars{font-size:13px;color:var(--accent)}
.rcard__brand .stars em{font-style:normal;color:var(--ink);font-weight:700;margin-left:6px;font-family:var(--mono)}

.rcard__specs{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:0;background:var(--bg-2);border-radius:4px;overflow:hidden}
.rcard__specs li{display:flex;flex-direction:column;gap:2px;padding:12px 16px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);font-size:14px;color:var(--ink);font-weight:600}
.rcard__specs li:nth-child(2n){border-right:none}
.rcard__specs li:nth-last-child(-n+2){border-bottom:none}
.rcard__specs li b{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--mute);font-weight:600;text-transform:uppercase}

.rcard__pros{list-style:none;padding:0;margin:0}
.rcard__pros li{padding:8px 0;border-bottom:1px dashed var(--line);font-size:13px;line-height:1.7;color:var(--ink-2);position:relative;padding-left:22px}
.rcard__pros li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}
.rcard__pros li:last-child{border-bottom:none}

.rcard__cta{display:flex;flex-direction:column;gap:10px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.rcard__detail{font-size:12px;color:var(--mute);text-align:center;font-family:var(--mono);letter-spacing:.04em;text-decoration:underline;text-underline-offset:3px}
.rcard__detail:hover{color:var(--ink)}

@media (max-width:980px){
  .rankpage{padding:40px 24px 72px}
  .rankpage__cards{grid-template-columns:1fr;gap:20px}
  .rcard{padding:22px}
}
@media (max-width:640px){
  .rankpage{padding:32px 20px 56px}
  .rankpage__h2{font-size:22px;margin:40px 0 20px}
  .ctbl{font-size:12px}
  .ctbl thead th,.ctbl tbody td{padding:10px 8px}
  .rcard__no{font-size:28px}
  .rcard__brand h3{font-size:16px}
}

/* =========================================================
   /simulator/ — 手数料シミュレーター
   ========================================================= */
.sim{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);padding:64px 32px 96px;position:relative;overflow:hidden}
.sim::before{content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(30,107,74,.08) 0%,transparent 60%);pointer-events:none}
.sim__inner{max-width:1100px;margin:0 auto;position:relative;z-index:1}
.sim__head{margin-bottom:40px;text-align:center}
.sim__kicker{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--accent);font-weight:600;margin-bottom:16px;text-transform:uppercase}
.sim__kicker::before,.sim__kicker::after{content:"";width:24px;height:1px;background:var(--accent)}
.sim__head h2{font-family:var(--serif);font-size:40px;line-height:1.25;color:var(--ink);font-weight:700;margin:0 0 14px;letter-spacing:-.01em}
.sim__head h2 em{font-style:normal;color:var(--accent);background:linear-gradient(180deg,transparent 60%,rgba(30,107,74,.18) 60%);padding:0 4px}
.sim__head p{font-size:15px;line-height:1.85;color:var(--ink-2);margin:0 auto;max-width:640px}
.sim__head p strong{color:var(--ink);font-weight:700}
.sim__badges{list-style:none;padding:0;margin:20px 0 0;display:inline-flex;flex-wrap:wrap;gap:10px;justify-content:center}
.sim__badges li{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--paper);border:1px solid var(--line-2);border-radius:999px;font-size:12px;font-weight:600;color:var(--ink-2);font-family:var(--mono);letter-spacing:.04em}
.sim__badges li::before{content:"✓";color:var(--accent);font-weight:700}

.sim__grid{display:grid;grid-template-columns:minmax(380px,440px) 1fr;gap:28px;align-items:stretch}
.sim__form{background:var(--paper);border:1px solid var(--line-2);border-radius:14px;padding:32px;display:flex;flex-direction:column;gap:18px;box-shadow:0 8px 24px -12px rgba(11,18,32,.12),0 2px 6px -2px rgba(11,18,32,.04);position:relative}
.sim__form::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,#4caf80 50%,var(--accent) 100%);border-radius:14px 14px 0 0}

.sim__hero{padding:18px 20px 16px;background:linear-gradient(135deg,#0b1220 0%,#172238 100%);border-radius:10px;color:#fff;position:relative;overflow:hidden}
.sim__hero::after{content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;background:radial-gradient(circle,rgba(30,107,74,.22) 0%,transparent 65%);pointer-events:none}
.sim__hero-label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--accent);font-weight:600;margin-bottom:8px;position:relative;z-index:1}
.sim__hero-input{display:flex;align-items:baseline;gap:8px;position:relative;z-index:1}
.sim__hero-input input{flex:1;background:transparent;border:none;border-bottom:2px solid rgba(30,107,74,.45);padding:4px 0;font-family:var(--serif);font-size:32px;font-weight:700;color:#fff;letter-spacing:-.01em;width:100%;min-width:0;font-feature-settings:"tnum"}
.sim__hero-input input:focus{outline:none;border-bottom-color:var(--accent)}
.sim__hero-input input::-webkit-outer-spin-button,.sim__hero-input input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.sim__hero-suffix{font-family:var(--serif);font-size:18px;color:var(--accent);font-weight:600}
.sim__hero-hint{display:block;font-size:11px;color:rgba(255,255,255,.55);margin-top:6px;position:relative;z-index:1}

.sim__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sim__field{display:flex;flex-direction:column;gap:6px;min-width:0}
.sim__field > span{font-size:11px;letter-spacing:.06em;color:var(--ink);font-weight:700;font-family:var(--mono)}
.sim__field input, .sim__field select{appearance:none;-webkit-appearance:none;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:11px 14px;font-size:14px;color:var(--ink);font-family:var(--sans);transition:all .15s;width:100%;cursor:pointer}
.sim__field select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%230b1220' d='M6 8L0 0h12z'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.sim__field input:focus, .sim__field select:focus,
.sim__field input:hover, .sim__field select:hover{outline:none;border-color:var(--ink)}
.sim__field input:focus, .sim__field select:focus{box-shadow:0 0 0 3px rgba(11,18,32,.08)}

.sim__btn{margin-top:6px;background:linear-gradient(135deg,var(--accent) 0%,#1e8a5a 100%);color:var(--ink);border:none;border-radius:10px;padding:18px 24px;font-size:16px;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 4px 14px -4px rgba(30,107,74,.45);position:relative;overflow:hidden}
.sim__btn::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s}
.sim__btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px -4px rgba(30,107,74,.55)}
.sim__btn:hover::before{left:100%}
.sim__btn:active{transform:translateY(0)}
.sim__btn-arrow{font-size:18px;transition:transform .2s}
.sim__btn:hover .sim__btn-arrow{transform:translateX(4px)}

.sim__result{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:32px;min-height:380px;display:flex;flex-direction:column;box-shadow:0 8px 24px -12px rgba(11,18,32,.08)}
.sim__placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--mute);font-size:14px;line-height:1.7;text-align:center;padding:24px;gap:16px}
.sim__placeholder-icon{color:var(--accent);opacity:.55}
.sim__placeholder h3{font-family:var(--serif);font-size:20px;color:var(--ink);font-weight:700;margin:0}
.sim__placeholder p{margin:0;color:var(--ink-2);font-size:14px}
.sim__placeholder p strong{color:var(--ink);font-weight:700}
.sim__placeholder-preview{list-style:none;padding:18px 20px;margin:8px 0 0;background:var(--bg-2);border-radius:8px;border:1px dashed var(--line);display:flex;flex-direction:column;gap:10px;width:100%;max-width:340px;text-align:left}
.sim__placeholder-preview li{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--ink-2);line-height:1.5}
.sim__placeholder-preview li span{flex-shrink:0;width:20px;height:20px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:700}
.sim__result-head{margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.sim__result-head h3{font-family:var(--serif);font-size:22px;color:var(--ink);font-weight:700;margin:0 0 6px}
.sim__result-head p{font-size:13px;color:var(--mute);margin:0;line-height:1.7}
.sim__result-head strong{color:var(--ink);font-weight:700}
.sim__stat{background:var(--bg-2);border-radius:6px;padding:18px 20px;margin-bottom:24px}
.sim__stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;border-bottom:1px solid var(--line)}
.sim__stat-row:last-child{border-bottom:none}
.sim__stat-row > span{font-size:13px;color:var(--ink-2)}
.sim__stat-row > b{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.sim__stat-row--net{margin-top:4px;border-top:2px solid var(--ink);padding-top:14px}
.sim__stat-row--net > b{font-size:28px;color:var(--accent)}

.sim__top-h{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--mute);font-weight:600;margin:0 0 14px;text-transform:uppercase}
.sim__tops{display:flex;flex-direction:column;gap:14px}
.sim__top{display:flex;flex-direction:column;gap:10px;padding:18px;background:#fff;border:1px solid var(--line-2);border-radius:8px;position:relative}
.sim__top--gold{border-left:4px solid #1e6b4a}
.sim__top--silver{border-left:4px solid #9ca3af}
.sim__top--bronze{border-left:4px solid #a36c3e}
.sim__top-rank{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--mute);font-weight:600}
.sim__top-brand{display:flex;align-items:center;gap:12px}
.sim__top-logo{width:40px;height:40px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:13px;font-weight:700;border-radius:4px;flex-shrink:0}
.sim__top-brand h4{font-size:15px;line-height:1.4;color:var(--ink);font-weight:700;margin:0 0 4px}
.sim__top-meta{font-size:12px;color:var(--mute);line-height:1.6}
.sim__top-cta{display:inline-block;padding:10px 16px;background:var(--accent);color:#fff !important;font-size:13px;font-weight:700;text-decoration:none;border-radius:4px;text-align:center;transition:all .15s}
.sim__top-cta:hover{background:var(--ink);color:#fff !important}
.sim__top-detail{font-size:11px;color:var(--mute);text-decoration:underline;text-underline-offset:3px;text-align:center;font-family:var(--mono);letter-spacing:.04em}
.sim__top-detail:hover{color:var(--ink)}

.sim__note{margin-top:24px;font-size:11px;color:var(--mute);line-height:1.85}

/* 記事本文内ショートコード時：本文幅 720px に収まるよう常に1カラム */
.art__body .sim{padding:36px 28px;border-radius:12px;margin-top:2em;margin-bottom:2em}
.art__body .sim__grid{grid-template-columns:1fr;gap:20px}
.art__body .sim__head{margin-bottom:24px}
.art__body .sim__head h2{font-size:28px}
.art__body .sim__form,.art__body .sim__result{padding:24px;border-radius:12px}
.art__body .sim__result{min-height:auto}
.art__body .sim__placeholder{padding:16px 8px}

@media (max-width:980px){
  .sim__grid{grid-template-columns:1fr;gap:24px}
  .sim{padding:48px 24px 72px}
  .sim__head h2{font-size:30px}
  .sim__head{margin-bottom:32px}
}
@media (max-width:640px){
  .sim__form, .sim__result{padding:22px}
  .sim__hero{padding:16px 18px 14px}
  .sim__hero-input input{font-size:26px}
  .sim__row{grid-template-columns:1fr;gap:14px}
  .sim__stat-row--net > b{font-size:24px}
  .sim__head h2{font-size:24px}
  .sim__badges{gap:6px}
  .sim__badges li{padding:5px 10px;font-size:11px}
}

/* =========================================================
   /companies/ — 全業者カタログ
   ========================================================= */
.catalog{background:var(--bg);padding:56px 32px 96px}
.catalog__inner{max-width:var(--maxw);margin:0 auto}

.catalog__sechd{margin:48px 0 28px;border-bottom:2px solid var(--ink);padding-bottom:18px}
.catalog__sechd:first-child{margin-top:0}
.catalog__sechd h2{font-family:var(--serif);font-size:28px;color:var(--ink);font-weight:700;display:flex;align-items:baseline;gap:18px;margin:0 0 10px}
.catalog__num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--mute);font-weight:500;text-transform:uppercase}
.catalog__sechd p{font-size:14px;color:var(--mute);line-height:1.85;margin:0;max-width:780px}

.catalog__grid{display:grid;gap:20px;align-items:start}
.catalog__grid--ranked{grid-template-columns:repeat(2,1fr)}
.catalog__grid--info{grid-template-columns:repeat(3,1fr);gap:16px}

.cco{background:var(--paper);border:1px solid var(--line-2);border-radius:8px;padding:24px 22px;display:flex;flex-direction:column;gap:14px}
.cco--ranked{border-color:var(--line-2);box-shadow:0 1px 2px rgba(11,18,32,.05)}
.cco--info{padding:18px 18px;font-size:13px}

.cco__hd{display:flex;align-items:center;gap:14px}
.cco--ranked .cco__hd{padding-bottom:14px;border-bottom:1px solid var(--line)}
.cco--info .cco__hd{padding-bottom:10px;border-bottom:1px dashed var(--line)}
.cco__rank{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--accent);font-weight:700;background:rgba(30,107,74,.1);padding:4px 10px;border-radius:3px;align-self:flex-start;border:1px solid rgba(30,107,74,.25)}
.cco__brand{flex:1;min-width:0}
.cco__brand h3{font-family:var(--serif);font-size:16px;line-height:1.45;color:var(--ink);margin:0;font-weight:700;overflow:hidden;text-overflow:ellipsis}
.cco--info .cco__brand h3{font-size:14px}
.cco__stars{font-size:12px;color:var(--accent);font-weight:600;margin-top:4px;font-family:var(--mono)}
.cco__stars--mute{color:var(--mute);font-size:11px}

.cco__meta{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--bg-2);border-radius:4px;overflow:hidden}
.cco__meta li{padding:8px 10px;font-size:12px;color:var(--ink);font-weight:600;border-right:1px solid var(--line);text-align:center;display:flex;flex-direction:column;gap:2px}
.cco__meta li:last-child{border-right:none}
.cco__meta li b{font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--mute);font-weight:600;text-transform:uppercase}

.cco__pros{list-style:none;padding:0;margin:0;font-size:12px;line-height:1.7;color:var(--ink-2)}
.cco__pros li{padding:4px 0 4px 16px;position:relative}
.cco__pros li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}

.cco--ranked .cta{padding:14px 18px !important;font-size:13px}
.cco__detail{font-size:11px;text-align:center;color:var(--mute);font-family:var(--mono);letter-spacing:.04em;text-decoration:underline;text-underline-offset:3px}
.cco__detail:hover{color:var(--ink)}

.cco__cta-row{display:flex;flex-direction:column;gap:8px;margin-top:auto}
.cco__website{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:var(--paper);color:var(--ink) !important;border:1px solid var(--line-2);border-radius:4px;font-size:12px;font-weight:600;text-decoration:none;transition:all .15s}
.cco__website:hover{background:var(--ink);color:#fff !important;border-color:var(--ink)}
.cco__website--disabled{background:var(--bg-2);color:var(--mute) !important;border-style:dashed;cursor:default;pointer-events:none}
.cco__website--disabled:hover{background:var(--bg-2);color:var(--mute) !important;border-color:var(--line)}
.cco__review{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:var(--ink);color:#fff !important;border:1px solid var(--ink);border-radius:4px;font-size:12px;font-weight:700;text-decoration:none;transition:all .15s;letter-spacing:.02em}
.cco__review:hover{background:var(--accent);color:#fff !important;border-color:var(--accent)}

.catalog__foot{margin-top:64px;padding:32px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;font-size:13px;line-height:1.85;color:var(--ink-2)}
.catalog__foot strong{color:var(--ink);font-weight:700}
.catalog__foot a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}

@media (max-width:980px){
  .catalog{padding:40px 24px 72px}
  .catalog__grid--ranked{grid-template-columns:1fr}
  .catalog__grid--info{grid-template-columns:repeat(2,1fr)}
  .catalog__sechd h2{font-size:22px}
}
@media (max-width:640px){
  .catalog__grid--info{grid-template-columns:1fr;gap:14px}
  .cco{padding:18px}
  .cco__meta li{padding:6px 6px}
}

/* =========================================================
   IRM banner — 1億円以上の資金調達誘導 (toshika-lp 風)
   ========================================================= */
.irm{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:96px 32px;position:relative;overflow:hidden}
.irm::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--accent) 50%,transparent 100%);opacity:.4}
.irm__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}

/* === Copy side === */
.irm__copy{min-width:0}
.irm__kicker{display:inline-flex;align-items:center;gap:16px;font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--mute);text-transform:uppercase;font-weight:500;margin-bottom:36px}
.irm__kicker::before{content:"";width:36px;height:1px;background:var(--accent)}
.irm__title{font-family:var(--serif);font-size:54px;font-weight:700;line-height:1.3;letter-spacing:-.02em;color:var(--ink);margin:0}
.irm__title em{font-style:normal;color:var(--ink);position:relative;display:inline-block}
.irm__title em::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.32em;background:var(--accent);opacity:.28;z-index:-1}
.irm__lead{margin-top:32px;font-size:15px;line-height:1.95;color:var(--ink-2);max-width:520px}
.irm__lead b{color:var(--ink);font-weight:700}
.irm__pts{list-style:none;padding:0;margin:32px 0 0;border-top:1px solid var(--line)}
.irm__pts li{display:flex;align-items:flex-start;gap:18px;padding:14px 0;border-bottom:1px solid var(--line);font-size:14px;line-height:1.7;color:var(--ink)}
.irm__pts li span{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--mute);font-weight:600;padding-top:2px;flex-shrink:0;min-width:24px}

.irm__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:18px;
  margin-top:40px;padding:18px 32px;
  background:var(--ink);color:#fff;
  font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.06em;
  text-decoration:none;border:1px solid var(--ink);border-radius:4px;
  transition:all .25s ease;
}
.irm__cta:hover{background:#fff;color:var(--ink);transform:translateY(-2px);box-shadow:0 12px 30px -12px rgba(11,18,32,.4)}
.irm__cta-arrow{display:inline-block;transition:transform .25s ease;font-family:var(--mono);font-weight:400}
.irm__cta:hover .irm__cta-arrow{transform:translateX(6px)}
.irm__note{margin-top:18px;font-size:11px;color:var(--mute);font-family:var(--mono);letter-spacing:.06em}

/* === Visual side === */
.irm__visual{aspect-ratio:4/5;background:linear-gradient(160deg,#0b1220 0%,#1a2438 50%,#0b1220 100%);border-radius:6px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 30px 80px -30px rgba(11,18,32,.5)}
.irm__visual::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(30,107,74,.18) 0%,transparent 45%),radial-gradient(circle at 80% 80%,rgba(31,59,115,.25) 0%,transparent 50%);pointer-events:none}
.irm__visual::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent 0,transparent 22px,rgba(255,255,255,.025) 22px,rgba(255,255,255,.025) 23px);pointer-events:none}
.irm__visual-inner{position:relative;z-index:1;text-align:center;color:#fff;padding:48px 36px;width:100%}

.irm__brand{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border:1px solid rgba(30,107,74,.4);border-radius:999px;font-size:11px;letter-spacing:.16em;font-family:var(--mono);font-weight:500;text-transform:uppercase;margin-bottom:48px;color:rgba(255,255,255,.86)}
.irm__brand-mark{color:var(--accent);font-size:14px}
.irm__brand-name em{font-style:normal;color:var(--accent);font-weight:600;margin-left:4px}

.irm__amount{font-family:var(--serif);font-size:54px;font-weight:700;line-height:1;letter-spacing:-.02em;color:#fff;margin-bottom:14px;display:flex;align-items:baseline;justify-content:center;gap:2px}
.irm__amount-prefix{font-size:32px;color:var(--accent);font-weight:500;margin-right:6px}
.irm__amount-suffix{font-size:32px;color:var(--accent);font-weight:500;margin-left:4px}

.irm__visual-tag{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:rgba(255,255,255,.5);text-transform:uppercase;margin-bottom:48px}

.irm__visual-lines{display:flex;justify-content:center;gap:6px;height:48px;align-items:flex-end}
.irm__visual-lines span{display:block;width:6px;background:rgba(30,107,74,.8);border-radius:1px}
.irm__visual-lines span:nth-child(1){height:35%}
.irm__visual-lines span:nth-child(2){height:60%}
.irm__visual-lines span:nth-child(3){height:48%}
.irm__visual-lines span:nth-child(4){height:80%;background:var(--accent)}
.irm__visual-lines span:nth-child(5){height:100%;background:var(--accent)}

@media (max-width:1100px){
  .irm{padding:80px 28px}
  .irm__inner{gap:56px;grid-template-columns:1.2fr 1fr}
  .irm__title{font-size:44px}
  .irm__amount{font-size:44px}
}
@media (max-width:880px){
  .irm{padding:64px 24px}
  .irm__inner{grid-template-columns:1fr;gap:48px;max-width:680px}
  .irm__visual{aspect-ratio:16/10;order:-1}
  .irm__visual-inner{padding:40px 28px}
  .irm__title{font-size:36px}
  .irm__brand{margin-bottom:32px}
  .irm__visual-tag{margin-bottom:24px}
}
@media (max-width:560px){
  .irm{padding:48px 20px}
  .irm__title{font-size:28px;line-height:1.35}
  .irm__lead{font-size:14px;margin-top:24px}
  .irm__pts{margin-top:24px}
  .irm__pts li{font-size:13px;padding:12px 0;gap:14px}
  .irm__cta{width:100%;padding:16px 24px;font-size:13px}
  .irm__amount{font-size:36px}
  .irm__amount-prefix,.irm__amount-suffix{font-size:22px}
}

/* =========================================================
   Single Article (single.php) — reading-optimized layout
   ========================================================= */
.art{background:var(--bg)}

/* Header (breadcrumb + title + byline) */
.art__hd{max-width:780px;margin:0 auto;padding:36px 32px 28px}
.art__hd .crumb{margin-bottom:20px}
.art__hd .tag{margin-bottom:14px;font-size:11px;padding:5px 12px;letter-spacing:.14em;background:#eafaf1!important;border:1px solid #a7e8c8!important;color:#78350f!important;font-weight:700;border-radius:4px}
.art__title{font-family:var(--serif);font-size:30px;font-weight:700;line-height:1.45;letter-spacing:-.01em;color:var(--ink);margin:0}
.art__lead{margin-top:16px;font-size:15px;line-height:1.85;color:var(--ink-2)}
.art__byline{margin-top:24px;padding-top:18px}

.art__byline{margin-top:32px;padding-top:24px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.byl__author{display:flex;align-items:center;gap:14px;min-width:0}
.byl__avatar{width:46px;height:46px;border-radius:50%;border:1px solid var(--line)}
.byl__name{display:block;font-weight:600;font-size:14px;color:var(--ink)}
.byl__name em{font-style:normal;font-weight:400;color:var(--mute);margin-left:4px;font-size:12px}
.byl__bio{display:block;font-size:12px;color:var(--mute);margin-top:2px;max-width:380px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.byl__meta{font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.04em;display:flex;gap:8px;flex-wrap:wrap}

/* Cover image */
.art__cover{max-width:980px;margin:8px auto 0;aspect-ratio:16/9;background:#0b1220 center/cover;border-radius:8px}

/* 2-col layout (body + sidebar) */
.art__layout{max-width:var(--maxw);margin:0 auto;padding:48px 32px 80px;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:64px;align-items:flex-start}

/* ======= Body content ======= */
.art__body{font-size:16px;line-height:1.95;color:var(--ink);min-width:0}
.art__body > *{max-width:720px;margin-left:0;margin-right:auto}
.art__body > .alignfull,.art__body > .alignwide{max-width:none}

.art__body p{margin:0 0 1.5em;font-size:16px;line-height:1.95;color:#1c2433}
.art__body h2{font-family:var(--serif);font-size:28px;line-height:1.5;letter-spacing:-.005em;margin:3em 0 .8em;padding-bottom:.5em;border-bottom:2px solid var(--ink);color:var(--ink);font-weight:700}
.art__body h3{font-family:var(--serif);font-size:22px;line-height:1.55;margin:2.5em 0 .8em;color:var(--ink);font-weight:700;padding-left:14px;border-left:4px solid var(--accent)}
.art__body h4{font-size:17px;line-height:1.6;margin:2em 0 .6em;color:var(--ink);font-weight:700}
.art__body h5,.art__body h6{font-size:15px;margin:1.6em 0 .5em;font-weight:700}

.art__body ul,.art__body ol{margin:0 0 1.5em;padding-left:1.8em}
.art__body ul li,.art__body ol li{margin:.45em 0;line-height:1.85}
.art__body ul li::marker{color:var(--accent)}
.art__body ol li::marker{color:var(--accent);font-weight:700}

.art__body a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:rgba(31,59,115,.35);transition:text-decoration-color .15s}
.art__body a:hover{text-decoration-color:var(--accent-2)}

.art__body strong{font-weight:700;color:var(--ink)}
.art__body em{font-style:normal;background:linear-gradient(transparent 62%,rgba(30,107,74,.32) 62%);padding:0 .1em}

.art__body blockquote{margin:2em 0;padding:20px 24px;border-left:4px solid var(--ink);background:var(--bg-2);font-size:15px;line-height:1.85;color:var(--ink-2);border-radius:0 6px 6px 0}
.art__body blockquote p{margin:0 0 .8em}
.art__body blockquote p:last-child{margin:0}

.art__body hr{border:none;height:1px;background:var(--line);margin:3em auto}

/* Tables */
.art__body table{width:100%;border-collapse:collapse;margin:2em 0;font-size:14px;line-height:1.7;background:var(--paper);border:1px solid var(--line);border-radius:6px;overflow:hidden}
/* テーブル横スクロール対応（モバイル時のはみ出し防止） */
@media (max-width:768px){
  .art__body table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:13px;white-space:nowrap;max-width:100%;border-radius:0}
  .art__body table th,.art__body table td{padding:10px 12px;white-space:nowrap}
}
/* 長い英数字・URL の overflow 防止（全体共通） */
.art__body{word-wrap:break-word;overflow-wrap:break-word}
.art__body a{word-break:break-word}
.article-hashtags a,.irm-inline a,.aff-cta-btn{word-break:keep-all;overflow-wrap:break-word}
/* ヘッダーのモバイル対応：ナビが画面はみ出さないように */
@media (max-width:768px){
  .hd__inner{padding:14px 16px;gap:12px;flex-wrap:wrap;justify-content:space-between}
  .hd__logo{order:1;flex-shrink:1;min-width:0}
  .hd__cta{order:2;margin-left:auto}
  .hd__cta .btn{padding:8px 14px;font-size:12px;letter-spacing:.02em}
  .hd__nav{order:3;width:100%;gap:14px;margin-left:0;margin-top:8px;justify-content:flex-start;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:10px}
  .hd__nav a{font-size:12px;padding:4px 0}
  .hd__name{font-size:18px}
  .hd__sub{display:none}
}
@media (max-width:480px){
  .hd__inner{padding:12px 12px;gap:8px}
  .hd__name{font-size:16px}
  .hd__cta .btn{padding:7px 11px;font-size:11px}
  .hd__nav{gap:10px;padding-top:8px}
  .hd__nav a{font-size:11px}
  .util__inner{padding:6px 12px}
  .util__live,.util__nav a{font-size:10px}
}

/* セクションタイトルのモバイル対応：kicker(RANKING/USE CASE等)と本タイトルを縦並びに */
@media (max-width:768px){
  .sec__title,.sec__title--big{flex-direction:column;align-items:flex-start!important;gap:6px}
  .sec__num{display:block;margin-bottom:0!important;font-size:11px;line-height:1.4}
  .sec__title--big{font-size:clamp(22px,5.6vw,32px)!important;line-height:1.3}
}

/* RANKING（.rrow）のモバイル余白問題修正 */
@media (max-width:980px){
  .rrow{padding:24px 20px 24px!important;gap:16px}
  .rrow--1::before{height:3px}
}
@media (max-width:640px){
  .rrow{padding:20px 16px 20px!important;border-radius:10px}
  .rrow__rank{margin-bottom:4px;gap:4px}
  .rrow__no{width:42px;height:42px;font-size:24px}
  .rrow__crown{font-size:8px;padding:2px 5px}
  .rrow__brand{gap:10px;margin-bottom:12px}
  .rrow__logo{width:44px;height:44px;font-size:16px}
  .rrow__brand h3{font-size:17px!important;line-height:1.35}
}
.art__body table th,.art__body table td{padding:12px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;background:#fff}
.art__body table th{background:var(--bg-2);font-weight:700;color:var(--ink);font-size:13px;letter-spacing:.02em}
.art__body table tr:last-child th,.art__body table tr:last-child td{border-bottom:none}
.art__body table thead th{background:var(--ink);color:#fff}
/* 行ストライプ（zebra）— 偶数行に薄いグレー背景 */
.art__body table tbody tr:nth-child(odd) td{background:#fff}
.art__body table tbody tr:nth-child(even) td{background:#f8fafc}

/* Code */
.art__body pre{margin:2em 0;padding:18px 22px;background:#0b1220;color:#e6e2d4;font-family:var(--mono);font-size:13px;line-height:1.7;border-radius:6px;overflow-x:auto}
.art__body code{background:var(--bg-2);padding:2px 6px;border-radius:3px;font-family:var(--mono);font-size:.92em;border:1px solid var(--line)}
.art__body pre code{background:none;padding:0;border:none;color:inherit}

/* Images */
.art__body img{max-width:100%;height:auto;display:block;margin:1.8em 0;border-radius:6px}
.art__body figure{margin:2em 0;max-width:720px}
.art__body figure img{margin:0 auto}
.art__body figcaption{margin-top:10px;font-size:13px;color:var(--mute);text-align:center;font-family:var(--mono)}

/* WordPress 旧記事の特殊な inline 装飾を整える */
.art__body > div[style*="background"]{max-width:720px;margin:1.8em 0 !important;border-radius:6px}
.art__body div[style*="border"]{border-radius:6px}
.art__body iframe{max-width:100%;border-radius:6px;margin:1.8em 0;display:block}

/* Affiliate disclosure (functions.php で自動挿入される blockquote) */
.affiliate-disclosure{
  max-width:720px;margin:0 0 36px !important;padding:14px 20px !important;
  font-size:12px;line-height:1.7;color:var(--mute) !important;
  background:rgba(30,107,74,.06);border-left:3px solid var(--accent) !important;
  border-radius:0 4px 4px 0;font-family:var(--sans) !important;
}
.affiliate-disclosure p{margin:0}

/* Rich TOC (目次) plugin の見栄えを馴染ませる */
.art__body .rtoc{max-width:720px;margin:2em 0 !important;border:1px solid var(--line) !important;border-radius:6px;background:var(--paper);box-shadow:none !important}
.art__body .rtoc-list{padding:8px 0}

/* Final CTA */
.art__finalcta{
  margin:60px auto;max-width:720px;
  padding:36px 32px;
  background:linear-gradient(145deg,var(--ink) 0%,#172238 100%);color:#fff;
  border-radius:10px;text-align:center;
  position:relative;overflow:hidden;
}
.art__finalcta::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(30,107,74,.18) 0%,transparent 50%);pointer-events:none}
.art__finalcta-kicker{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.16em;padding:6px 12px;background:rgba(30,107,74,.18);border:1px solid rgba(30,107,74,.35);border-radius:999px;color:var(--accent);margin-bottom:18px}
.art__finalcta h3{font-family:var(--serif);font-size:22px;line-height:1.55;margin:0 0 12px;color:#fff;font-weight:700;position:relative;z-index:1}
.art__finalcta p{font-size:14px;line-height:1.85;color:#cfd6e2;margin:0 0 24px;position:relative;z-index:1}
.art__finalcta p b{color:var(--accent);font-weight:700}
.art__finalcta .cta{position:relative;z-index:1}
.art__finalcta-sub{display:block;margin-top:18px;font-size:12px;color:#cfd6e2;text-decoration:underline;text-underline-offset:3px;position:relative;z-index:1}
.art__finalcta-sub:hover{color:#fff}

/* ======= Sidebar ======= */
/* サイドバー全体 — sticky-cta との衝突を回避するため底側に少し余白 */
.art__side{position:sticky;top:24px;align-self:flex-start;padding-bottom:24px}
.art__widget{background:var(--paper);border:1px solid var(--line-2);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgba(11,18,32,.04)}
.art__widget-head{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--ink);color:#fff}
.art__widget-head > span{font-size:22px}
.art__widget-head b{display:block;font-size:13px;font-weight:700}
.art__widget-head em{display:block;font-style:normal;font-size:11px;color:#cfd6e2;font-family:var(--mono);letter-spacing:.04em;margin-top:2px}
.art__widget-body{padding:20px}
.art__widget-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.art__widget-brand h4{font-size:15px;font-weight:700;line-height:1.4;color:var(--ink);margin:0}
.art__widget-brand .stars{font-size:13px;color:var(--accent);margin-top:4px}
.art__widget-brand .stars em{font-style:normal;color:var(--ink);font-weight:700;margin-left:6px}
.art__widget-pros{list-style:none;padding:0;margin:0 0 18px;border-top:1px solid var(--line)}
.art__widget-pros li{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink)}
.art__widget-pros li b{font-weight:600;color:var(--mute);font-size:11px;letter-spacing:.04em;font-family:var(--mono);text-transform:uppercase}
.art__widget-link{display:block;margin-top:14px;text-align:center;font-size:12px;color:var(--mute);text-decoration:underline;text-underline-offset:3px;font-family:var(--mono);letter-spacing:.04em}
.art__widget-link:hover{color:var(--ink)}

/* ======= IRM inline banner (本文中に自動挿入) ======= */
.art__body .irm-inline{
  max-width:720px;
  margin:2.4em auto !important;
  padding:22px 24px;
  background:linear-gradient(135deg,#0b1220 0%,#172238 100%);
  color:#fff;
  border-radius:8px;
  border:1px solid rgba(30,107,74,.28);
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.art__body .irm-inline::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 100% 0%,rgba(30,107,74,.16) 0%,transparent 50%);pointer-events:none}
.irm-inline__mark{font-size:22px;color:var(--accent);line-height:1;flex-shrink:0;position:relative;z-index:1}
.irm-inline__body{min-width:0;position:relative;z-index:1}
.irm-inline__kicker{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--accent);font-weight:500;margin-bottom:4px;text-transform:uppercase}
.art__body .irm-inline__lead,.irm-inline__lead{margin:0 !important;font-size:14px;line-height:1.7;color:#dcd8cc}
.art__body .irm-inline__lead b,.irm-inline__lead b{color:#fff;font-weight:700}
.irm-inline__cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 20px;background:var(--accent);color:#fff !important;
  font-weight:700;font-size:13px;letter-spacing:.04em;
  text-decoration:none !important;border-radius:4px;
  transition:all .2s;white-space:nowrap;position:relative;z-index:1;
  flex-shrink:0;
}
.irm-inline__cta:hover{background:#fff;transform:translateX(2px)}
.irm-inline__cta span{transition:transform .2s;display:inline-block}
.irm-inline__cta:hover span{transform:translateX(2px)}

/* PROTOCOL誘導バナーの余白圧縮 + note行の可読性確保 */
.art__body .irm-inline{padding:16px 20px!important;gap:14px!important;margin:1.8em auto!important;max-width:780px}
.art__body .irm-inline .irm-inline__mark{font-size:18px}
.art__body .irm-inline .irm-inline__kicker{margin-bottom:6px;font-size:11px}
.art__body .irm-inline .irm-inline__lead{font-size:13.5px;line-height:1.65}
.art__body .irm-inline .irm-inline__note,
.irm-inline .irm-inline__note{margin:.5em 0 0!important;font-size:11.5px;line-height:1.55;color:#cbd5e1!important;font-weight:500;letter-spacing:.01em}
.art__body .irm-inline .irm-inline__cta{padding:10px 16px;font-size:13px}

/* ======= IRM block under article CTA ======= */
.art__irm{
  margin:32px auto 0;max-width:720px;
  padding:28px 32px;
  background:var(--paper);
  border:1px solid var(--line-2);
  border-left:4px solid var(--ink);
  border-radius:6px;
  display:flex;flex-direction:column;gap:20px;
}
.art__irm-row{display:flex;align-items:flex-start;gap:18px}
.art__irm-mark{font-size:22px;color:var(--accent);line-height:1;flex-shrink:0;padding-top:2px}
.art__irm-text{min-width:0}
.art__irm-kicker{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--mute);font-weight:600;margin-bottom:8px;text-transform:uppercase}
.art__irm-text p{margin:0;font-size:14px;line-height:1.8;color:var(--ink-2)}
.art__irm-text p b{color:var(--ink);font-weight:700}
.art__irm-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:14px 24px;
  background:var(--ink);color:#fff !important;
  font-weight:700;font-size:13px;letter-spacing:.06em;
  text-decoration:none;border-radius:4px;border:1px solid var(--ink);
  align-self:flex-start;
  transition:all .2s;
}
.art__irm-cta:hover{background:transparent;color:var(--ink) !important;transform:translateY(-1px)}
.art__irm-cta span{display:inline-block;transition:transform .2s}
.art__irm-cta:hover span{transform:translateX(4px)}

/* ======= サイドバー IRM widget ======= */
.art__widget--irm{margin-top:20px}
.art__widget-head--irm{background:linear-gradient(135deg,#0b1220 0%,#1a2438 100%);border-bottom:1px solid rgba(30,107,74,.32)}
.art__widget-head--irm > span{color:var(--accent);font-size:18px}
.art__widget-head--irm b{color:#fff}
.art__widget-head--irm em{color:var(--accent);font-size:10px;letter-spacing:.14em}
.art__widget-irm-lead{font-size:13px;line-height:1.75;color:var(--ink-2);margin:0 0 16px}
.art__widget-pros--irm li b{font-size:10px}
.art__widget-irm-cta{
  background:var(--ink) !important;color:#fff !important;border:1px solid var(--ink) !important;
  padding:14px 16px !important;border-radius:4px !important;
  box-shadow:none !important;
  text-align:center;display:block;
}
.art__widget-irm-cta .cta__main{display:block;font-size:13px;font-weight:700;color:#fff;letter-spacing:.04em}
.art__widget-irm-cta .cta__sub{display:block;font-size:10px;color:rgba(255,255,255,.6);margin-top:4px;font-family:var(--mono);letter-spacing:.06em}
.art__widget-irm-cta:hover{background:var(--accent) !important;border-color:var(--accent) !important}
.art__widget-irm-cta:hover .cta__main{color:var(--ink)}
.art__widget-irm-cta:hover .cta__sub{color:rgba(11,18,32,.6)}

@media (max-width:640px){
  .art__body .irm-inline{grid-template-columns:auto 1fr;padding:18px 18px;gap:14px}
  .irm-inline__cta{grid-column:1 / -1;justify-content:center;padding:12px}
  .art__irm{padding:22px 22px;margin:24px auto 0}
  .art__irm-row{gap:14px}
  .art__irm-cta{width:100%;justify-content:center}
}

/* ======= Related posts ======= */
.art__related{background:var(--bg-2);border-top:1px solid var(--line);padding:64px 32px 96px}
.art__related-inner{max-width:var(--maxw);margin:0 auto}
.art__related .sec__head{margin-bottom:28px}
.art__related .sec__title{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--ink);display:flex;align-items:baseline;gap:18px}
.art__related .sec__num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--mute);font-weight:500;text-transform:uppercase}
.art__related .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

@media (max-width:1100px){
  .art__layout{grid-template-columns:minmax(0,1fr) 280px;gap:48px;padding:40px 28px 72px}
  .art__hd{padding:48px 28px 32px}
  .art__title{font-size:32px}
}
@media (max-width:980px){
  .art__layout{grid-template-columns:1fr;gap:48px;padding:36px 24px 64px}
  .art__side{position:static;max-width:480px;margin:0 auto;width:100%}
  .art__hd{padding:40px 24px 28px}
  .art__title{font-size:28px;line-height:1.45}
  .art__lead{font-size:15px}
  .art__cover{max-width:none;margin:0 24px;border-radius:6px}
  .art__related{padding:48px 24px 72px}
  .art__related .cards{grid-template-columns:repeat(2,1fr);gap:20px}
}
@media (max-width:640px){
  .art__hd{padding:32px 20px 24px}
  .art__title{font-size:23px}
  .art__lead{font-size:14px;margin-top:18px}
  .art__byline{margin-top:24px;padding-top:18px;align-items:flex-start}
  .byl__bio{display:none}
  .art__cover{margin:0 20px;aspect-ratio:16/10}
  .art__layout{padding:28px 20px 56px;gap:36px}
  .art__body{font-size:15px;line-height:1.9}
  .art__body h2{font-size:22px;margin-top:2.2em}
  .art__body h3{font-size:18px}
  .art__finalcta{padding:28px 22px}
  .art__finalcta h3{font-size:18px}
  .art__related{padding:40px 20px 56px}
  .art__related .sec__title{font-size:22px}
  .art__related .cards{grid-template-columns:1fr}
}

/* ======= アフィリエイトリンク (記事本文内) ======= */
.art__body a.aff-link{
  color:var(--accent-2);text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:var(--accent);text-decoration-thickness:2px;
  font-weight:700;transition:all .15s;
}
.art__body a.aff-link:hover{
  color:var(--accent);background:rgba(30,107,74,.08);
}
.art__body a.review-link{
  color:var(--accent-2);text-decoration:underline;text-underline-offset:3px;
}

/* テーブル内インライン CTA */
.art__body a.aff-cta-inline{
  display:inline-flex;align-items:center;gap:4px;
  padding:6px 12px;background:var(--accent);color:#fff !important;
  font-size:12px;font-weight:700;text-decoration:none !important;border-radius:4px;
  transition:all .15s;white-space:nowrap;
}
.art__body a.aff-cta-inline:hover{background:var(--ink);color:#fff !important}
.art__body a.aff-cta-inline--secondary{
  background:var(--paper);color:var(--ink) !important;border:1px solid var(--line-2);
}
.art__body a.aff-cta-inline--secondary:hover{background:var(--ink);color:#fff !important}

/* ブロック CTA (推奨5社) */
.art__body .aff-cta-block{margin:14px 0 8px !important}
.art__body a.aff-cta-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 28px;background:linear-gradient(135deg,var(--accent) 0%,#1e8a5a 100%);
  color:var(--ink) !important;font-size:15px;font-weight:700;letter-spacing:.02em;
  text-decoration:none !important;border-radius:8px;
  box-shadow:0 4px 14px -4px rgba(30,107,74,.45);
  transition:all .2s;
}
.art__body a.aff-cta-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 20px -4px rgba(30,107,74,.6);
  background:linear-gradient(135deg,#1e8a5a 0%,var(--accent) 100%);
}
.art__body a.aff-cta-btn--secondary{
  background:var(--paper);border:1px solid var(--line-2);box-shadow:none;
}
.art__body a.aff-cta-btn--secondary:hover{
  background:var(--ink);color:#fff !important;
  box-shadow:0 4px 12px -4px rgba(11,18,32,.3);
}

@media (max-width:640px){
  .art__body a.aff-cta-inline{padding:5px 10px;font-size:11px}
  .art__body a.aff-cta-btn{padding:12px 20px;font-size:14px}
}

/* ======= 自動関連記事リンク (内部リンク強化) ======= */
.art__body .art__autorelated{
  margin:3em 0 1em !important;
  padding:24px 28px;
  background:linear-gradient(135deg,var(--bg-2) 0%,var(--paper) 100%);
  border:1px solid var(--line-2);
  border-left:4px solid var(--accent);
  border-radius:8px;
  max-width:720px;
}
.art__autorelated-title{
  font-family:var(--serif) !important;
  font-size:18px !important;
  color:var(--ink) !important;
  margin:0 0 14px !important;
  padding:0 !important;
  border:none !important;
  letter-spacing:.01em;
}
.art__autorelated-list{
  list-style:none !important;
  padding:0 !important;
  margin:0 !important;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 20px;
}
.art__autorelated-list li{
  margin:0 !important;
  padding:0 !important;
}
.art__autorelated-list li::marker{display:none}
.art__autorelated-list a{
  display:flex;
  align-items:flex-start;
  gap:8px;
  padding:6px 0;
  font-size:13px;
  color:var(--ink-2) !important;
  text-decoration:none !important;
  line-height:1.6;
  transition:color .15s;
}
.art__autorelated-list a:hover{
  color:var(--accent-2) !important;
}
.art__autorelated-arrow{
  flex-shrink:0;
  color:var(--accent);
  font-weight:700;
  margin-top:2px;
}
.art__autorelated-text{
  flex:1;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:transparent;
  transition:text-decoration-color .15s;
}
.art__autorelated-list a:hover .art__autorelated-text{
  text-decoration-color:var(--accent-2);
}
@media (max-width:640px){
  .art__autorelated-list{grid-template-columns:1fr;gap:6px}
  .art__body .art__autorelated{padding:20px 22px}
}

/* ======= 業者比較カート ======= */
.compare-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:1000;
  background:linear-gradient(180deg,#0b1220 0%,#172238 100%);
  color:#fff;padding:14px 24px;
  transform:translateY(100%);
  transition:transform .3s ease-out;
  box-shadow:0 -4px 20px -4px rgba(0,0,0,.3);
}
.compare-bar.is-show{transform:translateY(0)}
.compare-bar__inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.compare-bar__count{font-family:var(--mono);font-size:13px;letter-spacing:.04em}
.compare-bar__count b{color:var(--accent);font-size:18px;font-weight:800}
.compare-bar__items{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.compare-bar__chip{
  display:inline-block;padding:4px 10px;
  background:rgba(30,107,74,.16);color:#e8f5ee;
  border:1px solid rgba(30,107,74,.4);border-radius:999px;
  font-size:12px;font-weight:600;
}
.compare-bar__cta{
  padding:10px 24px;background:var(--accent);color:#fff !important;
  font-weight:700;text-decoration:none;border-radius:6px;font-size:14px;
  transition:all .15s;white-space:nowrap;
}
.compare-bar__cta:hover{background:#fff}
.compare-bar__clear{
  width:32px;height:32px;background:transparent;border:1px solid rgba(255,255,255,.3);
  color:#fff;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.compare-bar__clear:hover{background:rgba(255,255,255,.1)}

[data-compare-id]{
  padding:8px 14px;background:var(--paper);
  border:1px dashed var(--line-2);border-radius:4px;
  font-size:12px;font-weight:700;color:var(--ink) !important;
  text-decoration:none;cursor:pointer;transition:all .15s;
  display:inline-block;margin-top:8px;
}
[data-compare-id]:hover{background:var(--accent);border-style:solid;border-color:var(--accent)}
[data-compare-id].is-added{background:var(--accent);border-style:solid;border-color:var(--accent);color:#fff}

/* 比較表ページ */
.compare-section{padding:56px 32px 96px;background:var(--bg)}
.compare-section__inner{max-width:1100px;margin:0 auto}
.compare-empty{text-align:center;padding:60px 20px;color:var(--mute);font-size:15px;line-height:1.8}
.compare-empty a{color:var(--accent-2);text-decoration:underline}
.cmp-grid{display:grid;gap:20px;grid-template-columns:repeat(var(--cols,3),1fr)}
.cmp-grid[data-cols="1"]{grid-template-columns:minmax(0,440px);justify-content:center}
.cmp-grid[data-cols="2"]{grid-template-columns:repeat(2,1fr)}
.cmp-col{
  background:var(--paper);border:1px solid var(--line-2);border-radius:10px;padding:24px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 4px 16px -8px rgba(11,18,32,.1);
}
.cmp-head{display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line);padding-bottom:14px}
.cmp-head h3{margin:0;font-family:var(--serif);font-size:18px;color:var(--ink)}
.cmp-logo{width:48px;height:48px;border-radius:8px;flex-shrink:0;object-fit:contain;background:#fff;padding:4px;border:1px solid var(--line)}
.cmp-logo--txt{display:flex;align-items:center;justify-content:center;background:var(--ink);color:#fff;font-weight:700}
.cmp-table{width:100%;border-collapse:collapse;font-size:13px}
.cmp-table th{text-align:left;font-weight:600;color:var(--mute);padding:8px 0;border-bottom:1px solid var(--line);width:42%}
.cmp-table td{text-align:right;padding:8px 0;border-bottom:1px solid var(--line);color:var(--ink);font-weight:700}
.cmp-pros{background:var(--bg-2);padding:12px 14px;border-radius:6px;font-size:12px}
.cmp-pros b{display:block;color:var(--ink);font-size:11px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em}
.cmp-pros ul{list-style:none;padding:0;margin:0}
.cmp-pros li{padding:2px 0 2px 14px;position:relative;color:var(--ink-2);line-height:1.5}
.cmp-pros li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}
.cmp-cta{
  display:block;padding:14px 16px;background:linear-gradient(135deg,var(--accent),#1e8a5a);
  color:var(--ink) !important;font-weight:700;text-align:center;border-radius:6px;
  text-decoration:none !important;font-size:14px;transition:all .2s;
  box-shadow:0 4px 12px -4px rgba(30,107,74,.4);
}
.cmp-cta:hover{transform:translateY(-1px);box-shadow:0 6px 16px -4px rgba(30,107,74,.55)}
.cmp-cta--secondary{background:var(--paper);border:1px solid var(--line-2);box-shadow:none}
.cmp-review-link{text-align:center;color:var(--accent-2) !important;font-size:12px;text-decoration:underline}
.cmp-remove{
  margin-top:auto;padding:6px 12px;background:transparent;border:1px solid var(--line);
  color:var(--mute);border-radius:4px;cursor:pointer;font-size:11px;
}
.cmp-remove:hover{background:var(--red,#8b2727);color:#fff;border-color:transparent}

@media (max-width:980px){
  .cmp-grid[data-cols="2"],.cmp-grid[data-cols="3"]{grid-template-columns:1fr}
  .cmp-grid{max-width:480px;margin:0 auto}
}
@media (max-width:640px){
  .compare-bar{padding:10px 14px}
  .compare-bar__items{display:none}
  .compare-bar__cta{padding:8px 16px;font-size:13px}
}

/* ======= ファーストビュー CTA バナー ======= */
.art__body .fv-cta{
  max-width:720px;
  margin:2em auto 2.4em !important;
  padding:0 !important;
  border-radius:14px;
  overflow:hidden;
  background:linear-gradient(135deg,#0b1220 0%,#172238 50%,#2a3a5a 100%);
  color:#fff;
  border:1px solid rgba(30,107,74,.35);
  box-shadow:0 12px 32px -8px rgba(11,18,32,.25);
  position:relative;
}
.art__body .fv-cta::before{
  content:"";position:absolute;top:0;right:0;width:280px;height:100%;
  background:radial-gradient(circle at 80% 30%,rgba(30,107,74,.18) 0%,transparent 60%);
  pointer-events:none;
}
.art__body .fv-cta__inner{position:relative;z-index:1;padding:28px 32px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.art__body .fv-cta__kicker{
  display:inline-block !important;font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;color:var(--accent) !important;font-weight:600;
  padding:4px 10px;background:rgba(30,107,74,.12);border:1px solid rgba(30,107,74,.3);
  border-radius:4px;margin:0 0 12px !important;
}
.art__body .fv-cta__title{
  font-family:var(--serif) !important;font-size:24px !important;line-height:1.45 !important;
  color:#fff !important;font-weight:700 !important;
  margin:0 0 12px !important;padding:0 !important;border:none !important;
}
.art__body .fv-cta__title em{
  font-style:normal;color:var(--accent) !important;
  background:linear-gradient(180deg,transparent 60%,rgba(30,107,74,.25) 60%);padding:0 4px;
}
.art__body .fv-cta__lead{
  font-size:13px !important;line-height:1.75 !important;
  color:rgba(255,255,255,.9) !important;margin:0 0 14px !important;
}
.art__body .fv-cta__lead strong{color:var(--accent) !important;font-weight:700 !important}
.art__body .fv-cta__trust{
  list-style:none !important;padding:0 !important;margin:0 !important;
  display:flex !important;flex-wrap:wrap;gap:6px 14px;
}
.art__body .fv-cta__trust li{
  margin:0 !important;padding:0 !important;
  color:rgba(255,255,255,.85) !important;
  font-size:11px !important;font-weight:600 !important;
  font-family:var(--mono);letter-spacing:.04em;
  display:inline-block !important;
  background:transparent !important;
}
.art__body .fv-cta__trust li::marker,
.art__body .fv-cta__trust li::before{display:none !important;content:"" !important}
.art__body .fv-cta__actions{display:flex;flex-direction:column;gap:10px;min-width:220px}
.art__body .fv-cta__btn{
  display:inline-flex !important;align-items:center;justify-content:center;
  padding:14px 22px;font-size:14px;font-weight:700;letter-spacing:.04em;
  text-decoration:none !important;border-radius:8px;transition:all .2s;
  white-space:nowrap;
}
.art__body .fv-cta__btn--primary{
  background:linear-gradient(135deg,var(--accent),#1e8a5a);color:var(--ink) !important;
  box-shadow:0 4px 14px -4px rgba(30,107,74,.5);
}
.art__body .fv-cta__btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px -4px rgba(30,107,74,.65)}
.art__body .fv-cta__btn--secondary{background:transparent;color:#fff !important;border:1px solid rgba(255,255,255,.4)}
.art__body .fv-cta__btn--secondary:hover{background:rgba(255,255,255,.1)}
/* マイクロコピーの :after が FV ボタンに付かないように打ち消し */
.art__body .fv-cta .fv-cta__btn::after{content:none !important;display:none !important}

@media (max-width:780px){
  .art__body .fv-cta__inner{grid-template-columns:1fr;padding:24px 22px}
  .art__body .fv-cta__title{font-size:20px !important}
  .art__body .fv-cta__actions{min-width:0}
}

/* ======= マイクロコピー（CTAボタン直下の安心訴求）======= */
.art__body .aff-cta-block{position:relative;margin-bottom:18px !important}
.art__body .aff-cta-block::after{
  content:"✓ 完全無料  ✓ 登録不要  ✓ 最短 60 分入金  ✓ 個人事業主 OK";
  display:block;text-align:center;
  font-size:11px;color:var(--mute);font-family:var(--mono);letter-spacing:.04em;
  margin-top:6px;
}
.fv-cta__actions .fv-cta__btn--primary::after{content:""}

/* ======= Exit Intent Popup ======= */
.exit-popup{
  position:fixed;inset:0;z-index:10000;
  opacity:0;visibility:hidden;
  transition:opacity .25s ease, visibility 0s .25s;
}
.exit-popup.is-show{
  opacity:1;visibility:visible;
  transition:opacity .25s ease, visibility 0s 0s;
}
.exit-popup__overlay{
  position:absolute;inset:0;background:rgba(11,18,32,.7);backdrop-filter:blur(4px);
}
.exit-popup__inner{
  position:relative;max-width:480px;margin:80px auto 20px;
  background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);
  border-radius:14px;padding:36px 32px 28px;
  box-shadow:0 24px 60px -8px rgba(11,18,32,.4);
  border-top:5px solid var(--accent);
  transform:scale(.94);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.exit-popup.is-show .exit-popup__inner{transform:scale(1)}
.exit-popup__close{
  position:absolute;top:12px;right:12px;
  width:36px;height:36px;border-radius:50%;
  background:transparent;border:1px solid var(--line);color:var(--ink-2);
  cursor:pointer;font-size:18px;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.exit-popup__close:hover{background:var(--bg-2)}
.exit-popup__badge{
  display:inline-block;font-family:var(--mono);font-size:11px;
  color:#fff;background:var(--red,#8b2727);padding:4px 10px;
  border-radius:4px;font-weight:600;letter-spacing:.04em;margin-bottom:14px;
}
.exit-popup h3{
  font-family:var(--serif);font-size:24px;color:var(--ink);font-weight:700;
  margin:0 0 12px;line-height:1.4;
}
.exit-popup h3 em{
  font-style:normal;color:var(--accent);
  background:linear-gradient(180deg,transparent 60%,rgba(30,107,74,.25) 60%);padding:0 4px;
}
.exit-popup__lead{font-size:14px;line-height:1.8;color:var(--ink-2);margin:0 0 16px}
.exit-popup__lead strong{color:var(--ink);font-weight:700}
.exit-popup__benefits{
  list-style:none;padding:0 0 0 0;margin:0 0 18px;
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
}
.exit-popup__benefits li{
  font-size:13px;color:var(--ink-2);font-weight:600;
}
.exit-popup__actions{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.exit-popup__cta{
  display:block;padding:14px 24px;text-align:center;
  background:linear-gradient(135deg,var(--accent),#1e8a5a);color:var(--ink) !important;
  font-weight:700;font-size:15px;text-decoration:none !important;border-radius:8px;
  box-shadow:0 4px 14px -4px rgba(30,107,74,.45);transition:all .2s;
}
.exit-popup__cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px -4px rgba(30,107,74,.6)}
.exit-popup__dismiss{
  background:transparent;border:none;color:var(--mute);font-size:12px;cursor:pointer;
  padding:6px;text-decoration:underline;text-underline-offset:3px;
}
.exit-popup__dismiss:hover{color:var(--ink)}
.exit-popup__note{font-size:10px;color:var(--mute);text-align:center;margin:6px 0 0;line-height:1.6}

body.exit-popup-open{overflow:hidden}

@media (max-width:520px){
  .exit-popup__inner{margin:40px 16px 20px;padding:28px 22px 22px}
  .exit-popup h3{font-size:20px}
}

/* ======= シーンファインダー（3秒診断）======= */
.scene-finder{
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
  padding:48px 24px 64px;
}
.scene-finder__inner{max-width:1100px;margin:0 auto}
.scene-finder__head{text-align:center;margin-bottom:28px}
.scene-finder__kicker{
  display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--accent);font-weight:600;padding:4px 12px;
  background:rgba(30,107,74,.12);border:1px solid rgba(30,107,74,.3);
  border-radius:4px;margin-bottom:14px;
}
.scene-finder__head h2{
  font-family:var(--serif);font-size:34px;line-height:1.3;color:var(--ink);font-weight:700;
  margin:0 0 12px;letter-spacing:-.01em;
}
.scene-finder__head h2 em{
  font-style:normal;color:var(--accent);
  background:linear-gradient(180deg,transparent 60%,rgba(30,107,74,.22) 60%);padding:0 6px;
}
.scene-finder__head p{font-size:15px;line-height:1.8;color:var(--ink-2);margin:0 auto;max-width:600px}
.scene-finder__head p strong{color:var(--ink);font-weight:700}

/* ─── 2 カラムレイアウト（左:ボタン / 右:結果）─── */
.scene-finder__layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:start;
}
.scene-finder__left{display:flex;flex-direction:column;gap:14px;min-width:0}

/* ─── メイングリッド 8（左カラム内 2×4）─── */
.scene-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:0;
}
.scene-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:22px 14px;background:var(--paper);
  border:2px solid var(--line-2);border-radius:12px;cursor:pointer;
  transition:all .2s;text-align:center;gap:6px;
  box-shadow:0 2px 8px -4px rgba(11,18,32,.05);
  font-family:inherit;color:var(--ink);
}
.scene-btn:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  box-shadow:0 8px 20px -6px rgba(30,107,74,.25);
  background:#fff;
}
.scene-btn.is-active{
  border-color:var(--accent);background:linear-gradient(135deg,#fff8e8 0%,#fff 100%);
  box-shadow:0 0 0 4px rgba(30,107,74,.15);
}
.scene-btn__icon{font-size:32px;line-height:1}
.scene-btn__label{font-size:14px;font-weight:700;line-height:1.4;color:var(--ink)}
.scene-btn__sub{font-size:11px;color:var(--mute);font-family:var(--mono);letter-spacing:.04em}

/* ─── トグル ─── */
.scene-toggle{
  display:block;margin:8px auto 16px;padding:10px 20px;
  background:transparent;border:1px dashed var(--line-2);border-radius:6px;
  font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;
  font-family:inherit;transition:all .15s;
}
.scene-toggle:hover{background:var(--paper);color:var(--ink)}

/* ─── サブシーン ─── */
.scene-sub{margin-top:18px;display:flex;flex-direction:column;gap:24px}
.scene-sub__group{}
.scene-sub__title{
  font-family:var(--serif);font-size:16px;color:var(--ink);font-weight:700;
  margin:0 0 12px;padding-left:8px;border-left:3px solid var(--accent);
}
.scene-grid--sub{grid-template-columns:repeat(4,1fr);gap:10px}
.scene-btn--sm{padding:14px 10px;gap:4px}
.scene-btn--sm .scene-btn__icon{font-size:22px}
.scene-btn--sm .scene-btn__label{font-size:12px}

/* ─── 結果エリア（右カラム / 高さ追従）─── */
.scene-result{
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:24px;display:block;min-height:480px;
  box-shadow:0 8px 24px -12px rgba(11,18,32,.08);
  position:sticky;top:80px;
  max-height:calc(100vh - 100px);overflow-y:auto;
}
.scene-result__placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:48px 20px;color:var(--mute);text-align:center;gap:14px;min-height:160px;
}
.scene-result__placeholder-icon{font-size:48px;animation:bounce 1.5s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.scene-result__placeholder p{margin:0;font-size:14px;line-height:1.8}
.scene-result__placeholder strong{color:var(--accent);font-weight:700}

.scene-result.is-shown .scene-result__placeholder{display:none}

.scene-result__head{margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.scene-result__head h3{
  font-family:var(--serif);font-size:22px;color:var(--ink);font-weight:700;
  margin:0 0 8px;line-height:1.4;
}
.scene-result__head p{font-size:13px;line-height:1.7;color:var(--mute);margin:0}

.scene-result__grid{
  display:flex;flex-direction:column;gap:12px;
}

.sf-card{
  background:#fff;border:1px solid var(--line-2);border-radius:10px;padding:18px;
  display:flex;flex-direction:column;gap:12px;position:relative;
  transition:all .2s;
}
.sf-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px -8px rgba(11,18,32,.15)}
.sf-card--rank-1{border-color:#1e6b4a;background:linear-gradient(180deg,#fff 0%,#fffaee 100%)}
.sf-card--rank-2{border-color:#9ca3af}
.sf-card--rank-3{border-color:#a36c3e}

.sf-card__head{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding-bottom:10px}
.sf-card__rank{
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.04em;
  padding:3px 8px;background:var(--bg-2);color:var(--ink);border-radius:4px;flex-shrink:0;
}
.sf-card__rank--gold{background:#1e6b4a;color:#fff}
.sf-card__rank--silver{background:#9ca3af;color:#fff}
.sf-card__rank--bronze{background:#a36c3e;color:#fff}
.sf-card__logo{
  width:36px;height:36px;border-radius:6px;flex-shrink:0;object-fit:contain;
  background:#fff;padding:3px;border:1px solid var(--line);
}
.sf-card__logo--txt{
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);color:#fff;font-weight:700;font-family:var(--mono);font-size:13px;
}
.sf-card__brand{flex:1;min-width:0}
.sf-card__brand h4{margin:0;font-size:14px;font-weight:700;color:var(--ink);line-height:1.3}
.sf-card__rating{font-size:11px;color:var(--accent);font-weight:700;margin-top:2px}

.sf-card__spec{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  margin:0;padding:0;
}
.sf-card__spec > div{text-align:center}
.sf-card__spec dt{
  font-size:10px;color:var(--mute);font-family:var(--mono);letter-spacing:.04em;
  font-weight:600;margin:0 0 2px;
}
.sf-card__spec dd{margin:0;font-size:13px;font-weight:700;color:var(--ink)}

.sf-card__pros{
  list-style:none;padding:0;margin:0;
  background:var(--bg-2);padding:8px 10px;border-radius:6px;font-size:11px;
}
.sf-card__pros li{
  padding:2px 0 2px 14px;position:relative;color:var(--ink-2);line-height:1.5;
}
.sf-card__pros li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}

.sf-card__cta-row{display:flex;flex-direction:column;gap:6px;margin-top:auto}
.sf-card__cta{
  display:block;text-align:center;padding:11px 14px;
  background:linear-gradient(135deg,var(--accent),#1e8a5a);color:var(--ink) !important;
  font-weight:700;font-size:13px;text-decoration:none !important;border-radius:6px;
  box-shadow:0 3px 10px -3px rgba(30,107,74,.4);transition:all .15s;
}
.sf-card__cta:hover{transform:translateY(-1px);box-shadow:0 5px 14px -3px rgba(30,107,74,.55)}
.sf-card__cta--secondary{background:var(--paper);color:var(--ink) !important;border:1px solid var(--line-2);box-shadow:none}
.sf-card__review{
  text-align:center;font-size:11px;color:var(--mute) !important;text-decoration:underline !important;
  text-underline-offset:3px;
}
.sf-card__review:hover{color:var(--accent-2) !important}
.sf-card__compare{
  padding:6px 10px;background:transparent;border:1px dashed var(--line-2);
  border-radius:4px;font-size:11px;font-weight:700;color:var(--ink);cursor:pointer;
  transition:all .15s;font-family:inherit;
}
.sf-card__compare:hover{background:var(--ink);color:#fff;border-style:solid;border-color:var(--ink)}
.sf-card__compare.is-added{background:var(--accent);color:#fff;border-style:solid;border-color:var(--accent)}

.scene-result__foot{margin-top:20px;text-align:center}
.scene-result__more{
  display:inline-block;padding:10px 20px;font-size:13px;color:var(--ink-2);
  text-decoration:underline;text-underline-offset:3px;font-weight:600;
}
.scene-result__more:hover{color:var(--accent-2)}

/* デスクトップで結果カードを 2 カラムにできる場合は維持（広い右カラム時用）*/
.scene-result__grid{display:flex;flex-direction:column;gap:12px}

/* タブレット以下: 1 カラムにスタック、結果をモバイルでもスクロール不要な位置に */
@media (max-width:980px){
  .scene-finder__layout{grid-template-columns:1fr;gap:18px}
  .scene-result{
    position:sticky;top:8px;
    z-index:50;
    max-height:65vh;
    margin-top:0;
    box-shadow:0 12px 28px -6px rgba(11,18,32,.18);
    border:2px solid var(--accent);
  }
  /* 結果空時はスティッキー解除（バーが邪魔にならないように）*/
  .scene-result:not(.is-shown){
    position:relative;top:auto;border:1px solid var(--line);
    box-shadow:0 8px 24px -12px rgba(11,18,32,.08);
  }
}
@media (max-width:840px){
  .scene-grid--sub{grid-template-columns:repeat(2,1fr)}
  .scene-finder__head h2{font-size:24px}
  .scene-btn{padding:18px 10px}
}
@media (max-width:480px){
  .scene-finder{padding:32px 16px 48px}
  .scene-btn__icon{font-size:26px}
  .scene-btn__label{font-size:13px}
  .scene-result{padding:20px}
  .scene-result.is-shown{max-height:60vh}
}

/* ======= インフォグラフィック / 業界マップ ======= */
.im-section{padding:48px 24px 96px;background:var(--bg)}
.im-section__inner{max-width:1100px;margin:0 auto}
.im-block{margin:48px 0;padding:32px;background:var(--paper);border:1px solid var(--line-2);border-radius:12px}
.im-block__title{
  font-family:var(--serif);font-size:24px;color:var(--ink);font-weight:700;
  margin:0 0 12px;padding-bottom:12px;border-bottom:2px solid var(--accent);letter-spacing:-.01em;
}
.im-block__lead{font-size:15px;line-height:1.8;color:var(--ink-2);margin:0 0 24px}
.im-block__lead strong{color:var(--accent);font-weight:700}

/* 棒グラフ */
.im-bars{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;align-items:end;height:280px;padding:20px 0;border-bottom:2px solid var(--ink)}
.im-bar{display:flex;flex-direction:column;align-items:center;height:100%;position:relative}
.im-bar__bar{
  width:60%;background:linear-gradient(180deg,var(--accent),#a0822f);border-radius:6px 6px 0 0;
  position:relative;display:flex;align-items:flex-end;justify-content:center;padding:6px 0;
  transition:all .3s;min-height:30px;
}
.im-bar__bar:hover{background:linear-gradient(180deg,#4caf80,#1e6b4a)}
.im-bar__val{font-family:var(--mono);font-size:11px;font-weight:700;color:#fff;writing-mode:initial;white-space:nowrap}
.im-bar__label{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink);margin-top:8px}
.im-bar__note{font-size:10px;color:var(--mute);text-align:center;margin-top:2px;line-height:1.4}

/* パイ風（横バー）*/
.im-pie{display:flex;flex-direction:column;gap:14px}
.im-pie__row{display:flex;align-items:center;gap:18px}
.im-pie__bar{
  height:48px;border-radius:6px;display:flex;align-items:center;justify-content:flex-end;
  padding:0 12px;color:#fff;font-weight:700;flex-shrink:0;font-family:var(--mono);
  min-width:60px;transition:all .2s;
}
.im-pie__bar:hover{transform:translateX(4px)}
.im-pie__info{flex:1}
.im-pie__info h4{margin:0;font-size:14px;font-weight:700;color:var(--ink)}
.im-pie__info p{margin:2px 0 0;font-size:12px;color:var(--ink-2);line-height:1.5}

/* 散布図 */
.im-scatter{display:flex;flex-direction:column;gap:14px}
.im-scatter__chart{
  position:relative;height:400px;background:linear-gradient(135deg,#fafaf8 0%,#fff 100%);
  border:1px solid var(--line);border-radius:8px;padding:30px;
}
.im-scatter__axis-y,.im-scatter__axis-x{
  position:absolute;font-family:var(--mono);font-size:11px;font-weight:700;
  color:var(--mute);letter-spacing:.04em;
}
.im-scatter__axis-y{top:50%;left:8px;transform:rotate(-90deg) translateX(50%);transform-origin:left}
.im-scatter__axis-x{bottom:8px;right:30px}
.im-scatter__plot{position:relative;width:100%;height:100%}
.im-scatter__dot{
  position:absolute;border-radius:50%;transform:translate(-50%,-50%);
  cursor:pointer;transition:all .15s;opacity:.85;
}
.im-scatter__dot:hover{opacity:1;transform:translate(-50%,-50%) scale(1.5);z-index:10}
.im-scatter__legend{
  display:flex;flex-wrap:wrap;gap:18px;font-size:12px;color:var(--ink-2);
  padding:12px 16px;background:var(--bg-2);border-radius:6px;
}
.im-scatter__legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:middle}

/* テーブル */
.im-table{width:100%;border-collapse:collapse;font-size:13px}
.im-table th{background:var(--ink);color:#fff;padding:12px;text-align:left;font-weight:600;letter-spacing:.04em}
.im-table td{padding:10px 12px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.im-table tr:nth-child(even){background:var(--bg-2)}
.im-table td:first-child{font-weight:700;color:var(--ink)}

/* 大きい数字統計 */
.im-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.im-stat{background:#fff;border:1px solid var(--line-2);border-left:4px solid var(--accent);border-radius:8px;padding:18px;text-align:center}
.im-stat__big{font-family:var(--serif);font-size:38px;font-weight:700;color:var(--accent);line-height:1;letter-spacing:-.02em}
.im-stat__label{font-size:12px;color:var(--ink-2);font-family:var(--mono);letter-spacing:.04em;margin-top:6px}

/* 引用 */
.im-block--ref{background:linear-gradient(135deg,var(--bg-2),var(--paper))}
.im-citation{
  background:var(--ink);color:#fff;padding:14px 18px;border-radius:6px;
  font-family:var(--mono);font-size:12px;line-height:1.7;letter-spacing:.04em;
  overflow-x:auto;margin:14px 0;
}

/* CTA */
.im-block--cta{background:linear-gradient(135deg,#0b1220,#172238);color:#fff;text-align:center;padding:48px 32px}
.im-block--cta h3{font-family:var(--serif);font-size:28px;color:#fff;margin:0 0 12px;padding:0;border:none}
.im-block--cta p{color:rgba(255,255,255,.85);margin:0 0 24px}
.im-block--cta strong{color:var(--accent)}
.im-block--cta .aff-cta-btn{display:inline-block !important;padding:16px 32px !important;font-size:16px}

@media (max-width:780px){
  .im-bars{grid-template-columns:repeat(4,1fr);gap:8px}
  .im-bars > :nth-child(n+5){display:none}
  .im-pie__row{flex-direction:column;align-items:stretch}
  .im-pie__bar{width:auto !important}
  .im-stats{grid-template-columns:1fr 1fr}
  .im-scatter__chart{height:300px;padding:20px}
}

/* ======= シーンファインダー: PROTOCOL Deal Secondary 専用カード ======= */
.sf-irm{
  background:linear-gradient(135deg,#0b1220 0%,#172238 50%,#2a3a5a 100%);
  color:#fff;border-radius:12px;padding:24px 28px;
  border:1px solid rgba(30,107,74,.4);
  box-shadow:0 12px 32px -8px rgba(11,18,32,.25);
  position:relative;overflow:hidden;
}
.sf-irm::before{
  content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;
  background:radial-gradient(circle,rgba(30,107,74,.18) 0%,transparent 60%);pointer-events:none;
}
.sf-irm__head{position:relative;z-index:1;margin-bottom:14px}
.sf-irm__kicker{
  display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  color:var(--accent);font-weight:600;padding:4px 10px;
  background:rgba(30,107,74,.12);border:1px solid rgba(30,107,74,.3);
  border-radius:4px;margin-bottom:10px;
}
.sf-irm__head h4{
  font-family:var(--serif);font-size:20px;line-height:1.4;color:#fff;font-weight:700;margin:0;
}
.sf-irm__head h4 em{
  font-style:normal;color:var(--accent);
  background:linear-gradient(180deg,transparent 60%,rgba(30,107,74,.22) 60%);padding:0 4px;
}
.sf-irm__lead{
  position:relative;z-index:1;
  font-size:13px;line-height:1.75;color:rgba(255,255,255,.88);margin:0 0 14px;
}
.sf-irm__lead strong{color:var(--accent)}
.sf-irm__features{
  position:relative;z-index:1;list-style:none;padding:0;margin:0 0 18px;
  display:flex;flex-direction:column;gap:6px;
}
.sf-irm__features li{
  font-size:12px;color:rgba(255,255,255,.85);
}
.sf-irm__cta{
  display:block;text-align:center;padding:14px 22px;
  background:linear-gradient(135deg,var(--accent),#1e8a5a);color:var(--ink) !important;
  font-weight:700;font-size:14px;text-decoration:none !important;border-radius:8px;
  box-shadow:0 4px 14px -4px rgba(30,107,74,.5);transition:all .2s;
  position:relative;z-index:1;
}
.sf-irm__cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px -4px rgba(30,107,74,.65)}

/* ======= 業界レポートハブ（ホーム掲載）======= */
.reports-hub{
  background:linear-gradient(180deg,#0b1220 0%,#172238 100%);
  color:#fff;padding:64px 24px 80px;position:relative;overflow:hidden;
}
.reports-hub::before{
  content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  background:radial-gradient(circle,rgba(30,107,74,.14) 0%,transparent 60%);pointer-events:none;
}
.reports-hub__inner{max-width:1100px;margin:0 auto;position:relative;z-index:1}
.reports-hub__head{text-align:center;margin-bottom:36px}
.reports-hub__kicker{
  display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.24em;
  color:var(--accent);font-weight:600;padding:4px 12px;
  background:rgba(30,107,74,.12);border:1px solid rgba(30,107,74,.3);
  border-radius:4px;margin-bottom:16px;
}
.reports-hub__head h2{
  font-family:var(--serif);font-size:36px;color:#fff;font-weight:700;
  margin:0 0 12px;letter-spacing:-.01em;
}
.reports-hub__head h2 em{
  font-style:normal;color:var(--accent);
  background:linear-gradient(180deg,transparent 60%,rgba(30,107,74,.25) 60%);padding:0 6px;
}
.reports-hub__head p{
  font-size:15px;line-height:1.85;color:rgba(255,255,255,.85);margin:0 auto;max-width:640px;
}
.reports-hub__head p strong{color:var(--accent)}

.reports-hub__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:32px;
}
.report-card{
  display:flex;flex-direction:column;
  padding:22px 24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-left:4px solid var(--accent);
  border-radius:8px;
  text-decoration:none !important;color:#fff !important;
  transition:all .2s;gap:6px;
}
.report-card:hover{
  background:rgba(255,255,255,.08);
  transform:translateY(-2px);
  border-left-color:#2f8a60;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.4);
}
.report-card__kicker{
  display:inline-block;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  color:var(--accent);font-weight:600;text-transform:uppercase;
  padding:3px 8px;background:rgba(30,107,74,.12);
  border-radius:3px;align-self:flex-start;
}
.report-card h3{
  font-family:var(--serif);font-size:17px;line-height:1.45;
  color:#fff !important;margin:6px 0 4px;font-weight:700;
}
.report-card p{
  font-size:13px;line-height:1.65;color:rgba(255,255,255,.7);margin:0 0 10px;
}
.report-card__cta{
  display:inline-block;margin-top:auto;font-family:var(--mono);font-size:11px;
  letter-spacing:.06em;color:var(--accent);font-weight:600;
}

.reports-hub__foot{
  text-align:center;padding:18px 22px;
  background:rgba(30,107,74,.08);border:1px dashed rgba(30,107,74,.3);
  border-radius:6px;
}
.reports-hub__foot p{
  font-size:13px;color:rgba(255,255,255,.85);margin:0;line-height:1.7;
}
.reports-hub__foot strong{color:var(--accent)}

@media (max-width:780px){
  .reports-hub__grid{grid-template-columns:1fr}
  .reports-hub__head h2{font-size:26px}
  .reports-hub{padding:48px 18px 56px}
}

/* ======= 金額別ファクタリングガイド（クラスタ相互リンク） ======= */
.amtnav{margin:36px 0 8px;padding:18px 20px;border:1px solid #d6e4dc;border-radius:10px;background:linear-gradient(180deg,#f4faf6,#ffffff)}
.amtnav__title{display:block;font-family:var(--serif);font-weight:700;font-size:16px;color:#1e6b4a;margin-bottom:12px}
.amtnav__links{display:flex;flex-wrap:wrap;gap:8px}
.amtnav__links a,.amtnav__cur{display:inline-flex;align-items:center;justify-content:center;min-width:84px;padding:8px 12px;border-radius:6px;font-size:13.5px;font-weight:700;text-decoration:none;line-height:1}
.amtnav__links a{background:#fff;color:#1e6b4a;border:1px solid #bcd9c9;transition:background .15s,color .15s}
.amtnav__links a:hover{background:#1e6b4a;color:#fff;border-color:#1e6b4a}
.amtnav__cur{background:#1e6b4a;color:#fff;border:1px solid #1e6b4a}
.amtnav__note{margin:12px 0 0;font-size:12.5px;color:#5b6b62}

/* ======= 内部リンク集中：編集部が選ぶ重要ガイド ======= */
.prio-links{margin:32px 0 8px;padding:18px 20px;border:1px solid #e3ddcb;border-left:4px solid #1e6b4a;border-radius:8px;background:#fbfaf5}
.prio-links__title{margin:0 0 12px;font-family:var(--serif,"Noto Serif JP",serif);font-weight:700;font-size:15.5px;color:#0b1220}
.prio-links__list{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.prio-links__list a{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border:1px solid #ece7d8;border-radius:6px;background:#fff;text-decoration:none;transition:border-color .15s,background .15s}
.prio-links__list a:hover{border-color:#1e6b4a;background:#fffdf5}
.prio-links__list strong{font-size:14px;font-weight:700;color:#1f3b73;line-height:1.45}
.prio-links__list span{font-size:12px;color:#687085}

/* ======= 結論ファースト（記事冒頭の即答ボックス） ======= */
.answer-first{margin:8px 0 28px;padding:20px 22px;border:1px solid #cfe0d6;border-left:5px solid #1e6b4a;border-radius:10px;background:linear-gradient(180deg,#f3faf6,#fff)}
.answer-first__label{margin:0 0 10px;font-family:var(--serif,"Noto Serif JP",serif);font-weight:700;font-size:16px;color:#1e6b4a}
.answer-first p{margin:0 0 10px;line-height:1.9;font-size:14.5px;color:#0b1220}
.answer-first ul{margin:6px 0 10px;padding-left:0;list-style:none;display:grid;gap:7px}
.answer-first li{padding:9px 12px;background:#fff;border:1px solid #e3ede7;border-radius:6px;font-size:13.5px;line-height:1.6}
.answer-first__note{margin:8px 0 0 !important;font-size:12.5px;color:#5b6b62}

/* ======= フッター運営会社クレジット ======= */
.ft__corp{margin:10px 0 0;font-size:11.5px;line-height:1.7;color:rgba(255,255,255,.62)}
.ft__corp a{color:rgba(255,255,255,.82);text-decoration:underline;white-space:nowrap}

/* ======= 資金繰りの悩み LPハブ (category-cashflow) ======= */
.cashlp{background:#faf9f4;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cashlp__inner{max-width:var(--maxw);margin:0 auto;padding:40px 20px 44px}
.cashlp__h{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--ink);text-align:center;margin:0 0 26px}
.cashlp__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.cashcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-top:4px solid #1e6b4a;border-radius:10px;padding:22px 22px 20px}
.cashcard--cash{border-top-color:#1e6b4a}
.cashcard--guard{border-top-color:#1e6b4a}
.cashcard--recover{border-top-color:#ea7317}
.cashcard--defer{border-top-color:#1f3b73}
.cashcard__top{margin-bottom:12px}
.cashcard__ic{font-size:28px;line-height:1}
.cashcard__worry{margin:8px 0 2px;font-size:13px;color:#5b6b62}
.cashcard__sol{margin:0;font-family:var(--serif);font-size:20px;font-weight:700;color:var(--ink)}
.cashcard__desc{margin:0 0 12px;font-size:13.5px;line-height:1.85;color:#1f2937}
.cashcard__links{list-style:none;margin:0 0 16px;padding:0;display:grid;gap:6px}
.cashcard__links a{font-size:13px;color:var(--accent-2);text-decoration:none;border-bottom:1px dotted #c7cedd;padding-bottom:1px}
.cashcard__links a:hover{color:#0b1220}
.cashcard__cta{margin-top:auto;display:block;text-align:center;text-decoration:none;background:var(--ink);color:#fff;font-weight:700;font-size:14px;padding:12px 16px;border-radius:7px}
.cashcard--cash .cashcard__cta{background:#1e6b4a}
.cashcard--recover .cashcard__cta{background:#ea7317}
.cashcard--defer .cashcard__cta{background:#1f3b73}
.cashcard__cta--deal{background:#1e6b4a !important}
.cashcard__sub{display:block;text-align:center;margin-top:8px;font-size:12.5px;color:var(--accent-2);text-decoration:none}
.cashcard__note{display:block;text-align:center;margin-top:7px;font-size:11.5px;color:#8a8f9c}
.cashlp__route{text-align:center;margin:26px 0 0;font-size:14px;color:#1f2937}
.cashlp__route a{color:var(--accent-2);font-weight:700}
.catlist__h{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--ink);margin:0 0 18px}
@media(max-width:720px){.cashlp__grid{grid-template-columns:1fr}}

/* ======= 目次 (Rich Table of Content) を編集部デザインに全面リニューアル =======
   プラグインは #rtoc-mokuji-wrapper / #rtoc-mokuji-title / ol.rtoc-mokuji / li.rtoc-item
   を出力する（従来の .rtoc 指定は当たっていなかった）。実クラスに当てて作り直す。 */
.art__body #rtoc-mokuji-wrapper{
  max-width:720px;margin:2.2em 0 !important;padding:0 !important;overflow:hidden;
  background:#fff !important;border:1px solid var(--line) !important;border-radius:12px !important;
  box-shadow:0 2px 10px rgba(11,18,32,.06) !important;font-family:var(--sans) !important;
}
/* タイトル帯（ネイビー＋ゴールド細線） */
.art__body #rtoc-mokuji-title{
  display:flex !important;align-items:center;gap:10px;margin:0 !important;
  padding:15px 22px !important;border:0 !important;
  background:linear-gradient(180deg,#152033,#0b1220) !important;
  border-bottom:2px solid var(--accent) !important;text-align:left !important;
}
.art__body #rtoc-mokuji-title > span{
  font-family:var(--serif) !important;font-weight:700;font-size:16.5px;letter-spacing:.06em;
  color:#fff !important;display:inline-flex;align-items:center;gap:8px;
}
.art__body #rtoc-mokuji-title > span::before{content:"\1F4D1";font-size:15px}
/* 開閉ボタン → 右端の白シェブロン */
.art__body #rtoc-mokuji-title .rtoc_open_close{
  margin-left:auto !important;width:22px;height:22px;background:none !important;border:0 !important;
  cursor:pointer;position:relative;padding:0 !important;
}
.art__body #rtoc-mokuji-title .rtoc_open_close::before{
  content:"";position:absolute;top:4px;left:5px;width:9px;height:9px;
  border-right:2px solid rgba(255,255,255,.85);border-bottom:2px solid rgba(255,255,255,.85);
  transform:rotate(45deg);transition:transform .2s;
}
.art__body #rtoc-mokuji-title .rtoc_open_close.rtoc_close::before{transform:rotate(-135deg);top:8px}

/* 第1階層リスト：カスタム番号バッジ */
.art__body ol.rtoc-mokuji.level-1{
  list-style:none !important;counter-reset:rtoc;margin:0 !important;padding:10px 24px 16px !important;
}
.art__body ol.rtoc-mokuji.level-1 > li.rtoc-item{
  counter-increment:rtoc;position:relative;margin:0 !important;padding:11px 0 11px 40px !important;
  border-bottom:1px dashed var(--line) !important;list-style:none !important;
}
.art__body ol.rtoc-mokuji.level-1 > li.rtoc-item:last-child{border-bottom:0 !important}
.art__body ol.rtoc-mokuji.level-1 > li.rtoc-item::before{
  content:counter(rtoc);position:absolute;left:0;top:10px;
  width:27px;height:27px;display:grid;place-items:center;
  background:#0b1220;color:#fff;border-radius:50%;
  font-family:var(--mono);font-size:12px;font-weight:700;line-height:1;
}
/* リンク */
.art__body #rtoc-mokuji-wrapper .rtoc-item a{
  color:var(--ink) !important;text-decoration:none !important;
  font-size:14.5px;line-height:1.65;font-weight:600;transition:color .15s;
}
.art__body #rtoc-mokuji-wrapper .rtoc-item a:hover{color:var(--accent-2) !important;text-decoration:underline !important}

/* 第2階層：左ガイド線＋ミュート */
.art__body ul.rtoc-mokuji.level-2{
  list-style:none !important;margin:9px 0 2px !important;padding:2px 0 2px 4px !important;
  border-left:2px solid #e6e1d3 !important;
}
.art__body ul.rtoc-mokuji.level-2 > li.rtoc-item{
  position:relative;padding:5px 0 5px 16px !important;border:0 !important;margin:0 !important;list-style:none !important;
}
.art__body ul.rtoc-mokuji.level-2 > li.rtoc-item::before{
  content:"";position:absolute;left:2px;top:13px;width:7px;height:1px;background:var(--mute);
}
.art__body ul.rtoc-mokuji.level-2 .rtoc-item a{font-size:13.5px !important;font-weight:500 !important;color:var(--ink-2) !important}

/* ======= 暗背景セクションの緑アクセントは明るい緑に（緑は暗くて暗背景で潰れる対策） ======= */
.art__finalcta-kicker{color:#5cc99a !important;background:rgba(92,201,154,.14) !important;border-color:rgba(92,201,154,.38) !important}
.art__finalcta p b{color:#5cc99a !important}
.diag__kicker{color:#5cc99a !important}
/* fv-cta（記事冒頭CTA・暗背景）の緑アクセント潰れ対策 */
.art__body .fv-cta__kicker{color:#5cc99a !important;background:rgba(92,201,154,.12) !important;border-color:rgba(92,201,154,.32) !important}
.art__body .fv-cta__title em{color:#5cc99a !important;background:linear-gradient(180deg,transparent 60%,rgba(92,201,154,.22) 60%) !important}
.art__body .fv-cta__lead strong{color:#5cc99a !important}
.art__body .fv-cta__btn--primary{background:linear-gradient(135deg,#2f8a60,#1e6b4a) !important;color:#fff !important}
/* art__finalcta：見出し・本文を確実に明色へ（暗背景で潰れる対策・強制） */
.art__finalcta h3{color:#fff !important;border-left:none !important;padding-left:0 !important}
.art__finalcta p{color:#dbe4f0 !important}
.art__finalcta-sub{color:#dbe4f0 !important}
.art__finalcta p b{color:#5cc99a !important}

/* ===================== v2 可読性 & カード化レイヤー ===================== */
.art__body{font-size:17px;line-height:2.0;color:#283143}
.art__body p{margin:0 0 1.7em;font-size:17px;line-height:2.0;color:#283143}
.art__body > p:first-of-type{font-size:17.5px;color:#1c2433}
/* 見出し：セクション区切りを明確に（緑アクセント・余白広め・重い紺線を廃止） */
.art__body h2{font-size:26px;margin:3.2em 0 1em;padding:0 0 .55em;border-bottom:none !important;position:relative}
.art__body h2::after{content:"";position:absolute;left:0;bottom:0;width:56px;height:4px;background:var(--accent);border-radius:2px}
.art__body h3{font-size:20px;margin:2.4em 0 .8em}
/* 本文直下のリストをソフトカード化（読者がスキャンしやすい） */
.art__body > ul,.art__body > ol{background:#fbfcfa;border:1px solid #e7ebe6;border-left:3px solid var(--accent);border-radius:8px;padding:1.15em 1.3em 1.15em 2.7em;margin:1.7em 0}
.art__body > ul li,.art__body > ol li{margin:.55em 0;line-height:1.9}
/* 段落と見出しの間にもう少し呼吸 */
.art__body h2 + p,.art__body h3 + p{margin-top:.2em}

/* v2 本文サイズUP（読みやすさ優先：18px / 行間2.0） */
.art__body{font-size:18px;line-height:2.0}
.art__body p{font-size:18px;line-height:2.0;margin:0 0 1.75em}
.art__body > p:first-of-type{font-size:18.5px}
.art__body > ul li,.art__body > ol li{font-size:18px;line-height:1.95}
.art__body h3{font-size:21px}
@media(max-width:600px){
  .art__body,.art__body p,.art__body > ul li,.art__body > ol li{font-size:17px}
}

/* ===================== v2 統一ラインアイコン ===================== */
.ic{display:inline-block;vertical-align:middle;flex-shrink:0}
.scene-btn__icon{color:#1e6b4a;display:flex;align-items:center;justify-content:center;line-height:1}
.scene-btn__icon .ic{width:28px;height:28px}
.scene-sub__title{display:flex;align-items:center;gap:8px}
.scene-sub__title .ic{color:#1e6b4a;width:20px;height:20px}
/* v2 アイコン: 目的別カード / クラウン / ピックアップ見出し */
.puc__ic{color:#1e6b4a;display:flex;align-items:center;justify-content:center;line-height:1}
.puc__ic .ic{width:30px;height:30px}
.cr__crown{color:#1e6b4a;display:inline-flex;align-items:center}
.cr__crown .ic{width:16px;height:16px}

/* ===================== 記事内アフィリエイトCTA ===================== */
.aff-cta{margin:2em 0;padding:20px 22px;border:1px solid #cfe0d6;border-radius:12px;background:linear-gradient(135deg,#f3faf6,#fff);box-shadow:0 2px 10px rgba(30,107,74,.08);text-align:center}
.aff-cta__badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;color:#1e6b4a;background:rgba(30,107,74,.1);border:1px solid rgba(30,107,74,.25);border-radius:4px;padding:2px 8px;margin-bottom:10px}
.aff-cta__lead{margin:0 0 14px !important;font-family:var(--serif);font-size:17px;font-weight:700;color:#0b1220;line-height:1.6}
.aff-cta__btn{display:inline-block;background:linear-gradient(180deg,#2f8a60,#1e6b4a);color:#fff !important;font-size:16px;font-weight:700;text-decoration:none !important;padding:15px 30px;border-radius:8px;box-shadow:0 5px 0 #14532d,0 8px 20px rgba(30,107,74,.3);transition:transform .12s,box-shadow .12s}
.aff-cta__btn:hover{transform:translateY(2px);box-shadow:0 3px 0 #14532d,0 6px 14px rgba(30,107,74,.3)}
.aff-cta__note{display:block;margin-top:12px;font-size:12px;color:#5b6b62}
@media(max-width:600px){.aff-cta__btn{font-size:15px;padding:14px 20px;width:100%}}

/* ===================== 図解コンポーネント ===================== */
/* 横フロー（ステップ説明） */
.soken-flow{display:flex;align-items:stretch;gap:6px;margin:1.8em 0;flex-wrap:wrap;justify-content:center}
.soken-flow__step{flex:1;min-width:150px;max-width:230px;text-align:center;background:#fff;border:1px solid #e3ede7;border-radius:12px;padding:18px 14px}
.soken-flow__ic{width:46px;height:46px;margin:0 auto 10px;border-radius:50%;background:#eafaf1;color:#1e6b4a;display:flex;align-items:center;justify-content:center}
.soken-flow__ic .ic{width:24px;height:24px}
.soken-flow__t{font-family:var(--serif);font-weight:700;font-size:14.5px;color:#0b1220;margin-bottom:5px}
.soken-flow__d{font-size:12.5px;color:#5b6b62;line-height:1.65}
.soken-flow__arrow{display:flex;align-items:center;color:#2f8a60;font-weight:700;font-size:22px}
@media(max-width:640px){.soken-flow{flex-direction:column;align-items:stretch}.soken-flow__step{max-width:none}.soken-flow__arrow{justify-content:center;transform:rotate(90deg);height:24px}}
/* 対比図（A↔B） */
.soken-vs{display:flex;gap:12px;margin:1.8em 0;align-items:stretch;flex-wrap:wrap}
.soken-vs__c{flex:1;min-width:200px;border:1px solid #e3ede7;border-radius:12px;padding:18px;background:#fff}
.soken-vs__c--a{border-top:4px solid #1e6b4a}
.soken-vs__c--b{border-top:4px solid #1f3b73}
.soken-vs__h{display:flex;align-items:center;gap:8px;font-family:var(--serif);font-weight:700;font-size:15px;color:#0b1220;margin-bottom:8px}
.soken-vs__dir{font-size:22px;font-weight:800}
.soken-vs__c--a .soken-vs__dir{color:#1e6b4a}
.soken-vs__c--b .soken-vs__dir{color:#1f3b73}
.soken-vs__d{font-size:13px;color:#3a4452;line-height:1.8}

/* ===================== 記事内テーブルのデザイン強化 ===================== */
.art__body table{border:1px solid #dfe5e0 !important;border-radius:10px;box-shadow:0 2px 12px rgba(11,18,32,.06);overflow:hidden}
.art__body table thead th{background:linear-gradient(180deg,#2f8a60,#1e6b4a) !important;color:#fff !important;font-size:13.5px;padding:14px 16px !important;border-bottom:2px solid #185a3e !important;letter-spacing:.03em}
.art__body table th,.art__body table td{padding:13px 16px !important;border-bottom:1px solid #edf0ec !important}
.art__body table tbody tr:nth-child(odd) td{background:#fff !important}
.art__body table tbody tr:nth-child(even) td{background:#f5faf7 !important}
.art__body table tbody tr:hover td{background:#eafaf1 !important}
.art__body table tbody td:first-child{font-weight:700;color:#0b1220}

/* ===================== 見やすさレイヤー（全記事） ===================== */
/* ① セクションの余白（控えめに。ヘアラインは既存H2カードと干渉するため廃止） */
.art__body h2{margin-top:2.4em !important}
.art__body .mib-h2-summary{margin-top:1.2em !important}
/* ② 要点サマリーボックス */
.soken-point{display:flex;gap:12px;align-items:flex-start;margin:1em 0 1.6em;padding:14px 18px;background:#f3faf6;border:1px solid #cfe0d6;border-left:4px solid #1e6b4a;border-radius:0 10px 10px 0}
.soken-point__label{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:12px;font-weight:700;color:#1e6b4a;letter-spacing:.06em;padding-top:2px}
.soken-point__body{font-size:14.5px;line-height:1.85;color:#1f3326;font-weight:600}
/* ③ 比較表：おすすめ行ハイライト＋バッジ＋★ */
.art__body table tbody tr.is-pick td{background:#eafaf1 !important;box-shadow:inset 3px 0 0 #1e6b4a}
.art__body table tbody tr.is-pick td:first-child{position:relative;font-weight:800}
.art__body table tbody tr.is-pick td:first-child::after{content:"編集部おすすめ";display:block;margin-top:3px;font-size:10px;font-weight:700;color:#fff;background:#1e6b4a;border-radius:3px;padding:1px 6px;width:fit-content}
.art__body .star{color:#1e6b4a;font-weight:700;white-space:nowrap}
/* ④ サイドバー追従＋サイドTOC */
@media(min-width:981px){
  .art__side{position:sticky;top:74px;align-self:start;max-height:calc(100vh - 90px);overflow-y:auto}
  .art-side-toc{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:18px;box-shadow:0 2px 8px rgba(11,18,32,.05)}
  .art-side-toc__h{font-family:var(--serif);font-weight:700;font-size:13.5px;color:#1e6b4a;margin:0 0 10px;display:flex;align-items:center;gap:6px}
  .art-side-toc ol{list-style:none;margin:0;padding:0;counter-reset:t}
  .art-side-toc li{counter-increment:t;margin:0 0 7px;line-height:1.5}
  .art-side-toc a{font-size:12.5px;color:#475569;text-decoration:none;display:flex;gap:7px}
  .art-side-toc a::before{content:counter(t);flex-shrink:0;width:17px;height:17px;background:#eafaf1;color:#1e6b4a;border-radius:50%;font-size:10px;font-weight:700;display:grid;place-items:center}
  .art-side-toc a:hover{color:#1e6b4a}
  .art-side-toc a.is-active{color:#1e6b4a;font-weight:700}
}
