/* ==========================================================================
   90Phut TV — style.css
   Tông tối, điểm nhấn xanh lá; vừa khít phong cách ảnh gốc.
   ========================================================================== */
:root{
  --bg:        #0a0e14;
  --bg-2:      #0f1620;
  --card:      #131b26;
  --card-2:    #182230;
  --line:      #1f2c3b;
  --text:      #e6edf3;
  --muted:     #8b9bad;
  --green:     #19a34a;
  --green-2:   #21c25c;
  --green-dim: #0e6b32;
  --red:       #e0443e;
  --amber:     #e8a92b;
  --radius:    10px;
  --shadow:    0 2px 10px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
code{background:#000;padding:1px 6px;border-radius:4px;color:var(--green-2);font-size:.85em}

.container{width:min(1180px,94%);margin-inline:auto}

/* ---------- Header ---------- */
.site-header{
  background:linear-gradient(180deg,#0d141d,#0a0e14);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.header-inner{display:flex;align-items:center;gap:22px;height:60px}
.logo{display:flex;align-items:baseline;font-weight:800;font-size:22px;letter-spacing:.5px}
.logo-mark{color:var(--green-2)}
.logo-text{color:#fff}
.main-nav{display:flex;gap:18px;flex:1;flex-wrap:wrap}
.main-nav a{
  font-size:13px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.4px;padding:6px 0;
  border-bottom:2px solid transparent;transition:.15s;
}
.main-nav a:hover{color:var(--text)}
.main-nav a.active{color:var(--green-2);border-color:var(--green-2)}
.badge-trusted{
  background:var(--red);color:#fff;font-size:11px;font-weight:700;
  padding:7px 12px;border-radius:6px;white-space:nowrap;
}

.subbar{background:var(--bg-2);border-bottom:1px solid var(--line)}
.subbar-inner{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:8px 0;font-size:12px;color:var(--muted);
}
.subbar-inner strong{color:var(--green-2)}
.livescore-pill{
  margin-left:auto;color:var(--green-2);font-weight:700;font-size:11px;
  border:1px solid var(--green-dim);border-radius:20px;padding:3px 10px;
}

/* ---------- Section bars ---------- */
.section-bar{
  display:flex;align-items:center;justify-content:space-between;
  margin:26px 0 14px;padding-left:12px;
  border-left:4px solid var(--green);
}
.section-bar.accent{border-color:var(--amber)}
.block-title{font-size:18px;font-weight:800;margin:0;text-transform:uppercase;letter-spacing:.4px}
.muted{color:var(--muted);font-size:12px}

/* ---------- Match grid (tỷ số) ---------- */
.match-grid{
  display:grid;gap:12px;
  grid-template-columns:repeat(auto-fill,minmax(330px,1fr));
}
.match-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;box-shadow:var(--shadow);transition:.15s;
}
.match-card:hover{border-color:var(--green-dim);transform:translateY(-2px)}
.mc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.mc-league{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;
  max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mc-status{font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px}
.mc-live{background:var(--green);color:#fff;animation:pulse 1.6s infinite}
.mc-finished{background:#27313f;color:var(--muted)}
.mc-upcoming{background:#1c2735;color:#b9c6d4}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}

.mc-body{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.mc-team{display:flex;align-items:center;gap:8px;min-width:0}
.mc-team img{width:24px;height:24px;object-fit:contain;flex:none}
.mc-team span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;font-size:14px}
.mc-team-away{justify-content:flex-end;text-align:right}
.mc-score{display:flex;align-items:center;gap:6px;font-weight:800;font-size:20px}
.mc-score em{color:var(--muted);font-style:normal;font-size:15px}
.mc-foot{margin-top:10px;border-top:1px solid var(--line);padding-top:8px}
.mc-link{font-size:12px;color:var(--green-2);font-weight:600}
.mc-link:hover{text-decoration:underline}

/* ---------- Prediction grid (soi kèo) ---------- */
.pred-grid{
  display:grid;gap:16px;
  grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
}
.pred-card{
  background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);scroll-margin-top:80px;
}
.pred-card:target{border-color:var(--amber);box-shadow:0 0 0 2px rgba(232,169,43,.3)}
.pc-head{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.3px;margin-bottom:12px}
.pc-time{color:var(--amber);font-weight:700}
.pc-teams{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:12px}
.pc-team{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:0}
.pc-team img{width:40px;height:40px;object-fit:contain}
.pc-team span{font-weight:700;font-size:13px;text-align:center;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.pc-vs{font-size:12px;font-weight:800;color:var(--muted);flex:none}

.pc-title{font-size:15px;font-weight:800;margin:4px 0 6px;line-height:1.35}
.pc-desc{font-size:13px;color:var(--muted);margin:0 0 14px}

.pc-tips{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.pc-tip{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  padding:8px 6px;text-align:center;min-width:0}
.pc-tip-label{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.3px;margin-bottom:4px}
.pc-tip-value{display:block;font-size:12px;font-weight:700;line-height:1.3;
  overflow:hidden;text-overflow:ellipsis}
.pc-tip-value.score{font-size:18px;color:var(--green-2)}

.pc-confidence{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.pc-conf-label{font-size:11px;color:var(--muted);white-space:nowrap}
.pc-conf-bar{flex:1;height:7px;background:#0b1118;border-radius:6px;overflow:hidden}
.pc-conf-fill{height:100%;border-radius:6px}
.pc-conf-fill.high{background:var(--green-2)}
.pc-conf-fill.mid{background:var(--amber)}
.pc-conf-fill.low{background:var(--red)}
.pc-conf-num{font-size:12px;font-weight:800}

.pc-detail summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--green-2);
  list-style:none;user-select:none}
.pc-detail summary::-webkit-details-marker{display:none}
.pc-detail summary::before{content:"▸ ";color:var(--muted)}
.pc-detail[open] summary::before{content:"▾ "}
.pc-analysis{font-size:13.5px;color:#cfd9e3;margin-top:10px;line-height:1.65}
.pc-note{margin-top:12px;font-size:12px;color:var(--amber);
  background:rgba(232,169,43,.08);border:1px solid rgba(232,169,43,.25);
  border-radius:8px;padding:8px 10px}

/* ---------- Empty state ---------- */
.empty{
  background:var(--card);border:1px dashed var(--line);border-radius:var(--radius);
  padding:24px;text-align:center;color:var(--muted);font-size:14px;
}

/* ---------- Intro + footer ---------- */
.intro{margin-top:34px}
.intro-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.intro h3{font-size:14px;color:var(--green-2);margin:0 0 6px}
.intro p{font-size:13px;color:#c2cdd8;margin:0 0 14px}
.intro-list{margin:0;padding-left:18px;font-size:13px;color:#c2cdd8}
.intro-list li{margin-bottom:6px}

.site-footer{margin-top:34px;background:var(--bg-2);border-top:1px solid var(--line);
  padding:26px 0;text-align:center}
.footer-logo{font-weight:800;font-size:24px;margin-bottom:12px}
.footer-logo .logo-mark{color:var(--green-2)}
.responsible{max-width:760px;margin:0 auto 10px;font-size:12.5px;color:#c2cdd8;line-height:1.6}
.copyright{font-size:12px;color:var(--muted);margin:0}

/* ---------- Responsive ---------- */
@media(max-width:720px){
  .main-nav{display:none}
  .intro-grid{grid-template-columns:1fr}
  .match-grid{grid-template-columns:1fr}
  .header-inner{height:54px}
}

/* ==========================================================================
   预测卡 CTA + 单场详情页样式
   ========================================================================== */
.pc-title a{color:inherit}
.pc-title a:hover{color:var(--green-2)}
.pc-cta{display:inline-block;margin-top:12px;font-size:12.5px;font-weight:700;
  color:var(--green-2)}
.pc-cta:hover{text-decoration:underline}

/* 面包屑 */
.detail{padding-top:6px}
.crumbs{font-size:12px;color:var(--muted);margin:14px 0}
.crumbs a{color:var(--green-2)}
.crumbs a:hover{text-decoration:underline}

/* 比赛大头 */
.detail-hero{background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-bottom:14px}
.dh-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.dh-league{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.dh-teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px}
.dh-team{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.dh-team img{width:64px;height:64px;object-fit:contain}
.dh-team strong{font-size:16px}
.dh-score{display:flex;align-items:center;gap:10px;font-size:40px;font-weight:800}
.dh-score em{color:var(--muted);font-style:normal}
.dh-vs{font-size:22px;color:var(--muted);font-weight:800}
.dh-score small{display:block;font-size:13px;color:var(--green-2);font-weight:700;text-align:center}
.dh-info{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:16px;
  font-size:12.5px;color:var(--muted)}

/* 直播位 */
.player{margin-bottom:18px}
.player-frame{position:relative;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:#000}
.player-frame iframe{position:absolute;inset:0;width:100%;height:100%}
.player-placeholder{aspect-ratio:16/9;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:8px;text-align:center;background:#0b1018;border:1px dashed var(--line);
  border-radius:var(--radius);color:var(--muted);padding:20px}
.pp-icon{width:60px;height:60px;border-radius:50%;background:var(--green);color:#fff;
  display:grid;place-items:center;font-size:24px;margin-bottom:6px}
.player-placeholder p{margin:0;font-size:14px;color:#c2cdd8}
.player-placeholder small{font-size:12px}

/* 详情两栏 */
.detail-grid{display:grid;grid-template-columns:1fr 320px;gap:18px}
.detail-article{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.da-title{font-size:22px;font-weight:800;margin:0 0 8px;line-height:1.3}
.da-lead{font-size:14.5px;color:#c2cdd8;margin:0 0 18px}
.da-tips{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.da-h2{font-size:16px;font-weight:800;margin:20px 0 10px;padding-left:10px;border-left:3px solid var(--green)}
.da-body{font-size:14.5px;line-height:1.75;color:#d4dde6}

/* 侧栏 */
.detail-side{display:flex;flex-direction:column;gap:14px}
.side-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.side-title{font-size:14px;font-weight:800;margin:0 0 12px}
.side-title small{color:var(--muted);font-weight:500}
.side-hint{font-size:11px;color:var(--muted);margin:10px 0 0}

.odds-block{margin-bottom:12px}
.odds-name{font-size:12px;color:var(--muted);margin-bottom:6px}
.odds-values{display:flex;gap:6px;flex-wrap:wrap}
.odds-cell{display:flex;flex-direction:column;align-items:center;gap:2px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:6px 8px;min-width:52px}
.odds-cell em{font-style:normal;font-size:10px;color:var(--muted)}
.odds-cell strong{font-size:13px;color:var(--green-2)}

.h2h{width:100%;border-collapse:collapse;font-size:12px}
.h2h td{padding:6px 4px;border-bottom:1px solid var(--line)}
.h2h-date{color:var(--muted);white-space:nowrap}
.h2h-score{font-weight:800;text-align:center;color:var(--green-2)}
.h2h-home{text-align:right}
.h2h-away{text-align:left}

.responsible-box{background:rgba(232,169,43,.06);border-color:rgba(232,169,43,.25)}
.responsible-box strong{color:var(--amber);display:block;margin-bottom:6px;font-size:13px}
.responsible-box p{margin:0;font-size:12px;color:#c2cdd8;line-height:1.6}

.back-home{margin:20px 0 0}

@media(max-width:860px){
  .detail-grid{grid-template-columns:1fr}
  .dh-team img{width:48px;height:48px}
  .dh-score{font-size:32px}
}

/* ==========================================================================
   列表页：日期导航 + 页脚链接
   ========================================================================== */
.date-nav{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 0 18px}
.dn-btn{background:var(--card);border:1px solid var(--line);border-radius:8px;
  padding:8px 16px;font-size:13px;font-weight:600;color:var(--text);transition:.15s}
.dn-btn:hover{border-color:var(--green-dim);color:var(--green-2)}
.dn-current{font-size:15px;font-weight:800;color:var(--green-2);min-width:90px;text-align:center}

.footer-links{margin:0 0 10px;font-size:12.5px;color:var(--muted)}
.footer-links a{color:var(--green-2)}
.footer-links a:hover{text-decoration:underline}

/* ==========================================================================
   联赛分组标题 + 分页
   ========================================================================== */
.league-head{display:flex;align-items:center;gap:10px;margin:22px 0 10px;
  padding:8px 12px;background:var(--bg-2);border:1px solid var(--line);
  border-left:4px solid var(--green);border-radius:8px}
.league-head img{width:22px;height:22px;object-fit:contain;flex:none}
.lh-name{font-weight:800;font-size:14px}
.lh-country{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.lh-country::before{content:"· "}

.pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:6px;margin:26px 0 6px}
.pg-btn{min-width:38px;text-align:center;background:var(--card);border:1px solid var(--line);
  border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;color:var(--text);transition:.15s}
.pg-btn:hover{border-color:var(--green-dim);color:var(--green-2)}
.pg-btn.active{background:var(--green);border-color:var(--green);color:#fff}
.pg-gap{color:var(--muted);padding:0 2px}
.pg-info{text-align:center;font-size:12px;color:var(--muted);margin:0 0 6px}

/* ==========================================================================
   首页筛选条 + 加载更多按钮
   ========================================================================== */
.filterbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--bg-2);border:1px solid var(--line);border-radius:14px;
  padding:12px;margin:18px 0}
.fb-tabs{display:flex;gap:10px;flex-wrap:wrap;flex:1}
.fb-tab{display:inline-flex;align-items:center;gap:8px;
  background:var(--card);border:1px solid var(--line);border-radius:24px;
  padding:9px 16px;font-size:13px;font-weight:700;color:var(--muted);transition:.15s}
.fb-tab:hover{border-color:var(--green-dim);color:var(--text)}
.fb-tab.active{color:#fff;border-color:var(--green);
  box-shadow:inset 0 0 0 1px var(--green);background:rgba(25,163,74,.12)}
.fb-tab.active .fb-ico{color:var(--green-2)}
.fb-ico{display:inline-flex;color:var(--muted)}
.fb-count{display:inline-grid;place-items:center;min-width:22px;height:20px;padding:0 6px;
  background:#0b1118;border:1px solid var(--line);border-radius:11px;
  font-size:11px;font-weight:800;color:var(--green-2)}
.fb-tab.active .fb-count{background:var(--green);border-color:var(--green);color:#fff}

/* 联赛下拉 */
.fb-league{position:relative}
.fbl-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  background:var(--card);border:1px solid var(--line);border-radius:24px;
  padding:9px 14px;font-size:13px;font-weight:700;color:var(--text)}
.fbl-toggle:hover{border-color:var(--green-dim)}
.fbl-toggle.open .fbl-caret{transform:rotate(180deg)}
.fbl-caret{transition:.15s;color:var(--muted)}
.fbl-count{display:inline-grid;place-items:center;min-width:22px;height:20px;padding:0 6px;
  background:var(--green);border-radius:11px;font-size:11px;font-weight:800;color:#fff}
.fbl-count:empty{display:none}
.fbl-panel{position:absolute;right:0;top:calc(100% + 8px);z-index:40;width:300px;max-height:60vh;
  overflow:auto;background:var(--card-2);border:1px solid var(--line);border-radius:12px;
  box-shadow:0 12px 30px rgba(0,0,0,.5);padding:8px}
.fbl-head{font-size:12px;font-weight:800;color:var(--green-2);text-transform:uppercase;
  letter-spacing:.4px;padding:8px 10px}
.fbl-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;
  font-size:13px;font-weight:600;color:var(--text);transition:.12s}
.fbl-item:hover{background:var(--bg-2)}
.fbl-item.active{background:rgba(25,163,74,.12);color:var(--green-2)}
.fbl-item img{width:20px;height:20px;object-fit:contain;flex:none}
.fbl-globe{width:20px;text-align:center;flex:none}
.fbl-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fbl-num{font-size:12px;font-weight:800;color:var(--muted)}

/* 加载更多（绿色） */
.mg-item.is-hidden{display:none}
.load-more-wrap{display:flex;justify-content:center;margin:22px 0 6px}
.btn-load-more{display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  background:linear-gradient(180deg,var(--green-2),var(--green));
  color:#fff;border:none;border-radius:10px;padding:13px 30px;
  font-size:15px;font-weight:800;letter-spacing:.3px;
  box-shadow:0 4px 14px rgba(25,163,74,.35);transition:.15s}
.btn-load-more:hover{filter:brightness(1.07);transform:translateY(-1px)}
.btn-load-more:active{transform:translateY(0)}
.btn-load-more svg{opacity:.9}

@media(max-width:720px){
  .filterbar{padding:10px}
  .fb-label{display:none}        /* 手机上只留图标+计数，省空间 */
  .fb-tab{padding:9px 12px}
  .fb-league{width:100%}
  .fbl-toggle{width:100%;justify-content:center}
  .fbl-panel{width:100%}
}

/* AJAX 切换加载态 */
#homeFilterZone.is-loading{opacity:.5;pointer-events:none;transition:opacity .15s}
