/*
 * Event-specific styles
 * style.css のトークンに依存。追加スタイルや細かい調整をここに置く。
 */

/* イベント詳細ページの追加プログラムスタイル */
.on-program-list {
  list-style: none;
  padding-left: 0;
  counter-reset: on-program;
}
.on-program-list > li {
  counter-increment: on-program;
  padding: 12px 0 12px 36px;
  position: relative;
  border-bottom: 1px solid var(--on-border-soft2);
  font-size: 14px;
  line-height: 1.7;
}
.on-program-list > li:last-child { border-bottom: none; }
.on-program-list > li::before {
  content: counter(on-program, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 14px;
  font-family: var(--on-font-serif);
  font-size: 11px;
  font-weight: 700;
  color: var(--on-gold);
  letter-spacing: 0.04em;
}

/* 出演者リスト */
.on-artist-list {
  list-style: none;
  padding-left: 0;
}
.on-artist-list li {
  display: flex;
  gap: 12px;
  align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px solid var(--on-border-soft2);
  font-size: 14px;
}
.on-artist-list li:last-child { border-bottom: none; }
.on-artist-list .role {
  flex-shrink: 0;
  width: 80px;
  color: var(--on-text-muted);
  font-size: 12px;
}
.on-artist-list .name {
  font-weight: 700;
  color: var(--on-dark-2);
}

/* 詳細ページのCTA box */
.on-cta-box {
  background: var(--on-bg-warm);
  border: 1px solid var(--on-gold);
  padding: 20px 24px;
  margin: 20px 0;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.on-cta-box-text {
  flex: 1;
  font-size: 13px;
  color: var(--on-text-sub);
  min-width: 200px;
}
.on-cta-box-text strong {
  display: block;
  font-family: var(--on-font-serif);
  font-size: 16px;
  color: var(--on-dark-2);
  margin-bottom: 4px;
}

/* エリアハブページカード */
.on-area-card { color: #fff; }
.on-area-card .on-browse-card-name { color: #fff; }
.on-area-card .on-browse-card-meta { color: rgba(255,255,255,0.8); }
.on-area-tokyo  { background: linear-gradient(135deg,#1a3a5c 0%,#2d6a9f 100%); border-color: #2d6a9f; }
.on-area-kansai { background: linear-gradient(135deg,#5c1a1a 0%,#9f2d2d 100%); border-color: #9f2d2d; }
.on-area-chubu  { background: linear-gradient(135deg,#1a5c30 0%,#2d9f5a 100%); border-color: #2d9f5a; }
.on-area-kyushu { background: linear-gradient(135deg,#5c4a1a 0%,#9f7d2d 100%); border-color: #9f7d2d; }
.on-area-card:hover { filter: brightness(1.12); border-color: transparent; text-decoration: none; }
.on-area-card:hover .on-browse-card-name { color: #fff; }

/* 印刷スタイル */
@media print {
  .on-top-bar,
  .on-genre-bar,
  .on-header-nav,
  .on-sidebar,
  .on-footer,
  .on-sidebar-toggle,
  .on-active-filters,
  .on-results-sort {
    display: none !important;
  }
  .on-main { display: block; padding: 0; }
  .on-content { width: 100%; }
  body { background: #fff; color: #000; font-size: 11pt; }
}
