/* 字体定义 - 使用系统字体回退方案避免外部请求延迟 */
@font-face{font-family:'Oswald';font-style:normal;font-weight:400;font-display:swap;src:local('Oswald Regular'),local('Oswald-Regular');}
@font-face{font-family:'Oswald';font-style:normal;font-weight:700;font-display:swap;src:local('Oswald Bold'),local('Oswald-Bold');}
@font-face{font-family:'Roboto';font-style:normal;font-weight:400;font-display:swap;src:local('Roboto'),local('Roboto-Regular');}
@font-face{font-family:'Roboto';font-style:normal;font-weight:700;font-display:swap;src:local('Roboto Bold'),local('Roboto-Bold');}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--green-primary:#1B4332;--green-dark:#0d2818;--green-light:#2d6a4f;--green-field:#245c3a;--white:#FFFFFF;--gold:#FFD700;--gold-dark:#c9a800;--black:#1A1A1A;--gray-light:#f0f4f0;--gray-mid:#b0b8b0;--red-card:#e63946;--yellow-card:#f4d35e;--shadow-card:0 4px 16px rgba(0,0,0,0.13);--radius:12px;--font-title:'Oswald',sans-serif;--font-body:'Roboto',sans-serif}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--black);background:var(--green-primary);line-height:1.7;overflow-x:hidden}
body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(0deg,rgba(255,255,255,0.02) 0px,rgba(255,255,255,0.02) 2px,transparent 2px,transparent 30px);pointer-events:none;z-index:0}
a{text-decoration:none;color:inherit;transition:color .2s}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{font-family:var(--font-title);font-weight:700;line-height:1.3}
.pitch-jammer{display:none!important;visibility:hidden!important;position:absolute!important;width:0!important;height:0!important;overflow:hidden!important}
.stadium-wrap{position:relative;z-index:1;min-height:100vh}
/* 导航 */
.nav-bar{background:var(--green-dark);border-bottom:3px solid var(--gold);padding:0 20px}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo img{height:48px;width:auto}
.nav-links{display:flex;gap:6px;list-style:none}
.nav-links li a{font-family:var(--font-title);font-size:15px;color:var(--white);padding:8px 14px;border-radius:6px;transition:background .2s,color .2s;letter-spacing:.5px}
.nav-links li a:hover,.nav-links li a.active{background:var(--gold);color:var(--green-dark)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{display:block;width:26px;height:3px;background:var(--white);border-radius:2px;transition:transform .3s}
/* Hero 实时比分大屏 */
.hero-scoreboard{background:var(--black);padding:48px 20px 36px;text-align:center;position:relative;overflow:hidden}
.hero-scoreboard::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(27,67,50,0.35) 0%,transparent 70%);pointer-events:none}
.hero-scoreboard h1{font-family:var(--font-title);font-size:28px;color:var(--gold);margin-bottom:8px;text-transform:uppercase;letter-spacing:2px}
.hero-scoreboard .sub-text{color:var(--gray-mid);font-size:14px;margin-bottom:28px}
.score-main{display:flex;align-items:center;justify-content:center;gap:30px;margin-bottom:32px;flex-wrap:wrap}
.team-block{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:120px}
.team-block .team-badge{width:64px;height:64px;border-radius:50%;background:var(--green-dark);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--gold);font-family:var(--font-title);border:2px solid var(--gold)}
.team-block .team-name{color:var(--white);font-family:var(--font-title);font-size:16px}
.score-display{display:flex;align-items:center;gap:10px}
.score-num{font-family:var(--font-title);font-size:72px;color:var(--gold);text-shadow:0 0 20px rgba(255,215,0,0.5);line-height:1;min-width:60px;text-align:center}
.score-sep{font-family:var(--font-title);font-size:48px;color:var(--white)}
.match-status{display:inline-block;background:var(--red-card);color:var(--white);padding:4px 14px;border-radius:20px;font-size:13px;font-family:var(--font-title);animation:pulse-live 1.5s infinite}
@keyframes pulse-live{0%,100%{opacity:1}50%{opacity:.6}}
.ticker-bar{display:flex;gap:16px;overflow-x:auto;padding:16px 0;scrollbar-width:thin}
.ticker-item{flex-shrink:0;background:rgba(255,255,255,0.06);border:1px solid rgba(255,215,0,0.2);border-radius:8px;padding:10px 18px;display:flex;align-items:center;gap:12px;min-width:260px}
.ticker-item .t-teams{font-size:13px;color:var(--white);font-family:var(--font-body)}
.ticker-item .t-score{font-family:var(--font-title);font-size:20px;color:var(--gold);min-width:50px;text-align:center}
.ticker-item .t-time{font-size:11px;color:var(--gray-mid)}
/* 通用Section */
.pitch-module{max-width:1280px;margin:0 auto;padding:48px 20px}
.section-header{text-align:center;margin-bottom:36px}
.section-header h2{font-size:28px;color:var(--white);position:relative;display:inline-block;padding-bottom:12px}
.section-header h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--gold);border-radius:2px}
.section-header p{color:var(--gray-mid);font-size:15px;margin-top:10px}
/* 卡片通用 */
.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden;transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,0.18)}
/* 核心优势 */
.advantage-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.advantage-card{background:linear-gradient(145deg,var(--green-primary),var(--green-light));border-radius:var(--radius);padding:32px 24px;text-align:center;border:1px solid rgba(255,215,0,0.15);transition:border-color .3s}
.advantage-card:hover{border-color:var(--gold)}
.advantage-card .adv-icon{width:56px;height:56px;margin:0 auto 16px;background:rgba(255,255,255,0.12);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px}
.advantage-card h3{font-family:var(--font-title);color:var(--gold);font-size:18px;margin-bottom:10px}
.advantage-card p{color:rgba(255,255,255,0.85);font-size:14px;line-height:1.7}
/* 赛事列表 */
.match-filters{display:flex;gap:10px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}
.filter-btn{font-family:var(--font-title);padding:8px 22px;border-radius:20px;border:2px solid var(--gold);background:transparent;color:var(--gold);cursor:pointer;font-size:14px;transition:all .2s}
.filter-btn.active,.filter-btn:hover{background:var(--gold);color:var(--green-dark)}
.match-list{display:flex;flex-direction:column;gap:10px}
.match-row{background:var(--white);border-radius:var(--radius);padding:14px 24px;display:grid;grid-template-columns:80px 1fr 100px 1fr 120px;align-items:center;gap:12px;transition:border-color .3s;border-left:4px solid transparent}
.match-row.live{border-left-color:var(--red-card);animation:glow-border 2s infinite}
.match-row.finished{border-left-color:var(--gray-mid)}
.match-row.upcoming{border-left-color:var(--gold)}
@keyframes glow-border{0%,100%{box-shadow:0 0 0 rgba(230,57,70,0)}50%{box-shadow:0 0 12px rgba(230,57,70,0.3)}}
.match-time{font-family:var(--font-title);font-size:14px;color:var(--green-primary);text-align:center}
.match-team{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}
.match-team.away{justify-content:flex-end;text-align:right}
.match-team .badge-sm{width:28px;height:28px;border-radius:50%;background:var(--green-primary);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--gold);font-family:var(--font-title);flex-shrink:0}
.match-score-cell{text-align:center;font-family:var(--font-title);font-size:22px;color:var(--green-primary)}
.match-score-cell .half{font-size:11px;color:var(--gray-mid);display:block}
.match-status-tag{font-size:11px;padding:3px 10px;border-radius:10px;text-align:center;font-family:var(--font-title)}
.tag-live{background:var(--red-card);color:var(--white)}
.tag-fin{background:var(--gray-mid);color:var(--white)}
.tag-soon{background:var(--gold);color:var(--green-dark)}
/* 积分榜 */
.tabs-league{display:flex;gap:6px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}
.tab-btn{font-family:var(--font-title);padding:8px 20px;border:2px solid rgba(255,215,0,0.3);border-radius:8px;background:transparent;color:var(--white);cursor:pointer;font-size:14px;transition:all .2s}
.tab-btn.active,.tab-btn:hover{background:var(--gold);color:var(--green-dark);border-color:var(--gold)}
.standings-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden}
.standings-table th{background:var(--green-primary);color:var(--gold);font-family:var(--font-title);font-size:13px;padding:10px 8px;text-align:center}
.standings-table td{padding:9px 8px;text-align:center;font-size:13px;border-bottom:1px solid var(--gray-light)}
.standings-table tr.ucl-zone{background:rgba(27,67,50,0.08)}
.standings-table tr.rel-zone{background:rgba(230,57,70,0.08)}
.standings-table .team-cell{text-align:left;display:flex;align-items:center;gap:8px;font-weight:500}
/* 赔率 */
.odds-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.odds-table{width:100%;min-width:700px;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden}
.odds-table th{background:var(--green-primary);color:var(--gold);font-family:var(--font-title);font-size:13px;padding:10px 12px}
.odds-table td{padding:10px 12px;text-align:center;font-size:13px;border-bottom:1px solid var(--gray-light)}
.odds-up{color:var(--red-card);font-weight:700}
.odds-down{color:var(--green-primary);font-weight:700}
/* 射手榜 */
.twin-towers{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.tower-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}
.tower-card .tower-header{background:var(--green-primary);padding:16px 20px;display:flex;align-items:center;gap:10px}
.tower-card .tower-header h3{color:var(--gold);font-family:var(--font-title);font-size:18px}
.tower-card .tower-header .t-icon{font-size:22px}
.player-row{display:flex;align-items:center;padding:12px 20px;border-bottom:1px solid var(--gray-light);gap:12px}
.player-row .rank-num{font-family:var(--font-title);font-size:18px;color:var(--green-primary);min-width:30px;text-align:center}
.player-row .rank-num.top3{color:var(--gold)}
.player-row .p-avatar{width:40px;height:40px;border-radius:50%;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--white);flex-shrink:0}
.player-row .p-info{flex:1}
.player-row .p-name{font-weight:500;font-size:14px}
.player-row .p-team{font-size:12px;color:var(--gray-mid)}
.player-row .p-stat{font-family:var(--font-title);font-size:20px;color:var(--green-primary)}
/* 伤停情报 */
.injury-list{display:flex;flex-direction:column;gap:12px}
.injury-card{background:var(--white);border-radius:var(--radius);border-left:4px solid var(--red-card);padding:16px 20px;box-shadow:var(--shadow-card)}
.injury-card .inj-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.injury-card .inj-header .cross-icon{color:var(--red-card);font-size:18px}
.injury-card .inj-header h4{font-family:var(--font-title);font-size:16px;color:var(--green-primary)}
.injury-card .inj-player{font-size:14px;margin-bottom:4px}
.injury-card .inj-type{font-size:13px;color:var(--gray-mid)}
.injury-card .inj-return{font-size:13px;color:var(--red-card);font-weight:500}
/* 赛程日历 */
.calendar-wrap{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-card)}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.cal-header h3{font-family:var(--font-title);font-size:20px;color:var(--green-primary)}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:36px;height:36px;border-radius:50%;border:2px solid var(--green-primary);background:transparent;color:var(--green-primary);cursor:pointer;font-size:16px;transition:all .2s}
.cal-nav button:hover{background:var(--green-primary);color:var(--white)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}
.cal-grid .day-header{font-family:var(--font-title);font-size:13px;color:var(--green-primary);padding:8px 0}
.cal-grid .day-cell{padding:10px 4px;border-radius:8px;font-size:14px;cursor:pointer;transition:background .2s;position:relative}
.cal-grid .day-cell:hover{background:var(--gray-light)}
.cal-grid .day-cell.has-match::after{content:'⚽';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-size:10px}
.cal-grid .day-cell.today{background:var(--gold);color:var(--green-dark);font-weight:700;border-radius:50%}
.cal-grid .day-cell.selected{background:var(--green-primary);color:var(--white);border-radius:50%}
.cal-matches{margin-top:20px;border-top:2px solid var(--gray-light);padding-top:16px}
/* 图集 */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:16/10}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item .g-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,0.75));padding:16px;transform:translateY(100%);transition:transform .3s}
.gallery-item:hover .g-overlay{transform:translateY(0)}
.gallery-item .g-overlay p{color:var(--white);font-size:13px}
/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:10px;max-width:860px;margin:0 auto}
.faq-item{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}
.faq-q{display:flex;align-items:center;gap:12px;padding:16px 20px;cursor:pointer;font-family:var(--font-title);font-size:16px;color:var(--green-primary);transition:background .2s}
.faq-q:hover{background:var(--gray-light)}
.faq-q .whistle{font-size:18px}
.faq-q .arrow{margin-left:auto;transition:transform .3s;font-size:14px}
.faq-item.open .faq-q .arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 20px}
.faq-item.open .faq-a{max-height:500px;padding:0 20px 16px}
.faq-a p{font-size:14px;color:var(--black);line-height:1.8}
/* 页脚 */
.site-footer{background:var(--green-dark);border-top:3px solid var(--gold);padding:48px 20px 24px;margin-top:48px}
.footer-inner{max-width:1280px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-bottom:32px}
.footer-col h4{font-family:var(--font-title);color:var(--gold);font-size:16px;margin-bottom:14px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{color:rgba(255,255,255,0.75);font-size:14px;transition:color .2s}
.footer-col ul li a:hover{color:var(--gold)}
.footer-col p{color:rgba(255,255,255,0.65);font-size:13px;line-height:1.7}
.footer-social{display:flex;gap:12px;margin-top:10px}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:16px;transition:background .2s}
.footer-social a:hover{background:var(--gold);color:var(--green-dark)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:20px;text-align:center}
.footer-bottom p{color:rgba(255,255,255,0.5);font-size:13px;margin-bottom:6px}
.footer-disclaimer{color:rgba(255,255,255,0.4);font-size:12px;max-width:700px;margin:0 auto;line-height:1.6}
/* 面包屑 */
.breadcrumb{max-width:1280px;margin:0 auto;padding:14px 20px;font-size:13px;color:rgba(255,255,255,0.6)}
.breadcrumb a{color:var(--gold);transition:opacity .2s}
.breadcrumb a:hover{opacity:.8}
.breadcrumb span{margin:0 6px}
/* 内页Hero */
.inner-hero{background:linear-gradient(135deg,var(--green-dark),var(--green-primary));padding:48px 20px;text-align:center}
.inner-hero h1{font-size:32px;color:var(--gold);margin-bottom:10px}
.inner-hero p{color:rgba(255,255,255,0.8);font-size:15px;max-width:640px;margin:0 auto}
/* 内页内容 */
.inner-content{max-width:960px;margin:0 auto;padding:40px 20px}
.inner-content .content-card{background:var(--white);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow-card);margin-bottom:28px}
.inner-content h2{font-family:var(--font-title);font-size:24px;color:var(--green-primary);margin-bottom:16px}
.inner-content h3{font-family:var(--font-title);font-size:20px;color:var(--green-primary);margin:24px 0 12px}
.inner-content p{font-size:15px;line-height:1.85;margin-bottom:14px;color:var(--black)}
.inner-content .article-img{border-radius:var(--radius);overflow:hidden;margin:20px 0}
.inner-content .article-img img{width:100%;height:auto;display:block}
.inner-content .img-caption{font-size:12px;color:var(--gray-mid);text-align:center;margin-top:6px}
/* 文本块 */
.text-block{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-card);margin-bottom:24px}
.text-block h3{font-family:var(--font-title);font-size:20px;color:var(--green-primary);margin-bottom:12px}
.text-block p{font-size:15px;line-height:1.85;color:var(--black);margin-bottom:12px}
/* APP下载页 */
.app-hero{background:linear-gradient(135deg,var(--green-dark) 0%,var(--green-primary) 50%,var(--green-field) 100%);padding:60px 20px;text-align:center;position:relative;overflow:hidden}
.app-hero::before{content:'';position:absolute;bottom:-50px;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;border:2px dashed rgba(255,215,0,0.15);pointer-events:none}
.app-hero h1{font-size:32px;color:var(--gold);margin-bottom:12px}
.app-hero .sub{color:rgba(255,255,255,0.8);font-size:16px;margin-bottom:32px}
.app-features{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:700px;margin:0 auto 36px}
.app-feat-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,215,0,0.2);border-radius:var(--radius);padding:20px;text-align:left}
.app-feat-card .feat-icon{font-size:28px;margin-bottom:8px}
.app-feat-card h4{font-family:var(--font-title);color:var(--gold);font-size:16px;margin-bottom:6px}
.app-feat-card p{color:rgba(255,255,255,0.8);font-size:13px;line-height:1.6}
.qr-section{display:flex;gap:32px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:24px}
.qr-box{background:var(--white);border-radius:var(--radius);padding:24px;text-align:center;min-width:180px}
.qr-box .qr-placeholder{width:140px;height:140px;background:var(--gray-light);border-radius:8px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gray-mid);border:2px dashed var(--green-primary)}
.qr-box h4{font-family:var(--font-title);color:var(--green-primary);font-size:15px}
/* 响应式 */
@media(max-width:1024px){.advantage-grid{grid-template-columns:repeat(2,1fr)}.twin-towers{grid-template-columns:1fr}.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
.nav-links{display:none;position:absolute;top:68px;left:0;right:0;background:var(--green-dark);flex-direction:column;padding:16px;gap:4px;border-top:2px solid var(--gold);z-index:100}
.nav-links.open{display:flex}
.hamburger{display:flex}
.score-num{font-size:48px}
.match-row{grid-template-columns:60px 1fr 80px 1fr;font-size:13px}
.match-row .match-status-tag{display:none}
.advantage-grid{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:repeat(2,1fr)}
.app-features{grid-template-columns:1fr}
.footer-grid{grid-template-columns:1fr}
.hero-scoreboard h1{font-size:22px}
}
@media(max-width:480px){
.score-num{font-size:36px}
.gallery-grid{grid-template-columns:1fr}
.ticker-item{min-width:220px}
}
