/* ヤメコヨミ — サイト共通（ナビ / LINE導線 / 記事 / LP / 比較枠） */

/* ---------------- グローバルナビ ---------------- */

header.site { flex-wrap: wrap; row-gap: 10px; }
a.brand {
  display: flex; align-items: center; gap: 14px;
  color: inherit; text-decoration: none;
}
nav.gnav {
  margin-left: auto;
  display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
nav.gnav a {
  font-size: 0.82rem; letter-spacing: 0.06em;
  color: var(--ink-soft); text-decoration: none;
  padding: 7px 11px; border-radius: 999px;
  transition: all var(--dur) var(--ease);
}
nav.gnav a:hover { color: var(--ink); background: var(--paper-deep); }
nav.gnav a.on { color: var(--shu); font-weight: 700; }
nav.gnav a.nav-line {
  color: #fff; background: #06c755; font-weight: 700;
  padding: 7px 14px;
}
nav.gnav a.nav-line:hover { background: #05b34c; color: #fff; }
@media (max-width: 560px) {
  nav.gnav { margin-left: 0; width: 100%; justify-content: flex-start; }
}

/* ---------------- フローティングLINE ---------------- */

.line-float {
  position: fixed; right: 16px; bottom: 18px; z-index: 50;
  display: flex; align-items: center; gap: 8px;
  background: #06c755; color: #fff;
  font-weight: 700; font-size: 0.9rem; letter-spacing: 0.04em;
  padding: 13px 18px; border-radius: 999px;
  text-decoration: none;
  box-shadow: 0 10px 30px -10px #06c75599, 0 2px 6px #1d243333;
  opacity: 0; transform: translateY(14px); pointer-events: none;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.line-float.show { opacity: 1; transform: none; pointer-events: auto; }
.line-float:hover { background: #05b34c; }
.line-float .lf-badge {
  background: #fff; color: #06c755; border-radius: 50%;
  width: 26px; height: 26px; display: grid; place-items: center;
  font-size: 14px; flex: none;
}

/* ---------------- 結果画面・記事内のLINE CTA ---------------- */

.line-cta {
  margin: 2rem 0; padding: 26px 24px;
  background: linear-gradient(135deg, #0b3d24, #14532d);
  border-radius: 6px; color: #f0fdf4;
  position: relative; overflow: hidden;
}
.line-cta::after {
  content: "暦"; position: absolute; right: -14px; bottom: -34px;
  font-family: var(--serif); font-size: 9rem; color: #ffffff10;
  pointer-events: none;
}
.line-cta h4 { font-family: var(--serif); font-size: 1.2rem; letter-spacing: 0.06em; margin-bottom: 6px; }
.line-cta p { font-size: 0.88rem; color: #d2ecdb; max-width: 34em; }
.line-cta ul { list-style: none; margin: 12px 0 4px; display: grid; gap: 6px; }
.line-cta li { font-size: 0.86rem; padding-left: 1.4em; position: relative; }
.line-cta li::before { content: "✓"; position: absolute; left: 0; color: #6ee7a0; font-weight: 700; }
.line-cta .btn-line {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 16px;
  background: #06c755; color: #fff; text-decoration: none;
  font-weight: 700; font-size: 1rem;
  padding: 14px 28px; border-radius: 999px;
  box-shadow: 0 8px 22px -8px #06c755cc;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.line-cta .btn-line:hover { background: #05b34c; transform: translateY(-2px); }
.line-cta .sub { font-size: 0.74rem; color: #9fd4b2; margin-top: 10px; }

/* ---------------- パンくず・記事 ---------------- */

.crumb { font-size: 0.76rem; color: var(--ink-soft); margin: 1.4rem 0 0; }
.crumb a { color: inherit; }

article.prose { padding: 1.2rem 0 0; }
article.prose .a-head { padding: 1.2rem 0 0.4rem; }
article.prose h1 {
  font-family: var(--serif); font-weight: 700;
  font-size: clamp(1.55rem, 1.1rem + 2.6vw, 2.4rem);
  line-height: 1.5; letter-spacing: 0.03em;
}
article.prose .a-meta { font-size: 0.78rem; color: var(--ink-soft); margin-top: 0.8rem; }
article.prose h2 {
  font-family: var(--serif); font-size: 1.3rem; letter-spacing: 0.08em;
  margin: 3.2rem 0 1rem; padding-left: 14px;
  border-left: 4px solid var(--shu);
}
article.prose h3 {
  font-family: var(--serif); font-size: 1.05rem;
  margin: 2.2rem 0 0.8rem;
}
article.prose p { margin: 0 0 1.1rem; }
article.prose ul, article.prose ol { margin: 0 0 1.2rem 1.4em; }
article.prose li { margin-bottom: 0.4rem; }
article.prose strong { background: linear-gradient(transparent 72%, var(--shu-soft) 72%); }
article.prose table {
  width: 100%; border-collapse: collapse; margin: 1.2rem 0 1.6rem;
  background: #fffdf6; border: 1px solid var(--rule); font-size: 0.88rem;
}
article.prose th, article.prose td { border: 1px solid var(--rule); padding: 9px 12px; text-align: left; }
article.prose thead th { background: var(--ink); color: var(--paper); font-weight: 500; letter-spacing: 0.05em; }
article.prose .tbl-note { font-size: 0.74rem; color: var(--ink-soft); margin-top: -0.8rem; }

.callout {
  margin: 1.4rem 0; padding: 16px 18px;
  border-left: 4px solid var(--gold); background: #fdf8ec;
  font-size: 0.9rem; border-radius: 0 4px 4px 0;
}
.callout.shu { border-color: var(--shu); background: var(--shu-soft); }

/* ツールへ誘導するCTA */
.tool-cta {
  margin: 2.2rem 0; padding: 24px;
  border: 1.5px solid var(--ink); border-radius: 6px;
  background: #fffdf6; text-align: center;
}
.tool-cta p { font-family: var(--serif); font-weight: 700; font-size: 1.05rem; margin-bottom: 14px; }
.tool-cta a {
  display: inline-block;
  background: var(--ink); color: var(--paper); text-decoration: none;
  font: 700 0.98rem var(--serif); letter-spacing: 0.2em; text-indent: 0.2em;
  padding: 14px 34px; border-radius: 3px;
  transition: transform var(--dur) var(--ease);
}
.tool-cta a:hover { transform: translateY(-2px); }
.tool-cta .sub { font-family: var(--sans); font-weight: 400; font-size: 0.76rem; color: var(--ink-soft); margin-top: 10px; }

/* ---------------- LPヒーロー・比較カード ---------------- */

.lp-hero { padding: calc(var(--space-section) * 0.7) 0 1rem; }
.lp-hero .kicker { font-size: 0.78rem; letter-spacing: 0.3em; color: var(--shu); font-family: var(--serif); }
.lp-hero h1 {
  font-family: var(--serif); font-weight: 700;
  font-size: clamp(1.6rem, 1.1rem + 2.8vw, 2.5rem);
  line-height: 1.5; margin: 0.5rem 0 1rem;
}
.lp-hero .lede { color: var(--ink-soft); max-width: 38em; }

.offers { display: grid; gap: 16px; margin: 1.6rem 0; }
.offer {
  background: #fffdf6; border: 1px solid var(--rule); border-radius: 6px;
  padding: 22px 24px; position: relative;
  display: grid; gap: 8px;
}
.offer.reco { border: 2px solid var(--shu); }
.offer .o-badge {
  position: absolute; top: -11px; left: 18px;
  font-size: 0.7rem; letter-spacing: 0.15em;
  background: var(--shu); color: #fff; padding: 2px 12px; border-radius: 2px;
}
.offer h3 { font-family: var(--serif); font-size: 1.1rem; }
.offer .o-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.offer .o-tags span {
  font-size: 0.7rem; border: 1px solid var(--rule); border-radius: 999px;
  padding: 2px 10px; color: var(--ink-soft); background: var(--paper);
}
.offer p { font-size: 0.86rem; color: var(--ink-soft); }
.offer .offer-cta {
  justify-self: start;
  display: inline-block; text-decoration: none;
  background: var(--shu); color: #fff; font-weight: 700; font-size: 0.92rem;
  padding: 12px 26px; border-radius: 999px;
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.offer .offer-cta:hover { transform: translateY(-2px); }
.offer .offer-cta.offer-pending {
  background: var(--paper-deep); color: var(--ink-soft); cursor: default; pointer-events: none;
}
.offer .o-note { font-size: 0.7rem; color: var(--ink-soft); }

/* 選び方フローチャート風 */
.howto { counter-reset: step; margin: 1.4rem 0; display: grid; gap: 12px; }
.howto .step {
  background: #fffdf6; border: 1px solid var(--rule); border-radius: 4px;
  padding: 16px 18px 16px 58px; position: relative; font-size: 0.92rem;
}
.howto .step::before {
  counter-increment: step; content: counter(step);
  position: absolute; left: 16px; top: 14px;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ink); color: var(--paper);
  font-family: var(--serif); font-weight: 700;
  display: grid; place-items: center; font-size: 0.9rem;
}
.howto .step b { display: block; margin-bottom: 2px; }

/* ホームのガイドカード */
.guide-cards { display: grid; gap: 14px; grid-template-columns: 1fr; margin-top: 1rem; }
@media (min-width: 620px) { .guide-cards { grid-template-columns: 1fr 1fr; } }
.gcard {
  display: block; text-decoration: none; color: inherit;
  background: #fffdf6; border: 1px solid var(--rule); border-radius: 6px;
  padding: 20px 22px;
  transition: all var(--dur) var(--ease);
}
.gcard:hover { border-color: var(--shu); transform: translateY(-2px); box-shadow: 0 12px 28px -18px #1d243366; }
.gcard .g-kicker { font-size: 0.72rem; letter-spacing: 0.2em; color: var(--shu); font-family: var(--serif); }
.gcard h4 { font-family: var(--serif); font-size: 1.02rem; margin: 4px 0 6px; line-height: 1.6; }
.gcard p { font-size: 0.82rem; color: var(--ink-soft); }

/* フッターのナビ */
.f-nav { display: flex; flex-wrap: wrap; gap: 4px 18px; margin: 0.6rem 0 1.2rem; }
.f-nav a { color: var(--ink-soft); font-size: 0.78rem; }

/* 404 */
.err-hero { text-align: center; padding: var(--space-section) 0; }
.err-hero .code { font-family: var(--serif); font-size: 5rem; color: var(--shu); font-weight: 700; }

/* ---------------- 内訳テーブルの追加行（会社都合差額） ---------------- */

table.breakdown tr.alt th, table.breakdown tr.alt td {
  background: #fdf8ec;
  color: var(--ink);
  border-top: 1px dashed var(--gold);
}
table.breakdown tr.alt td { font-weight: 700; color: var(--shu); }
.qlink {
  display: inline-block; margin-left: 8px;
  font-size: 0.7rem; font-weight: 400; letter-spacing: 0.08em;
  color: var(--shu); border: 1px solid var(--shu); border-radius: 999px;
  padding: 1px 9px; text-decoration: none; vertical-align: 1px;
}
.qlink:hover { background: var(--shu); color: #fff; }
.cell-sub { display: block; font-size: 0.7rem; font-weight: 400; color: var(--ink-soft); }
