@charset "utf-8";
/* 仿 swbl.cn 风格 - 语义化命名 - 蓝色主题 #1a73e8 */

:root {
  --primary: #1a73e8;
  --primary-hover: #1557b0;
  --primary-light: #e8f0fe;
  --primary-border: #a8c7fa;
  --text-dark: #333;
  --text-gray: #666;
  --text-light: #999;
  --bg-body: #f4f4f4;
  --bg-white: #fff;
  --bg-gray: #f6f6f6;
  --border-color: #eee;
  --radius: 5px;
}

body { padding:0; margin:0; font-size:14px; font-family:"Microsoft Yahei",sans-serif; background:var(--bg-body); }
ul,ol { list-style:none; padding:0; margin:0; }
a { text-decoration:none; color:var(--text-dark); }
a:hover { color:var(--primary); }
p { margin:0; padding:0; }
html,body { overflow-x:hidden; }
.container { width:1200px; margin:0 auto; }

/* 顶部公告条 */
.site-topbar { background:#333; color:#fff; padding:5px 0; font-size:13px; }

/* 导航栏 */
/* 导航栏（不依赖 Bootstrap JS，纯CSS） */
#navBox { background:var(--bg-white); border-top:1px solid var(--border-color); border-bottom:1px solid var(--border-color); }
.site-nav-inner { display:flex; align-items:center; justify-content:space-between; height:64px; }
.site-nav-brand img { height:40px; display:block; }
.site-nav-menu { display:flex; align-items:center; margin:0; padding:0; list-style:none; }
.site-nav-menu li { margin:0; }
.site-nav-menu li a { display:block; padding:8px 22px; font-size:17px; color:var(--text-dark); border-radius:20px; margin:0 2px; transition:0.2s; }
.site-nav-menu li a:hover, .site-nav-menu li a.active { background:var(--primary); color:#fff; }
.site-nav-toggler { display:none; flex-direction:column; justify-content:center; gap:5px; width:40px; height:40px; background:none; border:none; cursor:pointer; padding:8px; }
.site-nav-toggler span { display:block; height:2px; background:var(--text-dark); border-radius:2px; }
.fixed { position:fixed; width:100%; top:0; left:0; z-index:999; box-shadow:0 4px 12px rgba(0,0,0,0.08); animation:fadeInDown .4s; }
@keyframes fadeInDown { from{opacity:0;transform:translateY(-100%);} to{opacity:1;transform:translateY(0);} }

/* 热门标签 */
.hot-tags { background:var(--bg-gray); padding:12px 0; font-size:14px; }
.hot-tags-title { width:70px; font-weight:bold; color:var(--text-dark); }
.hot-tags-list { width:calc(100% - 70px); }
.hot-tags-item { padding:0 10px; }
.hot-tags-item a { color:var(--text-gray); }
.hot-tags-item a:hover { color:var(--primary); }

/* 主布局 */
.match-layout { margin-top:10px; }
.main-content { width:calc(70% - 10px); border-radius:var(--radius); margin-bottom:20px; }
.sidebar { width:30%; border-radius:var(--radius); margin-bottom:20px; }

/* 赛事列表面板 */
.match-list-panel { background:rgba(255,255,255,0.95); border-radius:var(--radius); margin-bottom:15px; }
.match-list-header { padding:20px; border-bottom:2px var(--primary-border) solid; }
.match-filter-label { margin-right:10px; color:var(--text-dark); font-weight:bold; }
.match-filter-item { margin-right:4px; }
.match-filter-item a { padding:10px 20px; color:var(--text-dark); border-radius:var(--radius); display:block; }
.match-filter-item a:hover, .match-filter-item.active a { background:var(--primary); color:#fff; border-radius:var(--radius); }
.match-list-body { padding:0 0 20px; }

/* 日期分隔 */
.match-date-divider { background:var(--border-color); color:var(--text-dark); font-size:16px; padding:10px 20px; }

/* 赛事单条 */
.match-item { padding:10px 20px; color:var(--text-light); margin-top:0; border-bottom:1px solid #f5f5f5; }
.match-item a { color:var(--text-light); }
.match-item:hover { background:var(--primary-light); }
.match-item:hover a { color:var(--primary); }
.match-item-time { font-size:14px; min-width:80px; }
.match-item-time img { margin-right:10px; width:20px; vertical-align:middle; }
.match-item-league { padding:0 10px; width:70px; word-break:break-all; text-overflow:ellipsis; display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:1; overflow:hidden; }
.match-item-versus { display:flex; align-items:center; flex:1; justify-content:center; }
.match-versus-home, .match-versus-away { display:flex; align-items:center; min-width:120px; }
.match-versus-home { justify-content:flex-end; }
.match-versus-away { justify-content:flex-start; }
.match-versus-home img, .match-versus-away img { width:24px; height:24px; margin:0 8px; }
.match-versus-score { font-size:16px; color:var(--text-dark); font-weight:bold; min-width:60px; text-align:center; }
.match-item-btn a { background:#aaa; color:#fff; padding:5px 15px; border-radius:30px; font-size:12px; display:inline-flex; align-items:center; }
.match-item-btn a img { width:14px; margin-right:4px; }
.match-item-btn a:hover { background:#959595; color:#fff; }
.match-item-btn-live a { background:var(--primary); }
.match-item-btn-live a:hover { background:var(--primary-hover); }
.match-item-live { background:var(--primary-light); }

/* 面板通用 */
.panel-header { padding:15px 20px; border-bottom:2px var(--primary-border) solid; }
.panel-title { font-size:18px; color:var(--text-dark); font-weight:bold; }
.panel-more { font-size:14px; color:var(--text-gray); }
.panel-more:hover { color:var(--primary); }
.panel-body { padding:20px; }

/* 新闻面板 */
.news-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; padding:10px; }
.news-top { margin-top:10px; }
.news-top-pic { width:calc(60% - 10px); position:relative; overflow:hidden; border-radius:var(--radius); }
.news-top-pic img { width:100%; height:100%; object-fit:cover; transition:0.5s ease all; }
.news-top-pic img:hover { transform:scale(1.1); }
.news-top-title { position:absolute; width:100%; left:0; bottom:0; padding:15px; color:#fff; background:rgba(0,0,0,0.6); }
.news-top-list { width:40%; padding-left:10px; }
.news-top-item { background:var(--bg-gray); margin-bottom:8px; border-radius:var(--radius); overflow:hidden; }
.news-top-item-pic { width:35%; }
.news-top-item-pic img { width:100%; height:80px; object-fit:cover; }
.news-top-item-text { width:65%; padding:10px; font-size:14px; line-height:1.6; }
.news-top-item-text a { color:var(--text-dark); }
.news-top-item-text a:hover { color:var(--primary); }

/* 视频面板 */
.video-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; padding:10px; }
.video-list { margin-top:10px; }
.video-item { width:calc(16.66% - 8px); background:var(--bg-gray); border-radius:var(--radius); overflow:hidden; margin-bottom:10px; }
.video-item-pic { overflow:hidden; }
.video-item-pic img { width:100%; height:120px; object-fit:cover; transition:0.5s ease all; }
.video-item-pic img:hover { transform:scale(1.1); }
.video-item-title { font-size:13px; padding:10px; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; color:var(--text-dark); }
.video-item:hover .video-item-title { color:var(--primary); }

/* 侧边栏 */
.sidebar-block { background:rgba(255,255,255,0.95); border-radius:var(--radius); margin-bottom:15px; }
.sidebar-header { background:var(--primary); padding:15px 20px; border-radius:var(--radius) var(--radius) 0 0; }
.sidebar-title { font-size:18px; color:#fff; }
.sidebar-more { font-size:14px; color:#fff; }
.sidebar-more a { color:#fff; }
.sidebar-team-list { padding:20px; }
.sidebar-team-item { width:50%; padding:10px 0; display:flex; align-items:center; }
.sidebar-team-item img { margin-right:10px; width:32px; height:32px; }
.sidebar-team-item a { font-size:14px; color:var(--text-dark); }
.sidebar-team-item a:hover { color:var(--primary); }
.sidebar-record-list { padding:10px 20px; }
.sidebar-record-item { padding:5px 0; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; line-height:30px; }
.sidebar-record-item a { font-size:13px; color:var(--text-dark); }
.sidebar-record-item a:hover { color:var(--primary); }

/* 直播详情页 - 比分板 */
.match-detail-panel { background:var(--bg-white); border-radius:var(--radius); padding:30px; margin-bottom:15px; }
.match-scoreboard { display:flex; align-items:center; justify-content:space-between; }
.match-team { text-align:center; width:200px; }
.match-team-logo img { width:80px; height:80px; object-fit:contain; }
.match-team-placeholder { display:inline-flex; width:80px; height:80px; border-radius:50%; background:var(--bg-gray); align-items:center; justify-content:center; font-size:24px; color:var(--text-light); }
.match-team-name { font-size:18px; margin-top:10px; }
.match-info-center { text-align:center; flex:1; }
.match-league { margin-bottom:10px; }
.match-league span { display:inline-block; margin:0 8px; color:var(--text-gray); }
.match-score { font-size:48px; font-weight:bold; color:var(--text-dark); }
.match-score span { display:inline-block; min-width:40px; }
.match-status { margin-top:10px; font-size:14px; padding:4px 16px; border-radius:20px; display:inline-block; }
.status-upcoming { background:var(--bg-gray); color:var(--text-gray); }
.status-live { background:#ff4d4f; color:#fff; animation:pulse 1.5s infinite; }
.status-ended { background:var(--bg-gray); color:var(--text-light); }

@keyframes pulse {
  0%,100% { opacity:1; }
  50% { opacity:0.7; }
}

/* 直播信号 */
.match-signal-box { margin-top:20px; padding-top:20px; border-top:1px solid var(--border-color); }
.match-signal-title { font-size:16px; font-weight:bold; margin-bottom:10px; }
.match-signal-title img { width:20px; margin-right:8px; vertical-align:middle; }
.match-signal-list { display:flex; flex-wrap:wrap; gap:8px; }
.match-signal-list a { background:linear-gradient(135deg, var(--primary), var(--primary-light)); color:#fff; padding:6px 24px; border-radius:20px; font-size:13px; display:inline-block; transition:transform 0.3s; }
.match-signal-list a:hover { transform:scale(1.05); color:#fff; }

/* 倒计时 */
.match-countdown { margin-top:15px; padding:12px; background:#333; color:#fff; font-size:18px; border-radius:var(--radius); }

/* 直播介绍 */
.match-intro-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.match-intro-info p { padding:8px 0; font-size:14px; line-height:1.8; border-bottom:1px dashed var(--border-color); }
.match-intro-info p:last-child { border-bottom:none; }
.match-intro-info p span:first-child { color:var(--primary); font-weight:bold; }

/* 赛事详情内容 */
.match-content-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.match-content-body { font-size:15px; line-height:1.8; color:var(--text-dark); }
.match-content-body img { max-width:100%; height:auto; }

/* 相关赛事 */
.match-related-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }

/* 面包屑 */
.breadcrumb-bar { background:var(--bg-white); border-bottom:2px var(--primary-border) solid; font-size:14px; color:var(--text-gray); padding:15px 20px; border-radius:var(--radius) var(--radius) 0 0; }
.breadcrumb-bar a { color:var(--text-dark); }
.breadcrumb-bar a:hover { color:var(--primary); }

/* 底部 */
.site-footer { background:#333; color:#777; padding:20px 0; margin-top:20px; }

/* 列表页通用 */
.list-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.list-item { padding:12px 20px; border-bottom:1px solid #f5f5f5; display:flex; align-items:center; }
.list-item:hover { background:var(--primary-light); }
.list-item-pic { width:120px; height:80px; overflow:hidden; border-radius:var(--radius); margin-right:15px; flex-shrink:0; }
.list-item-pic img { width:100%; height:100%; object-fit:cover; }
.list-item-info { flex:1; }
.list-item-title { font-size:15px; color:var(--text-dark); margin-bottom:5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.list-item-title a { color:var(--text-dark); }
.list-item-title a:hover { color:var(--primary); }
.list-item-meta { font-size:12px; color:var(--text-light); }
.list-item-desc { font-size:13px; color:var(--text-gray); margin-top:5px; overflow:hidden; text-overflow:ellipsis; display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; }

/* 分页 */
.page-nav { text-align:center; padding:20px; }
.page-nav a, .page-nav span { display:inline-block; padding:6px 14px; margin:0 3px; border:1px solid var(--border-color); border-radius:var(--radius); font-size:13px; color:var(--text-dark); }
.page-nav a:hover, .page-nav .current { background:var(--primary); color:#fff; border-color:var(--primary); }

/* 球队/球员网格 */
.team-grid { display:flex; flex-wrap:wrap; padding:10px; }
.team-grid-item { width:calc(25% - 20px); margin:10px; border:1px solid var(--border-color); border-radius:var(--radius); text-align:center; padding:20px 10px; transition:0.3s; }
.team-grid-item:hover { transform:translateY(-2px); border-color:var(--primary); box-shadow:0 5px 15px rgba(0,0,0,0.08); }
.team-grid-item img { width:60px; height:60px; object-fit:contain; margin-bottom:10px; }
.team-grid-item .team-grid-name { font-size:16px; color:var(--text-dark); }
.team-grid-item .team-grid-name a { color:var(--text-dark); }
.team-grid-item:hover .team-grid-name a { color:var(--primary); }

/* 响应式 */
@media only screen and (max-width:767px) {
  .container { width:100%; padding:0 10px; }
  .site-nav-toggler { display:flex; }
  .site-nav-menu { display:none; position:absolute; top:64px; left:0; width:100%; flex-direction:column; background:#fff; box-shadow:0 8px 20px rgba(0,0,0,0.1); z-index:998; }
  .site-nav-menu.open { display:flex; }
  .site-nav-menu li { width:100%; border-bottom:1px solid var(--border-color); }
  .site-nav-menu li a { border-radius:0; padding:14px 20px; }
  #navBox { position:relative; }
  .main-content { width:100%; }
  .sidebar { width:100%; }
  .hot-tags { display:none; }
  .match-scoreboard { flex-direction:column; }
  .match-team { width:100%; margin-bottom:15px; }
  .match-score { font-size:32px; }
  .news-top-pic { width:100%; margin-bottom:10px; }
  .news-top-list { width:100%; padding-left:0; }
  .video-item { width:calc(50% - 8px); }
  .team-grid-item { width:calc(50% - 20px); }
  .match-versus-home, .match-versus-away { min-width:80px; }
  .match-item { flex-wrap:wrap; }
  .match-item-versus { width:100%; margin:8px 0; }
}
/* ============ 第二批模板样式 ============ */

/* 文章详情页 */
.article-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; padding:25px; }
.article-header { border-bottom:1px solid var(--border-color); padding-bottom:15px; margin-bottom:20px; }
.article-title { font-size:24px; color:var(--text-dark); line-height:1.4; margin-bottom:12px; }
.article-meta { font-size:13px; color:var(--text-light); }
.article-meta span { margin-right:15px; }
.article-body { font-size:16px; line-height:1.9; color:var(--text-dark); }
.article-body img { max-width:100%; height:auto; }
.article-body p { margin-bottom:15px; }
.article-tags { margin-top:20px; padding-top:15px; border-top:1px dashed var(--border-color); }
.article-tags span { color:var(--text-gray); }
.article-tags a { display:inline-block; padding:4px 12px; margin:0 5px 5px 0; background:var(--primary-light); color:var(--primary); border-radius:3px; font-size:13px; }
.article-pager { margin-top:20px; padding-top:15px; border-top:1px solid var(--border-color); font-size:14px; line-height:2; }
.article-pager a { color:var(--text-gray); }
.article-pager a:hover { color:var(--primary); }

/* 视频播放盒 */
.video-play-box { margin:20px 0; }
.video-play-link { position:relative; display:block; border-radius:var(--radius); overflow:hidden; }
.video-play-cover { width:100%; display:block; }
.video-play-icon { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:64px; height:64px; background:rgba(26,115,232,0.85) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") no-repeat center; background-size:32px; border-radius:50%; }
.video-source-list { padding:15px; background:var(--bg-gray); border-radius:var(--radius); margin-bottom:20px; }
.video-source-label { font-weight:bold; color:var(--text-dark); margin-right:10px; }
.video-source-list a { display:inline-block; margin:5px 10px 5px 0; color:var(--primary); }

/* 相关推荐面板 */
.related-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.related-item { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px dashed var(--border-color); }
.related-item a { color:var(--text-dark); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; }
.related-item a:hover { color:var(--primary); }
.related-item span { color:var(--text-light); font-size:12px; margin-left:10px; flex-shrink:0; }

/* 紧凑新闻列表（带图） */
.news-list-compact .news-item { padding:12px 0; border-bottom:1px solid #f5f5f5; }
.news-item-pic { width:120px; height:80px; overflow:hidden; border-radius:var(--radius); margin-right:15px; flex-shrink:0; }
.news-item-pic img { width:100%; height:100%; object-fit:cover; }
.news-item-info { flex:1; min-width:0; }
.news-item-title { font-size:16px; color:var(--text-dark); margin-bottom:8px; }
.news-item-title a { color:var(--text-dark); }
.news-item-title a:hover { color:var(--primary); }
.news-item-desc { font-size:13px; color:var(--text-gray); line-height:1.6; overflow:hidden; text-overflow:ellipsis; display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; margin-bottom:8px; }
.news-item-meta { font-size:12px; color:var(--text-light); }
.news-item-meta span { margin-right:15px; }

/* 新闻列表面板 */
.news-list-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.news-list-body { padding:0 20px; }
.news-list-body .news-item { padding:15px 0; border-bottom:1px solid #f5f5f5; }

/* 实体头部卡片（球队/球员/联赛） */
.entity-profile-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; padding:25px; }
.entity-profile-card { gap:20px; }
.entity-profile-logo { width:100px; height:100px; flex-shrink:0; display:flex; align-items:center; justify-content:center; background:var(--bg-gray); border-radius:var(--radius); }
.entity-profile-logo img { max-width:80px; max-height:80px; object-fit:contain; }
.entity-profile-logo-round img { border-radius:50%; }
.entity-profile-name { font-size:24px; color:var(--text-dark); }

/* 视频网格 */
.video-list-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.video-grid { display:flex; flex-wrap:wrap; padding:15px; gap:15px; }
.video-grid-item { width:calc(25% - 12px); background:var(--bg-gray); border-radius:var(--radius); overflow:hidden; transition:0.3s; }
.video-grid-item:hover { box-shadow:0 5px 15px rgba(0,0,0,0.1); }
.video-grid-item-pic { position:relative; height:130px; overflow:hidden; }
.video-grid-item-pic img { width:100%; height:100%; object-fit:cover; transition:0.5s; }
.video-grid-item:hover .video-grid-item-pic img { transform:scale(1.1); }
.video-grid-item-play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:44px; height:44px; background:rgba(26,115,232,0.85) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") no-repeat center; background-size:24px; border-radius:50%; }
.video-grid-item-title { padding:10px; font-size:14px; color:var(--text-dark); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.video-grid-item-meta { padding:0 10px 10px; font-size:12px; color:var(--text-light); }

/* 实体网格（球队/球员列表） */
.entity-list-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.entity-grid { padding:15px; gap:15px; }
.entity-grid-item { width:calc(20% - 12px); text-align:center; padding:20px 10px; border:1px solid var(--border-color); border-radius:var(--radius); transition:0.3s; }
.entity-grid-item:hover { border-color:var(--primary); transform:translateY(-2px); }
.entity-grid-item-pic { height:60px; display:flex; align-items:center; justify-content:center; margin-bottom:10px; }
.entity-grid-item-pic img { max-width:60px; max-height:60px; object-fit:contain; }
.entity-grid-item-name { font-size:14px; color:var(--text-dark); }
.entity-grid-item:hover .entity-grid-item-name { color:var(--primary); }

/* 搜索结果 */
.search-panel { background:var(--bg-white); border-radius:var(--radius); margin-bottom:15px; }
.search-results { padding:0 20px; }
.search-results .news-item { padding:15px 0; border-bottom:1px solid #f5f5f5; }

/* 侧边栏新闻列表 */
.sidebar-news-list { padding:15px 20px; }
.sidebar-news-item { padding:8px 0; border-bottom:1px dashed var(--border-color); }
.sidebar-news-item a { color:var(--text-dark); font-size:14px; display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sidebar-news-item a:hover { color:var(--primary); }

/* 分页 */
.match-pagination { padding:20px; text-align:center; }
.match-pagination a, .match-pagination span, .match-pagination b { display:inline-block; padding:6px 14px; margin:0 3px; border:1px solid var(--border-color); border-radius:var(--radius); font-size:13px; color:var(--text-dark); background:#fff; }
.match-pagination a:hover, .match-pagination b, .match-pagination .current { background:var(--primary); color:#fff; border-color:var(--primary); }

/* 第二批响应式 */
@media only screen and (max-width:767px) {
  .video-grid-item { width:calc(50% - 8px); }
  .entity-grid-item { width:calc(33.33% - 10px); }
  .article-title { font-size:20px; }
  .news-item-pic { width:90px; height:60px; }
  .entity-profile-card { flex-direction:column; text-align:center; }
}
