/* ============================================================
   1. カスタムプロパティ（デザイントークン）
   ============================================================ */

#ainavi {
  /* 背景色 */
  --bg:       #ffffff;
  --bg2:      #fff8f0;
  --bg3:      #fff1e0;

  /* ボーダー */
  --border:   #ffd4a0;
  --border2:  #ffb060;

  /* アクセントカラー */
  --blue:     #0088ff;
  --blue2:    #33aaff;
  --blue3:    #dff0ff;
  --orange:   #ff6a00;
  --coral:    #ff4d6a;
  --yellow:   #ffcc00;
  --teal:     #00c8b4;
  --purple:   #8b3dff;
  --lime:     #8ecc00;

  /* テキスト */
  --text:     #1a1208;
  --text2:    #5a4020;
  --text3:    #b89060;

  /* フォント */
  --font: 'BIZ UDPGothic', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Meiryo, 'Inter', sans-serif;
}


/* ============================================================
   2. リセット & ベース
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* html rule skipped (managed by CMS) */

#ainavi {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-weight: 400;
  line-height: 1.75;
  overflow-x: hidden;
}

@keyframes ainavi-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.2; }
}


/* ============================================================
   3. レイアウト共通
   ============================================================ */

/* セクション内幅 */
#ainavi .wrap{
  max-width: 1100px;
  margin: 0 auto;
  padding: 88px 2rem 88px 2rem ;
}

/* 背景帯（奇数セクション） */
#ainavi .band{
  background: #fff;
}

/* ネットワーク罫線：ドット＋ライン */
#ainavi .divider{
  height: 20px;
  background:
    radial-gradient(circle, var(--border) 1.5px, transparent 1.5px) 0 50% / 24px 24px,
    linear-gradient(90deg, transparent 0, var(--border) 50%, transparent 100%) 0 50% / 100% 1px;
  background-repeat: repeat-x, repeat-x;
  background-color: transparent;
}

/* レインボーアクセントバー */
#ainavi .accent-bar{
  height: 6px;
  background: linear-gradient(
    90deg,
    var(--blue)   0%,
    var(--teal)   22%,
    var(--lime)   44%,
    var(--yellow) 62%,
    var(--orange) 80%,
    var(--coral)  100%
  );
}


/* ============================================================
   4. セクションタイトル
   ============================================================ */

/* タイトル本体 */
#ainavi .s-title{
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text);
  line-height: 1.2;
  display: block;
  position: relative;
  padding-bottom: 14px;
  margin-bottom: 2.8rem !important;
}

/* タイトル下のカラーアンダーライン */
#ainavi .s-title::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  height: 5px;
  width: 48px;
  border-radius: 3px;
  margin-top: 8px;
  background: linear-gradient(90deg, var(--orange), var(--yellow));
}

/* タイトル中央揃えバリアント（予告動画セクションなど） */
#ainavi .s-title--center{
  text-align: center;
}

#ainavi .s-title--center::after{
  left: 50%;
  transform: translateX(-50%);
}


/* ============================================================
   5. ヘッダー（HERO）
   ============================================================ */

#ainavi .hero{
  background: var(--bg);
}

/* ① ロゴバー */
#ainavi .hero-logo-bar{
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.8rem 2rem;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  text-align: center;
}

/* ロゴ画像（本番差し替え用） */
#ainavi .hero-logo-img{
  display: inline-block;
  max-height: 70px;
  width: auto;
}

/* ロゴプレースホルダー（本番はlogo.pngに差し替え） */
#ainavi .hero-logo-placeholder{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--font);
}

#ainavi .hero-logo-placeholder .lp-mark{
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--orange), var(--yellow));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
}

#ainavi .hero-logo-placeholder .lp-text{
  text-align: left;
}

#ainavi .hero-logo-placeholder .lp-name{
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1;
}

#ainavi .hero-logo-placeholder .lp-name span{
  color: var(--orange);
}

#ainavi .hero-logo-placeholder .lp-sub{
  display: block;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text3);
  margin-top: 4px;
}


/* ② ヘッダー写真エリア */
#ainavi .hero-photo{
  position: relative;
  width: 100%;
  aspect-ratio: 1120 / 420; /* PC: 1120×504px */
  overflow: hidden;
  background: #fff;
}

#ainavi .hero-photo img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* 写真下部の暗転オーバーレイ（キャプション読みやすくするため） */
#ainavi .hero-photo-overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
}

/* 撮影地キャプション */
#ainavi .hero-photo-badge{
  position: absolute;
  bottom: 1.5rem;
  left: 2rem;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 8px;
}

#ainavi .hero-photo-badge-dot{
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #fff;
  animation: ainavi-blink 2.4s infinite;
}

#ainavi .hero-photo-caption{
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}

/* 写真プレースホルダー（本番はJPEGに差し替え） */
#ainavi .hero-photo-placeholder{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--bg3);
}

#ainavi .hero-photo-placeholder-label{
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text3);
}

#ainavi .hero-photo-placeholder-size{
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--text2);
}


/* ③ キャッチコピー・放送日エリア */
#ainavi .hero-sub-bar{
  padding: 4rem 2rem 3rem;
  background: var(--bg);
  text-align: center;
}

#ainavi .hero-sub-inner{
  max-width: 800px;
  margin: 0 auto;
}

#ainavi .hero-tagline{
  font-size: 35px;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--text);
  margin-bottom: 1.2rem !important;
}

#ainavi .hero-tagline span{
  color: var(--orange);
}

#ainavi .hero-sub-desc{
  font-size: 17px;
  color: var(--text2);
  line-height: 1.9;
  margin-bottom: 1.4rem;
}

#ainavi .hero-broadcast{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--text2);
}

#ainavi .hero-broadcast strong{
  background: var(--orange);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 3px 14px;
  border-radius: 100px;
  letter-spacing: 0.04em;
}


/* ============================================================
   6. 番組概要
   ============================================================ */

#ainavi .overview-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
}

#ainavi .overview-body{
  font-size: 16px;
  color: var(--text2);
  line-height: 2.1;
}


/* ============================================================
   7. 予告動画
   ============================================================ */

#ainavi .yt-wrap{
  max-width: 800px;
  margin: 0 auto;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 4px 32px rgba(255, 106, 0, 0.08);
}

#ainavi .yt-wrap iframe{
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
}


/* ============================================================
   8. 出演者
   ============================================================ */

/* メイン3名：横3列 */
#ainavi .cast-main-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

/* サブ2名：横2列（幅66%） */
#ainavi .cast-sub-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  max-width: 66.5%;
}

#ainavi .cast-card{
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: box-shadow 0.25s, transform 0.25s;
}

#ainavi .cast-card:hover{
  box-shadow: 0 8px 32px rgba(255, 106, 0, 0.14);
  transform: translateY(-3px);
}

/* 出演者写真：400×500px（4:5ポートレート） */
#ainavi .cast-img{
  width: 100%;
  display: block;
  object-fit: cover;
  background: var(--bg3);
}

#ainavi .cast-img.main{
  aspect-ratio: 400 / 400;
}

/* サブはやや横長（メインとのサイズ差を視覚化） */
#ainavi .cast-img.sub{
  aspect-ratio: 380 / 380;
}

/* 写真プレースホルダー（本番はJPEGに差し替え） */
#ainavi .cast-img-placeholder{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

#ainavi .cast-img-placeholder .p-name{
  font-size: 22px;
  font-weight: 700;
  color: var(--orange);
  opacity: 0.3;
}

#ainavi .cast-img-placeholder .p-label{
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text3);
}

/* テキストエリア */
#ainavi .cast-body{
  padding: 1.1rem 1.2rem 1.3rem;
}

/* 役職バッジ */
#ainavi .cast-role{
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 100px;
  margin-bottom: 7px;
}

/* 役職バッジ：担当カラー別 */
#ainavi .role-blue   .cast-role{ color: var(--blue);   background: rgba(0, 136, 255, 0.1); }
#ainavi .role-teal   .cast-role{ color: var(--teal);   background: rgba(0, 200, 180, 0.1); }
#ainavi .role-orange .cast-role{ color: var(--orange); background: rgba(255, 106, 0, 0.1); }
#ainavi .role-pink   .cast-role{ color: var(--coral);  background: rgba(255, 77, 106, 0.1); }
#ainavi .role-yellow .cast-role{ color: #b87800;        background: rgba(255, 204, 0, 0.18); }

#ainavi .cast-name{
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 5px;
}

#ainavi .cast-desc{
  font-size: 13px;
  color: var(--text2);
  line-height: 1.8;
}

#ainavi .cast-card.sub .cast-desc{
  font-size: 12px;
}


/* ============================================================
   9. コーナー紹介
   ============================================================ */

#ainavi .corner-block{
  margin-bottom: 4rem;
}

/* "Chapter 01" バッジ */
#ainavi .corner-num{
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(90deg, var(--orange), var(--coral));
  padding: 3px 12px;
  border-radius: 100px;
  margin-bottom: 0.7rem;
}

#ainavi .corner-title{
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-bottom: 0.7rem;
}

#ainavi .corner-lead{
  font-size: 15px;
  color: var(--text2);
  line-height: 2;
  max-width: 720px;
  margin-bottom: 1.5rem;
}

/* 写真グリッド：2列×2行 */
#ainavi .photo-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

#ainavi .photo-cell{
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 3 / 2;
  position: relative;
  background: var(--bg3);
}

#ainavi .photo-cell img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* 写真プレースホルダー（本番はJPEGに差し替え） */
#ainavi .photo-placeholder{
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--bg3);
}

#ainavi .photo-placeholder-tag{
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--orange);
  background: #fff3e0;
  border-radius: 100px;
  padding: 4px 16px;
}

#ainavi .photo-placeholder-label{
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text3);
}


/* ============================================================
   10. 配信情報（topo）
   ============================================================ */

#ainavi .stream-box{
  display: flex;
  flex-direction: column;
  border-radius: 18px;
  overflow: hidden;
  border: 3px solid #7ecc00;
  box-shadow: 0 6px 24px rgba(126, 204, 0, 0.18);
}

/* 上段：白背景（ロゴ＋ボタン） */
#ainavi .stream-logo-area{
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  padding: 2rem 2.5rem;
  background: #fff;
  border-bottom: 2px solid #e8f7cc;
}

#ainavi .stream-logo-img-wrap{
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* topoロゴプレースホルダー（本番はtopo_logo.pngに差し替え） */
#ainavi .stream-logo-placeholder{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, #c8f000, #7ecc00);
  padding: 10px 24px;
  border-radius: 10px;
}

#ainavi .stream-logo-placeholder-text{
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #0f3300;
  font-family: 'BIZ UDPGothic', 'Hiragino Sans', sans-serif;
}

#ainavi .stream-logo-caption{
  font-size: 13px;
  line-height: 1.7;
  color: #6b7280;
}

/* 「topo で視聴する」ボタン */
#ainavi .stream-btn{
  display: inline-block;
  flex-shrink: 0;
  margin-left: auto;
  padding: 13px 30px;
  background: #7ecc00;
  color: #0f3300;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none;
  border-radius: 100px;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(126, 204, 0, 0.35);
  transition: opacity 0.2s;
}

#ainavi .stream-btn:hover{
  opacity: 0.85;
}

/* 下段：黄緑グラデーション（説明テキスト） */
#ainavi .stream-body-area{
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
  padding: 1.6rem 2.5rem;
  background: linear-gradient(135deg, #c8f000 0%, #7ecc00 50%, #4db800 100%);
}

/* 装飾用の丸 */
#ainavi .stream-body-area::before{
  content: '';
  position: absolute;
  top: -30px;
  right: -30px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
}

#ainavi .stream-body-desc{
  font-size: 15px;
  font-weight: 400;
  color: rgba(15, 51, 0, 0.8);
  position: relative;
  text-align:left;
  margin-bottom:0 !important;
}




/* ============================================================
   12. スクロールアニメーション
   ============================================================ */

#ainavi .reveal{
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

#ainavi .reveal.vis{
  opacity: 1;
  transform: none;
}


/* ============================================================
   13. スマートフォン対応（768px以下）
   ============================================================ */

@media (max-width: 768px) {
br.pc{display:none;}

  /* ヘッダー写真：SP用サイズ 640×480px（4:3） */
#ainavi .hero-photo{
    aspect-ratio: unset;
    height: 340px;
  }

  /* キャッチコピーエリアを左揃えに */
#ainavi .hero-sub-bar{
    text-align: left;
    padding: 4rem 1.4rem 2rem;
  }

#ainavi .hero-sub-inner{
    max-width: 100%;
  }

#ainavi .hero-broadcast{
    justify-content: flex-start;
  }

  /* 番組概要：1列に */
#ainavi .overview-grid{
    grid-template-columns: 1fr;
  }

  /* 出演者：メインを2列に */
#ainavi .cast-main-grid{
    grid-template-columns: 1fr 1fr;
  }

  /* 出演者：サブも2列に（幅制限解除） */
#ainavi .cast-sub-grid{
    grid-template-columns: 1fr 1fr;
    max-width: 100%;
  }

  /* コーナー写真：2列を維持 */
#ainavi .photo-grid{
    grid-template-columns: 1fr 1fr;
  }

  /* 配信ボックス：縦並びに */
#ainavi .stream-logo-area{
    padding: 1.4rem;
  }

#ainavi .stream-body-area{
    flex-direction: column;
    text-align: center;
    padding: 1.4rem;
    gap: 1rem;
  }
}
