/* =============================================================
   LL HOME — page-specific styles
   Only loaded on pages using the LL Home template.
   ============================================================= */

/* ── SECTION ── */
.section { padding:0 0 24px; }
.section-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.section-title { font-weight:900; font-size:15px; letter-spacing:0.5px; color:var(--text-main); display:flex; align-items:center; gap:10px; }
.section-title::before { content:''; width:4px; height:15px; background:var(--blue); border-radius:2px; }
.section-link { font-size:13px; font-weight:600; color:var(--text-muted); text-decoration:none; transition:color 0.15s; }
.section-link:hover { color:var(--blue); }
.section-divider { border:none; border-top:1px solid var(--border); margin-bottom:24px; }

/* ── FEATURED MATCHES ── */
.featured-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.featured-head-title { font-weight:900; font-size:15px; letter-spacing:1px; color:var(--text-main); display:flex; align-items:center; gap:10px; }
.featured-head-title::before { content:''; width:4px; height:15px; background:var(--blue); border-radius:2px; }
.featured-head-live { font-size:11px; font-weight:700; letter-spacing:1.5px; color:#fff; background:#ef4444; padding:3px 9px; border-radius:4px; animation:pulse 2s infinite; }
.featured-grid { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:190px 190px; gap:8px; }

/* ── MATCH CARDS ── */
.mc { position:relative; border-radius:var(--r); overflow:hidden; text-decoration:none; display:block; transition:transform 0.2s, box-shadow 0.2s; }
.mc:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,0.25); text-decoration:none; }
.mc-img { width:100%; height:100%; object-fit:cover; display:block; filter:brightness(0.4); transition:filter 0.3s; }
.mc:hover .mc-img { filter:brightness(0.52); }
.mc-overlay { position:absolute; inset:0; background:linear-gradient(160deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.80) 100%); }
.mc-accent { position:absolute; top:0; left:0; right:0; height:3px; }
.mc-body { position:absolute; inset:0; padding:14px 16px; display:flex; flex-direction:column; justify-content:flex-end; z-index:2; }
.mc-league { font-size:10px; font-weight:700; letter-spacing:2px; color:rgba(255,255,255,0.6); margin-bottom:5px; }
.mc-title { font-weight:900; font-size:15px; line-height:1.2; color:#fff; margin-bottom:9px; }
.mc-footer { display:flex; align-items:center; justify-content:space-between; }
.mc-badge { font-weight:800; font-size:10px; letter-spacing:0.5px; padding:3px 9px; border-radius:3px; color:#fff; }
.mc-time { font-size:11px; font-weight:600; color:rgba(255,255,255,0.55); }

/* ── WORLD CUP HUB ── */
.wc-hub { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:8px; border-radius:var(--r); background:linear-gradient(135deg, #002868 0%, #003f9e 45%, #bf0a30 100%); border:1px solid rgba(255,255,255,0.1); text-decoration:none; padding:14px 20px; transition:opacity 0.15s; }
.wc-hub:hover { opacity:0.92; text-decoration:none; }
.wc-left { display:flex; align-items:center; gap:12px; }
.wc-trophy { font-size:28px; flex-shrink:0; }
.wc-label { font-size:10px; font-weight:700; letter-spacing:2.5px; color:rgba(255,255,255,0.55); margin-bottom:2px; }
.wc-title { font-weight:900; font-size:16px; color:#fff; line-height:1.1; }
.wc-sub { font-size:11px; color:rgba(255,255,255,0.55); margin-top:2px; }
.wc-right { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.wc-stat { text-align:center; }
.wc-stat-num { font-weight:900; font-size:20px; color:#fff; line-height:1; }
.wc-stat-lbl { font-size:10px; color:rgba(255,255,255,0.5); letter-spacing:0.5px; margin-top:1px; }
.wc-divider { width:1px; height:30px; background:rgba(255,255,255,0.2); }
.wc-cta { background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.3); color:#fff; font-weight:700; font-size:13px; padding:8px 16px; border-radius:6px; white-space:nowrap; }

/* ── ACCA STRIP ── */
.acca-strip { display:grid; grid-template-columns:repeat(2,1fr); gap:8px; }
.acca-card { background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; text-decoration:none; transition:all 0.15s; display:flex; flex-direction:column; }
.acca-card:hover { border-color:var(--border-mid); transform:translateY(-2px); text-decoration:none; }
.acca-top { height:3px; }
.acca-body { padding:14px; flex:1; }
.acca-type { font-weight:800; font-size:14px; color:var(--text-main); margin-bottom:4px; }
.acca-legs { font-size:12px; color:var(--text-muted); margin-bottom:10px; }
.acca-odds-wrap { display:flex; align-items:baseline; gap:5px; }
.acca-odds { font-weight:900; font-size:24px; line-height:1; }
.acca-odds-lbl { font-size:13px; color:var(--text-muted); }
.acca-foot { padding:9px 14px; background:var(--bg-card); border-top:1px solid var(--border); font-weight:700; font-size:12px; display:flex; align-items:center; justify-content:space-between; color:var(--text-muted); }
.acca-all-link { display:block; text-align:center; margin-top:10px; padding:10px; background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--r); font-weight:700; font-size:13px; color:var(--text-sec); text-decoration:none; transition:all 0.15s; }
.acca-all-link:hover { border-color:var(--blue); color:var(--blue); text-decoration:none; }

/* ── WC BLOG STRIP & LATEST ARTICLES ── */
.wc-blog-strip { display:flex; flex-direction:column; gap:6px; }
.wc-blog-card { display:flex; align-items:center; gap:14px; padding:13px 16px; background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--r); text-decoration:none; transition:all 0.15s; position:relative; overflow:hidden; }
.wc-blog-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:transparent; transition:background 0.15s; }
.wc-blog-card:hover { background:var(--bg-card); border-color:var(--border-mid); text-decoration:none; }
.wc-blog-card:hover::before { background:linear-gradient(to bottom, #002868, #bf0a30); }
.wc-blog-flag { font-size:22px; flex-shrink:0; width:32px; text-align:center; }
.article-icon { font-size:20px; flex-shrink:0; width:44px; height:44px; border-radius:var(--r); background:var(--bg-card); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; }
.wc-blog-body { flex:1; min-width:0; }
.wc-blog-cat { font-size:10px; font-weight:700; letter-spacing:2px; color:var(--blue); margin-bottom:3px; }
.wc-blog-title { font-weight:800; font-size:14px; color:var(--text-main); line-height:1.3; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.wc-blog-meta { font-size:11px; color:var(--text-muted); margin-top:3px; }
.wc-blog-arrow { font-size:13px; color:var(--text-muted); flex-shrink:0; transition:color 0.15s; }
.wc-blog-card:hover .wc-blog-arrow { color:var(--blue); }

/* ── SEO BLOCK ── */
.seo-block { border-top:1px solid var(--border); padding-top:24px; padding-left:16px; padding-right:16px; }
.seo-title { font-weight:900; font-size:20px; color:var(--text-main); margin-bottom:12px; line-height:1.3; }
.seo-h3 { font-weight:800; font-size:15px; color:var(--text-main); margin:20px 0 6px; }
.seo-p { font-size:15px; color:var(--text-main); line-height:1.8; margin-bottom:10px; }
.seo-p a { color:var(--blue); }
.seo-p a:hover { text-decoration:underline; }
.seo-text { max-width:100%; padding:2rem 0; font-size:15px; line-height:1.8; color:var(--text-sec); }
.seo-text h2 { font-size:20px; font-weight:500; color:var(--text-primary); margin:1.5rem 0 0.5rem; }
.seo-text h3 { font-size:16px; font-weight:500; color:var(--text-primary); margin:1.5rem 0 0.5rem; }
.seo-text a { color:var(--blue); }
.seo-text a:hover { text-decoration:underline; }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .acca-strip { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
  .featured-grid { grid-template-rows:150px 150px; gap:6px; }
  .mc-title { font-size:13px; }
  .wc-hub { flex-wrap:wrap; gap:10px; padding:12px 14px; }
  .wc-title { font-size:14px; }
  .acca-strip { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) {
  .featured-grid { grid-template-columns:1fr; grid-template-rows:repeat(4,220px); }
  .acca-strip { grid-template-columns:1fr; }
  .wc-right { width:100%; justify-content:space-between; }
}
