/* =====================================================================
   TechSuite 共通フッター（.rel 製品導線 ＋ .ft サイトフッター）単体CSS
   目的: WordPress通常ページにも LP と同じフッターを載せる（旧 site-footer/lp-chrome.css は廃止）。
   本文に影響しないよう .rel / .ft 配下にスコープ。DS全体(techsuite-ds.css)は載せない。
   ブランド色は各サイト theme.css（:root の --dark/--accent/--accent-2/--accent-on-dark）を利用。
   ===================================================================== */
.rel, .ft {
  --on-dark: #e8f0f6; --on-dark-dim: #9fb4c4; --fg: #0e2a43; --fg-muted: #52697a; --fg-dim: #7a8b98;
  --border: #e3eaf0; --r-sm: 14px; --maxw: 1120px;
  --font-serif: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --font-en: "Inter", system-ui, sans-serif; --ease: cubic-bezier(.4, 0, .2, 1);
  --shadow-card: 0 30px 60px -30px rgba(11, 35, 56, .18);
}
.rel *, .ft *, .rel *::before, .ft *::before { box-sizing: border-box; }
.rel a, .ft a { text-decoration: none; }
.rel .wrap { width: min(var(--maxw), 92%); margin-inline: auto; }
.rel { background: #fff; padding: clamp(60px, 7vw, 92px) 0; border-top: 1px solid var(--border); }
.rel_logo img { height: 24px; width: auto; margin: 0 auto 14px; opacity: .7; display: block; }
.rel h2 { text-align: center; font-family: var(--font-serif); font-weight: 600; font-size: clamp(20px, 2.4vw, 27px); color: var(--fg); margin: 0; }
.rel .div { text-align: center; font-family: var(--font-en); font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--accent-2); margin: 36px 0 16px; }
.rel_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.rel_card { background: #fff; border: 1px solid var(--border); border-radius: var(--r-sm); padding: 22px 24px; transition: transform .18s var(--ease), box-shadow .18s var(--ease), border-color .18s; }
.rel_card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card); border-color: var(--accent); }
.rel_card .d { font-size: 12.5px; color: var(--fg-muted); line-height: 1.7; margin: 0 0 8px; }
.rel_card .n { font-family: var(--font-serif); font-weight: 700; font-size: 16px; color: var(--fg); }
.ft { background: var(--dark); color: var(--on-dark-dim); padding: 56px 0 84px; }
.ft_inner { width: min(var(--maxw), 89%); margin-inline: auto; display: flex; flex-wrap: wrap; gap: 32px 64px; justify-content: space-between; }
.ft_info dt img { height: 30px; filter: brightness(0) invert(1); margin-bottom: 16px; }
.ft_info dt.co { font-weight: 800; color: #fff; font-size: 15px; }
.ft_info dd { margin: 8px 0 0; font-size: 12.5px; line-height: 1.8; max-width: 340px; }
.ft_col h5 { margin: 0 0 12px; font-family: var(--font-en); font-size: 11.5px; letter-spacing: .12em; color: var(--on-dark); font-weight: 600; }
.ft_col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.ft_col a { font-size: 13px; color: var(--on-dark-dim); transition: color .15s; }
.ft_col a:hover { color: var(--accent-on-dark); }
.ft_copy { width: min(var(--maxw), 89%); margin: 40px auto 0; font-size: 12px; color: var(--fg-dim); }
@media (max-width: 640px) { .rel_grid { grid-template-columns: 1fr; } }
