/*
Theme Name: 東海ゼロエネ窓口
Theme URI: https://example.com/
Author: 株式会社Cans
Description: 家庭用太陽光発電・蓄電池の地域特化リード獲得サイト。固定ページはスラッグではなく「テンプレート選択」で表示します（Executive Deck デザイン）。
Version: 3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tokai-zeroene
*/
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Noto+Sans+JP:wght@400;500;700&display=swap');

/* =============================================================
   DESIGN TOKENS  ―  デザインを差し替える場合はこのブロックだけを編集する
   現在のテーマ: Executive Deck — Silent Meetings（エグゼクティブ・プレゼン）
   ※ v1=Nintendo 2001 / v2=Mastercard はそれぞれ /v1 /v2 に保存
   ============================================================= */
:root {
  /* --- 1. RAW PALETTE (デザインファイル由来) --- */
  --c-primary:      #0284c7; /* Sky Blue : 主要アクセント・アイコン・CTA */
  --c-primary-lt:   #38bdf8; /* Bright Blue : 暗面の見出し・ハイライト */
  --c-amber:        #f59e0b; /* Amber : 補助ハイライト */
  --c-emerald:      #34d399; /* Emerald : 成功・ポジティブ */
  /* Light slide */
  --c-bg:           #f8fafc; /* 背景：クール・オフホワイト */
  --c-surface:      #ffffff; /* カード面 */
  --c-raised:       #f1f5f9; /* テーブルヘッダ等の微弱な面 */
  --c-border:       #e2e8f0;
  --c-border-strong:#cbd5e1;
  --c-text:         #0f172a; /* 見出し・本文（明面） */
  --c-text-2:       #475569; /* 段落 */
  --c-text-muted:   #94a3b8; /* キャプション */
  /* Dark slide */
  --c-navy:         #0f172a; /* 暗面キャンバス（ディープネイビー） */
  --c-navy-surface: #1e293b;
  --c-navy-raised:  #334155;
  --c-on-dark:      #f8fafc;
  --c-on-dark-2:    #94a3b8;
  --c-on-dark-3:    #64748b;
  /* semantic */
  --c-success:      #34d399;
  --c-warning:      #f59e0b;
  --c-error:        #f87171;
  --c-info:         #38bdf8;
  --c-tint:         #f0f9ff; /* アイコンタイル背景（淡いブルー） */
  --c-line:         #06c755; /* LINEブランド色（CV認知のため固定） */

  /* --- 2. SEMANTIC ROLES --- */
  --bg-body:          var(--c-bg);
  --bg-section:       var(--c-bg);
  --bg-section-alt:   var(--c-raised);
  --bg-surface:       var(--c-surface);
  --bg-soft:          var(--c-raised);
  --bg-command:       var(--c-navy);
  --bg-raised:        var(--c-surface);

  --text-main:        var(--c-text);
  --text-sub:         var(--c-text-2);
  --text-on-command:  var(--c-on-dark-2);
  --text-on-cta:      #ffffff;

  --accent:           var(--c-primary);
  --accent-2:         var(--c-amber);
  --cta:              var(--c-primary);
  --cta-press:        #0369a1;
  --nav-link:         var(--c-text);
  --border:           var(--c-border);
  --hero-tint:        var(--c-raised);
  --dot:              var(--c-primary);

  /* --- 3. TYPOGRAPHY --- */
  --font-jp: "Plus Jakarta Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", Meiryo, system-ui, sans-serif;
  --font-display: var(--font-jp);  /* 明朝は使わず、見出しもゴシック体に統一 */
  --font-pixel: var(--font-jp);

  --fz-display:  56px;
  --fz-h2:       38px;
  --fz-h3:       24px;
  --fz-lead:     17px;
  --fz-body:     16px;
  --fz-label:    13px;
  --fz-micro:    12px;
  --track:       -0.01em;

  /* --- 4. SPACING (8px base) --- */
  --sp-xxs: 2px;  --sp-xs: 4px;  --sp-sm: 8px;  --sp-md: 16px;
  --sp-lg: 24px;  --sp-xl: 32px; --sp-xxl: 48px; --sp-section: 88px;

  /* --- 5. RADIUS --- */
  --r-none: 0px; --r-xs: 4px; --r-sm: 4px; --r-btn: 8px; --r-consent: 8px;
  --r-card: 12px; --r-xl: 16px; --r-pill: 9999px; --r-full: 50%;

  /* --- 6. LAYOUT --- */
  --container: 1200px;
  --header-h: 84px;

  /* --- 7. SHADOW（淡い） --- */
  --shadow-nav:  0 4px 12px rgba(15,23,42,0.04);
  --shadow-card: 0 4px 12px rgba(15,23,42,0.05);
  --shadow-lg:   0 20px 40px rgba(15,23,42,0.12);

  /* --- 8. DARK GLOW（暗面の放射グラデ） --- */
  --glow-dark:
    radial-gradient(circle at 15% 15%, rgba(56,189,248,0.15) 0%, transparent 50%),
    radial-gradient(circle at 85% 85%, rgba(245,158,11,0.10) 0%, transparent 50%);
}

/* =============================================================
   RESET / BASE
   ============================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-jp);
  font-size: var(--fz-body);
  font-weight: 400;
  line-height: 1.6;
  color: var(--text-main);
  background-color: var(--bg-body);
  background-image:
    radial-gradient(circle at 0% 0%, rgba(2,132,199,0.04) 0%, transparent 38%),
    radial-gradient(circle at 100% 100%, rgba(245,158,11,0.03) 0%, transparent 38%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}
img { max-width: 100%; display: block; }
a { color: var(--c-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
h1,h2,h3,h4 { margin: 0; line-height: 1.2; font-family: var(--font-display); font-weight: 700; letter-spacing: var(--track); }
p { margin: 0 0 1em; }
ul { margin: 0; padding: 0; list-style: none; }

.container { width: min(100% - 48px, var(--container)); margin-inline: auto; }
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* =============================================================
   UTILITY: PLATE / CHAMFER / SLAB
   ============================================================= */
.plate {
  background: var(--bg-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  box-shadow: var(--shadow-card);
}
.chamfer { clip-path: none; border-radius: var(--r-xl); }
.slab {
  background-color: var(--c-navy);
  background-image: var(--glow-dark);
  color: var(--c-on-dark);
}

/* =============================================================
   TYPOGRAPHY HELPERS
   ============================================================= */
.eyebrow {
  font-family: var(--font-jp);
  font-size: var(--fz-label);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-primary);
  display: inline-flex;
  align-items: center;
  margin-bottom: var(--sp-sm);
}
.eyebrow::before {
  content: "";
  width: 18px; height: 2px; background: var(--c-primary);
  margin-right: 10px; flex-shrink: 0;
}
.label { font-family: var(--font-jp); font-weight: 700; font-size: var(--fz-label); letter-spacing: 0.03em; }
.display { /* ヒーロー画像上のワードマーク：白セリフ */
  font-family: var(--font-display);
  color: #fff; font-weight: 700; letter-spacing: 0;
  text-shadow: 0 2px 16px rgba(0,0,0,0.45);
  line-height: 1;
}
.section-title { margin-bottom: var(--sp-xl); max-width: 820px; }
.section-title .ja {
  font-size: var(--fz-h2); font-weight: 700; color: var(--text-main);
  border-left: 5px solid var(--c-primary-lt); padding-left: 15px;
}
.section-title .lead { color: var(--text-sub); max-width: 64ch; margin-top: var(--sp-md); font-size: var(--fz-lead); }

/* =============================================================
   BUTTONS
   ============================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 46px; padding: 11px 24px;
  font-family: var(--font-jp); font-weight: 600; font-size: var(--fz-body);
  letter-spacing: 0; line-height: 1.3; text-align: center;
  border: 1.5px solid transparent; border-radius: var(--r-btn);
  cursor: pointer; text-decoration: none; transition: background-color .15s, color .15s, box-shadow .15s, transform .08s;
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn--cta      { background: var(--c-primary); color: #fff; border-color: var(--c-primary); box-shadow: var(--shadow-card); }
.btn--cta:hover { background: var(--cta-press); border-color: var(--cta-press); }
.btn--amber    { background: var(--c-surface); color: var(--c-primary); border-color: var(--c-primary); }
.btn--amber:hover { background: var(--c-tint); }
.btn--carbon   { background: var(--c-navy); color: #fff; border-color: var(--c-navy); }
.btn--carbon:hover { background: var(--c-navy-surface); }
.btn--line     { background: var(--c-line); color: #fff; border-color: var(--c-line); }
.btn--line:hover { filter: brightness(1.05); }
.btn--ghost    { background: var(--c-surface); color: var(--c-text); border-color: var(--c-border-strong); }
.btn--ghost:hover { border-color: var(--c-primary); color: var(--c-primary); }
.btn--lg       { min-height: 54px; font-size: var(--fz-lead); padding: 15px 32px; }
.btn--sm       { min-height: 38px; padding: 7px 16px; font-size: var(--fz-label); }
.btn--block    { width: 100%; }
.btn .chev { font-size: 0.8em; }

.arrow-disc {
  display: inline-flex; align-items: center; justify-content: center;
  width: 50px; height: 50px; border-radius: var(--r-full);
  background: var(--c-primary); color: #fff; font-weight: 700;
  border: none; box-shadow: var(--shadow-lg);
}
.arrow-disc:hover { background: var(--cta-press); text-decoration: none; }

/* =============================================================
   HEADER  （明面・クリーンな企業ヘッダー）
   ============================================================= */
.site-header { position: sticky; top: 0; z-index: 100; }

.topbar { background: var(--c-navy); color: var(--c-on-dark-2); font-size: var(--fz-micro); }
.topbar .container { display: flex; justify-content: space-between; align-items: center; min-height: 32px; gap: 12px; }
.topbar .label { letter-spacing: 0.04em; font-weight: 600; color: var(--c-on-dark-2); }

.navbar { background: var(--c-surface); border-bottom: 1px solid var(--c-border); box-shadow: var(--shadow-nav); }
.navbar .container { display: flex; align-items: center; gap: var(--sp-md); min-height: 68px; }

.logo { display: inline-flex; align-items: center; gap: 10px; flex-shrink: 0; }
.logo:hover { text-decoration: none; }
.logo .mark {
  font-family: var(--font-display); font-size: 14px; font-weight: 700; color: #fff;
  background: var(--c-primary); border-radius: var(--r-btn);
  width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center;
}
.logo .name { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--c-text); white-space: nowrap; }

.gnav { margin-left: auto; }
.gnav ul { display: flex; align-items: center; gap: 4px; }
.gnav a {
  display: inline-block; padding: 8px 12px; border-radius: var(--r-btn);
  color: var(--c-text); font-weight: 600; font-size: var(--fz-body);
}
.gnav a:hover { color: var(--c-primary); background: var(--c-tint); text-decoration: none; }
.gnav a[aria-current="page"] { color: var(--c-primary); box-shadow: inset 0 -3px 0 var(--c-primary); border-radius: 0; }

.header-cta { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.tel-chip { color: var(--c-text); line-height: 1.2; text-align: right; display: flex; flex-direction: column; }
.tel-chip .num { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--c-text); }
.tel-chip .hours { font-size: var(--fz-micro); color: var(--c-text-muted); }
.tel-chip:hover { text-decoration: none; }

.hamburger { display: none; }
#nav-toggle { display: none; }
.nav-drawer { display: none; }   /* PCでは非表示。モバイルのメディアクエリで block に切替 */

/* =============================================================
   HERO
   ============================================================= */
.hero { /* ファーストビュー：全幅の背景画像＋暗いオーバーレイ（ダーク・タイトルスライド） */
  position: relative;
  display: flex; align-items: center;
  min-height: clamp(460px, 72vh, 680px);
  padding: var(--sp-section) 0;
  background-color: var(--c-navy); /* 画像読込失敗時のフォールバック */
  background-image:
    linear-gradient(rgba(15,23,42,0.72), rgba(15,23,42,0.48)),
    url("https://images.pexels.com/photos/160994/family-outdoor-happy-happiness-160994.jpeg?auto=compress&cs=tinysrgb&w=1920");
  background-size: cover; background-position: center 30%; background-repeat: no-repeat;
  color: var(--c-on-dark);
}
.hero-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-xl); align-items: center; max-width: 720px; }
.hero-copy { background: transparent; border: none; box-shadow: none; padding: 0; display: flex; flex-direction: column; justify-content: center; }
.hero-area-badge {
  display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  background: rgba(56,189,248,0.18); color: #fff; font-weight: 700; font-size: var(--fz-label);
  padding: 7px 16px; border-radius: var(--r-pill); margin-bottom: var(--sp-md); letter-spacing: 0.03em;
  border: 1px solid rgba(56,189,248,0.4);
}
.hero h1 { font-family: var(--font-display); font-size: clamp(34px, 5vw, 56px); font-weight: 700; line-height: 1.15; color: #fff; }
.hero h1 .hi { color: var(--c-primary-lt); }
.hero .sub { margin-top: var(--sp-md); color: var(--c-on-dark-2); font-size: var(--fz-lead); max-width: 50ch; }
.hero-visual { display: none; } /* 背景画像化に伴い右カラムの画像カードは非表示 */
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--sp-sm); margin-top: var(--sp-lg); }
.hero-badges { display: flex; gap: var(--sp-md); margin-top: var(--sp-xl); }
.trust-badge {
  flex: 1; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18); box-shadow: none;
  text-align: center; padding: var(--sp-md); border-radius: var(--r-card); backdrop-filter: blur(2px);
}
.trust-badge .n { font-family: var(--font-display); font-weight: 700; font-size: 30px; color: var(--c-primary-lt); }
.trust-badge .n small { font-size: 14px; }
.trust-badge .t { font-size: var(--fz-micro); color: var(--c-on-dark-2); font-weight: 600; }

.hero-visual {
  position: relative; min-height: 400px; overflow: hidden;
  background: var(--c-raised); border: 1px solid var(--c-border); border-radius: var(--r-card);
  box-shadow: var(--shadow-card);
}
.hero-visual img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.hero-visual .wordmark { position: absolute; left: 24px; bottom: 22px; z-index: 2; font-family: var(--font-display); font-size: clamp(26px, 4vw, 40px); }

/* =============================================================
   SECTIONS / GRID CARDS
   ============================================================= */
.section { padding: var(--sp-section) 0; }
.section--alt { background: var(--c-raised); }
.section--surface { background: var(--c-surface); }

.grid { display: grid; gap: var(--sp-lg); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.card {
  background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-card);
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; overflow: hidden;
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s;
}
.card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--c-border-strong); }
.card .thumb { aspect-ratio: 16/10; overflow: hidden; background: var(--c-raised); }
.card .thumb img { width: 100%; height: 100%; object-fit: cover; }
.card .body { padding: var(--sp-lg); display: flex; flex-direction: column; gap: var(--sp-sm); flex: 1; }
.card h3 { font-family: var(--font-display); font-size: var(--fz-h3); font-weight: 600; color: var(--c-text); }
.card .meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; font-size: var(--fz-micro); }
.card p { color: var(--text-sub); font-size: var(--fz-body); margin: 0; }
.card .more { margin-top: auto; padding-top: var(--sp-sm); font-weight: 600; color: var(--c-primary); font-size: var(--fz-body); }
.card .more:hover { color: var(--cta-press); }

.tag {
  display: inline-block; background: var(--c-tint); color: var(--c-primary);
  font-weight: 700; font-size: var(--fz-micro); letter-spacing: 0.03em;
  padding: 3px 10px; border-radius: var(--r-sm); border: none;
}
.tag--area { background: var(--c-primary); color: #fff; }
.tag--date { background: transparent; color: var(--c-text-muted); border: 1px solid var(--c-border); }

/* strength cards : アイコンタイル */
.strength { text-align: left; padding: var(--sp-lg); }
.strength .ic {
  width: 64px; height: 64px; display: flex; align-items: center; justify-content: center;
  background: var(--c-tint); color: var(--c-primary); border-radius: var(--r-card); border: none;
  font-size: 26px; margin-bottom: var(--sp-md);
}
.strength h3 { font-family: var(--font-display); font-size: var(--fz-h3); font-weight: 600; margin-bottom: var(--sp-xs); }

.svc-card { position: relative; }
.svc-card a.stretch { position: absolute; inset: 0; z-index: 1; }
.svc-card .body { z-index: 0; }

/* voice card */
.voice { padding: var(--sp-lg); display: flex; flex-direction: column; gap: var(--sp-md); }
.voice .who { display: flex; align-items: center; gap: var(--sp-md); }
.voice .ava { width: 64px; height: 64px; border-radius: var(--r-full); object-fit: cover; border: 2px solid var(--c-border); }
.voice .name { font-weight: 700; font-family: var(--font-display); }
.voice .attr { font-size: var(--fz-micro); color: var(--c-text-muted); }
.voice blockquote { margin: 0; font-size: var(--fz-body); color: var(--text-sub); line-height: 1.6; }

/* =============================================================
   BANNER （ダーク・セクション転換スライド）
   ============================================================= */
.banner {
  background-color: var(--c-navy);
  background-image: var(--glow-dark);
  color: var(--c-on-dark);
  padding: var(--sp-xxl); text-align: center;
  border: none; border-radius: var(--r-xl); box-shadow: var(--shadow-lg);
}
.banner .eyebrow { color: var(--c-primary-lt); }
.banner .eyebrow::before { background: var(--c-primary-lt); }
.banner h2 { font-family: var(--font-display); font-size: clamp(24px, 3vw, 38px); font-weight: 700; color: var(--c-on-dark); }
.banner p { margin: var(--sp-sm) auto var(--sp-lg); max-width: 60ch; color: var(--c-on-dark-2); }
.banner .note { font-size: var(--fz-micro); opacity: 0.8; margin-top: var(--sp-sm); margin-bottom: 0; color: var(--c-on-dark-2); }
.banner .btn--amber { background: transparent; color: var(--c-on-dark); border-color: rgba(248,250,252,0.4); }
.banner .btn--amber:hover { background: rgba(255,255,255,0.08); }

/* =============================================================
   FAQ
   ============================================================= */
.faq-item { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-card); margin-bottom: var(--sp-sm); box-shadow: var(--shadow-card); overflow: hidden; }
.faq-item summary { cursor: pointer; list-style: none; padding: var(--sp-md) var(--sp-lg); font-weight: 600; display: flex; gap: var(--sp-md); align-items: center; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: "Q"; font-family: var(--font-display); font-weight: 700; color: var(--c-primary); }
.faq-item summary::after { content: "\f067"; font-family: "Font Awesome 6 Free"; font-weight: 900; margin-left: auto; color: var(--c-primary); font-size: 14px; }
.faq-item[open] summary::after { content: "\f068"; }
.faq-item .answer { padding: 0 var(--sp-lg) var(--sp-md) calc(var(--sp-lg) + 22px); color: var(--text-sub); font-size: var(--fz-body); }

/* =============================================================
   PAGE HEADER (下層) ― ダーク・タイトルスライド
   ============================================================= */
.page-head {
  background-color: var(--c-navy);
  background-image: var(--glow-dark);
  color: var(--c-on-dark); padding: var(--sp-xxl) 0;
}
.page-head .eyebrow { color: var(--c-primary-lt); }
.page-head .eyebrow::before { background: var(--c-primary-lt); }
.page-head h1 {
  font-family: var(--font-display); font-size: clamp(30px, 4.5vw, 48px); font-weight: 700; color: var(--c-on-dark);
  border-left: 5px solid var(--c-primary-lt); padding-left: 16px;
}
.page-head p { color: var(--c-on-dark-2); margin: var(--sp-md) 0 0; max-width: 72ch; font-size: var(--fz-lead); padding-left: 21px; }
.breadcrumb { font-size: var(--fz-micro); margin-bottom: var(--sp-md); color: var(--c-on-dark-2); }
.breadcrumb a { color: var(--c-primary-lt); }
.breadcrumb a:hover { color: var(--c-on-dark); }

/* =============================================================
   FILTER BAR
   ============================================================= */
.filterbar { display: flex; flex-wrap: wrap; gap: var(--sp-md); align-items: center;
  background: var(--c-surface); border: 1px solid var(--c-border); padding: var(--sp-lg); border-radius: var(--r-card);
  box-shadow: var(--shadow-card); margin-bottom: var(--sp-xl); }
.filterbar .group { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.filterbar .group > span { font-weight: 700; font-size: var(--fz-label); margin-right: 4px; color: var(--c-text); }
.chip {
  display: inline-block; padding: 6px 14px; border: 1px solid var(--c-border);
  background: var(--c-surface); border-radius: var(--r-pill); font-size: var(--fz-label); font-weight: 600;
  color: var(--c-text-2); cursor: pointer;
}
.chip:hover { background: var(--c-tint); color: var(--c-primary); border-color: var(--c-primary); text-decoration: none; }
.chip[aria-pressed="true"], .chip.is-active { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }

/* =============================================================
   ARTICLE / DETAIL
   ============================================================= */
.layout-detail { display: grid; grid-template-columns: 1fr 320px; gap: var(--sp-xl); align-items: start; }
.prose { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-card); padding: var(--sp-xxl); box-shadow: var(--shadow-card); }
.prose h2 { font-family: var(--font-display); font-size: var(--fz-h2); font-weight: 700; margin: var(--sp-xl) 0 var(--sp-md); border-left: 5px solid var(--c-primary-lt); padding-left: 15px; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-family: var(--font-display); font-size: var(--fz-h3); font-weight: 600; margin: var(--sp-lg) 0 var(--sp-xs); color: var(--c-text); }
.prose p { color: var(--text-sub); }
.prose img { margin: var(--sp-md) 0; border: 1px solid var(--c-border); border-radius: var(--r-card); }
.prose ul.bullet { list-style: none; padding-left: 0; margin: 0 0 1em; color: var(--text-sub); }
.prose ul.bullet li { position: relative; padding-left: 28px; margin-bottom: 10px; }
.prose ul.bullet li::before { content: "\f058"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--c-primary); position: absolute; left: 0; top: 1px; }

.sidebar { display: flex; flex-direction: column; gap: var(--sp-lg); position: sticky; top: calc(var(--header-h) + 8px); }
.toc { background: var(--c-raised); border: 1px solid var(--c-border); border-radius: var(--r-card); padding: var(--sp-lg); }
.toc .label { display: block; margin-bottom: var(--sp-sm); color: var(--c-primary); text-transform: uppercase; letter-spacing: 0.06em; }
.toc ol { list-style: decimal; padding-left: 1.4em; color: var(--c-text-muted); }
.toc a { font-size: var(--fz-body); color: var(--text-sub); }

.spec-table { width: 100%; border-collapse: separate; border-spacing: 0; background: var(--c-surface);
  border: 1px solid var(--c-border); border-radius: var(--r-card); overflow: hidden; margin: var(--sp-md) 0; font-size: var(--fz-body); }
.spec-table th, .spec-table td { padding: 12px 18px; border-bottom: 1px solid var(--c-border); text-align: left; vertical-align: top; }
.spec-table tr:last-child th, .spec-table tr:last-child td { border-bottom: none; }
.spec-table th { background: var(--c-raised); font-weight: 700; width: 34%; white-space: nowrap; color: var(--c-text); }

.stat-row { display: flex; gap: var(--sp-md); flex-wrap: wrap; margin: var(--sp-md) 0; }
.stat { flex: 1; min-width: 140px; text-align: center; background: var(--c-raised); border: 1px solid var(--c-border); border-radius: var(--r-card); padding: var(--sp-lg); }
.stat .n { font-family: var(--font-display); font-weight: 700; font-size: 34px; color: var(--c-primary); }
.stat .t { font-size: var(--fz-micro); font-weight: 600; color: var(--c-text-2); }

/* =============================================================
   STEPS （スケジュールカード風：左ボーダー）
   ============================================================= */
.steps { counter-reset: step; display: grid; gap: var(--sp-md); }
.step { background: var(--c-surface); border: 1px solid var(--c-border); border-left: 4px solid var(--c-primary); border-radius: var(--r-card); padding: var(--sp-md) var(--sp-lg); box-shadow: var(--shadow-card); display: flex; gap: var(--sp-md); align-items: flex-start; }
.step::before { counter-increment: step; content: counter(step,decimal-leading-zero); font-family: var(--font-display); font-weight: 700; color: var(--c-primary); font-size: 26px; flex-shrink: 0; }
.step h3 { font-family: var(--font-display); font-size: var(--fz-h3); font-weight: 600; margin-bottom: 2px; }
.step p { margin: 0; font-size: var(--fz-body); color: var(--text-sub); }

/* =============================================================
   FORM
   ============================================================= */
.form-panel { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-card); padding: var(--sp-xxl); box-shadow: var(--shadow-card); }
.form-panel + .form-panel { margin-top: var(--sp-lg); }
.form-panel .panel-head { background: var(--c-primary); color: #fff; border-radius: var(--r-btn); display: inline-flex; align-items: center; gap: 8px; margin: 0 0 var(--sp-lg); padding: 8px 18px; font-weight: 700; font-size: var(--fz-label); letter-spacing: 0.04em; }
.field { margin-bottom: var(--sp-md); }
.field > label { display: block; font-weight: 700; font-size: var(--fz-body); margin-bottom: 6px; color: var(--c-text); }
.field .req { color: var(--c-error); font-size: 11px; margin-left: 6px; font-weight: 700; }
.field .opt { color: var(--c-text-muted); font-size: 11px; margin-left: 6px; }
.input, .select, .textarea {
  width: 100%; font-family: var(--font-jp); font-size: var(--fz-body); font-weight: 400; color: var(--text-main);
  background: var(--c-surface); border: 1px solid var(--c-border-strong); border-radius: var(--r-btn);
  padding: 12px 14px; min-height: 46px;
}
.input:focus, .select:focus, .textarea:focus { outline: 2px solid var(--c-primary); outline-offset: 1px; border-color: var(--c-primary); }
.textarea { min-height: 130px; resize: vertical; }
.radio-row, .check-row { display: flex; flex-wrap: wrap; gap: var(--sp-sm); }
.radio-row label, .check-row label { display: inline-flex; align-items: center; gap: 6px; background: var(--c-surface);
  border: 1px solid var(--c-border); border-radius: var(--r-btn); padding: 9px 16px; font-size: var(--fz-body); cursor: pointer; }
.radio-row label:hover, .check-row label:hover { border-color: var(--c-primary); }
.consent { display: flex; gap: 10px; align-items: flex-start; background: var(--c-raised); border: 1px solid var(--c-border);
  border-radius: var(--r-btn); padding: var(--sp-md); margin: var(--sp-md) 0; font-size: var(--fz-body); }
.consent a { color: var(--c-primary); text-decoration: underline; }
.dotted-divider { border: none; border-top: 1px dashed var(--c-border-strong); margin: var(--sp-lg) 0; }

/* =============================================================
   AREA LINK LIST
   ============================================================= */
.area-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-lg); }
.area-col h3 { font-family: var(--font-display); font-size: var(--fz-h3); font-weight: 600; color: var(--c-text); padding-bottom: var(--sp-xs); border-bottom: 2px solid var(--c-primary); margin-bottom: var(--sp-sm); }
.area-col a { display: block; padding: 6px 0; font-size: var(--fz-body); color: var(--text-sub); }
.area-col a:hover { color: var(--c-primary); }

/* =============================================================
   STAFF
   ============================================================= */
.staff { text-align: center; padding: var(--sp-lg); }
.staff img { width: 128px; height: 128px; object-fit: cover; border-radius: var(--r-full); border: 3px solid var(--c-tint); box-shadow: var(--shadow-card); margin: 0 auto var(--sp-md); }
.staff .role { font-size: var(--fz-micro); color: var(--c-primary); font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.staff .name { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h3); }
.staff .lic { font-size: var(--fz-micro); color: var(--c-text-muted); }

/* =============================================================
   FOOTER CTA + FOOTER
   ============================================================= */
.footer-cta { background: var(--c-raised); border-top: 1px solid var(--c-border); border-bottom: 1px solid var(--c-border); padding: var(--sp-section) 0; text-align: center; }
.footer-cta h2 { font-family: var(--font-display); font-size: clamp(26px, 4vw, 40px); font-weight: 700; }
.footer-cta .tel-big { font-family: var(--font-display); font-weight: 700; font-size: clamp(30px, 5vw, 48px); color: var(--c-primary); margin: var(--sp-sm) 0; display: inline-block; }
.footer-cta .hours { font-size: var(--fz-body); font-weight: 600; color: var(--c-text-2); }
.footer-cta .btns { display: flex; gap: var(--sp-sm); justify-content: center; flex-wrap: wrap; margin-top: var(--sp-lg); }

.site-footer { background-color: var(--c-navy); background-image: var(--glow-dark); color: var(--c-on-dark-2); padding: var(--sp-section) 0 var(--sp-xxl); }
.site-footer .container { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--sp-xl); }
.site-footer h4 { color: var(--c-on-dark); font-size: var(--fz-label); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: var(--sp-md); padding-bottom: 8px; border-bottom: 1px solid var(--c-navy-raised); }
.site-footer a { color: var(--c-on-dark-2); font-size: var(--fz-body); }
.site-footer a:hover { color: var(--c-primary-lt); }
.footer-logo { display: inline-flex; align-items: center; gap: 10px; color: var(--c-on-dark); font-family: var(--font-display); font-weight: 700; margin-bottom: var(--sp-sm); font-size: 18px; }
.footer-logo .mark { background: var(--c-primary); color: #fff; width: 32px; height: 32px; border-radius: var(--r-btn); display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 13px; }
.footer-nav li { margin-bottom: 9px; }
.sns { display: flex; gap: var(--sp-sm); margin-top: var(--sp-md); }
.sns a { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; background: var(--c-navy-surface); border: 1px solid var(--c-navy-raised); border-radius: var(--r-btn); color: #fff; font-size: 12px; font-weight: 700; }
.sns a:hover { background: var(--c-primary); border-color: var(--c-primary); text-decoration: none; }
.copyright { grid-column: 1 / -1; border-top: 1px solid var(--c-navy-raised); margin-top: var(--sp-lg); padding-top: var(--sp-lg); font-size: var(--fz-micro); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; color: var(--c-on-dark-3); }

/* back to top */
.to-top { position: fixed; right: 24px; bottom: 96px; z-index: 90; }

/* =============================================================
   STICKY MOBILE CTA BAR
   ============================================================= */
.mobile-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 95; display: none;
  background: var(--c-surface); border-top: 1px solid var(--c-border); box-shadow: 0 -4px 16px rgba(15,23,42,0.08);
}
.mobile-cta ul { display: grid; grid-template-columns: repeat(3, 1fr); }
.mobile-cta a { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; padding: 8px 4px; color: var(--c-text); font-size: 11px; font-weight: 700; min-height: 60px; }
.mobile-cta a:hover { text-decoration: none; }
.mobile-cta .ic { font-size: 18px; }
.mobile-cta a.tel { color: var(--c-primary); }
.mobile-cta a.line { color: var(--c-line); }
.mobile-cta a.est { background: var(--c-primary); color: #fff; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 900px) {
  .site-footer .container { grid-template-columns: 1fr 1fr; }
  .layout-detail { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .area-cols { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 820px) {
  :root { --fz-h2: 30px; --sp-section: 60px; }
  .gnav, .header-cta .tel-chip { display: none; }
  .hamburger {
    display: inline-flex; align-items: center; justify-content: center; margin-left: auto;
    width: 48px; height: 48px; background: var(--c-primary); color: #fff; border: none;
    border-radius: var(--r-btn); cursor: pointer; font-size: 18px;
  }
  .nav-drawer {
    display: block; position: fixed; inset: 0 0 0 auto; width: min(86vw, 360px);
    transform: translateX(100%); transition: transform .25s ease; z-index: 200;
    background-color: var(--c-navy); background-image: var(--glow-dark);
    padding: var(--sp-xl); overflow-y: auto; box-shadow: -8px 0 40px rgba(0,0,0,0.4);
  }
  #nav-toggle:checked ~ .nav-drawer { transform: translateX(0); }
  #nav-toggle:checked ~ .nav-backdrop { opacity: 1; pointer-events: auto; }
  .nav-backdrop { position: fixed; inset: 0; background: rgba(15,23,42,0.6); z-index: 150; opacity: 0; pointer-events: none; transition: opacity .25s; }
  .nav-drawer .close { display: block; text-align: right; color: var(--c-on-dark); font-size: 24px; margin-bottom: var(--sp-md); cursor: pointer; }
  .nav-drawer .gnav-m { display: block; margin-bottom: var(--sp-lg); }
  .nav-drawer .gnav-m a { display: block; padding: 13px 8px; color: var(--c-on-dark); font-weight: 600; border-bottom: 1px solid var(--c-navy-raised); font-size: 16px; }
  .nav-drawer .gnav-m a:hover { color: var(--c-primary-lt); }
  .nav-drawer .drawer-cta { display: flex; flex-direction: column; gap: var(--sp-sm); }
  .nav-drawer .drawer-sns { display: flex; gap: var(--sp-md); margin-top: var(--sp-lg); }
  .nav-drawer .drawer-sns a { color: var(--c-on-dark-2); font-size: 14px; font-weight: 700; }

  .hero-grid { grid-template-columns: 1fr; gap: var(--sp-xl); }
  .hero-visual { min-height: 260px; order: -1; }
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .mobile-cta { display: block; }
  body { padding-bottom: 64px; }
  .to-top { bottom: 76px; right: 16px; }
}

@media (max-width: 560px) {
  :root { --sp-section: 48px; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .area-cols { grid-template-columns: 1fr; }
  .hero-badges { flex-wrap: wrap; }
  .trust-badge { min-width: calc(50% - 8px); }
  .topbar .container { font-size: 10px; }
  .hero-cta .btn { width: 100%; }
  .spec-table th { width: 40%; }
  .form-panel { padding: var(--sp-lg); }
  .prose { padding: var(--sp-lg); }
  .page-head p { padding-left: 0; }
}

/* header logo image */
.logo-img{height:46px;width:auto;display:block;}
@media (max-width:820px){.logo-img{height:38px;}}
@media (max-width:400px){.logo-img{height:32px;}}

/* ===== FV背景画像（assets/image/top/fv-image.png）に合わせた上書き ===== */
.hero{
  background-color:#0f172a;
  background-image:
    linear-gradient(90deg, rgba(15,23,42,.86) 0%, rgba(15,23,42,.62) 34%, rgba(15,23,42,.22) 56%, rgba(15,23,42,0) 78%),
    url("https://zero-ene.cans01.jp/wp-content/themes/tokai-zeroene/assets/image/top/fv-image.png");
  background-size:cover;
  background-position:right center;
  background-repeat:no-repeat;
}
.hero .hero-grid{max-width:640px;}
@media (max-width:820px){
  .hero{
    background-image:
      linear-gradient(180deg, rgba(15,23,42,.58) 0%, rgba(15,23,42,.5) 45%, rgba(15,23,42,.82) 100%),
      url("https://zero-ene.cans01.jp/wp-content/themes/tokai-zeroene/assets/image/top/fv-image.png");
    background-position:65% center;
  }
  .hero .hero-grid{max-width:none;}
}
