@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700;800&display=swap');

:root {
    --bps-navy:   #0d1b2a;
    --bps-orange: #e85d04;
    --bps-border: #e9ecef;
    --bps-muted:  #6c757d;
    --bps-radius: 12px;
    --bps-shadow: 0 2px 12px rgba(0,0,0,.08);
    --bps-shadow-hover: 0 8px 32px rgba(0,0,0,.14);
}

.bps-wrapper { max-width:1200px; margin:0 auto; padding:0 16px; font-family:'Poppins',sans-serif; }

/* Filtres */
.bps-filters { background:#fff; border:1px solid var(--bps-border); border-radius:var(--bps-radius); padding:20px 24px; margin-bottom:28px; box-shadow:var(--bps-shadow); }
.bps-filter-group { margin-bottom:14px; }
.bps-filter-group:last-child { margin-bottom:0; }
.bps-filter-label { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--bps-muted); margin-bottom:8px; }
.bps-filter-row { display:flex; flex-wrap:wrap; gap:16px; align-items:flex-end; }
.bps-filter-inline { margin-bottom:0; }

.bps-pills { display:flex; flex-wrap:wrap; gap:8px; }
.bps-pill { padding:6px 14px; border-radius:20px; border:1.5px solid var(--bps-border); background:#fff; color:#212529; font-family:'Poppins',sans-serif; font-size:13px; font-weight:600; cursor:pointer; transition:all .18s; white-space:nowrap; }
.bps-pill:hover { border-color:var(--sport-color,var(--bps-orange)); color:var(--sport-color,var(--bps-orange)); }
.bps-pill.active { background:var(--sport-color,var(--bps-navy)); border-color:var(--sport-color,var(--bps-navy)); color:#fff; }

.bps-select { padding:7px 32px 7px 12px; border-radius:8px; border:1.5px solid var(--bps-border); background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat right 10px center; font-family:'Poppins',sans-serif; font-size:13px; font-weight:600; color:#212529; cursor:pointer; appearance:none; }
.bps-select:focus { outline:none; border-color:var(--bps-orange); }

/* Grille */
.bps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; transition:opacity .2s; }
.bps-grid.bps-loading { opacity:.5; pointer-events:none; }
@media(max-width:1100px){.bps-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:768px){.bps-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.bps-grid{grid-template-columns:1fr;}}

/* Card */
.bps-card { border-radius:var(--bps-radius); overflow:hidden; background:#fff; border:1px solid var(--bps-border); box-shadow:var(--bps-shadow); transition:transform .22s,box-shadow .22s; }
.bps-card:hover { transform:translateY(-4px); box-shadow:var(--bps-shadow-hover); }
.bps-card-link { display:flex; flex-direction:column; height:100%; text-decoration:none; color:inherit; }

.bps-card-image { position:relative; aspect-ratio:16/9; overflow:hidden; background:#f0f0f0; }
.bps-card-image img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .3s; }
.bps-card:hover .bps-card-image img { transform:scale(1.04); }
.bps-card-no-image { width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.bps-card-emoji { font-size:52px; opacity:.6; }

.bps-reading-time { position:absolute; bottom:10px; right:10px; background:rgba(0,0,0,.7); color:#fff; font-size:11px; font-weight:700; padding:3px 8px; border-radius:20px; }

.bps-score-badge { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(0,0,0,.85)); color:#fff; display:flex; align-items:center; justify-content:center; gap:6px; padding:20px 10px 10px; }
.bps-score-num { font-size:22px; font-weight:800; line-height:1; }
.bps-score-sep { font-size:16px; opacity:.7; font-weight:300; }
.bps-score-team { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; opacity:.9; max-width:60px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.bps-result-badge { position:absolute; top:10px; left:10px; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; color:#fff; }

/* Body */
.bps-card-body { padding:14px 16px 16px; display:flex; flex-direction:column; flex:1; }
.bps-card-meta { display:flex; align-items:center; gap:8px; margin-bottom:8px; flex-wrap:wrap; }
.bps-sport-tag { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; border:1.5px solid; padding:2px 8px; border-radius:20px; }
.bps-competition { font-size:11px; color:var(--bps-muted); font-weight:600; }
.bps-card-title { font-size:14px; font-weight:700; line-height:1.35; color:var(--bps-navy); margin:0 0 8px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.bps-card-club { font-size:11px; color:var(--bps-muted); font-weight:600; margin-bottom:8px; }
.bps-card-footer { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:10px; border-top:1px solid var(--bps-border); }
.bps-card-date { font-size:12px; color:var(--bps-muted); font-weight:500; }
.bps-card-arrow { width:28px; height:28px; background:var(--bps-navy); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; transition:background .18s,transform .18s; flex-shrink:0; }
.bps-card:hover .bps-card-arrow { background:var(--bps-orange); transform:translateX(2px); }

/* Load more */
.bps-load-more-wrap { text-align:center; margin-top:32px; }
.bps-load-more { display:inline-block; padding:12px 32px; background:var(--bps-navy); color:#fff; border:none; border-radius:30px; font-family:'Poppins',sans-serif; font-size:14px; font-weight:700; cursor:pointer; transition:background .18s,transform .18s; }
.bps-load-more:hover { background:var(--bps-orange); transform:translateY(-2px); }

.bps-empty { grid-column:1/-1; text-align:center; padding:48px 24px; color:var(--bps-muted); font-size:16px; font-weight:600; }
