/* 比赛详情文字直播（PC / 移动共用） */
.text-live-tab-wrap { background: #fff; border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); margin-bottom: 20px; overflow: hidden; border: 1px solid #eee; }
.text-live-head { display: flex; align-items: center; padding: 14px 18px; border-bottom: 1px solid #f0f0f0; background: linear-gradient(180deg, #fafafa 0%, #fff 100%); }
.text-live-head-bar { width: 4px; height: 18px; background: #e74c3c; border-radius: 2px; margin-right: 10px; flex-shrink: 0; }
.text-live-head h2 { margin: 0; font-size: 16px; font-weight: bold; color: #333; }
.text-live-head .text-live-sub { margin-left: auto; font-size: 12px; color: #999; font-weight: normal; }
.text-live-body { padding: 16px 18px 20px 14px; max-height: 560px; overflow-y: auto; -webkit-overflow-scrolling: touch; background: #fafafa; }
.text-live-list { margin: 0; padding: 0 0 0 4px; list-style: none; position: relative; }
.text-live-list::before { content: ""; position: absolute; left: 19px; top: 10px; bottom: 10px; width: 2px; background: #dcdcdc; border-radius: 1px; }
.text-live-item { position: relative; padding-left: 44px; margin-bottom: 14px; }
.text-live-item:last-child { margin-bottom: 0; }
.text-live-node { position: absolute; left: 4px; top: 12px; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; z-index: 1; }
.text-live-icon { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; background: #fff; border: 2px solid #e0e0e0; box-sizing: border-box; box-shadow: 0 1px 2px rgba(0,0,0,0.06); }
.text-live-icon--whistle { border-color: #e74c3c; color: #e74c3c; background: #fff5f5; }
.text-live-icon--horn { border-color: #ff9800; color: #ff9800; background: #fff8e6; }
.text-live-icon--goal { border-color: #2e7d32; color: #1b5e20; background: #e8f5e9; }
.text-live-icon--card { border-color: #f1c40f; color: #d68910; background: #fffbeb; }
.text-live-icon--sub { border-color: #3498db; color: #2980b9; background: #ebf5fb; }
.text-live-icon--miss { border-color: #43a047; color: #1b5e20; background: #e8f5e9; }
.text-live-icon--corner { border-color: #8e44ad; color: #6c3483; background: #f5eef8; }
.text-live-card { background: #f0f0f0; border-radius: 10px; padding: 12px 14px; display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 54px; border: 1px solid #e8e8e8; }
.text-live-card-text { flex: 1; min-width: 0; font-size: 14px; line-height: 1.55; color: #333; }
.text-live-time { font-weight: 700; color: #e74c3c; margin-right: 6px; }
.text-live-score-hint { font-size: 12px; color: #888; margin-top: 5px; }
.text-live-team-logo { width: 40px; height: 40px; object-fit: contain; border-radius: 50%; background: #fff; flex-shrink: 0; border: 1px solid #e0e0e0; box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
.text-live-empty, .text-live-error { text-align: center; color: #888; padding: 40px 20px; font-size: 14px; background: #fff; border-radius: 8px; border: 1px dashed #ddd; }
.text-live-loading { text-align: center; color: #888; padding: 36px 20px; font-size: 14px; }

@media (max-width: 768px) {
    .text-live-body { max-height: 420px; padding: 12px 10px 16px 8px; }
    .text-live-card-text { font-size: 13px; }
    .text-live-team-logo { width: 34px; height: 34px; }
}
