:root{
  --brand:#1e3a8a;   /* ネイビー */
  --accent:#f59e0b;  /* アクセント */
  --text:#111827;
  --muted:#6b7280;
  --bg:#ffffff;
  --bg-soft:#f7f8fb;
  --card:#ffffff;
  --border:#e5e7eb;
  --radius:16px;
  --shadow:0 6px 20px rgba(2,6,23,0.08);
  --w:1120px;
}

/* ベース（モバイルファースト） */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--text);background:var(--bg);
  font:16px/1.75 system-ui,-apple-system,"Noto Sans JP","Hiragino Kaku Gothic ProN","Meiryo",sans-serif;
  letter-spacing:.01em;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{opacity:.92}
.container{max-width:var(--w);margin:auto;padding:0 20px}
.section{padding:64px 0}
.section.is-muted{background:var(--bg-soft)}
.section-title{font-size:clamp(22px,4vw,32px);line-height:1.3;margin:0 0 16px}
.center{text-align:center}
.lead{color:var(--muted);margin:8px 0 24px}
.tip{margin-top:12px;color:var(--muted)}
.req{color:#ef4444;font-weight:600}
.hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* スキップリンク */
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{position:fixed;left:16px;top:16px;background:#fff;border:2px solid var(--brand);padding:8px 12px;border-radius:10px;z-index:10000}

/* ヘッダー */
.site-header{
  position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(120%) blur(10px);box-shadow:0 1px 0 var(--border);
  z-index: 2000;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-weight:800;font-size:20px;color:var(--brand)}

/* ハンバーガー & オフキャンバス */
.nav-toggle{display:none}
.hamburger{width:42px;height:42px;display:grid;place-content:center;gap:6px;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:#111;border-radius:2px}

/* 置き換え：ヘッダーより外にある全画面オーバーレイ */
.backdrop{
  position: fixed;
  inset: 0;             /* 画面全体を覆う（height指定は不要） */
  background: rgba(0,0,0,.8);
  display: none;
  z-index: 1500;        /* オーバーレイは高め */
}

/* オフキャンバスナビ */
.site-nav{
  position:fixed; left:0; top:64px; bottom:0; width:84%;
  max-width:320px; background:#fff; border-right:1px solid var(--border);
  transform:translateX(-100%); transition:.25s transform;
  z-index:2100;     
  padding:16px 14px;
}

.site-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.site-nav a{display:block;padding:12px;border-radius:12px}
.site-nav a:hover{background:#eef2ff}
.nav-cta a{background:var(--brand);color:#fff;text-align:center;border-radius:999px}
.nav-cta a:hover{opacity:.95}

/* チェックONで表示 */
#nav-toggle:checked ~ .site-nav{transform:none}
#nav-toggle:checked ~ .backdrop{display:block}
body.nav-open{overflow:hidden}

/* 追加：JSが body に付けるクラスで確実に開閉させる */
body.nav-open .backdrop{ display:block; }
body.nav-open .site-nav{ transform:none; }

@media (min-width:960px){
  .hamburger,.backdrop{display:none}
  .site-nav{
    position:static;transform:none;border:0;max-width:none;width:auto;padding:0;background:transparent
  }
  .site-nav ul{flex-direction:row;gap:14px;align-items:center}
  .site-nav a{padding:8px 10px}
  .site-nav a:hover{background:#eef2ff}
  .nav-cta a{padding:10px 14px}
}

/* ボタン */
.btn{display:inline-block;padding:10px 16px;border-radius:999px;border:1px solid transparent;transition:.2s box-shadow,.2s background,.2s color}
.btn:hover{box-shadow:var(--shadow)}
.btn-lg{padding:14px 22px;font-weight:700}
.btn-primary{background:var(--brand);color:#fff}
.btn-secondary{background:#111827;color:#fff}
.btn-ghost{background:#fff;border-color:var(--border);color:#111}
.cta-inline{margin-top:14px}

/* ヒーロー */
.hero{padding:40px 0 20px}
.hero-inner{display:grid;gap:24px;align-items:center}
.hero-title{font-size:clamp(26px,6vw,44px);margin:.2em 0 .3em}
.hero-sub{color:var(--muted);margin:0 0 20px}
.eyebrow{color:var(--brand);font-weight:700;margin:0 0 8px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
@media (min-width:960px){.hero-inner{grid-template-columns:1.1fr .9fr}}

/* グリッド */
.grid-2{display:grid;gap:24px}
@media (min-width:960px){.grid-2{grid-template-columns:1fr 1fr}}

/* カード */
.cards{display:grid;gap:16px}
.cards.three{grid-template-columns:1fr}
@media (min-width:960px){
  .cards{grid-template-columns:1fr 1fr}
  .cards.three{grid-template-columns:repeat(3,1fr)}
}
.card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow)
}
.card.mini{padding:20px;text-align:left}
.card-img{width:100%;height:auto;display:block}
.card-body{padding:20px}
.icon{font-size:28px}

/* リスト */
.check{margin:12px 0 0 0;padding-left:24px}
.check li{margin:.2rem 0}

/* 代表メッセージ */
.sign{margin:16px 0 22px;color:var(--muted);font-weight:600}

/* 市場背景 */
.bullets{margin:10px 0 0 0;padding-left:24px}
.bullets li{margin:.3rem 0}

/* 会社概要 */
.company{display:grid;gap:10px;margin:0}
.company > div{
  display:grid;grid-template-columns:140px 1fr;gap:10px;
  padding:14px;border:1px solid var(--border);border-radius:12px;background:#fff
}
.company dt{font-weight:700}
@media (min-width:720px){
  .company{grid-template-columns:1fr 1fr;gap:14px}
  .company > div{grid-template-columns:160px 1fr}
}

/* フォーム */
.form{margin-top:8px}
.grid-form{display:grid;gap:14px}
@media (min-width:960px){.grid-form{grid-template-columns:1fr 1fr}}
.field span{display:block;margin:0 0 6px;font-weight:600}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#fff
}
.field textarea{resize:vertical}
.span-2{grid-column:1/-1}
.radio-group{display:flex;gap:16px;flex-wrap:wrap}
.agree{display:flex;align-items:center;gap:10px;margin-top:4px}
.note{color:var(--muted);margin:.6rem 0 0}

/* アラート */
.alert{padding:12px 16px;border-radius:12px;margin:0 0 16px}
.alert.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}
.alert.error{background:#fef2f2;border:1px solid #fecaca;color:#7f1d1d}

/* フッター */
.site-footer{border-top:1px solid var(--border);background:#fff}
.footer-inner{display:grid;gap:12px;align-items:center;justify-items:center;padding:24px 0}
.footer-nav{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.footer-nav a{color:#374151}
.brand{font-weight:800;color:var(--brand)}
.copy{color:#6b7280}

/* ターゲット位置補正（ヘッダー分） */
:target{scroll-margin-top:80px}

@media (max-width: 959px){
  .site-nav{
    background: var(--brand);
    background: none;
    border: 0;
  }
  .site-nav a{
    color: #fff;                 /* 白文字 */
  }
  .site-nav a:hover{
    background: rgba(255,255,255,.12); /* ホバーで薄く反転 */
  }
  /* メニュー内のCTAはアクセント色で視認性UP */
  .site-nav .nav-cta a{
    background: var(--accent);
    color: #111827;
  }
  /* キーボード操作の視認性 */
  .site-nav a:focus-visible{
    outline: 3px solid rgba(255,255,255,.65);
    outline-offset: 2px;
  }
}