/* ================================================================
   FOOTBLEU — Homepage Premium CSS
   Ajout progressif sur main.css existant
   ================================================================ */

/* ── Hero Match ── */
.hero-section{background:var(--ffr-card);border-bottom:1px solid var(--ffr-border)}
.hero-match{padding:clamp(24px,4vw,48px) 0;position:relative}
.hero-match--live::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(230,57,70,.07),transparent 60%);pointer-events:none}
.hero-match::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(0,212,170,.05),transparent 60%);pointer-events:none}

/* Live bar */
.hero-match__live-bar{background:var(--ffr-live);color:#fff;font-size:11px;font-weight:800;letter-spacing:.15em;padding:6px 0;text-align:center;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:0}
.live-pulse{width:8px;height:8px;border-radius:50%;background:#fff;animation:live-pulse 1.5s infinite}
@keyframes live-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* Hero inner */
.hero-match__inner{max-width:800px;margin:0 auto;text-align:center;padding:0 16px}
.hero-match__comp{margin-bottom:20px}
.hero-match__comp-name{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--ffr-faint);background:var(--ffr-surface);padding:4px 14px;border-radius:20px;border:1px solid var(--ffr-border)}

/* Teams */
.hero-match__teams{display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(12px,4vw,48px);align-items:center;margin:0 0 20px}
.hero-team{display:flex;flex-direction:column;align-items:center;gap:12px}
.hero-team__logo{width:clamp(52px,9vw,88px);height:clamp(52px,9vw,88px);object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}
.hero-team__logo-ph{width:clamp(52px,9vw,88px);height:clamp(52px,9vw,88px);border-radius:var(--ffr-r-lg);display:flex;align-items:center;justify-content:center;font-size:clamp(18px,4vw,28px);font-weight:800;color:#fff}
.hero-team__name{font-size:clamp(13px,2.5vw,20px);font-weight:800;color:var(--ffr-text);text-align:center;line-height:1.2}

/* Score */
.hero-center{display:flex;flex-direction:column;align-items:center;gap:8px}
.hero-score{display:flex;align-items:center;gap:8px;font-family:var(--ffr-font-display);font-size:clamp(48px,10vw,88px);color:var(--ffr-text);line-height:1;letter-spacing:.04em}
.hero-score__sep{color:var(--ffr-faint);font-size:.7em}
.hero-status{font-size:13px;font-weight:600;color:var(--ffr-muted);padding:4px 12px;border-radius:20px;background:var(--ffr-surface);border:1px solid var(--ffr-border)}
.hero-status--live{color:var(--ffr-live);border-color:rgba(230,57,70,.3);background:rgba(230,57,70,.08);display:flex;align-items:center;gap:6px}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--ffr-live);animation:live-pulse 1.5s infinite;flex-shrink:0}
.hero-vs{font-family:var(--ffr-font-display);font-size:clamp(24px,5vw,40px);color:var(--ffr-faint);letter-spacing:.06em}
.hero-kickoff{font-size:14px;font-weight:600;color:var(--ffr-muted)}

/* Meta */
.hero-match__meta{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ffr-faint);padding-top:16px;border-top:1px solid var(--ffr-border)}
.hero-match__meta span{display:flex;align-items:center;gap:5px}

/* Empty state */
.hero-empty{padding:clamp(32px,6vw,56px) 0;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.hero-empty__icon{font-size:56px;opacity:.4}
.hero-empty__title{font-size:22px;font-weight:800;color:var(--ffr-text)}
.hero-empty__sub{font-size:15px;color:var(--ffr-muted);max-width:360px}
.hero-empty__cta{display:inline-flex;align-items:center;gap:8px;background:var(--ffr-accent);color:#000;font-size:14px;font-weight:700;padding:11px 22px;border-radius:var(--ffr-r-sm);transition:all var(--ffr-t)}
.hero-empty__cta:hover{background:var(--ffr-accent-h);color:#000;gap:12px}

/* ── Sections matches ── */
.matches-section{padding:20px 0 0}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}
.section-title{font-size:15px;font-weight:800;color:var(--ffr-text);display:flex;align-items:center;gap:8px;flex-shrink:0}
.section-title__bar{width:3px;height:18px;background:var(--ffr-accent);border-radius:2px;flex-shrink:0;display:inline-block}
.section-title__bar--live{background:var(--ffr-live)}
.section-count{background:var(--ffr-surface);border:1px solid var(--ffr-border);color:var(--ffr-muted);font-size:11px;font-weight:700;padding:2px 7px;border-radius:12px;min-width:22px;text-align:center}
.see-all{font-size:12px;font-weight:700;color:var(--ffr-accent);display:flex;align-items:center;gap:4px;white-space:nowrap;transition:gap var(--ffr-t)}
.see-all:hover{gap:8px}
.matches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
@media(min-width:768px){.matches-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1140px){.matches-grid{grid-template-columns:repeat(3,1fr)}}
.matches-empty,.articles-empty{padding:24px 0;color:var(--ffr-muted);font-size:14px}

/* ── Score Cards Premium ── */
.score-card{background:var(--ffr-card);border:1px solid var(--ffr-border);border-radius:var(--ffr-r-md);padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:all var(--ffr-t);position:relative;overflow:hidden;cursor:default}
.score-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:transparent;transition:background var(--ffr-t)}
.score-card.is-live::before{background:var(--ffr-live)}
.score-card:hover{border-color:var(--ffr-border-s);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.score-card:hover::before{background:var(--ffr-accent)}
.score-card.is-live:hover::before{background:var(--ffr-live)}
.score-card__top{display:flex;align-items:center;justify-content:space-between;gap:6px;min-height:20px}
.score-card__comp{display:flex;align-items:center;gap:5px;overflow:hidden;flex:1}
.score-card__comp-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ffr-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.score-card__body{display:grid;grid-template-columns:1fr 80px 1fr;align-items:center;gap:6px}
.sc-team{display:flex;align-items:center;gap:7px;overflow:hidden}
.sc-team--away{justify-content:flex-end;flex-direction:row-reverse}
.sc-team__logo{width:26px;height:26px;object-fit:contain;flex-shrink:0}
.sc-team__ph{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}
.sc-team__name{font-size:12px;font-weight:700;color:var(--ffr-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-center{text-align:center}
.sc-score{font-family:var(--ffr-font-display);font-size:24px;color:var(--ffr-text);letter-spacing:.04em;line-height:1}
.sc-score--vs{font-size:13px;font-weight:700;color:var(--ffr-muted);line-height:1}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;flex-shrink:0}
.badge-live{background:var(--ffr-live);color:#fff}
.badge-live::before{content:'';width:5px;height:5px;border-radius:50%;background:#fff;animation:live-pulse 1.5s infinite;flex-shrink:0}
.badge-upcoming{background:var(--ffr-surface);color:var(--ffr-muted);border:1px solid var(--ffr-border)}
.badge-done{background:var(--ffr-surface);color:var(--ffr-faint)}
.badge-postponed{background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}

/* ── Homepage Layout ── */
.home-layout{display:grid;grid-template-columns:1fr;gap:28px}
.home-sidebar-col{display:flex;flex-direction:column;gap:16px}
@media(min-width:1140px){
  .home-layout{grid-template-columns:minmax(0,1fr) 300px;align-items:start}
  .home-sidebar-col{position:sticky;top:76px;max-height:calc(100vh - 90px);overflow-y:auto;padding-right:2px}
  .home-sidebar-col::-webkit-scrollbar{width:3px}
  .home-sidebar-col::-webkit-scrollbar-track{background:transparent}
  .home-sidebar-col::-webkit-scrollbar-thumb{background:var(--ffr-border)}
}

/* ── Article Cards Premium ── */
.articles-grid{display:grid;gap:14px;grid-template-columns:1fr}
@media(min-width:640px){.articles-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.articles-grid{grid-template-columns:repeat(3,1fr)}}

/* Featured article */
.art-card--featured{grid-column:1/-1}
@media(min-width:640px){
  .art-card--featured{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr}
  .art-card--featured .art-card__img{aspect-ratio:auto;min-height:260px}
  .art-card--featured .art-card__body{padding:24px 28px;justify-content:center}
  .art-card--featured .art-card__title{font-size:clamp(15px,2.5vw,22px);-webkit-line-clamp:4}
}
@media(min-width:1024px){.art-card--featured{grid-column:span 2}}

.art-card{background:var(--ffr-card);border:1px solid var(--ffr-border);border-radius:var(--ffr-r-md);overflow:hidden;display:flex;flex-direction:column;transition:all var(--ffr-t)}
.art-card:hover{border-color:var(--ffr-border-s);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.2)}
.art-card__img-link{display:block;flex-shrink:0}
.art-card__img{aspect-ratio:16/9;overflow:hidden;background:var(--ffr-surface);position:relative}
.art-card__img-el{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.art-card:hover .art-card__img-el{transform:scale(1.04)}
.art-card__cat-badge{position:absolute;top:10px;left:10px;background:var(--ffr-accent);color:#000;font-size:9px;font-weight:900;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.1em;z-index:1}
.art-card__body{padding:14px 16px;display:flex;flex-direction:column;gap:7px;flex:1}
.art-card__cat{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--ffr-accent)}
.art-card__title{font-size:14px;font-weight:700;line-height:1.4;color:var(--ffr-text);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.art-card__excerpt{font-size:13px;color:var(--ffr-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:4px}
.art-card__meta{margin-top:auto;display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ffr-faint);padding-top:8px;border-top:1px solid var(--ffr-border)}

/* ── Sidebar Widgets ── */
.sidebar-ad{min-height:0}
.widget-box{background:var(--ffr-card);border:1px solid var(--ffr-border);border-radius:var(--ffr-r-md);overflow:hidden}
.widget-box__head{padding:12px 14px;border-bottom:1px solid var(--ffr-border);display:flex;align-items:center;justify-content:space-between;gap:8px}
.widget-box__title{font-size:13px;font-weight:800;color:var(--ffr-text);display:flex;align-items:center;gap:7px}
.widget-box__link{font-size:11px;font-weight:700;color:var(--ffr-accent);white-space:nowrap}
.st-head{display:grid;grid-template-columns:22px 1fr 24px 28px 32px;gap:4px;padding:5px 14px;background:var(--ffr-surface);border-bottom:1px solid var(--ffr-border)}
.st-head span{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ffr-faint);text-align:center}
.st-head span:nth-child(2){text-align:left}
.st-row{display:grid;grid-template-columns:22px 1fr 24px 28px 32px;gap:4px;padding:8px 14px;border-bottom:1px solid var(--ffr-border);align-items:center;transition:background var(--ffr-t)}
.st-row:last-child{border:none}
.st-row:hover{background:var(--ffr-surface)}
.st-rank{font-size:11px;font-weight:700;color:var(--ffr-faint);text-align:center}
.st-team{display:flex;align-items:center;gap:6px;overflow:hidden;min-width:0}
.st-team__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.st-team__name{font-size:12px;font-weight:700;color:var(--ffr-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.st-num{font-size:11px;color:var(--ffr-faint);text-align:center;font-variant-numeric:tabular-nums}
.st-num--pos{color:#10b981}
.st-num--neg{color:var(--ffr-live)}
.st-pts{font-size:13px;font-weight:800;color:var(--ffr-accent);text-align:center}
.next-row{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--ffr-border);gap:8px;transition:background var(--ffr-t)}
.next-row:last-child{border:none}
.next-row:hover{background:var(--ffr-surface)}
.next-row__teams{font-size:12px;font-weight:600;color:var(--ffr-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.next-row__time{font-size:10px;font-weight:700;color:var(--ffr-accent);white-space:nowrap;flex-shrink:0}

/* ── Pagination ── */
.ffr-pagination{display:flex;justify-content:center;gap:4px;margin-top:24px;flex-wrap:wrap}
.ffr-pagination a,.ffr-pagination span{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--ffr-r-sm);font-size:13px;font-weight:700;border:1px solid var(--ffr-border);color:var(--ffr-muted);transition:all var(--ffr-t)}
.ffr-pagination a:hover{border-color:var(--ffr-accent);color:var(--ffr-accent)}
.ffr-pagination .current{background:var(--ffr-accent);border-color:var(--ffr-accent);color:#000}

/* ── Animations ── */
@media(prefers-reduced-motion:no-preference){
  .score-card,.art-card{animation:card-rise .35s ease both}
  @keyframes card-rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
  .score-card:nth-child(1),.art-card:nth-child(1){animation-delay:.04s}
  .score-card:nth-child(2),.art-card:nth-child(2){animation-delay:.08s}
  .score-card:nth-child(3),.art-card:nth-child(3){animation-delay:.12s}
  .score-card:nth-child(4),.art-card:nth-child(4){animation-delay:.16s}
  .score-card:nth-child(5),.art-card:nth-child(5){animation-delay:.20s}
  .score-card:nth-child(6),.art-card:nth-child(6){animation-delay:.24s}
}

/* ── Mobile ── */
@media(max-width:479px){
  .hero-score{font-size:44px}
  .hero-team__name{font-size:12px}
  .matches-grid{grid-template-columns:1fr}
}
@media(max-width:639px){
  .art-card--featured{grid-column:1;display:flex;flex-direction:column}
  .art-card--featured .art-card__img{aspect-ratio:16/9}
}
@media(max-width:1023px){
  main{padding-bottom:70px}
}

/* ── Light mode ── */
[data-theme=light]{
  .score-card,.art-card,.widget-box{box-shadow:0 1px 3px rgba(0,0,0,.06)}
  .hero-section{background:#fff}
}
