body {
  margin: 0;
  font-family: "Noto Sans JP","Yu Gothic",sans-serif;
  background: #f4f4f4;
  color: #222;
  line-height: 1.7;
}

#main {
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
  background: #fff;
  box-shadow: 0 0 12px rgba(0,0,0,.15);
}

/* 共通横幅 */
.lead, .bio, .works, .prices, .schedule, .events, .page-title {
  max-width: 940px;
  margin: 0 auto 40px;
  padding: 0 20px;
}

/* キービジュアル */
.kv img {
  width: 100%;
  display: block;
}

/* ページタイトル */
.page-title h1 {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  margin: 30px 0 10px;
  color: #1a2a52;
}

/* セクション見出し */
.section-title {
    font-size: 22px;
    font-weight: 700;
    text-align: center;
    color: #fff;
    background: #c41d1f;
    padding: 12px;
    margin: 50px auto 20px;
    width: 100%;
    max-width: 940px;
}

/* リード */
.lead {
  padding: 30px 24px;
  background: linear-gradient(135deg, #f9fafc, #eef1f7);
  text-align: left;
  box-shadow: 0 2px 6px rgba(0,0,0,.05);
}
.lead h2 {
  font-size: 20px;
  color: #1a2a52;
  margin-top: 0;
  margin-bottom: 16px;
}
.lead p {
  margin: 0;
  font-size: 15px;
  color: #333;
}

/* 略歴 */
.bio {
  display: flex;
  gap: 20px;
  background: #f9f9f9;
  border: 1px solid #ddd;
  padding: 20px;
}
/* 画像が無いときは枠ごと消す */
.bio-img:not(:has(img)),
.poster:not(:has(img)) {
  display: none;
}

.bio-img img {
  width: 100%;
  height: auto;
  display: block;
  box-shadow: 0 2px 6px rgba(0,0,0,.1);
}
.bio-img .credit {
  font-size: 12px;
  color: #666;
  margin-top: 4px;
  text-align: left;
}
.bio-text {
  flex: 1;
}
.bio-text h2 {
  margin-top: 0;
  font-size: 18px;
  color: #1a2a52;
}

/* 画像が無いときは枠ごと消す */
.bio-img:empty,
.poster:empty {
  display: none;
}

/* 作品カード */
.work-card {
  display: flex;
  gap: 20px;
  margin-bottom: 24px;
  padding: 16px;
  border: 1px solid #ddd;
  background: #fff;
  box-shadow: 0 4px 10px rgba(0,0,0,.08);
}
.poster {
  flex: 0 0 300px;
}
.poster img {
  display: block;
  width: 100%;
  height: auto;
}
.poster .credit {
  font-size: 12px;
  color: #666;
  margin-top: 4px;
  text-align: right;
}
.info {
  flex: 1;
}
.info h3 {
  margin: 0 0 6px;
  font-size: 20px;
  font-weight: 700;
  color: #1a2a52;
}
.info h3 .en {
  display: block;
  font-size: 14px;
  font-weight: 400;
  color: #444;
}
.meta {
  font-size: 13px;
  color: #555;
  margin: 0 0 10px;
}
.desc {
  font-size: 14px;
  margin: 0;
}

/* 料金・イベント */
.prices h3 {
  margin: 0 0 10px;
  color: #1a2a52;
}
.prices p,
.events p {
  margin: 6px 0;
}
.prices .notice {
  font-size: 14px;
  color: #666;
}

/* スケジュール */
.schedule img {
  width: 100%;
}

/* フッター */
footer {
    background: #c41d1f;
    color: #fff;
    text-align: center;
    padding: 8px;
    font-size: 14px;
    margin-top: 20px;
}

.lightbox-overlay {
  /* 初期状態では非表示 */
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s, visibility 0.3s; /* フェードイン・アウトのアニメーション */

  /* オーバーレイの基本スタイル */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8); /* 半透明の背景 */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

/* :target擬似クラスで表示状態を切り替える */
.lightbox-overlay:target {
  visibility: visible;
  opacity: 1;
}

.lightbox-content {
  max-width: 90%;
  max-height: 90%;
  overflow: auto; /* 画像がはみ出す場合にスクロール */
  background: #fff;
  padding: 10px;
  border-radius: 5px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
  transform: scale(0.8); /* ポップアップ時の初期サイズ */
  transition: transform 0.3s ease-out;
}

.lightbox-overlay:target .lightbox-content {
  transform: scale(1); /* ポップアップ時に元のサイズに */
}

.lightbox-content img {
  display: block; /* 余白をなくす */
  max-width: 100%;
  height: auto;
}

.lightbox-close {
  position: absolute;
  top: 15px;
  right: 25px;
  color: #fff;
  font-size: 40px;
  text-decoration: none;
  line-height: 1;
  z-index: 1001; /* 画像より手前に表示 */
}

.lightbox-close:hover {
  color: #ccc;
}

/* オーバーレイクリックで閉じるための設定 (HTMLのa href="#_") */
.lightbox-overlay .lightbox-close-area { /* オーバーレイ全体をクリックで閉じるための要素を別途用意する場合 */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
}

/* スマホ対応 */
@media (max-width: 700px) {
  .work-card {
    flex-direction: column;
  }
  .poster {
    flex: 0 0 auto;
    max-width: 100%;
  }
  .bio {
    flex-direction: column;
    align-items: center;
  }
  .bio-img {
    max-width: 200px;
  }
  .page-title h1 {
    font-size: 22px;
  }
}
f4f4f4
