/* =================
 共通スタイル
================= */
body {
  font-family: 'Noto Sans JP', sans-serif;
  margin: 0;
  padding: 0;
  color: #222;
  background-color: #fff;
  text-align: center;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  box-sizing: border-box;
}
/* ========= PC用表示幅（65%）に制限 ========= */
.wrapper {
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0;
}

/* =================
 セクション基本
================= */
.section {
  max-width: 800px;
  margin: 40px auto;
  padding: 0 20px;
}

/* =================
 プライバシーポリシー用 左寄せ
================= */
.privacy-section {
  max-width: 800px;
  margin: 40px auto;
  padding: 0 20px;
  text-align: left;   /* ←左寄せ */
  line-height: 1.8;
}

/* =================
 ヒーロー画像
================= */
.hero-image {
  max-width: 100%;
  margin: 30px auto;
}

/* =================
 画像・バナー類
================= */
.large-banner { max-width: 100%; }
.section-image { max-width: 600px; margin: 30px auto; }
.image-small { max-width: 300px; margin: 20px auto; }
.banner-image { max-width: 200px; margin-left: 40px; }
.lecturer2-section { max-width: 70%; height: auto; margin: 20px auto; display: block; }

/* =================
 テキストスタイル
================= */
.highlight { background-color: yellow; font-weight: bold; }
.left-align { text-align: left; padding-left: 40px; }
.left-align1 { text-align: left; font-size: 22px; font-weight: bold; padding-left: 40px; }
.limited-offer {
  font-size: 22px; color: red; font-weight: bold;
  text-shadow: 1px 1px 0 #fff, 2px 2px 2px rgba(0,0,0,.2), 3px 3px 3px rgba(0,0,0,.15);
}

/* =================
 CTAボタン
================= */
.cta { margin: 40px auto; text-align: center; }
.cta-image {
  width: 60%; max-width: 400px; display: inline-block;
  transition: transform .3s ease, box-shadow .3s ease;
  border-radius: 9999px; box-shadow: 0 4px 6px rgba(0,0,0,.1);
  background-color: transparent;
}
.cta-image:hover { transform: translateY(-6px); box-shadow: 0 12px 20px rgba(0,0,0,.25); }

/* =================
 スケジュール表
================= */
.schedule-table { width: 90%; border-collapse: collapse; margin: 0 auto; border: 2px solid #000; }
.schedule-table th, .schedule-table td { border: 2px solid #ccc; padding: 10px; font-size: 16px; font-weight: bold; }
.schedule-table th { background-color: #e0f7fa; color: #000; font-weight: bold; }
.schedule-table .full { color: red; font-size: 14px; }
.schedule-table .re { color: blue; font-size: 14px; }


/* =================
 フッター
================= */
.site-footer { background-color: #EEFFFF; padding: 15px 10px; text-align: center; font-size: .85rem; color: #333; }
.footer-links { margin-bottom: 10px; line-height: 1.8; }
.footer-links a { color: #333; text-decoration: none; margin: 0 5px; }
.footer-links a:hover { text-decoration: underline; }
.footer-copy { font-size: .85rem; color: #777; }

/* =================
 トップに戻るボタン
================= */
.to-top-btn { position: fixed; bottom: 30px; right: 20px; display: none; z-index: 9999; }
.to-top-btn img { width: 50px; height: auto; transition: opacity .3s; }
.to-top-btn:hover img { opacity: .7; }

/* =================
 見出しデザイン（privacy / legal）
================= */
.policy h1, .legal h1 {
  font-size: 24px; font-weight: 700; margin: 32px auto 16px;
  text-align: center; padding-bottom: 8px; border-bottom: 3px solid #333;
}
.policy h2, .legal h2 {
  font-size: 18px; font-weight: 700; margin: 24px 0 12px;
  text-align: left; padding-bottom: 6px; border-bottom: 2px solid #ccc;
}
.policy .meta { color: #666; font-size: 13px; margin-top: 4px; }
.policy a, .legal a { color: #0ea5e9; text-decoration: none; }
.policy a:hover, .legal a:hover { text-decoration: underline; }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace; }

/* =================
 カード（privacy）
================= */
.policy .card { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; padding: 16px; margin: 16px 0; }

/* =================
 テーブル（legal）
================= */
.legal-table { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; overflow: hidden; }
.legal-table table { width: 100%; border-collapse: collapse; }
.legal-table th, .legal-table td { border-bottom: 1px solid #e5e7eb; padding: 12px 14px; vertical-align: top; }
.legal-table th { width: 240px; background: #f8fafc; text-align: left; font-weight: 700; color: #111; }
.legal-table tr:last-child th, .legal-table tr:last-child td { border-bottom: none; }

@media (max-width: 560px) {
  .legal-table table { border-collapse: separate; }
  .legal-table tr { display: block; border-bottom: 1px solid #e5e7eb; }
  .legal-table th { display: block; width: auto; border-bottom: 0; background: transparent; padding-bottom: 6px; }
  .legal-table td { display: block; padding-top: 0; }
}

/* =================
 レスポンシブ対応
================= */
@media screen and (min-width: 768px) {
  .wrapper { max-width: 65%; padding: 0 20px; }
  .section { margin: 30px auto; padding: 0 15px; }

  .schedule-table { width: 95%; }
  .schedule-table th, .schedule-table td { font-size: 14px; padding: 8px; }

  .cta-image { max-width: 50%; max-width: 560px; }
  .hero-image { max-width: 95%; }

  .left-align, .left-align1 { padding-left: 20px; }
  .banner-image { margin-left: 0; margin: 0 auto; }
  .lecturer2-section { max-width: 50%; }
}
