/* === Page blog listing — CSS partage === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Inter', sans-serif; min-height: 100vh; background: linear-gradient(135deg, #0f0c29, #302b63, #24243e); color: #e0e0e0; padding: 32px 16px; }
.container { max-width: 900px; margin: 0 auto; position: relative; z-index: 1; }
.blog-header { text-align: center; margin-bottom: 40px; }
.blog-header h1 { font-size: 2.2rem; font-weight: 800; margin-bottom: 12px; background: linear-gradient(90deg, var(--color-light), var(--color-mid), var(--color-dark)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.blog-header p { font-size: 1rem; color: #94a3b8; line-height: 1.6; }
.back-link { display: inline-block; margin-bottom: 24px; color: var(--color-mid); text-decoration: none; font-size: 0.9rem; font-weight: 600; transition: color 0.2s; }
.back-link:hover { color: var(--color-light); }
/* Wrapper glassmorphism — englobe header + grille + pagination, donne le même fond que les pages article */
.page-card { background: rgba(20, 20, 35, 0.55); border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 24px; padding: 36px 28px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4); margin-bottom: 24px; }
.page-card .blog-header { margin-bottom: 32px; }
@media (max-width: 480px) { .page-card { padding: 24px 16px; border-radius: 18px; } }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; margin-bottom: 32px; }
/* Cartes — fond plus clair quand elles sont dans un .page-card pour ressortir du wrapper */
.blog-card { background: rgba(20, 20, 35, 0.55); border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 16px; padding: 24px; transition: all 0.3s ease; display: flex; flex-direction: column; gap: 12px; }
.page-card .blog-card { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.08); }
.page-card .blog-card:hover { background: rgba(255, 255, 255, 0.09); }
.blog-card:hover { background: rgba(255, 255, 255, 0.1); border-color: color-mix(in srgb, var(--color-light) 40%, transparent); transform: translateY(-4px); box-shadow: 0 8px 24px color-mix(in srgb, var(--color-light) 15%, transparent); }
.card-date { font-size: 0.78rem; color: #64748b; font-weight: 600; }
.card-site { font-size: 0.72rem; color: var(--color-mid, #818cf8); font-weight: 600; margin-top: -6px; }
.blog-card h2 { font-size: 1.1rem; font-weight: 700; line-height: 1.4; }
.blog-card h2 a { color: var(--color-accent); text-decoration: none; transition: color 0.2s; }
.blog-card h2 a:hover { color: var(--color-light); }
.blog-card p { font-size: 0.85rem; color: #94a3b8; line-height: 1.5; flex: 1; }
.read-more { font-size: 0.85rem; font-weight: 600; color: var(--color-mid); text-decoration: none; transition: color 0.2s; }
.read-more:hover { color: var(--color-light); }
.pagination { display: flex; justify-content: center; gap: 8px; margin-bottom: 32px; }
.pagination-link { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 10px; font-size: 0.85rem; font-weight: 600; color: #94a3b8; text-decoration: none; background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.1); transition: all 0.2s; }
.pagination-link:hover { background: rgba(255, 255, 255, 0.12); color: var(--color-accent); }
.pagination-active { background: color-mix(in srgb, var(--color-light) 30%, transparent); border-color: color-mix(in srgb, var(--color-light) 60%, transparent); color: var(--color-accent); }
footer { text-align: center; font-size: 0.78rem; color: #64748b; margin-top: 8px; }
footer a { color: #818cf8; text-decoration: none; transition: color 0.2s; }
footer a:hover { color: #a78bfa; }
@media (max-width: 480px) { .blog-header h1 { font-size: 1.6rem; } .blog-grid { grid-template-columns: 1fr; } }
