/* ─────────────────────────────────────
   Blog CSS — full contrast, readable
   ───────────────────────────────────── */

/* ── Article hero ── */
.blog-article { padding-top: 56px; }
.article-hero { position: relative; min-height: 68vh; display: flex; align-items: flex-end; overflow: hidden; }
.article-hero-img-wrap { position: absolute; inset: 0; }
.article-hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.article-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(255,255,255,1) 0%, rgba(255,255,255,0.72) 42%, rgba(255,255,255,0.05) 100%); }
.article-hero-content { position: relative; z-index: 2; max-width: 820px; padding: 3rem 2rem 3.5rem; }

/* ── FIFA banner hero — clean image, text below ── */
.article-hero.banner-hero { min-height: auto; display: block; align-items: unset; }
.article-hero.banner-hero .article-hero-img-wrap { position: relative; height: 320px; inset: unset; }
.article-hero.banner-hero .article-hero-img { object-fit: cover; object-position: center; }
.article-hero.banner-hero .article-hero-overlay { display: none; }
.article-hero.banner-hero .article-hero-content { background: #fff; padding: 2.5rem 2rem 3rem; position: static; }

/* ── Meta + title ── */
.article-meta-top { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.article-category { background: #1d1d1f; color: #fff; padding: 4px 14px; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 980px; }
.article-date { font-size: 0.78rem; color: #6e6e73; font-weight: 500; }
.article-hero-content h1 { font-family: 'Cormorant Garamond', Georgia, serif; font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 500; line-height: 1.12; color: #1d1d1f; margin-bottom: 1rem; }
.article-deck { font-size: 1.05rem; color: #3a3a3c; line-height: 1.75; max-width: 680px; margin-bottom: 1.5rem; font-weight: 400; }
.article-byline { display: flex; align-items: center; gap: 12px; }
.byline-avatar { width: 38px; height: 38px; border-radius: 50%; background: #1d1d1f; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 0.78rem; font-weight: 600; flex-shrink: 0; }
.byline-name { font-size: 0.9rem; font-weight: 600; color: #1d1d1f; }
.byline-role { font-size: 0.72rem; color: #6e6e73; font-weight: 400; }

/* ── Article body ── */
.article-body { display: grid; grid-template-columns: 1fr 280px; gap: 4rem; max-width: 1080px; margin: 0 auto; padding: 4rem 2rem 6rem; align-items: start; }
.article-content { min-width: 0; }
.article-content h2 { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 1.75rem; font-weight: 500; color: #1d1d1f; margin: 3rem 0 1rem; line-height: 1.2; }
.article-content h2:first-of-type { margin-top: 0; }
.article-content p { font-size: 1rem; color: #3a3a3c; line-height: 1.85; margin-bottom: 1.25rem; font-weight: 400; }
.article-lead { font-size: 1.1rem !important; color: #1d1d1f !important; font-weight: 500; line-height: 1.75 !important; }
.article-content strong { color: #1d1d1f; font-weight: 600; }

/* ── Data callout ── */
.data-callout { background: #f5f5f7; border: 1px solid rgba(0,0,0,0.1); border-radius: 16px; padding: 2rem; margin: 2.5rem 0; }
.data-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; }
.data-stat { text-align: center; }
.ds-num { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 2rem; color: #1d1d1f; line-height: 1; margin-bottom: 4px; font-weight: 500; }
.ds-label { font-size: 0.72rem; color: #6e6e73; letter-spacing: 0.04em; line-height: 1.4; font-weight: 500; }

/* ── Bar chart ── */
.chart-wrap { background: #f5f5f7; border: 1px solid rgba(0,0,0,0.1); padding: 1.75rem; margin: 2.5rem 0; border-radius: 16px; }
.chart-title { font-size: 0.85rem; font-weight: 600; color: #1d1d1f; margin-bottom: 1.25rem; }
.bar-chart { display: flex; flex-direction: column; gap: 7px; }
.bar-row { display: flex; align-items: center; gap: 10px; }
.bar-month { font-size: 0.72rem; color: #6e6e73; width: 28px; flex-shrink: 0; font-weight: 600; }
.bar-outer { flex: 1; background: rgba(0,0,0,0.08); height: 16px; border-radius: 8px; overflow: hidden; }
.bar-fill { height: 100%; background: rgba(0,0,0,0.2); border-radius: 8px; }
.bar-fill.bar-peak { background: #1d1d1f; }
.bar-val { font-size: 0.72rem; color: #6e6e73; width: 62px; flex-shrink: 0; text-align: right; font-weight: 500; }
.chart-note { font-size: 0.7rem; color: #6e6e73; margin-top: 1rem; line-height: 1.5; }

/* ── Blockquote ── */
.article-quote { border-left: 2px solid #1d1d1f; padding: 1.25rem 1.5rem; margin: 2.5rem 0; font-family: 'Cormorant Garamond', Georgia, serif; font-style: italic; font-size: 1.2rem; color: #1d1d1f; line-height: 1.6; background: #f5f5f7; border-radius: 0 12px 12px 0; }
.article-quote cite { display: block; margin-top: 0.75rem; font-size: 0.72rem; color: #6e6e73; font-style: normal; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; }

/* ── Table ── */
.info-table { width: 100%; border-collapse: collapse; margin: 2rem 0; border-radius: 12px; overflow: hidden; border: 1px solid rgba(0,0,0,0.1); }
.info-table th { background: #1d1d1f; color: #fff; padding: 0.9rem 1rem; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; text-align: left; }
.info-table td { padding: 0.9rem 1rem; font-size: 0.92rem; color: #3a3a3c; border-top: 1px solid rgba(0,0,0,0.07); line-height: 1.55; font-weight: 400; }
.info-table tr:nth-child(even) td { background: #f5f5f7; }

/* ── Tip box ── */
.tip-box { background: #f5f5f7; border: 1px solid rgba(0,0,0,0.1); border-radius: 14px; padding: 1.5rem; margin: 2rem 0; }
.tip-box-title { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: #6e6e73; margin-bottom: 1rem; }
.tip-item { display: flex; gap: 12px; margin-bottom: 0.75rem; align-items: flex-start; }
.tip-item:last-child { margin-bottom: 0; }
.tip-num { width: 24px; height: 24px; background: #1d1d1f; color: #fff; border-radius: 50%; font-size: 0.68rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.tip-item p { font-size: 0.92rem; color: #3a3a3c; line-height: 1.65; margin: 0; font-weight: 400; }

/* ── CTA box ── */
.cta-box { background: #1d1d1f; border-radius: 18px; padding: 2.25rem 2rem; margin: 3rem 0 0; text-align: center; }
.cta-box h3 { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 1.5rem; font-weight: 500; margin-bottom: 0.5rem; color: #fff; }
.cta-box p { color: rgba(255,255,255,0.72); font-size: 0.95rem; margin-bottom: 1.5rem; line-height: 1.65; }

/* ── Sidebar ── */
.article-sidebar { position: sticky; top: 76px; display: flex; flex-direction: column; gap: 1.25rem; }
.sidebar-card { background: #f5f5f7; border: 1px solid rgba(0,0,0,0.1); padding: 1.5rem; border-radius: 16px; }
.sidebar-label { font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase; color: #6e6e73; margin-bottom: 0.85rem; font-weight: 700; }
.sidebar-avatar { width: 44px; height: 44px; border-radius: 50%; background: #1d1d1f; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 0.8rem; font-weight: 600; margin-bottom: 0.6rem; }
.sidebar-name { font-size: 0.95rem; font-weight: 600; color: #1d1d1f; margin-bottom: 0.5rem; }
.sidebar-card p { font-size: 0.87rem; color: #3a3a3c; line-height: 1.65; font-weight: 400; }
.sidebar-sources { list-style: none; padding: 0; }
.sidebar-sources li { font-size: 0.82rem; color: #3a3a3c; padding: 0.38rem 0; border-bottom: 1px solid rgba(0,0,0,0.08); line-height: 1.5; font-weight: 400; }
.sidebar-sources li:last-child { border-bottom: none; }
.sidebar-link { display: block; font-size: 0.87rem; color: #3a3a3c; text-decoration: none; padding: 0.6rem 0; border-bottom: 1px solid rgba(0,0,0,0.08); line-height: 1.5; transition: color 0.2s; font-weight: 400; }
.sidebar-link:hover { color: #1d1d1f; }
.sidebar-link:last-child { border-bottom: none; }

/* ── Blog index page ── */
.blog-index-page { padding: 7rem 0 5rem; min-height: 100vh; background: #fff; }
.blog-index-header { text-align: center; margin-bottom: 4rem; }
.blog-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.blog-card { background: #fff; border: 1px solid rgba(0,0,0,0.1); border-radius: 20px; overflow: hidden; text-decoration: none; color: #1d1d1f; display: flex; flex-direction: column; transition: transform 0.3s ease, box-shadow 0.3s ease; box-shadow: 0 2px 16px rgba(0,0,0,0.07); }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 8px 40px rgba(0,0,0,0.11); }
.blog-card-img { position: relative; height: 200px; overflow: hidden; }
.blog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.blog-card:hover .blog-card-img img { transform: scale(1.04); }
.blog-card-cat { position: absolute; top: 12px; left: 12px; background: rgba(255,255,255,0.92); backdrop-filter: blur(8px); color: #1d1d1f; padding: 4px 12px; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; border-radius: 980px; }
.blog-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.blog-card-date { font-size: 0.72rem; color: #6e6e73; margin-bottom: 0.5rem; font-weight: 500; }
.blog-card-body h2 { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 1.15rem; color: #1d1d1f; line-height: 1.35; margin-bottom: 0.75rem; font-weight: 500; flex: 1; }
.blog-card-body p { font-size: 0.9rem; color: #3a3a3c; line-height: 1.65; margin-bottom: 1rem; font-weight: 400; }
.blog-card-read { font-size: 0.82rem; color: #6e6e73; font-weight: 600; }

/* ── Shared blog nav override ── */
.blog-nav nav { background: rgba(255,255,255,0.9); }

/* ── Responsive ── */
@media (max-width: 900px) {
  .article-body { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
  .data-row { grid-template-columns: repeat(2,1fr); }
  .blog-cards { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 600px) {
  .article-hero-content { padding: 2rem 1.25rem 2.5rem; }
  .article-body { padding: 2.5rem 1.25rem 4rem; }
  .blog-cards { grid-template-columns: 1fr; }
  .data-row { grid-template-columns: repeat(2,1fr); }
  .article-hero.banner-hero .article-hero-img-wrap { height: 220px; }
}
