/*
 * ======================================
 * 盛福（じょうふく）解体専門業者 — サイト固有CSS（site.css）
 * 追加クラス一覧（共通SCSS取り込み検討用）
 * ======================================
 *
 * .jf-wrap           - サイト幅ラッパー（max1200 + 可変左右余白）
 * .jf-section        - セクション間余白（clamp可変）/ --paper / --ink
 * .jf-shead          - 英小ラベル+和大見出しの左寄せセクション見出し（--center）
 * .jf-btn            - 角型CTAボタン（--sub/--white/--ghost/--lg/--arrow）
 * .jf-ph             - 写真プレースホルダ（--photo / .has-img）
 * .jf-hazard         - 黒×山吹のハザードストライプ帯
 * .jf-bar            - 2段ヘッダー（ブランド帯 + 全幅ナビ）
 * .jf-foot / .jf-fixcta - フッター / 画面端固定CTA
 * .jf-phero / .jf-crumb / .jf-lede - 下層ヒーロー / パンくず / リード文
 * .jf-hero .jf-subsidy .jf-stats .jf-greet .jf-svc .jf-area .jf-midcta .jf-feat - TOP各部
 * .jf-promise .jf-svcblock .jf-svctag .jf-flow - 事業内容ページ
 * .jf-ptable .jf-pack - 解体費用ページ
 * .jf-point .jf-risk .jf-mvis .jf-promisebox - 基礎知識ページ
 * .jf-filter .jf-works .jf-wcard .jf-pager .jf-side .jf-swidget .jf-recent - 施工実績/詳細
 * .jf-entry .jf-company .jf-cgrid .jf-cside .jf-form - 詳細/会社概要/お問い合わせ
 *
 * ======================================
 * 共通SCSSに不足していたもの（5分類）
 * ======================================
 * ・装飾パターン不足: ハザードストライプ帯 / 2段ヘッダー（ブランド帯+全幅ナビ）/
 *   斜めテクスチャ下層ヒーロー（巨大半透明EN+和タイトル）/ 画面端縦書き固定CTA
 * ・構造不足: 数字インパクト(左ノート+右2分割) / svcblock左右交互(写真フル高)/
 *   タグ行(ラベル104px+チップ) / margin-vis(中間マージン比較図) / works絞り込み+カード+pager
 * ・値の粒度不足: セクション余白 clamp(64px,9vw,130px) 等、共通の固定値と不一致のため独自定義
 * ※ 配色は scss/style.scss で共通変数を上書き済み。本ファイルは design-output の見た目を px/clamp で忠実再現する。
 */

:root {
  --c-main: #910007;
  --c-main-d: #6e0005;
  --c-main-dd: #4a0003;
  --c-sub: #EC7A00;
  --c-sub-d: #c96400;
  --c-ink: #1a1513;
  --c-ink-2: #2c2522;
  --c-base: #ffffff;
  --c-paper: #f4f1ee;
  --c-paper-2: #ece7e2;
  --c-line: #ddd6d0;
  --c-mute: #6f6760;
  --c-text: #2a2421;
  --ig: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285aeb 90%);

  --ff-jp: "Noto Sans JP", system-ui, sans-serif;
  --ff-en: "Oswald", "Noto Sans JP", sans-serif;

  --maxw: 1200px;
  --pad: clamp(20px, 5vw, 64px);
  --head-h: 112px;
  --shadow: 0 18px 50px -22px rgba(26, 21, 19, .45);
}

/* ---------- base overrides（design-output に合わせる） ---------- */
body {
  font-family: var(--ff-jp);
  color: var(--c-text);
  background: var(--c-base);
  line-height: 1.85;
  letter-spacing: .02em;
}
a { color: inherit; text-decoration: none; }
.jf-en { font-family: var(--ff-en); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
/* スマホの body 基本文字サイズ（共通CSSの 1.2rem を上書き） */
@media (max-width: 639px) { body { font-size: 1.3rem; } }

/* ---------- layout ---------- */
.jf-wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad); }
.jf-section { padding-block: clamp(64px, 9vw, 130px); }
.jf-section--paper { background: var(--c-paper); }
.jf-section--ink { background: var(--c-ink); color: #efe9e4; }
.jf-section--pb0 { padding-bottom: 0; }
.jf-section--pt-sm { padding-top: clamp(40px, 5vw, 64px); }
.jf-midcta { padding-block: clamp(48px, 6vw, 72px); }

/* ---------- section heading ---------- */
.jf-shead { display: flex; flex-direction: column; gap: 6px; margin-bottom: clamp(36px, 5vw, 64px); }
.jf-shead__en { font-family: var(--ff-en); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--c-sub); font-size: clamp(13px, 1.6vw, 15px); display: flex; align-items: center; gap: 12px; }
.jf-shead__en::before { content: ""; width: 38px; height: 2px; background: var(--c-main); display: inline-block; }
.jf-section--ink .jf-shead__en::before { background: var(--c-sub); }
.jf-shead__ttl { font-weight: 900; font-size: clamp(26px, 4vw, 44px); line-height: 1.3; letter-spacing: .01em; color: var(--c-ink); }
.jf-section--ink .jf-shead__ttl { color: #fff; }
.jf-shead__ttl b { color: var(--c-main); }
.jf-section--ink .jf-shead__ttl b { color: var(--c-sub); }
.jf-shead--center { align-items: center; text-align: center; }
.jf-shead--center .jf-shead__en::before { display: none; }

/* ---------- buttons ---------- */
.jf-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  font-family: var(--ff-jp); font-weight: 700; font-size: 16px;
  padding: 18px 34px; border: 0; cursor: pointer; position: relative;
  transition: transform .25s ease, background .25s ease, color .25s ease;
  letter-spacing: .04em; color: #fff; background: var(--c-main);
}
.jf-btn i { font-size: 16px; }
.jf-btn:hover { background: var(--c-main-d); transform: translateY(-2px); }
.jf-btn--sub { background: var(--c-sub); }
.jf-btn--sub:hover { background: var(--c-sub-d); }
.jf-btn--white { background: #fff; color: var(--c-main); }
.jf-btn--white:hover { background: #fff; }
.jf-btn--ghost { background: transparent; color: var(--c-ink); border: 1.5px solid var(--c-ink); }
.jf-btn--ghost:hover { background: var(--c-ink); color: #fff; }
.jf-btn--lg { padding: 22px 48px; font-size: 17px; }
.jf-btn--arrow::after { content: "→"; font-family: var(--ff-en); font-weight: 700; }

/* ---------- photo placeholder ---------- */
.jf-ph {
  position: relative; overflow: hidden; background: var(--c-ink);
  background-image: linear-gradient(135deg, rgba(255,255,255,.04) 0 25%, transparent 25% 50%, rgba(255,255,255,.04) 50% 75%, transparent 75%);
  background-size: 28px 28px;
  display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.5);
}
.jf-ph::after { content: attr(data-label); font-family: var(--ff-en); font-size: 14px; letter-spacing: .14em; text-transform: uppercase; border: 1px solid rgba(255,255,255,.25); padding: 7px 14px; }
.jf-ph--photo { background: linear-gradient(135deg, #2a2421, #15110f); }
.jf-ph > img { width: 100%; height: 100%; object-fit: cover; display: block; }
.jf-ph.has-img { background: #15110f; }
.jf-ph.has-img::after { display: none; }

/* ---------- hazard stripe ---------- */
.jf-hazard { height: 8px; background: repeating-linear-gradient(45deg, var(--c-ink) 0 16px, var(--c-sub) 16px 32px); }

/* ---------- lede ---------- */
.jf-lede { font-size: clamp(15px, 1.9vw, 18px); line-height: 2.1; max-width: 860px; }
.jf-lede--full { max-width: none; }
.jf-lede b { color: var(--c-main); }
.jf-mb-40 { margin-bottom: 40px; }
.jf-mb-48 { margin-bottom: 48px; }
.jf-mb-lg { margin-bottom: clamp(48px, 6vw, 72px); }

/* =========================================================
   HEADER（2段：ブランド帯 + 全幅ナビ）
   ========================================================= */
.jf-bar { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.97); backdrop-filter: blur(6px); border-bottom: 1px solid var(--c-line); }
.jf-bar__top { display: flex; align-items: stretch; justify-content: space-between; }
.jf-brand { display: flex; align-items: center; gap: 20px; padding: 5px 0; }
.jf-brand__img { height: 95px; width: auto; display: block; }
.jf-brand__desc { display: flex; flex-direction: column; gap: 5px; padding-left: 20px; border-left: 1px solid var(--c-line); }
.jf-brand__desc b { font-weight: 900; font-size: 17px; color: var(--c-ink); letter-spacing: .1em; line-height: 1.2; }
.jf-brand__desc small { font-size: 11.5px; color: var(--c-mute); letter-spacing: .06em; }

.jf-bar__util { display: flex; align-items: stretch; }
.jf-util-info { display: flex; flex-direction: column; justify-content: center; padding: 0 22px; text-align: right; border-left: 1px solid var(--c-line); }
.jf-util-info__label { font-size: 10px; color: var(--c-mute); letter-spacing: .16em; }
.jf-util-info__tel { font-family: var(--ff-en); font-weight: 700; font-size: 24px; color: var(--c-main); letter-spacing: .02em; line-height: 1.1; white-space: nowrap; }
.jf-util-info__hours { font-size: 11px; color: var(--c-mute); }
.jf-util-sns { align-self: center; width: 46px; height: 46px; border-radius: 50%; margin: 0 18px; display: grid; place-items: center; background: var(--ig); color: #fff; transition: filter .2s, transform .2s; }
.jf-util-sns:hover { filter: brightness(1.08) saturate(1.1); transform: translateY(-1px); }
.jf-util-sns i { font-size: 19px; }
.jf-util-cta { align-self: center; display: flex; align-items: flex-start; gap: 9px; margin-left: 14px; padding: 16px 28px; background: var(--c-sub); color: #fff; font-weight: 700; transition: background .2s, transform .2s; }
.jf-util-cta:hover { background: var(--c-sub-d); transform: translateY(-1px); }
.jf-util-cta i { font-size: 18px; margin-top: 2px; }
.jf-util-cta small { display: block; font-size: 10px; letter-spacing: .1em; opacity: .85; font-weight: 400; }

.jf-nav { border-top: 1px solid var(--c-line); }
.jf-nav__list { display: flex; }
.jf-nav__list li { flex: 1; }
.jf-nav__list a { display: flex; align-items: center; justify-content: center; padding: 16px 6px; font-weight: 700; font-size: 15px; color: var(--c-ink); position: relative; transition: color .2s; }
.jf-nav__list a:hover, .jf-nav__list a[aria-current="page"] { color: var(--c-main); }

.jf-burger { display: none; background: var(--c-ink); color: #fff; border: 0; width: 64px; cursor: pointer; flex-direction: column; align-items: center; justify-content: center; gap: 5px; }
.jf-burger span { width: 26px; height: 2px; background: #fff; transition: .25s; }
.jf-burger__txt { font-family: var(--ff-en); font-size: 9px; letter-spacing: .1em; }

/* =========================================================
   FOOTER
   ========================================================= */
.jf-foot { background: var(--c-ink); color: #ccc4bd; }
.jf-foot__cta { background: var(--c-main); color: #fff; }
.jf-foot__cta-inner { display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: center; padding-block: clamp(40px, 6vw, 64px); }
.jf-foot__cta h2 { font-size: clamp(24px, 3.4vw, 38px); font-weight: 900; line-height: 1.35; }
.jf-foot__cta h2 .jf-en { display: block; font-size: 14px; color: rgba(255,255,255,.7); margin-bottom: 6px; }
.jf-foot__cta-btns { display: flex; flex-direction: column; gap: 14px; min-width: 320px; }
.jf-foot__tel-big { display: flex; align-items: baseline; gap: 12px; background: #fff; color: var(--c-main); padding: 14px 26px; }
.jf-foot__tel-big .jf-en { font-size: 32px; font-weight: 700; white-space: nowrap; }
.jf-foot__tel-big small { font-size: 12px; color: var(--c-ink); }

.jf-foot__main { display: grid; grid-template-columns: .6fr 1fr 1.3fr; gap: 48px; padding-block: clamp(48px, 6vw, 72px); }
.jf-foot__map { background: #fff; aspect-ratio: 16/10; }
.jf-foot__map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(.3); }
.jf-foot-logo { display: inline-flex; margin-bottom: 18px; }
.jf-foot-logo img { height: 140px; width: auto; display: block; }
.jf-foot-info { font-size: 14px; line-height: 2; }
.jf-foot-info dt { color: var(--c-sub); font-family: var(--ff-en); font-size: 11px; letter-spacing: .1em; margin-top: 12px; }
.jf-foot__sns { display: flex; gap: 12px; margin-top: 20px; width: 127px; justify-content: center; }
.jf-foot__sns a { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; border: 0; background: var(--ig); color: #fff; transition: filter .2s, transform .2s; }
.jf-foot__sns a:hover { filter: brightness(1.08) saturate(1.1); transform: translateY(-2px); }
.jf-foot__sns i { font-size: 18px; }
.jf-foot__copy { border-top: 1px solid rgba(255,255,255,.12); padding-block: 22px; font-size: 12px; color: #8d847d; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.jf-foot__copy .jf-en { letter-spacing: .12em; }

/* fixed side CTA */
.jf-fixcta { position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 90; display: flex; flex-direction: column; gap: 2px; }
.jf-fixcta a { writing-mode: vertical-rl; padding: 22px 12px; font-weight: 700; font-size: 15px; letter-spacing: .12em; display: flex; align-items: center; gap: 10px; transition: padding .2s; color: #fff; }
.jf-fixcta a i { font-size: 17px; display: inline-block; writing-mode: horizontal-tb; }
.jf-fixcta__estimate { background: var(--c-sub); }
.jf-fixcta__estimate:hover { background: var(--c-sub-d); }
.jf-fixcta__tel { background: var(--c-main); }

/* =========================================================
   PAGE HERO（下層）+ breadcrumb
   ========================================================= */
.jf-phero { position: relative; background: var(--c-ink); color: #fff; overflow: hidden; }
/* 写真レイヤー（style="background-image:url(...)" を要素に付与）。写真未指定時は暗いグラデーション */
.jf-phero__bg { position: absolute; inset: 0; background: linear-gradient(135deg, #2a2421, #15110f) center/cover no-repeat; background-color: var(--c-ink); }
/* 暗幕オーバーレイ（白文字・巨大半透明ENの可読性を確保） */
.jf-phero__bg::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(20,15,13,.92) 0%, rgba(20,15,13,.78) 48%, rgba(20,15,13,.58) 100%); }
/* 山吹の斜めテクスチャ（最前面・微弱） */
.jf-phero__bg::after { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent 0 38px, rgba(236,122,0,.06) 38px 40px); }
.jf-phero__inner { position: relative; padding-block: clamp(40px, 6vw, 80px); }
.jf-phero__en { font-family: var(--ff-en); font-size: clamp(40px, 8vw, 92px); color: rgba(255,255,255,.2); line-height: .9; letter-spacing: .02em; }
.jf-phero__ttl { font-size: clamp(28px, 5vw, 50px); font-weight: 900; margin-top: -.4em; }

.jf-crumb { background: var(--c-paper); border-bottom: 1px solid var(--c-line); }
.jf-crumb ol { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; padding-block: 12px; font-size: 12px; color: var(--c-mute); }
.jf-crumb a:hover { color: var(--c-main); }
.jf-crumb li:not(:last-child)::after { content: "/"; margin-left: 8px; color: var(--c-line); }

/* =========================================================
   TOP — hero
   ========================================================= */
.jf-hero { position: relative; color: #fff; overflow: hidden; background: var(--c-ink); }
/* 背景スライド層（静的画像 / CMSスライダー共通の土台）。前面コンテンツの下に敷く */
.jf-hero__slides { position: absolute; inset: 0; z-index: 0; }
.jf-hero__slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.1s ease; }
.jf-hero__slide.is-active { opacity: 1; }
.jf-hero__slide-bg { position: absolute; inset: 0; }
.jf-hero__slide-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(20,15,13,.55) 0%, rgba(20,15,13,.32) 45%, rgba(20,15,13,.06) 100%); }
.jf-bg-1 { background: #15110f url("https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28281/hero.jpg") center/cover no-repeat; }
/* CMSメインビュースライダー差し替え時の背景層（#slideshow）。CMSが .swiper-slide を出力 */
.jf-hero__cms-bg { position: absolute; inset: 0; z-index: 0; min-height: clamp(520px, 84vh, 820px); }
.jf-hero__cms-bg .swiper, .jf-hero__cms-bg .swiper-slide { height: 100%; }
.jf-hero__cms-bg img { width: 100%; height: 100%; object-fit: cover; }
.jf-hero__cms-bg::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(90deg, rgba(20,15,13,.55) 0%, rgba(20,15,13,.32) 45%, rgba(20,15,13,.06) 100%); }
.jf-hero__content { position: relative; z-index: 2; display: flex; align-items: center; min-height: clamp(520px, 84vh, 820px); }
.jf-hero__inner { padding-block: 60px; max-width: 820px; }
.jf-hero__kicker { display: inline-flex; align-items: center; gap: 12px; font-family: var(--ff-en); font-size: 14px; letter-spacing: .14em; color: var(--c-sub); margin-bottom: 22px; text-transform: uppercase; text-shadow: 0 2px 8px rgba(0,0,0,.5); }
.jf-hero__kicker::before { content: ""; width: 46px; height: 2px; background: var(--c-sub); }
.jf-hero__ttl { font-size: clamp(32px, 6.2vw, 65px); font-weight: 900; line-height: 1.22; letter-spacing: .01em; text-shadow: 0 2px 14px rgba(0,0,0,.65), 0 6px 30px rgba(0,0,0,.5); }
.jf-hero__ttl em { font-style: normal; color: var(--c-sub); }
.jf-hero__lead { margin-top: 24px; font-size: clamp(14px, 1.9vw, 18px); line-height: 2; max-width: 560px; color: #f0e8e2; text-shadow: 0 2px 10px rgba(0,0,0,.65); }
.jf-hero__actions { margin-top: 34px; display: flex; gap: 16px; flex-wrap: wrap; }
.jf-hero__dots { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 5; display: flex; gap: 12px; }
.jf-hero__dots button { width: 40px; height: 4px; background: rgba(255,255,255,.35); border: 0; cursor: pointer; transition: background .2s; padding: 0; }
.jf-hero__dots button.is-active { background: var(--c-sub); }

/* subsidy strip */
.jf-subsidy { background: var(--c-sub); color: #fff; position: relative; z-index: 6; }
.jf-subsidy__inner { display: flex; align-items: center; justify-content: center; gap: 18px; padding: 16px 20px; flex-wrap: wrap; text-align: center; }
.jf-subsidy__inner b { font-weight: 900; font-size: clamp(15px, 2vw, 20px); }
.jf-subsidy__inner .jf-en { background: #fff; color: var(--c-sub); padding: 4px 12px; font-size: 12px; }
.jf-subsidy__inner a { text-decoration: underline; font-weight: 700; }

/* stats */
.jf-stats { background: var(--c-ink); color: #fff; }
.jf-stats__inner { display: grid; grid-template-columns: auto 1fr 1fr; gap: 0; align-items: stretch; }
.jf-stats__note { display: flex; flex-direction: column; justify-content: center; padding: 40px 44px 40px 0; max-width: 280px; }
.jf-stats__note .jf-en { color: var(--c-sub); font-size: 14px; }
.jf-stats__note b { font-size: 22px; font-weight: 900; line-height: 1.4; }
.jf-stats__note small { color: #9a918a; font-size: 12px; margin-top: 8px; }
.jf-stat { padding: 44px 36px; border-left: 1px solid rgba(255,255,255,.14); display: flex; flex-direction: column; justify-content: center; }
.jf-stat__label { color: var(--c-sub); font-family: var(--ff-en); font-size: 14px; letter-spacing: .12em; }
.jf-stat__num { font-family: var(--ff-en); font-weight: 700; font-size: clamp(48px, 8vw, 88px); line-height: 1; letter-spacing: .01em; }
.jf-stat__num span { font-size: .42em; margin-left: 6px; color: #cfc7c0; }
.jf-stat__sub { color: #cabfb8; font-size: 14px; margin-top: 6px; }

/* greeting */
.jf-greet { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
.jf-greet__photo { aspect-ratio: 4/5; }
.jf-greet__body p { margin-bottom: 1.4em; }
.jf-greet__sign { margin-top: 8px; display: flex; align-items: baseline; gap: 14px; border-top: 2px solid var(--c-ink); padding-top: 20px; }
.jf-greet__sign small { color: var(--c-mute); font-size: 14px; }
.jf-greet__sign b { font-size: 22px; font-weight: 900; color: var(--c-ink); }

/* services grid (TOP) */
.jf-svc { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2px; background: var(--c-line); }
.jf-svc__card { background: #fff; padding: clamp(26px, 3vw, 40px); display: grid; grid-template-columns: auto 1fr auto; gap: 22px; align-items: center; position: relative; transition: background .25s; }
.jf-svc__card:hover { background: var(--c-paper); }
.jf-svc__no { font-family: var(--ff-en); font-weight: 700; font-size: 40px; color: var(--c-paper-2); line-height: 1; }
.jf-svc__card:hover .jf-svc__no { color: var(--c-sub); }
.jf-svc__body h3 { font-size: clamp(17px, 2.2vw, 21px); font-weight: 900; color: var(--c-ink); }
.jf-svc__body p { font-size: 14px; color: var(--c-mute); margin-top: 4px; }
.jf-svc__arrow { width: 44px; height: 44px; border: 1.5px solid var(--c-line); display: grid; place-items: center; color: var(--c-main); transition: .25s; }
.jf-svc__card:hover .jf-svc__arrow { background: var(--c-main); border-color: var(--c-main); color: #fff; }
.jf-svc__arrow i { font-size: 17px; }

/* area */
.jf-area { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px, 4vw, 60px); align-items: center; }
.jf-area__map { display: flex; align-items: center; justify-content: center; }
.jf-area__map img { max-width: 100%; max-height: 540px; width: auto; height: auto; }
.jf-area__cities { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }
.jf-area__cities span { font-size: 14px; padding: 7px 14px; background: #fff; border: 1px solid var(--c-line); color: var(--c-text); }
.jf-area__big { font-family: var(--ff-en); font-weight: 700; font-size: clamp(40px, 6vw, 64px); color: var(--c-main); line-height: 1; }
.jf-area__lead { margin-top: 12px; max-width: 480px; }

/* mid CTA */
.jf-midcta__inner { display: flex; align-items: center; justify-content: space-between; gap: 28px; flex-wrap: wrap; }
.jf-midcta__lead .jf-en { color: var(--c-sub); font-size: 14px; }
.jf-midcta__lead h2 { font-size: clamp(22px, 3.2vw, 34px); font-weight: 900; line-height: 1.4; }
.jf-midcta__btns { display: flex; gap: 14px; flex-wrap: wrap; }

/* split CTA (price + works) */
.jf-feat { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: var(--c-ink); }
.jf-feat__card { position: relative; overflow: hidden; min-height: 380px; display: flex; align-items: flex-end; color: #fff; }
.jf-feat__bg { position: absolute; inset: 0; transition: transform .6s ease; background-size: cover; background-position: center; }
.jf-feat__card:hover .jf-feat__bg { transform: scale(1.06); }
.jf-feat__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(20,15,13,.92), rgba(20,15,13,.3) 70%); }
.jf-feat__inner { position: relative; z-index: 2; padding: clamp(32px, 4vw, 52px); width: 100%; }
.jf-feat__en { font-family: var(--ff-en); font-size: 14px; letter-spacing: .14em; color: var(--c-sub); text-transform: uppercase; }
.jf-feat__card h3 { font-size: clamp(22px, 3vw, 30px); font-weight: 900; margin: 6px 0 12px; }
.jf-feat__card p { font-size: 14px; color: #d8cfc8; line-height: 1.9; max-width: 480px; }
.jf-feat__card .jf-btn { margin-top: 22px; }

/* =========================================================
   SERVICE page
   ========================================================= */
.jf-promise { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; background: var(--c-line); margin-top: 60px; }
.jf-promise__card { background: #fff; padding: clamp(28px,3vw,40px); }
.jf-promise__icon { width: 60px; height: 60px; display: grid; place-items: center; background: var(--c-main); color: #fff; margin-bottom: 20px; }
.jf-promise__icon i { font-size: 26px; }
.jf-promise__no { font-family: var(--ff-en); font-weight: 700; font-size: 15px; color: var(--c-sub); letter-spacing: .1em; }
.jf-promise__card h3 { font-size: clamp(18px,2.3vw,22px); font-weight: 900; color: var(--c-ink); margin: 10px 0 12px; padding-bottom: 12px; border-bottom: 2px solid var(--c-main); }
.jf-promise__card p { font-size: 14px; color: var(--c-text); }

.jf-svcblock { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-top: 2px; }
.jf-svcblock:nth-child(even) .jf-svcblock__photo { order: 2; }
.jf-svcblock__photo { min-height: 100%; overflow: hidden; }
.jf-svcblock__body { background: #fff; padding: clamp(32px,4vw,60px); display: flex; flex-direction: column; justify-content: center; }
.jf-svcblock__no { font-family: var(--ff-en); font-weight: 700; font-size: 64px; line-height: 1; color: var(--c-paper-2); }
.jf-svcblock__body h3 { font-size: clamp(21px,2.8vw,28px); font-weight: 900; color: var(--c-ink); margin: 8px 0 4px; }
.jf-svcblock__catch { color: var(--c-main); font-weight: 700; font-size: 15px; margin-bottom: 16px; }
.jf-svcblock__body p { font-size: 14.5px; }
.jf-svctags { margin-top: 24px; display: grid; gap: 14px; }
.jf-svctag { display: grid; grid-template-columns: 104px 1fr; gap: 16px; align-items: start; }
.jf-svctag__label { display: flex; align-items: center; justify-content: center; gap: 7px; font-size: 12px; font-weight: 700; letter-spacing: .06em; color: #fff; padding: 9px 6px; line-height: 1.2; }
.jf-svctag__label i { font-size: 13px; flex: none; }
.jf-svctag__label--case { background: var(--c-ink); }
.jf-svctag__label--target { background: var(--c-main); }
.jf-svctag__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.jf-svctag__chips .jf-chip { background: #fff; border: 1px solid var(--c-line); border-left: 3px solid var(--c-sub); padding: 7px 13px; font-size: 14px; color: var(--c-text); }
.jf-svctag__target { background: var(--c-paper); border-left: 3px solid var(--c-main); padding: 12px 16px; display: grid; gap: 8px; }
.jf-svctag__target .jf-ck { position: relative; padding-left: 22px; font-size: 13.5px; line-height: 1.7; color: var(--c-text); }
.jf-svctag__target .jf-ck::before { content: "\2713"; position: absolute; left: 0; top: 0; color: var(--c-main); font-weight: 900; }

.jf-flow { counter-reset: f; max-width: 880px; margin-inline: auto; }
.jf-flow__step { display: grid; grid-template-columns: auto 1fr; gap: 26px; padding-bottom: 36px; position: relative; }
.jf-flow__step::before { counter-increment: f; content: counter(f,decimal-leading-zero); font-family: var(--ff-en); font-weight: 700; font-size: 22px; color: #fff; background: var(--c-main); width: 56px; height: 56px; display: grid; place-items: center; flex: none; z-index: 2; }
.jf-flow__step:not(:last-child)::after { content: ""; position: absolute; left: 27px; top: 56px; bottom: -4px; width: 2px; background: var(--c-line); }
.jf-flow__step h3 { font-size: clamp(17px,2.2vw,20px); font-weight: 900; color: var(--c-ink); margin-bottom: 4px; }
.jf-flow__step p { font-size: 14px; }
.jf-flow__step .jf-free { display: inline-block; background: var(--c-sub); color: #fff; font-size: 11px; padding: 2px 9px; margin-left: 8px; vertical-align: middle; }

/* =========================================================
   PRICE page
   ========================================================= */
.jf-ptable { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--c-line); }
.jf-ptable th, .jf-ptable td { padding: 18px 22px; text-align: left; border-bottom: 1px solid var(--c-line); }
.jf-ptable thead th { background: var(--c-ink); color: #fff; font-weight: 700; font-size: 14px; letter-spacing: .05em; }
.jf-ptable tbody th { font-weight: 700; color: var(--c-ink); width: 38%; }
.jf-ptable .jf-price { font-family: var(--ff-en); font-weight: 700; font-size: clamp(20px,3vw,26px); color: var(--c-main); }
.jf-ptable .jf-price small { font-size: 14px; color: var(--c-text); font-family: var(--ff-jp); font-weight: 400; }
.jf-ptable tbody tr:hover { background: var(--c-paper); }
.jf-tnote { font-size: 12.5px; color: var(--c-mute); margin-top: 12px; }
.jf-tcap { font-weight: 900; color: var(--c-ink); font-size: clamp(17px,2.3vw,21px); margin: 0 0 16px; padding-left: 16px; border-left: 4px solid var(--c-main); }
.jf-scroll-x { overflow-x: auto; }

.jf-pack { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.jf-pack__card { background: #fff; border: 1px solid var(--c-line); border-top: 6px solid var(--c-main); padding: 32px 28px; display: flex; flex-direction: column; }
.jf-pack__card.is-rc { border-top-color: var(--c-sub); }
.jf-pack__tag { font-family: var(--ff-en); font-size: 12px; letter-spacing: .12em; color: var(--c-mute); }
.jf-pack__card h3 { font-size: 22px; font-weight: 900; color: var(--c-ink); margin: 4px 0 18px; }
.jf-pack__price { font-family: var(--ff-en); font-weight: 700; color: var(--c-main); line-height: 1; font-size: clamp(40px,6vw,52px); }
.jf-pack__card.is-rc .jf-pack__price { color: var(--c-sub-d); }
.jf-pack__price span { font-size: .42em; font-family: var(--ff-jp); color: var(--c-text); margin-left: 4px; }
.jf-pack__incl { display: inline-block; background: var(--c-paper); padding: 6px 14px; font-size: 14px; font-weight: 700; margin: 16px 0; align-self: flex-start; }
.jf-pack__note { font-size: 12.5px; color: var(--c-mute); margin-top: auto; }

/* =========================================================
   GUIDE page
   ========================================================= */
.jf-point { display: grid; grid-template-columns: auto 1fr; gap: clamp(20px,3vw,40px); margin-bottom: clamp(44px,6vw,72px); align-items: start; }
.jf-point__num { font-family: var(--ff-en); font-weight: 700; line-height: .9; }
.jf-point__num .jf-lbl { display: block; font-size: 14px; letter-spacing: .14em; color: var(--c-sub); }
.jf-point__num .jf-big { display: block; font-size: clamp(56px,9vw,104px); color: var(--c-main); }
.jf-point__body h2 { font-size: clamp(20px,2.8vw,28px); font-weight: 900; color: var(--c-ink); line-height: 1.4; margin-bottom: 16px; padding-bottom: 14px; border-bottom: 2px solid var(--c-line); }
.jf-point__body p { font-size: 15px; margin-bottom: 1.2em; }
.jf-risk { background: var(--c-paper); border-left: 4px solid var(--c-main); padding: 22px 26px; margin: 8px 0 20px; }
.jf-risk li { font-size: 14.5px; padding-left: 26px; position: relative; margin-bottom: 10px; }
.jf-risk li:last-child { margin-bottom: 0; }
.jf-risk li::before { content: "!"; position: absolute; left: 0; top: 1px; width: 18px; height: 18px; background: var(--c-main); color: #fff; font-family: var(--ff-en); font-size: 12px; display: grid; place-items: center; border-radius: 50%; }
.jf-mvis { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: stretch; margin: 8px 0 20px; }
.jf-mvis__col { background: #fff; border: 1px solid var(--c-line); padding: 22px; text-align: center; }
.jf-mvis__col h4 { font-size: 14px; font-weight: 900; color: var(--c-ink); margin-bottom: 12px; }
.jf-mvis__bar { height: 130px; display: flex; flex-direction: column-reverse; border: 1px solid var(--c-line); }
.jf-mvis__base { background: var(--c-main); flex: 1; display: grid; place-items: center; color: #fff; font-size: 12px; font-weight: 700; }
.jf-mvis__fee { background: repeating-linear-gradient(45deg, var(--c-sub) 0 8px, var(--c-sub-d) 8px 16px); height: 30%; display: grid; place-items: center; color: #fff; font-size: 11px; font-weight: 700; }
.jf-mvis__arrow { display: grid; place-items: center; font-family: var(--ff-en); font-weight: 700; color: var(--c-main); }
.jf-mvis__note { font-size: 12px; color: var(--c-mute); margin-top: 8px; }
.jf-promisebox { background: var(--c-ink); color: #efe9e4; padding: clamp(32px,5vw,56px); }
.jf-promisebox h2 { color: #fff; font-size: clamp(20px,2.8vw,28px); font-weight: 900; margin-bottom: 18px; }
.jf-promisebox h2 .jf-en { display: block; color: var(--c-sub); font-size: 14px; margin-bottom: 8px; }
.jf-promisebox p { font-size: 15px; margin-bottom: 1.2em; }

/* =========================================================
   WORKS list + entry
   ========================================================= */
.jf-cms { display: block; }
.jf-cms--sidebar { display: grid; grid-template-columns: 1fr 300px; gap: clamp(32px,4vw,56px); align-items: start; }
.jf-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 30px; }
.jf-filter button, .jf-filter a { font-family: var(--ff-jp); font-size: 14px; font-weight: 700; padding: 9px 18px; border: 1px solid var(--c-line); background: #fff; color: var(--c-text); cursor: pointer; transition: .2s; display: inline-block; text-decoration: none; line-height: 1.2; }
.jf-filter button.is-active, .jf-filter button:hover, .jf-filter a.is-active, .jf-filter a:hover { background: var(--c-main); border-color: var(--c-main); color: #fff; }
.jf-works { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
/* CMS出力の記事を .jf-works のグリッド子要素として整列させる（span自身はレイアウトから除外） */
.jf-works > [id^="cms-blog-entry-list-"] { display: contents; }
/* カテゴリ別一覧パネル：タブで表示切替（JSで is-active を付与・リロードなし） */
.jf-cat-panel { display: none; }
.jf-cat-panel.is-active { display: grid; }
.jf-wcard { background: #fff; border: 1px solid var(--c-line); display: flex; flex-direction: column; transition: .25s; }
.jf-wcard:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.jf-wcard__thumb { aspect-ratio: 16/10; position: relative; }
/* サムネ左上のカテゴリラベル（CMS出力 .category_tag）。背景はサイトの赤（--c-main）で統一 */
.jf-wcard__thumb .category_tag { position: absolute; top: 0; left: 0; background: var(--c-main); color: #fff; font-size: 12px; font-weight: 700; line-height: 1.4; padding: 5px 14px; z-index: 2; }
.jf-wcard__body { padding: 20px 22px; display: flex; flex-direction: column; flex: 1; }
.jf-wcard__date { font-family: var(--ff-en); font-size: 12px; color: var(--c-mute); letter-spacing: .08em; }
.jf-wcard__ttl { font-size: 16.5px; font-weight: 900; color: var(--c-ink); line-height: 1.5; margin: 6px 0 0; }
.jf-pager { display: flex; gap: 8px; justify-content: center; margin-top: 48px; }
.jf-pager a { width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid var(--c-line); font-family: var(--ff-en); font-weight: 600; background: #fff; transition: .2s; cursor: pointer; }
.jf-pager a:hover, .jf-pager a.is-active { background: var(--c-main); border-color: var(--c-main); color: #fff; }

.jf-side { display: grid; gap: 28px; position: sticky; top: 130px; }
.jf-swidget { border: 1px solid var(--c-line); background: #fff; }
.jf-swidget h3 { font-size: 14px; font-weight: 900; color: #fff; background: var(--c-ink); padding: 14px 18px; letter-spacing: .04em; display: flex; align-items: center; gap: 8px; }
.jf-swidget h3 .jf-en { color: var(--c-sub); font-size: 11px; }
.jf-swidget ul { padding: 8px 18px 14px; }
.jf-swidget li a { display: flex; justify-content: space-between; align-items: center; padding: 11px 0; font-size: 13.5px; border-bottom: 1px solid var(--c-line); transition: color .2s; }
.jf-swidget li:last-child a { border-bottom: 0; }
.jf-swidget li a:hover { color: var(--c-main); }
.jf-swidget li a span { font-family: var(--ff-en); font-size: 12px; color: var(--c-mute); }
.jf-recent a { display: grid; grid-template-columns: 64px 1fr; gap: 12px; align-items: center; padding: 12px 18px; border-bottom: 1px solid var(--c-line); }
.jf-recent a:last-child { border-bottom: 0; }
.jf-recent__th { aspect-ratio: 1; }
.jf-recent b { font-size: 14px; font-weight: 700; color: var(--c-ink); line-height: 1.5; display: block; }
.jf-recent small { font-family: var(--ff-en); font-size: 11px; color: var(--c-mute); }
.jf-side-cta { background: var(--c-main); color: #fff; padding: 26px 22px; text-align: center; }
.jf-side-cta b { font-size: 17px; font-weight: 900; display: block; margin-bottom: 14px; }
.jf-side-cta .jf-btn { width: 100%; }

/* entry detail */
.jf-entry__meta { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.jf-entry__cat { background: var(--c-main); color: #fff; font-size: 12px; font-weight: 700; padding: 5px 14px; }
.jf-entry__date { font-family: var(--ff-en); font-size: 14px; color: var(--c-mute); letter-spacing: .08em; }
.jf-entry__ttl { font-size: clamp(24px,3.4vw,36px); font-weight: 900; color: var(--c-ink); line-height: 1.4; margin-bottom: 24px; }
.jf-entry__hero { aspect-ratio: 16/9; margin-bottom: 32px; }
.jf-entry__body h2 { font-size: clamp(19px,2.5vw,24px); font-weight: 900; color: var(--c-ink); margin: 40px 0 16px; padding-left: 16px; border-left: 4px solid var(--c-main); }
.jf-entry__body p { font-size: 15px; margin-bottom: 1.3em; }
.jf-entry__spec { width: 100%; border-collapse: collapse; border: 1px solid var(--c-line); margin: 8px 0 24px; }
.jf-entry__spec th, .jf-entry__spec td { padding: 13px 18px; border-bottom: 1px solid var(--c-line); text-align: left; font-size: 14px; }
.jf-entry__spec th { background: var(--c-paper); width: 32%; font-weight: 700; color: var(--c-ink); }
.jf-entry__ba { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 8px 0 24px; }
.jf-entry__ba figure { margin: 0; }
.jf-entry__ba .jf-ph { aspect-ratio: 4/3; }
.jf-entry__ba figcaption { font-family: var(--ff-en); font-size: 12px; letter-spacing: .1em; color: var(--c-mute); margin-top: 8px; }
.jf-entry__nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--c-line); font-size: 14px; }
.jf-entry__nav a { font-weight: 700; color: var(--c-main); }
.jf-entry__back { margin-top: 40px; padding-top: 28px; border-top: 1px solid var(--c-line); text-align: center; }

/* =========================================================
   CONTACT / COMPANY
   ========================================================= */
.jf-company { width: 100%; border-collapse: collapse; border-top: 2px solid var(--c-ink); }
.jf-company th, .jf-company td { padding: 20px 24px; text-align: left; border-bottom: 1px solid var(--c-line); font-size: 15px; vertical-align: top; }
.jf-company th { width: 26%; font-weight: 700; color: var(--c-ink); background: var(--c-paper); }
.jf-cgrid { display: grid; grid-template-columns: .65fr 1.35fr; gap: clamp(36px,5vw,64px); align-items: start; }
.jf-cside-img { aspect-ratio: 16/10; margin-bottom: 24px; }
.jf-cside .jf-tel-card { background: var(--c-ink); color: #fff; padding: 30px; margin-bottom: 24px; }
.jf-cside .jf-tel-card .jf-en { color: var(--c-sub); font-size: 14px; }
.jf-cside .jf-tel-card b { font-family: var(--ff-en); font-weight: 700; font-size: clamp(30px,5vw,42px); display: block; line-height: 1.1; margin: 4px 0; }
.jf-cside .jf-tel-card small { color: #cabfb8; font-size: 14px; }
.jf-cside .jf-map-card { aspect-ratio: 4/3; background:#fff; border:1px solid var(--c-line); }
.jf-cside .jf-map-card iframe { width:100%; height:100%; border:0; }
.jf-form { display: grid; gap: 20px; }
.jf-form .jf-field { display: grid; gap: 8px; }
.jf-form label { font-size: 14px; font-weight: 700; color: var(--c-ink); display: flex; align-items: center; gap: 8px; }
.jf-form .jf-req { background: var(--c-main); color: #fff; font-size: 10px; padding: 2px 7px; font-weight: 700; }
.jf-form .jf-opt { background: var(--c-paper-2); color: var(--c-mute); font-size: 10px; padding: 2px 7px; }
.jf-form input, .jf-form select, .jf-form textarea { font-family: var(--ff-jp); font-size: 15px; padding: 13px 15px; border: 1px solid var(--c-line); background: #fff; width: 100%; transition: border .2s; }
.jf-form input:focus, .jf-form select:focus, .jf-form textarea:focus { outline: none; border-color: var(--c-main); }
.jf-form .jf-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.jf-form .jf-check { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--c-text); font-weight: 400; }
.jf-form .jf-check input { width: auto; margin-top: 4px; }
.jf-form .jf-submit { display: flex; justify-content: center; margin-top: 6px; }
.jf-form .jf-submit .jf-btn { min-width: 280px; }
.jf-formnote { font-size: 14px; color: var(--c-mute); background: var(--c-paper); padding: 16px 20px; border-left: 3px solid var(--c-sub); }

/* =========================================================
   reveal on scroll
   ========================================================= */
.reveal { transition: opacity .7s ease, transform .7s ease; }
.js-reveal .reveal { opacity: 0; transform: translateY(28px); }
.js-reveal .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .js-reveal .reveal { opacity: 1; transform: none; transition: none; } }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1100px) {
  .jf-side { position: static; }
}
@media (max-width: 980px) {
  :root { --head-h: 64px; }
  /* ハンバーガー表示時はヘッダー（白背景・ロゴ）を追従させない（sticky解除・通常スクロール）。
     backdrop-filter は fixed子要素(ハンバーガー/ナビ)の包含ブロックを作ってしまうため無効化し、
     ハンバーガー/ナビを真のビューポート固定にする */
  .jf-bar { position: relative; backdrop-filter: none; }
  /* header → compact + collapsing nav */
  .jf-brand__img { height: 60px; }
  .jf-brand { gap: 12px; padding: 10px 0; }
  .jf-brand__desc { display: none; }
  .jf-bar__util .jf-util-info, .jf-bar__util .jf-util-sns { display: none; }
  /* ハンバーガー表示時はヘッダーのお問い合わせボタンを非表示 */
  .jf-util-cta { display: none; }
  .jf-nav { position: fixed; top: 0; left: 0; right: 0; background: #fff; border-top: 0; max-height: 0; overflow: hidden; transition: max-height .4s ease; box-shadow: var(--shadow); z-index: 110; }
  .jf-nav.open { max-height: 100vh; }
  .jf-nav__list { flex-direction: column; padding-top: 80px; }
  .jf-nav__list a { flex-direction: row; justify-content: space-between; padding: 16px 24px; border-bottom: 1px solid var(--c-line); }
  /* ハンバーガーは追従（固定）・黒背景の正方形。ロゴ／白背景は追従しない */
  .jf-burger { display: flex; position: fixed; top: 12px; right: 12px; width: 56px; height: 56px; z-index: 130; }

  .jf-stats__inner { grid-template-columns: 1fr 1fr; }
  .jf-stats__note { grid-column: 1 / -1; max-width: none; padding: 28px 0; }
  .jf-stat:first-of-type { border-left: 0; }
  .jf-greet, .jf-area, .jf-feat, .jf-svc { grid-template-columns: 1fr; }
  .jf-greet__photo { aspect-ratio: 16/10; }

  .jf-cms--sidebar { grid-template-columns: 1fr; }

  /* footer / fixcta */
  .jf-foot__main { grid-template-columns: 1fr; gap: 32px; }
  .jf-foot__cta-inner { grid-template-columns: 1fr; }
  .jf-foot__cta-btns { min-width: 0; }
  .jf-fixcta { flex-direction: row; top: auto; bottom: 0; right: 0; left: 0; transform: none; }
  .jf-fixcta a { writing-mode: horizontal-tb; flex: 1; justify-content: center; padding: 16px; }
  body { padding-bottom: 56px; }
}
@media (max-width: 860px) {
  .jf-promise { grid-template-columns: 1fr; }
  .jf-svcblock { grid-template-columns: 1fr; }
  .jf-svcblock__photo { aspect-ratio: 16/10; min-height: 0; }
  .jf-svcblock:nth-child(even) .jf-svcblock__photo { order: 0; }
  .jf-pack { grid-template-columns: 1fr; }
  .jf-works { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 700px) {
  .jf-point { grid-template-columns: 1fr; gap: 8px; }
  .jf-point__num { display: flex; align-items: baseline; gap: 12px; }
  .jf-mvis { grid-template-columns: 1fr; }
  .jf-mvis__arrow { transform: rotate(90deg); }
}
@media (max-width: 560px) {
  /* スマホはロゴを大きく。ヘッダー高さ(--head-h)も追従させ、開閉ナビの開始位置を合わせる */
  :root { --head-h: 100px; }
  .jf-brand__img { height: 66px; }
  .jf-stats__inner { grid-template-columns: 1fr 1fr; }
  /* ノートは全幅1カラム、2つの数値は上揃え */
  .jf-stats__note { grid-column: 1 / -1; }
  .jf-stat { border-left: 1px solid rgba(255,255,255,.14); border-top: 0; padding: 24px 16px; justify-content: flex-start; }
  .jf-stat__sub { font-size: 12px; }
  /* サービスカードの矢印をスマホで少し小さく */
  .jf-svc__arrow { width: 34px; height: 34px; }
  .jf-svc__arrow i { font-size: 14px; }
  .jf-entry__ba { grid-template-columns: 1fr; }
  .jf-works { grid-template-columns: 1fr; }
  .jf-cgrid { grid-template-columns: 1fr; }
  .jf-form .jf-row2 { grid-template-columns: 1fr; }
  /* 会社概要テーブル：SPで項目名（th）が改行されないよう余白を詰める */
  .jf-company th, .jf-company td { padding: 14px 14px; font-size: 14px; }
  .jf-company th { width: 32%; white-space: nowrap; }
  /* 価格・工事概要などのテーブルも余白を詰める */
  .jf-ptable th, .jf-ptable td { padding: 14px 14px; }
  .jf-entry__spec th, .jf-entry__spec td { padding: 12px 12px; }
  /* 対応エリアの地図はスマホ時のみ高さを抑える */
  .jf-area__map img { max-height: 300px; }
  /* スマホ：フッターのロゴとインスタアイコンを中央寄せで横並び */
  .jf-foot__brandcol { display: flex; justify-content: center; align-items: center; gap: 22px; }
  .jf-foot__brandcol .jf-foot-logo img { height: auto; max-height: 96px; max-width: 100%; }
  .jf-foot__brandcol .jf-foot__sns { margin-top: 0; width: auto; }
  /* スマホ：フッターCTAの電話ボタンは1カラム（番号と受付時間を縦並び・中央） */
  .jf-foot__tel-big { flex-direction: column; align-items: center; gap: 2px; text-align: center; }
  /* スマホ：細部の文字・余白調整 */
  .jf-svc__no { font-size: 30px; }
  .jf-btn--lg { padding: 22px 35px; }
  .jf-fixcta a { font-size: 13px; }
}
@media (max-width: 520px) {
  .jf-svctag { grid-template-columns: 1fr; gap: 8px; }
  .jf-svctag__label { justify-self: start; padding: 7px 16px; }
}
