/* =========================================
   LIVE Single (single-live.css)
   - archive-live と同じ背景トーン
========================================= */

/* 背景（一覧と共通） */
.nk-archive-hero{
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.nk-archive-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("/wp-content/uploads/2026/03/hero1.webp") center/cover no-repeat;
  opacity:.07;
}

/* 本文 */
.nk-single{
  position: relative;
  z-index: 1;
  max-width: 960px;
  margin: 0 auto;
  padding: 120px 16px 80px;
}

.nk-single-header{ margin-bottom: 18px; }

.nk-single-title{
  font-size: 36px;
  margin: 0 0 10px;
  letter-spacing: .02em;
  overflow-wrap: anywhere;
}

/* meta（date + dow + venue） */
.nk-single-meta{
  display:flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;     /* SPでも改行しない（要件） */
  opacity: .78;
  font-size: 13px;
  letter-spacing: .06em;
}

/* 日付が長い/会場が長い時の崩れ対策 */
.nk-single-meta .nk-date{ white-space: nowrap; }
.nk-single-meta .nk-venue{
  display: inline-flex;
  align-items: center;
  min-width: 0;
  gap: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 曜日チップ（重複排除：これが正） */
.nk-dow{
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .10em;
  background: rgb(179 179 179 / 10%);
}
.nk-dow.is-sun{
  color:#c9302c;
  background: rgba(201,48,44,.10);
}
.nk-dow.is-sat{
  color:#2c5cc9;
  background: rgba(44,92,201,.10);
}

/* venue icon */
.nk-venue i{
  margin-right: 6px;
  opacity: .8;
  font-size: .95em;
}

/* flyer */
.nk-live-flyer{
  margin: 18px 0 14px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.05);
  border-radius: 16px;
  padding: 12px;
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}
.nk-live-flyer img{
  width: 100%;
  height: auto;
  display:block;
  border-radius: 14px;
}

/* details DL（メリハリ版に一本化） */
.nk-live-dl{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.05);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}
.nk-live-dl dt{
  position: relative;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .55;
}
.nk-live-dl dt::before{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: rgba(0,0,0,.06);
}
.nk-live-dl dt:first-child{
  padding-top: 0;
}
.nk-live-dl dt:first-child::before{
  display:none;
}
.nk-live-dl dd{
  margin: 6px 0 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

/* 普通リンク（控えめ） */
.nk-a{
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,.18);
  color: inherit;
}
.nk-a:hover{
  border-bottom-color: rgba(0,0,0,.35);
}

/* （Google Map）を控えめに */
.nk-map-link{
  margin-left: 8px;
  font-size: 12px;
  opacity: .6;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,.18);
}
.nk-map-link:hover{ opacity: .85; }

/* 公演日 dd 内で日付 + 曜日を横並び（使ってるなら） */
.nk-date-dd{
  display: flex;
  align-items: center;
  gap: 10px;
}

/* editor body（記事本文がある時だけ） */
.nk-live-body{
  margin-top: 18px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.05);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}
.nk-h3{
  margin: 0 0 10px;
  font-size: 16px;
  letter-spacing: .08em;
  opacity: .8;
}
.nk-prose{ line-height: 1.8; }
.nk-prose img{ max-width: 100%; height:auto; }
.nk-prose a{ text-decoration: underline; text-underline-offset: 3px; }

/* 戻るリンク（最下部） */
.nk-live-back{
  margin-top: 18px;
  text-align: center;
}
.nk-live-back-a{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(0,0,0,.04);
  border: 1px solid rgba(0,0,0,.08);
  color: rgba(0,0,0,.75);
  text-decoration: none;
  font-weight: 600;
  font-size: 13px;
}
.nk-live-back-a:hover{
  background: rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.12);
}

/* SP */
@media (max-width: 767px){
  .nk-single{ padding: 96px 14px 70px; } /* 上の詰まり対策で少し余裕 */
  .nk-single-title{
    font-size: 24px;
    line-height: 1.22;
    letter-spacing: .01em;
    margin-bottom: 10px;
  }
  .nk-single-meta{
    font-size: 12px;
    gap: 10px;
    margin-top: 8px;
    margin-bottom: 12px;
  }
  .nk-live-flyer{
    margin: 14px 0 12px;
    padding: 8px;
    border-radius: 14px;
  }
  .nk-live-flyer img{ border-radius: 12px; }
}

/* リンク（チケット/配信）をボタン化 */ .nk-live-dl dd .nk-a{ display: inline-flex; align-items: center; gap: 8px; padding: 10px 12px; border-radius: 12px; border: 1px solid rgba(0,0,0,.10); background: rgba(0,0,0,.04); text-decoration: none; font-weight: 700; }

