/**
 * iCraft Pages — 下層ページ共通のダークコンポーネント
 * 非フロントページで読み込み。Phaseごとにここへ追記していく。
 */

/* ==========================================================================
   1. ページヒーロー（icraft_page_hero）
   ========================================================================== */

.ic-page-hero {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--line-1);
}

.ic-page-hero__inner {
  position: relative;
  z-index: 2;
  padding: clamp(3rem, 2rem + 4vw, 5.5rem) 0 clamp(3.5rem, 2.5rem + 5vw, 7rem);
}

.ic-page-hero--compact .ic-page-hero__inner {
  padding: clamp(2rem, 1.5rem + 2vw, 3rem) 0 clamp(2.5rem, 2rem + 2.5vw, 4rem);
}

.ic-page-hero__ghost {
  position: absolute;
  right: -0.04em;
  bottom: -0.16em;
  z-index: 1;
  opacity: 0.5;
}

.ic-page-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.ic-page-hero__bg img {
  opacity: 0.4;
}

.ic-page-hero__bg::after {
  background: linear-gradient(180deg, rgba(18, 19, 21, 0.55), rgba(18, 19, 21, 0.85));
}

.ic-page-hero .breadcrumb {
  margin: 0 0 clamp(1.5rem, 1rem + 2vw, 2.5rem);
  color: var(--paper-500);
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
}

.ic-page-hero .breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.ic-page-hero .breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: color var(--dur-1) var(--ease-out);
}

.ic-page-hero .breadcrumb a:hover {
  color: var(--accent);
}

.ic-page-hero .breadcrumb__sep {
  opacity: 0.5;
}

.ic-page-hero__kicker {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 clamp(1rem, 0.75rem + 1vw, 1.5rem);
  color: var(--accent);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.22em;
  line-height: 1;
  text-transform: uppercase;
}

.ic-page-hero__kicker::before {
  content: "";
  display: inline-block;
  width: 40px;
  height: 1px;
  background: var(--accent);
}

.ic-page-hero__title {
  margin: 0;
  font-size: var(--fs-h1);
  font-weight: 900;
  letter-spacing: 0.02em;
  line-height: 1.25;
  color: var(--paper-100);
}

.ic-page-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
}

.ic-page-hero__lead {
  max-width: 34em;
  margin: clamp(1.25rem, 1rem + 1vw, 1.75rem) 0 0;
  color: var(--paper-300);
  font-size: var(--fs-lead);
  line-height: 1.9;
  letter-spacing: 0.03em;
}

/* ==========================================================================
   2. セクション基礎（下層）
   ========================================================================== */

.icraft-page--dark .ic-section {
  position: relative;
  padding: var(--section-py) 0;
}

.icraft-page--dark .ic-section--tight {
  padding: calc(var(--section-py) * 0.55) 0;
}

.icraft-page--dark .ic-section--alt {
  background: var(--ink-850);
}

.icraft-page--dark .ic-section--deep {
  background: var(--ink-950);
  border-top: 1px solid var(--line-1);
  border-bottom: 1px solid var(--line-1);
}

/* ==========================================================================
   3. ページ内スティッキーナビ
   ========================================================================== */

.ic-subnav {
  position: sticky;
  top: var(--header-h);
  z-index: 20;
  border-bottom: 1px solid var(--line-1);
  background: rgba(18, 19, 21, 0.88);
}

@supports (backdrop-filter: blur(12px)) {
  .ic-subnav {
    background: rgba(18, 19, 21, 0.72);
    backdrop-filter: blur(12px);
  }
}

.ic-subnav__inner {
  display: flex;
  gap: 4px;
  overflow-x: auto;
  scrollbar-width: none;
}

.ic-subnav__inner::-webkit-scrollbar {
  display: none;
}

.ic-subnav a {
  flex: none;
  display: inline-flex;
  align-items: center;
  min-height: 52px;
  padding: 0 18px;
  color: var(--paper-500);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-decoration: none;
  background: linear-gradient(var(--accent), var(--accent)) center bottom / 0% 2px no-repeat;
  transition: color var(--dur-1) var(--ease-out), background-size 0.35s var(--ease-out);
}

.ic-subnav a:hover {
  color: var(--paper-100);
  background-size: 100% 2px;
}

/* ==========================================================================
   4. スペックシート（材料・工法仕様表）
   ========================================================================== */

.ic-spec {
  border-top: 1px solid var(--line-2);
}

.ic-spec__row {
  display: grid;
  grid-template-columns: minmax(140px, 220px) 1fr;
  gap: 16px clamp(1.5rem, 1rem + 2vw, 3rem);
  padding: 18px 0;
  border-bottom: 1px solid var(--line-1);
}

.ic-spec__label {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ic-spec__label-en {
  color: var(--paper-500);
  font-family: var(--font-en);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.ic-spec__label-ja {
  color: var(--paper-300);
  font-size: var(--fs-sm);
  font-weight: 700;
}

.ic-spec__value {
  margin: 0;
  color: var(--paper-100);
  font-size: var(--fs-body);
  font-feature-settings: "tnum" 1;
  line-height: 1.9;
}

@media (max-width: 640px) {
  .ic-spec__row {
    grid-template-columns: 1fr;
    gap: 6px;
  }
}

/* ==========================================================================
   5. 課題リスト（ISSUES — 課題と答えの対）
   ========================================================================== */

.ic-issues {
  display: grid;
  gap: 1px;
  background: var(--line-1);
  border: 1px solid var(--line-1);
}

.ic-issue {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px clamp(1.25rem, 1rem + 1.5vw, 2.5rem);
  padding: clamp(1.75rem, 1.25rem + 2vw, 2.75rem);
  background: var(--ink-900);
}

.ic-issue__num {
  grid-row: 1 / 3;
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: var(--fs-h2);
  font-weight: 700;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px var(--line-2);
}

.ic-issue.is-inview .ic-issue__num,
.ic-issue:hover .ic-issue__num {
  color: var(--accent);
  -webkit-text-stroke-color: transparent;
  transition: color var(--dur-3) var(--ease-out);
}

.ic-issue__q {
  margin: 0;
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--paper-100);
}

.ic-issue__a {
  grid-column: 2;
  margin: 0;
  color: var(--paper-500);
  font-size: var(--fs-body);
  line-height: 2;
}

@media (max-width: 767px) {
  .ic-issue {
    grid-template-columns: 1fr;
  }

  .ic-issue__num {
    grid-row: auto;
  }

  .ic-issue__a {
    grid-column: 1;
  }
}

/* ==========================================================================
   6. スコープ（対応範囲 2カラム）
   ========================================================================== */

.ic-scope {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  gap: clamp(2rem, 1.5rem + 3vw, 4rem);
  align-items: start;
}

.ic-scope__heading {
  margin: 0 0 20px;
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--paper-100);
}

.ic-scope__list {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--line-1);
}

.ic-scope__list li {
  position: relative;
  padding: 16px 0 16px 30px;
  border-bottom: 1px solid var(--line-1);
  color: var(--paper-300);
  font-size: var(--fs-body);
  line-height: 1.9;
}

.ic-scope__list li::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 1.35em;
  width: 14px;
  height: 1px;
  background: var(--accent);
}

.ic-scope__side {
  padding: clamp(1.5rem, 1.25rem + 1.5vw, 2.5rem);
  border: 1px solid var(--line-1);
  border-left: 3px solid var(--accent);
  background: var(--ink-850);
}

.ic-scope__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ic-scope__tags span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 6px 16px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-full);
  color: var(--paper-300);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
}

@media (max-width: 1023px) {
  .ic-scope {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   7. アコーディオン（FAQ）
   ========================================================================== */

.ic-accordion {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--line-1);
}

.ic-accordion details {
  border-bottom: 1px solid var(--line-1);
}

.ic-accordion summary {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: clamp(1rem, 0.75rem + 1vw, 1.75rem);
  padding: clamp(1.25rem, 1rem + 1vw, 1.75rem) 4px;
  cursor: pointer;
  list-style: none;
  color: var(--paper-100);
  font-size: var(--fs-body);
  font-weight: 700;
  line-height: 1.8;
  transition: color var(--dur-1) var(--ease-out);
}

.ic-accordion summary::-webkit-details-marker {
  display: none;
}

.ic-accordion summary:hover {
  color: var(--accent);
}

.ic-accordion .ic-accordion__glyph {
  font-family: var(--font-en);
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}

.ic-accordion summary::after {
  content: "+";
  justify-self: end;
  font-family: var(--font-en);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--paper-500);
  line-height: 1;
  transition: transform 0.35s var(--ease-out), color var(--dur-1) var(--ease-out);
}

.ic-accordion details[open] summary::after {
  transform: rotate(45deg);
  color: var(--accent);
}

.ic-accordion details[open] summary {
  color: var(--paper-100);
}

.ic-accordion__body {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1rem, 0.75rem + 1vw, 1.75rem);
  padding: 0 4px clamp(1.5rem, 1.25rem + 1vw, 2rem);
}

.ic-accordion__body .ic-accordion__glyph {
  color: var(--paper-500);
}

.ic-accordion__body p {
  margin: 0;
  color: var(--paper-300);
  line-height: 2;
}

/* ==========================================================================
   8. サービスハブ: 大判インデックス行
   ========================================================================== */

.ic-index {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--line-1);
}

.ic-index__row {
  display: grid;
  grid-template-columns: auto minmax(0, 5fr) minmax(0, 6fr) auto;
  align-items: center;
  gap: clamp(1.25rem, 1rem + 2vw, 3rem);
  padding: clamp(1.75rem, 1.25rem + 2.5vw, 3rem) 8px;
  border-bottom: 1px solid var(--line-1);
  text-decoration: none;
  transition: background var(--dur-2) var(--ease-out);
}

.ic-index__row:hover {
  background: var(--ink-850);
}

.ic-index__num {
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: var(--fs-h1);
  font-weight: 700;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px var(--line-2);
  transition: color var(--dur-2) var(--ease-out);
}

.ic-index__row:hover .ic-index__num {
  color: var(--accent);
  -webkit-text-stroke-color: transparent;
}

.ic-index__en {
  display: block;
  margin: 0 0 8px;
  color: var(--accent);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.22em;
  line-height: 1;
  text-transform: uppercase;
}

.ic-index__title {
  margin: 0;
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--paper-100);
}

.ic-index__sub {
  display: block;
  margin: 6px 0 0;
  color: var(--paper-500);
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
}

.ic-index__text {
  margin: 0;
  color: var(--paper-500);
  font-size: var(--fs-sm);
  line-height: 1.9;
}

.ic-index__swatches {
  display: flex;
  gap: 6px;
  margin-top: 12px;
}

.ic-index__swatches .ic-swatch {
  width: 22px;
  height: 22px;
}

.ic-index__arrow {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-full);
  color: var(--paper-100);
  transition:
    background var(--dur-2) var(--ease-out),
    border-color var(--dur-2) var(--ease-out),
    color var(--dur-2) var(--ease-out),
    transform var(--dur-2) var(--ease-out-expo);
}

.ic-index__row:hover .ic-index__arrow {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
  transform: translateX(4px);
}

@media (max-width: 1023px) {
  .ic-index__row {
    grid-template-columns: auto 1fr auto;
  }

  .ic-index__text {
    display: none;
  }
}

/* ==========================================================================
   9. 汎用: 2カラムsticky（intro等）・ミニリンク列
   ========================================================================== */

.ic-split {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: clamp(2.5rem, 2rem + 4vw, 6rem);
  align-items: start;
}

.ic-split__sticky {
  position: sticky;
  top: calc(var(--header-h) + 40px);
}

.ic-split__statement {
  margin: 0;
  font-size: var(--fs-h2);
  font-weight: 700;
  color: var(--paper-100);
}

.ic-split__body p {
  margin: 0 0 1.5em;
  color: var(--paper-300);
  line-height: 2.1;
}

.ic-split__body p:last-of-type {
  margin-bottom: 0;
}

@media (max-width: 1023px) {
  .ic-split {
    grid-template-columns: 1fr;
  }

  .ic-split__sticky {
    position: static;
  }
}

.ic-minilinks {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: var(--space-8);
}

.ic-minilinks a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 8px 18px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-full);
  color: var(--paper-300);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
  text-decoration: none;
  transition:
    border-color var(--dur-1) var(--ease-out),
    color var(--dur-1) var(--ease-out),
    background var(--dur-1) var(--ease-out);
}

.ic-minilinks a:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(199, 162, 99, 0.06);
}

/* サブナビがある場合はアンカー着地位置をさらに下げる */
html:has(.ic-subnav) {
  scroll-padding-top: calc(var(--header-h) + 60px);
}

/* Process 5ステップ版・3ステップ版 */
@media (min-width: 768px) {
  .ic-process--five {
    grid-template-columns: repeat(5, 1fr);
  }

  .ic-process--five .ic-process__item:nth-child(5)::after {
    transition-delay: 0.6s;
  }

  .ic-process--three {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* フィルタで隠すカード（hidden属性はdisplay:flexに負けるため属性セレクタで担保） */
.icraft-page--dark .icraft-card[hidden],
.icraft-page--dark .icraft-card.is-filtered-out {
  display: none;
}

/* スクリーンリーダー専用テキスト */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* サイドボックスのプレーンリスト（リンクなし） */
.ic-sidebox__list--plain li {
  padding: 11px 2px;
  color: var(--paper-300);
  font-size: var(--fs-sm);
  line-height: 1.7;
}

/* ==========================================================================
   P3-1. フィルタピル（works/columnアーカイブ）
   ========================================================================== */

.ic-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 var(--space-10);
}

.ic-filter__button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 8px 18px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--paper-300);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-decoration: none;
  cursor: pointer;
  transition:
    border-color var(--dur-1) var(--ease-out),
    color var(--dur-1) var(--ease-out),
    background var(--dur-1) var(--ease-out);
}

.ic-filter__button span {
  color: var(--paper-500);
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: var(--fs-xs);
}

.ic-filter__button:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.ic-filter__button.is-active {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--accent-ink);
}

.ic-filter__button.is-active span {
  color: var(--accent-ink);
  opacity: 0.7;
}

/* ==========================================================================
   P3-2. ページネーション（ダーク）
   ========================================================================== */

.icraft-page--dark .icraft-pagination {
  margin-top: var(--space-12);
}

.icraft-page--dark .icraft-pagination .nav-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}

.icraft-page--dark .icraft-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-xs);
  color: var(--paper-300);
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: var(--fs-sm);
  text-decoration: none;
  transition:
    border-color var(--dur-1) var(--ease-out),
    color var(--dur-1) var(--ease-out),
    background var(--dur-1) var(--ease-out);
}

.icraft-page--dark .icraft-pagination .page-numbers:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.icraft-page--dark .icraft-pagination .page-numbers.current {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--accent-ink);
}

.icraft-page--dark .icraft-pagination .page-numbers.dots {
  border: 0;
}

/* ==========================================================================
   P3-3. サイドボックス・2カラムレイアウト（ダーク）
   ========================================================================== */

.ic-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: clamp(2rem, 1.5rem + 2vw, 3rem);
  align-items: start;
}

.ic-layout__side {
  position: sticky;
  top: calc(var(--header-h) + 24px);
  display: grid;
  gap: 16px;
}

.ic-sidebox {
  padding: 24px;
  border: 1px solid var(--line-1);
  border-radius: var(--radius-xs);
  background: var(--ink-850);
}

.ic-sidebox--cta {
  border-left: 3px solid var(--accent);
}

.ic-sidebox__title {
  margin: 0 0 14px;
  color: var(--accent);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.22em;
  line-height: 1.4;
  text-transform: uppercase;
}

.ic-sidebox__title--ja {
  font-family: var(--font-display);
  font-feature-settings: "palt" 1;
  color: var(--paper-100);
  font-size: var(--fs-body);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: none;
}

.ic-sidebox p {
  margin: 0 0 16px;
  color: var(--paper-500);
  font-size: var(--fs-sm);
  line-height: 1.9;
}

.ic-sidebox .icraft-button {
  width: 100%;
}

.ic-sidebox__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ic-sidebox__list li {
  border-bottom: 1px solid var(--line-1);
}

.ic-sidebox__list li:last-child {
  border-bottom: 0;
}

.ic-sidebox__list a {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 2px;
  color: var(--paper-300);
  font-size: var(--fs-sm);
  line-height: 1.7;
  text-decoration: none;
  transition: color var(--dur-1) var(--ease-out);
}

.ic-sidebox__list a:hover {
  color: var(--accent);
}

.ic-sidebox__list em,
.ic-sidebox__list time {
  flex: none;
  color: var(--paper-500);
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: var(--fs-xs);
  font-style: normal;
}

@media (max-width: 1023px) {
  .ic-layout {
    grid-template-columns: 1fr;
  }

  .ic-layout__side {
    position: static;
  }
}

/* ==========================================================================
   P3-4. 記事本文（明るいサーフェス）— column single
   ダークフレームの中に「紙」を置く。長文可読性を最優先。
   ========================================================================== */

.ic-article-surface {
  --article-bg: #F7F5F0;
  --article-text: #26292D;
  --article-muted: #6B675F;
  --article-line: rgba(38, 41, 45, 0.12);
  padding: clamp(1.75rem, 1.25rem + 2.5vw, 3.5rem);
  border-radius: var(--radius-xs);
  background: var(--article-bg);
  color: var(--article-text);
}

.ic-article-summary {
  margin: 0 0 clamp(1.75rem, 1.5rem + 1vw, 2.5rem);
  padding: 20px 24px;
  border-left: 3px solid var(--accent-deep);
  background: rgba(199, 162, 99, 0.08);
}

.ic-article-summary__label {
  margin: 0 0 6px;
  color: var(--accent-deep);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.ic-article-summary p {
  margin: 0;
  color: var(--article-text);
  font-size: var(--fs-sm);
  line-height: 1.95;
}

/* 記事本文タイポグラフィ */
.ic-article-surface .icraft-entry {
  font-size: 1.0625rem;
  line-height: 1.95;
  letter-spacing: 0.03em;
  color: var(--article-text);
}

.ic-article-surface .icraft-entry > * {
  margin-top: 0;
  margin-bottom: 1.6em;
}

.ic-article-surface .icraft-entry :is(h2, h3, h4) {
  font-family: var(--font-display);
  font-feature-settings: "palt" 1;
  letter-spacing: 0.03em;
  line-height: 1.5;
  color: #1C1E20;
  text-wrap: balance;
}

.ic-article-surface .icraft-entry h2 {
  position: relative;
  margin-top: 2.6em;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--article-line);
  font-size: clamp(1.375rem, 1.25rem + 0.6vw, 1.75rem);
  font-weight: 700;
}

.ic-article-surface .icraft-entry h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 56px;
  height: 2px;
  background: var(--accent-deep);
}

.ic-article-surface .icraft-entry h3 {
  margin-top: 2.2em;
  padding-left: 14px;
  border-left: 3px solid var(--accent-deep);
  font-size: clamp(1.1875rem, 1.1rem + 0.4vw, 1.375rem);
  font-weight: 700;
}

.ic-article-surface .icraft-entry h4 {
  margin-top: 2em;
  font-size: 1.0625rem;
  font-weight: 700;
}

.ic-article-surface .icraft-entry a {
  color: var(--accent-deep);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color var(--dur-1) var(--ease-out);
}

.ic-article-surface .icraft-entry a:hover {
  color: #6E5730;
}

.ic-article-surface .icraft-entry :is(ul, ol) {
  padding-left: 1.6em;
}

.ic-article-surface .icraft-entry li {
  margin-bottom: 0.5em;
}

.ic-article-surface .icraft-entry li::marker {
  color: var(--accent-deep);
}

.ic-article-surface .icraft-entry blockquote {
  margin: 2em 0;
  padding: 18px 24px;
  border-left: 3px solid var(--accent-deep);
  background: rgba(38, 41, 45, 0.04);
  color: var(--article-muted);
  font-style: normal;
}

.ic-article-surface .icraft-entry blockquote > *:last-child {
  margin-bottom: 0;
}

/* テーブル: モバイル横スクロール */
.ic-article-surface .icraft-entry table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  line-height: 1.8;
}

.ic-article-surface .icraft-entry .ic-table-scroll,
.ic-article-surface .icraft-entry figure.wp-block-table {
  overflow-x: auto;
  margin: 2em 0;
}

.ic-article-surface .icraft-entry :is(th, td) {
  padding: 12px 16px;
  border: 1px solid var(--article-line);
  text-align: left;
  vertical-align: top;
  min-width: 8em;
}

.ic-article-surface .icraft-entry th {
  background: rgba(38, 41, 45, 0.05);
  font-weight: 700;
  white-space: nowrap;
}

.ic-article-surface .icraft-entry img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-xs);
}

.ic-article-surface .icraft-entry :is(code, pre) {
  font-size: 0.9em;
}

/* SWELL自動目次（.p-toc）のリスタイル */
.ic-article-surface .p-toc {
  margin: 2.4em 0;
  padding: 24px 28px;
  border: 1px solid var(--article-line);
  border-radius: var(--radius-xs);
  background: rgba(38, 41, 45, 0.03);
}

.ic-article-surface .p-toc__title {
  margin: 0 0 12px;
  color: #1C1E20;
  font-family: var(--font-display);
  font-feature-settings: "palt" 1;
  font-size: var(--fs-body);
  font-weight: 700;
  letter-spacing: 0.06em;
}

.ic-article-surface .p-toc__title::before,
.ic-article-surface .p-toc__title::after {
  content: none;
}

.ic-article-surface .p-toc a {
  color: var(--article-text);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color var(--dur-1) var(--ease-out);
}

.ic-article-surface .p-toc a:hover {
  color: var(--accent-deep);
}

.ic-article-surface .p-toc ol {
  counter-reset: none;
}

.ic-article-surface .p-toc li::marker {
  color: var(--accent-deep);
}

/* 前後記事ナビ */
.ic-post-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px solid var(--article-line);
}

.ic-article-surface .ic-post-nav a {
  color: var(--article-muted);
  font-size: var(--fs-sm);
  line-height: 1.7;
  text-decoration: none;
}

.ic-article-surface .ic-post-nav a:hover {
  color: var(--accent-deep);
}

.ic-post-nav > div:last-child {
  text-align: right;
}

@media (max-width: 640px) {
  .ic-post-nav {
    grid-template-columns: 1fr;
  }

  .ic-post-nav > div:last-child {
    text-align: left;
  }
}

/* ==========================================================================
   P3-5. 記事末: 関連サービスカード
   ========================================================================== */

.ic-service-link {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(1rem, 0.75rem + 1vw, 2rem);
  margin-top: var(--space-8);
  padding: clamp(1.25rem, 1rem + 1.5vw, 2rem);
  border: 1px solid var(--line-1);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-xs);
  background: var(--ink-850);
  text-decoration: none;
  transition: background var(--dur-2) var(--ease-out);
}

.ic-service-link:hover {
  background: var(--ink-800);
}

.ic-service-link__kicker {
  margin: 0;
  color: var(--accent);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
}

.ic-service-link__title {
  margin: 0 0 4px;
  color: var(--paper-100);
  font-size: var(--fs-h3);
  font-weight: 700;
}

.ic-service-link__text {
  margin: 0;
  color: var(--paper-500);
  font-size: var(--fs-sm);
  line-height: 1.8;
}

.ic-service-link__arrow {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-full);
  color: var(--paper-100);
  transition:
    background var(--dur-2) var(--ease-out),
    border-color var(--dur-2) var(--ease-out),
    color var(--dur-2) var(--ease-out);
}

.ic-service-link:hover .ic-service-link__arrow {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}

@media (max-width: 640px) {
  .ic-service-link {
    grid-template-columns: 1fr auto;
  }

  .ic-service-link__kicker {
    display: none;
  }
}

/* ==========================================================================
   P3-6. works グリッド・アーカイブ見出し行
   ========================================================================== */

.ic-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 0.75rem + 1vw, 1.5rem);
}

@media (max-width: 1023px) {
  .ic-archive-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .ic-archive-grid {
    grid-template-columns: 1fr;
  }
}

/* works single: ハイライト行 */
.ic-highlights {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line-1);
  border: 1px solid var(--line-1);
  margin: var(--space-10) 0;
}

.ic-highlight {
  padding: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
  background: var(--ink-900);
}

.ic-highlight__num {
  display: block;
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: var(--fs-h2);
  font-weight: 700;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px var(--line-2);
}

.ic-highlight__title {
  margin: 14px 0 8px;
  font-size: var(--fs-body);
  font-weight: 700;
  color: var(--paper-100);
}

.ic-highlight__text {
  margin: 0;
  color: var(--paper-500);
  font-size: var(--fs-sm);
  line-height: 1.9;
}

@media (max-width: 767px) {
  .ic-highlights {
    grid-template-columns: 1fr;
  }
}

/* works single: 本文パネル */
.ic-work-body {
  padding: clamp(1.5rem, 1.25rem + 1.5vw, 2.5rem);
  border: 1px solid var(--line-1);
  border-radius: var(--radius-xs);
  background: var(--ink-850);
}

.ic-work-body__heading {
  margin: 0 0 18px;
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--paper-100);
}

.ic-work-body .icraft-entry {
  color: var(--paper-300);
  line-height: 2;
}

.ic-work-body .icraft-entry :is(h2, h3) {
  color: var(--paper-100);
}

.ic-work-body .icraft-entry img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-xs);
}

/* ==========================================================================
   P4-1. Statsバンド（about用 — front.cssと同等の下層版）
   ========================================================================== */

.ic-stats-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.ic-stats-band .ic-stat {
  padding: 8px clamp(1rem, 0.5rem + 2vw, 2.5rem);
  border-left: 1px solid var(--line-1);
}

.ic-stats-band .ic-stat:first-child {
  border-left: 0;
  padding-left: 0;
}

@media (max-width: 1023px) {
  .ic-stats-band {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-10) 0;
  }

  .ic-stats-band .ic-stat:nth-child(odd) {
    border-left: 0;
    padding-left: 0;
  }
}

/* ==========================================================================
   P4-2. 電話アクションバー（contact）
   ========================================================================== */

.ic-contact-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: clamp(1.25rem, 1rem + 1.5vw, 2.5rem);
  padding: clamp(1.5rem, 1.25rem + 1.5vw, 2.5rem);
  border: 1px solid var(--line-1);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-xs);
  background: var(--ink-850);
}

.ic-contact-bar__label {
  margin: 0 0 6px;
  color: var(--accent);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.icraft-page--dark .ic-contact-bar__tel {
  display: block;
  color: var(--paper-100);
  font-family: var(--font-en);
  font-feature-settings: "tnum" 1;
  font-size: clamp(1.75rem, 1.4rem + 1.5vw, 2.5rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.2;
  text-decoration: none;
  transition: color var(--dur-1) var(--ease-out);
}

.ic-contact-bar__tel:hover {
  color: var(--accent);
}

.ic-contact-bar__hours {
  margin: 4px 0 0;
  color: var(--paper-500);
  font-size: var(--fs-sm);
  letter-spacing: 0.06em;
}

.ic-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ic-badges span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 6px 16px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-full);
  color: var(--paper-300);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
}

.ic-badges span::before {
  content: "";
  width: 10px;
  height: 1px;
  background: var(--accent);
}

/* ==========================================================================
   P4-3. フォームサーフェス（明るい面 + CF7）
   ========================================================================== */

.ic-form-surface {
  --article-bg: #F7F5F0;
  --article-text: #26292D;
  --article-muted: #6B675F;
  --article-line: rgba(38, 41, 45, 0.16);
  padding: clamp(1.75rem, 1.25rem + 2.5vw, 3.5rem);
  border-radius: var(--radius-xs);
  background: var(--article-bg);
  color: var(--article-text);
}

.ic-form-surface__head {
  margin-bottom: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
  padding-bottom: 18px;
  border-bottom: 1px solid var(--article-line);
}

.ic-form-surface__kicker {
  margin: 0 0 8px;
  color: var(--accent-deep);
  font-family: var(--font-en);
  font-size: var(--fs-kicker);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

/* (0,2,0)でdesign-systemのダーク見出し色(0,1,1)に勝つ — 明るい面での白文字化を防ぐ */
.ic-form-surface .ic-form-surface__title {
  margin: 0;
  color: #1C1E20;
  font-size: var(--fs-h3);
  font-weight: 700;
}

.ic-form-surface__desc {
  margin: 10px 0 0;
  color: var(--article-muted);
  font-size: var(--fs-sm);
  line-height: 1.9;
}

/* CF7コントロール（フォーム定義は不変更・スタイルのみ） */
.ic-form-surface .wpcf7 p,
.ic-form-surface .wpcf7 label {
  color: var(--article-text);
  font-size: var(--fs-sm);
  font-weight: 700;
  line-height: 1.8;
}

.ic-form-surface .wpcf7-form-control-wrap {
  display: block;
  margin-top: 6px;
  font-weight: 400;
}

.ic-form-surface input[type="text"],
.ic-form-surface input[type="email"],
.ic-form-surface input[type="tel"],
.ic-form-surface input[type="url"],
.ic-form-surface input[type="date"],
.ic-form-surface input[type="number"],
.ic-form-surface textarea,
.ic-form-surface select {
  width: 100%;
  max-width: 100%;
  padding: 13px 16px;
  border: 1px solid var(--article-line);
  border-radius: var(--radius-xs);
  background: #FFFFFF;
  color: var(--article-text);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  transition: border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
}

.ic-form-surface :is(input, textarea, select):focus-visible {
  outline: none;
  border-color: var(--accent-deep);
  box-shadow: 0 0 0 3px rgba(143, 115, 64, 0.18);
}

.ic-form-surface .wpcf7-list-item {
  margin: 4px 12px 4px 0;
  font-weight: 400;
}

.ic-form-surface input[type="checkbox"],
.ic-form-surface input[type="radio"] {
  accent-color: var(--accent-deep);
  width: 1.05em;
  height: 1.05em;
}

.ic-form-surface input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 44px;
  border: 0;
  border-radius: var(--radius-xs);
  background: var(--accent);
  color: var(--accent-ink);
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background var(--dur-1) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
}

.ic-form-surface input[type="submit"]:hover {
  background: var(--accent-strong);
  box-shadow: var(--shadow-accent);
}

.ic-form-surface .wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  color: #B3412F;
  font-size: var(--fs-xs);
  font-weight: 400;
}

.ic-form-surface .wpcf7-response-output {
  margin: 20px 0 0;
  padding: 14px 18px;
  border: 1px solid var(--accent-deep);
  border-radius: var(--radius-xs);
  color: var(--article-text);
  font-size: var(--fs-sm);
}

.ic-form-surface .wpcf7-spinner {
  vertical-align: middle;
}

/* CF7フォームHTML内の構造クラス（DB定義のフォームが持つグリッド等）の復元 */
.ic-form-surface .contact-form__grid,
.ic-form-surface .recruit-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px 22px;
}

.ic-form-surface .form-field {
  min-width: 0;
  margin: 0;
}

.ic-form-surface .form-field--full,
.ic-form-surface .contact-form__privacy,
.ic-form-surface .recruit-form__privacy,
.ic-form-surface .contact-form__submit,
.ic-form-surface .recruit-form__submit {
  grid-column: 1 / -1;
}

.ic-form-surface .form-label,
.ic-form-surface legend.form-label {
  display: block;
  margin: 0 0 6px;
  padding: 0;
  color: var(--article-text);
  font-size: var(--fs-sm);
  font-weight: 700;
  line-height: 1.8;
}

.ic-form-surface .form-required {
  display: inline-block;
  margin-left: 6px;
  color: #B3412F;
  font-size: var(--fs-xs);
  font-weight: 700;
}

.ic-form-surface .contact-form__privacy,
.ic-form-surface .recruit-form__privacy {
  margin-top: 8px;
  color: var(--article-muted);
  font-size: var(--fs-xs);
  line-height: 1.8;
}

.ic-form-surface .contact-form__submit,
.ic-form-surface .recruit-form__submit {
  margin-top: 12px;
  text-align: center;
}

@media (max-width: 640px) {
  .ic-form-surface .contact-form__grid,
  .ic-form-surface .recruit-form__grid {
    grid-template-columns: 1fr;
  }
}

/* フォーム2枚並び */
.ic-form-panels {
  display: grid;
  gap: clamp(1.5rem, 1.25rem + 1.5vw, 2.5rem);
  margin-top: var(--space-10);
}

/* ==========================================================================
   P4-4. 2カラムチェックリスト
   ========================================================================== */

@media (min-width: 768px) {
  .icraft-page--dark .icraft-feature-list--cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 clamp(1.5rem, 1rem + 2vw, 3rem);
  }
}

/* ==========================================================================
   10. 材料ページ用: 大判スウォッチ
   ========================================================================== */

.ic-swatch-feature {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: clamp(2rem, 1.5rem + 3vw, 4rem);
  align-items: stretch;
}

.ic-swatch-feature .ic-swatch {
  min-height: 320px;
  aspect-ratio: auto;
}

@media (max-width: 1023px) {
  .ic-swatch-feature {
    grid-template-columns: 1fr;
  }

  .ic-swatch-feature .ic-swatch {
    min-height: 220px;
  }
}
