/* ==========================================================================
   icraft メインスタイルシート
   ========================================================================== */


/* ------------------------------------------------------------------
   リセット・ベース
   ------------------------------------------------------------------ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-ja);
  font-size: var(--text-base);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  color: var(--color-text-primary);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--color-blue);
  text-decoration: none;
  transition: color var(--transition-fast);
}
a:hover { color: var(--color-blue-light); }

ul, ol { list-style: none; }

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
  font-size: inherit;
}

address { font-style: normal; }

h1, h2, h3 {
  font-family: var(--font-ja);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-normal);
  color: var(--color-text-primary);
}

h4, h5, h6 {
  font-family: var(--font-ja);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-normal);
  color: var(--color-text-primary);
}

p {
  line-height: var(--lh-normal);
  letter-spacing: 0.03em;
}


/* ------------------------------------------------------------------
   コンテナ・レイアウト
   ------------------------------------------------------------------ */

.container {
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-px);
  padding-right: var(--container-px);
}

.section {
  padding-top: var(--section-py);
  padding-bottom: var(--section-py);
}

.section--gray {
  background-color: var(--color-bg-section);
}

.section--dark {
  background-color: var(--color-gray);
  color: var(--color-white);
}
.section--dark h2,
.section--dark h3,
.section--dark p {
  color: inherit;
}

.section--blue {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.section--blue h2,
.section--blue h3,
.section--blue p {
  color: inherit;
}


/* ------------------------------------------------------------------
   ボタン
   ------------------------------------------------------------------ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.875rem 2rem;
  font-family: var(--font-ja);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-normal);
  border-radius: var(--radius-sm);
  transition:
    background-color var(--transition-normal),
    color var(--transition-normal),
    border-color var(--transition-normal),
    transform var(--transition-fast),
    box-shadow var(--transition-normal);
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
}

.btn:active { transform: translateY(1px); }

/* プライマリ: Blue */
.btn--primary {
  background-color: var(--color-blue);
  color: var(--color-white);
  border: 1px solid var(--color-blue);
}
.btn--primary:hover {
  background-color: var(--color-blue-dark);
  border-color: var(--color-blue-dark);
  color: var(--color-white);
  box-shadow: var(--shadow-md);
}

/* セカンダリ: アウトライン */
.btn--secondary {
  background-color: transparent;
  color: var(--color-blue);
  border: 1px solid var(--color-blue);
}
.btn--secondary:hover {
  background-color: var(--color-bg-section);
  color: var(--color-blue-dark);
}

/* アクセント: Blue（プライマリと同義） */
.btn--accent {
  background-color: var(--color-blue);
  color: var(--color-white);
  border: 1px solid var(--color-blue);
}
.btn--accent:hover {
  background-color: var(--color-blue-dark);
  border-color: var(--color-blue-dark);
  color: var(--color-white);
}

/* アウトライン白（ダーク背景上） */
.btn--outline-white {
  background-color: transparent;
  color: var(--color-white);
  border: 1px solid rgba(255, 255, 255, 0.6);
}
.btn--outline-white:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
  border-color: var(--color-white);
}

/* テキストリンク */
.btn--text {
  padding: 0;
  border: none;
  background: none;
  color: var(--color-blue);
  font-weight: var(--fw-semibold);
}
.btn--text:hover { color: var(--color-blue-light); }

.btn--block { width: 100%; }
.btn--sm { padding: 0.5rem 1.25rem; font-size: var(--text-sm); }
.btn--lg { padding: 1.125rem 2.5rem; font-size: var(--text-lg); }

.btn--nav {
  padding: 0.5rem 1.25rem;
  font-size: var(--text-sm);
}


/* ------------------------------------------------------------------
   タグ・バッジ
   ------------------------------------------------------------------ */

.tag {
  display: inline-block;
  padding: 0.25rem 0.625rem;
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  border-radius: var(--radius-sm);
  white-space: nowrap;
}
.tag--work {
  background-color: var(--color-bg-section);
  color: var(--color-blue);
  border: 1px solid var(--color-blue-light);
}
.tag--property {
  background-color: var(--color-bg-section);
  color: var(--color-gray);
  border: 1px solid var(--color-border);
}

.tag-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}


/* ------------------------------------------------------------------
   セクションタイトル共通
   ------------------------------------------------------------------ */

.section-title {
  margin-bottom: var(--space-12);
}
.section-title--center { text-align: center; }
.section-title--left   { text-align: left; }

.section-title__en {
  display: block;
  font-family: var(--font-en);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.section-title__ja {
  font-family: var(--font-ja);
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-normal);
  color: var(--color-gray);
}

.section-title__desc {
  margin-top: var(--space-4);
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

.section-title__accent-line {
  width: 40px;
  height: 2px;
  background-color: var(--color-blue);
  margin-top: var(--space-5);
}
.section-title--center .section-title__accent-line {
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 767px) {
  .section-title__ja { font-size: var(--text-3xl); }
}


/* ------------------------------------------------------------------
   パンくずリスト
   ------------------------------------------------------------------ */

.breadcrumb {
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-border-light);
  margin-bottom: var(--space-12);
}

.breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-light);
}

.breadcrumb__item a {
  color: var(--color-blue);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.breadcrumb__item a:hover { color: var(--color-blue-light); }
.breadcrumb__item--current { color: var(--color-text-primary); }
.breadcrumb__sep { color: var(--color-border); }


/* ------------------------------------------------------------------
   ページネーション
   ------------------------------------------------------------------ */

.pagination {
  display: flex;
  justify-content: center;
  margin-top: var(--space-16);
}

.pagination .nav-links {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: var(--text-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-secondary);
  transition: all var(--transition-fast);
}
.pagination .page-numbers:hover,
.pagination .page-numbers.current {
  background-color: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
}
.pagination .page-numbers.dots { border: none; }


/* ================================================================
   ヘッダー
   ================================================================ */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-header);
  height: var(--header-height);
  background-color: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid transparent;
  transition:
    background-color var(--transition-normal),
    border-color var(--transition-normal),
    box-shadow var(--transition-normal);
}

.site-header.is-scrolled {
  border-bottom-color: var(--color-border-light);
  box-shadow: var(--shadow-sm);
}

/* ヒーロー上ではヘッダーを透過 */
.site-header.is-hero-top {
  background-color: rgba(70, 68, 68, 0.75);
  backdrop-filter: blur(4px);
}
.site-header.is-hero-top .global-nav__link,
.site-header.is-hero-top .header-logo__en,
.site-header.is-hero-top .header-logo__ja {
  color: var(--color-white);
}
.site-header.is-hero-top .hamburger__bar {
  background-color: var(--color-white);
}
.site-header.is-hero-top .btn--nav {
  background-color: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
}

.header-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
}

/* ロゴ */
.header-logo a,
.header-logo__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-decoration: none;
}
.header-logo img { height: 40px; width: auto; }

.header-logo__en {
  font-family: var(--font-en);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-gray);
  line-height: 1;
  transition: color var(--transition-fast);
}
.header-logo__ja {
  font-family: var(--font-ja);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-widest);
  color: var(--color-text-secondary);
  line-height: 1;
  transition: color var(--transition-fast);
}


/* ------------------------------------------------------------------
   グローバルナビ（PC）
   ------------------------------------------------------------------ */

.global-nav { display: flex; align-items: center; }

.global-nav__list {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.global-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-normal);
  color: var(--color-text-primary);
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast), background-color var(--transition-fast);
  position: relative;
}
.global-nav__link::after {
  content: '';
  position: absolute;
  left: var(--space-3);
  right: var(--space-3);
  bottom: 4px;
  height: 2px;
  background-color: var(--color-blue);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-normal);
}
.global-nav__link:hover,
.global-nav__link.is-active {
  color: var(--color-blue);
}
.global-nav__link:hover::after,
.global-nav__link.is-active::after {
  transform: scaleX(1);
}

.global-nav__arrow {
  transition: transform var(--transition-fast);
}
.global-nav__item--has-dropdown:hover .global-nav__arrow,
.global-nav__item--has-dropdown.is-hovering .global-nav__arrow,
.global-nav__link[aria-expanded="true"] .global-nav__arrow {
  transform: rotate(180deg);
}

.global-nav__item--cta .global-nav__link::after { display: none; }


/* ドロップダウンメニュー */
.global-nav__item--has-dropdown {
  position: relative;
}

.dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 280px;
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-top: 2px solid var(--color-blue);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  box-shadow: var(--shadow-md);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--transition-normal),
    transform var(--transition-normal),
    visibility var(--transition-normal);
  z-index: var(--z-header);
}

.global-nav__item--has-dropdown:hover .dropdown-menu,
.global-nav__item--has-dropdown.is-hovering .dropdown-menu,
.dropdown-menu.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.dropdown-menu__link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  border-bottom: 1px solid var(--color-border-light);
  transition: background-color var(--transition-fast), color var(--transition-fast);
}
.dropdown-menu__link:hover {
  background-color: var(--color-bg-section);
  color: var(--color-blue);
}
.dropdown-menu__item:last-child .dropdown-menu__link {
  border-bottom: none;
}

.dropdown-menu__icon {
  font-size: var(--text-xs);
  color: var(--color-blue-light);
  flex-shrink: 0;
}
.dropdown-menu__link strong {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
}
.dropdown-menu__link small {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-light);
  margin-top: 2px;
}

.dropdown-menu__item--featured .dropdown-menu__link {
  background-color: var(--color-bg-section);
}
.dropdown-menu__item--featured .dropdown-menu__link strong {
  color: var(--color-blue);
}
.dropdown-menu__item--featured .dropdown-menu__link:hover {
  background-color: #dde8f4;
}
.dropdown-menu__item--sub .dropdown-menu__link {
  background-color: #f2f2f2;
}
.dropdown-menu__item--sub .dropdown-menu__link:hover {
  background-color: #e4e4e4;
}


/* ------------------------------------------------------------------
   ハンバーガーボタン
   ------------------------------------------------------------------ */

.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast);
}
.hamburger:hover { background-color: var(--color-bg-section); }

.hamburger__bar {
  display: block;
  width: 24px;
  height: 1.5px;
  background-color: var(--color-gray);
  border-radius: 1px;
  transition: transform var(--transition-normal), opacity var(--transition-normal);
}

/* ×に変形 */
.hamburger.is-active .hamburger__bar:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.hamburger.is-active .hamburger__bar:nth-child(2) {
  opacity: 0;
}
.hamburger.is-active .hamburger__bar:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}


/* ------------------------------------------------------------------
   ドロワーナビゲーション
   ------------------------------------------------------------------ */

.drawer-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(70, 68, 68, 0.6);
  z-index: calc(var(--z-drawer) - 1);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-normal), visibility var(--transition-normal);
}
.drawer-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.drawer-nav {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(360px, 90vw);
  background-color: var(--color-white);
  z-index: var(--z-drawer);
  transform: translateX(100%);
  transition: transform var(--transition-normal);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  flex-direction: column;
}
.drawer-nav.is-open {
  transform: translateX(0);
}

.drawer-nav__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-border-light);
  background-color: var(--color-gray);
}

.drawer-nav__logo {
  font-family: var(--font-en);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-white);
}

.drawer-nav__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--color-white);
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast);
}
.drawer-nav__close:hover { background-color: rgba(255, 255, 255, 0.15); }

.drawer-nav__list {
  padding: var(--space-4) 0;
  flex: 1;
}

.drawer-nav__item {
  border-bottom: 1px solid var(--color-border-light);
}

.drawer-nav__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-base);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-normal);
  color: var(--color-text-primary);
  transition: color var(--transition-fast), background-color var(--transition-fast);
}
.drawer-nav__link:hover {
  color: var(--color-blue);
  background-color: var(--color-bg-section);
}

.drawer-nav__arrow {
  transition: transform var(--transition-fast);
}
.drawer-nav__link--toggle[aria-expanded="true"] .drawer-nav__arrow {
  transform: rotate(180deg);
}

.drawer-sub-menu {
  display: none;
  background-color: var(--color-bg);
}
.drawer-sub-menu.is-open { display: block; }
.drawer-sub-menu li a {
  display: block;
  padding: var(--space-3) var(--space-8);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  border-bottom: 1px solid var(--color-border-light);
  transition: color var(--transition-fast);
}
.drawer-sub-menu li:last-child a { border-bottom: none; }
.drawer-sub-menu li a:hover { color: var(--color-blue); }

.drawer-nav__item--cta {
  padding: var(--space-6);
  border-bottom: none;
}

.drawer-nav__contact {
  padding: var(--space-6);
  border-top: 1px solid var(--color-border-light);
  background-color: var(--color-bg);
}

.drawer-nav__contact-label {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  letter-spacing: var(--ls-wide);
  margin-bottom: var(--space-2);
}

.drawer-nav__tel {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  letter-spacing: var(--ls-tight);
}
.drawer-nav__tel:hover { color: var(--color-blue); }


/* ------------------------------------------------------------------
   スティッキーCTA（SP）
   ------------------------------------------------------------------ */

.sticky-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-header);
  grid-template-columns: 1fr 1fr;
  height: 56px;
  box-shadow: 0 -2px 16px rgba(56, 96, 153, 0.15);
}

.sticky-cta__tel,
.sticky-cta__form {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-normal);
  transition: filter var(--transition-fast);
}
.sticky-cta__tel:hover,
.sticky-cta__form:hover { filter: brightness(0.9); }

.sticky-cta__tel {
  background-color: var(--color-gray);
  color: var(--color-white);
}
.sticky-cta__form {
  background-color: var(--color-blue);
  color: var(--color-white);
}


/* ================================================================
   フッター
   ================================================================ */

.site-footer {
  background-color: var(--color-gray);
  color: var(--color-white);
}

.footer-main {
  padding: var(--space-24) 0 var(--space-16);
}

.footer-main__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--space-12);
  align-items: start;
}

/* フッターロゴ */
.footer-logo {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: var(--space-6);
}
.footer-logo__en {
  font-family: var(--font-en);
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-white);
  line-height: 1;
}
.footer-logo__ja {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-widest);
  color: rgba(255, 255, 255, 0.5);
  line-height: 1;
}

.footer-tagline {
  font-family: var(--font-ja);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-normal);
  margin-bottom: var(--space-4);
}

.footer-desc {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: rgba(255, 255, 255, 0.65);
  margin-bottom: var(--space-6);
}

.footer-accent-line {
  width: 40px;
  height: 2px;
  background-color: var(--color-blue-light);
}

/* フッターナビ */
.footer-nav__title {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.footer-nav__title--mt { margin-top: var(--space-8); }

.footer-nav__list li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.footer-nav__list a {
  display: block;
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.7);
  transition: color var(--transition-fast), padding-left var(--transition-fast);
}
.footer-nav__list a:hover {
  color: var(--color-blue-light);
  padding-left: var(--space-2);
}
.footer-nav__featured {
  color: var(--color-blue-light) !important;
}

/* フッター連絡先 */
.footer-contact {
  margin-top: var(--space-8);
  padding: var(--space-6);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  background-color: rgba(255, 255, 255, 0.05);
}
.footer-contact__label {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: var(--ls-wide);
  margin-bottom: var(--space-3);
}
.footer-contact__tel {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-2);
}
.footer-contact__tel:hover { color: var(--color-blue-light); }
.footer-contact__hours {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: var(--space-4);
}
.footer-contact__btn { margin-top: var(--space-2); }

.footer-address {
  margin-top: var(--space-6);
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.5);
  line-height: var(--lh-normal);
}

/* フッターボトム */
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--space-6) 0;
}
.footer-bottom__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.footer-copyright {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.4);
  letter-spacing: var(--ls-normal);
}
.footer-legal ul {
  display: flex;
  gap: var(--space-6);
}
.footer-legal a {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.4);
  transition: color var(--transition-fast);
}
.footer-legal a:hover { color: var(--color-blue-light); }


/* ================================================================
   施工実績テーブル
   ================================================================ */

.works-meta-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.works-meta-table th,
.works-meta-table td {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border-light);
  text-align: left;
  vertical-align: top;
}
.works-meta-table th {
  width: 160px;
  background-color: var(--color-blue);
  color: var(--color-white);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
}


/* ================================================================
   レスポンシブ対応
   ================================================================ */

@media (max-width: 1023px) {
  .global-nav { display: none; }
  .hamburger { display: flex; }
  .sticky-cta { display: grid; }

  body { padding-bottom: 56px; }

  .footer-main__grid {
    grid-template-columns: 1fr 1fr;
  }
  .footer-col--brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 767px) {
  .footer-main__grid {
    grid-template-columns: 1fr;
  }
  .footer-bottom__inner {
    flex-direction: column;
    text-align: center;
  }
  .footer-legal ul {
    justify-content: center;
  }
}


/* ================================================================
   アクセシビリティ
   ================================================================ */

.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;
}


/* ================================================================
   ヒーローセクション（header.php / template-parts/hero.php）
   ================================================================ */

.hero {
  position: relative;
  height: 100svh;
  min-height: 560px;
  overflow: hidden;
  display: flex;
  align-items: center;
}

.hero-swiper,
.hero-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.hero-slide {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* 画像がない場合のフォールバック */
.hero-slide:not([style*="background-image"]) {
  background-color: var(--color-gray);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(28, 28, 28, 0.55) 0%,
    rgba(28, 28, 28, 0.35) 50%,
    rgba(28, 28, 28, 0.65) 100%
  );
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: var(--header-height);
}

.hero-en {
  font-family: var(--font-en);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}

.hero-title {
  font-family: var(--font-ja);
  font-size: var(--text-6xl);
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: var(--color-white);
  letter-spacing: var(--ls-normal);
  margin-bottom: var(--space-6);
}

.hero-desc {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-10);
}

.hero-actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* スクロール誘導 */
.hero-scroll {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}
.hero-scroll__label {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: rgba(255, 255, 255, 0.6);
}
.hero-scroll__line {
  display: block;
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,0.6), transparent);
  animation: scroll-line 2s ease-in-out infinite;
}
@keyframes scroll-line {
  0%, 100% { opacity: 1; transform: scaleY(1); transform-origin: top; }
  50%       { opacity: 0.4; }
}

/* Swiper ページネーション（Hero） */
.hero-swiper .swiper-pagination {
  bottom: 24px;
  left: auto;
  right: 32px;
  width: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.hero-swiper .swiper-pagination-bullet {
  width: 3px;
  height: 24px;
  border-radius: 2px;
  background: rgba(255,255,255,0.4);
  opacity: 1;
  transition: background var(--transition-normal), height var(--transition-normal);
}
.hero-swiper .swiper-pagination-bullet-active {
  background: var(--color-blue-light);
  height: 40px;
}

@media (max-width: 767px) {
  .hero-title { font-size: var(--text-4xl); }
  .hero-desc  { font-size: var(--text-base); }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; max-width: 320px; }
  .hero-swiper .swiper-pagination { right: 16px; }
}


/* ================================================================
   Stats セクション（トップページ）
   ================================================================ */

.stats-section {
  padding: var(--space-16) 0;
}

.stats-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
}

.stat-item {
  text-align: center;
  flex: 1;
  padding: var(--space-6) var(--space-8);
}

.stat-divider {
  width: 1px;
  height: 60px;
  background-color: rgba(255, 255, 255, 0.2);
  flex-shrink: 0;
}

.stat-number {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
  margin-bottom: var(--space-2);
}

.stat-en-num {
  font-family: var(--font-en);
  font-size: var(--text-5xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  line-height: 1;
}

.counter-number {
  font-family: var(--font-en);
  font-size: var(--text-5xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.stat-unit {
  font-family: var(--font-ja);
  font-size: var(--text-lg);
  font-weight: var(--fw-medium);
  color: rgba(255, 255, 255, 0.8);
}

.stat-label {
  font-family: var(--font-ja);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: rgba(255, 255, 255, 0.75);
  letter-spacing: var(--ls-normal);
}

@media (max-width: 767px) {
  .stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
  }
  .stat-divider { display: none; }
  .stat-item { border-bottom: 1px solid rgba(255,255,255,0.1); }
  .stat-en-num,
  .counter-number { font-size: var(--text-4xl); }
}


/* ================================================================
   強みカード（トップページ）
   ================================================================ */

.strengths-section { background-color: var(--color-white); }

.strengths-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}

.strength-card {
  position: relative;
  padding: var(--space-10) var(--space-8);
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-top: 3px solid var(--color-blue);
  border-radius: var(--radius-md);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}
.strength-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.strength-card__num {
  margin-bottom: var(--space-4);
}
.strength-card__num-en {
  font-family: var(--font-en);
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  color: var(--color-bg-section);
  line-height: 1;
  letter-spacing: -2px;
}

.strength-card__icon {
  margin-bottom: var(--space-4);
  color: var(--color-blue);
}

.strength-card__title {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-4);
  color: var(--color-gray);
}

.strength-card__desc {
  font-size: var(--text-base);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}

@media (max-width: 1023px) {
  .strengths-grid { grid-template-columns: 1fr; gap: var(--space-6); }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .strengths-grid { grid-template-columns: repeat(3, 1fr); }
}


/* ================================================================
   サービスカード（トップページ・サービスページ共通）
   ================================================================ */

.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.service-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}
.service-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
.service-card--featured {
  border-color: var(--color-blue);
  border-top-width: 3px;
}

.service-card__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: var(--space-8) var(--space-6);
  text-decoration: none;
  color: inherit;
}

.service-card__icon {
  color: var(--color-blue);
  margin-bottom: var(--space-4);
}

.service-card__body { flex: 1; }

.service-card__badge {
  display: inline-block;
  padding: 2px 8px;
  background-color: var(--color-blue);
  color: var(--color-white);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-2);
  letter-spacing: var(--ls-wide);
}

.service-card__title {
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-1);
}

.service-card__sub {
  font-size: var(--text-xs);
  color: var(--color-blue-light);
  font-weight: var(--fw-medium);
  margin-bottom: var(--space-3);
  letter-spacing: var(--ls-wide);
}

.service-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-4);
}

.service-card__footer {
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-light);
}

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


/* ================================================================
   施工実績スライダー（トップページ）
   ================================================================ */

.works-slider-section { overflow: hidden; }

.works-swiper-wrap {
  position: relative;
  padding: 0 var(--space-4);
  margin-bottom: var(--space-12);
}

.works-swiper .swiper-slide {
  height: auto;
}

.works-swiper .swiper-button-prev,
.works-swiper .swiper-button-next {
  width: 44px;
  height: 44px;
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
  color: var(--color-blue);
  transition: background-color var(--transition-fast), color var(--transition-fast);
}
.works-swiper .swiper-button-prev:hover,
.works-swiper .swiper-button-next:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.works-swiper .swiper-button-prev::after,
.works-swiper .swiper-button-next::after {
  font-size: 14px;
  font-weight: 700;
}

.works-swiper .swiper-pagination-bullet {
  background: var(--color-blue-light);
  opacity: 0.4;
}
.works-swiper .swiper-pagination-bullet-active {
  background: var(--color-blue);
  opacity: 1;
}

.works-slider-cta {
  text-align: center;
}

/* 施工実績カード（一覧・スライダー共通） */
.works-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.works-card__thumb-link,
.works-card__thumb {
  display: block;
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background-color: var(--color-bg-section);
}
.works-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.works-card:hover .works-card__thumb img {
  transform: scale(1.05);
}

.works-card__no-image {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-border);
}

.works-card__thumb-tags {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.works-card__body {
  padding: var(--space-5) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.works-card__area {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
  color: var(--color-text-light);
  margin-bottom: var(--space-2);
  margin-top: var(--space-2);
}

.works-card__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-2);
  line-height: var(--lh-tight);
}
.works-card__title a {
  color: var(--color-gray);
  transition: color var(--transition-fast);
}
.works-card__title a:hover { color: var(--color-blue); }

.works-card__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  flex: 1;
  margin-bottom: var(--space-4);
}

.works-card__more {
  margin-top: auto;
}


/* ================================================================
   施工フロー（プロセスセクション）
   ================================================================ */

.process-steps {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  margin-bottom: var(--space-12);
}

.step-item {
  display: flex;
  align-items: flex-start;
  gap: 0;
}

.step-item__inner {
  flex: 1;
  text-align: center;
  padding: var(--space-4) var(--space-2);
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  position: relative;
}
.step-item__inner::before {
  content: '';
  display: block;
  width: 24px;
  height: 3px;
  background-color: var(--color-blue);
  margin: 0 auto var(--space-3);
}

.step-item__num {
  margin-bottom: var(--space-2);
}
.step-item__num-en {
  font-family: var(--font-en);
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-blue-light);
  opacity: 0.4;
  line-height: 1;
}

.step-item__title {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-1);
}

.step-item__desc {
  font-size: 0.65rem;
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

.step-connector {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2px;
  color: var(--color-blue-light);
  flex-shrink: 0;
  margin-top: 32px;
}

.process-cta { text-align: center; }

@media (max-width: 1199px) {
  .process-steps { grid-template-columns: repeat(4, 1fr); }
  .step-connector { display: none; }
  .step-item { display: block; }
  .step-item__inner {
    padding: var(--space-5) var(--space-4);
  }
  .step-item__inner::before { width: 32px; margin-bottom: var(--space-4); }
  .step-item__num-en { font-size: var(--text-4xl); }
  .step-item__title { font-size: var(--text-sm); margin-bottom: var(--space-2); }
  .step-item__desc { font-size: var(--text-xs); }
}
@media (max-width: 767px) {
  .process-steps { grid-template-columns: 1fr 1fr; }
}


/* ================================================================
   採用バナー（トップページ）
   ================================================================ */

.recruit-banner-section {
  position: relative;
  overflow: hidden;
  padding: var(--space-24) 0;
}

.recruit-banner-bg {
  position: absolute;
  inset: 0;
  background-color: var(--color-gray);
  background-size: cover;
  background-position: center;
}

.recruit-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(70, 68, 68, 0.90) 0%,
    rgba(70, 68, 68, 0.70) 60%,
    rgba(70, 68, 68, 0.40) 100%
  );
}

.recruit-banner-inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
}

.recruit-banner-en {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.recruit-banner-title {
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-6);
}

.recruit-banner-points {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.recruit-banner-points li {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.8);
  padding-left: var(--space-4);
  position: relative;
}
.recruit-banner-points li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--color-blue-light);
  font-weight: var(--fw-bold);
}

.recruit-banner-action { flex-shrink: 0; }

@media (max-width: 767px) {
  .recruit-banner-inner { flex-direction: column; align-items: flex-start; }
  .recruit-banner-title { font-size: var(--text-3xl); }
  .recruit-banner-action .btn { width: 100%; }
}


/* ================================================================
   CTAバナー（template-parts/cta-banner.php）
   ================================================================ */

.cta-banner {
  padding: var(--space-20) 0;
}

.cta-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
}

.cta-banner__en-sub {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.cta-banner__title {
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-4);
}

.cta-banner__sub {
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.75);
}

.cta-banner__actions {
  display: flex;
  gap: var(--space-4);
  flex-shrink: 0;
  flex-wrap: wrap;
}

@media (max-width: 767px) {
  .cta-banner__inner { flex-direction: column; align-items: flex-start; }
  .cta-banner__actions { flex-direction: column; width: 100%; }
  .cta-banner__actions .btn { width: 100%; }
}


/* ================================================================
   ページヒーロー（archive-works.php / page.php）
   ================================================================ */

.page-hero {
  position: relative;
  background-color: var(--color-gray);
  padding: var(--space-20) 0;
  overflow: hidden;
  text-align: center;
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-gray) 0%, var(--color-blue-dark) 100%);
  opacity: 0.95;
}

.page-hero .container { position: relative; }

.page-hero__en {
  font-family: var(--font-en);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.page-hero__title {
  font-size: var(--text-5xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin-bottom: var(--space-4);
}

.page-hero__desc {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.75);
  max-width: 600px;
  margin: 0 auto;
  line-height: var(--lh-normal);
}

@media (max-width: 767px) {
  .page-hero__title { font-size: var(--text-3xl); }
  .page-hero__desc  { font-size: var(--text-base); }
}


/* ================================================================
   施工実績フィルター（archive-works.php）
   ================================================================ */

.works-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-10);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border-light);
}

.filter-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-normal);
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background-color: var(--color-white);
  cursor: pointer;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast);
}
.filter-btn:hover {
  background-color: var(--color-bg-section);
  border-color: var(--color-blue-light);
  color: var(--color-blue);
}
.filter-btn.is-active {
  background-color: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
}

.filter-btn__count {
  font-size: var(--text-xs);
  background-color: rgba(0, 0, 0, 0.1);
  border-radius: var(--radius-full);
  padding: 0 6px;
  min-width: 20px;
  text-align: center;
}
.filter-btn.is-active .filter-btn__count {
  background-color: rgba(255, 255, 255, 0.25);
}

/* 施工実績グリッド */
.works-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
  margin-bottom: var(--space-12);
}

.no-posts {
  text-align: center;
  padding: var(--space-20) 0;
  color: var(--color-text-light);
}
.no-posts p { margin-bottom: var(--space-6); }

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


/* ================================================================
   施工実績詳細（single-works.php）
   ================================================================ */

.works-hero-image {
  position: relative;
  width: 100%;
  max-height: 560px;
  overflow: hidden;
}
.works-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-height: 560px;
}
.works-hero-image__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28,28,28,0.75) 0%, transparent 50%);
}
.works-hero-image__caption {
  position: absolute;
  bottom: var(--space-10);
  left: 0;
  right: 0;
  padding: 0 var(--space-8);
}
.works-hero-image__title {
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin-bottom: var(--space-3);
}
.works-title-no-image {
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-8);
}

.works-detail-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-12);
  align-items: start;
  margin-top: var(--space-8);
}

.works-section-title {
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  padding-bottom: var(--space-4);
  margin-bottom: var(--space-6);
  border-bottom: 2px solid var(--color-blue);
}

.works-meta-section,
.works-point-section,
.works-gallery-section {
  margin-bottom: var(--space-12);
}

/* ギャラリー */
.works-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.works-gallery__item {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.works-gallery__link {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}
.works-gallery__link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}
.works-gallery__link:hover img { transform: scale(1.05); }
.works-gallery__zoom {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(56, 96, 153, 0.5);
  color: var(--color-white);
  opacity: 0;
  transition: opacity var(--transition-normal);
}
.works-gallery__link:hover .works-gallery__zoom { opacity: 1; }
.works-gallery__caption {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  text-align: center;
  padding: var(--space-2);
}

/* サイドバー */
.works-detail-sidebar { position: sticky; top: calc(var(--header-height) + var(--space-6)); }

.works-sidebar-box {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}
.works-sidebar-box__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border-light);
}
.works-sidebar-box__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
  line-height: var(--lh-normal);
}

/* 関連実績 */
.related-works-section {
  margin-top: var(--space-16);
  padding-top: var(--space-12);
  border-top: 1px solid var(--color-border-light);
}
.related-works-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}

@media (max-width: 1023px) {
  .works-detail-layout { grid-template-columns: 1fr; }
  .works-detail-sidebar { position: static; }
  .related-works-grid { grid-template-columns: 1fr 1fr; }
  .works-gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .works-hero-image__title { font-size: var(--text-2xl); }
  .works-hero-image__caption { padding: 0 var(--space-4); bottom: var(--space-6); }
  .related-works-grid { grid-template-columns: 1fr; }
  .works-gallery { grid-template-columns: 1fr 1fr; }
}


/* ================================================================
   採用ページ（page-recruit.php）
   ================================================================ */

/* 採用ヒーロー */
.recruit-hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: var(--space-20) 0;
}
.recruit-hero__bg {
  position: absolute;
  inset: 0;
  background-color: var(--color-gray);
}
.recruit-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(42, 74, 117, 0.85) 0%, rgba(70, 68, 68, 0.75) 100%);
}
.recruit-hero .container { position: relative; }
.recruit-hero__inner { max-width: 680px; }

.recruit-hero__en {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.recruit-hero__title {
  font-size: var(--text-5xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-6);
}
.recruit-hero__desc {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.8);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-10);
}

@media (max-width: 767px) {
  .recruit-hero { min-height: 50vh; }
  .recruit-hero__title { font-size: var(--text-3xl); }
}


/* 採用メッセージ */
.recruit-message-inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--space-12);
  align-items: center;
}
.recruit-message-body {
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}
.recruit-message-sig {
  margin-top: var(--space-6);
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}
.recruit-message-photo__placeholder {
  width: 100%;
  aspect-ratio: 3 / 4;
  background-color: var(--color-bg-section);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  color: var(--color-border);
  font-size: var(--text-sm);
  text-align: center;
  border: 2px dashed var(--color-border);
}

@media (max-width: 767px) {
  .recruit-message-inner { grid-template-columns: 1fr; }
  .recruit-message-photo { order: -1; max-width: 240px; }
}


/* 募集職種カード */
.job-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}

.job-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.job-card__header {
  background-color: var(--color-blue);
  padding: var(--space-6) var(--space-8);
}
.job-card__title {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin-bottom: 4px;
}
.job-card__sub {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.75);
  letter-spacing: var(--ls-normal);
}

.job-card__body {
  padding: var(--space-6) var(--space-8);
  flex: 1;
}
.job-card__section {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border-light);
}
.job-card__section:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.job-card__section-title {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.job-card__section p {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}

.job-benefit-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.job-benefit-list li {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  padding-left: var(--space-4);
  position: relative;
  line-height: var(--lh-normal);
}
.job-benefit-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--color-blue);
  font-weight: var(--fw-bold);
  font-size: var(--text-xs);
  top: 2px;
}

.job-card__footer {
  padding: var(--space-5) var(--space-8) var(--space-6);
  border-top: 1px solid var(--color-border-light);
}
.job-card__footer .btn { width: 100%; }

@media (max-width: 1023px) {
  .job-cards { grid-template-columns: 1fr; max-width: 600px; margin: 0 auto; }
}


/* タイムライン */
.timeline {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
}
.timeline::before {
  content: '';
  position: absolute;
  left: 100px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--color-blue) 0%, var(--color-blue-light) 100%);
}

.timeline-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
  position: relative;
}

.timeline-item__time {
  text-align: right;
  padding-right: var(--space-6);
}
.timeline-item__time-en {
  font-family: var(--font-en);
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-blue);
  line-height: var(--lh-tight);
}

.timeline-item__dot {
  position: absolute;
  left: 92px;
  top: 4px;
  width: 16px;
  height: 16px;
  background-color: var(--color-blue);
  border: 3px solid var(--color-white);
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--color-blue);
}

.timeline-item__content {
  padding-bottom: var(--space-4);
}
.timeline-item__event {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-2);
}
.timeline-item__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

@media (max-width: 767px) {
  .timeline::before { left: 70px; }
  .timeline-item { grid-template-columns: 70px 1fr; }
  .timeline-item__dot { left: 62px; }
  .timeline-item__time-en { font-size: var(--text-sm); }
}


/* 先輩の声 */
.voices-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}

.voice-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.voice-card__photo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background-color: var(--color-bg-section);
  border: 2px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-border);
}

.voice-card__quote {
  font-size: var(--text-base);
  font-weight: var(--fw-medium);
  color: var(--color-gray);
  line-height: var(--lh-normal);
  font-style: normal;
  border-left: 3px solid var(--color-blue);
  padding-left: var(--space-4);
  flex: 1;
}

.voice-card__detail {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

.voice-card__footer {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-light);
}
.voice-card__name {
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}
.voice-card__years {
  font-size: var(--text-xs);
  color: var(--color-blue);
  font-weight: var(--fw-medium);
}

@media (max-width: 1023px) {
  .voices-grid { grid-template-columns: 1fr; max-width: 560px; margin: 0 auto; }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .voices-grid { grid-template-columns: repeat(3, 1fr); max-width: none; }
}


/* 福利厚生 */
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.benefit-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}
.benefit-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.benefit-card__icon {
  color: var(--color-blue);
  margin: 0 auto var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background-color: var(--color-bg-section);
  border-radius: 50%;
}

.benefit-card__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-3);
}

.benefit-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

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


/* 応募フォーム */
.recruit-form-wrap {
  max-width: 800px;
  margin: 0 auto;
}
.recruit-form-inner {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-10) var(--space-12);
  border: 1px solid var(--color-border-light);
  box-shadow: var(--shadow-md);
  margin-bottom: var(--space-8);
}

.recruit-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

.form-field { display: flex; flex-direction: column; gap: var(--space-2); }
.form-field--full { grid-column: 1 / -1; }

.form-label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray);
}
.form-required {
  font-size: var(--text-xs);
  color: var(--color-error);
  margin-left: 4px;
}

.form-input,
.form-select,
.form-textarea,
.wpcf7-form-control:not([type="submit"]):not([type="radio"]):not([type="checkbox"]) {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-ja);
  font-size: var(--text-base);
  color: var(--color-text-primary);
  background-color: var(--color-white);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus,
.wpcf7-form-control:not([type="submit"]):not([type="radio"]):not([type="checkbox"]):focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(56, 96, 153, 0.12);
}

/* CF7: コントロールラッパーを幅100%に */
.wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* CF7: フォーム内の不要な<p>マージンをリセット */
.wpcf7 p { margin: 0; }
.form-field p { margin: 0; }

/* CF7: ラジオ・チェックボックスのラベル */
.wpcf7-radio .wpcf7-list-item,
.wpcf7-checkbox .wpcf7-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: 0;
  font-size: var(--text-base);
  cursor: pointer;
}
.wpcf7-radio .wpcf7-list-item input[type="radio"],
.wpcf7-checkbox .wpcf7-list-item input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-blue);
  flex-shrink: 0;
  margin: 0;
}
.form-radios--row .wpcf7-radio { display: flex; flex-wrap: wrap; gap: var(--space-4); }
.form-radios--row .wpcf7-radio .wpcf7-list-item { margin: 0; }

/* CF7: Acceptanceチェックボックス
 * .form-checkbox が flex コンテナ。内側の CF7 span を display:contents で
 * レイアウトから透過させ、input と テキストが直接 flex 子として並ぶようにする。
 */
.form-checkbox .wpcf7-form-control-wrap,
.form-checkbox .wpcf7-form-control,
.form-checkbox .wpcf7-list-item {
  display: contents;
}
.form-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-blue);
  flex-shrink: 0;
  cursor: pointer;
  margin: 0;
}

/* CF7: 送信ボタン */
.wpcf7 input[type="submit"],
.wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4) var(--space-10);
  background-color: var(--color-blue);
  color: var(--color-white);
  font-family: var(--font-ja);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
  min-width: 200px;
}
.wpcf7 input[type="submit"]:hover,
.wpcf7-submit:hover {
  background-color: var(--color-blue-dark);
  transform: translateY(-1px);
}

/* CF7: バリデーションエラーメッセージ */
.wpcf7-not-valid-tip {
  display: block;
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-error);
}
.wpcf7-form-control.wpcf7-not-valid {
  border-color: var(--color-error);
}

/* CF7: 送信結果メッセージ */
.wpcf7-response-output {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  text-align: center;
}
.wpcf7-form.sent .wpcf7-response-output {
  background-color: #f0fdf4;
  border: 1px solid #86efac;
  color: #166534;
}
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output,
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.unaccepted .wpcf7-response-output {
  background-color: #fef2f2;
  border: 1px solid #fca5a5;
  color: #991b1b;
}

/* CF7: スピナー（送信中） */
.wpcf7-spinner {
  display: none;
  width: 20px;
  height: 20px;
  margin-left: var(--space-2);
  vertical-align: middle;
}
.wpcf7-form.submitting .wpcf7-spinner { display: inline-block; }

.form-radios {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.form-radio {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-base);
  cursor: pointer;
}
.form-radio input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-blue);
  flex-shrink: 0;
}

.recruit-form__submit {
  margin-top: var(--space-8);
  text-align: center;
}
.recruit-form__note {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  margin-bottom: var(--space-4);
}

.recruit-contact-direct {
  text-align: center;
}
.recruit-contact-direct__label {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}
.recruit-contact-direct__tel {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-blue);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-2);
}
.recruit-contact-direct__tel:hover { color: var(--color-blue-dark); }
.recruit-contact-direct__hours {
  font-size: var(--text-sm);
  color: var(--color-text-light);
}

@media (max-width: 767px) {
  .recruit-form-inner { padding: var(--space-6); }
  .recruit-form__grid { grid-template-columns: 1fr; }
}


/* ================================================================
   サービスページ（page-service.php）
   ================================================================ */

/* 一括施工パッケージ（差別化訴求） */
.package-featured-section {
  background: linear-gradient(135deg, var(--color-blue-dark) 0%, var(--color-blue) 100%);
  color: var(--color-white);
}

.package-featured-inner {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: var(--space-16);
  align-items: center;
}

.package-featured-badge {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  border: 1px solid var(--color-blue-light);
  border-radius: var(--radius-full);
  padding: 4px var(--space-4);
  margin-bottom: var(--space-4);
}

.package-featured-title {
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin-bottom: var(--space-2);
  line-height: var(--lh-tight);
}

.package-featured-sub {
  font-size: var(--text-base);
  color: var(--color-blue-light);
  margin-bottom: var(--space-6);
  font-weight: var(--fw-medium);
}

.package-featured-desc {
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-8);
}

.package-featured-merits {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-10);
}
.package-featured-merits li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.9);
  font-weight: var(--fw-medium);
}
.package-featured-merits li svg { color: var(--color-blue-light); flex-shrink: 0; }

/* パッケージフロー図 */
.package-flow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  background-color: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-lg);
  padding: var(--space-10) var(--space-8);
  margin-bottom: var(--space-4);
}

.package-flow__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.package-flow__icon {
  width: 64px;
  height: 64px;
  background-color: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
}

.package-flow__label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-white);
}

.package-flow__arrow { color: rgba(255, 255, 255, 0.4); flex-shrink: 0; }

.package-flow__label-main {
  text-align: center;
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  color: var(--color-blue-light);
  letter-spacing: var(--ls-normal);
}

@media (max-width: 1023px) {
  .package-featured-inner { grid-template-columns: 1fr; }
  .package-featured-visual { order: -1; }
}
@media (max-width: 767px) {
  .package-featured-title { font-size: var(--text-3xl); }
  .package-flow { flex-direction: column; gap: var(--space-3); }
  .package-flow__arrow { transform: rotate(90deg); }
}


/* サービス詳細リスト */
.service-detail-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}

.service-detail-item {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--space-12);
  align-items: center;
}
.service-detail-item--reverse {
  grid-template-columns: 1fr 320px;
}
.service-detail-item--reverse .service-detail-item__media {
  order: 2;
}
.service-detail-item--reverse .service-detail-item__body {
  order: 1;
}

.service-detail-item__media {
  position: relative;
}
.service-detail-item__num {
  position: absolute;
  top: -20px;
  left: -10px;
  font-family: var(--font-en);
  font-size: 6rem;
  font-weight: var(--fw-black);
  color: var(--color-border-light);
  line-height: 1;
  z-index: 0;
  user-select: none;
}
.service-detail-item__img-wrap {
  position: relative;
  z-index: 1;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.service-detail-item__img-placeholder {
  aspect-ratio: 4 / 3;
  background-color: var(--color-bg-section);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-border);
}
.service-detail-item__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.service-detail-item__header {
  margin-bottom: var(--space-6);
}
.service-detail-item__category {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue);
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--space-2);
}
.service-detail-item__title {
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-2);
  line-height: var(--lh-tight);
}
.service-detail-item__sub {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
}

.service-detail-item__desc {
  font-size: var(--text-base);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
}

.service-detail-item__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}
.service-detail-item__list li {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  padding-left: var(--space-5);
  position: relative;
  line-height: var(--lh-normal);
}
.service-detail-item__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 12px;
  height: 2px;
  background-color: var(--color-blue);
}

@media (max-width: 1023px) {
  .service-detail-item,
  .service-detail-item--reverse {
    grid-template-columns: 1fr;
  }
  .service-detail-item--reverse .service-detail-item__media { order: 0; }
  .service-detail-item--reverse .service-detail-item__body { order: 0; }
  .service-detail-item__num { font-size: 4rem; }
}


/* サービスエリア（service-page） */
.service-area-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-bottom: var(--space-6);
}

.service-area-tag {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--color-blue);
  background-color: var(--color-white);
  border: 1px solid var(--color-blue-light);
  border-radius: var(--radius-full);
}

.service-area-note {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--color-text-light);
}


/* ================================================================
   会社概要ページ（page-about.php）
   ================================================================ */

/* 代表メッセージ */
.about-message-inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--space-12);
  align-items: start;
}

.about-message-body {
  font-size: var(--text-base);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
}

.about-message-sig {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-light);
  font-style: normal;
}
.about-message-sig__company {
  font-size: var(--text-sm);
  color: var(--color-text-light);
}
.about-message-sig__name {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}

.about-message-photo__wrap {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}
.about-message-photo__placeholder {
  width: 100%;
  aspect-ratio: 3 / 4;
  background-color: var(--color-bg-section);
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  color: var(--color-border);
  font-size: var(--text-sm);
  text-align: center;
  line-height: var(--lh-normal);
}

@media (max-width: 1023px) {
  .about-message-inner { grid-template-columns: 1fr; }
  .about-message-photo { order: -1; max-width: 240px; }
  .about-message-photo__wrap { position: static; }
}


/* フィロソフィーグリッド */
.philosophy-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}

.philosophy-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-top: 3px solid var(--color-blue);
  border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-6);
  text-align: center;
}

.philosophy-card__icon {
  width: 72px;
  height: 72px;
  background-color: var(--color-bg-section);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-6);
  color: var(--color-blue);
}

.philosophy-card__title {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-4);
}

.philosophy-card__desc {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}

@media (max-width: 1023px) {
  .philosophy-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .philosophy-grid { grid-template-columns: repeat(3, 1fr); max-width: none; }
}


/* 会社概要テーブル */
.about-company-inner { max-width: 800px; margin: 0 auto; }

.company-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
}
.company-table tr {
  border-bottom: 1px solid var(--color-border-light);
}
.company-table tr:first-child { border-top: 1px solid var(--color-border-light); }
.company-table th {
  width: 180px;
  padding: var(--space-5) var(--space-6);
  text-align: left;
  font-weight: var(--fw-semibold);
  color: var(--color-gray);
  background-color: var(--color-bg-section);
  white-space: nowrap;
  vertical-align: top;
}
.company-table td {
  padding: var(--space-5) var(--space-6);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}
.company-table td a { color: var(--color-blue); }
.company-table td a:hover { text-decoration: underline; }

@media (max-width: 767px) {
  .company-table th,
  .company-table td { display: block; width: 100%; }
  .company-table th {
    padding-bottom: var(--space-2);
    border-bottom: none;
    font-size: var(--text-sm);
  }
  .company-table td { padding-top: var(--space-2); }
}


/* 施工エリア（about） */
.about-area-inner { max-width: 900px; margin: 0 auto; }

.about-area-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-bottom: var(--space-10);
}

.about-area-tag {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--space-3) var(--space-6);
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  min-width: 100px;
}
.about-area-tag--main {
  background-color: var(--color-blue);
  border-color: var(--color-blue);
}
.about-area-tag--main .about-area-tag__name { color: var(--color-white); }
.about-area-tag--main .about-area-tag__type { color: rgba(255,255,255,0.75); }

.about-area-tag__name {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}
.about-area-tag__type {
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

.about-map-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  margin-bottom: var(--space-4);
}

.about-area-note {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--color-text-light);
}


/* ================================================================
   お問い合わせページ（page-contact.php）
   ================================================================ */

/* 2カラムレイアウト */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-12);
  align-items: start;
  padding: var(--space-12) 0 var(--space-20);
}

/* フォームカラム */
.contact-form-col {}

.contact-form-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border-light);
}
.contact-form-head__title {
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}
.contact-form-head__note {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  white-space: nowrap;
}

/* お問い合わせフォームグリッド */
.contact-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

/* プライバシー同意 */
.contact-form__privacy {
  margin-bottom: var(--space-8);
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-bg-section);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-blue);
}

.form-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  cursor: pointer;
  line-height: var(--lh-normal);
}
.form-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-blue);
  flex-shrink: 0;
}
.form-checkbox a { color: var(--color-blue); text-decoration: underline; }

.form-radios--row {
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-6);
}

.form-fieldset {
  border: none;
  padding: 0;
  margin: 0;
}

/* ファイルアップロード */
.form-file {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}
.form-file-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.form-file-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  background-color: var(--color-bg-section);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}
.form-file-label:hover {
  background-color: var(--color-border-light);
  border-color: var(--color-blue-light);
}
.form-file-note {
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

.contact-form__submit { text-align: center; }

/* 送信完了メッセージ */
.contact-sent-msg {
  text-align: center;
  padding: var(--space-20) var(--space-8);
  background-color: var(--color-bg-section);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-light);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}
.contact-sent-msg svg { color: var(--color-blue); }
.contact-sent-msg__title {
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}
.contact-sent-msg__desc {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  max-width: 480px;
}

/* サイドバー */
.contact-info-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}

.contact-info-box {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.contact-info-box__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-blue);
}

/* 電話番号 */
.contact-info-tel {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-blue);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-2);
}
.contact-info-tel:hover { color: var(--color-blue-dark); }

.contact-info-hours {
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

.contact-form-recommend {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: color-mix(in srgb, var(--color-blue) 8%, transparent);
  border-left: 3px solid var(--color-blue);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}
.contact-form-recommend svg {
  flex-shrink: 0;
  color: var(--color-blue);
  margin-top: 1px;
}

/* 会社情報DL */
.contact-info-dl {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
}
.contact-info-dl dt {
  font-weight: var(--fw-semibold);
  color: var(--color-gray);
  padding-top: var(--space-2);
  align-self: start;
}
.contact-info-dl dd {
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  padding-top: var(--space-2);
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: var(--space-2);
}
.contact-info-dl dd:last-child { border-bottom: none; }

/* FAQ */
.contact-faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.contact-faq-item {}
.contact-faq-q {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-2);
  line-height: var(--lh-normal);
}
.contact-faq-q svg { flex-shrink: 0; color: var(--color-blue); margin-top: 1px; }
.contact-faq-a {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  padding-left: calc(16px + var(--space-2));
}

@media (max-width: 1023px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }
  .contact-info-col {
    position: static;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .contact-info-col .contact-info-box:first-child {
    grid-column: 1 / -1;
  }
}
@media (max-width: 767px) {
  .contact-form__grid { grid-template-columns: 1fr; }
  .contact-info-col { grid-template-columns: 1fr; }
}


/* ================================================================
   技術コラム一覧（archive-column.php）
   ================================================================ */

.column-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-10);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border-light);
}
.column-filter .filter-btn {
  text-decoration: none;
}

.column-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
  margin-bottom: var(--space-12);
}

/* コラムカード */
.column-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.column-card__thumb-link {
  display: block;
  overflow: hidden;
}
.column-card__thumb {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background-color: var(--color-bg-section);
  position: relative;
}
.column-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}
.column-card:hover .column-card__thumb img { transform: scale(1.05); }

.column-card__no-image {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-border);
}

.column-card__body {
  padding: var(--space-5) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.column-card__cats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.tag--column {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--color-blue);
  background-color: var(--color-bg-section);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: 2px var(--space-3);
  text-decoration: none;
}
.tag--column:hover { background-color: var(--color-blue); color: var(--color-white); border-color: var(--color-blue); }

.tag--gray {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--color-text-secondary);
  background-color: var(--color-bg-section);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-full);
  padding: 2px var(--space-3);
  text-decoration: none;
}

.column-card__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  flex: 1;
}
.column-card__title a {
  color: var(--color-gray);
  text-decoration: none;
}
.column-card__title a:hover { color: var(--color-blue); }

.column-card__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.column-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border-light);
  margin-top: auto;
}

.column-card__date {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  color: var(--color-text-light);
  letter-spacing: var(--ls-normal);
}
.column-card__more { font-size: var(--text-sm); }

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


/* ================================================================
   技術コラム詳細（single-column.php）
   ================================================================ */

/* コラムヒーロー画像 */
.column-hero-image {
  position: relative;
  width: 100%;
  max-height: 480px;
  overflow: hidden;
}
.column-hero-image img {
  width: 100%;
  max-height: 480px;
  object-fit: cover;
}
.column-hero-image__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28,28,28,0.4) 0%, transparent 60%);
}

/* 2カラムレイアウト */
.column-detail-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-12);
  align-items: start;
  padding: var(--space-8) 0 var(--space-16);
}

/* メインコンテンツ */
.column-detail-header {
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border-light);
}

.column-detail-cats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
}

.column-detail-title {
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-4);
}

.column-detail-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.column-detail-date {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-en);
  font-size: var(--text-sm);
  color: var(--color-text-light);
}

.column-detail-updated {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  padding: 2px var(--space-3);
  background-color: var(--color-bg-section);
  border-radius: var(--radius-full);
}

/* 本文エリア */
.column-detail-content.entry-content {
  font-size: var(--text-base);
  line-height: var(--lh-loose);
  color: var(--color-text-secondary);
}
.column-detail-content h2 {
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin: var(--space-10) 0 var(--space-5);
  padding-left: var(--space-4);
  border-left: 4px solid var(--color-blue);
}
.column-detail-content h3 {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin: var(--space-8) 0 var(--space-4);
}
.column-detail-content p { margin-bottom: var(--space-5); }
.column-detail-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  margin: var(--space-6) 0;
}
.column-detail-content ul,
.column-detail-content ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-5);
}
.column-detail-content li { margin-bottom: var(--space-2); line-height: var(--lh-normal); }

/* タグ */
.column-detail-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-light);
}
.column-detail-tags .tag--gray { text-decoration: none; }
.column-detail-tags .tag--gray:hover { background-color: var(--color-border-light); }

/* 前後ナビ */
.column-post-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border-light);
}

.column-post-nav__link {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-5) var(--space-6);
  background-color: var(--color-bg-section);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-light);
  text-decoration: none;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}
.column-post-nav__link:hover {
  background-color: var(--color-border-light);
  border-color: var(--color-blue-light);
}
.column-post-nav__link--next { text-align: right; }

.column-post-nav__dir {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--color-blue);
  letter-spacing: var(--ls-normal);
  text-transform: uppercase;
}
.column-post-nav__title {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray);
  line-height: var(--lh-tight);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* サイドバー */
.column-detail-sidebar {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.column-sidebar-box {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-6);
}
.column-sidebar-box__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-blue);
}

/* CTAボックス */
.column-sidebar-box--cta {
  background: linear-gradient(135deg, var(--color-blue-dark) 0%, var(--color-blue) 100%);
  border-color: transparent;
}
.column-sidebar-box--cta .column-sidebar-box__label {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  color: var(--color-blue-light);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
  display: block;
}
.column-sidebar-box--cta .column-sidebar-box__desc {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.8);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-5);
}

.column-sidebar-tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  letter-spacing: var(--ls-tight);
  margin-top: var(--space-4);
  text-decoration: none;
}
.column-sidebar-tel:hover { opacity: 0.85; }
.column-sidebar-hours {
  text-align: center;
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.6);
  margin-top: var(--space-1);
}

/* カテゴリリスト */
.column-sidebar-cats {
  list-style: none;
  display: flex;
  flex-direction: column;
}
.column-sidebar-cats__item {
  border-bottom: 1px solid var(--color-border-light);
}
.column-sidebar-cats__item:last-child { border-bottom: none; }
.column-sidebar-cats__item a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.column-sidebar-cats__item a:hover { color: var(--color-blue); }
.column-sidebar-cats__count {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  background-color: var(--color-bg-section);
  border-radius: var(--radius-full);
  padding: 2px 8px;
}

/* 最新記事 */
.column-sidebar-recent {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.column-sidebar-recent__item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}
.column-sidebar-recent__thumb {
  width: 64px;
  height: 48px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
  display: block;
}
.column-sidebar-recent__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.column-sidebar-recent__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.column-sidebar-recent__title {
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--color-gray);
  text-decoration: none;
  line-height: var(--lh-tight);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.column-sidebar-recent__title:hover { color: var(--color-blue); }
.column-sidebar-recent__date {
  font-family: var(--font-en);
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

/* 関連コラム */
.related-columns-section {
  margin-top: var(--space-16);
  padding-top: var(--space-12);
  border-top: 1px solid var(--color-border-light);
}

.column-grid--related {
  margin-bottom: 0;
}

@media (max-width: 1023px) {
  .column-detail-layout { grid-template-columns: 1fr; }
  .column-detail-sidebar { position: static; }
  .column-post-nav { grid-template-columns: 1fr; }
  .column-post-nav__link--next { text-align: left; }
}
@media (max-width: 767px) {
  .column-detail-title { font-size: var(--text-2xl); }
}


/* ================================================================
   サービス詳細ページ共通（page-concrete / repair / waterproof / package）
   ================================================================ */

/* サービス概要セクション */
.service-overview-inner {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-16);
  align-items: center;
}

.service-overview-body {
  font-size: var(--text-base);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-5);
}

.service-overview-stats {
  display: flex;
  gap: var(--space-8);
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-light);
}

.service-stat {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.service-stat__num {
  font-family: var(--font-en);
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-blue);
  line-height: 1;
}
.service-stat__num small {
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
}
.service-stat__label {
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

.service-overview-visual {}
.service-overview-img-placeholder {
  aspect-ratio: 4 / 3;
  background-color: var(--color-bg-section);
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  color: var(--color-border);
  font-size: var(--text-sm);
  text-align: center;
  line-height: var(--lh-normal);
}

@media (max-width: 1023px) {
  .service-overview-inner { grid-template-columns: 1fr; }
  .service-overview-visual { max-width: 480px; }
}
@media (max-width: 767px) {
  .service-overview-stats { flex-direction: column; gap: var(--space-4); }
}


/* 対応工事カードグリッド */
.work-types-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.work-types-grid--3col { grid-template-columns: repeat(3, 1fr); }

.work-type-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-top: 3px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: box-shadow var(--transition-normal), border-color var(--transition-normal);
}
.work-type-card:hover {
  box-shadow: var(--shadow-md);
  border-top-color: var(--color-blue);
}
.work-type-card--featured {
  border-top-color: var(--color-blue);
}

.work-type-card__icon {
  width: 56px;
  height: 56px;
  background-color: var(--color-bg-section);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-blue);
}

.work-type-card__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  line-height: var(--lh-tight);
}

.work-type-card__desc {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
  flex: 1;
}

.work-type-card__link {
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--color-blue);
  text-decoration: none;
  margin-top: var(--space-2);
}
.work-type-card__link:hover { text-decoration: underline; }

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


/* こんなお悩みに */
.pain-points-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

.pain-point-item {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.pain-point-item__q {
  background-color: var(--color-bg-section);
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  line-height: var(--lh-normal);
  position: relative;
  padding-left: var(--space-10);
}
.pain-point-item__q::before {
  content: 'Q';
  position: absolute;
  left: var(--space-5);
  top: var(--space-4);
  font-family: var(--font-en);
  font-size: var(--text-base);
  font-weight: var(--fw-black);
  color: var(--color-blue-light);
  line-height: 1.2;
}

.pain-point-item__a {
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
  position: relative;
  padding-left: var(--space-10);
}
.pain-point-item__a::before {
  content: 'A';
  position: absolute;
  left: var(--space-5);
  top: var(--space-4);
  font-family: var(--font-en);
  font-size: var(--text-base);
  font-weight: var(--fw-black);
  color: var(--color-blue);
  line-height: 1.2;
}

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


/* 施工の流れ（ステップ） */
.service-flow-steps {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  counter-reset: flow-step;
}

.service-flow-step {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
}

.service-flow-step__num {
  font-family: var(--font-en);
  font-size: var(--text-3xl);
  font-weight: var(--fw-black);
  color: var(--color-blue-light);
  line-height: 1;
  opacity: 0.6;
}

.service-flow-step__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  border-left: 3px solid var(--color-blue);
  padding-left: var(--space-3);
  line-height: var(--lh-tight);
}

.service-flow-step__desc {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}

@media (max-width: 1023px) {
  .service-flow-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .service-flow-steps { grid-template-columns: 1fr; }
}


/* FAQアコーディオン */
.service-faq-list {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-item {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.faq-item[open] {
  border-color: var(--color-blue-light);
}

.faq-item__q {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  color: var(--color-gray);
  cursor: pointer;
  list-style: none;
  line-height: var(--lh-normal);
  position: relative;
}
.faq-item__q::-webkit-details-marker { display: none; }
.faq-item__q::before {
  content: 'Q';
  font-family: var(--font-en);
  font-size: var(--text-lg);
  font-weight: var(--fw-black);
  color: var(--color-blue);
  flex-shrink: 0;
  width: 28px;
}
.faq-item__q::after {
  content: '';
  position: absolute;
  right: var(--space-6);
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--color-blue-light);
  border-bottom: 2px solid var(--color-blue-light);
  transform: rotate(45deg) translateY(-3px);
  transition: transform var(--transition-fast);
}
.faq-item[open] .faq-item__q::after {
  transform: rotate(-135deg) translateY(-3px);
}
.faq-item__q:hover { background-color: var(--color-bg-section); }

.faq-item__a {
  padding: var(--space-4) var(--space-6) var(--space-5) calc(var(--space-6) + 28px + var(--space-4));
  border-top: 1px solid var(--color-border-light);
  background-color: var(--color-bg-section);
}
.faq-item__a p {
  font-size: var(--text-base);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}


/* 一括施工パッケージ専用 */
.page-hero--package .page-hero__overlay {
  background: linear-gradient(135deg, var(--color-blue-dark) 0%, var(--color-blue) 60%, var(--color-blue-light) 100%);
}

.package-merit-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}

.package-merit-badges {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.package-badge {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background-color: var(--color-bg-section);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-blue);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--color-gray);
}
.package-badge svg { color: var(--color-blue); flex-shrink: 0; }

@media (max-width: 1023px) {
  .package-merit-inner { grid-template-columns: 1fr; }
  .work-types-grid--3col { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .package-merit-badges { grid-template-columns: 1fr; }
}


/* ================================================================
   セルフレベリング工法ページ（page-selfleveling.php）
   ================================================================ */

/* イントロセクション */
.sl-intro-inner {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-16);
  align-items: start;
  margin-bottom: var(--space-16);
}

.sl-feature-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.sl-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--color-blue);
  background-color: var(--color-bg-section);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
}
.sl-tag svg { flex-shrink: 0; }

.sl-intro-visual {}

@media (max-width: 1023px) {
  .sl-intro-inner { grid-template-columns: 1fr; }
  .sl-intro-visual { max-width: 480px; }
}


/* 比較表 */
.sl-compare-wrap {
  padding-top: var(--space-12);
  border-top: 1px solid var(--color-border-light);
}

.sl-compare-title {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-6);
  text-align: center;
}

.sl-compare-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: var(--space-4);
}

.sl-compare-table {
  width: 100%;
  min-width: 560px;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.sl-compare-table thead th {
  padding: var(--space-4) var(--space-6);
  background-color: var(--color-bg-section);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  border-bottom: 2px solid var(--color-border);
  text-align: center;
}

.sl-compare-table thead .sl-compare-table__highlight {
  background-color: var(--color-blue);
}

.sl-compare-label {
  color: var(--color-white);
  font-weight: var(--fw-bold);
}

.sl-compare-table tbody tr { border-bottom: 1px solid var(--color-border-light); }
.sl-compare-table tbody tr:last-child { border-bottom: none; }

.sl-compare-table tbody th {
  padding: var(--space-4) var(--space-6);
  font-weight: var(--fw-semibold);
  color: var(--color-gray);
  background-color: var(--color-bg-section);
  white-space: nowrap;
  width: 180px;
}

.sl-compare-table tbody td {
  padding: var(--space-4) var(--space-6);
  color: var(--color-text-secondary);
  text-align: center;
  line-height: var(--lh-normal);
  vertical-align: top;
}

.sl-compare-table tbody td small {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-light);
  margin-top: 4px;
}

.sl-compare-table__highlight {
  background-color: rgba(56, 96, 153, 0.05);
  border-left: 2px solid var(--color-blue-light);
  border-right: 2px solid var(--color-blue-light);
}

.sl-good { color: var(--color-blue); font-weight: var(--fw-bold); }

.sl-compare-note {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  text-align: center;
}


/* 活用シーングリッド */
.sl-usecase-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8);
}

.sl-usecase-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.sl-usecase-card__icon {
  width: 64px;
  height: 64px;
  background-color: var(--color-bg-section);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-blue);
}

.sl-usecase-card__title {
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  line-height: var(--lh-tight);
}

.sl-usecase-card__desc {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
  flex: 1;
}

.sl-usecase-card__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border-light);
}
.sl-usecase-card__list li {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  padding-left: var(--space-4);
  position: relative;
}
.sl-usecase-card__list li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--color-blue-light);
  font-size: 10px;
  top: 1px;
}

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


/* 施工の流れ（フロー） */
.sl-flow-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  max-width: 900px;
  margin: 0 auto;
}

.sl-flow-item {
  display: grid;
  grid-template-columns: 60px 160px 1fr;
  gap: var(--space-6);
  align-items: center;
  background-color: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
  position: relative;
}

.sl-flow-item__num {
  font-family: var(--font-en);
  font-size: var(--text-3xl);
  font-weight: var(--fw-black);
  color: var(--color-blue-light);
  opacity: 0.5;
  line-height: 1;
  text-align: center;
}

.sl-flow-item__img-wrap {
  aspect-ratio: 4 / 3;
  background-color: var(--color-bg-section);
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sl-flow-item__img-wrap img { width: 100%; height: 100%; object-fit: cover; }

.sl-flow-item__img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-border);
}

.sl-flow-item__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-2);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.sl-flow-item__title::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 1em;
  background-color: var(--color-blue);
  border-radius: 2px;
  flex-shrink: 0;
}

.sl-flow-item__desc {
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
  color: var(--color-text-secondary);
}

@media (max-width: 1023px) {
  .sl-flow-item { grid-template-columns: 48px 120px 1fr; }
}
@media (max-width: 767px) {
  .sl-flow-item {
    grid-template-columns: 40px 1fr;
    grid-template-rows: auto auto;
  }
  .sl-flow-item__img-wrap { display: none; }
  .sl-flow-item__body { grid-column: 2; }
}


/* 関連サービスリンク */
.sl-related-services {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  padding: var(--space-8) 0 var(--space-12);
  border-top: 1px solid var(--color-border-light);
  margin-top: var(--space-4);
}

.sl-related-services__label {
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  color: var(--color-text-light);
  white-space: nowrap;
}

.sl-related-services__links {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.btn--sm {
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
}

@media (max-width: 767px) {
  .sl-related-services { flex-direction: column; align-items: flex-start; }
}


/* ==========================================================================
   サイトマップページ
   ========================================================================== */

.sitemap-body {
  padding: var(--space-16) 0 var(--space-20);
}

.sitemap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
  align-items: start;
}

/* セクション */
.sitemap-section {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.sitemap-section__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: var(--color-blue);
  color: var(--color-white);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  margin: 0;
}

.sitemap-section__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  opacity: .85;
}

/* リスト */
.sitemap-list {
  list-style: none;
  margin: 0;
  padding: var(--space-3) 0;
}

.sitemap-list__item {
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
}
.sitemap-list__item:last-child { border-bottom: none; }

.sitemap-list__item a {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  transition: color var(--transition-fast), background-color var(--transition-fast);
}
.sitemap-list__item a::before {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-top: 2px solid var(--color-blue);
  border-right: 2px solid var(--color-blue);
  transform: rotate(45deg);
  flex-shrink: 0;
}
.sitemap-list__item a:hover {
  color: var(--color-blue);
  background-color: var(--color-bg-section);
}

/* 親リンク（太字） */
.sitemap-list__item--top > a {
  font-weight: var(--fw-medium);
}

/* 子リンク（インデント） */
.sitemap-list__item--child > a {
  padding-left: var(--space-8);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}
.sitemap-list__item--child > a::before {
  width: 5px;
  height: 5px;
  border-color: var(--color-text-light);
}

/* 空の場合 */
.sitemap-list__item--empty {
  padding: var(--space-3) var(--space-8);
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

/* SEOバッジ */
.sitemap-list__item--badge a { justify-content: space-between; }
.sitemap-badge {
  font-size: 10px;
  font-weight: var(--fw-bold);
  color: var(--color-white);
  background: var(--color-blue);
  border-radius: 3px;
  padding: 1px 5px;
  letter-spacing: .05em;
  flex-shrink: 0;
}

/* Responsive */
@media (max-width: 1023px) {
  .sitemap-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .sitemap-grid { grid-template-columns: 1fr; gap: var(--space-5); }
  .sitemap-body { padding: var(--space-10) 0 var(--space-16); }
}


/* ==========================================================================
   FAQ PAGE
   ========================================================================== */

.faq-body {
  padding: var(--space-12) 0 var(--space-20);
}

.faq-group {
  margin-bottom: var(--space-12);
}

.faq-group__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  background: var(--color-blue-dark);
  padding: var(--space-4) var(--space-6);
  border-radius: 6px 6px 0 0;
  margin: 0;
}

.faq-group__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  opacity: .9;
}

.faq-list {
  border: 1px solid var(--color-border);
  border-top: none;
  border-radius: 0 0 6px 6px;
  overflow: hidden;
}

.faq-item {
  border-bottom: 1px solid var(--color-border);
}
.faq-item:last-child { border-bottom: none; }

.faq-item__q {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  cursor: pointer;
  list-style: none;
  font-size: var(--text-base);
  font-weight: var(--fw-medium);
  color: var(--color-text-primary);
  background: var(--color-white);
  transition: background-color var(--transition-fast);
  user-select: none;
}
.faq-item__q::-webkit-details-marker { display: none; }
.faq-item__q:hover { background: var(--color-bg-section); }

.faq-item__q-label {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-blue);
  color: var(--color-white);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  border-radius: 50%;
  line-height: 1;
  margin-top: 1px;
}

.faq-item__q-text {
  flex: 1;
}

.faq-item__chevron {
  flex-shrink: 0;
  color: var(--color-text-light);
  transition: transform var(--transition-fast);
  margin-top: 4px;
}

[open] .faq-item__q .faq-item__chevron {
  transform: rotate(180deg);
}

.faq-item__a {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  background: var(--color-bg-section);
  border-top: 1px solid var(--color-border);
}

.faq-item__a-label {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-gray);
  color: var(--color-white);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  border-radius: 50%;
  line-height: 1;
  margin-top: 1px;
}

.faq-item__a p {
  flex: 1;
  margin: 0;
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: 1.8;
}

/* FAQ お問い合わせCTA */
.faq-contact-cta {
  margin-top: var(--space-12);
  padding: var(--space-10) var(--space-8);
  background: var(--color-bg-section);
  border-radius: 8px;
  text-align: center;
}

.faq-contact-cta__text {
  margin: 0 0 var(--space-6);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
}

/* Responsive */
@media (max-width: 767px) {
  .faq-body { padding: var(--space-10) 0 var(--space-16); }
  .faq-group__head { font-size: var(--text-base); padding: var(--space-3) var(--space-4); }
  .faq-item__q { padding: var(--space-4); font-size: var(--text-sm); }
  .faq-item__a { padding: var(--space-4); }
  .faq-contact-cta { padding: var(--space-8) var(--space-5); }
}


/* ==========================================================================
   一人親方・協力会社募集ページ（page-partner）
   ========================================================================== */

/* ヒーロー背景 */
.page-hero--partner .page-hero__overlay {
  background: linear-gradient(135deg, var(--color-gray) 0%, var(--color-blue-dark) 55%, var(--color-blue) 100%);
  opacity: 0.92;
}

/* ヒーローボタン群 */
.page-hero__actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-top: var(--space-8);
}

/* セクション共通リード文 */
.partner-section-body {
  max-width: 760px;
  margin: 0 auto var(--space-12);
  text-align: center;
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: var(--lh-loose);
}

/* ----------------------------------------------------------------
   強みグリッド（4カード）
   ---------------------------------------------------------------- */
.partner-points-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-bottom: var(--space-12);
}

.partner-point-card {
  background: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-6) var(--space-5);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}
.partner-point-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

.partner-point-card__num {
  font-family: var(--font-en);
  font-size: var(--text-4xl);
  font-weight: var(--fw-black);
  color: var(--color-blue-light);
  opacity: 0.25;
  line-height: 1;
  margin-bottom: var(--space-3);
}

.partner-point-card__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-2);
}

.partner-point-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

/* ----------------------------------------------------------------
   職種別単価グリッド（3カード）
   ---------------------------------------------------------------- */
.partner-types-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-12);
}

.partner-type-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-top: 4px solid var(--color-blue);
  border-radius: var(--radius-md);
  padding: var(--space-7, 1.75rem) var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}
.partner-type-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.partner-type-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border-light);
}

.partner-type-card__type {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}

.partner-type-card__rate {
  font-family: var(--font-en);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  color: var(--color-blue);
  background: rgba(56, 96, 153, 0.08);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.partner-type-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

/* ----------------------------------------------------------------
   応募条件・希望条件ボックス
   ---------------------------------------------------------------- */
.partner-req-box {
  background: var(--color-bg-section);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-10) var(--space-12);
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
}

.partner-req-box__title {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 2px solid var(--color-blue-light);
  display: inline-block;
}

.partner-req-box__list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-8);
  text-align: left;
  display: inline-block;
}

.partner-req-box__list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
  padding: var(--space-2) 0;
}

.partner-req-box__list li::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  min-width: 20px;
  background-color: var(--color-blue);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='9' viewBox='0 0 11 9' fill='none'%3E%3Cpath d='M1 4.5L4 7.5L10 1' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.partner-req-box__action { text-align: center; }

/* ----------------------------------------------------------------
   協業メリットグリッド（2×2）
   ---------------------------------------------------------------- */
.partner-merits-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-12);
}

.partner-merit-card {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  background: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-normal);
}
.partner-merit-card:hover { box-shadow: var(--shadow-hover); }

.partner-merit-card__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-blue);
  color: var(--color-white);
  border-radius: 50%;
}

.partner-merit-card__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: var(--space-2);
}

.partner-merit-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-normal);
}

/* フォームセクション説明文 */
.partner-form-desc {
  text-align: center;
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-10);
}

/* ----------------------------------------------------------------
   Responsive
   ---------------------------------------------------------------- */
@media (max-width: 1023px) {
  .partner-points-grid { grid-template-columns: repeat(2, 1fr); }
  .partner-merits-grid { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .page-hero__actions { flex-direction: column; align-items: flex-start; }
  .partner-section-body { font-size: var(--text-base); }
  .partner-points-grid { grid-template-columns: 1fr; }
  .partner-types-grid  { grid-template-columns: 1fr; }
  .partner-req-box     { padding: var(--space-8) var(--space-5); }
  .partner-type-card__header { flex-wrap: wrap; gap: var(--space-2); }
  .partner-merit-card  { flex-direction: column; gap: var(--space-3); }
}
