/* ── PAGE HEADER BLOG ── */
.page-header::before { content: none; }
.page-header h1 { margin-bottom: 20px; }

/* Articles grisés — blog en construction */
.article-card.coming-soon { pointer-events: none; opacity: 0.45; filter: grayscale(0.3); }
.articles-coming { text-align: center; padding: 48px 24px; color: #aaa; font-size: 14px; line-height: 1.7; }
.articles-coming strong { display: block; font-size: 16px; color: var(--dark); margin-bottom: 8px; }

/* ── ARTICLE À LA UNE ── */
.une-section { padding: 64px 0 0; }
.une-label { display: flex; align-items: center; gap: 16px; font-size: 12px; font-weight: 800; color: var(--hot); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 24px; }
.une-label::after { content: ''; flex: 1; height: 1px; background: rgba(241,5,96,0.15); }

.une-card { display: grid; grid-template-columns: 1.2fr 1fr; border: 1.5px solid rgba(247,172,186,0.3); border-radius: var(--card-r); overflow: hidden; transition: box-shadow 0.2s; cursor: pointer; margin-bottom: 64px; text-decoration: none; color: inherit; }
.une-card:hover { box-shadow: 0 12px 40px rgba(131,0,48,0.1); }

.une-photo { position: relative; min-height: 400px; overflow: hidden; }
.une-photo img { width: 100%; height: 100%; object-fit: cover; }
.une-ph { width: 100%; height: 100%; min-height: 400px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; background: var(--blush); }
.une-ph .ph-icon { font-size: 44px; }
.une-ph .ph-label { font-size: 11px; font-weight: 800; color: var(--hot); text-transform: uppercase; letter-spacing: 0.5px; }
.une-ph .ph-name  { font-size: 11px; color: var(--gray); }

.une-content { background: #fff; padding: 44px 40px; display: flex; flex-direction: column; justify-content: center; }
.une-cat { font-size: 11px; font-weight: 800; color: var(--hot); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 12px; }
.une-content h2 { font-family: var(--serif); font-size: clamp(22px, 3vw, 30px); color: var(--dark); line-height: 1.25; margin-bottom: 16px; }
.une-content p  { font-size: 15px; color: #666; line-height: 1.7; margin-bottom: 24px; }
.une-meta { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; font-size: 13px; color: var(--gray); }
.une-meta-sep { color: rgba(131,0,48,0.2); }
.btn-lire {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--hot); color: #fff;
  border: none; border-radius: var(--radius); padding: 12px 22px;
  font-family: var(--font); font-size: 14px; font-weight: 700; cursor: pointer;
  box-shadow: 0 4px 16px rgba(241,5,96,0.3); transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none;
}
.btn-lire:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(241,5,96,0.35); }

/* ── GRILLE ARTICLES ── */
.articles-section { padding: 0 0 80px; }
.blog-layout { display: grid; grid-template-columns: 1fr 280px; gap: 48px; align-items: start; padding-bottom: 80px; }
.articles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }

.article-card { background: #fff; border-radius: var(--card-r); overflow: hidden; border: 1.5px solid rgba(247,172,186,0.3); transition: transform 0.2s, box-shadow 0.2s; text-decoration: none; color: inherit; display: block; }
.article-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(131,0,48,0.1); }
.article-thumb { height: 200px; overflow: hidden; position: relative; }
.article-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.article-card:hover .article-thumb img { transform: scale(1.03); }
.article-thumb-ph { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; }
.aph1 { background: var(--blush); } .aph2 { background: var(--cream); } .aph3 { background: #fce4f3; }
.aph4 { background: #e8f4fd; }     .aph5 { background: #f0fce8; }
.article-thumb-ph .ph-icon { font-size: 32px; }

.article-body { padding: 20px 22px; }
.article-cat  { font-size: 11px; font-weight: 800; color: var(--hot); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.article-body h3 { font-family: var(--serif); font-size: 17px; color: var(--dark); line-height: 1.3; margin-bottom: 8px; }
.article-body p  { font-size: 13px; color: #777; line-height: 1.6; margin-bottom: 14px; }
.article-footer  { display: flex; justify-content: space-between; align-items: center; }
.article-meta    { font-size: 12px; color: #aaa; }
.lire-link { font-size: 13px; font-weight: 700; color: var(--hot); display: inline-flex; align-items: center; gap: 4px; }
.lire-link::after { content: '→'; transition: transform 0.15s; }
.article-card:hover .lire-link::after { transform: translateX(4px); }

.badge-lu      { display: inline-block; background: var(--cream); color: var(--dark); font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: var(--radius); }
.badge-nouveau { display: inline-block; background: var(--hot); color: #fff; font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: var(--radius); }

/* ── PAGINATION ── */
.pagination { display: flex; justify-content: center; gap: 8px; padding: 0 0 80px; }
.page-btn { width: 36px; height: 36px; border-radius: 50%; border: 1.5px solid rgba(247,172,186,0.4); background: #fff; font-family: var(--font); font-size: 13px; font-weight: 700; color: var(--dark); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.page-btn.active { background: var(--hot); color: #fff; border-color: var(--hot); }
.page-btn.nav-pg { width: auto; padding: 0 14px; border-radius: var(--radius); }
.page-btn:hover:not(.active) { border-color: var(--pink); }

/* ── SIDEBAR ── */
.sidebar { position: sticky; top: 84px; }
.sidebar-block { background: #fff; border-radius: var(--card-r); padding: 24px; border: 1.5px solid rgba(247,172,186,0.3); margin-bottom: 20px; }
.sidebar-block h3 { font-size: 13px; font-weight: 800; color: var(--dark); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 16px; }
.sidebar-cats { display: flex; flex-direction: column; gap: 8px; }
.sidebar-cat { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; border-radius: 10px; background: var(--blush); font-size: 13px; font-weight: 700; color: var(--dark); cursor: pointer; transition: all 0.15s; }
.sidebar-cat:hover { background: var(--hot); color: #fff; }
.cat-count { background: rgba(131,0,48,0.1); color: var(--dark); font-size: 11px; font-weight: 800; padding: 2px 8px; border-radius: var(--radius); }
.sidebar-cat:hover .cat-count { background: rgba(255,255,255,0.2); color: #fff; }

.sidebar-recents { display: flex; flex-direction: column; gap: 14px; }
.recent-item { display: flex; gap: 12px; align-items: flex-start; cursor: pointer; }
.recent-thumb { width: 56px; height: 56px; border-radius: 10px; flex-shrink: 0; overflow: hidden; }
.recent-thumb img { width: 100%; height: 100%; object-fit: cover; }
.recent-thumb-ph { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 20px; }
.rph1 { background: var(--blush); } .rph2 { background: var(--cream); } .rph3 { background: #fce4f3; }
.recent-info h4 { font-size: 13px; font-weight: 800; color: var(--dark); line-height: 1.3; margin-bottom: 4px; }
.recent-info p  { font-size: 11px; color: var(--gray); }

/* ── NEWSLETTER INLINE ── */
.nl-inline { background: var(--hot); border-radius: var(--card-r); padding: 24px; }
.nl-inline h3 { font-family: var(--serif); font-size: 18px; color: #fff; margin-bottom: 8px; }
.nl-inline p  { font-size: 13px; color: rgba(255,255,255,0.6); margin-bottom: 16px; line-height: 1.5; }
.nl-inline input  { width: 100%; padding: 11px 16px; border-radius: var(--radius); border: none; font-family: var(--font); font-size: 13px; outline: none; margin-bottom: 8px; }
.nl-inline button { width: 100%; background: var(--dark); color: #fff; border: none; border-radius: var(--radius); padding: 11px; font-family: var(--font); font-size: 13px; font-weight: 700; cursor: pointer; }

/* ── RESPONSIVE ── */
@media (max-width: 1000px) {
  .blog-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .nl-inline { grid-column: span 2; }
}
@media (max-width: 768px) {
  .une-card { grid-template-columns: 1fr; }
  .une-photo { min-height: 240px; }
  .une-content { padding: 24px 20px; }
  .sidebar { grid-template-columns: 1fr; }
  .nl-inline { grid-column: span 1; }
}
