/* ================ CSS 共通設定（ランディング／ダウンロード共用） ================ */
:root{
  --ink:#0f172a;
  --sub:#475569;
  --bg:#ffffff;
  --bg-soft:#f8fafc;
  --accent:#2563eb;        /* 青ボタンなど基調色 */
  --accent-weak:#eff6ff;   /* セクション薄色 */
  --login:#16a34a;         /* 緑ボタン（動画DLやログイン用途） */
  --border:#e5e7eb;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  color:var(--ink);
  background:var(--bg);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Noto Sans JP","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  line-height:1.6;
}

a {
  text-decoration: none;
  outline: none;
}
/* 共通レイアウトユーティリティ */
.container{max-width:1024px;margin-inline:auto;padding:0 20px}
.wrap{max-width:960px;margin:48px auto;padding:0 20px} /* 既存DLページ互換 */
.section{padding:48px 0}
.section-accent{background:var(--accent-weak)}
.mb-12{margin-bottom:12px}
.mt-16{margin-top:16px}

/* ================ ヘッダー（LP用） ================ */
.site-header{border-bottom:1px solid var(--border);background:#fff;position:sticky;top:0;z-index:10}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand__logo{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:6px;background:var(--accent);color:#fff}
.brand__name{font-size:18px;letter-spacing:.02em}
.site-nav a{color:var(--ink);text-decoration:none;margin-left:16px}
.site-nav a:hover{color:var(--accent)}

/* ================ ヒーロー（LP用） ================ */
.hero{background:linear-gradient(180deg,#fff, var(--bg-soft));padding:56px 0}
.hero__inner h1{font-size:clamp(22px,3.2vw,32px);margin:0 0 8px}
.lead{color:var(--sub);margin:0 0 16px}

/* ================ お知らせ（LP用） ================ */
#news h2, #videos h2, #contact h2{font-size:clamp(18px,2.6vw,26px);margin:0 0 16px}
.news-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.news-list li{
  display:grid;
  grid-template-columns: 110px 1fr;
  gap:10px;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
}
.news-date{color:#334155;font-variant-numeric:tabular-nums}
.news-title{font-weight:700}
.news-desc{color:var(--sub);grid-column:2}

/* ================ 分割レイアウト（LP用） ================ */
.split{display:grid;gap:20px;grid-template-columns: 1.2fr .8fr}
@media (max-width: 860px){ .split{grid-template-columns:1fr} }

.panel{
  border:1px solid var(--border);
  border-radius:14px;
  background:#fff;
  padding:16px;
}
.panel__title{font-size:16px;margin:0 0 8px}
.panel__list{margin:0;padding-left:18px}

/* ================ ダウンロードカード（DLページ用） ================ */
.file-box{display:flex;gap:16px;flex-wrap:wrap}
.file{
  flex:1 1 30%;
  min-width:260px;
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--bg-soft);
  padding:16px 18px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.file h2{font-size:18px;margin:0 0 6px}
.meta{margin:0 0 12px;color:#475569;font-size:14px;word-break:break-all}

/* ================ ボタン（共通） ================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:10px 14px;border-radius:9999px;
  text-decoration:none;font-weight:700;cursor:pointer;transition:opacity .2s ease;
  background:var(--accent);color:#fff;
}
.btn:hover{opacity:.92}
.btn svg{width:1.1em;height:1.1em;flex:0 0 auto}

.btn-primary{background:var(--accent);color:#fff}
.btn-secondary{background:var(--accent);color:#fff}
.btn-outline{border:1px solid var(--border);color:var(--ink);background:#fff}

/* 緑ボタン：動画DLやログイン用（DLページの「動画だけ緑」互換） */
.btn-green,
.btn-login{background:var(--login);color:#fff}

/* ================ フッター（LP用/共通） ================ */
.site-footer{border-top:1px solid var(--border);padding:20px 0;background:#fff;color:#64748b}
.site-footer small{letter-spacing:.02em}

/* 補助 */
code{background:#eef2ff;padding:2px 6px;border-radius:6px}

/* サムネイル枠 */
.thumb {
  width: 100%;
  aspect-ratio: 16/9;          /* 16:9の比率を保つ */
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 12px;
  background-color: #e5e7eb;   /* サムネイル未設定時の背景色 */
  display: flex;
  align-items: center;
  justify-content: center;
}
.thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* ===== モバイル最適化（ボタン押しやすく） ===== */
@media (max-width: 600px) {
  /* 触りやすいサイズに統一（44px以上推奨→48px） */
  .btn {
    font-size: 16px;
    padding: 14px 18px;
    min-height: 48px;
    border-radius: 14px;
  }

  /* LPのヒーロー＆連絡先のボタンは横幅いっぱいに */
  .hero .btn,
  #contact .contact-cta .btn {
    width: 100%;
  }

  /* 連絡先ボタンは縦並びにして誤タップ防止 */
  .contact-cta {
    flex-direction: column;
    gap: 10px;
  }

  /* ヘッダー周りもタップしやすく少し広げる */
  .hdr-inner { height: 60px; }
  .site-nav a { font-size: 16px; padding: 10px 0; }
}
/* YouTubeボタン */
.btn-youtube {
  background: #ff0000;  /* YouTube公式レッド */
  color: #fff;
}
.btn-youtube:hover {
  opacity: 0.8;
}
.btn-youtube svg {
  width: 1.2em;
  height: 1.2em;
}
