/*
Theme Name: 大西重機オリジナルテーマ
Theme URI: https://onishijuki.com/
Author: 株式会社大西重機
Author URI: https://onishijuki.com/
Description: 株式会社大西重機の公式ホームページ用カスタムテーマ
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: onishijuki
*/

/* === Modern CSS Reset === */

/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role */
ul[role='list'],
ol[role='list'],
nav ul,
nav ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.8;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove default button styles */
button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* === Design System v2 === */
:root {
  /* === Color System === */
  --color-black: #000000;
  --color-white: #FFFFFF;
  --color-primary: #01523F;
  --color-sub: #F7E97E;
  --color-accent: #ABCD04;
  --color-cta-text: #0A2A00;

  --color-base: var(--color-white);
  --color-bg: var(--color-white);
  --color-bg-soft: color-mix(in srgb, var(--color-sub) 16%, var(--color-white));
  --color-features-bg: color-mix(in srgb, var(--color-sub) 22%, var(--color-white));
  --color-text: #1A1A1A;
  --color-text-sub: #5C5C5C;
  --color-primary-light: #026B52;
  --color-primary-dark: #013D2F;
  --color-secondary: var(--color-sub);
  --color-secondary-light: color-mix(in srgb, var(--color-sub) 70%, var(--color-white));
  --color-accent-light: color-mix(in srgb, var(--color-accent) 18%, var(--color-white));
  --color-accent-dark: #8AA803;
  --brand-gradient-line: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-accent) 48%,
    var(--color-sub) 100%
  );
  --section-title-underline-w: 5.5rem;
  --color-border: #E5E7EB;
  --service-showcase-accent: #005a54;

  /* レイヤード見出し・背面英字（左はやや薄め → 中央〜右寄りで明るく → 右端だけわずかに締まる） */
  --section-title-en-gradient-light: linear-gradient(
    90deg,
    #bccad8 0%,
    #d3dde8 26%,
    #e9eef6 52%,
    #f6f9fc 76%,
    #dae5ef 100%
  );
  --section-title-en-gradient-on-dark-bg: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.14) 0%,
    rgba(255, 255, 255, 0.26) 34%,
    rgba(255, 255, 255, 0.48) 68%,
    rgba(255, 255, 255, 0.34) 100%
  );
  /* 代表ご挨拶 MESSAGE：背景に溶けるウォーターマーク（同上のリズム） */
  --section-title-en-gradient-greeting-air: linear-gradient(
    90deg,
    rgba(184, 196, 210, 0.38) 0%,
    rgba(218, 226, 236, 0.36) 40%,
    rgba(245, 248, 252, 0.32) 74%,
    rgba(198, 212, 228, 0.4) 100%
  );

  /* === Typography === */
  --font-heading: 'Zen Kaku Gothic New', 'Noto Sans JP', sans-serif;
  --font-body: 'Noto Sans JP', sans-serif;
  --font-hero-catch: 'Zen Kaku Gothic New', 'Noto Sans JP', sans-serif;
  --font-greeting-serif: 'Noto Serif JP', 'Noto Sans JP', serif;
  --font-en: 'Inter', sans-serif;
  --font-script: 'Great Vibes', cursive;
  --font-sign: 'Allura', 'Great Vibes', cursive;

  /* === Layout === */
  --content-max: 1140px;
  --container-max: var(--content-max);
  --blog-article-max: min(42rem, 100%);
  --header-height: 64px;
  --section-gap: 6rem;
  --section-gap-mobile: 4rem;
  --element-gap: 1.5rem;

  /* === Spacing === */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 40px;
  --space-2xl: 64px;
  --space-3xl: 96px;

  /* === Border Radius === */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;
  --radius-button: var(--radius-md);
  --radius-card: var(--radius-lg);

  /* === Shadows === */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.12);
  --shadow-xl: 0 16px 48px rgba(0,0,0,0.16);

  /* === Transitions === */
  --transition-fast: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-normal: var(--transition-base);

  /* === Z-index === */
  --z-header: 100;
  --z-modal: 1000;
  --z-loader: 9999;
}

/* Breakpoints (使用時のリファレンスとしてコメントで記載) */
/* PC: 1024px以上 */
/* タブレット: 768px〜1023px */
/* スマホ: 767px以下 */

/* リセット */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  font-family: var(--font-body);
  line-height: 1.8;
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  min-height: 100vh;
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

button, input, textarea, select {
  font: inherit;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover, a:focus {
  color: var(--color-primary-dark);
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-family: var(--font-heading);
  color: var(--color-text);
}

h1 { font-size: clamp(2rem,   5vw,   3.5rem);   font-weight: 900; line-height: 1.2; }
h2 {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.06em;
}
h3 { font-size: clamp(1.2rem, 2.5vw, 1.5rem);   font-weight: 700; line-height: 1.4; }
h4 { font-size: clamp(1rem,   1.5vw, 1.125rem); font-weight: 500; line-height: 1.5; }
small { font-size: 0.875rem; }

/* 英数字・電話番号・日付に Inter を適用 */
.num, .en, time, [class*="-en"] { font-family: var(--font-en); }

p {
  margin: 0 0 1.25rem;
}

ul, ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

button {
  border: none;
  background: none;
}

img {
  border-style: none;
}

main {
  display: block;
}

.container {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 2rem);
}

/* ヒーロー（ファーストビュー）は全幅のまま、内側コンテナのみ従来どおり */
.hero-section .container,
.hero-section-parallax .container {
  max-width: none;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  width: 100%;
  background-color: var(--color-white);
  border-bottom: 1px solid var(--color-border);
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.06);
  transition:
    background-color 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease;
}

/* ヘッダーは画面幅いっぱい・ロゴ左／ナビ右（本文用 max-width は適用しない） */
.site-header .header-inner.container {
  width: 100%;
  max-width: none;
  margin-inline: 0;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
  box-sizing: border-box;
}

/* ヒーロー上：背景のみ100%透過（次のセクションに入るまで）。ロゴ・ナビの色は通常どおり */
.site-header.is-translucent {
  background-color: transparent;
  border-bottom-color: transparent;
  box-shadow: none;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(0.75rem, 2vw, 1.5rem);
  min-height: var(--header-height);
}

.site-branding {
  flex: 0 0 auto;
  min-width: 0;
}

.site-header .site-navigation {
  flex: 1 1 auto;
  min-width: 0;
}

.footer-inner {
  display: grid;
  align-items: center;
  gap: 1rem;
  grid-template-columns: auto 1fr auto;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.site-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

.site-logo-mark {
  display: block;
  flex-shrink: 0;
  width: 28px;
  height: 32px;
  line-height: 0;
}

.site-logo-svg {
  width: 28px;
  height: auto;
  overflow: visible;
}

.site-logo-mark .loader-logo-shape {
  fill: var(--color-black);
  stroke: none;
}

.site-logo-text {
  font-family: var(--font-heading);
  font-size: 1.425rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.06em;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .site-logo-mark {
    width: 24px;
    height: 27px;
  }

  .site-logo-svg {
    width: 24px;
  }

  .site-logo-text {
    font-size: 1.2rem;
  }
}

.site-navigation {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.site-navigation .main-menu {
  display: flex;
  justify-content: flex-end;
  gap: 2rem;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-navigation .main-menu li {
  margin: 0;
  list-style: none;
}

/* ナビリンク：センターから広がるアンダーライン */
.site-navigation .main-menu a {
  position: relative;
  color: var(--color-text);
  font-weight: 600;
  text-decoration: none;
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  padding-bottom: 3px;
  transition: color 0.22s ease;
}

.site-navigation .main-menu a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  right: 50%;
  height: 2px;
  background-color: var(--color-primary);
  border-radius: 1px;
  transition: left 0.25s ease, right 0.25s ease;
}

.site-navigation .main-menu a:hover,
.site-navigation .main-menu a:focus {
  color: var(--color-primary);
}

.site-navigation .main-menu a:hover::after,
.site-navigation .main-menu a:focus::after {
  left: 0;
  right: 0;
}

/* カレントページ */
.site-navigation .main-menu .current-menu-item > a,
.site-navigation .main-menu .current_page_item > a,
.site-navigation .main-menu .current-menu-ancestor > a,
.site-navigation .main-menu .current-page-ancestor > a {
  color: var(--color-primary);
}

.site-navigation .main-menu .current-menu-item > a::after,
.site-navigation .main-menu .current_page_item > a::after,
.site-navigation .main-menu .current-menu-ancestor > a::after,
.site-navigation .main-menu .current-page-ancestor > a::after {
  left: 0;
  right: 0;
}

/* お問い合わせボタン（ヘッダー全高・CTAアクセント） */
.site-navigation .main-menu a[href*="/contact/"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--header-height);
  padding: 0 1.75rem;
  border-radius: 0;
  background: var(--color-accent);
  border: none;
  color: var(--color-cta-text);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1;
  transition: background 0.22s ease, color 0.22s ease;
}

.site-navigation .main-menu a[href*="/contact/"]:hover,
.site-navigation .main-menu a[href*="/contact/"]:focus {
  background: var(--color-accent-dark);
  color: var(--color-cta-text);
}

.site-navigation .main-menu a[href*="/contact/"]::after {
  display: none;
}

/* ハンバーガーボタン */
.menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  background: none;
  border: 1.5px solid rgba(17, 17, 17, 0.22);
  color: #111;
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.22s ease, color 0.22s ease;
}

.menu-toggle:hover {
  border-color: #111;
}


.menu-toggle-box {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 22px;
  height: 16px;
}

.menu-toggle-bar {
  display: block;
  height: 2px;
  width: 100%;
  background-color: currentColor;
  border-radius: 1px;
  transform-origin: center;
  transition: transform 0.3s ease, opacity 0.25s ease;
}

.site-navigation.open .menu-toggle-bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.site-navigation.open .menu-toggle-bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.site-navigation.open .menu-toggle-bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}


.site-footer {
  position: relative;
  z-index: 1;
  width: 100%;
  background: #0b100e;
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.9rem;
}

.site-footer::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: var(--brand-gradient-line);
}

.footer-main-wrap {
  padding-block: clamp(2.5rem, 5vw, 3.75rem);
}

.footer-main {
  --footer-gap: clamp(1.25rem, 2vw, 1.75rem);
  --footer-brand-col: minmax(280px, 360px);
  --footer-map-col: minmax(clamp(320px, 38vw, 540px), 1fr);
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas:
    'brand'
    'nav'
    'map';
  gap: var(--footer-gap);
  text-align: left;
}

.footer-brand {
  grid-area: brand;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  min-width: 0;
}

.footer-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.footer-logo:hover,
.footer-logo:focus {
  opacity: 0.92;
}

.footer-logo img {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  filter: brightness(0) invert(1);
}

.footer-logo__text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.footer-logo__name {
  font-family: var(--font-heading);
  font-size: clamp(1.15rem, 2.4vw, 1.35rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.05em;
  line-height: 1.35;
}

.footer-logo__tagline {
  font-size: 0.75rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.48);
  letter-spacing: 0.04em;
}

.footer-address {
  margin: 0;
  font-style: normal;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.875rem;
}

.footer-contact {
  display: grid;
  gap: 0.55rem;
  margin: 0;
}

.footer-contact__item {
  display: grid;
  grid-template-columns: 5.5rem minmax(0, 1fr);
  align-items: baseline;
  gap: 0.65rem;
  margin: 0;
}

.footer-contact dt {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.42);
}

.footer-contact dd {
  margin: 0;
  font-family: var(--font-en);
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
}

.footer-contact__item:first-child dd {
  font-size: 1.15rem;
}

.footer-contact a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-contact a:hover,
.footer-contact a:focus {
  color: var(--color-sub);
}

.footer-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.25rem;
  margin-top: 0.35rem;
}

.footer-social {
  display: flex;
  gap: 0.65rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.14);
  line-height: 0;
  text-decoration: none;
  transition:
    transform var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
}

.footer-social__link img {
  width: 1.65rem;
  height: 1.65rem;
  display: block;
  object-fit: contain;
}

.footer-social__link:hover,
.footer-social__link:focus {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--color-accent) 55%, transparent);
  box-shadow: 0 0 16px color-mix(in srgb, var(--color-accent) 28%, transparent);
  background: rgba(255, 255, 255, 0.1);
}

.footer-social__link:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.footer-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  padding: 0 1.35rem;
  border-radius: 999px;
  background: var(--color-accent);
  color: var(--color-cta-text);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none;
  transition:
    background var(--transition-fast),
    transform var(--transition-fast),
    box-shadow var(--transition-fast);
}

.footer-cta:hover,
.footer-cta:focus {
  background: var(--color-accent-dark);
  color: var(--color-cta-text);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(171, 205, 4, 0.28);
}

.footer-cta:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

.footer-nav {
  grid-area: nav;
  display: flex;
  justify-content: flex-start;
  padding-top: 0;
}

.footer-map {
  grid-area: map;
  position: relative;
  width: 100%;
  min-width: 0;
  min-height: 0;
  background: #121816;
  border-left: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  overflow: hidden;
}

.footer-menu {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-menu a {
  position: relative;
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.875rem;
  text-decoration: none;
  padding-left: 0.85rem;
  transition: color var(--transition-fast);
}

.footer-menu a::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-accent);
  opacity: 0.65;
  transition: opacity var(--transition-fast);
}

.footer-menu a:hover,
.footer-menu a:focus {
  color: #fff;
}

.footer-menu a:hover::before,
.footer-menu a:focus::before {
  opacity: 1;
}

.footer-map__frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(20%) contrast(1.02) brightness(0.9);
}

.footer-map__link {
  position: absolute;
  right: 0.85rem;
  bottom: 0.85rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0 0.85rem;
  border-radius: 4px;
  background: rgba(11, 16, 14, 0.82);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-decoration: none;
  backdrop-filter: blur(6px);
  transition:
    background var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast);
}

.footer-map__link:hover,
.footer-map__link:focus {
  background: rgba(11, 16, 14, 0.95);
  border-color: color-mix(in srgb, var(--color-accent) 50%, transparent);
  color: #fff;
}

.footer-bottom-wrap {
  padding-block: 1.35rem 1.65rem;
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  text-align: left;
}

.footer-copyright {
  margin: 0;
  color: rgba(255, 255, 255, 0.38);
  font-size: 0.8rem;
  font-family: var(--font-en);
}

.footer-legal {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 1.35rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-legal a {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.8rem;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-legal a:hover,
.footer-legal a:focus {
  color: rgba(255, 255, 255, 0.9);
}

@media (min-width: 1024px) {
  .footer-main {
    grid-template-columns: var(--footer-brand-col) var(--footer-map-col);
    grid-template-areas:
      'brand map'
      'nav .';
    align-items: stretch;
    justify-content: center;
    column-gap: clamp(1.25rem, 2vw, 1.75rem);
    row-gap: clamp(1.5rem, 3vw, 2rem);
  }

  .footer-brand {
    align-self: start;
  }

  .footer-map {
    grid-row: 1;
    grid-column: 2;
    height: auto;
    align-self: stretch;
  }
}

@media (max-width: 1023px) {
  .footer-main-wrap {
    padding-block: clamp(2rem, 6vw, 2.75rem);
  }

  .footer-main {
    gap: clamp(1.25rem, 4vw, 1.75rem);
    justify-items: center;
  }

  .footer-brand,
  .footer-nav {
    width: fit-content;
    max-width: 100%;
  }

  .footer-map {
    justify-self: stretch;
    height: clamp(240px, 48vw, 320px);
    min-height: clamp(240px, 48vw, 320px);
    border-left: none;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
  }

  .footer-nav {
    justify-content: flex-start;
  }
}

@media (max-width: 767px) {
  .footer-main-wrap {
    padding-block: clamp(2rem, 6vw, 2.5rem);
  }

  .footer-contact__item {
    grid-template-columns: 4.75rem minmax(0, 1fr);
  }

  .footer-actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
  }

  .footer-nav {
    padding-top: 0;
    border-top: none;
  }

  .footer-map {
    height: clamp(220px, 56vw, 300px);
    min-height: clamp(220px, 56vw, 300px);
  }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
}

/* === トップページ・オープニング（全画面ステージ + 線描画 + フェードアウト） === */
html.opening-skip .site-opening-stage {
  display: none !important;
}

.site-opening-stage {
  position: fixed;
  inset: 0;
  z-index: var(--z-loader);
  display: grid;
  place-items: center;
  background: var(--color-black);
  opacity: 1;
  pointer-events: auto;
  transition: opacity 0.7s ease;
}

.site-opening-stage.is-fade-out {
  opacity: 0;
  pointer-events: none;
}

.site-opening-stage__logo-wrap {
  padding: 10px;
}

.site-opening-stage .site-logo-svg {
  width: min(240px, 56vw);
  height: auto;
  overflow: visible;
  display: block;
}

.site-opening-stage .loader-logo-shape {
  fill: none;
  stroke: #fff;
  stroke-width: 5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: var(--path-length, 1000);
  stroke-dashoffset: var(--path-length, 1000);
}

.site-opening-stage.is-animate .loader-logo-shape {
  animation: logoLineDraw 1.45s ease forwards;
}

@keyframes logoLineDraw {
  to {
    stroke-dashoffset: 0;
  }
}

body.opening-pointer-lock {
  overflow: hidden;
}

.hero-section {
  background-color: var(--color-bg-soft);
  padding: 5rem 0;
  position: relative;
  overflow: hidden;
}

.hero-section .container {
  position: relative;
  z-index: 2;
}

.hero-section-parallax {
  background-color: #0a1e22;
  color: #fff;
  min-height: calc(100dvh - var(--header-height));
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 0;
  position: sticky;
  top: var(--header-height);
  z-index: 0;
}

.hero-section-parallax .container {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  min-height: calc(100dvh - var(--header-height));
  box-sizing: border-box;
  padding-top: clamp(1.75rem, 9vh, 4.5rem);
  padding-bottom: clamp(1.5rem, 4vh, 2.5rem);
}

.hero-section-parallax h1,
.hero-section-parallax .eyebrow {
  color: #fff;
}

.hero-parallax-bg {
  position: absolute;
  top: -10%;
  left: 0;
  width: 100%;
  height: 120%;
  background-size: cover;
  background-position: center 35%;
  transform: translate3d(0, 0, 0) scale(1.12);
  /* 黄味を抑え、クールな青緑トーンに寄せる */
  filter: saturate(0.88) hue-rotate(-5deg) brightness(0.98) contrast(1.03);
  will-change: transform;
  z-index: 0;
}

.hero-animated .hero-parallax-bg {
  animation: heroBackgroundZoom 8s ease-out forwards;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  /* 高級感のある深い被せ（黄味の少ないクールティール） */
  background: linear-gradient(
    180deg,
    rgba(6, 28, 34, 0.62) 0%,
    rgba(5, 30, 36, 0.4) 38%,
    rgba(2, 14, 18, 0.22) 58%,
    rgba(0, 0, 0, 0) 78%
  );
}

.hero-content {
  width: fit-content;
  max-width: min(1080px, 100%);
  margin-inline: auto;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: clamp(1.75rem, 4.5vw, 3.5rem);
}

.hero-tagline-col {
  flex: 0 1 auto;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding-top: clamp(1.75rem, 4.5vh, 2.85rem);
}

.hero-catch-col {
  flex: 0 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.hero-tagline {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  gap: clamp(0.75rem, 1.35vw, 1.1rem);
  margin: 0;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.94);
  text-shadow: 0 1px 16px rgba(0, 0, 0, 0.45);
  opacity: 0;
  transform: translateY(1.25rem);
  animation: heroTaglineRise 0.55s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  animation-delay: 1.65s;
  animation-play-state: paused;
}

.hero-tagline p {
  display: block;
  margin: 0;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: clamp(0.8125rem, 0.78rem + 0.28vw, 0.975rem);
  line-height: 1.45;
  letter-spacing: 0.08em;
}

.hero-tagline p br {
  display: block;
  line-height: 1.45;
}

.hero-catch-reveal {
  position: relative;
  display: block;
  width: fit-content;
  max-width: min(100%, 90vw);
  margin-inline: auto;
  overflow: visible;
}

.hero-catch-image {
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  margin-bottom: 0;
  clip-path: inset(0 100% 0 0);
  animation: heroCatchImgUnclip 0.38s cubic-bezier(0.65, 0, 0.35, 1) forwards;
  animation-delay: 0;
  animation-fill-mode: both;
}

.hero-catch-copy {
  position: relative;
  z-index: 0;
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  justify-content: center;
  gap: clamp(0.35rem, 1.2vw, 0.65rem);
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  color: #fff;
}

.hero-catch-copy__line {
  --catch-delay: 0.2s;
  display: block;
  font-family: var(--font-hero-catch);
  font-size: clamp(1.75rem, 4.2vw, 3.25rem);
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 0.12em;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-feature-settings: 'palt' 1;
  text-shadow: 0 1px 24px rgba(0, 0, 0, 0.35);
}

.hero-catch-copy__line--delay {
  --catch-delay: 0.72s;
}

.hero-catch-line__inner {
  position: relative;
  display: block;
  overflow: hidden;
}

.hero-catch-line__text {
  display: block;
  opacity: 0;
  clip-path: inset(0 0 100% 0);
  animation: heroCatchTextReveal 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  animation-delay: var(--catch-delay, 0s);
  animation-play-state: paused;
}

.hero-catch-line__slit {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 2;
  width: 2px;
  height: 30%;
  margin-left: -1px;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(255, 255, 255, 0.92) 45%,
    rgba(255, 255, 255, 0.92) 55%,
    transparent 100%
  );
  box-shadow:
    0 0 10px 1px rgba(255, 255, 255, 0.5),
    0 0 22px 3px rgba(255, 255, 255, 0.22);
  opacity: 0;
  transform: translateY(-130%);
  pointer-events: none;
  animation: heroCatchSlitDown 0.9s cubic-bezier(0.42, 0, 0.2, 1) forwards;
  animation-delay: var(--catch-delay, 0s);
  animation-play-state: paused;
}

.hero-fade-up {
  opacity: 0;
  transform: translateY(24px);
  animation: heroFadeUp 0.9s ease forwards;
}

.hero-fade-delay-1 {
  animation-delay: 0.2s;
}

.hero-fade-delay-2 {
  animation-delay: 0.45s;
}

.hero-fade-delay-3 {
  animation-delay: 0.7s;
}

.hero-title-reveal {
  position: relative;
  display: inline-block;
  overflow: hidden;
}

.hero-title-reveal > span {
  display: inline-block;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(8px);
  animation: heroTitleShow 0.5s ease forwards;
  animation-delay: 0.5s;
}

.hero-title-reveal::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.9);
  transform: translateX(-102%);
  animation: heroTitleMask 1s cubic-bezier(0.77, 0, 0.18, 1) forwards;
  animation-delay: 0.35s;
}

.hero-animated .hero-parallax-bg,
.hero-animated .hero-fade-up,
.hero-animated .hero-title-reveal > span,
.hero-animated .hero-title-reveal::after,
.hero-animated .hero-catch-image,
.hero-animated .hero-catch-line__text,
.hero-animated .hero-catch-line__slit,
.hero-animated .hero-tagline {
  animation-play-state: paused;
}

body.hero-ready .hero-animated .hero-parallax-bg,
body.hero-ready .hero-animated .hero-fade-up,
body.hero-ready .hero-animated .hero-title-reveal > span,
body.hero-ready .hero-animated .hero-title-reveal::after,
body.hero-ready .hero-animated .hero-catch-image,
body.hero-ready .hero-animated .hero-catch-line__text,
body.hero-ready .hero-animated .hero-catch-line__slit,
body.hero-ready .hero-animated .hero-tagline {
  animation-play-state: running;
}

body:not(.hero-ready) .hero-catch-image,
body:not(.hero-ready) .hero-catch-line__text,
body:not(.hero-ready) .hero-catch-line__slit,
body:not(.hero-ready) .hero-tagline {
  animation-play-state: paused;
}

body.hero-ready .hero-section:not(.hero-animated) .hero-catch-image,
body.hero-ready .hero-section:not(.hero-animated) .hero-catch-line__text,
body.hero-ready .hero-section:not(.hero-animated) .hero-catch-line__slit,
body.hero-ready .hero-section:not(.hero-animated) .hero-tagline {
  animation-play-state: running;
}

body.hero-ready .hero-tagline {
  animation-play-state: running;
}

@keyframes heroBackgroundZoom {
  0% {
    transform: scale(1.05);
  }
  100% {
    transform: scale(1.16);
  }
}

@keyframes heroFadeUp {
  0% {
    opacity: 0;
    transform: translateY(24px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes heroTitleMask {
  0% {
    transform: translateX(-102%);
  }
  45% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(102%);
  }
}

@keyframes heroCatchSlitDown {
  0% {
    opacity: 0;
    transform: translateY(-130%);
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    transform: translateY(420%);
  }
}

@keyframes heroCatchTextReveal {
  0% {
    opacity: 0;
    clip-path: inset(0 0 100% 0);
  }

  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0);
  }
}

@keyframes heroTaglineRise {
  0% {
    opacity: 0;
    transform: translateY(1.25rem);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes heroCatchImgUnclip {
  from {
    clip-path: inset(0 100% 0 0);
  }

  to {
    clip-path: inset(0 0 0 0);
  }
}

@keyframes heroTitleShow {
  0% {
    opacity: 0;
    transform: translateY(8px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.eyebrow {
  display: block;
  margin-bottom: 1rem;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
}

.hero-section h2 {
  font-size: 30px;
  line-height: 1.1;
  margin-bottom: 0;
}

/* キャッチコピー + REBUILD THE NEXT を重ねるグループ */
.hero-headline {
  position: relative;
  display: inline-block;
  margin-bottom: 2rem;
}

.hero-headline .hero-title-reveal {
  position: relative;
  z-index: 2;
}

/* REBUILD THE NEXT：h2 の下半分に重なるストロークレイヤー */
.hero-headline .eyebrow {
  position: absolute;
  top: 38%;
  left: 50%;
  transform: translateX(-50%);
  width: max-content;
  margin: 0;
  font-size: 8.8rem;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  word-spacing: 0.55em;
  letter-spacing: 0.04em;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.22);
  text-stroke: 1px rgba(255, 255, 255, 0.22);
  z-index: 1;
}

@media screen and (max-width: 1023px) {
  .hero-section-parallax .container {
    padding-top: clamp(0.75rem, 3.5vh, 1.5rem);
    padding-bottom: clamp(3.5rem, 14vh, 5.5rem);
  }

  .hero-content {
    flex-direction: column;
    align-items: center;
    gap: clamp(1rem, 3vw, 1.5rem);
    width: 100%;
    max-width: min(32rem, 100%);
  }

  .hero-tagline-col {
    flex: none;
    width: 100%;
    justify-content: center;
    padding-top: clamp(1rem, 3vh, 1.5rem);
    order: 2;
  }

  .hero-catch-col {
    order: 1;
  }

  .hero-tagline {
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(0.55rem, 2vw, 0.85rem);
    padding-top: 0;
  }

  .hero-tagline p {
    font-size: clamp(0.75rem, 2.6vw, 0.875rem);
    line-height: 1.4;
    letter-spacing: 0.06em;
  }

  .hero-section .hero-catch-reveal {
    width: fit-content;
    max-width: min(100%, 90vw);
    margin-inline: auto;
  }

  .hero-catch-copy__line {
    font-size: clamp(1.5rem, 5vw, 2.5rem);
    letter-spacing: 0.12em;
  }
}

@media screen and (max-width: 800px) {
  .hero-section-parallax .hero-catch-reveal {
    margin-bottom: clamp(0.625rem, 1.8vw + 0.35rem, 1.125rem);
  }
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 1.5rem;
  border-radius: var(--radius-button);
  font-weight: 700;
}

/* 共通：ホバーで左からフィルが広がる */
.button--fill-lr,
.button-primary,
.button-secondary,
.button-tertiary,
.button-cta,
.contact-form .wpcf7 input[type="submit"],
.cta-contact-section .button-primary,
.button-greeting-outline,
.service-showcase__cta,
.cta-card__btn,
.cta-card__phone-dial,
.recruit-banner__cta {
  position: relative;
  z-index: 0;
  overflow: hidden;
  transition:
    color 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.45s ease,
    box-shadow 0.45s ease;
}

.button--fill-lr::before,
.button-primary::before,
.button-secondary::before,
.button-tertiary::before,
.button-cta::before,
.contact-form .wpcf7 input[type="submit"]::before,
.cta-contact-section .button-primary::before,
.button-greeting-outline::before,
.service-showcase__cta::before,
.cta-card__btn::before,
.cta-card__phone-dial::before,
.recruit-banner__cta::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}

.button-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.button-primary::before {
  background: var(--color-primary-dark);
}

.button-cta,
.contact-form .wpcf7 input[type="submit"],
.cta-contact-section .button-primary {
  background-color: var(--color-accent);
  color: var(--color-cta-text);
}

.button-cta::before,
.contact-form .wpcf7 input[type="submit"]::before,
.cta-contact-section .button-primary::before {
  background: var(--color-accent-dark);
}

.button-secondary,
.button-tertiary {
  background-color: #fff;
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  isolation: isolate;
}

.button-secondary::before,
.button-tertiary::before {
  z-index: -1;
  background: linear-gradient(118deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}

.button-greeting-outline {
  gap: 0.35em;
  padding: 0.9rem 1.85rem;
  border: 1.5px solid var(--color-primary);
  font-family: var(--font-heading);
  font-size: clamp(0.9375rem, 0.9rem + 0.25vw, 1.0625rem);
  letter-spacing: 0.04em;
  color: var(--color-primary-dark);
  background-color: rgba(255, 255, 255, 0.55);
  text-decoration: none;
  isolation: isolate;
}

.button-greeting-outline::before {
  z-index: -1;
  background: linear-gradient(118deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}

@media (hover: hover) and (pointer: fine) {
  .button-primary:hover,
  .button-primary:focus-visible,
  .button-cta:hover,
  .button-cta:focus-visible,
  .contact-form .wpcf7 input[type="submit"]:hover,
  .contact-form .wpcf7 input[type="submit"]:focus-visible,
  .cta-contact-section .button-primary:hover,
  .cta-contact-section .button-primary:focus-visible {
    color: var(--color-white);
    border-color: transparent;
  }

  .button-primary:hover::before,
  .button-primary:focus-visible::before,
  .button-cta:hover::before,
  .button-cta:focus-visible::before,
  .contact-form .wpcf7 input[type="submit"]:hover::before,
  .contact-form .wpcf7 input[type="submit"]:focus-visible::before,
  .cta-contact-section .button-primary:hover::before,
  .cta-contact-section .button-primary:focus-visible::before {
    transform: scaleX(1);
  }

  .button-secondary:hover,
  .button-secondary:focus-visible,
  .button-tertiary:hover,
  .button-tertiary:focus-visible,
  .button-greeting-outline:hover,
  .button-greeting-outline:focus-visible,
  .service-showcase__cta:hover,
  .service-showcase__cta:focus-visible,
  .cta-card__phone-dial:hover,
  .cta-card__phone-dial:focus-visible {
    color: var(--color-white);
    border-color: var(--color-primary-dark);
    background-color: transparent;
  }

  .button-secondary:hover::before,
  .button-secondary:focus-visible::before,
  .button-tertiary:hover::before,
  .button-tertiary:focus-visible::before,
  .button-greeting-outline:hover::before,
  .button-greeting-outline:focus-visible::before,
  .service-showcase__cta:hover::before,
  .service-showcase__cta:focus-visible::before,
  .cta-card__phone-dial:hover::before,
  .cta-card__phone-dial:focus-visible::before {
    transform: scaleX(1);
  }

  .service-showcase__cta:hover,
  .service-showcase__cta:focus-visible {
    border-color: var(--color-primary);
  }

  .cta-card__phone-dial:hover .cta-card__btn-arrow,
  .cta-card__phone-dial:focus-visible .cta-card__btn-arrow {
    color: var(--color-white);
  }

  .company-intro-section--greeting .button-greeting-outline:hover,
  .company-intro-section--greeting .button-greeting-outline:focus-visible {
    color: var(--color-white);
  }

  a.button.button-secondary:hover,
  a.button.button-secondary:focus-visible,
  a.button.button-tertiary:hover,
  a.button.button-tertiary:focus-visible,
  .blog-preview-section .section-actions .button-secondary:hover,
  .blog-preview-section .section-actions .button-secondary:focus-visible {
    color: var(--color-white);
  }
}

.button-greeting-outline:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-primary) 45%, transparent);
  outline-offset: 3px;
}

.contact-form .wpcf7 input[type="submit"] {
  border: none;
}

/* ヒーロー後のセクションがスティッキーヒーローを覆い隠す */
.features-section,
.company-intro-section,
.services-section,
.area-section,
.blog-preview-section,
.works-preview-section,
.faq-preview-section {
  position: relative;
  z-index: 1;
  background-color: var(--color-bg);
}

.features-section:not(.features-section--home) {
  background-color: var(--color-features-bg);
}

.recruit-banner {
  z-index: 1;
}

.features-section,
.company-intro-section,
.services-section,
.area-section,
.works-preview-section,
.blog-preview-section,
.faq-preview-section {
  padding: var(--section-gap) 0;
}

/* === Scroll reveal animations === */
.reveal-up {
  opacity: 0;
  transform: translate3d(0, 16px, 0);
  transition:
    opacity 0.78s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.78s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: calc(var(--reveal-delay, 0) * 1ms);
  will-change: opacity, transform;
}

.reveal-up.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.reveal-heading {
  display: inline-block;
  position: relative;
  padding-bottom: 0.45rem;
  margin-bottom: 0.15rem;
  text-wrap: balance;
}

.reveal-heading::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.75rem;
  margin: 0 auto;
  width: min(4rem, 22%);
  min-width: 3rem;
  height: 3px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-dark));
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.68s cubic-bezier(0.22, 1, 0.36, 1) 0.12s;
}

.reveal-heading.is-visible::after {
  transform: scaleX(1);
}

/* トップ：h2 左から光が流れ、文字が現れる（clip-path は IO を阻害するため mask で表示） */
.site-main--front h2.reveal-heading.reveal-up:not(.recruit-banner__heading) {
  position: relative;
  display: inline-block;
  overflow: hidden;
  padding: 0.14em 0.55em 0.55rem;
  color: var(--color-black);
  opacity: 0;
  transform: translate3d(0, 8px, 0);
  transition:
    opacity 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
  -webkit-mask-image: linear-gradient(90deg, #000 0%, #000 100%);
  mask-image: linear-gradient(90deg, #000 0%, #000 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: left center;
  mask-position: left center;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.site-main--front h2.reveal-heading.reveal-up:not(.recruit-banner__heading)::before {
  content: "";
  position: absolute;
  top: -35%;
  bottom: -35%;
  left: 0;
  width: 55%;
  max-width: 14rem;
  background: linear-gradient(
    100deg,
    transparent 0%,
    rgba(255, 255, 255, 0.25) 22%,
    rgba(255, 252, 238, 0.92) 46%,
    rgba(255, 255, 255, 1) 52%,
    rgba(255, 245, 195, 0.88) 64%,
    rgba(255, 255, 255, 0.35) 80%,
    transparent 100%
  );
  transform: translateX(-140%);
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  filter: blur(0.35px);
  mix-blend-mode: screen;
}

.site-main--front h2.reveal-heading.reveal-up:not(.recruit-banner__heading).is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  animation: front-h2-text-unveil 0.62s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

.site-main--front h2.reveal-heading.reveal-up:not(.recruit-banner__heading).is-visible::before {
  animation: front-h2-light-sweep 0.56s cubic-bezier(0.33, 1, 0.42, 1) forwards;
}

@keyframes front-h2-text-unveil {
  from {
    -webkit-mask-size: 0% 100%;
    mask-size: 0% 100%;
  }

  to {
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
  }
}

@keyframes front-h2-light-sweep {
  0% {
    transform: translateX(-140%);
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  100% {
    transform: translateX(240%);
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .reveal-up {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .reveal-heading::after {
    transform: scaleX(1);
    transition: none;
  }

  .site-main--front h2.reveal-heading.reveal-up:not(.recruit-banner__heading) {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none;
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
  }

  .site-main--front h2.reveal-heading.reveal-up:not(.recruit-banner__heading)::before {
    animation: none;
    opacity: 0;
  }

  .features-section--home .feature-card-icon__img {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
    will-change: auto;
  }

  .features-section--home .feature-card h3::after {
    transform: translateX(-50%) scaleX(1);
    transition: none;
  }

  .service-showcase__slide.is-illus-revealed .service-showcase__illus img,
  .service-showcase__slide.is-active:not(.is-illus-revealed) .service-showcase__illus img {
    animation: none;
    opacity: 1;
    transform: none;
    filter: none;
  }

  .section-title-wrap__en {
    opacity: 1 !important;
    transition: none !important;
    transform: translate(-50%, -50%) scale(1) !important;
  }

  .section-title-wrap--left .section-title-wrap__en {
    transform: translateY(-50%) scale(1) !important;
  }

  .section-title-wrap__heading-text {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .section-title-wrap .section-title-wrap__jp::after {
    transition: none !important;
    transform: translateX(-50%) scaleX(1) !important;
  }

  .section-title-wrap--left .section-title-wrap__jp::after {
    transform: translateX(0) scaleX(1) !important;
  }

  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) > .section-title-wrap__en {
    transform: translate(-50%, -100%) scale(1) !important;
  }

  .site-main--front .section-title-wrap--left:not(.recruit-banner__en-decor) > .section-title-wrap__en {
    transform: translateY(-100%) scale(1) !important;
  }
}

/* === レイヤード・セクション見出し（英字ウォーターマーク + マスクリビール） === */
.section-title-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: clamp(0.35rem, 1.5vw, 1rem) 0 clamp(0.65rem, 2.2vw, 1.35rem);
  /* 英字は親幅いっぱいに描画。日本語のマスクは __reveal 側のみ */
  overflow-x: visible;
  overflow-y: visible;
  box-sizing: border-box;
}

.section-title-wrap--left {
  align-items: flex-start;
  text-align: left;
  margin-left: 0;
  margin-right: 0;
}

/* section-heading は align-items:center のため子が狭くならないようタイトル行だけ全幅に伸ばす */
.section-intro.section-intro--center .section-title-wrap,
.section-heading .section-title-wrap {
  align-self: stretch;
}

.section-title-wrap__en {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 0;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 clamp(0.5rem, 4vw, 1.75rem);
  box-sizing: border-box;
  font-family: 'Montserrat', var(--font-en), sans-serif;
  font-weight: 800;
  font-size: clamp(2.75rem, min(12.5vw, 18vh), 9.375rem);
  line-height: 0.82;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  text-align: center;
  color: #f4f8fb;
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  opacity: 0;
  transform: translate(-50%, calc(-50% + 26px)) scale(0.97);
  transition:
    opacity 1.2s cubic-bezier(0.22, 1, 0.36, 1),
    transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

/* 代表ご挨拶：clip 非対応でも背景に溶ける単色ウォーターマーク */
.site-main--front .company-intro-section--greeting .section-title-wrap .section-title-wrap__en {
  color: rgba(215, 223, 234, 0.52);
}

/* 背景クリップ対応ブラウザのみグラデーション（未対応は単色で表示） */
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .section-title-wrap__en {
    color: transparent;
    background-image: var(--section-title-en-gradient-light);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-position: left center;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .site-main--front .company-intro-section--greeting .section-title-wrap .section-title-wrap__en {
    background-image: var(--section-title-en-gradient-greeting-air);
  }
}

.section-title-wrap--left .section-title-wrap__en {
  left: 0;
  text-align: left;
  padding-left: 0;
  padding-right: clamp(0.5rem, 3vw, 1.25rem);
  transform: translateY(calc(-50% + 24px)) scale(0.97);
}

.section-title-wrap.is-visible .section-title-wrap__en {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.section-title-wrap--left.is-visible .section-title-wrap__en {
  transform: translateY(-50%) scale(1);
}

/* 二重下線防止：レイヤード見出しの飾りは .section-title-wrap__jp::after のみ */
.section-title-wrap .section-title-wrap__heading.reveal-heading::after {
  content: none !important;
  display: none !important;
}

.section-title-wrap__jp {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  width: 100%;
  padding-top: clamp(0.2rem, 1.4vw, 0.85rem);
  box-sizing: border-box;
}

.section-title-wrap--left .section-title-wrap__jp {
  justify-content: flex-start;
}

.section-title-wrap__reveal {
  overflow: hidden;
  padding-bottom: 0.65rem;
  max-width: 100%;
}

.section-title-wrap__heading {
  position: relative;
  display: inline-block;
  margin: 0;
  max-width: 100%;
  padding-bottom: 0.45rem;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(1.75rem, 1.05rem + 2vw, 2.1875rem);
  line-height: 1.32;
  letter-spacing: 0.04em;
  text-wrap: balance;
  color: var(--color-black);
}

.section-title-wrap__heading::after {
  content: none !important;
  display: none !important;
}

.section-title-wrap__heading-text {
  display: inline-block;
  opacity: 0;
  transform: translate3d(0, calc(118% + 4px), 0);
  transition:
    opacity 0.82s cubic-bezier(0.22, 1, 0.36, 1) 0.3s,
    transform 0.9s cubic-bezier(0.2, 0.85, 0.36, 1) 0.3s;
  will-change: transform, opacity;
}

.section-title-wrap.is-visible .section-title-wrap__heading-text {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  will-change: auto;
}

.section-title-wrap__jp::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  width: min(4rem, 22%);
  min-width: 3rem;
  height: 3px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-dark));
  transform: translateX(-50%) scaleX(0);
  transform-origin: center;
  transition: transform 0.72s cubic-bezier(0.22, 1, 0.36, 1) 0.52s;
  pointer-events: none;
}

.section-title-wrap.is-visible .section-title-wrap__jp::after {
  transform: translateX(-50%) scaleX(1);
}

.section-title-wrap--left .section-title-wrap__jp::after {
  left: 0;
  right: auto;
  margin: 0;
  transform: translateX(0) scaleX(0);
  transform-origin: left center;
}

.section-title-wrap--left.is-visible .section-title-wrap__jp::after {
  transform: translateX(0) scaleX(1);
}

.section-heading .section-title-wrap {
  padding-left: 0;
  padding-right: 0;
}

.section-title-wrap--in-heading {
  margin-bottom: clamp(0.65rem, 2vw, 1.1rem);
}

.site-main--front .section-heading .section-title-wrap__heading {
  margin-bottom: 0;
}

.site-main--front .company-intro-section--greeting .section-intro .section-title-wrap__heading {
  color: #141814;
  text-align: left;
}

.site-main--front .company-intro-section--greeting .section-title-wrap--left .section-title-wrap__jp::after {
  width: clamp(2.25rem, 14vw, 3.75rem);
  min-width: 2.25rem;
  height: 3px;
  border-radius: 1px;
  background: var(--color-primary-dark);
}

.site-main--front .company-intro-section--greeting .section-title-wrap--left .section-title-wrap__en {
  width: min(135vw, 58rem);
  max-width: none;
  padding-right: min(18vw, 7rem);
}

@media (max-width: 767px) {
  .site-main--front .company-intro-section--greeting .section-title-wrap--left .section-title-wrap__en {
    width: 100%;
    padding-right: clamp(0.5rem, 3vw, 1rem);
  }
}

.site-main--front .section-title-wrap--center .section-title-wrap__heading {
  text-align: center;
}

.site-main--front section:not(.recruit-banner) .section-intro--layered .section-title-wrap__heading {
  margin-bottom: 0;
}

@media (max-width: 767px) {
  .section-title-wrap:not(.recruit-banner__en-decor) > .section-title-wrap__en {
    /* 約 40px〜70px：はみ出し・横スクロールを抑制 */
    font-size: clamp(2.5rem, 10vw, 4.375rem);
    padding-inline: clamp(0.35rem, 3vw, 1rem);
  }

  .section-title-wrap--left .section-title-wrap__en {
    padding-right: clamp(0.35rem, 3vw, 1rem);
  }
}

/* トップ：狭い画面でも英字 > 日本語・はみ出しは上方向（求人バナーは除外） */
@media (max-width: 1023px) {
  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) {
    container-type: inline-size;
    padding-top: clamp(1rem, 3.5vw, 1.75rem);
    overflow: visible;
  }

  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) > .section-title-wrap__en {
    top: 50%;
    width: 100%;
    max-width: 100%;
    font-size: clamp(2.85rem, 16cqw, 5.5rem);
    line-height: 0.78;
    letter-spacing: clamp(-0.06em, -0.02em, -0.035em);
    padding-inline: clamp(0.25rem, 2.5vw, 0.85rem);
    transform: translate(-50%, calc(-100% + 24px)) scale(0.97);
  }

  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor).is-visible > .section-title-wrap__en {
    transform: translate(-50%, -100%) scale(1);
  }

  .site-main--front .section-title-wrap--left:not(.recruit-banner__en-decor) > .section-title-wrap__en {
    transform: translateY(calc(-100% + 22px)) scale(0.97);
  }

  .site-main--front .section-title-wrap--left:not(.recruit-banner__en-decor).is-visible > .section-title-wrap__en {
    transform: translateY(-100%) scale(1);
  }

  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) .section-title-wrap__heading {
    font-size: clamp(1.5rem, 0.95rem + 2.2vw, 2.0625rem);
  }
}

@media (max-width: 767px) {
  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) {
    padding-top: clamp(1.15rem, 4.5vw, 2rem);
  }

  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) > .section-title-wrap__en {
    font-size: clamp(2.6rem, 17cqw, 4.85rem);
    padding-inline: clamp(0.2rem, 2vw, 0.65rem);
  }

  .site-main--front .section-title-wrap:not(.recruit-banner__en-decor) .section-title-wrap__heading {
    font-size: clamp(1.375rem, 0.9rem + 2.6vw, 1.875rem);
  }
}

/* トップ：見出しブロック（求人セクションは対象外） */
.section-intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.65rem, 1.5vw, 0.95rem);
  margin-bottom: clamp(1.85rem, 4vw, 2.65rem);
}

.section-intro--center {
  text-align: center;
  max-width: min(48rem, 100%);
  margin-left: auto;
  margin-right: auto;
}

.section-intro__lead,
.section-heading__lead {
  max-width: 42rem;
  margin: 0;
  font-size: clamp(0.9375rem, 0.88rem + 0.35vw, 1.0625rem);
  line-height: 1.75;
  color: var(--color-text-sub);
}

.section-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.55rem, 1.2vw, 0.85rem);
  max-width: min(48rem, 100%);
  margin-left: auto;
  margin-right: auto;
  margin-bottom: clamp(2rem, 4.5vw, 2.75rem);
  text-align: center;
}

/* トップ：代表ご挨拶（参照モック：左アクセントバー／白シートが写真へグラデフェード／MESSAGE が上空へ） */
.company-intro-section--greeting {
  position: relative;
  width: 100%;
  overflow-x: visible;
  box-sizing: border-box;
  padding-block: 0;
  background-color: #dfe6ea;
  background-image: url('assets/images/greeting.png');
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
}

.company-greeting-layout {
  display: grid;
  grid-template-columns: clamp(2.75rem, 8vw, 6.25rem) minmax(0, 1fr);
  grid-template-rows: minmax(min(88vh, 900px), auto);
  align-items: stretch;
  width: 100%;
  min-height: min(88vh, 900px);
}

.company-greeting-accent-bar {
  grid-column: 1;
  grid-row: 1 / -1;
  background: linear-gradient(
    165deg,
    #011f18 0%,
    var(--color-primary-dark) 42%,
    var(--color-primary) 100%
  );
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.06);
}

.company-greeting-main {
  grid-column: 2;
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  min-width: 0;
  padding: clamp(2.35rem, 6.5vh, 4.75rem) clamp(1rem, 4vw, 2.75rem)
    clamp(2.35rem, 6.5vh, 4.75rem) clamp(0.85rem, 3vw, 1.75rem);
}

.company-greeting-panel {
  flex: 0 1 auto;
  width: 100%;
  max-width: min(720px, 100%);
  align-self: center;
  padding: clamp(2rem, 4.8vmin, 3.25rem) clamp(1.35rem, 4vw, 2.75rem)
    clamp(2.15rem, 5vmin, 3.35rem) clamp(1.25rem, 3.6vw, 2.35rem);
  border-radius: 0;
  border: none;
  background: linear-gradient(
    91deg,
    rgba(255, 255, 255, 0.99) 0%,
    rgba(255, 255, 255, 0.97) 38%,
    rgba(255, 255, 255, 0.78) 62%,
    rgba(255, 255, 255, 0.35) 82%,
    rgba(255, 255, 255, 0) 100%
  );
  box-shadow: none;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.site-main--front .company-intro-section--greeting .section-intro {
  align-items: flex-start;
  text-align: left;
  max-width: 100%;
  width: 100%;
  gap: clamp(0.65rem, 1.5vw, 0.95rem);
  margin: 0 0 clamp(1.35rem, 3vw, 1.95rem);
}

.site-main--front .company-intro-section--greeting .section-title-wrap {
  max-width: 100%;
  margin-inline: 0;
  overflow: visible;
}

.company-greeting-copy {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.company-greeting-copy__body {
  width: 100%;
}

.company-greeting-copy__para {
  margin: 0;
  font-family: var(--font-greeting-serif);
  font-size: clamp(0.9375rem, 0.88rem + 0.35vw, 1.0625rem);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  color: #1f2428;
}

.company-greeting-copy__para + .company-greeting-copy__para {
  margin-top: clamp(1.15rem, 2.8vw, 1.65rem);
}

.company-greeting-copy__signature-block {
  margin-top: clamp(1.85rem, 4vw, 2.75rem);
  margin-left: auto;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
  gap: 0.45rem;
  max-width: 100%;
}

.company-greeting-copy__signature {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(0.8125rem, 0.78rem + 0.22vw, 0.9375rem);
  font-weight: 700;
  line-height: 1.85;
  letter-spacing: 0.06em;
  color: var(--color-primary-dark);
}

.company-greeting-copy__sign-accent-row {
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
}

.company-greeting-copy__sign-line {
  display: inline-block;
  width: clamp(3rem, 14vw, 4.5rem);
  height: 2px;
  margin-top: 0.35em;
  background: linear-gradient(
    90deg,
    transparent,
    var(--color-primary-dark)
  );
  border-radius: 1px;
  flex-shrink: 0;
}

.company-greeting-copy__sign-brush {
  font-family: 'Yuji Syuku', var(--font-greeting-serif);
  font-size: clamp(2.15rem, 5vw + 0.55rem, 3.05rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: 0.16em;
  color: var(--color-primary-dark);
  transform: rotate(-0.25deg);
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.55),
    0 18px 42px rgba(1, 61, 47, 0.07);
}

.company-intro-section--greeting .company-intro-foot {
  max-width: 100%;
  margin: clamp(1.85rem, 4vw, 2.55rem) 0 0;
  text-align: left;
}

.company-intro-section--greeting .company-intro-foot .section-actions {
  display: flex;
  justify-content: flex-start;
  margin-top: 0;
}

@media (max-width: 1023px) {
  .company-greeting-layout {
    grid-template-columns: clamp(2.35rem, 7vw, 5rem) minmax(0, 1fr);
    grid-template-rows: minmax(min(82vh, 820px), auto);
    min-height: min(82vh, 820px);
  }

  .company-greeting-main {
    padding-right: clamp(1rem, 3vw, 2rem);
  }
}

@media (max-width: 767px) {
  .company-intro-section--greeting {
    overflow-x: hidden;
    background-position: 78% center;
  }

  .company-greeting-layout {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr);
    min-height: 0;
  }

  .company-greeting-accent-bar {
    display: none;
  }

  .company-greeting-layout {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto;
    min-height: 0;
  }

  .company-greeting-main {
    grid-column: 1;
    grid-row: 1;
    padding: clamp(1.65rem, 6vw, 2.35rem) clamp(1.15rem, 5vw, 1.65rem)
      clamp(2rem, 8vw, 2.65rem);
  }

  .company-greeting-panel {
    max-width: none;
    padding: clamp(1.35rem, 5vw, 1.85rem) clamp(1.05rem, 4vw, 1.45rem)
      clamp(1.65rem, 6vw, 2.15rem);
    background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.97) 0%,
      rgba(255, 255, 255, 0.93) 55%,
      rgba(255, 255, 255, 0.82) 100%
    );
  }

  .company-greeting-copy__signature-block {
    align-items: flex-start;
    text-align: left;
    margin-left: 0;
  }

  .company-greeting-copy__sign-accent-row {
    justify-content: flex-start;
  }

  .company-greeting-copy__sign-line {
    background: linear-gradient(90deg, var(--color-primary-dark), transparent);
  }
}

/* セクション見出し・本文の中央寄せ */
.recruit-section .container {
  text-align: center;
}

.recruit-section p {
  margin-left: auto;
  margin-right: auto;
}

.area-section__copy {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.area-section__copy p {
  margin-left: 0;
  margin-right: 0;
  max-width: 40rem;
}

.service-card h4 {
  margin-bottom: 0.75rem;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.4;
}

.feature-grid,
.service-grid {
  display: grid;
  gap: 1.5rem;
}

.feature-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.feature-card,
.service-card,
.service-grid article {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  padding: 1.75rem;
  border-radius: var(--radius-card);
}

.service-card ul {
  list-style: disc inside;
  color: var(--color-text-sub);
  margin: 0;
  padding-left: 1rem;
}

.service-card ul li {
  margin-bottom: 0.75rem;
}

.service-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.area-section p {
  max-width: 720px;
}

.recruit-section {
  padding: var(--section-gap) 0;
  background-color: var(--color-bg-soft);
}

.recruit-section h2 {
  margin-bottom: 1rem;
}

.recruit-section p {
  margin-bottom: 1.5rem;
  max-width: 720px;
  color: var(--color-text-sub);
}

/* 採用ページ等のサムネイル用（トップのフルワイドバナーとは別） */
.recruit-section .recruit-banner {
  display: inline-block;
  max-width: 100%;
  line-height: 0;
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.recruit-section .recruit-banner:hover,
.recruit-section .recruit-banner:focus {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.18);
}

.recruit-section .recruit-banner img {
  display: block;
  width: 600px;
  max-width: 100%;
  height: auto;
}

.blog-preview-section,
.blog-listing {
  padding: var(--section-gap) 0;
}

.blog-preview-grid,
.blog-grid,
.related-posts-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}

.works-preview-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}

.blog-preview-card,
.blog-card,
.related-card,
.works-preview-card {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}

.works-preview-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* 拡大プレビュー（position:fixed）がビューポート基準になるよう、reveal の transform を外す */
.works-preview-card.reveal-up {
  transform: none !important;
  opacity: 0;
}

.works-preview-card.reveal-up.is-visible {
  transform: none !important;
  opacity: 1;
}

.blog-preview-card a {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.blog-card-link,
.related-card a {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.works-preview-card > .works-preview-card__content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.blog-preview-image,
.blog-card-image {
  position: relative;
  flex-shrink: 0;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 0;
  overflow: hidden;
  background-color: var(--color-bg-soft);
}

.blog-preview-image img,
.blog-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 施工事例：帯の縦幅は従来どおり。各スロットは 16:9 のアイキャッチ相当枠に内接表示（画像は contain） */
.works-preview-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: minmax(0, 1fr);
  align-items: stretch;
  gap: 2px;
  width: 100%;
  height: clamp(135px, 26vw, 240px);
  background: var(--color-bg-soft);
  box-sizing: border-box;
  flex-shrink: 0;
}

.works-preview-images--legacy-single {
  grid-template-columns: 1fr;
}

.works-preview-images__cell {
  position: relative;
  min-height: 0;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem;
  background: var(--color-bg-soft);
  overflow: hidden;
}

/* 16:9 枠（コンテナクエリでセル内に最大まで収める） */
.works-preview-images__inner {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  max-height: 100%;
  width: 100%;
  height: 100%;
}

@supports (width: 1cqw) {
  .works-preview-images__cell {
    container-type: size;
  }

  .works-preview-images__inner {
    width: min(100cqw, calc(100cqh * 16 / 9));
    height: min(100cqh, calc(100cqw * 9 / 16));
    aspect-ratio: 16 / 9;
  }
}

.works-preview-images__inner > img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: center;
  display: block;
}

.works-preview-images__placeholder {
  opacity: 0.85;
}

.works-preview-images__badge {
  position: absolute;
  bottom: 0.45rem;
  left: 0.45rem;
  padding: 0.2rem 0.45rem;
  font-size: 0.65rem;
  font-weight: 700;
  color: #fff;
  background: rgba(1, 82, 63, 0.88);
  border-radius: 3px;
  letter-spacing: 0.04em;
  line-height: 1.2;
}

.works-preview-images--legacy-single .works-preview-images__badge {
  display: none;
}

/* 施工事例：ホバー／フォーカスでフルサイズ拡大 */
.works-preview-images__inner--has-enlarge {
  cursor: zoom-in;
}

.works-preview-images__inner--has-enlarge:focus {
  outline: none;
}

.works-preview-images__inner--has-enlarge:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.works-preview-images__enlarge-shade {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, visibility 0.22s ease;
  pointer-events: none;
}

.works-preview-images__enlarge {
  position: fixed;
  left: 50%;
  top: 50%;
  z-index: 9999;
  transform: translate(-50%, -50%) scale(0.97);
  max-width: min(94vw, 1280px);
  max-height: min(88vh, 900px);
  padding: 0.5rem;
  box-sizing: border-box;
  background: #fff;
  border-radius: var(--radius-card);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.28);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, visibility 0.22s ease, transform 0.22s ease;
  pointer-events: none;
}

.works-preview-images__enlarge img {
  display: block;
  max-width: min(90vw, 1200px);
  max-height: min(82vh, 860px);
  width: auto;
  height: auto;
  object-fit: contain;
  margin: 0 auto;
}

@media (hover: hover) and (pointer: fine) {
  .works-preview-images__inner--has-enlarge:hover .works-preview-images__enlarge-shade,
  .works-preview-images__inner--has-enlarge:hover .works-preview-images__enlarge,
  .works-preview-images__inner--has-enlarge:focus-within .works-preview-images__enlarge-shade,
  .works-preview-images__inner--has-enlarge:focus-within .works-preview-images__enlarge {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .works-preview-images__enlarge-shade,
  .works-preview-images__enlarge {
    transition: none;
  }
}

.blog-preview-body,
.blog-card-body,
.works-preview-body {
  padding: 1.5rem;
}

.blog-preview-body,
.blog-card-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.works-preview-body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 8rem;
}

.blog-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.blog-card-category,
.related-post-category,
.works-card-category {
  display: inline-flex;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-full);
  background-color: var(--color-bg-soft);
  color: var(--color-primary);
  font-size: 0.85rem;
  font-weight: 700;
}

.badge-new {
  display: inline-flex;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  background-color: var(--color-accent);
  color: var(--color-cta-text);
  font-size: 0.85rem;
  font-weight: 700;
}

.blog-card h2,
.blog-preview-body h3,
.related-card h3,
.works-preview-body h3 {
  margin-bottom: 0.75rem;
  font-size: 1.25rem;
  line-height: 1.4;
}

.works-preview-excerpt {
  margin: 0.85rem 0 0;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--color-text-sub);
  flex: 1 1 auto;
  white-space: pre-line;
}

.blog-card time,
.blog-preview-body time,
.related-card time,
.works-preview-body time {
  color: var(--color-text-sub);
  font-size: 0.95rem;
}

.blog-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 2rem;
}

.filter-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-button);
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.filter-button.active,
.filter-button:hover {
  background-color: var(--color-primary);
  color: #fff;
  border-color: transparent;
}

.blog-card {
  display: flex;
  flex-direction: column;
}

.blog-preview-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.related-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.related-card > a {
  flex: 1 1 auto;
  min-height: 0;
}

.related-card > a > img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  flex-shrink: 0;
  background-color: var(--color-bg-soft);
}

.related-card > a > div {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 1rem;
}

/* トップ：お知らせ・解体コラム 横スクロールマーキー */
.blog-preview-section--marquee {
  overflow: hidden;
}

.blog-preview-section--marquee .section-heading {
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
}

.blog-marquee {
  width: 100%;
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
  cursor: default;
  outline: none;
}

.blog-marquee__viewport {
  overflow: hidden;
  width: 100%;
}

.blog-marquee__track {
  display: flex;
  align-items: stretch;
  gap: 1.5rem;
  width: max-content;
  opacity: 0;
  animation: none;
  will-change: transform;
}

.blog-marquee--ready .blog-marquee__track {
  opacity: 1;
  animation: blog-marquee-scroll var(--blog-marquee-duration, 48s) linear infinite;
}

.blog-marquee__group {
  display: flex;
  align-items: stretch;
  flex: 0 0 auto;
  gap: 1.5rem;
}

.blog-marquee:hover .blog-marquee__track,
.blog-marquee:focus-visible .blog-marquee__track {
  animation-play-state: paused;
}

.blog-marquee__card {
  flex: 0 0 auto;
  width: var(--blog-marquee-card-width, 22.5rem);
  max-width: min(22.5rem, 88vw);
}

.blog-marquee__card.reveal-up {
  opacity: 1;
  transform: none;
  transition: none;
}

@keyframes blog-marquee-scroll {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(var(--blog-marquee-shift, 0), 0, 0);
  }
}

@media screen and (max-width: 1023px) {
  .blog-marquee__card {
    width: var(--blog-marquee-card-width, 19rem);
  }

  .blog-marquee__track,
  .blog-marquee__group {
    gap: 1.25rem;
  }
}

@media screen and (max-width: 767px) {
  .blog-marquee__card {
    width: var(--blog-marquee-card-width, min(17.5rem, 82vw));
  }

  .blog-marquee__track,
  .blog-marquee__group {
    gap: 1rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .blog-marquee__viewport {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 0.5rem;
  }

  .blog-marquee__track {
    opacity: 1;
    animation: none;
    transform: none;
    padding-inline: clamp(1rem, 4vw, 1.5rem);
  }

  .blog-marquee--ready .blog-marquee__track {
    animation: none;
  }

  .blog-marquee__card {
    scroll-snap-align: start;
  }
}

.blog-preview-section .section-actions,
.works-preview-section .section-actions {
  margin-top: 2rem;
}

.blog-preview-section--marquee .section-actions {
  display: flex;
  justify-content: center;
  margin-top: clamp(1.75rem, 4vw, 2.5rem);
  text-align: center;
}

/* NEWバッジ：アイキャッチ画像の右上 */
.new-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--color-accent);
  color: #fff;
  padding: 2px 8px;
  font-size: 0.75rem;
  font-weight: bold;
  border-radius: 3px;
  z-index: 2;
}

/* カテゴリラベル：アイキャッチ画像の左上 */
.category-label {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 10px;
  font-size: 0.75rem;
  font-weight: bold;
  color: #fff;
  border-radius: 3px;
  z-index: 2;
  background: var(--color-text-sub);
}

.category-label.category-news {
  background: #1d3557;
}

.category-label.category-column {
  background: #2a9d8f;
}

.single-post-section {
  padding: var(--section-gap) 0;
}

/* ブログ個別：パンくず・タイトル・メタと本文・アイキャッチを同じ最大幅に揃える */
body.single-post .page-hero .breadcrumbs,
body.single-post .page-hero .container > h2,
body.single-post .page-hero .post-meta {
  max-width: var(--blog-article-max);
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

body.single-post .page-hero .breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.85rem;
  color: var(--color-text-sub);
  margin-bottom: 1rem;
}

body.single-post .page-hero .breadcrumbs a {
  color: var(--color-primary);
  text-decoration: none;
}

body.single-post .page-hero .breadcrumbs a:hover,
body.single-post .page-hero .breadcrumbs a:focus {
  text-decoration: underline;
}

body.single-post .page-hero .container > h2 {
  margin-bottom: 0.75rem;
}

.single-post-section .single-post {
  display: grid;
  gap: 2rem;
  width: 100%;
  max-width: var(--blog-article-max);
  margin-left: auto;
  margin-right: auto;
}

.single-post-image {
  overflow: hidden;
  border-radius: var(--radius-card);
  aspect-ratio: 16 / 9;
  background-color: var(--color-bg-soft);
}

.single-post-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.single-post-content {
  font-size: 1.05rem;
  line-height: 1.9;
  color: var(--color-text);
  max-width: 100%;
  display: flow-root;
}

.single-post-content > *:first-child {
  margin-top: 0;
}

.single-post-content p,
.single-post-content ul,
.single-post-content ol,
.single-post-content dd {
  margin-top: 0;
  margin-bottom: 1.25rem;
}

.single-post-content h2,
.single-post-content h3,
.single-post-content h4 {
  margin-top: 2.25rem;
  margin-bottom: 0.75rem;
  line-height: 1.35;
}

.single-post-content h2:first-child,
.single-post-content h3:first-child,
.single-post-content h4:first-child {
  margin-top: 0;
}

.single-post-content figure,
.single-post-content .wp-block-image {
  margin: 1.5rem 0;
}

.single-post-content img,
.single-post-content video,
.single-post-content iframe {
  max-width: 100%;
  height: auto;
}

.single-post-content figure img {
  margin-left: auto;
  margin-right: auto;
}

.single-post-content .alignleft {
  float: left;
  margin: 0.5rem 1.25rem 1rem 0;
}

.single-post-content .alignright {
  float: right;
  margin: 0.5rem 0 1rem 1.25rem;
}

.single-post-content .aligncenter,
.single-post-content .aligncenter img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.single-post-content figcaption,
.single-post-content .wp-element-caption {
  font-size: 0.875rem;
  color: var(--color-text-sub);
  margin-top: 0.5rem;
  line-height: 1.5;
}

.post-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
}

.related-posts {
  margin-top: 3rem;
}

.related-posts h2,
.related-posts h3 {
  margin-bottom: 1.25rem;
  font-size: 1.25rem;
}

.pagination {
  margin-top: 2rem;
  text-align: center;
}

@media screen and (max-width: 1023px) {
  .blog-preview-grid,
  .blog-grid,
  .related-posts-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (max-width: 767px) {
  .blog-preview-grid,
  .blog-grid,
  .related-posts-grid,
  .works-preview-grid {
    grid-template-columns: 1fr;
  }
}

.faq-preview-section {
  padding: var(--section-gap) 0;
}

.faq-preview-section .section-actions {
  margin-top: 2rem;
}

.flow-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.flow-grid article {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.5rem;
}

.flow-grid h3 {
  margin-bottom: 0.75rem;
  font-size: 1.1rem;
}

@media screen and (max-width: 1023px) {
  .flow-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.flow-grid p {
  margin: 0;
  color: var(--color-text-sub);
  line-height: 1.75;
}

.contact-hero,
.archive-hero {
  position: relative;
  padding: 3.5rem 0 3rem;
  background-color: var(--color-bg-soft);
  color: var(--color-text);
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1.5rem;
}

.contact-info {
  padding: var(--section-gap) 0;
}

.contact-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.contact-grid--dual {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

.contact-grid article,
.contact-form-panel {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  padding: 1.5rem;
  border-radius: var(--radius-card);
}

.contact-form-panel h3 {
  margin-bottom: 0.75rem;
  font-size: 1.2rem;
}

.contact-form-panel > p {
  margin: 0 0 1.25rem;
  color: var(--color-text-sub);
  line-height: 1.75;
}

.contact-form-panel .contact-form {
  margin-top: 0;
}

.contact-forms-section {
  padding: var(--section-gap) 0;
}

.contact-form-section {
  padding: var(--section-gap) 0;
}

.contact-details {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}

.contact-details p {
  margin: 0 0 0.75rem;
  font-weight: 700;
}

.contact-details ul {
  list-style: disc;
  margin: 0;
  padding-left: 1.25rem;
  color: var(--color-text-sub);
}

.contact-details li {
  margin-bottom: 0.75rem;
}

.contact-form {
  display: grid;
  gap: 1.5rem;
}

.form-row {
  display: grid;
  gap: 0.75rem;
}

.form-row label,
.form-label {
  font-weight: 700;
}

.form-row input,
.form-row textarea {
  width: 100%;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-button);
  background: var(--color-base);
  color: var(--color-text);
}

.form-row textarea {
  min-height: 160px;
  resize: vertical;
}

.checkbox-group {
  display: grid;
  gap: 0.75rem;
}

.checkbox-group label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 500;
  color: var(--color-text);
}

.contact-form .button {
  width: fit-content;
}

.form-note {
  font-size: 0.95rem;
  color: var(--color-text-sub);
}

.contact-form-placeholder,
.contact-form-callout .contact-form-placeholder {
  background-color: var(--color-bg-soft);
  border: 1px dashed var(--color-primary);
  padding: 2rem;
  border-radius: var(--radius-card);
}

.contact-benefits {
  display: grid;
  gap: 1rem;
  list-style: disc;
  padding-left: 1.25rem;
}

.contact-benefits li {
  margin-bottom: 0.75rem;
  color: var(--color-text-sub);
}

.contact-form-callout {
  background-color: var(--color-bg-soft);
  padding: 3rem 0;
}

.contact-form-callout p {
  max-width: 720px;
  margin: 0 auto 1.5rem;
}

.works-listing {
  padding: var(--section-gap) 0;
}

.works-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.work-card {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}

.work-card-image img {
  width: 100%;
  height: auto;
  display: block;
}

.work-card-body {
  padding: 1.5rem;
}

.work-card-title {
  margin-bottom: 0.75rem;
}

.pagination {
  margin-top: 2rem;
  text-align: center;
}

.page-content {
  padding: 4rem 0;
}

.page-hero {
  position: relative;
  padding: 3.5rem 0 3rem;
  background-color: var(--color-bg-soft);
  color: var(--color-text);
}

.page-hero.page-hero--subpage {
  background-color: var(--color-white);
}

.page-hero h2,
.contact-hero h2,
.archive-hero h2 {
  font-size: 30px;
  line-height: 1.2;
  margin-bottom: 0;
  color: var(--color-text);
}

.page-hero-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 1.25rem;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  color: var(--color-text-sub);
}

.page-hero-breadcrumb a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.page-hero-breadcrumb a:hover,
.page-hero-breadcrumb a:focus {
  color: var(--color-text);
  border-bottom-color: currentColor;
}

.page-hero-breadcrumb .separator {
  opacity: 0.5;
}

.page-hero-eyebrow {
  display: block;
  margin: 0 0 0.5rem;
  font-family: var(--font-en);
  font-size: 0.85rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
}

.page-hero-lead {
  margin: 1rem 0 0;
  max-width: 720px;
  font-size: 1rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.page-section {
  padding: var(--section-gap) 0;
}

.process-list {
  display: grid;
  gap: 1rem;
  counter-reset: process-step;
}

.faq-list {
  display: grid;
  gap: 1rem;
}

.faq-item {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}

.faq-item__toggle {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  margin: 0;
  padding: 1.25rem 1.5rem;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.faq-item__toggle:hover,
.faq-item__toggle:focus-visible {
  background-color: rgba(0, 0, 0, 0.03);
  outline: none;
}

.faq-item__toggle:focus-visible {
  box-shadow: inset 0 0 0 2px var(--color-primary);
}

.faq-item__labels {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}

.faq-item__category {
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: 0.04em;
}

.faq-item__question {
  display: block;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.6;
  color: var(--color-text);
}

.faq-item__icon {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  margin-top: 0.15rem;
  position: relative;
}

.faq-item__icon::before,
.faq-item__icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 2px;
  background-color: var(--color-primary);
  transform: translate(-50%, -50%);
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.faq-item__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.faq-item.is-open .faq-item__icon::after {
  transform: translate(-50%, -50%) rotate(90deg) scaleX(0);
  opacity: 0;
}

.faq-item__panel {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.35s ease;
}

.faq-item.is-open .faq-item__panel:not([hidden]) {
  max-height: var(--faq-panel-height, 999px);
}

.faq-item__answer {
  padding: 0 1.5rem 1.5rem;
  border-top: 1px solid var(--color-border);
}

.faq-item__answer p {
  margin: 1rem 0 0;
  color: var(--color-text-sub);
  line-height: 1.85;
}

.faq-item__answer p:first-child {
  margin-top: 1.25rem;
}

@media (prefers-reduced-motion: reduce) {
  .faq-item__panel {
    transition: none;
  }

  .faq-item.is-open .faq-item__panel:not([hidden]) {
    max-height: none;
  }

  .faq-item__icon::before,
  .faq-item__icon::after {
    transition: none;
  }
}

.policy-content {
  display: grid;
  gap: 1.5rem;
}

.policy-content h2 {
  margin-bottom: 0.5rem;
}

.policy-content p {
  margin: 0;
  color: var(--color-text-sub);
}

.process-list li {
  position: relative;
  padding-left: 3rem;
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.5rem;
}

.process-list li::before {
  counter-increment: process-step;
  content: counter(process-step);
  position: absolute;
  left: 1rem;
  top: 1.5rem;
  width: 2rem;
  height: 2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background-color: var(--color-primary);
  color: #fff;
  font-weight: 700;
}

.info-grid,
.company-details {
  display: grid;
  gap: 1.5rem;
}

.info-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.company-details div {
  display: grid;
  gap: 0.5rem;
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.5rem;
}

.company-details dt {
  font-weight: 700;
}

.company-details dd {
  margin: 0;
  color: var(--color-text-sub);
}

.company-values {
  display: grid;
  gap: 1rem;
  list-style: disc;
  padding-left: 1.25rem;
}

.company-values li {
  margin-bottom: 0.5rem;
}

.recruit-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.recruit-grid article {
  background-color: var(--color-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.5rem;
}

.recruit-grid h3 {
  margin-bottom: 0.75rem;
}

@media screen and (max-width: 767px) {
  .recruit-grid {
    grid-template-columns: 1fr;
  }
}

.contact-callout {
  background-color: var(--color-bg-soft);
  padding: 3rem 0;
  text-align: center;
}

.contact-callout p {
  max-width: 720px;
  margin: 0 auto 1.5rem;
}

@media screen and (max-width: 767px) {
  .info-grid,
  .company-details {
    grid-template-columns: 1fr;
  }
}

.entry-title {
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
  margin-bottom: 1.5rem;
}

.entry-content {
  color: var(--color-text);
  line-height: 1.9;
}

@media screen and (max-width: 1199px) {
  .footer-inner {
    grid-template-columns: 1fr;
  }

  .header-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 1rem;
    row-gap: 0;
  }

  .site-branding {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    min-width: 0;
  }

  .site-navigation {
    display: contents;
  }

  .menu-toggle {
    display: inline-flex;
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    align-self: center;
  }

  /* モバイルメニュー：カード型ドロワー */
  .site-navigation .main-menu {
    display: none;
    flex-direction: column;
    gap: 0;
    width: 100%;
    grid-column: 1 / -1;
    grid-row: 2;
    align-items: stretch;
    background-color: #f9f9f9;
    border-radius: 12px;
    margin-top: 0.625rem;
    overflow: hidden;
    border: 1px solid var(--color-border);
  }

  .site-navigation.open .main-menu {
    display: flex;
  }

  .site-navigation .main-menu li {
    width: 100%;
    border-bottom: 1px solid var(--color-border);
  }

  .site-navigation .main-menu li:last-child {
    border-bottom: none;
  }

  .site-navigation .main-menu a {
    display: block;
    padding: 0.9rem 1.25rem;
    text-align: left;
    color: var(--color-text);
    font-size: 0.95rem;
    padding-bottom: 0.9rem;
  }

  .site-navigation .main-menu a::after {
    display: none;
  }

  .site-navigation .main-menu a[href*="/contact/"] {
    height: auto;
    margin: 0;
    border-radius: 0;
    background: none;
    border: none;
    color: var(--color-accent-dark);
    font-weight: 700;
    box-shadow: none;
    padding: 0.9rem 1.25rem;
  }

  .site-navigation .main-menu a[href*="/contact/"]:hover,
  .site-navigation .main-menu a[href*="/contact/"]:focus {
    background: color-mix(in srgb, var(--color-accent) 12%, transparent);
    box-shadow: none;
    color: var(--color-cta-text);
  }

}

@media screen and (max-width: 767px) {
  .hero-section {
    padding: 3rem 0;
  }

  .hero-section.hero-section-parallax {
    min-height: 90vh;
    padding-top: 100px;
    padding-bottom: 3rem;
  }

  .hero-section h2 {
    font-size: 30px;
  }

  .hero-headline {
    display: block;
    width: 100%;
  }

  .hero-headline .eyebrow {
    position: static;
    width: auto;
    transform: none;
    margin-top: 0.75rem;
    color: rgba(255, 255, 255, 0.38);
    -webkit-text-stroke: none;
    text-stroke: none;
    text-align: left;
    text-align-last: auto;
    letter-spacing: 0.18em;
    font-size: 0.85rem;
    font-weight: 700;
  }

  .hero-overlay {
    background: linear-gradient(
      180deg,
      rgba(6, 28, 34, 0.58) 0%,
      rgba(5, 30, 36, 0.38) 40%,
      rgba(2, 14, 18, 0.18) 62%,
      rgba(0, 0, 0, 0) 82%
    );
  }

  .top-message-section,
  .features-section,
  .company-intro-section,
  .services-section,
  .area-section,
  .contact-info,
  .page-section {
    padding: var(--section-gap-mobile) 0;
  }

  .features-section--home {
    padding-top: 0;
  }

  .features-section--home .features-section__inner {
    padding-top: var(--section-gap-mobile);
  }

  section.company-intro-section--greeting {
    padding-block: clamp(2.75rem, 10vw, 4rem);
  }

  .feature-grid,
  .service-grid,
  .contact-grid,
  .flow-grid,
  .info-grid,
  .company-details,
  .works-grid,
  .process-list {
    grid-template-columns: 1fr;
  }

  .cta-sub-actions {
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
  }

  .cta-sub-btn {
    width: 100%;
    max-width: 320px;
    padding: 1.1rem 1.75rem;
    font-size: 1rem;
  }

  .cta-sub-btn--line,
  .cta-sub-btn--form {
    padding: 0;
  }

  .header-utility {
    justify-content: flex-start;
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-opening-stage {
    display: none !important;
  }

  .hero-animated .hero-parallax-bg,
  .hero-fade-up,
  .hero-title-reveal > span,
  .hero-title-reveal::after,
  .hero-catch-image,
  .hero-catch-line__text,
  .hero-catch-line__slit,
  .hero-tagline {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    clip-path: none !important;
  }

  .hero-title-reveal::after,
  .hero-catch-line__slit {
    display: none;
  }
}

.error-404 {
  padding: var(--section-gap) 0;
}

/* パンくずリスト */
.breadcrumb {
  margin-bottom: 1.5rem;
}

.breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem 0.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-text-sub);
}

.breadcrumb-list li:not(:last-child)::after {
  content: '›';
  margin-left: 0.5rem;
  color: var(--color-text-sub);
}

.breadcrumb-list a {
  color: var(--color-primary);
  text-decoration: none;
}

.breadcrumb-list a:hover {
  text-decoration: underline;
}

/* 施工事例個別ページ — ヒーロー */
.single-work-hero {
  padding: var(--section-gap) 0 2rem;
}

.single-work-header {
  margin-bottom: 2rem;
}

.single-work-date {
  display: inline-block;
  color: var(--color-text-sub);
  font-size: 0.9rem;
  margin-bottom: 0.75rem;
  margin-right: 1rem;
}

.single-work-images {
  border-radius: var(--radius-card);
  overflow: hidden;
}

.single-work-images .works-preview-images {
  height: clamp(160px, 32vw, 300px);
}

.placeholder-image {
  width: 100%;
  height: auto;
  object-fit: cover;
  background-color: var(--color-bg-soft);
  display: block;
}

/* 施工事例個別ページ — 本文 */
.single-work-content {
  padding: var(--section-gap) 0;
  background: var(--color-base);
}

.single-work-body {
  max-width: 860px;
  margin: 0 auto;
}

/* 関連施工事例 */
.related-works {
  padding: var(--section-gap) 0;
  background-color: var(--color-bg-soft);
}

.related-works-heading {
  text-align: center;
  margin-bottom: 2rem;
}

/* 施工事例個別ページ — CTA */
.single-work-cta {
  padding: var(--section-gap) 0;
  background-color: var(--color-primary-dark);
  color: #fff;
  text-align: center;
}

.single-work-cta h2 {
  color: #fff;
  margin-bottom: 1rem;
}

.single-work-cta p {
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 2rem;
}

.single-work-cta-actions {
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.error-404 h1 {
  margin-bottom: 1rem;
}

.error-404 p {
  margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .footer-inner {
    grid-template-columns: 1fr;
  }

  .site-navigation .main-menu {
    justify-content: flex-start;
  }

  .header-utility {
    justify-content: flex-start;
  }
}

/* === Contact Form 7 デザイン調整 === */

/* CF7 が出力する <p> タグの余白をリセット */
.wpcf7 .form-row p {
  margin: 0;
}

/* form-control-wrap を block 化してフル幅を確保 */
.form-row .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* テキスト・メール・電話・テキストエリア */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  width: 100%;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-button);
  background: var(--color-base);
  color: var(--color-text);
  font-family: inherit;
  font-size: 1rem;
  transition: border-color 0.2s;
}

.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 textarea:focus {
  outline: none;
  border-color: var(--color-primary);
}

.wpcf7 textarea {
  min-height: 160px;
  resize: vertical;
}

/* 「必須」バッジ */
.wpcf7 .required,
.form-row .required {
  display: inline-block;
  background-color: var(--color-primary);
  color: var(--color-white);
  padding: 2px 8px;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 3px;
  margin-left: 8px;
  vertical-align: middle;
  line-height: 1.4;
}

/* チェックボックスグループ：縦並び左寄せ */
.checkbox-group .wpcf7-list-item {
  display: block;
  width: auto;
  margin: 0 0 0.5rem 0;
}

.checkbox-group .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 500;
  cursor: pointer;
}

.checkbox-group .wpcf7-list-item input[type="checkbox"] {
  width: auto;
  flex-shrink: 0;
}

/* プライバシーポリシー同意チェックボックス（横並び1行） */
.wpcf7-acceptance .wpcf7-list-item {
  display: block;
  margin: 0;
}

.wpcf7-acceptance .wpcf7-list-item label {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-weight: 500;
  cursor: pointer;
  line-height: 1.6;
}

.wpcf7-acceptance input[type="checkbox"] {
  width: auto;
  flex-shrink: 0;
  margin-top: 0.25rem;
}

/* 送信ボタン：button-primary スタイルを継承 */
.wpcf7 input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--padding-button);
  border-radius: var(--radius-button);
  background-color: var(--color-primary);
  color: #fff;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  border: none;
  cursor: pointer;
  width: fit-content;
}

/* バリデーションエラー表示 */
.wpcf7-not-valid-tip {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.85rem;
  color: var(--color-accent);
}

.wpcf7-response-output {
  margin-top: 1.5rem;
  padding: 1rem;
  border-radius: var(--radius-button);
  font-size: 0.95rem;
}

/* レスポンシブ：スマホでの調整 */
@media screen and (max-width: 767px) {
  .wpcf7 input[type="text"],
  .wpcf7 input[type="email"],
  .wpcf7 input[type="tel"],
  .wpcf7 textarea {
    font-size: 1rem;
  }

  .wpcf7 input[type="submit"] {
    width: 100%;
  }
}

/* === タイポグラフィ レスポンシブ === */
/* h1〜h3 はグローバル定義の clamp() でモバイル対応済み */

/* === トップページ：デザインカンプ寄せ（文言は変更なし） === */

.features-section__inner {
  position: relative;
  overflow: hidden;
}

.features-section--home .features-section__inner {
  overflow: visible;
  padding-top: var(--section-gap);
}

.top-message-section__inner {
  position: relative;
  overflow: hidden;
}

.features-watermark,
.top-message-watermark {
  position: absolute;
  top: 42%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
  line-height: 1;
  color: var(--color-primary);
  opacity: 0.055;
  pointer-events: none;
  white-space: nowrap;
  user-select: none;
}

.features-watermark {
  font-family: var(--font-en);
  font-weight: 800;
  letter-spacing: 0.06em;
  font-size: clamp(4.5rem, 22vw, 15rem);
}

.top-message-watermark {
  font-family: var(--font-script);
  font-weight: 400;
  letter-spacing: 0.02em;
  font-size: clamp(4rem, 16vw, 11rem);
}

.features-section__inner > *:not(.features-watermark) {
  position: relative;
  z-index: 1;
}

.top-message-section__inner > *:not(.top-message-watermark) {
  position: relative;
  z-index: 1;
}

.top-message-section__inner .top-message-intro {
  max-width: 36rem;
  margin: 0 auto;
  text-align: center;
  font-size: clamp(1.02rem, 0.94rem + 0.42vw, 1.15rem);
  line-height: 1.85;
  color: #000;
}

.top-message-section__inner .top-message-intro p {
  margin: 0;
}

.top-message-section__inner .top-message-intro__body {
  margin-top: 0;
  text-align: center;
}

.top-message-type {
  display: flex;
  flex-direction: column;
  gap: 1.85em;
  line-height: 1.85;
}

.top-message-section__inner .top-message-intro__body p + p {
  margin-top: 0;
}

.top-message-type p {
  line-height: inherit;
}

.top-message-type p br {
  display: block;
  line-height: inherit;
}

.top-message-type .top-message-char {
  opacity: 0;
}

.top-message-type.is-visible .top-message-char {
  opacity: 1;
  transition: opacity 0.06s linear;
  transition-delay: calc(var(--char-i, 0) * 52ms);
}

@media (prefers-reduced-motion: reduce) {
  .top-message-type .top-message-char {
    opacity: 1;
    transition: none;
  }
}

.top-message-section__inner .top-message-intro__lead {
  font-size: clamp(1.0625rem, 0.98rem + 0.48vw, 1.25rem);
  font-weight: 700;
  color: var(--color-primary-dark);
  letter-spacing: 0.02em;
}

/* トップ：選ばれる理由 */
.features-section--home {
  background-color: var(--color-white);
  border-top: none;
  padding-top: 0;
}

.features-section--home::before {
  content: '';
  display: block;
  height: 3px;
  background: var(--brand-gradient-line);
}

/* トップ：レイヤード見出し下ライン（選ばれる理由・サービス・コラム・お問い合わせ） */
.site-main--front .features-section--home .section-title-wrap__jp::after,
.site-main--front .services-section--showcase .section-title-wrap__jp::after,
.site-main--front .blog-preview-section--marquee .section-title-wrap__jp::after,
.site-main--front .cta-contact-section .section-title-wrap--on-dark .section-title-wrap__jp::after {
  width: var(--section-title-underline-w);
  min-width: var(--section-title-underline-w);
  max-width: var(--section-title-underline-w);
  height: 2px;
  border-radius: 1px;
  background: var(--color-black);
}

.site-main--front .features-section--home .section-title-wrap__reveal,
.site-main--front .services-section--showcase .section-title-wrap__reveal,
.site-main--front .blog-preview-section--marquee .section-title-wrap__reveal {
  padding-bottom: 0.2rem;
}

.site-main--front .cta-contact-section .section-title-wrap--on-dark .section-title-wrap__reveal {
  padding-bottom: 0.65rem;
}

.features-section--home .feature-grid {
  align-items: stretch;
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.features-section--home .feature-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
  padding: clamp(1.75rem, 3vw, 2.25rem) clamp(1.35rem, 2.5vw, 1.75rem);
  text-align: center;
  background-color: var(--color-white);
  border: 0.5px solid color-mix(in srgb, var(--color-primary) 24%, var(--color-border));
  border-radius: var(--radius-md);
  box-shadow: none;
  transition: border-color var(--transition-base);
}

.features-section--home .feature-card:hover {
  transform: none;
  box-shadow: none;
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border));
}

.features-section--home .feature-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 100%;
  margin: 0 0 clamp(1rem, 2.2vw, 1.25rem);
}

.features-section--home .feature-card-icon__img {
  display: block;
  width: clamp(5.85rem, 15.6vw, 7.15rem);
  max-width: 100%;
  height: auto;
  margin-inline: auto;
  object-fit: contain;
  object-position: center center;
  opacity: 0;
  transform: translate3d(0, 1.15rem, 0) scale(0.84) rotate(-4deg);
  transform-origin: center center;
  will-change: transform, opacity, filter;
  filter: blur(5px);
  transition:
    opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.78s cubic-bezier(0.33, 1.4, 0.52, 1),
    filter 0.52s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: calc(var(--reveal-delay, 0) * 1ms + 95ms);
}

.features-section--home .feature-card.reveal-up.is-visible .feature-card-icon__img {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  filter: blur(0);
  will-change: auto;
}

.features-section:not(.features-section--home) .feature-card {
  border: none;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.features-section:not(.features-section--home) .feature-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* トップページ：求人以外の h2 を中央寄せ（光の演出は上記 .reveal-heading ルール） */
.site-main--front section:not(.recruit-banner) h2.reveal-heading:not(.recruit-banner__heading) {
  text-align: center;
}

.site-main--front section:not(.recruit-banner):not(.features-section--home) h2.reveal-heading:not(.recruit-banner__heading)::after,
.site-main--front section:not(.recruit-banner):not(.features-section--home) h2.reveal-heading:not(.recruit-banner__heading).is-visible::after {
  content: none;
  display: none;
}

.site-main--front section:not(.recruit-banner):not(.company-intro-section--greeting) .section-intro {
  gap: clamp(0.9rem, 2.2vw, 1.35rem);
  margin-bottom: clamp(2.5rem, 6vw, 3.75rem);
}

.site-main--front section:not(.recruit-banner) .section-intro h2.reveal-heading {
  margin-bottom: clamp(0.5rem, 1.5vw, 0.85rem);
}

.site-main--front section:not(.recruit-banner) .section-heading {
  gap: clamp(0.85rem, 2vw, 1.15rem);
  margin-bottom: clamp(2.35rem, 5.5vw, 3.35rem);
}

.site-main--front section:not(.recruit-banner) .section-heading h2.reveal-heading {
  margin-bottom: clamp(0.45rem, 1.2vw, 0.75rem);
}

.site-main--front .area-section__layout {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
  gap: clamp(1.75rem, 4vw, 2.75rem);
}

.site-main--front .area-section__copy {
  width: 100%;
  max-width: 40rem;
  margin-inline: auto;
  text-align: center;
  align-items: center;
}

.site-main--front .area-section__copy > p {
  text-align: center;
}

.site-main--front .area-section__map {
  margin-inline: auto;
}

.features-section--home .feature-card h3 {
  position: relative;
  margin: 0 0 clamp(0.85rem, 2vw, 1.1rem);
  padding-bottom: clamp(0.75rem, 2vw, 0.95rem);
  font-size: clamp(1.05rem, 0.95rem + 0.35vw, 1.2rem);
  font-weight: 700;
  line-height: 1.45;
  color: var(--color-primary);
  text-align: center;
}

.features-section--home .feature-card h3::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  width: min(5.5rem, 72%);
  min-width: 4.25rem;
  height: 3px;
  border-radius: 2px;
  background: var(--brand-gradient-line);
  transform: translateX(-50%) scaleX(0);
  transform-origin: center;
  transition: transform 0.72s cubic-bezier(0.22, 1, 0.36, 1) 0.38s;
  pointer-events: none;
}

.features-section--home .feature-card.reveal-up.is-visible h3::after {
  transform: translateX(-50%) scaleX(1);
}

.features-section--home .feature-card p {
  margin: 0;
  flex: 1;
  font-size: clamp(0.875rem, 0.82rem + 0.2vw, 0.9375rem);
  line-height: 1.85;
  color: var(--color-text);
  text-align: left;
}

/* サービス紹介：スプリット・スクロール連動ショーケース */
.services-section--showcase {
  padding-bottom: clamp(2.5rem, 6vw, 4rem);
  overflow: clip;
}

.services-section--showcase .section-intro {
  margin-bottom: clamp(2rem, 4.5vw, 3rem);
}

.service-showcase {
  width: 100%;
  /* .container と同じ「本文左端」位置（1140px 中央寄せ + 内側パディング） */
  --svc-container-pad: clamp(1.25rem, 4vw, 2rem);
  --svc-align-gutter: max(
    var(--svc-container-pad),
    calc((100vw - var(--content-max)) / 2 + var(--svc-container-pad))
  );
}

.service-showcase__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: stretch;
  min-height: 0;
}

.service-showcase__slides {
  grid-column: 1;
  display: flex;
  flex-direction: column;
  align-self: stretch;
}

.service-showcase__slide {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: calc(100dvh - var(--header-height));
  padding-block: clamp(2rem, 5vmin, 3rem);
  padding-inline: clamp(1.25rem, 4vw, 2rem);
  box-sizing: border-box;
}

@media (min-width: 1024px) {
  .service-showcase__slide {
    min-height: calc(100dvh - var(--header-height));
    padding-block: clamp(1.25rem, 3vmin, 2rem);
    padding-inline: clamp(1.25rem, 4vw, 2rem);
  }
}

.service-showcase__slide-inner {
  width: min(44rem, 100%);
  max-width: min(44rem, calc(50vw - var(--svc-container-pad) * 2 - clamp(1rem, 3vw, 2rem)));
  margin-inline: auto;
  transition: opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.service-showcase__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  text-align: center;
}

.service-showcase__slide:not(.is-active) .service-showcase__slide-inner {
  opacity: 0.4;
}

.service-showcase__slide.is-active .service-showcase__slide-inner {
  opacity: 1;
}

.service-showcase__num {
  width: 100%;
  margin: 0 0 clamp(0.25rem, 0.9vw, 0.45rem);
  font-family: 'Jost', var(--font-en);
  font-size: clamp(3.25rem, 7.5vw, 6.5rem);
  font-weight: 200;
  line-height: 0.92;
  letter-spacing: -0.05em;
  text-align: center;
  color: color-mix(in srgb, var(--service-showcase-accent) 28%, transparent);
  transition: color 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.service-showcase__illus {
  flex: 0 0 auto;
  width: min(260px, 100%);
  max-width: 100%;
  height: auto;
  margin: clamp(0.2rem, 0.8vw, 0.4rem) auto clamp(0.7rem, 1.8vw, 1rem);
  aspect-ratio: 320 / 200;
}

.service-showcase__illus img {
  display: block;
  width: min(260px, 100%);
  max-width: 100%;
  height: auto;
  margin-inline: auto;
  aspect-ratio: 320 / 200;
  object-fit: contain;
  object-position: center center;
  opacity: 0;
  transform: translate3d(0, 1.15rem, 0) scale(0.84) rotate(-4deg);
  transform-origin: center center;
  filter: blur(5px);
  will-change: transform, opacity, filter;
}

.service-showcase__slide.is-active:not(.is-illus-revealed) .service-showcase__illus img {
  animation: service-illus-reveal 0.78s cubic-bezier(0.33, 1.4, 0.52, 1) forwards;
}

.service-showcase__slide.is-illus-revealed .service-showcase__illus img {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  filter: blur(0);
  animation: none;
  will-change: auto;
}

@keyframes service-illus-reveal {
  from {
    opacity: 0;
    transform: translate3d(0, 1.15rem, 0) scale(0.84) rotate(-4deg);
    filter: blur(5px);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
    filter: blur(0);
  }
}

.service-showcase__slide.is-active .service-showcase__num {
  color: var(--service-showcase-accent);
}

.service-showcase__title {
  width: 100%;
  margin: clamp(0.75rem, 2vw, 1.15rem) 0 clamp(1rem, 2.2vw, 1.35rem);
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.02em;
  text-align: center;
  color: #1a1a1a;
}

.service-showcase__desc {
  margin: 0;
  max-width: 36ch;
  font-size: clamp(0.9375rem, 0.88rem + 0.25vw, 1.0625rem);
  line-height: 1.95;
  text-align: left;
  color: #3e3e3e;
}

.service-showcase__body .service-showcase__desc {
  align-self: center;
}

.service-showcase__slide-media {
  display: none;
  margin: 0;
}

.service-showcase__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  gap: 0.85rem;
  margin-top: clamp(1.5rem, 3vw, 2rem);
  padding: 0.85rem 1.35rem 0.85rem 1.45rem;
  border: 2px solid var(--color-sub);
  border-radius: 999px;
  color: var(--color-cta-text);
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-decoration: none;
  background: var(--color-sub);
}

.service-showcase__cta::before {
  background: linear-gradient(118deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}

.service-showcase__cta-label,
.service-showcase__cta-icon {
  position: relative;
  z-index: 1;
}

.service-showcase__cta-icon {
  display: inline-flex;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
  .service-showcase__cta:hover .service-showcase__cta-icon,
  .service-showcase__cta:focus-visible .service-showcase__cta-icon {
    transform: translateX(6px);
  }
}

.service-showcase__stage {
  grid-column: 2;
  grid-row: 1 / -1;
  position: sticky;
  top: var(--header-height);
  height: calc(100dvh - var(--header-height));
  align-self: start;
  /* 右端はビューポートに接地（左列との境界のみ内側余白なし） */
  padding: clamp(1.25rem, 2.25vw, 1.75rem) 0;
}

@media (min-width: 1024px) {
  .service-showcase__stage {
    padding-block: clamp(1rem, 2vw, 1.5rem);
  }
}

.service-showcase__stage-inner {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: clamp(0.65rem, 1.25vw, 1rem) 0 0 clamp(0.65rem, 1.25vw, 1rem);
  background: #0d1f1c;
}

.service-showcase__figure {
  position: absolute;
  inset: 0;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0.85s;
}

.service-showcase__figure.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
}

.service-showcase__figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.08);
  transition: transform 1.15s cubic-bezier(0.22, 1, 0.36, 1);
}

.service-showcase__figure.is-active img {
  transform: scale(1);
}

@media (max-width: 1023px) {
  .service-showcase__layout {
    grid-template-columns: 1fr;
    gap: clamp(1.25rem, 4vw, 2rem);
    padding-inline: var(--svc-align-gutter);
  }

  .service-showcase__stage {
    display: none;
  }

  .service-showcase__slides {
    gap: clamp(1rem, 3vw, 1.5rem);
    padding-bottom: 0.5rem;
  }

  .service-showcase__slide {
    min-height: auto;
    padding: 0;
  }

  .service-showcase__slide-inner {
    width: 100%;
    max-width: none;
    padding: clamp(1.35rem, 4vw, 1.75rem);
    border: 1px solid color-mix(in srgb, var(--service-showcase-accent) 12%, var(--color-border));
    border-radius: var(--radius-md);
    background: var(--color-white);
    box-shadow: 0 14px 40px rgba(0, 90, 84, 0.06);
  }

  .service-showcase__slide:not(.is-active) .service-showcase__slide-inner {
    opacity: 1;
  }

  .service-showcase__illus {
    width: min(240px, 78%);
    margin: clamp(0.15rem, 1vw, 0.35rem) auto clamp(0.6rem, 2vw, 0.9rem);
  }

  .service-showcase__illus img {
    width: min(240px, 100%);
    height: auto;
  }

  .service-showcase__num {
    font-size: clamp(2.5rem, 10vw, 3.75rem);
    font-weight: 400;
    margin-bottom: clamp(0.15rem, 0.8vw, 0.35rem);
    color: var(--service-showcase-accent);
  }

  .service-showcase__slide-media {
    display: block;
    margin: clamp(1rem, 3vw, 1.35rem) 0 0;
    overflow: hidden;
    border-radius: calc(var(--radius-md) - 2px);
    aspect-ratio: 16 / 10;
  }

  .service-showcase__slide-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

/* ── スマホ（768px以下）：sticky ステージ画像 + スクロール連動フェード + ガラスカード ── */
@media screen and (max-width: 768px) {
  .services-section--showcase {
    overflow: visible;
  }

  .service-showcase {
    overflow: visible;
  }

  .service-showcase__layout {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-inline: 0;
    align-items: stretch;
  }

  /* DOMは「スライド→ステージ」のまま / 画面上はステージを先に見せる */
  .service-showcase__slides {
    order: 2;
    margin-top: clamp(-3.25rem, -9vw, -1.5rem);
    padding-inline: var(--svc-align-gutter);
    padding-bottom: clamp(1.75rem, 6vw, 2.75rem);
    gap: clamp(1.75rem, 6vh, 2.75rem);
    position: relative;
    z-index: 2;
  }

  .service-showcase__stage {
    display: block;
    order: 1;
    position: sticky;
    top: var(--header-height);
    height: clamp(260px, 46dvh, 400px);
    margin: 0;
    grid-column: auto;
    grid-row: auto;
    padding: 0;
    align-self: stretch;
    width: 100%;
    max-width: none;
    z-index: 0;
  }

  .service-showcase__stage-inner {
    height: 100%;
    border-radius: 0 0 clamp(1rem, 4.5vw, 1.5rem) clamp(1rem, 4.5vw, 1.5rem);
    box-shadow:
      0 24px 48px rgba(0, 0, 0, 0.12),
      0 0 0 1px rgba(255, 255, 255, 0.04) inset;
  }

  /* 画像下端に視認性用の上品なグラデーション */
  .service-showcase__stage-inner::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: clamp(52%, 62%, 70%);
    background: linear-gradient(
      to top,
      rgba(13, 31, 28, 0.68) 0%,
      rgba(13, 31, 28, 0.22) 48%,
      transparent 100%
    );
    pointer-events: none;
    z-index: 2;
  }

  .service-showcase__figure {
    z-index: 0;
  }

  .service-showcase__figure.is-active {
    z-index: 1;
  }

  .service-showcase__slide {
    align-items: center;
    min-height: 85vh;
    min-height: min(92dvh, 640px);
    padding-block: clamp(1rem, 3vh, 1.75rem);
    scroll-margin-top: calc(var(--header-height) + 12px);
  }

  .service-showcase__slide-inner {
    width: 100%;
    max-width: none;
    margin-top: clamp(1.75rem, 5vh, 2.75rem);
    padding: clamp(1.35rem, 4.2vw, 1.75rem) clamp(1.35rem, 4.5vw, 1.75rem);
    background: linear-gradient(
      158deg,
      rgba(255, 255, 255, 0.94) 0%,
      rgba(255, 255, 255, 0.78) 55%,
      rgba(247, 250, 249, 0.72) 100%
    );
    border-radius: clamp(1rem, 4vw, 1.25rem);
    border: 1px solid rgba(255, 255, 255, 0.55);
    box-shadow:
      0 22px 50px rgba(0, 30, 28, 0.14),
      0 0 0 1px rgba(0, 90, 84, 0.06);
    backdrop-filter: blur(16px) saturate(1.15);
    -webkit-backdrop-filter: blur(16px) saturate(1.15);
    transition:
      opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1),
      transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
      filter 0.5s ease,
      box-shadow 0.5s ease;
  }

  .service-showcase__slide-media {
    display: none !important;
  }

  /* スクロール中の「読む対象」をはっきり */
  .service-showcase__slide:not(.is-active) .service-showcase__slide-inner {
    opacity: 0.68;
    transform: translateY(6px) scale(0.99);
    filter: saturate(0.92);
    box-shadow:
      0 12px 28px rgba(0, 30, 28, 0.08),
      0 0 0 1px rgba(0, 90, 84, 0.05);
  }

  .service-showcase__slide.is-active .service-showcase__slide-inner {
    opacity: 1;
    transform: none;
    filter: none;
  }

  .service-showcase__illus {
    width: min(200px, 62vw);
    margin: clamp(0.1rem, 0.8vw, 0.25rem) auto clamp(0.5rem, 1.8vw, 0.75rem);
  }

  .service-showcase__illus img {
    width: min(200px, 100%);
    height: auto;
  }

  .service-showcase__num {
    font-size: clamp(2rem, 11vw, 2.85rem);
    font-weight: 500;
    margin-bottom: clamp(0.1rem, 0.6vw, 0.25rem);
    padding-top: 0;
  }

  .service-showcase__title {
    font-size: clamp(1.2rem, 5.2vw, 1.45rem);
    margin: clamp(0.6rem, 2.2vw, 0.95rem) 0 clamp(0.85rem, 2.4vw, 1.15rem);
  }

  .service-showcase__desc {
    max-width: none;
  }
}

/* スマホでも「動きを減らす」設定のときは、カード＋インライン画像の静かなレイアウトへ */
@media screen and (max-width: 768px) and (prefers-reduced-motion: reduce) {
  .services-section--showcase {
    overflow: clip;
  }

  .service-showcase {
    overflow: visible;
    border-radius: 0;
  }

  .service-showcase__layout {
    padding-inline: var(--svc-align-gutter);
  }

  .service-showcase__slides {
    order: unset;
    margin-top: 0;
    padding-inline: 0;
  }

  .service-showcase__stage {
    display: none;
  }

  .service-showcase__slide {
    min-height: 0;
    padding-block: 0;
  }

  .service-showcase__slide-inner {
    margin-top: 0;
    background: var(--color-white);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 14px 40px rgba(0, 90, 84, 0.06);
  }

  .service-showcase__slide:not(.is-active) .service-showcase__slide-inner,
  .service-showcase__slide.is-active .service-showcase__slide-inner {
    opacity: 1;
    transform: none;
    filter: none;
  }

  .service-showcase__slide-media {
    display: block !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .service-showcase__slide-inner,
  .service-showcase__num,
  .service-showcase__illus img,
  .service-showcase__figure,
  .service-showcase__figure img,
  .service-showcase__cta,
  .service-showcase__cta::before,
  .service-showcase__cta-icon,
  .button--fill-lr::before,
  .button-primary::before,
  .button-secondary::before,
  .button-tertiary::before,
  .button-cta::before,
  .button-greeting-outline::before,
  .cta-card__btn::before,
  .cta-card__phone-dial::before,
  .recruit-banner__cta::before {
    transition: none;
    transform: scaleX(1);
  }

  .recruit-banner__cta,
  .recruit-banner__cta-arrow {
    color: #000;
  }

  .button-secondary,
  .button-tertiary {
    color: var(--color-white);
    border-color: var(--color-primary-dark);
    background-color: transparent;
  }

  .service-showcase__figure img {
    transform: none;
  }
}

/* ── CTA Contact（ディープグリーン・白抜き／3カラムグラスカード） ── */
.cta-contact-section {
  --cta-contact-bg: #005a54;
  --cta-contact-bg-deep: #012a27;
  position: relative;
  z-index: 1;
  padding: clamp(3.75rem, 9vmin, 6rem) 0;
  color: #fff;
  background-color: var(--cta-contact-bg);
  background-image: linear-gradient(
    168deg,
    #001e1c 0%,
    var(--cta-contact-bg-deep) 38%,
    var(--cta-contact-bg) 58%,
    #006b62 112%
  );
}

/* レイヤード見出し（他セクションと同一マークアップ・濃色背景用の色替え） */
.cta-contact-section .section-title-wrap--on-dark .section-title-wrap__heading {
  color: #fff;
}

.cta-contact-section .section-title-wrap--on-dark .section-title-wrap__en {
  color: rgba(255, 255, 255, 0.32);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .cta-contact-section .section-title-wrap--on-dark .section-title-wrap__en {
    color: transparent;
    background-image: var(--section-title-en-gradient-on-dark-bg);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-position: left center;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
  }
}

.cta-contact__inner {
  max-width: var(--content-max);
  margin: 0 auto;
  text-align: center;
}

/* トップ：施工事例・ブログ等の section-heading と同じ見出しブロック幅 */
.site-main--front .cta-contact__heading-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.9rem, 2.2vw, 1.35rem);
  max-width: min(48rem, 100%);
  margin-left: auto;
  margin-right: auto;
  margin-bottom: clamp(2.35rem, 5.5vw, 3.35rem);
}

.site-main--front .cta-contact__heading-group .section-title-wrap {
  align-self: stretch;
  margin-bottom: clamp(0.65rem, 2vw, 1.1rem);
  padding-bottom: clamp(0.85rem, 2.5vw, 1.5rem);
}

.cta-contact__tagline {
  font-size: clamp(1rem, 2.2vw, 1.125rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  color: rgba(255, 255, 255, 0.95);
}

.cta-contact__lead {
  font-size: clamp(0.9375rem, 1.6vw, 1.0625rem);
  line-height: 2;
  color: rgba(255, 255, 255, 0.74);
  margin-bottom: clamp(2.15rem, 5vw, 3.15rem);
}

.cta-contact__cards {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(1.25rem, 3vw, 1.75rem);
  align-items: stretch;
  max-width: min(100%, 52rem);
  margin-inline: auto;
  text-align: left;
}

.cta-contact__stack {
  display: flex;
  flex-direction: column;
  gap: clamp(1.25rem, 3vw, 1.75rem);
  min-height: 100%;
}

.cta-contact__stack .cta-card {
  flex: 1;
  min-height: 0;
}

a.cta-card {
  text-decoration: none;
  color: var(--cta-contact-bg-deep);
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(1, 82, 63, 0.12);
}

a.cta-card:focus-visible {
  outline: 3px solid var(--color-sub);
  outline-offset: 3px;
}

.cta-card {
  --cta-card-trans: 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0.55rem, 1.4vw, 0.75rem);
  padding: clamp(1.65rem, 3.5vw, 2.25rem) clamp(1.35rem, 3vw, 1.75rem);
  border-radius: clamp(18px, 2.4vw, 26px);
  background: #fff;
  background-image: linear-gradient(
    165deg,
    #fff 0%,
    color-mix(in srgb, var(--color-sub) 6%, #fff) 100%
  );
  border: 2px solid var(--color-accent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--color-sub) 35%, transparent),
    0 0 16px color-mix(in srgb, var(--color-accent) 34%, transparent),
    0 0 28px color-mix(in srgb, var(--color-accent) 18%, transparent),
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    inset 0 0 36px color-mix(in srgb, var(--color-accent) 10%, transparent),
    0 14px 36px rgba(1, 42, 39, 0.14),
    0 6px 18px rgba(247, 233, 126, 0.14);
  animation: cta-card-edge-glow 2.8s ease-in-out infinite;
  transition:
    transform var(--cta-card-trans),
    box-shadow var(--cta-card-trans),
    border-color var(--cta-card-trans);
}

.cta-card::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  border: 1.5px solid color-mix(in srgb, var(--color-accent) 55%, transparent);
  box-shadow:
    inset 0 0 28px color-mix(in srgb, var(--color-accent) 16%, transparent),
    inset 0 0 10px color-mix(in srgb, var(--color-accent-dark) 10%, transparent);
  pointer-events: none;
  animation: cta-card-edge-inner 2.8s ease-in-out infinite;
}

.cta-card > * {
  position: relative;
  z-index: 1;
}

@keyframes cta-card-edge-glow {
  0%,
  100% {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 30%, transparent),
      0 0 12px color-mix(in srgb, var(--color-accent) 26%, transparent),
      0 0 22px color-mix(in srgb, var(--color-accent) 14%, transparent),
      0 1px 0 rgba(255, 255, 255, 0.95) inset,
      inset 0 0 30px color-mix(in srgb, var(--color-accent) 8%, transparent),
      0 14px 36px rgba(1, 42, 39, 0.14),
      0 6px 18px rgba(247, 233, 126, 0.14);
  }

  50% {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 42%, transparent),
      0 0 22px color-mix(in srgb, var(--color-accent) 44%, transparent),
      0 0 38px color-mix(in srgb, var(--color-accent) 24%, transparent),
      0 1px 0 rgba(255, 255, 255, 0.95) inset,
      inset 0 0 44px color-mix(in srgb, var(--color-accent) 14%, transparent),
      0 14px 36px rgba(1, 42, 39, 0.14),
      0 6px 18px rgba(247, 233, 126, 0.18);
  }
}

@keyframes cta-card-edge-inner {
  0%,
  100% {
    opacity: 0.88;
  }

  50% {
    opacity: 1;
  }
}

.cta-card--phone {
  justify-content: center;
}

@media (hover: hover) and (pointer: fine) {
  a.cta-card:hover,
  a.cta-card:focus-visible {
    color: var(--cta-contact-bg-deep);
  }

  .cta-card:hover {
    transform: translateY(-6px);
    border-color: var(--color-accent-dark);
    animation: none;
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 45%, transparent),
      0 0 24px color-mix(in srgb, var(--color-accent) 50%, transparent),
      0 0 40px color-mix(in srgb, var(--color-accent) 28%, transparent),
      0 1px 0 rgba(255, 255, 255, 1) inset,
      inset 0 0 48px color-mix(in srgb, var(--color-accent) 16%, transparent),
      0 22px 48px rgba(1, 42, 39, 0.18),
      0 10px 28px rgba(247, 233, 126, 0.22);
  }

  .cta-card:hover::after {
    animation: none;
    opacity: 1;
    border-color: color-mix(in srgb, var(--color-accent-dark) 70%, transparent);
    box-shadow:
      inset 0 0 36px color-mix(in srgb, var(--color-accent) 22%, transparent),
      inset 0 0 14px color-mix(in srgb, var(--color-accent-dark) 14%, transparent);
  }
}

.cta-card__head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.65rem, 2vw, 0.9rem);
  width: 100%;
}

.cta-card__hero-icon {
  position: relative;
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: clamp(3.35rem, 8.5vw, 4.15rem);
  height: clamp(3.35rem, 8.5vw, 4.15rem);
  border-radius: 50%;
  background: #fff;
  color: var(--color-primary-dark);
  border: 2px solid var(--color-accent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--color-sub) 40%, transparent),
    0 0 10px color-mix(in srgb, var(--color-accent) 26%, transparent),
    0 0 16px rgba(247, 233, 126, 0.72),
    0 0 28px rgba(247, 233, 126, 0.42),
    0 0 44px rgba(247, 233, 126, 0.22),
    inset 0 0 12px rgba(247, 233, 126, 0.18);
  animation: cta-card-icon-glow 2.8s ease-in-out infinite;
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.cta-card__hero-icon svg,
.cta-card__hero-icon .cta-card__line-icon {
  position: relative;
  z-index: 1;
}

.cta-card__hero-icon::before {
  content: '';
  position: absolute;
  inset: -7px;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(247, 233, 126, 0.55) 0%,
    rgba(247, 233, 126, 0.28) 42%,
    transparent 72%
  );
  pointer-events: none;
  animation: cta-card-icon-halo 2.8s ease-in-out infinite;
}

@keyframes cta-card-icon-glow {
  0%,
  100% {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 38%, transparent),
      0 0 8px color-mix(in srgb, var(--color-accent) 22%, transparent),
      0 0 14px rgba(247, 233, 126, 0.58),
      0 0 24px rgba(247, 233, 126, 0.32),
      0 0 38px rgba(247, 233, 126, 0.16),
      inset 0 0 10px rgba(247, 233, 126, 0.14);
  }

  50% {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 52%, transparent),
      0 0 14px color-mix(in srgb, var(--color-accent) 34%, transparent),
      0 0 22px rgba(247, 233, 126, 0.88),
      0 0 36px rgba(247, 233, 126, 0.55),
      0 0 52px rgba(247, 233, 126, 0.28),
      inset 0 0 16px rgba(247, 233, 126, 0.26);
  }
}

@keyframes cta-card-icon-halo {
  0%,
  100% {
    opacity: 0.72;
    transform: scale(0.96);
  }

  50% {
    opacity: 1;
    transform: scale(1.04);
  }
}

@media (hover: hover) and (pointer: fine) {
  .cta-card:hover .cta-card__hero-icon {
    transform: scale(1.07);
    border-color: var(--color-accent-dark);
    animation: none;
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 50%, transparent),
      0 0 14px color-mix(in srgb, var(--color-accent) 38%, transparent),
      0 0 24px rgba(247, 233, 126, 0.95),
      0 0 40px rgba(247, 233, 126, 0.6),
      0 0 56px rgba(247, 233, 126, 0.32),
      inset 0 0 18px rgba(247, 233, 126, 0.3);
  }

  .cta-card:hover .cta-card__hero-icon::before {
    animation: none;
    opacity: 1;
    transform: scale(1.08);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cta-card,
  .cta-card::after,
  .cta-card__hero-icon,
  .cta-card__hero-icon::before {
    animation: none;
  }

  .cta-card {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 35%, transparent),
      0 0 18px color-mix(in srgb, var(--color-accent) 32%, transparent),
      0 0 30px color-mix(in srgb, var(--color-accent) 16%, transparent),
      0 1px 0 rgba(255, 255, 255, 0.95) inset,
      inset 0 0 36px color-mix(in srgb, var(--color-accent) 10%, transparent),
      0 14px 36px rgba(1, 42, 39, 0.14),
      0 6px 18px rgba(247, 233, 126, 0.14);
  }

  .cta-card__hero-icon {
    border-color: var(--color-accent);
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--color-sub) 40%, transparent),
      0 0 10px color-mix(in srgb, var(--color-accent) 26%, transparent),
      0 0 18px rgba(247, 233, 126, 0.7),
      0 0 30px rgba(247, 233, 126, 0.38),
      inset 0 0 12px rgba(247, 233, 126, 0.2);
  }
}

.cta-card__line-icon {
  display: block;
  width: clamp(2.15rem, 5vw, 2.5rem);
  height: auto;
  object-fit: contain;
}

.cta-card__brand-mark {
  margin-bottom: 0.15rem;
}

.cta-card__title {
  position: relative;
  z-index: 1;
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(0.9375rem, 1.9vw, 1.125rem);
  font-weight: 700;
  line-height: 1.35;
  color: var(--cta-contact-bg-deep);
  letter-spacing: 0.04em;
  text-align: left;
}

.cta-card__icon-phone,
.cta-card__icon-mail {
  flex-shrink: 0;
}

.cta-card__badge,
.cta-card__badge-hour {
  position: relative;
  z-index: 1;
  display: inline-block;
  padding: 0.2em 0.7em;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--cta-contact-bg-deep);
  border: 1px solid color-mix(in srgb, var(--color-sub) 65%, transparent);
  background: color-mix(in srgb, var(--color-sub) 22%, #fff);
  box-shadow: 0 2px 8px rgba(247, 233, 126, 0.2);
}

.cta-card__phone-dial {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  margin-top: auto;
  width: 100%;
  max-width: 100%;
  min-height: 3.35rem;
  padding: clamp(0.85rem, 2vw, 1rem) clamp(1.15rem, 2.8vw, 1.5rem);
  border-radius: clamp(12px, 1.5vw, 16px);
  font-weight: 700;
  color: var(--cta-contact-bg-deep);
  background: #fff;
  border: 1.5px solid color-mix(in srgb, var(--cta-contact-bg) 22%, transparent);
  text-decoration: none;
  box-shadow:
    0 10px 28px rgba(1, 42, 39, 0.14),
    0 2px 0 rgba(255, 255, 255, 0.9) inset;
}

.cta-card__cta-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.28rem;
  min-width: 0;
  text-align: left;
}

.cta-card__cta-main {
  font-family: var(--font-heading);
  font-size: clamp(0.9375rem, 2vw, 1.05rem);
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: 0.03em;
  color: var(--cta-contact-bg-deep);
}

.cta-card__phone-dial::before {
  background: linear-gradient(118deg, var(--cta-contact-bg) 0%, var(--cta-contact-bg-deep) 100%);
}

.cta-card__phone-dial-number,
.cta-card__phone-dial .cta-card__btn-arrow {
  position: relative;
  z-index: 1;
}

.cta-card__phone-dial-number {
  font-family: var(--font-en);
  font-size: clamp(1.05rem, 2.8vw, 1.35rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: 0.05em;
  color: var(--cta-contact-bg);
}

.cta-card__btn-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: inherit;
  transition: transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
}

.cta-card__phone-dial .cta-card__btn-arrow {
  color: var(--cta-contact-bg-deep);
}

.cta-card__phone-dial svg,
.cta-card__btn svg {
  display: block;
}

.cta-card__phone-dial:hover .cta-card__btn-arrow,
.cta-card__phone-dial:focus-visible .cta-card__btn-arrow,
.cta-card__btn:hover .cta-card__btn-arrow,
.cta-card__btn:focus-visible .cta-card__btn-arrow {
  transform: translateX(7px);
}

@media (hover: hover) and (pointer: fine) {
  .cta-card__phone-dial:hover,
  .cta-card__phone-dial:focus-visible {
    border-color: var(--cta-contact-bg);
    box-shadow: 0 16px 40px rgba(1, 42, 39, 0.22);
  }

  .cta-card__phone-dial:hover .cta-card__cta-main,
  .cta-card__phone-dial:focus-visible .cta-card__cta-main,
  .cta-card__phone-dial:hover .cta-card__phone-dial-number,
  .cta-card__phone-dial:focus-visible .cta-card__phone-dial-number {
    color: #fff;
  }
}

.cta-card__phone-dial:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.85);
  outline-offset: 3px;
}

.cta-card__line-logo {
  display: block;
  width: min(10.25rem, 88%);
  height: auto;
  margin: 0.15rem 0 0;
  filter: drop-shadow(0 4px 18px rgba(0, 0, 0, 0.25));
}

.cta-card__text {
  margin: 0;
  flex: 1;
  font-size: 0.9375rem;
  line-height: 1.78;
  color: color-mix(in srgb, var(--cta-contact-bg-deep) 78%, #fff);
}

.cta-card__number {
  position: relative;
  z-index: 1;
  margin: 0;
  padding: 0.15rem 0.35rem 0;
  font-family: var(--font-en);
  font-size: clamp(1.15rem, 2.8vw, 1.45rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  color: var(--cta-contact-bg);
  text-align: center;
}

.cta-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  margin-top: auto;
  width: 100%;
  min-height: 3.15rem;
  padding: clamp(0.95rem, 2.2vw, 1.1rem) clamp(1.25rem, 3vw, 1.65rem);
  border-radius: clamp(12px, 1.5vw, 999px);
  font-weight: 700;
  font-size: clamp(0.9rem, 1.8vw, 0.98rem);
  text-decoration: none;
  text-align: center;
}

.cta-card__btn .cta-card__cta-main,
.cta-card__phone-dial .cta-card__cta-main {
  position: relative;
  z-index: 1;
}

.cta-card__btn .cta-card__btn-arrow {
  position: relative;
  z-index: 1;
}

.cta-card__btn--line .cta-card__cta-main {
  color: #fff;
}

.cta-card__btn--line {
  color: #fff;
  background: #06c755;
  box-shadow:
    0 12px 32px rgba(6, 199, 85, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.cta-card__btn--line::before {
  background: linear-gradient(118deg, #05b34c 0%, #048c3c 100%);
}

@media (hover: hover) and (pointer: fine) {
  .cta-card__btn--line:hover,
  .cta-card__btn--line:focus-visible {
    box-shadow:
      0 18px 44px rgba(6, 199, 85, 0.45),
      inset 0 1px 0 rgba(255, 255, 255, 0.3);
  }

  .cta-card__btn--line:hover::before,
  .cta-card__btn--line:focus-visible::before {
    transform: scaleX(1);
  }
}

.cta-card__btn--mail {
  color: #fff;
  border: none;
  background: linear-gradient(118deg, var(--cta-contact-bg) 0%, var(--cta-contact-bg-deep) 100%);
  box-shadow:
    0 12px 32px rgba(1, 42, 39, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.cta-card__btn--mail .cta-card__cta-main {
  color: #fff;
}

.cta-card__btn--mail::before {
  background: linear-gradient(118deg, #006b62 0%, var(--cta-contact-bg-deep) 100%);
}

@media (hover: hover) and (pointer: fine) {
  .cta-card__btn--mail:hover,
  .cta-card__btn--mail:focus-visible {
    box-shadow:
      0 18px 40px rgba(1, 42, 39, 0.28),
      inset 0 1px 0 rgba(255, 255, 255, 0.28);
  }

  .cta-card__btn--mail:hover::before,
  .cta-card__btn--mail:focus-visible::before {
    transform: scaleX(1);
  }

  .cta-card__btn--mail:hover .cta-card__cta-main,
  .cta-card__btn--mail:focus-visible .cta-card__cta-main,
  .cta-card__btn--mail:hover .cta-card__btn-arrow,
  .cta-card__btn--mail:focus-visible .cta-card__btn-arrow {
    color: #fff;
  }
}

.cta-card__btn:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.55);
  outline-offset: 3px;
}

.cta-phone,
.cta-sub-actions {
  display: none;
}

@media (max-width: 1023px) {
  .cta-contact__lead {
    line-height: 1.85;
  }

  .cta-contact__cards {
    grid-template-columns: minmax(0, 1fr);
    max-width: min(100%, 24rem);
  }

  .cta-contact__stack {
    min-height: 0;
  }

  .cta-contact__stack .cta-card {
    flex: none;
  }
}

@media (max-width: 767px) {
  .cta-contact__cards {
    max-width: min(100%, 22.5rem);
  }

  .cta-contact__stack {
    min-height: 0;
  }

  .cta-contact__stack .cta-card {
    flex: none;
  }

  .cta-card {
    padding: 1.5rem 1.35rem 1.4rem;
  }
}

.area-section__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 280px);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  text-align: left;
}

.area-section__copy .reveal-heading {
  display: inline-block;
}

.area-section__copy .reveal-heading::after {
  left: 0;
  right: auto;
  margin: 0;
  width: 3rem;
  min-width: 3rem;
  transform-origin: left center;
}

.area-section__map {
  aspect-ratio: 1;
  max-width: 280px;
  margin: 0 auto;
  border-radius: 50%;
  background-color: #e8f2ee;
  background-image:
    radial-gradient(circle, var(--color-primary) 2.5px, transparent 2.5px);
  background-size: 14px 14px;
  background-position: center;
  opacity: 0.85;
  box-shadow: inset 0 0 0 8px rgba(255, 255, 255, 0.65);
}

/* トップ：対応エリア（2グループ＋概念図） */
.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.area-section--home .section-intro {
  margin-bottom: clamp(1.85rem, 4vw, 2.65rem);
}

.area-section--home .area-section__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, clamp(200px, 28vw, 280px));
  gap: clamp(1.75rem, 4vw, 3rem);
  align-items: center;
  text-align: left;
}

.area-section--home .area-section__zones {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
}

.area-zone {
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  border-radius: var(--radius-md);
  border: 0.5px solid color-mix(in srgb, var(--color-primary) 20%, var(--color-border));
  background: var(--color-white);
}

.area-zone--main {
  border-top: 2px solid var(--color-primary);
}

.area-zone--demolition {
  background: color-mix(in srgb, var(--color-primary) 4%, var(--color-white));
  border-top: 2px solid var(--color-sub);
}

.area-zone__label {
  margin: 0 0 0.75rem;
  font-size: clamp(0.8125rem, 0.78rem + 0.2vw, 0.9375rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--color-primary);
}

.area-zone--demolition .area-zone__label {
  color: var(--color-text-sub);
}

.area-zone__note {
  margin: 0 0 0.85rem;
  font-size: clamp(0.8125rem, 0.78rem + 0.18vw, 0.875rem);
  line-height: 1.6;
  color: var(--color-text-sub);
}

.area-city-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.area-city-tag {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.85rem;
  border-radius: var(--radius-full);
  border: 1px solid color-mix(in srgb, var(--color-primary) 35%, var(--color-border));
  background: color-mix(in srgb, var(--color-primary) 6%, var(--color-white));
  font-size: clamp(0.9375rem, 0.88rem + 0.25vw, 1.0625rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3;
}

.area-city-tag--sub {
  font-weight: 500;
  font-size: clamp(0.875rem, 0.82rem + 0.2vw, 0.9375rem);
  border-color: var(--color-border);
  background: var(--color-white);
  color: var(--color-text);
}

.area-section--home .area-section__figure {
  justify-self: center;
}

.area-section__map-svg {
  width: 100%;
  max-width: 260px;
  height: auto;
  margin-inline: auto;
  display: block;
}

.area-section__map-bg {
  fill: #e8f2ee;
  stroke: color-mix(in srgb, var(--color-primary) 22%, transparent);
  stroke-width: 1;
}

.area-map-dot--main {
  fill: var(--color-primary);
}

.area-map-dot--sub {
  fill: var(--color-sub);
  stroke: var(--color-primary);
  stroke-width: 1.5;
}

.site-main--front .area-section--home .area-section__layout {
  grid-template-columns: minmax(0, 1fr) minmax(0, clamp(200px, 28vw, 280px));
  justify-items: stretch;
  text-align: left;
}

@media screen and (min-width: 1024px) {
  .flow-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
  }

  .flow-grid article {
    position: relative;
  }

  .flow-grid article:not(:last-child)::after {
    content: "›";
    position: absolute;
    right: -0.55rem;
    top: 40%;
    font-size: 1.75rem;
    font-weight: 300;
    line-height: 1;
    color: var(--color-primary);
    transform: translateY(-50%);
    pointer-events: none;
  }
}

/* === 求人：フルワイドヒーローバナー === */
.site-main--front .recruit-banner,
section.recruit-banner {
  display: block;
  position: relative;
  width: 100%;
  max-width: none;
  line-height: normal;
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}

/* CONTACT と同じ英字ウォーターマーク（__bg と同じ領域の右・上下中央） */
.recruit-banner__en-decor.section-title-wrap {
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  align-self: stretch;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  text-align: right;
}

.recruit-banner__en-decor {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 clamp(0.75rem, 3.5vw, 2.5rem) 0 0;
  box-sizing: border-box;
  pointer-events: none;
  overflow: visible;
  min-height: 0;
}

.recruit-banner__en-decor .section-title-wrap__en,
.recruit-banner__en-decor.section-title-wrap.is-visible .section-title-wrap__en {
  position: static;
  left: auto;
  top: auto;
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0;
  font-size: clamp(3rem, min(10vw, 20vh), 6.5rem);
  line-height: 0.82;
  letter-spacing: -0.035em;
  text-align: right;
  opacity: 1;
  transform: none !important;
  transition: none;
}

.recruit-banner .section-title-wrap--on-dark .section-title-wrap__en {
  color: rgba(255, 255, 255, 0.32);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .recruit-banner .section-title-wrap--on-dark .section-title-wrap__en {
    color: transparent;
    background-image: var(--section-title-en-gradient-on-dark-bg);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-position: right center;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
  }
}

.recruit-banner__link {
  position: relative;
  display: block;
  width: 100%;
  min-height: clamp(260px, 38vmin, 400px);
  text-decoration: none;
  color: inherit;
}

.recruit-banner__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-color: var(--service-showcase-accent, #005a54);
  background-image: url('assets/images/onishijuki_kyujin_top.png');
  background-size: cover;
  background-position: 18% center;
  transition: transform 1s cubic-bezier(0.22, 1, 0.36, 1);
}

.recruit-banner__fade {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    105deg,
    rgba(1, 32, 30, 0.05) 0%,
    rgba(1, 50, 48, 0.18) 32%,
    rgba(0, 90, 84, 0.82) 58%,
    rgba(1, 60, 55, 0.96) 78%,
    var(--service-showcase-accent, #005a54) 100%
  );
  pointer-events: none;
}

.recruit-banner__link:hover .recruit-banner__bg,
.recruit-banner__link:focus-visible .recruit-banner__bg {
  transform: scale(1.035);
}

.recruit-banner__link:focus-visible {
  outline: 3px solid var(--color-sub);
  outline-offset: 2px;
}

.recruit-banner__container {
  position: relative;
  z-index: 3;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: clamp(2.25rem, 6vmin, 3.75rem) clamp(1.25rem, 4vw, 2rem);
  min-height: clamp(260px, 38vmin, 400px);
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.recruit-banner__content {
  position: relative;
  z-index: 1;
  max-width: min(28rem, 100%);
  text-align: right;
  padding-left: clamp(1rem, 4vw, 2rem);
}

.recruit-banner__heading {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.2em;
  margin: 0 0 clamp(0.85rem, 2vw, 1.25rem);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.35rem, 3.2vmin, 1.875rem);
  line-height: 1.38;
  letter-spacing: 0.04em;
  color: #fff;
}

.recruit-banner__title-line {
  display: block;
}

.recruit-banner__sub {
  margin: 0 0 clamp(1.35rem, 3vw, 1.85rem);
  font-size: clamp(0.9rem, 1.95vmin, 1.05rem);
  font-weight: 600;
  line-height: 1.85;
  color: rgba(255, 255, 255, 0.9);
}

.recruit-banner__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.82rem 1.45rem;
  margin-left: auto;
  margin-right: 0;
  border: 1.5px solid rgba(255, 255, 255, 0.85);
  border-radius: 999px;
  font-size: clamp(0.8125rem, 1.5vmin, 0.9375rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #fff;
  background: transparent;
  box-shadow: 0 0 0 rgba(255, 255, 255, 0);
  isolation: isolate;
}

.recruit-banner__cta::before {
  z-index: -1;
  background: rgba(255, 255, 255, 0.94);
}

.recruit-banner__cta-arrow {
  position: relative;
  z-index: 1;
  font-family: var(--font-en);
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    color 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

/* 親 <a> の color 継承より優先（::before が文字の上に重なる問題も isolation で解消） */
.recruit-banner__link:hover .recruit-banner__cta,
.recruit-banner__link:focus-visible .recruit-banner__cta {
  color: #000;
}

.recruit-banner__link:hover .recruit-banner__cta-arrow,
.recruit-banner__link:focus-visible .recruit-banner__cta-arrow {
  color: #000;
}

@media (hover: hover) and (pointer: fine) {
  .recruit-banner__link:hover .recruit-banner__cta::before,
  .recruit-banner__link:focus-visible .recruit-banner__cta::before {
    transform: scaleX(1);
  }

  .recruit-banner__link:hover .recruit-banner__cta-arrow,
  .recruit-banner__link:focus-visible .recruit-banner__cta-arrow {
    transform: translateX(5px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .recruit-banner__bg,
  .recruit-banner__cta-arrow {
    transition: none;
  }

  .recruit-banner__link:hover .recruit-banner__bg,
  .recruit-banner__link:focus-visible .recruit-banner__bg {
    transform: none;
  }
}

@media screen and (max-width: 900px) {
  .area-section__layout {
    grid-template-columns: 1fr;
  }

  .area-section--home .area-section__layout {
    grid-template-columns: 1fr;
    gap: clamp(1.25rem, 3.5vw, 1.75rem);
  }

  .area-section--home .area-section__zones {
    grid-template-columns: 1fr;
  }

  .area-section--home .area-section__figure {
    order: -1;
    max-width: min(100%, 12rem);
    margin-inline: auto;
  }

  .area-section__map {
    order: -1;
    max-width: 220px;
  }

  .recruit-banner__bg {
    background-position: 50% center;
  }

  .recruit-banner__fade {
    background: linear-gradient(
      180deg,
      rgba(1, 32, 30, 0.72) 0%,
      rgba(0, 70, 65, 0.9) 42%,
      rgba(0, 90, 84, 0.96) 68%,
      var(--service-showcase-accent, #005a54) 100%
    );
  }

  .recruit-banner__en-decor {
    align-items: flex-start;
    justify-content: center;
    padding: clamp(0.35rem, 2vw, 0.85rem) clamp(0.75rem, 3vw, 1.25rem) 0;
  }

  .recruit-banner__en-decor .section-title-wrap__en,
  .recruit-banner__en-decor.section-title-wrap.is-visible .section-title-wrap__en {
    width: 100%;
    max-width: 100%;
    font-size: clamp(2.15rem, 12vw, 3.5rem) !important;
    text-align: center;
    opacity: 0.22 !important;
  }

  .recruit-banner__container {
    justify-content: center;
    text-align: center;
    padding-block: clamp(2.75rem, 8vw, 3.5rem);
  }

  .recruit-banner__content {
    max-width: 36rem;
    margin-inline: auto;
    text-align: center;
    padding: clamp(1rem, 3.5vw, 1.35rem) clamp(0.85rem, 3vw, 1.15rem);
  }

  .recruit-banner__content::before {
    content: '';
    position: absolute;
    inset: -0.35rem -0.65rem;
    z-index: -1;
    border-radius: 0.35rem;
    background: rgba(0, 35, 32, 0.38);
  }

  .recruit-banner__heading {
    align-items: center;
    font-size: clamp(1.45rem, 4.6vw, 1.875rem);
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.42);
  }

  .recruit-banner__sub {
    font-size: clamp(0.9375rem, 2.85vw, 1.0625rem);
    color: #fff;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.38);
  }

  .recruit-banner__cta {
    margin-inline: auto;
    font-size: clamp(0.875rem, 2.4vw, 0.9375rem);
    border-color: rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.22);
  }

  .flow-grid article:not(:last-child)::after {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .recruit-banner__link {
    min-height: clamp(280px, 72vw, 360px);
  }

  .recruit-banner__container {
    min-height: clamp(280px, 72vw, 360px);
  }

  .recruit-banner__en-decor .section-title-wrap__en,
  .recruit-banner__en-decor.section-title-wrap.is-visible .section-title-wrap__en {
    font-size: clamp(1.85rem, 11vw, 2.75rem) !important;
    opacity: 0.18 !important;
  }

  .recruit-banner__heading {
    font-size: clamp(1.375rem, 5.2vw, 1.625rem);
    line-height: 1.42;
  }

  .recruit-banner__sub {
    line-height: 1.75;
  }
}

/* === フローティングCTA（フリーコール） === */
.float-cta {
  position: fixed;
  right: clamp(0.35rem, 1.25vw, 0.75rem);
  bottom: clamp(1.25rem, 3.5vh, 2rem);
  z-index: 50;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.float-cta.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.float-cta-link {
  display: block;
  width: 200px;
  max-width: 200px;
  transition: transform 0.2s ease;
  filter: drop-shadow(0 3px 10px rgba(0, 0, 0, 0.14));
}

.float-cta-link:hover,
.float-cta-link:focus {
  transform: translateY(-3px);
}

.float-cta-link:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 4px;
  border-radius: 4px;
}

.float-cta-link img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .float-cta {
    right: max(0.5rem, env(safe-area-inset-right, 0px));
    bottom: max(1rem, env(safe-area-inset-bottom, 0px));
  }

  .float-cta-link {
    width: 200px;
    max-width: min(200px, 46vw);
  }

  .float-cta-link:hover,
  .float-cta-link:focus {
    transform: translateY(-2px);
  }
}

/* === 求人セクション：吹き出し画像 === */
.recruit-fukidashi {
  display: block;
  width: clamp(270px, 90%, 420px);
  height: auto;
  margin: 1.5rem auto 0;
}

@media (max-width: 900px) {
  .recruit-fukidashi {
    margin: 1.25rem auto 0;
  }
}

/* ========================================
   ご利用の流れ ページ（page-first-visit.php）
   ======================================== */

/* ---- セクション背景 ---- */

.flow-steps-section {
  background-color: var(--color-features-bg);
}

.site-main--subpage .flow-steps-section--subpage {
  background-color: var(--color-white);
}

.flow-remote-section {
  background-color: var(--color-bg-soft);
}

/* ---- リードセクション ---- */

.flow-lead-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

.flow-lead-heading {
  font-size: clamp(1.35rem, 2.5vw, 1.9rem);
  font-weight: 700;
  margin-bottom: 1.25rem;
  color: var(--color-text);
  line-height: 1.35;
}

.flow-lead-text p {
  color: var(--color-text-sub);
  font-size: clamp(0.9375rem, 1vw + 0.5rem, 1.0625rem);
  line-height: 1.95;
  margin: 0;
}

/* 画像ボックス */
.flow-img-box {
  margin: 0;
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.flow-img-box img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* プレースホルダー */
.flow-img-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  aspect-ratio: 16 / 9;
  background-color: #e8e8e8;
  border: 2px dashed #c8c8c8;
  border-radius: var(--radius-card);
  color: #aaa;
  font-size: 0.875rem;
  text-align: center;
  line-height: 1.6;
}

.flow-img-placeholder small {
  font-size: 0.75rem;
  color: #bbb;
  font-family: monospace;
}

/* ---- 9ステップグリッド ---- */

.flow-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  margin-top: clamp(2rem, 4vw, 2.75rem);
}

.flow-step-card {
  background-color: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.flow-step-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.flow-step-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.flow-step-number {
  font-family: var(--font-en);
  font-size: clamp(1.9rem, 3.2vw, 2.5rem);
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

.flow-step-icon {
  width: 52px;
  height: 52px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-features-bg);
  border-radius: var(--radius-md);
  border: 1px dashed var(--color-border);
  overflow: hidden;
}

.flow-step-icon img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  display: block;
}

.flow-step-body h3 {
  font-size: clamp(0.9375rem, 1.1vw + 0.3rem, 1.0625rem);
  font-weight: 700;
  margin: 0 0 0.6rem;
  color: var(--color-text);
  line-height: 1.45;
}

.flow-step-body p {
  margin: 0;
  font-size: clamp(0.875rem, 0.9vw + 0.3rem, 0.9375rem);
  line-height: 1.9;
  color: var(--color-text-sub);
}

/* ---- 役割対比グリッド ---- */

.flow-role-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.flow-role-card {
  border-radius: var(--radius-card);
  padding: clamp(1.5rem, 3vw, 2rem);
}

.flow-role-card--customer {
  background-color: var(--color-bg-soft);
  border: 1px solid var(--color-border);
}

.flow-role-card--company {
  background-color: var(--color-primary);
  color: #fff;
}

.flow-role-card h3 {
  font-size: clamp(1rem, 1.4vw + 0.2rem, 1.125rem);
  font-weight: 700;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  line-height: 1.4;
}

.flow-role-card--customer h3 {
  color: var(--color-primary-dark);
  border-bottom: 2px solid var(--color-border);
}

.flow-role-card--company h3 {
  color: #fff;
  border-bottom: 2px solid rgba(255, 255, 255, 0.25);
}

.flow-role-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.flow-role-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: clamp(0.875rem, 0.9vw + 0.3rem, 0.9375rem);
  line-height: 1.75;
}

.flow-role-list li::before {
  content: '';
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  margin-top: 0.57em;
}

.flow-role-card--customer .flow-role-list li {
  color: var(--color-text-sub);
}

.flow-role-card--customer .flow-role-list li::before {
  background-color: var(--color-primary);
}

.flow-role-card--company .flow-role-list li {
  color: rgba(255, 255, 255, 0.9);
}

.flow-role-card--company .flow-role-list li::before {
  background-color: rgba(255, 255, 255, 0.7);
}

/* ---- お手続きグリッド ---- */

.flow-procedures-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.flow-procedures-box {
  background-color: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: clamp(1.5rem, 2.5vw, 2rem);
}

.flow-procedures-box--highlight {
  background-color: #fff;
  border-left: 4px solid var(--color-secondary);
}

.flow-procedures-subheading {
  font-size: clamp(1rem, 1.2vw + 0.2rem, 1.125rem);
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--color-text);
  line-height: 1.4;
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
}

.flow-procedures-subheading::before {
  content: '';
  display: block;
  flex-shrink: 0;
  width: 4px;
  height: 1.1em;
  background-color: var(--color-primary);
  border-radius: 2px;
  margin-top: 0.12em;
}

.flow-procedures-box p {
  font-size: 0.9375rem;
  color: var(--color-text-sub);
  line-height: 1.9;
  margin-bottom: 1rem;
}

.flow-procedures-box p:last-child {
  margin-bottom: 0;
}

.flow-procedures-list {
  list-style: disc;
  padding-left: 1.5rem;
  margin: 0.5rem 0 1rem;
  color: var(--color-text-sub);
}

.flow-procedures-list li {
  margin-bottom: 0.5rem;
  font-size: 0.9375rem;
  line-height: 1.75;
}

.flow-note {
  font-size: 0.875rem;
  color: var(--color-text-sub);
  margin: 0;
  padding-top: 0.75rem;
  border-top: 1px dashed var(--color-border);
}

/* ---- 遠方グリッド ---- */

.flow-remote-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.flow-remote-card {
  background-color: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: clamp(1.5rem, 2.5vw, 1.75rem);
}

.flow-remote-card h3 {
  font-size: clamp(0.9375rem, 1.1vw + 0.2rem, 1.0625rem);
  font-weight: 700;
  margin-bottom: 0.75rem;
  color: var(--color-primary-dark);
  line-height: 1.45;
}

.flow-remote-card p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--color-text-sub);
  line-height: 1.9;
}

/* ---- FAQプレースホルダー ---- */

.flow-faq-placeholder {
  background-color: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 3rem 2rem;
  text-align: center;
  color: var(--color-text-sub);
  font-size: 1rem;
  line-height: 1.75;
}

.flow-faq-placeholder p {
  margin: 0;
}

.flow-faq-placeholder a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ---- CTAセクション ---- */

.flow-cta-section {
  position: relative;
  z-index: 1;
  background-color: var(--color-bg-soft);
  padding: var(--section-gap) 0;
}

.flow-cta-inner {
  max-width: 680px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
}

.flow-cta-section h2 {
  font-size: 30px;
  color: var(--color-text);
  margin: 0;
}

.flow-cta-lead {
  margin: 0;
  color: var(--color-text-sub);
  line-height: 1.95;
  font-size: clamp(0.9375rem, 1vw + 0.3rem, 1.0625rem);
}

.flow-cta-phone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.flow-cta-phone__link {
  display: inline-flex;
  align-items: baseline;
  text-decoration: none;
  color: var(--color-primary);
  transition: opacity var(--transition-fast);
}

.flow-cta-phone__link:hover,
.flow-cta-phone__link:focus {
  opacity: 0.82;
  color: var(--color-primary);
}

.flow-cta-phone__number {
  font-family: var(--font-en);
  font-size: clamp(2.5rem, 6vw, 3.75rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--color-primary);
}

.flow-cta-phone__hours {
  font-size: 0.875rem;
  color: var(--color-text-sub);
  margin: 0;
  letter-spacing: 0.04em;
}

.flow-cta-sub {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  width: 100%;
  max-width: 560px;
}

.flow-cta-sub-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: 1.25rem 1.5rem;
  border-radius: var(--radius-card);
  text-decoration: none;
  font-weight: 700;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.flow-cta-sub-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.flow-cta-sub-btn--line {
  background-color: #06C755;
  color: #fff;
}

.flow-cta-sub-btn--line:hover {
  background-color: #05a847;
  color: #fff;
}

.flow-cta-sub-btn--form {
  background-color: var(--color-primary);
  color: #fff;
}

.flow-cta-sub-btn--form:hover {
  background-color: var(--color-primary-dark);
  color: #fff;
}

.flow-cta-sub-btn__label {
  font-size: clamp(0.875rem, 1.1vw + 0.1rem, 1rem);
  line-height: 1.4;
}

.flow-cta-sub-btn__note {
  font-size: 0.8rem;
  font-weight: 400;
  opacity: 0.87;
  line-height: 1.4;
}

/* ---- ご利用の流れ レスポンシブ ---- */

@media screen and (max-width: 1023px) {
  .flow-steps-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .flow-procedures-grid {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .flow-lead-inner {
    grid-template-columns: 1fr;
  }

  .flow-steps-grid {
    grid-template-columns: 1fr;
  }

  .flow-role-grid {
    grid-template-columns: 1fr;
  }

  .flow-remote-grid {
    grid-template-columns: 1fr;
  }

  .flow-cta-sub {
    grid-template-columns: 1fr;
    max-width: 100%;
  }

  .flow-cta-phone__number {
    font-size: clamp(2.25rem, 9vw, 3.25rem);
  }

  .flow-cta-section {
    padding: var(--section-gap-mobile) 0;
  }
}

/* ========================================
   下層ページ共通（site-main--subpage）
   ======================================== */

.site-main--subpage {
  --subpage-surface-alt: #f8f9fa;
  --subpage-en-watermark: #eaeaea;
  --subpage-cta-bg: #005a54;
  --subpage-cta-deep: #012a27;
  --color-bg-soft: var(--subpage-surface-alt);
  --color-features-bg: var(--subpage-surface-alt);
  background-color: var(--color-white);
}

.site-main--subpage .subpage-section,
.site-main--subpage .page-section,
.site-main--subpage .works-preview-section,
.site-main--subpage .faq-preview-section,
.site-main--subpage .flow-steps-section,
.site-main--subpage .blog-listing {
  padding: clamp(4rem, 9vw, 7rem) 0;
}

.site-main--subpage .subpage-section--alt,
.site-main--subpage .page-section.subpage-section--alt {
  background-color: var(--subpage-surface-alt);
}

/* ── 下層ヒーロー（白背景・タイポのみ） ── */

.subpage-hero--minimal,
.page-hero--subpage {
  position: relative;
  padding: 0;
  color: var(--color-text);
  background-color: var(--color-white);
  border-bottom: 1px solid #eceef0;
}

.subpage-hero--minimal .subpage-hero__inner,
.page-hero--subpage > .container {
  padding: clamp(1.5rem, 3vw, 2rem) 0 clamp(3rem, 7vw, 4.5rem);
}

.subpage-hero__breadcrumb,
.page-hero--subpage .page-hero-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
  font-family: var(--font-en);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-sub);
}

.subpage-hero__breadcrumb a,
.page-hero--subpage .page-hero-breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}

.subpage-hero__breadcrumb a:hover,
.subpage-hero__breadcrumb a:focus-visible,
.page-hero--subpage .page-hero-breadcrumb a:hover,
.page-hero--subpage .page-hero-breadcrumb a:focus-visible {
  color: var(--color-primary);
}

.subpage-hero__breadcrumb-sep,
.page-hero--subpage .page-hero-breadcrumb .separator {
  opacity: 0.45;
}

.subpage-hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.85fr);
  gap: clamp(2rem, 5vw, 3.5rem);
  align-items: center;
}

.subpage-hero__content {
  max-width: min(36rem, 100%);
}

.subpage-hero__title,
.page-hero--subpage .subpage-hero__title,
.page-hero--subpage > .container > h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(2rem, 1.2rem + 3vw, 2.75rem);
  font-weight: 700;
  line-height: 1.22;
  letter-spacing: 0.03em;
  color: var(--color-text);
}

.subpage-hero__en,
.page-hero--subpage .subpage-hero__en {
  margin: 0.35rem 0 0;
  font-family: var(--font-en);
  font-size: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--subpage-en-watermark);
}

.subpage-hero__lead,
.page-hero--subpage .page-hero-lead {
  margin: clamp(1.1rem, 2.5vw, 1.5rem) 0 0;
  max-width: min(40rem, 100%);
  font-size: clamp(0.9375rem, 0.88rem + 0.25vw, 1.0625rem);
  line-height: 1.95;
  color: var(--color-text-sub);
}

.subpage-hero__media {
  display: flex;
  justify-content: center;
  align-items: center;
}

.subpage-hero__image {
  width: 100%;
  max-width: min(100%, 22rem);
  height: auto;
  object-fit: contain;
}

.subpage-hero__illus-placeholder {
  width: 100%;
  max-width: 20rem;
  aspect-ratio: 4 / 3;
  border: 1px dashed #d8dce0;
  border-radius: var(--radius-lg);
  background: var(--subpage-surface-alt);
}

/* ── 下層セクション見出し（薄グレー英字ウォーターマーク） ── */

.site-main--subpage .section-intro--subpage {
  gap: clamp(0.75rem, 1.8vw, 1.1rem);
  margin-bottom: clamp(2.25rem, 5vw, 3.25rem);
}

.site-main--subpage .section-title-wrap--subpage .section-title-wrap__en {
  color: var(--subpage-en-watermark);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .site-main--subpage .section-title-wrap--subpage .section-title-wrap__en {
    color: var(--subpage-en-watermark);
    background: none;
    -webkit-text-fill-color: var(--subpage-en-watermark);
  }
}

.site-main--subpage .section-title-wrap--subpage .section-title-wrap__jp::after {
  width: var(--section-title-underline-w);
  min-width: var(--section-title-underline-w);
  max-width: var(--section-title-underline-w);
  height: 2px;
  background: var(--color-primary);
}

.site-main--subpage .section-intro--subpage .section-intro__lead {
  max-width: min(42rem, 100%);
  margin-top: clamp(0.25rem, 1vw, 0.5rem);
  font-size: clamp(0.9375rem, 0.88rem + 0.2vw, 1.0625rem);
  line-height: 1.9;
  color: var(--color-text-sub);
}

.site-main--subpage .section-intro--center.section-intro--subpage .section-intro__lead {
  margin-inline: auto;
  text-align: center;
}

.site-main--subpage .section-intro--on-dark .section-title-wrap--on-dark .section-title-wrap__en {
  color: rgba(255, 255, 255, 0.22);
}

.site-main--subpage .section-intro--on-dark .section-title-wrap--on-dark .section-title-wrap__jp::after {
  background: var(--color-sub);
}

.site-main--subpage .page-section > .container > h3 {
  position: relative;
  margin: 0 0 clamp(1.5rem, 3vw, 2rem);
  padding-bottom: 0.65rem;
  font-family: var(--font-heading);
  font-size: clamp(1.35rem, 1.1rem + 0.8vw, 1.65rem);
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--color-text);
}

.site-main--subpage .page-section > .container > h3::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 3rem;
  height: 2px;
  border-radius: 1px;
  background: var(--color-accent);
}

/* ── サービスカード（ふんわりシャドウ） ── */

.demolition-services-section {
  background-color: var(--color-white);
}

.service-grid--subpage {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.site-main--subpage .service-grid--subpage .service-card--subpage {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 0;
  overflow: hidden;
  background: var(--color-white);
  border: none;
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 24px rgba(26, 26, 26, 0.06);
  transition:
    box-shadow 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.site-main--subpage .service-grid--subpage .service-card--subpage:hover {
  box-shadow: 0 10px 36px rgba(26, 26, 26, 0.1);
  transform: translateY(-4px);
}

.service-card__head {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: clamp(1.35rem, 2.5vw, 1.65rem) clamp(1.35rem, 2.5vw, 1.65rem) 1rem;
  border-bottom: none;
  background: var(--color-white);
}

.service-card__illus {
  flex-shrink: 0;
  width: 4.5rem;
  height: 4.5rem;
  object-fit: contain;
}

.service-card__illus--placeholder {
  border: 1px dashed #e2e5e8;
  border-radius: var(--radius-md);
  background: var(--subpage-surface-alt);
}

.service-card__head-text {
  flex: 1;
  min-width: 0;
}

.service-card__index {
  display: block;
  margin-bottom: 0.35rem;
  font-family: var(--font-en);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--color-accent-dark);
}

.service-card--subpage h3 {
  margin: 0;
  font-size: clamp(1.05rem, 0.95rem + 0.35vw, 1.2rem);
  font-weight: 700;
  line-height: 1.45;
  color: var(--color-primary-dark);
}

.service-card__list {
  margin: 0;
  padding: clamp(1rem, 2vw, 1.25rem) clamp(1.25rem, 2.5vw, 1.5rem) clamp(1.25rem, 2.5vw, 1.5rem);
  list-style: none;
}

.service-card__list li {
  position: relative;
  margin-bottom: 0.7rem;
  padding-left: 1.35rem;
  font-size: clamp(0.875rem, 0.82rem + 0.2vw, 0.9375rem);
  line-height: 1.85;
  color: var(--color-text);
}

.service-card__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 2px;
  background: var(--color-accent);
  transform: rotate(45deg);
}

.service-card__list li:last-child {
  margin-bottom: 0;
}

.service-card__list li strong {
  font-weight: 700;
  color: var(--color-text);
}

/* ── 施工事例 ── */

.demolition-works-section {
  background-color: var(--subpage-surface-alt);
}

.site-main--subpage .demolition-works-section .section-actions {
  margin-top: clamp(1.75rem, 3.5vw, 2.5rem);
  text-align: center;
}

/* ── 9ステップ（アウトライン数字） ── */

.flow-steps-section--subpage {
  background-color: var(--color-white);
}

.flow-steps-grid--subpage {
  margin-top: 0;
}

.site-main--subpage .flow-step-card--subpage {
  border: none;
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 20px rgba(26, 26, 26, 0.05);
}

.site-main--subpage .flow-step-card--subpage .flow-step-number {
  color: transparent;
  -webkit-text-stroke: 1.5px var(--color-primary);
  font-size: clamp(2rem, 1.5rem + 1.5vw, 2.75rem);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.site-main--subpage .flow-step-card--subpage .flow-step-icon {
  background-color: var(--color-white);
  border: 1px solid #eceef0;
}

/* ── FAQ（左アクセントライン） ── */

.faq-preview-section--subpage {
  background-color: var(--subpage-surface-alt);
}

.site-main--subpage .faq-preview-section--subpage .faq-list {
  max-width: min(52rem, 100%);
  margin-inline: auto;
}

.site-main--subpage .faq-preview-section--subpage .faq-item {
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  border-bottom: 1px solid #eceef0;
}

.site-main--subpage .faq-preview-section--subpage .faq-item__toggle {
  position: relative;
  padding-left: 1.25rem;
}

.site-main--subpage .faq-preview-section--subpage .faq-item__toggle::before {
  content: '';
  position: absolute;
  left: 0;
  top: 1.35rem;
  bottom: 1.35rem;
  width: 3px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
}

.site-main--subpage .faq-preview-section--subpage .faq-item__answer {
  padding-left: 1.25rem;
  border-top: none;
}

/* ── 対応エリア ── */

.demolition-area-section {
  background-color: var(--color-white);
}

.demolition-area-panel {
  max-width: min(44rem, 100%);
  margin-inline: auto;
  padding: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
  background: var(--color-white);
  border: none;
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 24px rgba(26, 26, 26, 0.06);
}

.demolition-area-panel__intro {
  margin: 0 0 clamp(1rem, 2vw, 1.25rem);
  font-size: clamp(0.9375rem, 0.88rem + 0.2vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.75;
  color: var(--color-primary-dark);
}

.demolition-area-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem 0.65rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.demolition-area-tag {
  display: inline-block;
  padding: 0.45rem 1rem;
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--color-primary-dark);
  background: var(--subpage-surface-alt);
  border: 1px solid #eceef0;
  border-radius: var(--radius-full);
}

/* ── スマートテーブル（会社案内・採用） ── */

.site-main--subpage .subpage-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #eceef0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-white);
  box-shadow: 0 4px 20px rgba(26, 26, 26, 0.04);
}

.site-main--subpage .subpage-table th,
.site-main--subpage .subpage-table td {
  padding: clamp(0.9rem, 2vw, 1.15rem) clamp(1rem, 2.5vw, 1.35rem);
  font-size: clamp(0.875rem, 0.82rem + 0.2vw, 0.9375rem);
  line-height: 1.75;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid #eceef0;
}

.site-main--subpage .subpage-table tr:last-child th,
.site-main--subpage .subpage-table tr:last-child td {
  border-bottom: none;
}

.site-main--subpage .subpage-table th {
  width: 32%;
  min-width: 7.5rem;
  font-weight: 700;
  color: var(--color-text);
  background: var(--subpage-surface-alt);
}

.site-main--subpage .subpage-table td {
  color: var(--color-text-sub);
}

/* ── 採用カード ── */

.site-main--subpage .subpage-card {
  padding: clamp(1.5rem, 3vw, 2rem);
  background: var(--color-white);
  border: none;
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 24px rgba(26, 26, 26, 0.06);
  transition:
    box-shadow 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.site-main--subpage .subpage-card:hover {
  box-shadow: 0 10px 32px rgba(26, 26, 26, 0.09);
  transform: translateY(-3px);
}

.site-main--subpage .subpage-card h3 {
  margin-bottom: 0.85rem;
  font-size: clamp(1.1rem, 1rem + 0.4vw, 1.25rem);
  font-weight: 700;
  color: var(--color-primary-dark);
}

.site-main--subpage .subpage-card p {
  margin-bottom: 0.65rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.site-main--subpage .recruit-grid article {
  background: transparent;
  border: none;
  padding: 0;
  border-radius: 0;
}

.site-main--subpage .subpage-contact-callout {
  background-color: var(--subpage-surface-alt);
  text-align: center;
}

.site-main--subpage .subpage-contact-callout .hero-actions {
  justify-content: center;
}

/* ── ブログ一覧 ── */

.site-main--subpage .filter-button {
  position: relative;
  z-index: 0;
  overflow: hidden;
  padding: 0.65rem 1.25rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border-radius: var(--radius-button);
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  isolation: isolate;
  transition: color 0.45s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.45s ease;
}

.site-main--subpage .filter-button::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(118deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
  .site-main--subpage .filter-button.active,
  .site-main--subpage .filter-button:hover,
  .site-main--subpage .filter-button:focus-visible {
    color: var(--color-white);
    border-color: transparent;
  }

  .site-main--subpage .filter-button.active::before,
  .site-main--subpage .filter-button:hover::before,
  .site-main--subpage .filter-button:focus-visible::before {
    transform: scaleX(1);
  }
}

.site-main--subpage .blog-card {
  overflow: hidden;
  border: none;
  border-radius: var(--radius-lg);
  background: var(--color-white);
  box-shadow: 0 4px 20px rgba(26, 26, 26, 0.06);
  transition:
    box-shadow 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
  .site-main--subpage .blog-card:hover {
    box-shadow: 0 12px 32px rgba(26, 26, 26, 0.1);
    transform: translateY(-4px);
  }
}

.site-main--subpage .blog-card-image {
  background-color: var(--subpage-surface-alt);
}

/* ── CTAバンド ── */

.subpage-cta-band {
  position: relative;
  overflow: clip;
  padding: clamp(3.5rem, 8vw, 5rem) 0;
  color: #fff;
}

.subpage-cta-band__bg {
  position: absolute;
  inset: 0;
  background-color: var(--subpage-cta-bg);
  background-image: linear-gradient(
    168deg,
    var(--subpage-cta-deep) 0%,
    var(--subpage-cta-bg) 48%,
    color-mix(in srgb, var(--color-accent) 22%, var(--subpage-cta-bg)) 100%
  );
  pointer-events: none;
}

.subpage-cta-band__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0.12;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(247, 233, 126, 0.35) 0%, transparent 45%),
    radial-gradient(circle at 85% 15%, rgba(171, 205, 4, 0.25) 0%, transparent 40%);
}

.subpage-cta-band__inner {
  position: relative;
  z-index: 1;
  text-align: center;
}

.subpage-cta-band .button-primary {
  background-color: var(--color-accent);
  color: var(--color-cta-text);
}

.subpage-cta-band .button-primary::before {
  background: var(--color-accent-dark);
}

.subpage-cta-band__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1.25rem, 3vw, 1.75rem);
  max-width: min(36rem, 100%);
  margin-inline: auto;
}

.subpage-cta-band__phone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: clamp(1rem, 2.5vw, 1.25rem) clamp(1.5rem, 4vw, 2rem);
  text-decoration: none;
  color: inherit;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(8px);
  transition:
    background-color 0.25s ease,
    border-color 0.25s ease,
    transform 0.25s ease;
}

.subpage-cta-band__phone:hover,
.subpage-cta-band__phone:focus-visible {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.4);
  transform: translateY(-2px);
}

.subpage-cta-band__phone-label {
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--color-sub);
}

.subpage-cta-band__phone-number {
  font-family: var(--font-en);
  font-size: clamp(1.75rem, 1.2rem + 2vw, 2.35rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.1;
}

.subpage-cta-band__buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  width: 100%;
}

.button-secondary--on-dark {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.55);
  color: #fff;
}

.button-secondary--on-dark::before {
  background: rgba(255, 255, 255, 0.12);
}

@media (hover: hover) and (pointer: fine) {
  .button-secondary--on-dark:hover,
  .button-secondary--on-dark:focus-visible {
    color: var(--color-primary-dark);
    border-color: #fff;
  }
}

@media screen and (max-width: 1023px) {
  .service-grid--subpage {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 1023px) {
  .subpage-hero__layout {
    grid-template-columns: 1fr;
  }

  .subpage-hero__media {
    order: -1;
    justify-content: flex-start;
  }

  .subpage-hero__image {
    max-width: 14rem;
  }
}

@media screen and (max-width: 767px) {
  .subpage-hero--minimal .subpage-hero__inner,
  .page-hero--subpage > .container {
    padding-bottom: 2.75rem;
  }

  .site-main--subpage .subpage-table th,
  .site-main--subpage .subpage-table td {
    display: block;
    width: 100%;
  }

  .site-main--subpage .subpage-table th {
    padding-bottom: 0.35rem;
    border-bottom: none;
  }

  .subpage-cta-band__buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .subpage-cta-band__buttons .button {
    width: 100%;
    justify-content: center;
  }

  .demolition-area-tags {
    justify-content: flex-start;
  }
}

/* ========================================
   解体工事ページ（01_page-demolition.md）
   ======================================== */

.site-main--demolition {
  --color-bg-offwhite: #fafaf7;
  --color-deep-green: #0b4d3c;
  --color-lime: #a8d11c;
  --color-pale-yellow: #f5e876;
  --color-muted: #8b8680;
  --color-border: #eeeeee;
  background: var(--color-white);
}

.site-main--service-page {
  --color-bg-offwhite: #fafaf7;
  --color-deep-green: #0b4d3c;
  --color-lime: #a8d11c;
  --color-pale-yellow: #f5e876;
  --color-muted: #8b8680;
  --color-border: #eeeeee;
  background: var(--color-white);
}

/* ページヘッダー */
.demolition-page-header,
.service-page-header {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: var(--subpage-hero-min-h, clamp(220px, 32vw, 320px));
  overflow: hidden;
}

.demolition-page-header__bg,
.service-page-header__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

.demolition-page-header__overlay,
.service-page-header__overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.7);
}

.demolition-page-header__inner,
.service-page-header__inner {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: var(--subpage-hero-inner-py, clamp(2rem, 4.5vw, 3rem)) 0;
}

.demolition-page-header__en,
.service-page-header__en {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--font-en);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  color: var(--color-lime);
}

.demolition-page-header__title,
.service-page-header__title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(2rem, 1.2rem + 3vw, 3rem);
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-text);
}

/* パンくず（下層ページシェルで余白を制御） */
.demolition-breadcrumb-wrap,
.service-breadcrumb-wrap {
  padding-top: 0;
  padding-bottom: 0;
}

.demolition-breadcrumb,
.service-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.875rem;
  color: var(--color-muted);
}

.demolition-breadcrumb a,
.service-breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.demolition-breadcrumb a:hover,
.demolition-breadcrumb a:focus-visible,
.service-breadcrumb a:hover,
.service-breadcrumb a:focus-visible {
  color: var(--color-deep-green);
}

.demolition-breadcrumb [aria-current="page"],
.service-breadcrumb [aria-current="page"] {
  color: var(--color-deep-green);
}

.demolition-breadcrumb__sep,
.service-breadcrumb__sep {
  opacity: 0.5;
}

/* イントロ（下層ページシェルで余白を制御） */
.demolition-intro,
.service-intro {
  padding: 0;
}

.demolition-intro__lead,
.service-intro__lead {
  max-width: 45rem;
  margin: 0 auto;
  text-align: center;
  font-size: clamp(1rem, 0.92rem + 0.35vw, 1.125rem);
  line-height: 1.9;
  color: var(--color-text-sub);
}

/* セクション */
.demolition-section,
.service-section {
  padding: clamp(4rem, 9vw, 7.5rem) 0;
}

.demolition-section--alt,
.service-section--alt {
  background: var(--color-bg-offwhite);
}

/* 見出し（指示書） */
.section-heading-design {
  position: relative;
  margin-bottom: clamp(2rem, 4vw, 3rem);
  padding-top: 1rem;
}

.section-heading-design::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 2.5rem;
  height: 2px;
  background: var(--color-deep-green);
}

.section-heading-design--center {
  text-align: center;
}

.section-heading-design--center::before {
  left: 50%;
  transform: translateX(-50%);
}

.section-heading-design__en {
  display: block;
  margin-bottom: 0.5rem;
  font-family: var(--font-en);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--color-lime);
}

.section-heading-design__title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 1.1rem + 1.8vw, 2.25rem);
  font-weight: 700;
  line-height: 1.35;
  color: var(--color-text);
}

.section-heading-design__lead {
  max-width: 42rem;
  margin: 1rem 0 0;
  font-size: 1rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.section-heading-design--center .section-heading-design__lead {
  margin-inline: auto;
}

/* サービスカード */
.demolition-service-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
  align-items: stretch;
}

.demolition-service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #fff 0%, var(--color-bg-offwhite) 100%);
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.07);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.demolition-service-card::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: var(--brand-gradient-line);
}

.demolition-service-card:hover {
  transform: translateY(-5px);
  border-color: color-mix(in srgb, var(--color-deep-green) 22%, var(--color-border));
  box-shadow: 0 16px 36px rgba(11, 77, 60, 0.12);
}

.demolition-service-card__inner {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: clamp(1.5rem, 3vw, 1.85rem) clamp(1.35rem, 2.8vw, 1.75rem) clamp(1.35rem, 2.8vw, 1.65rem);
}

.demolition-service-card__head {
  margin-bottom: 1.15rem;
}

.demolition-service-card__illus-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 7.5rem;
  margin-bottom: 1rem;
  padding: 0.5rem;
}

.demolition-service-card__illus {
  width: min(11.5rem, 88%);
  margin: 0;
  aspect-ratio: 320 / 200;
}

.demolition-service-card__illus img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 6.5rem;
  aspect-ratio: 320 / 200;
  object-fit: contain;
  object-position: center center;
}

.demolition-service-card__title {
  margin: 0;
  font-size: clamp(1.0625rem, 0.98rem + 0.35vw, 1.25rem);
  font-weight: 700;
  line-height: 1.55;
  color: var(--color-deep-green);
}

.demolition-service-card__list {
  flex: 1;
  margin: 0;
  padding: 0;
  list-style: none;
}

.demolition-service-card__list li {
  position: relative;
  margin: 0;
  padding: 0.8rem 0 0.8rem 1.05rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text);
  border-top: 1px solid color-mix(in srgb, var(--color-deep-green) 8%, var(--color-border));
}

.demolition-service-card__list li::before {
  content: '';
  position: absolute;
  top: 1.15em;
  left: 0;
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 50%;
  background: var(--color-lime);
}

.demolition-service-card__list li strong {
  color: var(--color-text);
  font-weight: 700;
}

/* 縦タイムライン */
.flow-timeline {
  margin: 0;
  padding: 0;
  list-style: none;
}

.flow-timeline__step {
  display: grid;
  grid-template-columns: 5rem minmax(0, 1fr);
  gap: 1.5rem 2rem;
  position: relative;
  padding-bottom: 2.5rem;
}

.flow-timeline__step:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 2.5rem;
  top: 4.5rem;
  bottom: 0;
  width: 2px;
  border-left: 2px dashed var(--color-deep-green);
  transform: translateX(-50%);
  opacity: 0.35;
}

.flow-timeline__number {
  font-family: var(--font-en);
  font-size: clamp(3rem, 2rem + 3vw, 4.5rem);
  font-weight: 800;
  line-height: 1;
  color: var(--color-lime);
  text-align: center;
}

.flow-timeline__content h3 {
  margin: 0 0 0.65rem;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-text);
}

.flow-timeline__content p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

/* 選ばれる理由 */
.demolition-reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
}

.demolition-reason-card {
  padding: 2rem 1.5rem;
  text-align: center;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.demolition-reason-card:hover {
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  transform: translateY(-4px);
}

.demolition-reason-card .feature-card-icon {
  margin-bottom: 1rem;
}

.demolition-reason-card h3 {
  margin: 0 0 0.85rem;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-deep-green);
}

.demolition-reason-card p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text);
  text-align: left;
}

/* 施工事例 */
.site-main--demolition .section-actions {
  margin-top: 2rem;
  text-align: center;
}

.site-main--demolition .works-preview-grid {
  gap: 2rem;
}

/* 解体ページ：9ステップタイムライン */
.site-main--demolition .flow-timeline__content {
  padding: clamp(1.25rem, 2.5vw, 1.75rem) clamp(1.35rem, 2.8vw, 1.85rem);
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 8%, var(--color-border));
  border-radius: var(--radius-md);
  background: #fff;
  box-shadow: 0 6px 20px rgba(11, 77, 60, 0.05);
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.site-main--demolition .flow-timeline__step:hover .flow-timeline__content {
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.09);
  transform: translateX(4px);
}

.site-main--demolition .flow-timeline__content h3 {
  color: var(--color-deep-green);
}

@media screen and (max-width: 767px) {
  .site-main--demolition .flow-timeline__step:hover .flow-timeline__content {
    transform: none;
  }
}

/* 法令対応・安全管理（シールドアイコン + テキストボックス） */
.safety-callout {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 12%, var(--color-border));
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #fff 0%, var(--color-bg-offwhite) 100%);
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.07);
}

.safety-callout::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: var(--brand-gradient-line);
}

.safety-callout__inner {
  display: flex;
  align-items: flex-start;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  padding: clamp(1.75rem, 4vw, 2.75rem);
}

.safety-callout__icon-wrap {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: clamp(3.25rem, 8vw, 3.75rem);
  height: clamp(3.25rem, 8vw, 3.75rem);
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-lime) 24%, #fff);
  color: var(--color-deep-green);
  line-height: 1;
}

.safety-callout__icon-wrap .service-icon,
.safety-callout__icon.service-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
}

.safety-callout__text {
  margin: 0;
  font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  line-height: 1.8;
  color: #333;
}

@media screen and (max-width: 767px) {
  .safety-callout__inner {
    gap: 0.875rem;
    padding: clamp(1.5rem, 5vw, 2rem);
  }

  .safety-callout__icon-wrap .service-icon__svg,
  .safety-callout__icon .service-icon__svg {
    width: 24px;
    height: 24px;
  }
}

/* 法令対応（コンテナページ等） */
.demolition-compliance-card,
.service-compliance-card {
  padding: 2rem 2rem 2rem calc(2rem + 4px);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-deep-green);
  border-radius: var(--radius-md);
}

.demolition-compliance-card ul,
.service-compliance-card ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.demolition-compliance-card li,
.service-compliance-card li {
  margin-bottom: 1rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text);
}

.demolition-compliance-card li:last-child,
.service-compliance-card li:last-child {
  margin-bottom: 0;
}

.service-compliance-card p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text);
}

/* コンテナページ */
.container-service-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 3rem;
  align-items: center;
}

.container-service-list {
  margin: 0;
  padding-left: 1.25rem;
  list-style: disc;
}

.container-service-list li {
  margin-bottom: 0.75rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text);
}

.container-service-list li:last-child {
  margin-bottom: 0;
}

.container-service-split__media {
  margin: 0;
}

.container-service-split__media img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.container-waste-panel {
  padding: 2rem;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.container-waste-panel__lead {
  margin: 0 0 1.25rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.container-waste-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.waste-tag {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.4;
  color: var(--color-text);
  background: var(--color-pale-yellow);
  border-radius: var(--radius-sm);
}

.container-plans-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
}

.container-plan-card {
  padding: 2rem;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.container-plan-card:hover {
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  transform: translateY(-4px);
}

.container-plan-card h3 {
  margin: 0 0 0.85rem;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-deep-green);
}

.container-plan-card p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.service-page-header__title {
  max-width: min(52rem, 100%);
  margin-inline: auto;
}

/* FAQ */
.site-main--demolition .faq-list {
  max-width: 52rem;
  margin-inline: auto;
}

.site-main--demolition .faq-item {
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

.site-main--demolition .faq-item__toggle {
  position: relative;
  padding-left: 1.25rem;
}

.site-main--demolition .faq-item__toggle::before {
  content: '';
  position: absolute;
  left: 0;
  top: 1.35rem;
  bottom: 1.35rem;
  width: 3px;
  border-radius: var(--radius-full);
  background: var(--color-deep-green);
}

.site-main--demolition .faq-item__answer {
  padding-left: 1.25rem;
  border-top: none;
}

/* 信頼ブロック */
.subpage-trust-block {
  padding: 2rem;
  background: color-mix(in srgb, var(--color-pale-yellow) 35%, var(--color-white));
  border-radius: var(--radius-md);
}

.subpage-trust-block__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.subpage-trust-block__list li {
  position: relative;
  padding-left: 1.25rem;
  margin-bottom: 0.65rem;
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.75;
  color: var(--color-text);
}

.subpage-trust-block__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: var(--color-deep-green);
}

.subpage-trust-block__list li:last-child {
  margin-bottom: 0;
}

/* 末尾CTA（下層：トップお問い合わせのコンパクト版） */
.cta-contact-section--compact {
  padding: clamp(2.75rem, 6.5vw, 4.25rem) 0;
}

.cta-contact-section--compact .cta-contact__heading-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.65rem, 1.75vw, 0.95rem);
  max-width: min(42rem, 100%);
  margin-inline: auto;
  margin-bottom: clamp(1.25rem, 3vw, 1.85rem);
}

.cta-contact-section--compact .cta-contact__heading-group .section-title-wrap {
  align-self: stretch;
  margin-bottom: clamp(0.45rem, 1.5vw, 0.75rem);
  padding-top: clamp(0.5rem, 1.5vw, 0.85rem);
  padding-bottom: clamp(0.65rem, 2vw, 1rem);
}

.cta-contact-section--compact .section-title-wrap__en {
  font-size: clamp(2.15rem, min(9vw, 14vh), 4rem);
  line-height: 0.82;
}

.cta-contact-section--compact .section-title-wrap__heading {
  font-size: clamp(1.375rem, 0.95rem + 1.4vw, 1.75rem);
}

.cta-contact-section--compact .cta-contact__tagline {
  font-size: clamp(0.9375rem, 1.8vw, 1.0625rem);
}

.cta-contact-section--compact .cta-contact__lead {
  max-width: 38rem;
  margin-inline: auto;
  margin-bottom: clamp(1.35rem, 3vw, 2rem);
  font-size: clamp(0.875rem, 1.4vw, 0.96875rem);
  line-height: 1.85;
}

.cta-contact-section--compact .cta-contact__cards {
  max-width: min(100%, 46rem);
  gap: clamp(0.85rem, 2vw, 1.25rem);
}

.cta-contact-section--compact .cta-contact__stack {
  gap: clamp(0.85rem, 2vw, 1.25rem);
}

.cta-contact-section--compact .cta-card {
  padding: clamp(1.1rem, 2.4vw, 1.45rem) clamp(1rem, 2.2vw, 1.25rem);
  border-radius: clamp(14px, 2vw, 20px);
  gap: clamp(0.4rem, 1vw, 0.55rem);
}

.cta-contact-section--compact .cta-card__hero-icon {
  width: clamp(2.75rem, 7vw, 3.35rem);
  height: clamp(2.75rem, 7vw, 3.35rem);
}

.cta-contact-section--compact .cta-card__title {
  font-size: clamp(0.9375rem, 1.5vw, 1.03125rem);
}

.cta-contact-section--compact .cta-card__number {
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
}

.cta-contact-section--compact .cta-contact__note {
  margin: clamp(1.15rem, 2.5vw, 1.5rem) 0 0;
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.68);
}

.cta-contact-section--compact .cta-contact__extra {
  margin: 0.65rem 0 0;
  font-size: 0.9375rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.88);
}

.cta-contact-section--phone-line .cta-contact__cards {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: min(100%, 40rem);
}

.cta-contact-section--phone-line .cta-card--line {
  min-height: 100%;
}

/* ボタン（指示書） */
.btn-design {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: all 0.3s ease;
}

.btn-design--primary {
  background: var(--color-lime);
  color: var(--color-text);
  border: none;
}

.btn-design--primary:hover,
.btn-design--primary:focus-visible {
  background: var(--color-deep-green);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(11, 77, 60, 0.2);
}

.btn-design--secondary {
  background: transparent;
  color: var(--color-deep-green);
  border: 2px solid var(--color-deep-green);
}

.btn-design--secondary:hover,
.btn-design--secondary:focus-visible {
  background: var(--color-deep-green);
  color: var(--color-white);
}

.btn-design__arrow {
  transition: transform 0.3s ease;
}

.btn-design:hover .btn-design__arrow,
.btn-design:focus-visible .btn-design__arrow {
  transform: translateX(5px);
}

.btn-design:focus-visible {
  outline: 2px solid var(--color-lime);
  outline-offset: 2px;
}

@media screen and (max-width: 1023px) {
  .demolition-reasons-grid {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .demolition-service-grid {
    grid-template-columns: 1fr;
  }

  .container-service-split {
    grid-template-columns: 1fr;
  }

  .container-service-split__media {
    order: 2;
  }

  .container-plans-grid {
    grid-template-columns: 1fr;
  }

  .flow-timeline__step {
    grid-template-columns: 3.5rem minmax(0, 1fr);
    gap: 1rem;
  }

  .flow-timeline__step:not(:last-child)::after {
    left: 1.75rem;
  }

  .btn-design {
    width: 100%;
  }
}

/* ========================================
   お知らせ・解体コラム（05_page-news.md）
   ======================================== */

.service-page-header--plain {
  background: var(--color-bg-offwhite);
}

.site-main--news .news-listing {
  padding-top: 0;
}

.site-main--news {
  --subpage-intro-pb: clamp(2.75rem, 5.5vw, 4.25rem);
}

/* お知らせ：ノート＋カテゴリタブ（左寄せ） */
.news-notebook {
  position: relative;
}

.news-notebook__tags-wrap {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: flex-start;
  margin-bottom: -1px;
  padding: 0;
}

.news-notebook__tags {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: flex-start;
  gap: 0.5rem;
  max-width: 100%;
}

.news-notebook__tag {
  appearance: none;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.72rem 1.4rem 0.88rem;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 12%, var(--color-border));
  border-bottom: none;
  border-radius: 0.65rem 0.65rem 0 0;
  background: color-mix(in srgb, var(--color-bg-offwhite) 82%, #fff);
  color: #5f6662;
  font-family: inherit;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.35;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
  transform: translateY(2px);
  transition:
    color 0.22s ease,
    background 0.22s ease,
    border-color 0.22s ease,
    box-shadow 0.22s ease,
    transform 0.22s ease;
}

.news-notebook__tag-label {
  position: relative;
  z-index: 1;
}

.news-notebook__tag:hover,
.news-notebook__tag:focus-visible {
  color: var(--color-deep-green);
  border-color: color-mix(in srgb, var(--color-deep-green) 22%, var(--color-border));
  background: #fff;
  outline: none;
}

.news-notebook__tag.is-active {
  z-index: 4;
  padding-bottom: calc(0.88rem + 1px);
  margin-bottom: -1px;
  border-color: color-mix(in srgb, var(--color-deep-green) 16%, var(--color-border));
  background: #fff;
  color: var(--color-deep-green);
  box-shadow:
    0 -6px 16px rgba(11, 77, 60, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 1);
  transform: translateY(0);
}

.news-notebook__tag.is-active::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: 0.65rem 0.65rem 0 0;
  background: var(--brand-gradient-line);
}

.news-notebook__tag:active:not(.is-active) {
  transform: translateY(3px);
}

.news-notebook__sheet {
  position: relative;
  z-index: 1;
  overflow: hidden;
  padding: clamp(1.75rem, 4vw, 2.65rem);
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 12%, var(--color-border));
  border-radius: 0 1rem 1rem 1rem;
  background:
    repeating-linear-gradient(
      180deg,
      transparent 0,
      transparent calc(1.85rem - 1px),
      color-mix(in srgb, var(--color-deep-green) 4%, transparent) calc(1.85rem - 1px),
      color-mix(in srgb, var(--color-deep-green) 4%, transparent) 1.85rem
    ),
    linear-gradient(180deg, #fff 0%, color-mix(in srgb, var(--color-bg-offwhite) 22%, #fff) 100%);
  box-shadow:
    0 14px 40px rgba(11, 77, 60, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.news-notebook__sheet-inner {
  position: relative;
  z-index: 1;
}

.news-filter__empty,
.news-empty {
  margin: 0;
  padding: clamp(2rem, 5vw, 3rem);
  text-align: center;
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-muted);
  border: 1px dashed color-mix(in srgb, var(--color-deep-green) 14%, var(--color-border));
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.72);
}

.news-card.is-filtered-out {
  display: none;
}

/* 記事カードグリッド */
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
}

.news-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(11, 77, 60, 0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.news-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--color-deep-green) 20%, var(--color-border));
  box-shadow: 0 14px 32px rgba(11, 77, 60, 0.1);
}

.news-card__link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.news-card__image {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg-offwhite);
}

.news-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: calc(var(--radius-md, 12px) - 1px) calc(var(--radius-md, 12px) - 1px) 0 0;
}

.news-card__new {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  padding: 0.2rem 0.55rem;
  background: var(--color-lime);
  color: var(--color-text);
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  border-radius: 4px;
}

.news-card__new--inline {
  position: static;
  display: inline-block;
  vertical-align: middle;
}

.news-card__body {
  padding: 1.5rem;
}

.news-category-badge {
  display: inline-block;
  padding: 0.3rem 0.75rem;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 16%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-lime) 22%, #fff);
  color: var(--color-deep-green);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.35;
  margin-bottom: 0.75rem;
}

.news-card__date {
  display: block;
  font-size: 0.875rem;
  color: var(--color-muted);
  margin-bottom: 0.5rem;
}

.news-card__title {
  margin: 0.5rem 0 0.75rem;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--color-text);
}

.news-card__excerpt {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-text-sub);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-empty {
  margin: 0;
  padding: 3rem 0;
  text-align: center;
  color: var(--color-text-sub);
}

/* ページネーション */
.site-main--news .news-pagination {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
}

.site-main--news .news-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 2.5rem;
  margin: 0 0.2rem;
  padding: 0 0.65rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-deep-green);
  text-decoration: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.site-main--news .news-pagination .page-numbers.current {
  background: var(--color-lime);
  border-color: var(--color-lime);
  color: var(--color-text);
}

.site-main--news .news-pagination a.page-numbers:hover,
.site-main--news .news-pagination a.page-numbers:focus-visible {
  background: var(--color-deep-green);
  border-color: var(--color-deep-green);
  color: var(--color-white);
}

.site-main--news .news-pagination .dots {
  border: none;
  min-width: auto;
}

/* 記事詳細 */
.news-article__inner {
  max-width: 50rem;
  margin: 0 auto;
}

.news-article__header {
  margin-bottom: 2rem;
}

.news-article__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1.25rem;
  margin: 0.75rem 0 1rem;
  font-size: 0.875rem;
  color: var(--color-muted);
}

.news-article__title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 1.2rem + 2vw, 2.25rem);
  font-weight: 700;
  line-height: 1.35;
  color: var(--color-text);
}

.news-article__figure {
  margin: 0 0 2rem;
  overflow: hidden;
  border-radius: 8px;
}

.news-article__figure img {
  width: 100%;
  height: auto;
  display: block;
}

.site-main--news .article-body {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-text);
}

.site-main--news .article-body > *:first-child {
  margin-top: 0;
}

.site-main--news .article-body h2 {
  font-size: clamp(1.5rem, 1.1rem + 1.2vw, 1.75rem);
  font-weight: 700;
  padding-left: 1rem;
  border-left: 4px solid var(--color-deep-green);
  margin: 3rem 0 1.5rem;
  line-height: 1.4;
}

.site-main--news .article-body h3 {
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.375rem);
  font-weight: 700;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-deep-green);
  margin: 2rem 0 1rem;
  line-height: 1.4;
}

.site-main--news .article-body h4 {
  font-size: 1.125rem;
  font-weight: 700;
  margin: 1.5rem 0 0.75rem;
  line-height: 1.4;
}

.site-main--news .article-body p {
  margin-bottom: 1.5rem;
}

.site-main--news .article-body ul,
.site-main--news .article-body ol {
  margin: 0 0 1.5rem;
  padding-left: 1.25rem;
}

.site-main--news .article-body li {
  margin-bottom: 0.5rem;
}

.site-main--news .article-body ul li::marker,
.site-main--news .article-body ol li::marker {
  color: var(--color-deep-green);
}

.site-main--news .article-body blockquote {
  border-left: 4px solid var(--color-lime);
  padding-left: 1.5rem;
  margin: 1.5rem 0;
  color: var(--color-muted);
}

.site-main--news .article-body a {
  color: var(--color-deep-green);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s ease;
}

.site-main--news .article-body a:hover,
.site-main--news .article-body a:focus-visible {
  border-bottom-color: var(--color-deep-green);
}

.site-main--news .article-body pre,
.site-main--news .article-body code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.9em;
}

.site-main--news .article-body pre {
  padding: 1rem 1.25rem;
  background: var(--color-bg-offwhite);
  border-radius: 4px;
  overflow-x: auto;
  margin-bottom: 1.5rem;
}

.site-main--news .article-body img,
.site-main--news .article-body figure img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

.site-main--news .article-body figure {
  margin: 1.5rem 0;
}

.site-main--news .article-body figcaption {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-muted);
  text-align: center;
}

.news-related {
  margin-top: clamp(3rem, 6vw, 5rem);
  padding-top: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--color-border);
}

.news-related .news-grid {
  margin-top: 2rem;
}

.news-back {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
  text-align: center;
}

@media screen and (max-width: 1023px) {
  .news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media screen and (max-width: 767px) {
  .news-grid {
    grid-template-columns: 1fr;
  }

  .news-notebook__tags-wrap {
    justify-content: flex-start;
    margin-inline: calc(-1 * var(--container-padding, 1rem));
    padding-inline: var(--container-padding, 1rem);
    overflow-x: auto;
    scrollbar-width: none;
  }

  .news-notebook__tags-wrap::-webkit-scrollbar {
    display: none;
  }

  .news-notebook__tags {
    flex-wrap: nowrap;
    width: max-content;
    min-width: min(100%, max-content);
    padding-bottom: 0.1rem;
  }

  .news-notebook__tag {
    flex-shrink: 0;
    padding: 0.62rem 1.05rem 0.78rem;
    font-size: 0.75rem;
  }

  .news-notebook__sheet {
    border-radius: 0 0.85rem 0.85rem 0.85rem;
    padding: clamp(1.35rem, 4.5vw, 1.85rem);
  }
}

/* ========================================
   採用情報（06_page-recruit.md）
   ======================================== */

.recruit-page-header__overlay {
  background: rgba(255, 255, 255, 0.72);
}

.recruit-intro__lead {
  max-width: 52rem;
  font-size: clamp(1rem, 0.92rem + 0.35vw, 1.125rem);
  line-height: 1.9;
}

/* 募集職種カード（インライン詳細） */
.recruit-job-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
  align-items: start;
}

.recruit-job-card {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #fff 0%, var(--color-bg-offwhite) 100%);
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.07);
  scroll-margin-top: calc(var(--header-height, 4.5rem) + 1rem);
  transition: border-color 0.28s ease, box-shadow 0.28s ease;
}

.recruit-job-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--brand-gradient-line);
}

.recruit-job-card:hover:not(.is-open) {
  border-color: color-mix(in srgb, var(--color-deep-green) 18%, var(--color-border));
  box-shadow: 0 14px 32px rgba(11, 77, 60, 0.1);
}

.recruit-job-card.is-open {
  border-color: color-mix(in srgb, var(--color-deep-green) 24%, var(--color-border));
  box-shadow: 0 16px 36px rgba(11, 77, 60, 0.12);
}

.recruit-job-card__summary {
  display: flex;
  flex-direction: column;
  padding: clamp(1.5rem, 3vw, 2rem);
}

.recruit-job-card .job-badge {
  align-self: flex-start;
  margin-bottom: 1rem;
}

.recruit-job-card__title {
  margin: 0 0 0.85rem;
  font-size: clamp(1.0625rem, 0.98rem + 0.35vw, 1.25rem);
  font-weight: 700;
  line-height: 1.5;
  color: var(--color-text);
}

.recruit-job-card__pay {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.65rem;
  margin: 0 0 0.85rem;
}

.recruit-job-card__pay-label {
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--color-muted);
}

.recruit-job-card__pay-value {
  font-family: var(--font-en);
  font-size: clamp(1.25rem, 1rem + 1vw, 1.625rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--color-deep-green);
}

.recruit-job-card__catch {
  flex: 1;
  margin: 0 0 1.35rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.recruit-job-card__toggle {
  margin-top: auto;
  width: 100%;
  min-height: 2.75rem;
  justify-content: space-between;
  cursor: pointer;
  font-family: inherit;
}

.recruit-job-card__toggle-icon {
  flex-shrink: 0;
  width: 1.125rem;
  height: 1.125rem;
  position: relative;
}

.recruit-job-card__toggle-icon::before,
.recruit-job-card__toggle-icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.75rem;
  height: 2px;
  background-color: var(--color-deep-green);
  transform: translate(-50%, -50%);
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.recruit-job-card__toggle-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.recruit-job-card.is-open .recruit-job-card__toggle-icon::after {
  transform: translate(-50%, -50%) rotate(90deg) scaleX(0);
  opacity: 0;
}

.recruit-job-card__toggle:hover .recruit-job-card__toggle-icon::before,
.recruit-job-card__toggle:hover .recruit-job-card__toggle-icon::after,
.recruit-job-card__toggle:focus-visible .recruit-job-card__toggle-icon::before,
.recruit-job-card__toggle:focus-visible .recruit-job-card__toggle-icon::after {
  background-color: #fff;
}

.recruit-job-card__details {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.35s ease;
}

.recruit-job-card__details-inner {
  padding: 0 clamp(1.25rem, 3vw, 1.75rem) clamp(1.35rem, 3vw, 1.75rem);
  border-top: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  background: #fff;
}

.recruit-job-card.is-open .recruit-job-card__details-inner {
  padding-top: clamp(1.15rem, 2.5vw, 1.35rem);
}

.site-main--recruit .recruit-job-card__details .recruit-detail-section:first-child {
  padding-top: 0;
}

.site-main--recruit .recruit-job-card__details .recruit-detail-section {
  padding-bottom: 1.15rem;
  margin-bottom: 1.15rem;
}

/* バッジ */
.job-badge {
  display: inline-block;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.35;
}

.job-badge--experienced {
  background: var(--color-deep-green);
  color: #fff;
}

.job-badge--newcomer {
  background: #f9a825;
  color: #3d2e00;
}

.job-badge--fulltime {
  background: var(--color-lime);
  color: var(--color-text);
}

.recruit-detail-section {
  padding: 0 0 1.35rem;
  margin: 0 0 1.35rem;
  border-bottom: 1px solid color-mix(in srgb, var(--color-deep-green) 8%, var(--color-border));
}

.recruit-detail-section:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: none;
}

.recruit-detail-section__heading {
  margin: 0 0 0.75rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-deep-green);
}

.recruit-detail-note {
  margin: 0 0 0.5rem;
  font-size: 0.8125rem;
  line-height: 1.75;
  color: var(--color-muted);
}

.recruit-detail-label {
  margin: 0 0 0.45rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text);
}

.recruit-detail-text {
  margin: 0 0 0.65rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.recruit-detail-list {
  margin: 0;
  padding-left: 1.15rem;
  list-style: disc;
}

.recruit-detail-list li {
  margin-bottom: 0.4rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.recruit-detail-list li::marker {
  color: var(--color-deep-green);
}

/* 応募CTA */
.recruit-apply-cta__inner {
  max-width: 44rem;
  margin: 0 auto;
  text-align: center;
}

.recruit-apply-cta__inner .section-heading-design {
  margin-bottom: 1.25rem;
}

.recruit-apply-cta__inner .section-heading-design::before {
  left: 50%;
  transform: translateX(-50%);
}

.recruit-apply-cta__lead {
  max-width: 38rem;
  margin: 0 auto 1.75rem;
  font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  line-height: 1.85;
  color: var(--color-text-sub);
}

.recruit-apply-cta__buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.85rem;
  margin-bottom: 1.15rem;
}

.recruit-apply-cta__buttons .btn-design {
  min-height: 2.75rem;
  min-width: min(100%, 17.5rem);
}

.recruit-apply-cta__reassure {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-deep-green);
}

@media screen and (max-width: 1023px) {
  .recruit-job-list {
    grid-template-columns: 1fr;
    max-width: 40rem;
    margin: 0 auto;
  }
}

@media screen and (max-width: 767px) {
  .recruit-apply-cta__buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .recruit-apply-cta__buttons .btn-design {
    width: 100%;
    max-width: none;
  }
}

/* ========================================
   クレーン作業（03_page-crane.md）
   ======================================== */

.crane-service-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
}

.crane-service-card {
  padding: 2rem;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.crane-service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

.crane-service-card__icon {
  width: 3rem;
  height: 3rem;
  margin-bottom: 1rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-deep-green) 12%, var(--color-white));
  border: 2px solid var(--color-deep-green);
}

.crane-service-card h3 {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.55;
  color: var(--color-deep-green);
}

.crane-recommend__list {
  margin: 0 0 1.25rem;
  padding-left: 1.25rem;
  list-style: disc;
}

.crane-recommend__list li {
  margin-bottom: 0.65rem;
  line-height: 1.85;
  color: var(--color-text);
}

.crane-recommend__list li::marker {
  color: var(--color-deep-green);
}

.crane-recommend p,
.crane-area p {
  margin: 0 0 0.85rem;
  font-size: 1rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.crane-recommend p:last-child,
.crane-area p:last-child {
  margin-bottom: 0;
}

.crane-safety-block {
  padding: 2rem;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-deep-green);
  border-radius: 8px;
}

.crane-safety-block p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

@media screen and (max-width: 767px) {
  .crane-service-grid {
    grid-template-columns: 1fr;
  }
}

/* ========================================
   会社案内（04_page-company.md）
   ======================================== */

.company-greeting-split {
  display: grid;
  grid-template-columns: minmax(0, 20rem) minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 3rem);
  align-items: start;
}

.company-greeting-split__photo {
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
}

.company-greeting-split__photo img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.company-greeting-split__body p {
  margin: 0 0 1.25rem;
  font-size: 1rem;
  line-height: 1.9;
  color: var(--color-text-sub);
}

.company-greeting-split__signature {
  margin-top: 1.5rem !important;
  font-weight: 700;
  color: var(--color-deep-green) !important;
}

.site-main--company .company-profile-panel {
  position: relative;
  max-width: 52rem;
  margin: 0 auto;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  border-radius: var(--radius-md);
  background: #fff;
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.07);
}

.site-main--company .company-profile-panel::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: var(--brand-gradient-line);
}

.company-profile-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.company-profile-table th,
.company-profile-table td {
  padding: clamp(1rem, 2.2vw, 1.2rem) clamp(1.25rem, 3vw, 1.75rem);
  font-size: clamp(0.9375rem, 0.88rem + 0.2vw, 1rem);
  line-height: 1.75;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid color-mix(in srgb, var(--color-deep-green) 8%, var(--color-border));
}

.company-profile-table tr:last-child th,
.company-profile-table tr:last-child td {
  border-bottom: none;
}

.company-profile-table th {
  width: 34%;
  font-weight: 700;
  color: var(--color-deep-green);
  background: color-mix(in srgb, var(--color-bg-offwhite) 75%, #fff);
}

.company-profile-table td {
  color: var(--color-text);
}

.company-profile-table td > div + div {
  margin-top: 0.4rem;
}

.company-services-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
  margin-bottom: 2rem;
  align-items: stretch;
}

.company-service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  border-radius: var(--radius-md, 12px);
  background: linear-gradient(180deg, #fff 0%, var(--color-bg-offwhite) 100%);
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.07);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.company-service-card::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: var(--brand-gradient-line);
}

.company-service-card:hover {
  transform: translateY(-5px);
  border-color: color-mix(in srgb, var(--color-deep-green) 22%, var(--color-border));
  box-shadow: 0 16px 36px rgba(11, 77, 60, 0.12);
}

.company-service-card__inner {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding: clamp(1.5rem, 3vw, 1.75rem) clamp(1.25rem, 2.5vw, 1.5rem) clamp(1.35rem, 2.8vw, 1.5rem);
  text-align: center;
}

.company-service-card__illus-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 8.75rem;
  margin-bottom: 1.15rem;
  padding: 0.65rem 0.5rem;
}

.company-service-card__illus {
  width: min(11.5rem, 88%);
  margin: 0;
  aspect-ratio: 320 / 200;
}

.company-service-card__illus img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 7.25rem;
  aspect-ratio: 320 / 200;
  object-fit: contain;
  object-position: center center;
}

.company-service-card--crane .company-service-card__illus {
  width: min(9.25rem, 72%);
}

.company-service-card--crane .company-service-card__illus img {
  max-height: 5.85rem;
}

.company-service-card__title {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3.4em;
  margin: 0 0 1.35rem;
  font-size: clamp(1rem, 0.92rem + 0.35vw, 1.125rem);
  font-weight: 700;
  line-height: 1.55;
  color: var(--color-text);
}

.company-service-card__footer {
  width: 100%;
  margin-top: auto;
}

.company-service-card__link {
  width: 100%;
  padding: 0.875rem 1.25rem;
  font-size: 0.9375rem;
}

.company-services-list {
  margin: 0;
  padding-left: 1.25rem;
  list-style: disc;
}

.company-services-list li {
  margin-bottom: 0.5rem;
  line-height: 1.75;
  color: var(--color-text-sub);
}

.company-services-list li::marker {
  color: var(--color-deep-green);
}

.company-access__map {
  overflow: hidden;
  border-radius: 8px;
  margin-bottom: 1.25rem;
}

.company-access__frame {
  display: block;
  width: 100%;
  min-height: clamp(280px, 40vw, 420px);
  border: 0;
}

.company-access__info p {
  margin: 0 0 1rem;
  font-size: 1rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

@media screen and (max-width: 1023px) {
  .company-greeting-split {
    grid-template-columns: 1fr;
  }

  .company-greeting-split__photo {
    max-width: 20rem;
  }

  .company-services-grid {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .site-main--company .company-profile-table th,
  .site-main--company .company-profile-table td {
    display: block;
    width: 100%;
  }

  .site-main--company .company-profile-table th {
    padding-bottom: 0.35rem;
    border-bottom: none;
    background: transparent;
  }

  .site-main--company .company-profile-table td {
    padding-top: 0;
    padding-bottom: 1.1rem;
  }

  .site-main--company .company-profile-table tr:last-child td {
    padding-bottom: 0;
  }
}

/* ========================================
   お問い合わせ（07_page-contact.md）
   ======================================== */

.site-main--contact .contact-forms-section {
  padding-top: 0;
}

.contact-forms-wrap {
  max-width: 56rem;
  margin: 0 auto;
}

.site-main--contact .contact-grid--dual {
  gap: clamp(1.25rem, 3vw, 1.75rem);
}

.site-main--contact .contact-form-panel {
  position: relative;
  min-width: 0;
  overflow: hidden;
  padding: clamp(1.5rem, 3vw, 2rem);
  border: 1px solid color-mix(in srgb, var(--color-deep-green) 10%, var(--color-border));
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #fff 0%, var(--color-bg-offwhite) 100%);
  box-shadow: 0 10px 28px rgba(11, 77, 60, 0.07);
}

.site-main--contact .contact-form-panel::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--brand-gradient-line);
}

.site-main--contact .contact-form-panel h3 {
  margin: 0 0 0.65rem;
  font-size: clamp(1.0625rem, 0.98rem + 0.35vw, 1.25rem);
  font-weight: 700;
  color: var(--color-deep-green);
}

.site-main--contact .contact-form-panel > p {
  margin: 0 0 1.35rem;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.site-main--contact .wpcf7 input[type="text"],
.site-main--contact .wpcf7 input[type="email"],
.site-main--contact .wpcf7 input[type="tel"],
.site-main--contact .wpcf7 input[type="url"],
.site-main--contact .wpcf7 select,
.site-main--contact .wpcf7 textarea {
  width: 100%;
  padding: 0.875rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  font-size: 1rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.site-main--contact .wpcf7 input:focus,
.site-main--contact .wpcf7 select:focus,
.site-main--contact .wpcf7 textarea:focus {
  outline: none;
  border-color: var(--color-deep-green);
  box-shadow: 0 0 0 3px rgba(11, 77, 60, 0.1);
}

.site-main--contact .wpcf7 textarea {
  min-height: 10rem;
  resize: vertical;
}

@media screen and (max-width: 1023px) {
  .site-main--contact .contact-grid--dual {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .site-main--contact .contact-forms-section {
    padding-block: clamp(2.5rem, 8vw, 4rem);
  }

  .site-main--contact .contact-grid--dual {
    grid-template-columns: 1fr;
  }

  .site-main--contact .contact-form-panel {
    padding: 1.25rem;
  }

  .site-main--contact .wpcf7 input[type="submit"] {
    width: 100%;
    max-width: none;
  }

  .cta-contact-section--phone-line .cta-contact__cards {
    grid-template-columns: 1fr;
    max-width: min(100%, 22rem);
  }
}

/* ========================================
   プライバシーポリシー（08_page-privacy-sitemap.md）
   ======================================== */

.policy-body {
  max-width: 50rem;
  margin: 0 auto;
}

.site-main--privacy .policy-body h3 {
  font-size: clamp(1.125rem, 1rem + 0.5vw, 1.375rem);
  font-weight: 700;
  padding-left: 1rem;
  border-left: 4px solid var(--color-deep-green);
  margin: 2.5rem 0 1rem;
  line-height: 1.45;
  color: var(--color-text);
}

.site-main--privacy .policy-body h3:first-child {
  margin-top: 0;
}

.site-main--privacy .policy-body p {
  margin-bottom: 1rem;
  line-height: 1.8;
  color: var(--color-text-sub);
}

.site-main--privacy .policy-body ul,
.site-main--privacy .policy-body ol {
  margin: 0 0 1.5rem;
  padding-left: 1.5rem;
}

.site-main--privacy .policy-body li {
  margin-bottom: 0.5rem;
  line-height: 1.8;
  color: var(--color-text-sub);
}

.site-main--privacy .policy-body li::marker {
  color: var(--color-deep-green);
}

.policy-meta {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
  text-align: right;
}

.policy-meta p {
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-muted);
}

/* サイトマップ */
.sitemap-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(2rem, 4vw, 3rem);
}

.sitemap-group__title {
  margin: 0 0 1rem;
  font-size: 1.25rem;
  font-weight: 700;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--color-deep-green);
  color: var(--color-text);
}

.sitemap-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.sitemap-list li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border);
}

.sitemap-list a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.3s ease;
}

.sitemap-list a::before {
  content: '→';
  color: var(--color-lime);
  font-weight: 700;
}

.sitemap-list a:hover,
.sitemap-list a:focus-visible {
  color: var(--color-deep-green);
}

@media screen and (max-width: 1023px) {
  .sitemap-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media screen and (max-width: 767px) {
  .sitemap-grid {
    grid-template-columns: 1fr;
  }
}

/* ========================================
   09_fixes.md — 下層ページ修正（トップ非影響）
   ======================================== */

/* サービスアイコン */
.service-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #0b4d3c;
}

.crane-service-card__icon.service-icon {
  width: 3rem;
  height: 3rem;
  margin-bottom: 1rem;
  border-radius: 50%;
  background: color-mix(in srgb, #a8d11c 28%, #fff);
  border: none;
}

/* 施工事例カード */
.site-main--demolition .works-preview-body {
  padding: 1.5rem;
}

.site-main--demolition .works-preview-body time {
  display: block;
  margin: 0.5rem 0 0.75rem;
  font-size: 0.875rem;
  color: #8b8680;
}

.site-main--demolition .works-preview-body h3 {
  margin: 0;
}

/* お知らせ：デフォルト画像 */
.news-card__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: #fafaf7;
}

.news-card__placeholder-logo {
  width: 42%;
  max-width: 7.5rem;
  height: auto;
  opacity: 0.28;
}

/* 会社案内：会社概要パネル（company-profile-table は上記 COMPANY ブロック） */

.company-greeting-split__photo {
  max-width: 17.5rem;
}

.company-access__frame {
  min-height: 25rem;
}

/* 採用 */
.recruit-page-header__bg {
  background-position: center 35%;
}

/* お問い合わせフォーム */
.site-main--contact .wpcf7 .required,
.site-main--contact .form-row .required {
  background: #a8d11c;
  color: #1a1a1a;
}

.site-main--contact .wpcf7 input[type="submit"] {
  display: block;
  width: min(100%, 20rem);
  margin: 1rem auto 0;
  padding: 1.25rem 2.5rem;
  font-size: 1.125rem;
  background: #a8d11c;
  color: #1a1a1a;
  border: none;
  border-radius: 4px;
}

.site-main--contact .wpcf7 input[type="submit"]:hover,
.site-main--contact .wpcf7 input[type="submit"]:focus-visible {
  background: #0b4d3c;
  color: #fff;
}

.site-main--contact .contact-form-submit-note {
  margin: 0.75rem 0 0;
  text-align: center;
  font-size: 0.875rem;
  color: #8b8680;
}

.site-main--contact .wpcf7-acceptance input[type="checkbox"],
.site-main--contact .checkbox-group input[type="checkbox"] {
  accent-color: #0b4d3c;
}

/* プライバシーポリシー */
.site-main--privacy .policy-body h3 {
  margin-top: 3rem;
  margin-bottom: 1.5rem;
}

.site-main--privacy .policy-body a {
  color: #0b4d3c;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* 解体ヒーローオーバーレイ強化 */
.site-main--demolition .demolition-page-header__overlay {
  background: rgba(255, 255, 255, 0.72);
}

@media screen and (max-width: 767px) {
  .company-greeting-split__photo {
    max-width: 100%;
  }
}

/* ============================================================
   下層ページ統一デザイン（トップページは対象外）
   ============================================================ */

.site-main--service-page,
.site-main--demolition {
  --subpage-section-y: clamp(3.5rem, 8vw, 6.5rem);
  --subpage-section-y-tight: clamp(2rem, 4vw, 3rem);
  --subpage-breadcrumb-pt: clamp(0.85rem, 2vw, 1.15rem);
  --subpage-breadcrumb-pb: 0;
  --subpage-intro-gap: clamp(2rem, 4.5vw, 3rem);
  --subpage-intro-pt: var(--subpage-intro-gap);
  --subpage-intro-pb: var(--subpage-intro-gap);
  --subpage-hero-min-h: clamp(220px, 32vw, 320px);
  --subpage-hero-inner-py: clamp(2rem, 4.5vw, 3rem);
}

.site-main--service-page .service-page-header,
.site-main--service-page .demolition-page-header,
.site-main--demolition .service-page-header,
.site-main--demolition .demolition-page-header {
  min-height: var(--subpage-hero-min-h);
}

.site-main--service-page .service-page-header__inner,
.site-main--service-page .demolition-page-header__inner,
.site-main--demolition .service-page-header__inner,
.site-main--demolition .demolition-page-header__inner {
  padding-block: var(--subpage-hero-inner-py);
}

/* ヒーロー下端：フッター上部と同じブランドグラデーションライン */
.site-main--service-page .service-page-header::after,
.site-main--service-page .demolition-page-header::after,
.site-main--demolition .service-page-header::after,
.site-main--demolition .demolition-page-header::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 3px;
  background: var(--brand-gradient-line);
  pointer-events: none;
}

/* ヒーロー → パンくず → イントロの余白 */
.site-main--service-page .service-breadcrumb-wrap,
.site-main--service-page .demolition-breadcrumb-wrap,
.site-main--demolition .service-breadcrumb-wrap,
.site-main--demolition .demolition-breadcrumb-wrap {
  padding-top: var(--subpage-breadcrumb-pt);
  padding-bottom: var(--subpage-breadcrumb-pb);
}

.site-main--service-page .service-intro,
.site-main--service-page .demolition-intro,
.site-main--demolition .service-intro,
.site-main--demolition .demolition-intro {
  padding-top: var(--subpage-intro-pt);
  padding-bottom: var(--subpage-intro-pb);
}

/* イントロ直後の最初のセクションは上余白を付けない（イントロ下余白と二重にならない） */
.site-main--service-page .service-intro + .service-section,
.site-main--service-page .service-intro + .demolition-section,
.site-main--service-page .demolition-intro + .demolition-section,
.site-main--demolition .service-intro + .service-section,
.site-main--demolition .service-intro + .demolition-section,
.site-main--demolition .demolition-intro + .demolition-section {
  padding-top: 0;
}

.site-main--service-page .service-section,
.site-main--service-page .demolition-section,
.site-main--demolition .demolition-section {
  padding-block: var(--subpage-section-y);
}

/* 同色背景（--alt）が続く場合は余白を抑える（9ステップ → 施工事例など） */
.site-main--service-page .service-section--alt + .service-section--alt,
.site-main--service-page .demolition-section--alt + .demolition-section--alt,
.site-main--service-page .service-section--alt + .demolition-section--alt,
.site-main--service-page .demolition-section--alt + .service-section--alt,
.site-main--demolition .demolition-section--alt + .demolition-section--alt,
.site-main--demolition .service-section--alt + .demolition-section--alt,
.site-main--demolition .demolition-section--alt + .service-section--alt {
  padding-top: var(--subpage-section-y-tight);
}

.site-main--service-page .service-section--alt:has(+ .service-section--alt),
.site-main--service-page .service-section--alt:has(+ .demolition-section--alt),
.site-main--service-page .demolition-section--alt:has(+ .demolition-section--alt),
.site-main--service-page .demolition-section--alt:has(+ .service-section--alt),
.site-main--demolition .demolition-section--alt:has(+ .demolition-section--alt),
.site-main--demolition .demolition-section--alt:has(+ .service-section--alt),
.site-main--demolition .service-section--alt:has(+ .demolition-section--alt) {
  padding-bottom: var(--subpage-section-y-tight);
}

.site-main--service-page .section-heading-design {
  margin-bottom: clamp(2.25rem, 4.5vw, 3.25rem);
}

/* 2カラム分割（リード + 画像など） */
.subpage-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

.subpage-split__body .section-heading-design {
  margin-bottom: clamp(1.25rem, 2.5vw, 1.75rem);
}

.subpage-split__body .section-heading-design::before {
  left: 0;
  transform: none;
}

.subpage-media-placeholder,
.flow-img-placeholder {
  aspect-ratio: 4 / 3;
  background: linear-gradient(145deg, #f3f4f2 0%, #e8ece8 100%);
  border: 1.5px dashed color-mix(in srgb, var(--color-primary) 18%, var(--color-border));
  color: var(--color-muted);
}

/* カードグリッド（遠方サポート等） */
.subpage-card-grid {
  display: grid;
  gap: clamp(1.15rem, 2.5vw, 1.5rem);
}

.subpage-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: clamp(1.35rem, 2.5vw, 1.75rem);
  box-shadow: 0 1px 0 rgba(11, 77, 60, 0.04);
  transition:
    border-color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-base);
}

.subpage-card:hover {
  border-color: color-mix(in srgb, var(--color-primary) 24%, var(--color-border));
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.subpage-card h3 {
  margin: 0 0 0.75rem;
  font-size: clamp(1rem, 0.92rem + 0.35vw, 1.0625rem);
  font-weight: 700;
  line-height: 1.45;
  color: var(--color-deep-green, var(--color-primary-dark));
}

.subpage-card p {
  margin: 0;
  font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  line-height: 1.9;
  color: var(--color-text-sub);
}

.site-main--flow .flow-remote-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* 大番号タイムライン（9ステップ強調） */
.flow-timeline-section--hero .flow-timeline__number,
.site-main--service-page .flow-timeline__number {
  font-size: clamp(3rem, 2rem + 3.5vw, 4.75rem);
}

.flow-timeline-section--hero .flow-timeline__step:not(:last-child)::after {
  top: 4.5rem;
}

.site-main--service-page .flow-timeline__content h3 {
  font-size: clamp(1.0625rem, 0.95rem + 0.45vw, 1.25rem);
}

.site-main--service-page .flow-timeline__content p {
  font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  line-height: 1.95;
}

.site-main--service-page .flow-role-card,
.site-main--service-page .flow-procedures-box,
.site-main--service-page .flow-remote-card {
  border-radius: var(--radius-card);
}

.site-main--service-page .flow-role-grid,
.site-main--service-page .flow-procedures-grid,
.site-main--service-page .flow-remote-grid {
  margin-top: 0;
}

/* 空状態・404 */
.subpage-empty-state {
  max-width: 40rem;
  padding: clamp(2rem, 5vw, 3rem);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  background: var(--color-bg-offwhite, var(--color-bg-soft));
}

.subpage-empty-state--center {
  margin-inline: auto;
  text-align: center;
}

.subpage-empty-state__lead {
  margin: 0 0 0.75rem;
  font-size: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  font-weight: 700;
  line-height: 1.65;
  color: var(--color-text);
}

.subpage-empty-state__note {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--color-text-sub);
}

.error-404-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.85rem 1rem;
  margin-top: 1.75rem;
}

/* 施工事例 */
.works-archive-grid {
  gap: clamp(1.35rem, 3vw, 2rem);
}

.works-single-article__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  margin-bottom: clamp(1.25rem, 3vw, 1.75rem);
}

.works-single-article__category {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-lime, var(--color-accent)) 16%, #fff);
  color: var(--color-deep-green, var(--color-primary-dark));
  font-size: 0.8125rem;
  font-weight: 700;
}

.works-single-article__date {
  font-family: var(--font-en);
  font-size: 0.875rem;
  color: var(--color-muted, var(--color-text-sub));
}

.works-single-article__media {
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
}

.works-single-article__media .works-preview-images {
  border-radius: var(--radius-card);
  overflow: hidden;
}

.works-single-article__excerpt {
  margin: 0 0 1.25rem;
  font-size: 1.0625rem;
  line-height: 1.9;
  color: var(--color-text-sub);
}

.works-single-article__actions {
  margin-top: clamp(2rem, 4vw, 2.75rem);
}

/* 汎用ページ */
.generic-page-content__body {
  max-width: 46rem;
  margin-inline: auto;
  font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  line-height: 1.95;
  color: var(--color-text-sub);
}

.generic-page-content__body > :first-child {
  margin-top: 0;
}

.generic-page-content__body h2,
.generic-page-content__body h3 {
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  color: var(--color-text);
}

@media screen and (max-width: 1023px) {
  .subpage-split,
  .flow-lead-inner,
  .flow-role-grid,
  .flow-procedures-grid,
  .site-main--flow .flow-remote-grid {
    grid-template-columns: 1fr;
  }

  .subpage-split__media {
    order: -1;
  }

  .flow-timeline-section--hero .flow-timeline__step:not(:last-child)::after {
    top: 3.75rem;
  }
}

@media screen and (max-width: 767px) {
  .site-main--service-page,
  .site-main--demolition {
    --subpage-section-y: clamp(2.75rem, 9vw, 4rem);
    --subpage-hero-min-h: clamp(180px, 48vw, 240px);
    --subpage-hero-inner-py: clamp(1.75rem, 5vw, 2.5rem);
  }

  .flow-steps-grid {
    grid-template-columns: 1fr;
  }
}